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
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

client_handshake.go 766B

12345678910111213141516171819202122232425262728
  1. package obfuscated2
  2. import (
  3. "crypto/cipher"
  4. "crypto/subtle"
  5. "encoding/hex"
  6. "fmt"
  7. "io"
  8. )
  9. func ClientHandshake(secret []byte, reader io.Reader) (int, cipher.Stream, cipher.Stream, error) {
  10. handshake := clientHandhakeFrame{}
  11. if _, err := io.ReadFull(reader, handshake.data[:]); err != nil {
  12. return 0, nil, nil, fmt.Errorf("cannot read frame: %w", err)
  13. }
  14. decryptor := handshake.decryptor(secret)
  15. encryptor := handshake.encryptor(secret)
  16. decryptor.XORKeyStream(handshake.data[:], handshake.data[:])
  17. if val := handshake.connectionType(); subtle.ConstantTimeCompare(handshakeConnectionType, val) != 1 {
  18. return 0, nil, nil, fmt.Errorf("unsupported connection type: %s", hex.EncodeToString(val))
  19. }
  20. return handshake.dc(), encryptor, decryptor, nil
  21. }