package telegram import ( "fmt" "github.com/pkg/errors" "path/filepath" "strconv" "dev.narayana.im/narayana/telegabber/config" "dev.narayana.im/narayana/telegabber/persistence" "github.com/zelenin/go-tdlib/client" ) var logConstants = map[string]int32{ ":fatal": 0, ":error": 1, ":warn": 2, ":info": 3, ":debug": 4, ":verbose": 5, ":all": 1023, } func stringToLogConstant(c string) int32 { level, ok := logConstants[c] if !ok { level = 0 } return level } // Client stores the metadata for lazily invoked TDlib instance type Client struct { client *client.Client jid string parameters *client.TdlibParameters Session *persistence.Session online bool logVerbosity client.Option } // NewClient instantiates a Telegram App func NewClient(conf config.TelegramConfig, jid string, session *persistence.Session) (Client, error) { logVerbosity := client.WithLogVerbosity(&client.SetLogVerbosityLevelRequest{ NewVerbosityLevel: stringToLogConstant(conf.Loglevel), }) apiID, err := strconv.Atoi(conf.Tdlib.Client.APIID) if err != nil { return Client{}, errors.Wrap(err, "Wrong api_id") } parameters := client.TdlibParameters{ UseTestDc: false, DatabaseDirectory: filepath.Join("./sessions/", jid), FilesDirectory: filepath.Join("./sessions/", jid, "/files/"), UseFileDatabase: true, UseChatInfoDatabase: conf.Tdlib.Client.UseChatInfoDatabase, UseMessageDatabase: true, UseSecretChats: conf.Tdlib.Client.UseSecretChats, ApiId: int32(apiID), ApiHash: conf.Tdlib.Client.APIHash, SystemLanguageCode: "en", DeviceModel: conf.Tdlib.Client.DeviceModel, SystemVersion: "1.0.0", ApplicationVersion: conf.Tdlib.Client.ApplicationVersion, EnableStorageOptimizer: true, IgnoreFileNames: false, } return Client{ parameters: ¶meters, jid: jid, Session: session, logVerbosity: logVerbosity, }, nil } func updateHandler(tdlibClient *client.Client) { listener := tdlibClient.GetListener() defer listener.Close() for update := range listener.Updates { if update.GetClass() == client.ClassUpdate { fmt.Printf("%#v", update) } } }