7a04f298d2
- update to latest telegram layer - remove some references to fields in tg.Entities that don't exist in the schema - originally added here: https://github.com/beeper/td/commit/820929062a2ba0104397bc01235ab58a9cff780e - referenced here - https://github.com/mautrix/telegramgo/commit/124f0967ed195b5a380c9bd02e170ada9710dde3 - https://github.com/mautrix/telegramgo/commit/4205047aab2e0639217148b5d125bfaab668bd8e
50 lines
1.1 KiB
Go
50 lines
1.1 KiB
Go
package message_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"os/signal"
|
|
|
|
"go.mau.fi/mautrix-telegram/pkg/gotd/telegram"
|
|
"go.mau.fi/mautrix-telegram/pkg/gotd/telegram/message"
|
|
"go.mau.fi/mautrix-telegram/pkg/gotd/telegram/message/peer"
|
|
"go.mau.fi/mautrix-telegram/pkg/gotd/tg"
|
|
)
|
|
|
|
func resolve(ctx context.Context) error {
|
|
client, err := telegram.ClientFromEnvironment(telegram.Options{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return client.Run(ctx, func(ctx context.Context) error {
|
|
sender := message.NewSender(tg.NewClient(client))
|
|
|
|
// Resolve and return input peer for @misato.
|
|
_, err := sender.Resolve("misato").AsInputPeer(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// Resolve and join channel @seele.
|
|
// If @seele is a user, not channel, error would be returned.
|
|
_, err = sender.Resolve("seele", peer.OnlyChannel).Join(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
})
|
|
}
|
|
|
|
func ExampleSender_Resolve() {
|
|
ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt)
|
|
defer cancel()
|
|
|
|
if err := resolve(ctx); err != nil {
|
|
_, _ = fmt.Fprintf(os.Stderr, "%+v\n", err)
|
|
os.Exit(2)
|
|
}
|
|
}
|