mcchunkie/main.go

189 lines
4.0 KiB
Go
Raw Normal View History

package main
import (
"flag"
"fmt"
"log"
"net/http"
"os"
"time"
2020-01-31 19:57:40 -07:00
"git.sr.ht/~qbit/mcchunkie/plugins"
"github.com/matrix-org/gomatrix"
)
func main() {
var username, password, userID, accessToken, server, db, avatar string
var key, value, get string
var setup bool
flag.StringVar(&username, "user", "", "username to connect to matrix server with")
flag.StringVar(&get, "get", "", "grab an entry from the store")
flag.StringVar(&key, "key", "", "create an entry in the data store listed under 'key'")
flag.StringVar(&value, "value", "", "set the value of 'key' to be stored")
flag.StringVar(&server, "server", "", "matrix server")
flag.StringVar(&avatar, "avatar", "", "set the avatar of the bot to specified url")
flag.BoolVar(&setup, "s", false, "setup account")
2020-02-04 17:22:19 -07:00
flag.StringVar(&db, "db", "db", "full path to database directory")
flag.Parse()
2020-02-03 20:42:19 -07:00
pledge("stdio unveil rpath wpath cpath flock dns inet tty")
unveil("/etc/resolv.conf", "r")
unveil("/etc/ssl/cert.pem", "r")
unveil(db, "rwc")
unveilBlock()
var store, err = NewStore(db)
if err != nil {
log.Fatalf("%s\n", err)
}
if key != "" && value != "" {
2020-02-05 22:04:04 -07:00
store.Set(key, value)
os.Exit(0)
}
if get != "" {
2020-02-05 22:04:04 -07:00
val, err := store.Get(get)
if err != nil {
log.Fatalf("%s\n", err)
}
fmt.Println(val)
os.Exit(0)
}
if server == "" {
2020-02-05 22:04:04 -07:00
server, err = store.Get("server")
2020-02-10 16:08:33 -07:00
if err != nil {
if err != nil {
log.Fatalf("%s\n", err)
}
}
if server == "" {
log.Fatalln("please specify a server")
}
} else {
2020-02-05 22:04:04 -07:00
store.Set("server", server)
}
log.Printf("connecting to %s\n", server)
cli, err := gomatrix.NewClient(
server,
"",
"",
)
2020-02-10 16:08:33 -07:00
if err != nil {
log.Fatalf("%s\n", err)
}
if setup {
log.Println("requesting access token")
password, err = prompt(fmt.Sprintf("Password for '%s': ", username))
if err != nil {
log.Fatalln(err)
}
fmt.Println()
resp, err := cli.Login(&gomatrix.ReqLogin{
Type: "m.login.password",
User: username,
Password: password,
})
if err != nil {
log.Fatalln(err)
}
2020-02-03 20:42:19 -07:00
// No longer need tty now that we have our info
pledge("stdio unveil rpath wpath cpath flock dns inet")
2020-02-05 22:04:04 -07:00
store.Set("username", username)
store.Set("access_token", resp.AccessToken)
store.Set("user_id", resp.UserID)
accessToken = resp.AccessToken
userID = resp.UserID
} else {
2020-02-05 22:04:04 -07:00
username, _ = store.Get("username")
accessToken, _ = store.Get("access_token")
userID, _ = store.Get("user_id")
}
cli.SetCredentials(userID, accessToken)
cli.Store = store
syncer := gomatrix.NewDefaultSyncer(username, store)
cli.Client = http.DefaultClient
cli.Syncer = syncer
/*
2020-01-31 19:57:40 -07:00
// TODO: Add ability to join / part rooms
if _, err := cli.JoinRoom("!tmCVBJAeuKjCfihUjb:cobryce.com", "", nil); err != nil {
log.Fatalln(err)
}
if _, err := cli.JoinRoom("!sFPUeGfHqjiItcjNIN:matrix.org", "", nil); err != nil {
log.Fatalln(err)
}
if _, err := cli.JoinRoom("!ALCZnrYadLGSySIFZr:matrix.org", "", nil); err != nil {
log.Fatalln(err)
}
2020-01-30 06:48:37 -07:00
if _, err := cli.JoinRoom("!LTxJpLHtShMVmlpwmZ:tapenet.org", "", nil); err != nil {
log.Fatalln(err)
}
2020-02-01 20:56:55 -07:00
if _, err := cli.JoinRoom("!TjjamgVanKpNiswkoJ:pintobyte.com", "", nil); err != nil {
log.Fatalln(err)
}
*/
syncer.OnEventType("m.room.message", func(ev *gomatrix.Event) {
if ev.Sender == username {
return
}
2020-01-31 19:57:40 -07:00
for _, p := range plugins.Plugs {
var post string
var ok bool
if post, ok = ev.Body(); !ok {
// Invaild body, for some reason
return
}
if mtype, ok := ev.MessageType(); ok {
switch mtype {
case "m.text":
2020-02-10 17:10:57 -07:00
if p.Match(username, post) {
p.SetStore(store)
p.RespondText(cli, ev, username, post)
}
}
}
}
})
if avatar != "" {
log.Printf("Setting avatar to: '%s'", avatar)
rmu, err := cli.UploadLink(avatar)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
err = cli.SetAvatarURL(rmu.ContentURI)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
os.Exit(0)
}
for {
log.Println("syncing..")
if err := cli.Sync(); err != nil {
fmt.Println("Sync() returned ", err)
}
time.Sleep(1 * time.Second)
}
}