diff options
author | Vidhu Kant Sharma <vidhukant@protonmail.ch> | 2022-02-23 21:32:44 +0530 |
---|---|---|
committer | Vidhu Kant Sharma <vidhukant@protonmail.ch> | 2022-02-23 21:32:44 +0530 |
commit | e21dc47f2fe1dd3b1ad47224cd9cc3e75d0835fb (patch) | |
tree | 1bbc1d2b57c7eb8a7a36feb51ce0656cf49faf8a /errhandlers | |
parent | 7a68abbc9e492934cf4170d5a0ff52a456fe92bd (diff) |
finalized manga package with all the endpoints added
Diffstat (limited to 'errhandlers')
-rw-r--r-- | errhandlers/anime_validators.go (renamed from errhandlers/validators.go) | 2 | ||||
-rw-r--r-- | errhandlers/errhandlers.go | 22 | ||||
-rw-r--r-- | errhandlers/manga_validators.go | 70 |
3 files changed, 92 insertions, 2 deletions
diff --git a/errhandlers/validators.go b/errhandlers/anime_validators.go index 4e4137d..b51afa6 100644 --- a/errhandlers/validators.go +++ b/errhandlers/anime_validators.go @@ -33,7 +33,7 @@ func IsValidRankingType(rankingType string) bool { return false } -// Checks if given rankingType is valid +// Checks if given field is valid func IsValidField(field string) bool { switch field { case diff --git a/errhandlers/errhandlers.go b/errhandlers/errhandlers.go index 14c1d33..5f4db25 100644 --- a/errhandlers/errhandlers.go +++ b/errhandlers/errhandlers.go @@ -22,8 +22,9 @@ import ( "github.com/MikunoNaka/MAL2Go/util" ) -// if fields aren't specified +// this is only for anime fields func FieldsErrHandler(fields []string) ([]string, error) { + // if fields aren't specified if cap(fields) == 0 { // uses all the default fields if none specified return util.DefaultFields, nil @@ -40,6 +41,25 @@ func FieldsErrHandler(fields []string) ([]string, error) { return fields, nil } +// only for manga fields +func MangaFieldsErrHandler(fields []string) ([]string, error) { + // if fields aren't specified + if cap(fields) == 0 { + // uses all the default fields if none specified + return util.DefaultMangaFields, nil + } + + // checks if each given field is valid + for _, j := range(fields) { + if !IsValidMangaField(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 LimitErrHandler(limit, maxLimit int) error { if limit > maxLimit { diff --git a/errhandlers/manga_validators.go b/errhandlers/manga_validators.go new file mode 100644 index 0000000..fa12e5f --- /dev/null +++ b/errhandlers/manga_validators.go @@ -0,0 +1,70 @@ +/* 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 errhandlers + +// Checks if given field is valid +func IsValidMangaField(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_volumes", + "num_chapters", + "authors", + "pictures", + "background", + "related_anime", + "related_manga", + "recommendations", + "serialization": return true + } + return false +} + +// Checks if given ranking type is valid +func IsValidMangaRankingType(rankingType string) bool { + switch rankingType { + case + "all", + "manga", + "novels", + "oneshots", + "doujin", + "manhwa", + "manhua", + "bypopularity", + "favorite": return true + } + return false +} |