1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-07-01 03:25:23 +00:00
v2fly/transport/internet/kcp/io.go

96 lines
1.9 KiB
Go
Raw Normal View History

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