move gotd fork into repo. (#111)

- 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
This commit is contained in:
Adam Van Ymeren
2025-06-27 20:03:37 -07:00
committed by GitHub
parent 0952df0244
commit 7a04f298d2
19264 changed files with 1539697 additions and 84 deletions
+70
View File
@@ -0,0 +1,70 @@
package cluster
import (
"crypto/rsa"
"go.uber.org/zap"
"go.mau.fi/mautrix-telegram/pkg/gotd/crypto"
"go.mau.fi/mautrix-telegram/pkg/gotd/exchange"
"go.mau.fi/mautrix-telegram/pkg/gotd/tgtest"
"go.mau.fi/mautrix-telegram/pkg/gotd/tgtest/services"
"go.mau.fi/mautrix-telegram/pkg/gotd/transport"
)
// Common returns common dispatcher.
func (c *Cluster) Common() *tgtest.Dispatcher {
return c.common
}
func (c *Cluster) getCodec() (codec func() transport.Codec) {
if !c.web {
codec = c.protocol.Codec
}
return codec
}
// DC registers new server and returns it.
func (c *Cluster) DC(id int, name string) (*tgtest.Server, *tgtest.Dispatcher) {
if s, ok := c.setups[id]; ok {
return s.srv, s.dispatch
}
key, err := rsa.GenerateKey(c.random, crypto.RSAKeyBits)
if err != nil {
// TODO(tdakkota): Return error instead.
panic(err)
}
privateKey := exchange.PrivateKey{
RSA: key,
}
d := tgtest.NewDispatcher()
server := tgtest.NewServer(privateKey, tgtest.UnpackInvoke(d), tgtest.ServerOptions{
DC: id,
Logger: c.log.Named(name).With(zap.Int("dc_id", id)),
Codec: c.getCodec(),
})
c.setups[id] = setup{
srv: server,
dispatch: d,
}
c.keys = append(c.keys, server.Key())
// We set server fallback handler to dispatch request in order
// 1) Explicit DC handler
// 2) Explicit common handler
// 3) Common fallback
d.Fallback(c.Common())
return server, d
}
// Dispatch registers new server and returns its dispatcher.
func (c *Cluster) Dispatch(id int, name string) *tgtest.Dispatcher {
_, d := c.DC(id, name)
return d
}
func (c *Cluster) fallback() tgtest.HandlerFunc {
return services.NotImplemented
}