galched-bot/main.go

63 lines
1.1 KiB
Go
Raw Normal View History

package main
import (
"context"
"log"
2019-05-10 08:53:58 +00:00
"galched-bot/modules/discord"
"galched-bot/modules/grace"
"galched-bot/modules/settings"
"go.uber.org/fx"
)
type (
silentPrinter struct{}
appParam struct {
fx.In
Context context.Context
2019-05-10 08:53:58 +00:00
Discord *discord.Discord
Settings *settings.Settings
}
)
func (s *silentPrinter) Printf(str string, i ...interface{}) {}
func start(p appParam) {
2019-05-10 08:53:58 +00:00
var err error
log.Print("main: starting galched-bot v", p.Settings.Version)
2019-05-10 08:53:58 +00:00
err = p.Discord.Start()
if err != nil {
log.Fatal("discord: cannot start instance", err)
}
log.Printf("main: discord instance running")
log.Printf("main: — — —")
2019-05-10 08:53:58 +00:00
<-p.Context.Done()
2019-05-10 08:53:58 +00:00
log.Print("main: stopping galched-bot")
err = p.Discord.Stop()
if err != nil {
log.Fatal("discord: cannot stop instance", err)
}
log.Print("main: galched bot successfully stopped")
}
func main() {
var err error
app := fx.New(
fx.Logger(new(silentPrinter)),
2019-05-10 08:53:58 +00:00
fx.Provide(settings.New, grace.New, discord.New),
fx.Invoke(start))
err = app.Start(context.Background())
if err != nil {
log.Fatal(err)
}
}