-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathharverster.go
102 lines (77 loc) · 1.89 KB
/
harverster.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
package main
import (
"fmt"
"log"
"os"
"strings"
)
type Logs struct {
data *[]byte
batch int
file string
}
type HarvesterConfig struct {
ReadTime int
ReadDir string
}
type Harvester struct {
Dumper *Dumper
ReaderMap map[string]*Reader
Listener *Watcher
EventChan chan string
DumpChan chan *Logs
}
func NewHarvester(cfg HarvesterConfig, dumper *Dumper) (*Harvester, error) {
// Check the validity of the dir
files, err := os.ReadDir(cfg.ReadDir)
if err != nil {
return nil, fmt.Errorf("creating harvester: %s", err)
}
harvester := Harvester{}
harvester.EventChan = make(chan string)
harvester.DumpChan = make(chan *Logs)
harvester.ReaderMap = make(map[string]*Reader)
harvester.Dumper = dumper
for _, entry := range files {
if !entry.IsDir() {
// Look for the log files
parts := strings.Split(entry.Name(), ".")
if parts[len(parts)-1] == "log" || parts[len(parts)-1] == "logs" {
fullPath := cfg.ReadDir + entry.Name()
reader, err := NewReader(fullPath, cfg.ReadTime, harvester.DumpChan)
if err != nil {
log.Println("Error creating Reader for " + fullPath + ": " + err.Error())
}
harvester.ReaderMap[fullPath] = reader
}
}
}
harvester.Listener, err = NewWatcher(cfg.ReadDir, harvester.EventChan)
if err != nil {
return nil, fmt.Errorf("creating harvester: %s", err)
}
return &harvester, nil
}
func (h *Harvester) Start() {
// Run the Reader and Watcher
go h.Listener.Listen()
for _, reader := range h.ReaderMap {
go reader.Read()
}
for {
select {
case f := <-h.EventChan:
log.Println("Recieved Write Event for " + f)
reader, ok := h.ReaderMap[f]
if ok && !reader.Active {
reader.NotifyChan <- struct{}{}
}
case logs := <-h.DumpChan:
log.Println("Recieved Dump Event for " + logs.file)
err := h.Dumper.dumpLogs(logs)
if err != nil {
log.Printf("Error in dumping logs: %s", err)
}
}
}
}