Files
mautrix-telegram/pkg/gotd/mtproto/handle_session_created.go
T
2025-06-27 20:03:37 -07:00

41 lines
1.0 KiB
Go

package mtproto
import (
"github.com/go-faster/errors"
"go.uber.org/zap"
"go.mau.fi/mautrix-telegram/pkg/gotd/bin"
"go.mau.fi/mautrix-telegram/pkg/gotd/mt"
"go.mau.fi/mautrix-telegram/pkg/gotd/proto"
)
func (c *Conn) handleSessionCreated(b *bin.Buffer) error {
var s mt.NewSessionCreated
if err := s.Decode(b); err != nil {
return errors.Wrap(err, "decode")
}
c.gotSession.Signal()
created := proto.MessageID(s.FirstMsgID).Time()
now := c.clock.Now()
c.log.Debug("Session created",
zap.Int64("unique_id", s.UniqueID),
zap.Int64("first_msg_id", s.FirstMsgID),
zap.Time("first_msg_time", created.Local()),
)
if (created.Before(now) && now.Sub(created) > maxPast) || created.Sub(now) > maxFuture {
c.log.Warn("Local clock needs synchronization",
zap.Time("first_msg_time", created),
zap.Time("local", now),
zap.Duration("time_difference", now.Sub(created)),
)
}
c.storeSalt(s.ServerSalt)
if err := c.handler.OnSession(c.session()); err != nil {
return errors.Wrap(err, "handler.OnSession")
}
return nil
}