-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathmain.go
68 lines (56 loc) · 1.14 KB
/
main.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
// metrics example illustrates how to implement and plug a metrics interface
// to Baker.
package main
import (
"log"
"strings"
"github.com/AdRoll/baker"
"github.com/AdRoll/baker/input"
"github.com/AdRoll/baker/output"
)
// Some example fields
const (
Timestamp baker.FieldIndex = 0
Source baker.FieldIndex = 1
Target baker.FieldIndex = 2
)
var fields = map[string]baker.FieldIndex{
"timestamp": Timestamp,
"source": Source,
"target": Target,
}
func fieldByName(key string) (baker.FieldIndex, bool) {
idx, ok := fields[key]
return idx, ok
}
func main() {
toml := `
[metrics]
name="Foobar"
[metrics.config]
host="metrics.foobar.com"
port=8080
[input]
name = "List"
[input.config]
files=["testdata/input.csv.zst"]
[output]
name = "FileWriter"
procs=1
[output.config]
PathString="./_out/output.csv.gz"
`
c := baker.Components{
Inputs: input.All,
Outputs: output.All,
FieldByName: fieldByName,
Metrics: []baker.MetricsDesc{fooBarDesc},
}
cfg, err := baker.NewConfigFromToml(strings.NewReader(toml), c)
if err != nil {
log.Fatal(err)
}
if err := baker.Main(cfg); err != nil {
log.Fatal(err)
}
}