|
9 éve | |
---|---|---|
bot | 9 éve | |
LICENSE | 9 éve | |
README.md | 9 éve | |
channel.go | 9 éve | |
discord.go | 9 éve | |
guild.go | 9 éve | |
restapi.go | 9 éve | |
session.go | 9 éve | |
structs.go | 9 éve | |
users.go | 9 éve | |
util.go | 9 éve | |
wsapi.go | 9 éve |
Discordgo provides a mostly complete low-level Golang interface to the Discord REST and Websocket API.
package main
import (
"fmt"
"time"
"github.com/bwmarrin/discordgo"
)
func main() {
var err error
// Create a new Discord Session and set a handler for the OnMessageCreate
// event that happens for every new message on any channel
Session := discordgo.Session{
OnMessageCreate: messageCreate,
}
// Login to the Discord server and store the authentication token
// inside the Session
Session.Token, err = Session.Login("coolusername", "cleverpassword")
if err != nil {
fmt.Println(err)
return
}
// Open websocket connection
err = Session.Open()
if err != nil {
fmt.Println(err)
}
// Do websocket handshake.
err = Session.Handshake()
if err != nil {
fmt.Println(err)
}
// Listen for events.
Session.Listen()
return
}
func messageCreate(s *discordgo.Session, m discordgo.Message) {
fmt.Printf("%25d %s %20s > %s\n", m.ChannelId, time.Now().Format(time.Stamp), m.Author.Username, m.Content)
}
Low level functions exist for the majority of the REST and Websocket API.
Special thanks goes to both the below projects who helped me get started with this project. If you're looking for alternative Golang interfaces to Discord please check both of these out.