1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-06 17:36:40 -05:00
v2fly/transport/internet/kcp/io.go

93 lines
1.7 KiB
Go
Raw Normal View History

2016-12-08 10:27:41 -05:00
package kcp
import (
"crypto/cipher"
"crypto/rand"
"io"
2018-04-02 16:12:51 -04:00
"v2ray.com/core/common"
"v2ray.com/core/common/buf"
2016-12-08 10:27:41 -05:00
"v2ray.com/core/transport/internet"
)
type PacketReader interface {
Read([]byte) []Segment
}
type PacketWriter interface {
Overhead() int
io.Writer
}
type KCPPacketReader struct {
Security cipher.AEAD
Header internet.PacketHeader
}
2017-04-13 16:17:58 -04:00
func (r *KCPPacketReader) Read(b []byte) []Segment {
if r.Header != nil {
b = b[r.Header.Size():]
2016-12-08 10:27:41 -05:00
}
2017-04-13 16:17:58 -04:00
if r.Security != nil {
nonceSize := r.Security.NonceSize()
overhead := r.Security.Overhead()
if len(b) <= nonceSize+overhead {
return nil
}
2017-04-13 16:17:58 -04:00
out, err := r.Security.Open(b[nonceSize:nonceSize], b[:nonceSize], b[nonceSize:], nil)
2016-12-08 10:27:41 -05:00
if err != nil {
return nil
}
b = out
}
var result []Segment
for len(b) > 0 {
seg, x := ReadSegment(b)
if seg == nil {
break
}
result = append(result, seg)
b = x
}
return result
}
type KCPPacketWriter struct {
Header internet.PacketHeader
Security cipher.AEAD
Writer io.Writer
}
2017-04-13 16:17:58 -04:00
func (w *KCPPacketWriter) Overhead() int {
2016-12-08 10:27:41 -05:00
overhead := 0
2017-04-13 16:17:58 -04:00
if w.Header != nil {
2018-04-02 14:00:50 -04:00
overhead += int(w.Header.Size())
2016-12-08 10:27:41 -05:00
}
2017-04-13 16:17:58 -04:00
if w.Security != nil {
overhead += w.Security.Overhead()
2016-12-08 10:27:41 -05:00
}
return overhead
}
2017-04-13 16:17:58 -04:00
func (w *KCPPacketWriter) Write(b []byte) (int, error) {
2018-11-15 15:32:27 -05:00
bb := buf.StackNew()
2018-04-02 16:12:51 -04:00
defer bb.Release()
2017-04-13 16:17:58 -04:00
if w.Header != nil {
2018-11-02 16:34:04 -04:00
w.Header.Serialize(bb.Extend(w.Header.Size()))
2016-12-08 10:27:41 -05:00
}
2017-04-13 16:17:58 -04:00
if w.Security != nil {
nonceSize := w.Security.NonceSize()
2018-11-02 16:34:04 -04:00
common.Must2(bb.ReadFullFrom(rand.Reader, int32(nonceSize)))
2018-04-02 16:12:51 -04:00
nonce := bb.BytesFrom(int32(-nonceSize))
2018-11-02 16:34:04 -04:00
encrypted := bb.Extend(int32(w.Security.Overhead() + len(b)))
w.Security.Seal(encrypted[:0], nonce, b, nil)
2016-12-08 10:27:41 -05:00
} else {
2018-04-19 16:56:55 -04:00
bb.Write(b)
2016-12-08 10:27:41 -05:00
}
2018-04-02 16:12:51 -04:00
_, err := w.Writer.Write(bb.Bytes())
2016-12-08 10:27:41 -05:00
return len(b), err
}