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 kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

client_handshake.go 1.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. package obfuscated2
  2. import (
  3. "crypto/cipher"
  4. "crypto/subtle"
  5. "encoding/hex"
  6. "fmt"
  7. "io"
  8. )
  9. // Connection Type secure. We support only fake tls.
  10. var clientHandshakeMagic = []byte{0xdd, 0xdd, 0xdd, 0xdd}
  11. func ClientHandshake(secret []byte, reader io.Reader) (int16, cipher.Stream, cipher.Stream, error) {
  12. handshakeFrame := acquireHandshakeFrame()
  13. defer releaseHandshakeFrame(handshakeFrame)
  14. if _, err := io.ReadFull(reader, handshakeFrame.data[:]); err != nil {
  15. return 0, nil, nil, fmt.Errorf("cannot read frame: %w", err)
  16. }
  17. decHasher := acquireSha256Hasher()
  18. defer releaseSha256Hasher(decHasher)
  19. decHasher.Write(handshakeFrame.key()) // nolint: errcheck
  20. decHasher.Write(secret) // nolint: errcheck
  21. decryptor := makeAesCtr(decHasher.Sum(nil), handshakeFrame.iv())
  22. encHasher := acquireSha256Hasher()
  23. defer releaseSha256Hasher(encHasher)
  24. invertedFrame := acquireHandshakeFrame()
  25. defer releaseHandshakeFrame(invertedFrame)
  26. for i, v := range handshakeFrame.data {
  27. invertedFrame.data[handshakeFrameLen-1-i] = v
  28. }
  29. encHasher.Write(invertedFrame.key()) // nolint: errcheck
  30. encHasher.Write(secret) // nolint: errcheck
  31. encryptor := makeAesCtr(encHasher.Sum(nil), invertedFrame.iv())
  32. decryptor.XORKeyStream(handshakeFrame.data[:], handshakeFrame.data[:])
  33. if magic := handshakeFrame.magic(); subtle.ConstantTimeCompare(clientHandshakeMagic, magic) != 1 {
  34. return 0, nil, nil, fmt.Errorf("unsupported connection type: %s", hex.EncodeToString(magic))
  35. }
  36. return handshakeFrame.dc(), encryptor, decryptor, nil
  37. }