package mtproto
import (
"github.com/go-faster/errors"
"go.uber.org/zap"
"github.com/gotd/td/bin"
"github.com/gotd/td/internal/mt"
"github.com/gotd/td/internal/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
}
The pages are generated with Golds v0.6.7 . (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu .
PR and bug reports are welcome and can be submitted to the issue list .
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds .