teldrive/internal/tgc/run.go

44 lines
1 KiB
Go
Raw Normal View History

2023-09-20 03:20:44 +08:00
package tgc
import (
"context"
"github.com/divyam234/teldrive/internal/logging"
2023-09-20 03:20:44 +08:00
"github.com/gotd/td/telegram"
"github.com/pkg/errors"
"go.uber.org/zap"
)
func RunWithAuth(ctx context.Context, client *telegram.Client, token string, f func(ctx context.Context) error) error {
2023-09-20 03:20:44 +08:00
return client.Run(ctx, func(ctx context.Context) error {
status, err := client.Auth().Status(ctx)
logger := logging.FromContext(ctx)
2023-09-20 03:20:44 +08:00
if err != nil {
return err
}
if token == "" {
if !status.Authorized {
return errors.Errorf("not authorized. please login first")
}
logger.Debugw("User Session",
2023-09-20 03:20:44 +08:00
zap.Int64("id", status.User.ID),
zap.String("username", status.User.Username))
} else {
if !status.Authorized {
logger.Debugw("creating bot session")
2023-09-20 03:20:44 +08:00
_, err := client.Auth().Bot(ctx, token)
if err != nil {
return err
}
status, _ = client.Auth().Status(ctx)
logger.Debugw("Bot Session",
2023-09-20 03:20:44 +08:00
zap.Int64("id", status.User.ID),
zap.String("username", status.User.Username))
}
}
return f(ctx)
})
}