-
Notifications
You must be signed in to change notification settings - Fork 59
/
Copy pathtypes.go
118 lines (97 loc) · 1.88 KB
/
types.go
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
package netflow
import (
"encoding/json"
"fmt"
"sync"
)
const (
TCP_ESTABLISHED = iota + 1
TCP_SYN_SENT
TCP_SYN_RECV
TCP_FIN_WAIT1
TCP_FIN_WAIT2
TCP_TIME_WAIT
TCP_CLOSE
TCP_CLOSE_WAIT
TCP_LAST_ACK
TCP_LISTEN
TCP_CLOSING
//TCP_NEW_SYN_RECV
//TCP_MAX_STATES
)
var states = map[int]string{
TCP_ESTABLISHED: "ESTABLISHED",
TCP_SYN_SENT: "SYN_SENT",
TCP_SYN_RECV: "SYN_RECV",
TCP_FIN_WAIT1: "FIN_WAIT1",
TCP_FIN_WAIT2: "FIN_WAIT2",
TCP_TIME_WAIT: "TIME_WAIT",
TCP_CLOSE: "CLOSE",
TCP_CLOSE_WAIT: "CLOSE_WAIT",
TCP_LAST_ACK: "LAST_ACK",
TCP_LISTEN: "LISTEN",
TCP_CLOSING: "CLOSING",
//TCP_NEW_SYN_RECV: "NEW_SYN_RECV",
//TCP_MAX_STATES: "MAX_STATES",
}
// https://github.com/torvalds/linux/blob/master/include/net/tcp_states.h
var StateMapping = map[string]string{
"01": "ESTABLISHED",
"02": "SYN_SENT",
"03": "SYN_RECV",
"04": "FIN_WAIT1",
"05": "FIN_WAIT2",
"06": "TIME_WAIT",
"07": "CLOSE",
"08": "CLOSE_WAIT",
"09": "LAST_ACK",
"0A": "LISTEN",
"0B": "CLOSING",
}
type Mapping struct {
cb func()
dict map[string]string
sync.RWMutex
}
func NewMapping() *Mapping {
size := 1000
return &Mapping{
dict: make(map[string]string, size),
}
}
func (m *Mapping) Handle() {
}
func (m *Mapping) Add(k, v string) {
m.Lock()
defer m.Unlock()
m.dict[k] = v
}
func (m *Mapping) Get(k string) string {
m.RLock()
defer m.RUnlock()
return m.dict[k]
}
func (m *Mapping) Delete(k string) {
m.Lock()
defer m.Unlock()
delete(m.dict, k)
}
func (m *Mapping) String() string {
m.RLock()
defer m.RUnlock()
bs, _ := json.Marshal(m.dict)
return string(bs)
}
type Null struct{}
type LoggerInterface interface {
Debug(...interface{})
Error(...interface{})
}
var defaultLogger string
type logger struct{}
func (l *logger) Debug(msg ...interface{}) {
fmt.Println(msg...)
}
func (l *logger) Error(msg ...interface{}) {
fmt.Println(msg...)
}