mirror of https://github.com/velour/catbase.git
aoc: refactor
This commit is contained in:
parent
951c345666
commit
dfbcfafab9
|
@ -2,6 +2,7 @@ package aoc
|
|||
|
||||
import (
|
||||
"fmt"
|
||||
"regexp"
|
||||
"sort"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
@ -10,7 +11,6 @@ import (
|
|||
"code.chrissexton.org/cws/getaoc"
|
||||
|
||||
"github.com/velour/catbase/bot"
|
||||
"github.com/velour/catbase/bot/msg"
|
||||
"github.com/velour/catbase/config"
|
||||
)
|
||||
|
||||
|
@ -24,42 +24,35 @@ func New(b bot.Bot) *AOC {
|
|||
b: b,
|
||||
c: b.Config(),
|
||||
}
|
||||
b.Register(aoc, bot.Message, aoc.message)
|
||||
b.RegisterRegexCmd(aoc, bot.Message, aocRegex, aoc.aocCmd)
|
||||
return aoc
|
||||
}
|
||||
|
||||
func (p *AOC) message(c bot.Connector, kind bot.Kind, message msg.Message, args ...interface{}) bool {
|
||||
if !message.Command {
|
||||
return false
|
||||
}
|
||||
cleaned := strings.TrimSpace(strings.ToLower(message.Body))
|
||||
fields := strings.Split(cleaned, " ")
|
||||
if strings.HasPrefix(cleaned, "aoc") {
|
||||
var aocRegex = regexp.MustCompile(`(?i)^aoc\s?(?P<year>\S+)?$`)
|
||||
|
||||
func (p *AOC) aocCmd(r bot.Request) bool {
|
||||
year := time.Now().Year()
|
||||
if len(fields) > 1 {
|
||||
year, _ = strconv.Atoi(fields[1])
|
||||
if time.Now().Month() < 11 {
|
||||
year--
|
||||
}
|
||||
if r.Values["year"] != "" {
|
||||
year, _ = strconv.Atoi(r.Values["year"])
|
||||
}
|
||||
boardId := p.c.GetInt("aoc.board", 0)
|
||||
var err error
|
||||
if len(fields) > 2 {
|
||||
boardId, err = strconv.Atoi(fields[2])
|
||||
if err != nil {
|
||||
p.b.Send(c, bot.Message, message.Channel, fmt.Sprintf("Error getting leaderboard: %s", err))
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
session := p.c.Get("aoc.session", "")
|
||||
if session == "" {
|
||||
p.b.Send(c, bot.Message, message.Channel, "Error getting leaderboard: must have a session ID.")
|
||||
p.b.Send(r.Conn, bot.Message, r.Msg.Channel, "Error getting leaderboard: must have a session ID.")
|
||||
return true
|
||||
}
|
||||
if boardId == 0 {
|
||||
p.b.Send(c, bot.Message, message.Channel, "Error getting leaderboard: must have a board ID.")
|
||||
p.b.Send(r.Conn, bot.Message, r.Msg.Channel, "Error getting leaderboard: must have a board ID.")
|
||||
return true
|
||||
}
|
||||
board, err := getaoc.GetLeaderboard(session, year, boardId)
|
||||
if err != nil {
|
||||
p.b.Send(c, bot.Message, message.Channel, fmt.Sprintf("Error getting leaderboard: %s", err))
|
||||
p.b.Send(r.Conn, bot.Message, r.Msg.Channel, fmt.Sprintf("Error getting leaderboard: %s", err))
|
||||
return true
|
||||
}
|
||||
|
||||
|
@ -88,7 +81,7 @@ func (p *AOC) message(c bot.Connector, kind bot.Kind, message msg.Message, args
|
|||
}
|
||||
}
|
||||
|
||||
link := c.URLFormat("leaderboard", fmt.Sprintf("https://adventofcode.com/%d/leaderboard/private/view/%d", year, boardId))
|
||||
link := r.Conn.URLFormat("leaderboard", fmt.Sprintf("https://adventofcode.com/%d/leaderboard/private/view/%d", year, boardId))
|
||||
msg := fmt.Sprintf("AoC %s:\n", link)
|
||||
for _, m := range members {
|
||||
if m.Stars == 0 {
|
||||
|
@ -97,18 +90,16 @@ func (p *AOC) message(c bot.Connector, kind bot.Kind, message msg.Message, args
|
|||
trophy := ""
|
||||
switch m.ID {
|
||||
case goldID:
|
||||
trophy = c.Emojy(":gold-trophy:")
|
||||
trophy = r.Conn.Emojy(":gold-trophy:")
|
||||
case silverID:
|
||||
trophy = c.Emojy(":silver-trophy:")
|
||||
trophy = r.Conn.Emojy(":silver-trophy:")
|
||||
case bronzeID:
|
||||
trophy = c.Emojy(":bronze-trophy:")
|
||||
trophy = r.Conn.Emojy(":bronze-trophy:")
|
||||
}
|
||||
msg += fmt.Sprintf("%s has %d :star: for a score of %d%s\n", m.Name, m.Stars, m.LocalScore, trophy)
|
||||
}
|
||||
msg = strings.TrimSpace(msg)
|
||||
|
||||
p.b.Send(c, bot.Message, message.Channel, msg)
|
||||
p.b.Send(r.Conn, bot.Message, r.Msg.Channel, msg)
|
||||
return true
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue