Compare commits
2 Commits
Author | SHA1 | Date | |
---|---|---|---|
5e662ec995 | |||
af7437c238 |
40
aoc.go
40
aoc.go
@@ -7,7 +7,6 @@ import (
|
|||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -46,7 +45,7 @@ func (a *AoC) GetLeaderboard(year int) (*Leaderboard, error) {
|
|||||||
return nil, errors.New("Invalid Year")
|
return nil, errors.New("Invalid Year")
|
||||||
}
|
}
|
||||||
if board, ok := a.boards[year]; ok {
|
if board, ok := a.boards[year]; ok {
|
||||||
if time.Since(board.LastFetch) < (time.Minute * 10) {
|
if time.Since(board.LastFetch) < (time.Minute * 15) {
|
||||||
return board, nil
|
return board, nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -83,7 +82,7 @@ func (a *AoC) fetchLeaderboard(year int) (*Leaderboard, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
strBody := string(body)
|
strBody := string(body)
|
||||||
strBody = strings.ReplaceAll(strBody, "\"last_star_ts\":\"0\"", "\"last_star_ts\":0")
|
//strBody = strings.ReplaceAll(strBody, "\"last_star_ts\":\"0\"", "\"last_star_ts\":0")
|
||||||
err = json.Unmarshal([]byte(strBody), &leaderboard)
|
err = json.Unmarshal([]byte(strBody), &leaderboard)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error parsing board")
|
fmt.Println("Error parsing board")
|
||||||
@@ -104,14 +103,14 @@ func (a *AoC) fetchLeaderboard(year int) (*Leaderboard, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Leaderboard struct {
|
type Leaderboard struct {
|
||||||
OwnerID string `json:"owner_id"`
|
OwnerID int `json:"owner_id"`
|
||||||
Event string `json:"event"`
|
Event string `json:"event"`
|
||||||
Members map[string]Member `json:"members"`
|
Members map[string]Member `json:"members"`
|
||||||
LastFetch time.Time
|
LastFetch time.Time
|
||||||
}
|
}
|
||||||
|
|
||||||
type Member struct {
|
type Member struct {
|
||||||
ID string `json:"id"`
|
ID int `json:"id"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Stars int `json:"stars"`
|
Stars int `json:"stars"`
|
||||||
RawStarTs string `json:"last_star_ts"`
|
RawStarTs string `json:"last_star_ts"`
|
||||||
@@ -143,3 +142,34 @@ func (a ByStarsThenScore) Less(i, j int) bool {
|
|||||||
}
|
}
|
||||||
return a[i].Stars < a[j].Stars
|
return a[i].Stars < a[j].Stars
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (m *Member) UnmarshalJSON(data []byte) error {
|
||||||
|
|
||||||
|
var v map[string]interface{}
|
||||||
|
var err error
|
||||||
|
|
||||||
|
if err = json.Unmarshal(data, &v); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
m.ID = int(v["id"].(float64))
|
||||||
|
m.Name = v["name"].(string)
|
||||||
|
m.Stars = int(v["stars"].(float64))
|
||||||
|
|
||||||
|
switch v["last_star_ts"].(type) {
|
||||||
|
case float64:
|
||||||
|
m.RawStarTs = fmt.Sprintf("%d", int(v["last_star_ts"].(float64)))
|
||||||
|
case int:
|
||||||
|
m.RawStarTs = strconv.Itoa(v["last_star_ts"].(int))
|
||||||
|
case string:
|
||||||
|
m.RawStarTs = v["last_star_ts"].(string)
|
||||||
|
default:
|
||||||
|
m.RawStarTs = "0"
|
||||||
|
}
|
||||||
|
starTs, err := strconv.ParseInt(m.RawStarTs, 10, 64)
|
||||||
|
if err != nil {
|
||||||
|
starTs = 0
|
||||||
|
}
|
||||||
|
m.LastStarTs = time.Unix(starTs, 0)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@@ -16,7 +16,7 @@ func main() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
l, err := a.GetLeaderboard(2020)
|
l, err := a.GetLeaderboard(2021)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
|
Reference in New Issue
Block a user