forked from dmachard/DNS-collector
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtzsp_darwin.go
78 lines (63 loc) · 1.64 KB
/
tzsp_darwin.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
//go:build darwin
// +build darwin
package collectors
import (
"github.com/dmachard/go-dnscollector/dnsutils"
"github.com/dmachard/go-logger"
)
type TzspSniffer struct {
done chan bool
exit chan bool
loggers []dnsutils.Worker
config *dnsutils.Config
logger *logger.Logger
name string
}
// workaround for macos, not yet supported
func NewTzsp(loggers []dnsutils.Worker, config *dnsutils.Config, logger *logger.Logger, name string) *AfpacketSniffer {
logger.Info("[%s] tzsp collector - enabled", name)
s := &AfpacketSniffer{
done: make(chan bool),
exit: make(chan bool),
config: config,
loggers: loggers,
logger: logger,
name: name,
}
s.ReadConfig()
return s
}
func (c *TzspSniffer) GetName() string { return c.name }
func (c *TzspSniffer) SetLoggers(loggers []dnsutils.Worker) {
c.loggers = loggers
}
func (c *TzspSniffer) LogInfo(msg string, v ...interface{}) {
c.logger.Info("["+c.name+"] tzsp collector - "+msg, v...)
}
func (c *TzspSniffer) LogError(msg string, v ...interface{}) {
c.logger.Error("["+c.name+"] tzsp collector - "+msg, v...)
}
func (c *TzspSniffer) Loggers() []chan dnsutils.DnsMessage {
channels := []chan dnsutils.DnsMessage{}
for _, p := range c.loggers {
channels = append(channels, p.Channel())
}
return channels
}
func (c *TzspSniffer) ReadConfig() {
}
func (c *TzspSniffer) Channel() chan dnsutils.DnsMessage {
return nil
}
func (c *TzspSniffer) Stop() {
c.LogInfo("stopping...")
// exit to close properly
c.exit <- true
// read done channel and block until run is terminated
<-c.done
close(c.done)
}
func (c *TzspSniffer) Run() {
c.LogInfo("run terminated")
c.done <- true
}