MalConvert

This commit is contained in:
daru
2022-04-16 19:20:19 +02:00
parent 95baa2f40c
commit 1910cb3079
2 changed files with 61 additions and 15 deletions

View File

@@ -12,28 +12,31 @@ import (
"github.com/valyala/fasthttp"
)
func GetAnimeDetailData(animeId int64) (*AnimeDetailMal, []byte, error) {
var anime AnimeDetailMal
body, err := GetAnimeDetailBytesCached(animeId)
if err != nil {
return nil, body, err
}
err = json.Unmarshal(body, &anime)
return &anime, body, err
}
func GetAnimeDetailBytesCached(animeId int64) ([]byte, error) {
func GetAnimeDetailData(animeId int64) (*Anime, []byte, error) {
var anime Anime
key := strconv.FormatInt(animeId, 10)
data, err := animeCache.Get(key)
if err != nil {
data, err = GetDataMal(animeApiMal + key + "?fields=id,title,main_picture,alternative_titles,start_date,end_date,synopsis,mean,rank,popularity,num_list_users,num_scoring_users,nsfw,media_type,status,genres,my_list_status,num_episodes,start_season,broadcast,source,average_episode_duration,rating,studios")
dataMal, err := GetDataMal(animeApiMal + key + "?fields=id,title,main_picture,alternative_titles,start_date,end_date,synopsis,mean,rank,popularity,num_list_users,num_scoring_users,nsfw,media_type,status,genres,my_list_status,num_episodes,start_season,broadcast,source,average_episode_duration,rating,studios")
if err != nil {
return data, err
return nil, nil, err
}
var animeMal AnimeDetailMal
err = json.Unmarshal(dataMal, &animeMal)
if err != nil {
return nil, nil, err
}
// convert to anime
anime = MalConvert(&animeMal)
data, err = json.Marshal(&anime)
if err != nil {
return &anime, data, err
}
animeCache.Set(key, data)
return data, err
} else {
err = json.Unmarshal(data, &anime)
}
return data, err
return &anime, data, err
}
func GetUserAnimeListData(username, status string) (*AnimeListMal, []byte, error) {