io.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package crypto
  2. import (
  3. "crypto/cipher"
  4. "io"
  5. "github.com/xtls/xray-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. var _ buf.Writer = (*CryptionWriter)(nil)
  25. type CryptionWriter struct {
  26. stream cipher.Stream
  27. writer io.Writer
  28. bufWriter buf.Writer
  29. }
  30. // NewCryptionWriter creates a new CryptionWriter.
  31. func NewCryptionWriter(stream cipher.Stream, writer io.Writer) *CryptionWriter {
  32. return &CryptionWriter{
  33. stream: stream,
  34. writer: writer,
  35. bufWriter: buf.NewWriter(writer),
  36. }
  37. }
  38. // Write implements io.Writer.Write().
  39. func (w *CryptionWriter) Write(data []byte) (int, error) {
  40. w.stream.XORKeyStream(data, data)
  41. if err := buf.WriteAllBytes(w.writer, data, nil); err != nil {
  42. return 0, err
  43. }
  44. return len(data), nil
  45. }
  46. // WriteMultiBuffer implements buf.Writer.
  47. func (w *CryptionWriter) WriteMultiBuffer(mb buf.MultiBuffer) error {
  48. for _, b := range mb {
  49. w.stream.XORKeyStream(b.Bytes(), b.Bytes())
  50. }
  51. return w.bufWriter.WriteMultiBuffer(mb)
  52. }