This repository has been archived by the owner on Mar 5, 2020. It is now read-only.
forked from vmware-archive/blackbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
file_watcher.go
101 lines (81 loc) · 2.16 KB
/
file_watcher.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
package blackbox
import (
"io/ioutil"
"log"
"os"
"path/filepath"
"strings"
"time"
"github.com/concourse/blackbox/syslog"
"github.com/tedsuo/ifrit/grouper"
)
const POLL_INTERVAL = 5 * time.Second
type fileWatcher struct {
logger *log.Logger
sourceDir string
dynamicGroupClient grouper.DynamicClient
drainerFactory syslog.DrainerFactory
}
func NewFileWatcher(
logger *log.Logger,
sourceDir string,
dynamicGroupClient grouper.DynamicClient,
drainerFactory syslog.DrainerFactory,
) *fileWatcher {
return &fileWatcher{
logger: logger,
sourceDir: sourceDir,
dynamicGroupClient: dynamicGroupClient,
drainerFactory: drainerFactory,
}
}
func (f *fileWatcher) Watch() {
for {
logDirs, err := ioutil.ReadDir(f.sourceDir)
if err != nil {
f.logger.Fatalf("could not list directories in source dir: %s\n", err)
}
for _, logDir := range logDirs {
tag := logDir.Name()
tagDirPath := filepath.Join(f.sourceDir, tag)
fileInfo, err := os.Stat(tagDirPath)
if err != nil {
f.logger.Fatalf("failed to determine if path is directory: %s\n", err)
}
if !fileInfo.IsDir() {
continue
}
logFiles, err := ioutil.ReadDir(tagDirPath)
if err != nil {
f.logger.Fatalf("could not list files in log dir %s: %s\n", tag, err)
}
for _, logFile := range logFiles {
if !strings.HasSuffix(logFile.Name(), ".log") {
continue
}
logFileFullPath := filepath.Join(tagDirPath, logFile.Name())
if _, found := f.dynamicGroupClient.Get(logFileFullPath); !found {
f.dynamicGroupClient.Inserter() <- f.memberForFile(logFileFullPath)
}
}
}
time.Sleep(POLL_INTERVAL)
}
}
func (f *fileWatcher) memberForFile(logfilePath string) grouper.Member {
drainer, err := f.drainerFactory.NewDrainer()
if err != nil {
f.logger.Fatalf("could not drain to syslog: %s\n", err)
}
logfileDir := filepath.Dir(logfilePath)
tag, err := filepath.Rel(f.sourceDir, logfileDir)
if err != nil {
f.logger.Fatalf("could not compute tag from file path %s: %s\n", logfilePath, err)
}
tailer := &Tailer{
Path: logfilePath,
Tag: tag,
Drainer: drainer,
}
return grouper.Member{tailer.Path, tailer}
}