Documentation ¶
Overview ¶
Package bbolt contains gotd storage implementations using etcd bbolt.
Index ¶
- type Credentials
- type PeerStorage
- func (s PeerStorage) Add(ctx context.Context, value storage.Peer) error
- func (s PeerStorage) Assign(ctx context.Context, key string, value storage.Peer) error
- func (s PeerStorage) Find(ctx context.Context, key storage.PeerKey) (p storage.Peer, rerr error)
- func (s PeerStorage) Iterate(ctx context.Context) (storage.PeerIterator, error)
- func (s PeerStorage) Resolve(ctx context.Context, key string) (p storage.Peer, rerr error)
- type SessionStorage
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Credentials ¶
type Credentials struct {
kv.Credentials
}
Credentials stores user credentials to bbolt.
Example ¶
package main import ( "context" "fmt" "os" "os/signal" bboltdb "go.etcd.io/bbolt" "golang.org/x/xerrors" "github.com/gotd/td/telegram" tgauth "github.com/gotd/td/telegram/auth" "github.com/gotd/contrib/auth" "github.com/gotd/contrib/auth/terminal" "github.com/gotd/contrib/bbolt" ) func bboltAuth(ctx context.Context) error { db, err := bboltdb.Open("bbolt.db", 0666, &bboltdb.Options{}) // nolint:gocritic if err != nil { return xerrors.Errorf("create bbolt storage: %w", err) } cred := bbolt.NewCredentials(db, []byte("bucket")). WithPhoneKey("phone"). WithPasswordKey("password") client, err := telegram.ClientFromEnvironment(telegram.Options{}) if err != nil { return xerrors.Errorf("create client: %w", err) } return client.Run(ctx, func(ctx context.Context) error { return client.Auth().IfNecessary( ctx, tgauth.NewFlow(auth.Build(cred, terminal.OS()), tgauth.SendCodeOptions{}), ) }) } func main() { ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt) defer cancel() if err := bboltAuth(ctx); err != nil { _, _ = fmt.Fprintf(os.Stderr, "%+v\n", err) os.Exit(1) } }
Output:
func NewCredentials ¶
func NewCredentials(db *bbolt.DB, bucket []byte) Credentials
NewCredentials creates new Credentials.
type PeerStorage ¶
type PeerStorage struct {
// contains filtered or unexported fields
}
PeerStorage is a peer storage based on pebble.
func NewPeerStorage ¶
func NewPeerStorage(db *bbolt.DB, bucket []byte) *PeerStorage
NewPeerStorage creates new peer storage using bbolt.
func (PeerStorage) Assign ¶
Assign adds given peer to the storage and associate it to the given key.
func (PeerStorage) Iterate ¶
func (s PeerStorage) Iterate(ctx context.Context) (storage.PeerIterator, error)
Iterate creates and returns new PeerIterator.
type SessionStorage ¶
SessionStorage is a MTProto session bbolt storage.
Example ¶
package main import ( "context" "fmt" "os" "os/signal" bboltdb "go.etcd.io/bbolt" "golang.org/x/xerrors" "github.com/gotd/td/telegram" "github.com/gotd/contrib/bbolt" ) func bboltStorage(ctx context.Context) error { db, err := bboltdb.Open("bbolt.db", 0666, &bboltdb.Options{}) // nolint:gocritic if err != nil { return xerrors.Errorf("create bbolt storage: %w", err) } storage := bbolt.NewSessionStorage(db, "session", []byte("bucket")) client, err := telegram.ClientFromEnvironment(telegram.Options{ SessionStorage: storage, }) if err != nil { return xerrors.Errorf("create client: %w", err) } return client.Run(ctx, func(ctx context.Context) error { _, err := client.Auth().Bot(ctx, os.Getenv("BOT_TOKEN")) return err }) } func main() { ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt) defer cancel() if err := bboltStorage(ctx); err != nil { _, _ = fmt.Fprintf(os.Stderr, "%+v\n", err) os.Exit(1) } }
Output:
func NewSessionStorage ¶
func NewSessionStorage(db *bbolt.DB, key string, bucket []byte) SessionStorage
NewSessionStorage creates new SessionStorage.
Click to show internal directories.
Click to hide internal directories.