matrix-kagisum/main.go

51 lines
1.2 KiB
Go
Raw Normal View History

2023-06-24 12:23:32 +02:00
package main
import (
"os"
2023-06-25 15:53:40 +02:00
"os/signal"
2023-07-11 15:56:02 +02:00
"ewintr.nl/matrix-kagisum/bot"
"golang.org/x/exp/slog"
2023-06-24 12:23:32 +02:00
)
func main() {
2023-06-25 15:53:40 +02:00
logger := slog.New(slog.NewTextHandler(os.Stderr, nil))
2023-06-24 12:23:32 +02:00
2023-07-11 15:56:02 +02:00
kagi := bot.NewKagi("https://kagi.com/api/v0", getParam("KAGI_API_KEY", ""))
2023-06-25 15:53:40 +02:00
mtrxConf := bot.MatrixConfig{
Homeserver: getParam("MATRIX_HOMESERVER", "http://localhost/"),
UserID: getParam("MATRIX_USER_ID", "@user:localhost"),
UserAccessKey: getParam("MATRIX_USER_ACCESS_KEY", "secret"),
UserPassword: getParam("MATRIX_USER_PASSWORD", "secret"),
RoomID: getParam("MATRIX_ROOM_ID", "!room:localhost"),
DBPath: getParam("MATRIX_DB_PATH", "matrix.db"),
Pickle: getParam("MATRIX_PICKLE", "matrix.pickle"),
AcceptInvites: getParam("MATRIX_ACCEPT_INVITES", "false") == "true",
}
2023-07-11 15:56:02 +02:00
ks := bot.NewBot(mtrxConf, kagi, logger)
if err := ks.Init(); err != nil {
logger.Error("error running matrix ks: %v", slog.String("error", err.Error()))
2023-06-25 15:53:40 +02:00
os.Exit(1)
2023-06-24 12:23:32 +02:00
}
2023-07-11 15:56:02 +02:00
go ks.Run()
defer ks.Close()
logger.Info("matrix ks started")
2023-06-25 15:53:40 +02:00
done := make(chan os.Signal)
signal.Notify(done, os.Interrupt)
<-done
2023-07-11 15:56:02 +02:00
logger.Info("matrix ks stopped")
2023-06-25 15:53:40 +02:00
2023-06-24 12:23:32 +02:00
}
func getParam(param, def string) string {
if val, ok := os.LookupEnv(param); ok {
return val
}
return def
}