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 символов.

blockcipher.go 1.8KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package wrappers
  2. import (
  3. "crypto/aes"
  4. "crypto/cipher"
  5. "net"
  6. "github.com/9seconds/mtg/utils"
  7. "github.com/juju/errors"
  8. )
  9. type WrapBlockCipher struct {
  10. BufferedReader
  11. conn WrapStreamReadWriteCloser
  12. encryptor cipher.BlockMode
  13. decryptor cipher.BlockMode
  14. }
  15. func (w *WrapBlockCipher) Read(p []byte) (int, error) {
  16. return w.BufferedRead(p, func() error {
  17. var buf []byte
  18. for len(buf) == 0 || len(buf)%aes.BlockSize != 0 {
  19. rv, err := utils.ReadCurrentData(w.conn)
  20. if err != nil {
  21. return errors.Annotate(err, "Cannot read from socket")
  22. }
  23. buf = append(buf, rv...)
  24. }
  25. w.decryptor.CryptBlocks(buf, buf)
  26. w.Buffer.Write(buf)
  27. return nil
  28. })
  29. }
  30. func (w *WrapBlockCipher) Write(p []byte) (int, error) {
  31. if len(p)%aes.BlockSize > 0 {
  32. return 0, errors.Errorf("Incorrect block size %d", len(p))
  33. }
  34. encrypted := make([]byte, len(p))
  35. w.encryptor.CryptBlocks(encrypted, p)
  36. return w.conn.Write(encrypted)
  37. }
  38. func (w *WrapBlockCipher) LogDebug(msg string, data ...interface{}) {
  39. w.conn.LogDebug(msg, data...)
  40. }
  41. func (w *WrapBlockCipher) LogInfo(msg string, data ...interface{}) {
  42. w.conn.LogInfo(msg, data...)
  43. }
  44. func (w *WrapBlockCipher) LogWarn(msg string, data ...interface{}) {
  45. w.conn.LogWarn(msg, data...)
  46. }
  47. func (w *WrapBlockCipher) LogError(msg string, data ...interface{}) {
  48. w.conn.LogError(msg, data...)
  49. }
  50. func (w *WrapBlockCipher) LocalAddr() *net.TCPAddr {
  51. return w.conn.LocalAddr()
  52. }
  53. func (w *WrapBlockCipher) RemoteAddr() *net.TCPAddr {
  54. return w.conn.RemoteAddr()
  55. }
  56. func (w *WrapBlockCipher) Close() error {
  57. return w.conn.Close()
  58. }
  59. func NewWrapBlockCipher(conn WrapStreamReadWriteCloser, encryptor, decryptor cipher.BlockMode) WrapStreamReadWriteCloser {
  60. return &WrapBlockCipher{
  61. BufferedReader: NewBufferedReader(),
  62. conn: conn,
  63. encryptor: encryptor,
  64. decryptor: decryptor,
  65. }
  66. }