aboutsummaryrefslogtreecommitdiff
path: root/user/anime/animelist.go
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@protonmail.ch>2022-02-08 21:47:58 +0530
committerVidhu Kant Sharma <vidhukant@protonmail.ch>2022-02-08 21:47:58 +0530
commit4bd702d111c6e4d5455865a7e1fbe5de11899b15 (patch)
treef190db20b0d38aa0f74a564c339aaf9b3ac008d4 /user/anime/animelist.go
parent7816a8487dd5d79111ca84b0da227faf5f8d7bad (diff)
NOT WORKING: pushing current progress, adding support for different options with GetAnimeList
Diffstat (limited to 'user/anime/animelist.go')
-rw-r--r--user/anime/animelist.go35
1 files changed, 31 insertions, 4 deletions
diff --git a/user/anime/animelist.go b/user/anime/animelist.go
index c48980d..b36b50d 100644
--- a/user/anime/animelist.go
+++ b/user/anime/animelist.go
@@ -17,16 +17,43 @@
package anime
import (
- "fmt"
+ "encoding/json"
+ "fmt"
+ "github.com/MikunoNaka/mal2go/anime"
)
const BASE_URL string = "https://api.myanimelist.net/v2"
// Get authenticated user's anime list
-func (c AnimeListClient) GetAnimeList() {
- endpoint := BASE_URL + "/users/@me/animelist?fields=list_status&limit=4"
+func (c AnimeListClient) GetAnimeList(user, status, sort string/*, limit, offset int*/) {
+ // get own list if user not specified
+ if user == "" {
+ user = "@me"
+ }
+ var userAnimeList anime.AnimeList
+ endpoint := BASE_URL + "/users/0ZeroTsu/animelist?fields=list_status&limit=4"
+
+ // get data from API
+ var animeListData AnimeListRaw
data := c.requestHandler(endpoint, "GET")
- fmt.Println(data)
+ json.Unmarshal([]byte(data), &animeListData)
+
+ // set MyListStatus for each element and add it to array
+ var animes []anime.Anime
+ for _, element := range animeListData.Data {
+ a := element.Anime
+ a.MyListStatus = element.ListStatus
+
+ animes = append(animes, a)
+ }
+
+ // finally create AnimeList
+ userAnimeList = anime.AnimeList {
+ Animes: animes,
+ Paging: animeListData.Paging,
+ }
+
+ fmt.Println(userAnimeList)
}