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.

nonce_response.go 1022B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. package rpc
  2. import (
  3. "bytes"
  4. "github.com/juju/errors"
  5. )
  6. type NonceResponse struct {
  7. NonceRequest
  8. Type []byte
  9. Crypto []byte
  10. }
  11. func (r *NonceResponse) Bytes() []byte {
  12. buf := &bytes.Buffer{}
  13. buf.Write(r.Type)
  14. buf.Write(r.KeySelector)
  15. buf.Write(r.Crypto)
  16. buf.Write(r.CryptoTS)
  17. buf.Write(r.Nonce)
  18. return buf.Bytes()
  19. }
  20. func (r *NonceResponse) Valid(req *NonceRequest) error {
  21. if !bytes.Equal(r.Type, TagNonce) {
  22. return errors.New("Unexpected RPC type")
  23. }
  24. if !bytes.Equal(r.Crypto, NonceCryptoAES) {
  25. return errors.New("Unexpected crypto type")
  26. }
  27. if !bytes.Equal(r.KeySelector, req.KeySelector) {
  28. return errors.New("Unexpected key selector")
  29. }
  30. return nil
  31. }
  32. func NewNonceResponse(data []byte) (*NonceResponse, error) {
  33. if len(data) != 32 {
  34. return nil, errors.New("Unexpected message length")
  35. }
  36. return &NonceResponse{
  37. NonceRequest: NonceRequest{
  38. KeySelector: data[4:8],
  39. CryptoTS: data[12:16],
  40. Nonce: data[16:],
  41. },
  42. Type: data[:4],
  43. Crypto: data[8:12],
  44. }, nil
  45. }