ALFRED/alfred.go

78 lines
2.2 KiB
Go
Raw Normal View History

2018-07-23 16:59:39 +02:00
/*
* @Author: Bartuccio Antoine
* @Date: 2018-07-23 15:24:22
* @Last Modified by: Bartuccio Antoine
* @Last Modified time: 2019-01-05 17:47:10
2018-07-23 16:59:39 +02:00
*/
package main
import (
2018-11-14 00:35:25 +01:00
"log"
"time"
"git.klmp200.net/ALFRED/ALFRED/commands"
"git.klmp200.net/ALFRED/ALFRED/settings"
"git.klmp200.net/ALFRED/ALFRED/shared"
2018-07-23 16:59:39 +02:00
tb "gopkg.in/tucnak/telebot.v2"
)
func main() {
2018-11-14 00:35:25 +01:00
registeredCommands := map[string]func(*tb.Message){
tb.OnText: commands.OnText,
"/registerprivate": commands.RegisterPrivate,
"/unregisterprivate": commands.UnRegisterPrivate,
"/hello": commands.Hello,
"/sponge": commands.Sponge,
"/git": commands.Git,
"/framapad": commands.Framapad,
"/setgender": commands.SetGender,
"/gender": commands.Gender,
"/roll": commands.Dice,
"/trump": commands.LastTrumpTweet,
"/trends": commands.TwitterTrends,
"/chaos": commands.TwitterSJW,
"/apero": commands.AperoTime,
"/quote": commands.Quote,
"/subscribe": commands.Subscribe,
"/unsubscribe": commands.Unsubscribe,
"/listsubscribers": commands.ListSubscribers,
"/publish": commands.Publish,
"/unpublish": commands.Unpublish,
"/retrieve": commands.Retrieve,
"/toggleupdates": commands.ToggleUpdates,
}
2018-07-23 19:25:35 +02:00
if err := settings.LoadSettings("settings.json", "settings_custom.json"); err != nil {
log.Fatal(err)
}
2018-07-23 16:59:39 +02:00
2018-07-24 02:28:45 +02:00
log.Println("Initialize history")
2018-07-24 12:57:31 +02:00
shared.InitHistory(int(settings.Settings["history size"].(float64)),
settings.Settings["history file"].(string))
log.Println("Initialize users infos")
shared.InitUsers(settings.Settings["users file"].(string))
log.Println("Initialize chat data")
shared.InitChatData(settings.Settings["chat data file"].(string))
2018-07-24 02:28:45 +02:00
2018-07-23 16:59:39 +02:00
log.Println("Bot initialisation")
b, err := tb.NewBot(tb.Settings{
Token: settings.Settings["token"].(string),
Poller: &tb.LongPoller{Timeout: 10 * time.Second},
})
if err != nil {
log.Fatal(err)
return
}
2018-07-24 11:59:36 +02:00
shared.Bot = b
2018-07-23 16:59:39 +02:00
2018-11-14 00:35:25 +01:00
for key, value := range registeredCommands {
b.Handle(key, value)
}
2018-07-24 03:07:13 +02:00
2018-07-23 16:59:39 +02:00
log.Println("Starting bot")
b.Start()
}