aboutsummaryrefslogtreecommitdiff
path: root/anime
diff options
context:
space:
mode:
authorVidhu Kant Sharma <bokuwakanojogahoshii@yahoo.com>2022-02-13 11:27:12 +0000
committerGitHub <noreply@github.com>2022-02-13 11:27:12 +0000
commit541c75949e862f6fd1081bc4081b08187fa7da7b (patch)
treec32a78c0c6f16416f42975cac86fbfc23d1b1735 /anime
parent0eb32bb339f66d3416c1088d6372bc7219b6e323 (diff)
parent419e08bc3a369a0c1138871184e1a30320032afd (diff)
Merge pull request #3 from MikunoNaka/user-animelist
User animelist functions complete
Diffstat (limited to 'anime')
-rw-r--r--anime/anime.go39
-rw-r--r--anime/errhandlers.go71
-rw-r--r--anime/general.structs.go5
-rw-r--r--anime/request_handler.go (renamed from anime/util.go)38
-rw-r--r--anime/validators.go96
5 files changed, 27 insertions, 222 deletions
diff --git a/anime/anime.go b/anime/anime.go
index 90231e3..969b04c 100644
--- a/anime/anime.go
+++ b/anime/anime.go
@@ -21,28 +21,33 @@ import (
"errors"
"fmt"
"strconv"
+ e "github.com/MikunoNaka/mal2go/errhandlers"
+ u "github.com/MikunoNaka/mal2go/util"
)
const BASE_URL string = "https://api.myanimelist.net/v2/anime"
+// MAL Might change this
+const maxAnimeLimit int = 500
+
// in MAL documentation this is named Get Anime List
func (c AnimeClient) SearchAnime(searchString string, limit, offset int, fields []string) (AnimeSearch, error) {
var searchResults AnimeSearch
// error handling for limit and offset
- limitsErr := limitsErrHandler(limit, offset)
+ limitsErr := e.LimitsErrHandler(limit, offset, maxAnimeLimit)
if limitsErr != nil {
return searchResults, limitsErr
}
// handle all the errors for the fields
- fields, err := fieldsErrHandler(fields)
+ fields, err := e.FieldsErrHandler(fields)
if err != nil {
return searchResults, err
}
// generate endpoint url with custom params
- endpoint, _ := urlGenerator(
+ endpoint, _ := u.UrlGenerator(
BASE_URL,
[]string{"q", "limit", "offset", "fields"},
[][]string{{searchString}, {strconv.Itoa(limit)}, {strconv.Itoa(offset)}, fields},
@@ -74,12 +79,12 @@ func (c AnimeClient) GetAnimeById(animeId int, fields []string) (Anime, error) {
var anime Anime
// handle all the errors for the fields
- fields, err := fieldsErrHandler(fields)
+ fields, err := e.FieldsErrHandler(fields)
if err != nil {
return anime, err
}
- endpoint, _ := urlGenerator(
+ endpoint, _ := u.UrlGenerator(
BASE_URL + "/" + strconv.Itoa(animeId),
[]string{"fields"},
/* it seems to still return all fields from the API.
@@ -100,23 +105,23 @@ func (c AnimeClient) GetAnimeRanking(rankingType string, limit, offset int, fiel
var animeRanking AnimeRanking
// error handling for limit and offset
- limitsErr := limitsErrHandler(limit, offset)
+ limitsErr := e.LimitsErrHandler(limit, offset, maxAnimeLimit)
if limitsErr != nil {
return animeRanking, limitsErr
}
// handle all the errors for the fields
- fields, err := fieldsErrHandler(fields)
+ fields, err := e.FieldsErrHandler(fields)
if err != nil {
return animeRanking, err
}
// if ranking type is invalid
- if !isValidRankingType(rankingType) {
+ if !e.IsValidRankingType(rankingType) {
return animeRanking, errors.New(fmt.Sprintf("GetAnimeRanking: Invalid ranking type specified: \"%s\"", rankingType))
}
- endpoint, _ := urlGenerator(
+ endpoint, _ := u.UrlGenerator(
BASE_URL + "/ranking",
[]string{"ranking_type", "limit", "offset", "fields"},
[][]string{{rankingType}, {strconv.Itoa(limit)}, {strconv.Itoa(offset)}, fields},
@@ -157,28 +162,28 @@ func (c AnimeClient) GetSeasonalAnime(year, season, sort string, limit, offset i
var seasonalAnime SeasonalAnime
// error handling for limit and offset
- limitsErr := limitsErrHandler(limit, offset)
+ limitsErr := e.LimitsErrHandler(limit, offset, maxAnimeLimit)
if limitsErr != nil {
return seasonalAnime, limitsErr
}
// handle all the errors for the fields
- fields, err := fieldsErrHandler(fields)
+ fields, err := e.FieldsErrHandler(fields)
if err != nil {
return seasonalAnime, err
}
// checks if valid season is specified
- if !isValidSeason(season) {
+ if !e.IsValidSeason(season) {
return seasonalAnime, errors.New(fmt.Sprintf("GetSeasonalAnime: Invalid season specified: \"%s\"", season))
}
// checks if valid sort is specified
- if !isValidSort(sort) {
+ if !e.IsValidSeasonalSort(sort) {
return seasonalAnime, errors.New(fmt.Sprintf("GetSeasonalAnime: Invalid sort specified: \"%s\"", sort))
}
- endpoint, _ := urlGenerator(
+ endpoint, _ := u.UrlGenerator(
BASE_URL + fmt.Sprintf("/season/%s/%s", year, season),
[]string{"sort", "limit", "offset", "fields"},
[][]string{{sort}, {strconv.Itoa(limit)}, {strconv.Itoa(offset)}, fields},
@@ -211,18 +216,18 @@ func (c AnimeClient) GetSuggestedAnime(limit, offset int, fields []string) (Sugg
var suggestedAnime SuggestedAnime
// error handling for limit and offset
- limitsErr := limitsErrHandler(limit, offset)
+ limitsErr := e.LimitsErrHandler(limit, offset, maxAnimeLimit)
if limitsErr != nil {
return suggestedAnime, limitsErr
}
// handle all the errors for the fields
- fields, err := fieldsErrHandler(fields)
+ fields, err := e.FieldsErrHandler(fields)
if err != nil {
return suggestedAnime, err
}
- endpoint, _ := urlGenerator(
+ endpoint, _ := u.UrlGenerator(
BASE_URL + "/suggestions",
[]string{"limit", "offset", "fields"},
[][]string{{strconv.Itoa(limit)}, {strconv.Itoa(offset)}, fields},
diff --git a/anime/errhandlers.go b/anime/errhandlers.go
deleted file mode 100644
index d7f70f9..0000000
--- a/anime/errhandlers.go
+++ /dev/null
@@ -1,71 +0,0 @@
-/* mal2go - MyAnimeList V2 API wrapper for Go
- * Copyright (C) 2022 Vidhu Kant Sharma <vidhukant@protonmail.ch>
-
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
-
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
-
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>. */
-
-package anime
-
-import (
- "errors"
- "fmt"
-)
-
-/* NOTE: MAL still seems to send some fields
- * even if they aren't requested.
- * those include Title, Picture, Id, etc */
-// default fields to use when none are specified
-var defaultFields []string = []string{
- "id", "title", "main_picture",
- "alternative_titles", "start_date",
- "end_date", "synopsis", "mean", "rank",
- "popularity", "num_list_users",
- "num_scoring_users", "nsfw", "created_at",
- "updated_at", "media_type", "status",
- "genres", "my_list_status", "num_episodes",
- "start_season", "broadcast", "source",
- "average_episode_duration", "rating",
- "pictures", "background", "related_anime",
- "related_manga", "recommendations",
- "studios", "statistics",
-}
-
-// if fields aren't specified
-func fieldsErrHandler(fields []string) ([]string, error) {
- if cap(fields) == 0 {
- // uses all the default fields if none specified
- return defaultFields, nil
- }
-
- // checks if each given field is valid
- for _, j := range(fields) {
- if !isValidField(j) {
- return []string{}, errors.New(fmt.Sprintf("InvalidFieldError: Invalid field specified: \"%s\"", j))
- }
- }
-
- // everything's fine!
- return fields, nil
-}
-
-// if limit or error specified are above the limit
-func limitsErrHandler(limit, offset int) error {
- maxOffset := 500 - limit
- if limit > 500 {
- return errors.New(fmt.Sprintf("InvalidLimitError: Limit specified too high (%d > 500).", limit))
- } else if offset > maxOffset {
- return errors.New(fmt.Sprintf("InvalidOffsetError: Offset specified too high (%d > %d).", offset, maxOffset))
- }
- // return nil if no error
- return nil
-}
diff --git a/anime/general.structs.go b/anime/general.structs.go
index c49b762..5df1357 100644
--- a/anime/general.structs.go
+++ b/anime/general.structs.go
@@ -26,3 +26,8 @@ type Season struct {
Year int `json:"year"`
Name string `json:"season"`
}
+
+type AnimeList struct {
+ Animes []Anime
+ Paging ListPaging
+}
diff --git a/anime/util.go b/anime/request_handler.go
index 862b54d..809ca07 100644
--- a/anime/util.go
+++ b/anime/request_handler.go
@@ -20,7 +20,6 @@ import (
"io/ioutil"
"log"
"net/http"
- "errors"
)
// Handles HTTP request with your OAuth token as a Header
@@ -48,40 +47,3 @@ func (c AnimeClient) requestHandler(endpoint string) string {
return string(body)
}
-
-func urlGenerator(baseUrl string, names []string, values [][]string, isPrimary bool) (string, error) {
- // length of names and values should be same
- if cap(names) != cap(values) {
- return "", errors.New("urlGenerator: Error: Length of names and values don't match.")
- }
-
- var fields string
-
- for index, name := range(names) {
- var data string
- /* if the data is the first field in URL,
- * it goes like ?key=value
- * else it is &nextkey=value */
- if isPrimary {
- data = "?" + name + "="
- } else {
- data = "&" + name + "="
- }
-
- // add values to data variable
- for i, j := range values[index] {
- if i > 0 {
- data = data + "," + j
- } else {
- data = data + j
- }
- }
-
- fields = fields + data
-
- // from now on all other fields will be secondary
- isPrimary = false
- }
-
- return baseUrl + fields, nil
-}
diff --git a/anime/validators.go b/anime/validators.go
deleted file mode 100644
index 7f6a7cc..0000000
--- a/anime/validators.go
+++ /dev/null
@@ -1,96 +0,0 @@
-/* mal2go - MyAnimeList V2 API wrapper for Go
- * Copyright (C) 2022 Vidhu Kant Sharma <vidhukant@protonmail.ch>
-
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
-
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
-
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>. */
-
-package anime
-
-// Checks if given rankingType is valid
-func isValidRankingType(rankingType string) bool {
- switch rankingType {
- case
- "all",
- "airing",
- "upcoming",
- "tv",
- "ova",
- "movie",
- "special",
- "bypopularity",
- "favorite": return true
- }
- return false
-}
-
-// Checks if given rankingType is valid
-func isValidField(field string) bool {
- switch field {
- case
- "id",
- "title",
- "main_picture",
- "alternative_titles",
- "start_date",
- "end_date",
- "synopsis",
- "mean",
- "rank",
- "popularity",
- "num_list_users",
- "num_scoring_users",
- "nsfw",
- "created_at",
- "updated_at",
- "media_type",
- "status",
- "genres",
- "my_list_status",
- "num_episodes",
- "start_season",
- "broadcast",
- "source",
- "average_episode_duration",
- "rating",
- "pictures",
- "background",
- "related_anime",
- "related_manga",
- "recommendations",
- "studios",
- "statistics": return true
- }
- return false
-}
-
-// Checks if given season is valid
-func isValidSeason(season string) bool {
- switch season {
- case
- "winter",
- "spring",
- "summer",
- "fall": return true
- }
- return false
-}
-
-// Checks if given sort is valid
-func isValidSort(sort string) bool {
- switch sort {
- case
- "anime_score",
- "anime_num_list_users": return true
- }
- return false
-}