use json config and enable arguments

This commit is contained in:
gempir 2018-11-29 22:20:57 +01:00
parent c7e61f33a1
commit 48aeb14a85
15 changed files with 100 additions and 75 deletions

View file

@ -1,4 +0,0 @@
ADMIN=gempir
IRCUSER=gempbot
IRCTOKEN=oauth:123123123
CHANNELS=gempir,pajlada

View file

@ -1,11 +0,0 @@
FROM golang:latest
WORKDIR /go/src/github.com/gempir/gempbotgo
COPY . .
RUN go get ./...
RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o app .
FROM alpine:latest
RUN apk --no-cache add ca-certificates
COPY --from=0 /go/src/github.com/gempir/gempbotgo/app .
CMD ["./app"]
EXPOSE 8025

View file

@ -1,6 +1,6 @@
MIT License MIT License
Copyright (c) 2017 gempir Copyright (c) 2018 gempir
Permission is hereby granted, free of charge, to any person obtaining a copy Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal of this software and associated documentation files (the "Software"), to deal

View file

@ -1,5 +1,5 @@
--- ---
api_domain: api2.gempir.com api_domain: justlog.gempir.com
email: !vault | email: !vault |
$ANSIBLE_VAULT;1.1;AES256 $ANSIBLE_VAULT;1.1;AES256
65373739353434323038366266343639376262633166356330336339396664326264343334633864 65373739353434323038366266343639376262633166356330336339396664326264343334633864
@ -7,3 +7,5 @@ email: !vault |
35666538386231343533333231646131383734663834663039636235313237636366343535376366 35666538386231343533333231646131383734663834663039636235313237636366343535376366
3438353430666537630a323338663565366439353163646435633738653563393330613064363163 3438353430666537630a323338663565366439353163646435633738653563393330613064363163
66356363623063373532626262343361663933623132653162633034396131623038 66356363623063373532626262343361663933623132653162633034396131623038
admin: gempir
channels: "gempir,pajlada"

View file

@ -5,9 +5,6 @@
roles: roles:
- {role: 'common', tags: ['common']} - {role: 'common', tags: ['common']}
- {role: 'geerlingguy.docker', tags: ['docker']}
- {role: 'traefik', tags: ['traefik']}
- {role: 'portainer', tags: ['portainer']}
- {role: 'bot', tags: ['bot']} - {role: 'bot', tags: ['bot']}
handlers: handlers:

View file

@ -1,16 +1,23 @@
--- ---
- name: create directory - name: create log directory
file: file:
path: /var/twitch_logs path: /var/justlog
state: directory state: directory
owner: root owner: justlog
group: docker group: justlog
mode: 0740 mode: 0740
- name: create channels file - name: create env file
template: template:
src: templates/channels.j2 src: templates/env.j2
dest: /var/logstv_channels dest: /etc/justlog.env
owner: root owner: justlog
group: docker group: justlog
mode: 0640 mode: 0640
- name: install systemd unit file
template: src=myservice.j2 dest=/etc/systemd/system/myservice.service
- name: reload units
systemd:
daemon_reload: yes

View file

@ -1,5 +0,0 @@
gempir
pajlada
forsen
nymn
nani

View file

@ -0,0 +1,8 @@
{
"admin: "{{ admin }}",
"logDirectory": "/var/justlog"
"channels": [
"gempir",
"pajlada"
]
}

View file

@ -0,0 +1,11 @@
[Unit]
Description=justlog service
After=network.target
[Service]
Type=simple
ExecStart=/home/justlog/justlog
TimeoutStopSec=5
[Install]
WantedBy=multi-user.target

View file

@ -14,3 +14,15 @@
- name: install ufw firewall - name: install ufw firewall
include: ufw.yml include: ufw.yml
- name: Ensure group "justlog" exists
group:
name: justlog
state: present
- name: Create justlog user
user:
name: justlog
shell: /bin/bash
groups: justlog
append: yes

5
config.json Normal file
View file

@ -0,0 +1,5 @@
{
"admin": "gempir",
"logsDirectory": "./logs",
"channels": ["gempir", "pajlada"]
}

View file

@ -1,11 +0,0 @@
version: "2.1"
services:
gempbotgo:
build: ./
restart: always
ports:
- "8025:8025"
env_file:
- .env
volumes:
- ./logs:/var/twitch_logs

View file

@ -13,9 +13,9 @@ type Logger struct {
} }
// NewFileLogger create file logger // NewFileLogger create file logger
func NewFileLogger() Logger { func NewFileLogger(logPath string) Logger {
return Logger{ return Logger{
logPath: "/var/twitch_logs", logPath: logPath,
} }
} }

55
main.go
View file

@ -1,8 +1,9 @@
package main package main
import ( import (
"encoding/json"
"flag"
"fmt" "fmt"
"log"
"os" "os"
"time" "time"
@ -13,26 +14,33 @@ import (
"github.com/gempir/gempbotgo/humanize" "github.com/gempir/gempbotgo/humanize"
"github.com/gempir/go-twitch-irc" "github.com/gempir/go-twitch-irc"
_ "github.com/go-sql-driver/mysql" log "github.com/sirupsen/logrus"
) )
type config struct {
LogsDirectory string `json:"logsDirectory"`
Admin string `json:"admin"`
Channels []string `json:"channels"`
}
var ( var (
admin string cfg config
) )
func main() { func main() {
startTime := time.Now() startTime := time.Now()
admin = os.Getenv("ADMIN")
configFile := flag.String("config", "config.json", "json config file")
flag.Parse()
cfg = loadConfiguration(*configFile)
apiServer := api.NewServer() apiServer := api.NewServer()
go apiServer.Init() go apiServer.Init()
twitchClient := twitch.NewClient(os.Getenv("IRCUSER"), os.Getenv("IRCTOKEN")) twitchClient := twitch.NewClient("justinfan123123", "oauth:123123123")
fileLogger := filelog.NewFileLogger(cfg.LogsDirectory)
fileLogger := filelog.NewFileLogger() for _, channel := range cfg.Channels {
channels := strings.Split(os.Getenv("CHANNELS"), ",")
for _, channel := range channels {
fmt.Println("Joining " + channel) fmt.Println("Joining " + channel)
twitchClient.Join(channel) twitchClient.Join(channel)
apiServer.AddChannel(channel) apiServer.AddChannel(channel)
@ -43,20 +51,20 @@ func main() {
go func() { go func() {
err := fileLogger.LogMessageForUser(channel, user, message) err := fileLogger.LogMessageForUser(channel, user, message)
if err != nil { if err != nil {
log.Println(err.Error()) log.Error(err.Error())
} }
}() }()
go func() { go func() {
err := fileLogger.LogMessageForChannel(channel, user, message) err := fileLogger.LogMessageForChannel(channel, user, message)
if err != nil { if err != nil {
log.Println(err.Error()) log.Error(err.Error())
} }
}() }()
if user.Username == admin && strings.HasPrefix(message.Text, "!status") { if user.Username == cfg.Admin && strings.HasPrefix(message.Text, "!status") {
uptime := humanize.TimeSince(startTime) uptime := humanize.TimeSince(startTime)
twitchClient.Say(channel, admin+", uptime: "+uptime) twitchClient.Say(channel, cfg.Admin+", uptime: "+uptime)
} }
}) })
@ -65,17 +73,34 @@ func main() {
go func() { go func() {
err := fileLogger.LogMessageForUser(channel, user, message) err := fileLogger.LogMessageForUser(channel, user, message)
if err != nil { if err != nil {
log.Println(err.Error()) log.Error(err.Error())
} }
}() }()
go func() { go func() {
err := fileLogger.LogMessageForChannel(channel, user, message) err := fileLogger.LogMessageForChannel(channel, user, message)
if err != nil { if err != nil {
log.Println(err.Error()) log.Error(err.Error())
} }
}() }()
}) })
twitchClient.Connect() twitchClient.Connect()
} }
func loadConfiguration(file string) config {
log.Info("Loading config from " + file)
var cfg config
configFile, err := os.Open(file)
defer configFile.Close()
if err != nil {
log.Fatal(err)
}
jsonParser := json.NewDecoder(configFile)
jsonParser.Decode(&cfg)
cfg.LogsDirectory = strings.TrimSuffix(cfg.LogsDirectory, "/")
return cfg
}

View file

@ -1,11 +0,0 @@
version: "3"
services:
gempbotgo:
image: gempir/gempbotgo
restart: always
ports:
- "8025:8025"
env_file:
- .env
volumes:
- /var/twitch_logs:/var/twitch_logs