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
Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

server_handshake.go 1.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package obfuscated2
  2. import (
  3. "crypto/cipher"
  4. "crypto/rand"
  5. "encoding/binary"
  6. "fmt"
  7. "io"
  8. )
  9. type serverHandshakeFrame struct {
  10. handshakeFrame
  11. }
  12. func (s *serverHandshakeFrame) decryptor() cipher.Stream {
  13. invertedHandshake := s.invert()
  14. return makeAesCtr(invertedHandshake.key(), invertedHandshake.iv())
  15. }
  16. func (s *serverHandshakeFrame) encryptor() cipher.Stream {
  17. return makeAesCtr(s.key(), s.iv())
  18. }
  19. func ServerHandshake(writer io.Writer) (cipher.Stream, cipher.Stream, error) {
  20. handshake := generateServerHanshakeFrame()
  21. copyHandshake := handshake
  22. encryptor := handshake.encryptor()
  23. decryptor := handshake.decryptor()
  24. encryptor.XORKeyStream(handshake.data[:], handshake.data[:])
  25. copy(handshake.key(), copyHandshake.key())
  26. copy(handshake.iv(), copyHandshake.iv())
  27. if _, err := writer.Write(handshake.data[:]); err != nil {
  28. return nil, nil, fmt.Errorf("cannot send a handshake frame to telegram: %w", err)
  29. }
  30. return encryptor, decryptor, nil
  31. }
  32. func generateServerHanshakeFrame() serverHandshakeFrame {
  33. frame := serverHandshakeFrame{}
  34. for {
  35. if _, err := rand.Read(frame.data[:]); err != nil {
  36. panic(err)
  37. }
  38. if frame.data[0] == 0xef { // taken from tg sources
  39. continue
  40. }
  41. switch binary.LittleEndian.Uint32(frame.data[:4]) {
  42. case 0x44414548, 0x54534f50, 0x20544547, 0x4954504f, 0xeeeeeeee: // taken from tg sources
  43. continue
  44. }
  45. if frame.data[4]|frame.data[5]|frame.data[6]|frame.data[7] == 0 {
  46. continue
  47. }
  48. copy(frame.connectionType(), handshakeConnectionType)
  49. return frame
  50. }
  51. }