io.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package crypto
  2. import (
  3. "crypto/cipher"
  4. "io"
  5. "v2ray.com/core/common"
  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 (v *CryptionReader) Read(data []byte) (int, error) {
  18. nBytes, err := v.reader.Read(data)
  19. if nBytes > 0 {
  20. v.stream.XORKeyStream(data[:nBytes], data[:nBytes])
  21. }
  22. return nBytes, err
  23. }
  24. func (v *CryptionReader) Release() {
  25. common.Release(v.reader)
  26. common.Release(v.stream)
  27. }
  28. type CryptionWriter struct {
  29. stream cipher.Stream
  30. writer io.Writer
  31. }
  32. // NewCryptionWriter creates a new CryptionWriter.
  33. func NewCryptionWriter(stream cipher.Stream, writer io.Writer) *CryptionWriter {
  34. return &CryptionWriter{
  35. stream: stream,
  36. writer: writer,
  37. }
  38. }
  39. // Write implements io.Writer.Write().
  40. func (v *CryptionWriter) Write(data []byte) (int, error) {
  41. v.stream.XORKeyStream(data, data)
  42. return v.writer.Write(data)
  43. }
  44. // Release implements common.Releasable.Release().
  45. func (v *CryptionWriter) Release() {
  46. common.Release(v.writer)
  47. common.Release(v.stream)
  48. }