2020-11-19 20:03:14 +00:00
|
|
|
// Package main demonstrates a bare simple bot without a state cache. It logs
|
|
|
|
// all messages it sees into stderr.
|
2020-01-17 22:29:13 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
|
2020-10-28 22:39:59 +00:00
|
|
|
"github.com/diamondburned/arikawa/v2/gateway"
|
|
|
|
"github.com/diamondburned/arikawa/v2/session"
|
2020-01-17 22:29:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// To run, do `BOT_TOKEN="TOKEN HERE" go run .`
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
var token = os.Getenv("BOT_TOKEN")
|
|
|
|
if token == "" {
|
|
|
|
log.Fatalln("No $BOT_TOKEN given.")
|
|
|
|
}
|
|
|
|
|
|
|
|
s, err := session.New("Bot " + token)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln("Session failed:", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
s.AddHandler(func(c *gateway.MessageCreateEvent) {
|
|
|
|
log.Println(c.Author.Username, "sent", c.Content)
|
|
|
|
})
|
|
|
|
|
|
|
|
if err := s.Open(); err != nil {
|
|
|
|
log.Fatalln("Failed to connect:", err)
|
|
|
|
}
|
2020-04-12 18:06:43 +00:00
|
|
|
defer s.Close()
|
2020-01-17 22:29:13 +00:00
|
|
|
|
2020-11-19 20:03:14 +00:00
|
|
|
// Add the needed Gateway intents.
|
|
|
|
s.Gateway.AddIntents(gateway.IntentGuildMessages)
|
|
|
|
s.Gateway.AddIntents(gateway.IntentDirectMessages)
|
|
|
|
|
2020-01-17 22:29:13 +00:00
|
|
|
u, err := s.Me()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln("Failed to get myself:", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Println("Started as", u.Username)
|
|
|
|
|
2020-04-12 18:06:43 +00:00
|
|
|
// Block forever.
|
|
|
|
select {}
|
2020-01-17 22:29:13 +00:00
|
|
|
}
|