-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
68 lines (57 loc) · 1.5 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
package ddnsclient
import (
"errors"
"os"
"os/signal"
"syscall"
"time"
"github.com/datahearth/ddnsclient/pkg/utils"
"github.com/datahearth/ddnsclient/pkg/watcher"
"github.com/sirupsen/logrus"
)
// Start create a new instance of ddns-client
func Start(logger logrus.FieldLogger, config utils.ClientConfig) error {
log := logger.WithFields(logrus.Fields{
"pkg": "ddnsclient",
"component": "root",
})
ws := make([]watcher.Watcher, 0, len(config.Watchers))
for _, cw := range config.Watchers {
w, err := watcher.NewWatcher(logger, &cw, config.WebIP)
if err != nil {
logger.Warnf("Provider error: %v. Skipping...\n", err.Error())
continue
}
ws = append(ws, w)
}
if len(ws) == 0 {
return errors.New("no valid watchers were created. Checkout [watchers] configuration and its [providers] configuration")
}
sigc := make(chan os.Signal, 1)
signal.Notify(sigc, syscall.SIGINT, syscall.SIGTERM, syscall.SIGQUIT)
defer close(sigc)
chClose := make(chan struct{})
chErr := make(chan error)
defer close(chClose)
defer close(chErr)
logger.Infoln("Start watching periodically for changes!")
for _, w := range ws {
tickTime := config.UpdateTime
if tickTime == 0 {
tickTime = 180
}
t := time.NewTicker(time.Duration(tickTime) * time.Second)
go w.Run(t, chClose, chErr)
}
for {
select {
case err := <-chErr:
log.Errorln(err.Error())
continue
case <-sigc:
log.Infoln("Interrupt signal received. Stopping watcher...")
chClose <- struct{}{}
return nil
}
}
}