|
@@ -3,6 +3,8 @@ package crypto
|
|
|
import (
|
|
import (
|
|
|
"crypto/cipher"
|
|
"crypto/cipher"
|
|
|
"io"
|
|
"io"
|
|
|
|
|
+
|
|
|
|
|
+ "v2ray.com/core/common/buf"
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
type CryptionReader struct {
|
|
type CryptionReader struct {
|
|
@@ -17,10 +19,10 @@ func NewCryptionReader(stream cipher.Stream, reader io.Reader) *CryptionReader {
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (v *CryptionReader) Read(data []byte) (int, error) {
|
|
|
|
|
- nBytes, err := v.reader.Read(data)
|
|
|
|
|
|
|
+func (r *CryptionReader) Read(data []byte) (int, error) {
|
|
|
|
|
+ nBytes, err := r.reader.Read(data)
|
|
|
if nBytes > 0 {
|
|
if nBytes > 0 {
|
|
|
- v.stream.XORKeyStream(data[:nBytes], data[:nBytes])
|
|
|
|
|
|
|
+ r.stream.XORKeyStream(data[:nBytes], data[:nBytes])
|
|
|
}
|
|
}
|
|
|
return nBytes, err
|
|
return nBytes, err
|
|
|
}
|
|
}
|
|
@@ -39,7 +41,16 @@ func NewCryptionWriter(stream cipher.Stream, writer io.Writer) *CryptionWriter {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// Write implements io.Writer.Write().
|
|
// Write implements io.Writer.Write().
|
|
|
-func (v *CryptionWriter) Write(data []byte) (int, error) {
|
|
|
|
|
- v.stream.XORKeyStream(data, data)
|
|
|
|
|
- return v.writer.Write(data)
|
|
|
|
|
|
|
+func (w *CryptionWriter) Write(data []byte) (int, error) {
|
|
|
|
|
+ w.stream.XORKeyStream(data, data)
|
|
|
|
|
+ return w.writer.Write(data)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func (w *CryptionWriter) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
|
|
|
|
+ bs := mb.ToNetBuffers()
|
|
|
|
|
+ for _, b := range bs {
|
|
|
|
|
+ w.stream.XORKeyStream(b, b)
|
|
|
|
|
+ }
|
|
|
|
|
+ nBytes, err := bs.WriteTo(w.writer)
|
|
|
|
|
+ return int(nBytes), err
|
|
|
}
|
|
}
|