io.go 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. package crypto
  2. import (
  3. "crypto/cipher"
  4. "io"
  5. "v2ray.com/core/common/buf"
  6. )
  7. type CryptionReader struct {
  8. stream cipher.Stream
  9. reader io.Reader
  10. }
  11. func NewCryptionReader(stream cipher.Stream, reader io.Reader) *CryptionReader {
  12. return &CryptionReader{
  13. stream: stream,
  14. reader: reader,
  15. }
  16. }
  17. func (r *CryptionReader) Read(data []byte) (int, error) {
  18. nBytes, err := r.reader.Read(data)
  19. if nBytes > 0 {
  20. r.stream.XORKeyStream(data[:nBytes], data[:nBytes])
  21. }
  22. return nBytes, err
  23. }
  24. type CryptionWriter struct {
  25. stream cipher.Stream
  26. writer io.Writer
  27. }
  28. // NewCryptionWriter creates a new CryptionWriter.
  29. func NewCryptionWriter(stream cipher.Stream, writer io.Writer) *CryptionWriter {
  30. return &CryptionWriter{
  31. stream: stream,
  32. writer: writer,
  33. }
  34. }
  35. // Write implements io.Writer.Write().
  36. func (w *CryptionWriter) Write(data []byte) (int, error) {
  37. w.stream.XORKeyStream(data, data)
  38. return w.writer.Write(data)
  39. }
  40. func (w *CryptionWriter) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
  41. bs := mb.ToNetBuffers()
  42. for _, b := range bs {
  43. w.stream.XORKeyStream(b, b)
  44. }
  45. nBytes, err := bs.WriteTo(w.writer)
  46. return int(nBytes), err
  47. }