mirror of
https://github.com/jackmerrill/hampbot.git
synced 2025-04-19 02:00:47 -04:00
feat: xkcd command
This commit is contained in:
parent
8e6ed1e9ce
commit
ab852f001d
145
internal/commands/fun/xkcd.go
Normal file
145
internal/commands/fun/xkcd.go
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
package fun
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"math/rand"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/jackmerrill/hampbot/internal/utils/config"
|
||||||
|
"github.com/jackmerrill/hampbot/internal/utils/embed"
|
||||||
|
"github.com/zekroTJA/shireikan"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Xkcd struct {
|
||||||
|
Month string `json:"month"`
|
||||||
|
Num int64 `json:"num"`
|
||||||
|
Link string `json:"link"`
|
||||||
|
Year string `json:"year"`
|
||||||
|
News string `json:"news"`
|
||||||
|
SafeTitle string `json:"safe_title"`
|
||||||
|
Transcript string `json:"transcript"`
|
||||||
|
Alt string `json:"alt"`
|
||||||
|
Img string `json:"img"`
|
||||||
|
Title string `json:"title"`
|
||||||
|
Day string `json:"day"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type XKCD struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetInvokes() []string {
|
||||||
|
return []string{"xkcd"}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetDescription() string {
|
||||||
|
return "Get a random, specific, or the latest XKCD comic"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetHelp() string {
|
||||||
|
return "`xkcd <number|latest|random>` - Get a random (default), specific, or the latest XKCD comic"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetGroup() string {
|
||||||
|
return config.GroupFun
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetDomainName() string {
|
||||||
|
return "hamp.fun.xkcd"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) GetSubPermissionRules() []shireikan.SubPermission {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func (c *XKCD) IsExecutableInDMChannels() bool {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *XKCD) Exec(ctx shireikan.Context) error {
|
||||||
|
id := ctx.GetArgs().Get(0).AsString()
|
||||||
|
|
||||||
|
if id == "" {
|
||||||
|
id = "random"
|
||||||
|
}
|
||||||
|
|
||||||
|
var comic Xkcd
|
||||||
|
|
||||||
|
if id == "latest" {
|
||||||
|
res, err := http.Get("https://xkcd.com/info.0.json")
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching the latest comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer res.Body.Close()
|
||||||
|
|
||||||
|
err = json.NewDecoder(res.Body).Decode(&comic)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching the latest comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else if id == "random" {
|
||||||
|
latest, err := http.Get("https://xkcd.com/info.0.json")
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching a random comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer latest.Body.Close()
|
||||||
|
|
||||||
|
var tempComic Xkcd
|
||||||
|
|
||||||
|
err = json.NewDecoder(latest.Body).Decode(&tempComic)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching a random comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
id = fmt.Sprintf("%d", rand.Intn((int(tempComic.Num)-1)+1))
|
||||||
|
|
||||||
|
res, err := http.Get(fmt.Sprintf("https://xkcd.com/%s/info.0.json", id))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching a random comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer res.Body.Close()
|
||||||
|
|
||||||
|
err = json.NewDecoder(res.Body).Decode(&comic)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching a random comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
res, err := http.Get(fmt.Sprintf("https://xkcd.com/%s/info.0.json", id))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching the comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer res.Body.Close()
|
||||||
|
|
||||||
|
err = json.NewDecoder(res.Body).Decode(&comic)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewErrorEmbed(ctx).SetTitle("Error").SetDescription("An error occured while fetching the comic.").AddField("Error", err.Error(), false).MessageEmbed)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.GetSession().ChannelMessageSendEmbed(ctx.GetChannel().ID, embed.NewEmbed().
|
||||||
|
SetTitle(fmt.Sprintf("%s (%d)", comic.Title, comic.Num)).
|
||||||
|
SetDescription(comic.Alt).
|
||||||
|
SetImage(comic.Img).
|
||||||
|
SetColor(0x96A8C8).
|
||||||
|
SetURL(fmt.Sprintf("https://xkcd.com/%d", comic.Num)).
|
||||||
|
MessageEmbed)
|
||||||
|
return nil
|
||||||
|
}
|
@ -4,6 +4,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/bwmarrin/discordgo"
|
"github.com/bwmarrin/discordgo"
|
||||||
@ -69,7 +70,7 @@ func (c *Laundry) IsExecutableInDMChannels() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Laundry) Exec(ctx shireikan.Context) error {
|
func (c *Laundry) Exec(ctx shireikan.Context) error {
|
||||||
building := ctx.GetArgs().Get(0)
|
building := ctx.GetArgs().Get(0).AsString()
|
||||||
|
|
||||||
if building == "" {
|
if building == "" {
|
||||||
ctx.GetSession().ChannelMessageSendComplex(ctx.GetChannel().ID, &discordgo.MessageSend{
|
ctx.GetSession().ChannelMessageSendComplex(ctx.GetChannel().ID, &discordgo.MessageSend{
|
||||||
@ -79,6 +80,8 @@ func (c *Laundry) Exec(ctx shireikan.Context) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
building = strings.ToLower(building)
|
||||||
|
|
||||||
if building != "dakin" && building != "merrill" && building != "prescott" && building != "enfield" {
|
if building != "dakin" && building != "merrill" && building != "prescott" && building != "enfield" {
|
||||||
ctx.GetSession().ChannelMessageSendComplex(ctx.GetChannel().ID, &discordgo.MessageSend{
|
ctx.GetSession().ChannelMessageSendComplex(ctx.GetChannel().ID, &discordgo.MessageSend{
|
||||||
Embed: embed.NewErrorEmbed(ctx).SetDescription("Please specify a valid building to get the laundry status of.\n\n**Usage:** `laundry [dakin/merrill/prescott/enfield]`").MessageEmbed,
|
Embed: embed.NewErrorEmbed(ctx).SetDescription("Please specify a valid building to get the laundry status of.\n\n**Usage:** `laundry [dakin/merrill/prescott/enfield]`").MessageEmbed,
|
||||||
|
10
main.go
10
main.go
@ -1,9 +1,11 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"math/rand"
|
||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/bwmarrin/discordgo"
|
"github.com/bwmarrin/discordgo"
|
||||||
"github.com/jackmerrill/hampbot/internal/commands/fun"
|
"github.com/jackmerrill/hampbot/internal/commands/fun"
|
||||||
@ -47,6 +49,9 @@ func main() {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
log.Info("Initializing Random")
|
||||||
|
rand.Seed(time.Now().UnixNano())
|
||||||
|
|
||||||
log.Info("Registering commands...")
|
log.Info("Registering commands...")
|
||||||
|
|
||||||
handler.Register(&util.Ping{})
|
handler.Register(&util.Ping{})
|
||||||
@ -61,6 +66,11 @@ func main() {
|
|||||||
handler.Register(&fun.AI{})
|
handler.Register(&fun.AI{})
|
||||||
log.Debug("Registered ai command")
|
log.Debug("Registered ai command")
|
||||||
|
|
||||||
|
handler.Register(&fun.XKCD{})
|
||||||
|
log.Debug("Registered xkcd command")
|
||||||
|
|
||||||
|
log.Info("Registered all commands")
|
||||||
|
|
||||||
handler.Setup(session)
|
handler.Setup(session)
|
||||||
|
|
||||||
log.Info("Bot is now running. Press CTRL-C to exit.")
|
log.Info("Bot is now running. Press CTRL-C to exit.")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user