-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcodec.go
More file actions
126 lines (118 loc) · 2.32 KB
/
Copy pathcodec.go
File metadata and controls
126 lines (118 loc) · 2.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
package main
import (
"bytes"
"encoding/binary"
"fmt"
"io"
"log"
"proxy/encrypt"
"strings"
)
var buffSize = 1024
func EncryptPack(data []byte) []byte {
transformed := encrypt.AesEncryptData(data)
dataLen := uint16(len(transformed))
if dataLen > 0 {
var pkg = new(bytes.Buffer)
err := binary.Write(pkg, binary.BigEndian, dataLen)
errPrint(err)
err = binary.Write(pkg, binary.BigEndian, transformed)
errPrint(err)
return pkg.Bytes()
}
return make([]byte, 0)
}
func transformIoEncrypt(dst io.Writer, src io.Reader) {
for {
buf := make([]byte, buffSize-encrypt.BlockSize)
n, err := src.Read(buf)
if checkNetError(err) {
break
}
if n == 0 {
continue
}
pack := EncryptPack(buf[:n])
if len(pack) > 0 {
_, ew := dst.Write(pack)
if checkNetError(ew) {
break
}
}
}
}
func DecryptUnpackOne(src io.Reader) ([]byte, error) {
cnt := 0
head := make([]byte, 2)
var data []byte
var packLen int
for {
//read length head
if cnt < 2 {
tmp := make([]byte, 2-cnt)
n, err := src.Read(tmp)
if checkNetError(err) {
return make([]byte, 0), err
}
for i := 0; i < n; i++ {
head[cnt+i] = tmp[i]
}
cnt += n
if cnt < 2 {
continue
}
}
var dataLen uint16
err := binary.Read(bytes.NewBuffer(head), binary.BigEndian, &dataLen)
if checkNetError(err) || dataLen == 0 {
return make([]byte, 0), err
}
packLen = int(dataLen) + 2
tmp := make([]byte, packLen-cnt)
n, err := src.Read(tmp)
if checkNetError(err) {
return make([]byte, 0), err
}
cnt += n
data = append(data, tmp[:n]...)
if cnt < packLen {
continue
}
transformed, err := encrypt.AesDecryptData(data)
errPrint(err)
return transformed, err
}
}
func transformIoDecrypt(dst io.Writer, src io.Reader) {
for {
onePack, err := DecryptUnpackOne(src)
if len(onePack) > 0 {
_, ew := dst.Write(onePack)
if checkNetError(ew) {
break
}
}
if err != nil {
break
}
}
}
var ignoreNetErrors = []string{
"EOF",
"use of closed network connection",
"connection reset by peer",
"broken pipe",
//"operation timed out",
}
func checkNetError(err error) bool {
if err != nil {
message := err.Error()
for _, ignore := range ignoreNetErrors {
if strings.Contains(message, ignore) {
return err != nil
}
}
_ = log.Output(2, fmt.Sprintln(err))
}
return err != nil
}