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
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

logrwc.go 984B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. package proxy
  2. import (
  3. "io"
  4. "go.uber.org/zap"
  5. )
  6. type LogReadWriteCloser struct {
  7. conn io.ReadWriteCloser
  8. logger *zap.SugaredLogger
  9. sockid string
  10. name string
  11. }
  12. func (l *LogReadWriteCloser) Read(p []byte) (n int, err error) {
  13. n, err = l.conn.Read(p)
  14. l.logger.Debugw("Finish reading", "name", l.name, "socketid", l.sockid, "nbytes", n, "error", err)
  15. return
  16. }
  17. func (l *LogReadWriteCloser) Write(p []byte) (n int, err error) {
  18. n, err = l.conn.Write(p)
  19. l.logger.Debugw("Finish writing", "name", l.name, "socketid", l.sockid, "nbytes", n, "error", err)
  20. return
  21. }
  22. func (l *LogReadWriteCloser) Close() error {
  23. err := l.conn.Close()
  24. l.logger.Debugw("Finish closing socket", "name", l.name, "socketid", l.sockid, "error", err)
  25. return err
  26. }
  27. func newLogReadWriteCloser(conn io.ReadWriteCloser, logger *zap.SugaredLogger, sockid string, name string) io.ReadWriteCloser {
  28. return &LogReadWriteCloser{
  29. conn: conn,
  30. logger: logger,
  31. sockid: sockid,
  32. name: name,
  33. }
  34. }