Highly-opinionated (ex-bullshit-free) MTPROTO proxy for Telegram. If you use v1.0 or upgrade broke you proxy, please read the chapter Version 2
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

client_handshake.go 1.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. package obfuscated2
  2. import (
  3. "crypto/cipher"
  4. "crypto/subtle"
  5. "encoding/hex"
  6. "fmt"
  7. "io"
  8. )
  9. type clientHandhakeFrame struct {
  10. handshakeFrame
  11. }
  12. func (c *clientHandhakeFrame) decryptor(secret []byte) cipher.Stream {
  13. hasher := acquireSha256Hasher()
  14. defer releaseSha256Hasher(hasher)
  15. hasher.Write(c.key()) // nolint: errcheck
  16. hasher.Write(secret) // nolint: errcheck
  17. return makeAesCtr(hasher.Sum(nil), c.iv())
  18. }
  19. func (c *clientHandhakeFrame) encryptor(secret []byte) cipher.Stream {
  20. invertedHandshake := c.invert()
  21. hasher := acquireSha256Hasher()
  22. defer releaseSha256Hasher(hasher)
  23. hasher.Write(invertedHandshake.key()) // nolint: errcheck
  24. hasher.Write(secret) // nolint: errcheck
  25. return makeAesCtr(hasher.Sum(nil), invertedHandshake.iv())
  26. }
  27. func ClientHandshake(secret []byte, reader io.Reader) (int, cipher.Stream, cipher.Stream, error) {
  28. handshake := clientHandhakeFrame{}
  29. if _, err := io.ReadFull(reader, handshake.data[:]); err != nil {
  30. return 0, nil, nil, fmt.Errorf("cannot read frame: %w", err)
  31. }
  32. decryptor := handshake.decryptor(secret)
  33. encryptor := handshake.encryptor(secret)
  34. decryptor.XORKeyStream(handshake.data[:], handshake.data[:])
  35. if val := handshake.connectionType(); subtle.ConstantTimeCompare(handshakeConnectionType, val) != 1 {
  36. return 0, nil, nil, fmt.Errorf("unsupported connection type: %s", hex.EncodeToString(val))
  37. }
  38. return handshake.dc(), encryptor, decryptor, nil
  39. }