justlog/main.go

120 lines
2.7 KiB
Go
Raw Normal View History

2017-03-04 12:35:53 +01:00
package main
import (
2018-11-29 22:20:57 +01:00
"encoding/json"
"flag"
2017-03-04 12:35:53 +01:00
"os"
"time"
2017-03-04 12:35:53 +01:00
2017-09-11 19:51:29 +02:00
"strings"
2018-12-01 17:46:24 +01:00
"github.com/gempir/justlog/api"
2018-12-06 22:58:42 +01:00
"github.com/gempir/justlog/archiver"
"github.com/gempir/justlog/bot"
2018-12-01 17:46:24 +01:00
"github.com/gempir/justlog/filelog"
2018-12-02 19:23:54 +01:00
"github.com/gempir/justlog/helix"
2017-11-19 11:50:18 +01:00
2018-11-29 22:20:57 +01:00
log "github.com/sirupsen/logrus"
2017-03-04 12:35:53 +01:00
)
2018-11-29 22:20:57 +01:00
type config struct {
LogsDirectory string `json:"logsDirectory"`
2018-12-02 14:53:01 +01:00
Username string `json:"username"`
OAuth string `json:"oauth"`
ListenAddress string `json:"listenAddress"`
2018-11-29 22:20:57 +01:00
Admin string `json:"admin"`
Channels []string `json:"channels"`
2018-12-02 19:23:54 +01:00
ClientID string `json:"clientID"`
LogLevel string `json:"logLevel"`
2018-11-29 22:20:57 +01:00
}
// @title justlog API
// @version 1.0
// @description API for twitch logs
// @contact.name gempir
// @contact.url https://gempir.com
// @contact.email gempir.dev@gmail.com
// @license.name MIT
// @license.url https://github.com/gempir/justlog/blob/master/LICENSE
// @host api.gempir.com
// @BasePath /
2017-03-04 12:35:53 +01:00
func main() {
2017-03-08 20:42:35 +01:00
startTime := time.Now()
2018-11-29 22:20:57 +01:00
configFile := flag.String("config", "config.json", "json config file")
flag.Parse()
2018-12-07 21:40:33 +01:00
cfg := loadConfiguration(*configFile)
2017-03-04 12:35:53 +01:00
2018-12-02 19:23:54 +01:00
setupLogger(cfg)
2018-11-29 22:20:57 +01:00
fileLogger := filelog.NewFileLogger(cfg.LogsDirectory)
2018-12-02 19:23:54 +01:00
helixClient := helix.NewClient(cfg.ClientID)
2018-12-06 22:58:42 +01:00
archiver := archiver.NewArchiver(cfg.LogsDirectory)
go archiver.Boot()
2018-12-02 14:53:01 +01:00
2018-12-02 19:23:54 +01:00
apiServer := api.NewServer(cfg.LogsDirectory, cfg.ListenAddress, &fileLogger, &helixClient)
2018-12-02 14:53:01 +01:00
go apiServer.Init()
bot := bot.NewBot(cfg.Admin, cfg.Username, cfg.OAuth, &startTime, &helixClient, &fileLogger)
bot.Connect(cfg.Channels)
2017-03-04 12:35:53 +01:00
}
2018-11-29 22:20:57 +01:00
func loadConfiguration(file string) config {
log.Info("Loading config from " + file)
2018-12-02 14:53:01 +01:00
// setup defaults
cfg := config{
LogsDirectory: "./logs",
ListenAddress: "127.0.0.1:8025",
Username: "justinfan777777",
OAuth: "oauth:777777777",
Channels: []string{},
Admin: "gempir",
2018-12-02 19:23:54 +01:00
LogLevel: "info",
2018-12-02 14:53:01 +01:00
}
2018-11-29 22:20:57 +01:00
configFile, err := os.Open(file)
if err != nil {
log.Fatal(err)
}
2018-12-02 14:53:01 +01:00
defer configFile.Close()
2018-11-29 22:20:57 +01:00
jsonParser := json.NewDecoder(configFile)
2018-12-02 14:53:01 +01:00
err = jsonParser.Decode(&cfg)
if err != nil {
log.Fatal(err)
}
2018-11-29 22:20:57 +01:00
2018-12-02 19:23:54 +01:00
// normalize
2018-11-29 22:20:57 +01:00
cfg.LogsDirectory = strings.TrimSuffix(cfg.LogsDirectory, "/")
2018-12-02 14:53:01 +01:00
cfg.OAuth = strings.TrimPrefix(cfg.OAuth, "oauth:")
2018-12-02 19:23:54 +01:00
cfg.LogLevel = strings.ToLower(cfg.LogLevel)
// ensure required
if cfg.ClientID == "" {
log.Fatal("No clientID specified")
}
2018-11-29 22:20:57 +01:00
return cfg
}
2018-12-07 21:40:33 +01:00
func setupLogger(cfg config) {
switch cfg.LogLevel {
case "fatal":
log.SetLevel(log.FatalLevel)
case "panic":
log.SetLevel(log.PanicLevel)
case "error":
log.SetLevel(log.ErrorLevel)
case "warn":
log.SetLevel(log.WarnLevel)
case "info":
log.SetLevel(log.InfoLevel)
case "debug":
log.SetLevel(log.DebugLevel)
}
}