blob: 97bc87e1cec2c21c399796721a58143d1f1d9782 (
plain)
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
|
package main
import (
"encoding/json"
"errors"
"fmt"
"io/ioutil"
"log"
"os"
"time"
)
var (
clogger *log.Logger
)
func init() {
clogger = log.New(os.Stdout, "[ Main ]", log.LstdFlags)
}
type Config struct {
Limit int `json:limit`
Interval string `json:interval`
Epsilon float64 `json:epsilon`
Verbose bool `json:verbose`
DataSource string `json:dataSource`
DBConn string `json:DBConn`
DBName string `json:DBName`
RawTable string `json:rawTable`
CleanTable string `json:cleanTable`
DBUser string `json:DBUser`
DBPass string `json:DBPass`
}
func (cfg *Config) getInterval() (interval time.Duration, err error) {
switch cfg.Interval {
case "5min":
interval = time.Minute * 5
case "10min":
interval = time.Minute * 10
case "30min":
interval = time.Minute * 30
case "hour":
interval = time.Hour
case "day":
interval = time.Hour * 24
default:
err = errors.New(fmt.Sprintf("Invalid interval: %s", cfg.Interval))
}
return
}
func readConfig() (cfg *Config, err error) {
clogger.Println("Reading config...")
content, err := ioutil.ReadFile("config.json")
if err != nil {
log.Println(err)
}
err = json.Unmarshal(content, &cfg)
if err != nil {
log.Println(err)
}
clogger.Println("Done!")
return
}
|