| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 | 
							- package crypto
 
- import (
 
- 	"crypto/cipher"
 
- 	"io"
 
- 	"v2ray.com/core/common"
 
- )
 
- type CryptionReader struct {
 
- 	stream cipher.Stream
 
- 	reader io.Reader
 
- }
 
- func NewCryptionReader(stream cipher.Stream, reader io.Reader) *CryptionReader {
 
- 	return &CryptionReader{
 
- 		stream: stream,
 
- 		reader: reader,
 
- 	}
 
- }
 
- func (v *CryptionReader) Read(data []byte) (int, error) {
 
- 	nBytes, err := v.reader.Read(data)
 
- 	if nBytes > 0 {
 
- 		v.stream.XORKeyStream(data[:nBytes], data[:nBytes])
 
- 	}
 
- 	return nBytes, err
 
- }
 
- func (v *CryptionReader) Release() {
 
- 	common.Release(v.reader)
 
- 	common.Release(v.stream)
 
- }
 
- type CryptionWriter struct {
 
- 	stream cipher.Stream
 
- 	writer io.Writer
 
- }
 
- // NewCryptionWriter creates a new CryptionWriter.
 
- func NewCryptionWriter(stream cipher.Stream, writer io.Writer) *CryptionWriter {
 
- 	return &CryptionWriter{
 
- 		stream: stream,
 
- 		writer: writer,
 
- 	}
 
- }
 
- // Write implements io.Writer.Write().
 
- func (v *CryptionWriter) Write(data []byte) (int, error) {
 
- 	v.stream.XORKeyStream(data, data)
 
- 	return v.writer.Write(data)
 
- }
 
- // Release implements common.Releasable.Release().
 
- func (v *CryptionWriter) Release() {
 
- 	common.Release(v.writer)
 
- 	common.Release(v.stream)
 
- }
 
 
  |