yanic/main.go

101 lines
2.4 KiB
Go
Raw Normal View History

2015-12-29 03:08:03 +00:00
package main
import (
2016-02-19 10:30:42 +00:00
"flag"
2015-12-29 03:08:03 +00:00
"log"
2016-02-25 21:06:15 +00:00
"net"
2016-02-19 10:13:30 +00:00
"net/http"
"os"
"os/signal"
"syscall"
"time"
2016-05-14 10:31:43 +00:00
"github.com/NYTimes/gziphandler"
2016-06-16 16:03:45 +00:00
"github.com/julienschmidt/httprouter"
2016-05-14 10:31:43 +00:00
2016-06-16 16:03:45 +00:00
"github.com/FreifunkBremen/respond-collector/api"
2016-10-03 17:55:37 +00:00
"github.com/FreifunkBremen/respond-collector/database"
2016-03-15 22:26:30 +00:00
"github.com/FreifunkBremen/respond-collector/models"
"github.com/FreifunkBremen/respond-collector/respond"
2016-10-03 17:56:02 +00:00
"github.com/FreifunkBremen/respond-collector/rrd"
2015-12-29 13:05:47 +00:00
)
2016-02-19 10:30:42 +00:00
var (
2016-06-16 16:03:45 +00:00
configFile string
config *models.Config
collector *respond.Collector
2016-10-03 17:55:37 +00:00
db *database.DB
2016-06-16 16:03:45 +00:00
nodes *models.Nodes
2016-02-19 10:30:42 +00:00
)
func main() {
2016-10-03 17:56:02 +00:00
var importPath string
flag.StringVar(&importPath, "import", "", "import global statistics from the given RRD file, requires influxdb")
2016-03-12 15:40:41 +00:00
flag.StringVar(&configFile, "config", "config.yml", "path of configuration file (default:config.yaml)")
2016-02-19 10:30:42 +00:00
flag.Parse()
2016-03-20 18:54:43 +00:00
config = models.ReadConfigFile(configFile)
2016-03-12 02:36:02 +00:00
if config.Influxdb.Enable {
2016-10-03 17:55:37 +00:00
db = database.New(config)
2016-10-03 17:56:02 +00:00
if importPath != "" {
importRRD(importPath)
os.Exit(0)
}
2016-03-12 02:36:02 +00:00
}
2016-10-03 17:55:37 +00:00
nodes = models.NewNodes(config)
2016-03-09 02:26:08 +00:00
if config.Respondd.Enable {
2016-03-12 02:58:36 +00:00
collectInterval := time.Second * time.Duration(config.Respondd.CollectInterval)
2016-10-03 17:55:37 +00:00
collector = respond.NewCollector(db, nodes, collectInterval, config.Respondd.Interface)
2016-03-07 08:52:52 +00:00
}
2016-03-07 08:52:52 +00:00
if config.Webserver.Enable {
2016-05-14 10:31:43 +00:00
router := httprouter.New()
2016-05-17 09:07:14 +00:00
if config.Webserver.Api.NewNodes {
2016-06-16 16:03:45 +00:00
api.NewNodes(config, router, "/api/nodes", nodes)
2016-05-17 08:59:34 +00:00
log.Println("api nodes started")
2016-05-14 10:31:43 +00:00
}
if config.Webserver.Api.Aliases {
2016-06-16 16:03:45 +00:00
api.NewAliases(config, router, "/api/aliases", nodes)
2016-05-17 08:59:34 +00:00
log.Println("api aliases started")
2016-05-14 10:31:43 +00:00
}
router.NotFound = gziphandler.GzipHandler(http.FileServer(http.Dir(config.Webserver.Webroot)))
2016-03-20 17:30:44 +00:00
address := net.JoinHostPort(config.Webserver.Address, config.Webserver.Port)
log.Println("starting webserver on", address)
// TODO bad
2016-05-14 10:31:43 +00:00
log.Fatal(http.ListenAndServe(address, router))
2016-03-07 08:52:52 +00:00
}
2016-03-12 02:58:36 +00:00
// Wait for INT/TERM
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
sig := <-sigs
log.Println("received", sig)
// Close everything at the end
2016-03-19 22:18:26 +00:00
if collector != nil {
collector.Close()
2016-03-07 09:28:24 +00:00
}
2016-10-03 17:55:37 +00:00
if db != nil {
db.Close()
2016-03-12 02:58:36 +00:00
}
}
2016-10-03 17:56:02 +00:00
func importRRD(path string) {
log.Println("importing RRD from", path)
for ds := range rrd.Read(path) {
db.AddPoint(
database.MeasurementGlobal,
nil,
map[string]interface{}{
"nodes": ds.Nodes,
"clients.total": ds.Clients,
},
ds.Time,
)
}
db.Close()
}