feat(anime): add episode api support

This commit is contained in:
2026-04-18 05:54:15 +02:00
parent df3a6e3610
commit 9eb3e21ffa
4 changed files with 102 additions and 0 deletions

View File

@@ -207,11 +207,41 @@ func (h *Handler) HandleAPIAnime(w http.ResponseWriter, r *http.Request) {
return
}
templates.AnimeRecommendations(recs).Render(r.Context(), w)
case "episodes":
currentEpisode := r.URL.Query().Get("current")
episodes, err := h.svc.GetEpisodes(r.Context(), id)
if err != nil {
log.Printf("episodes error for %d: %v", id, err)
writeInlineLoadError(w, "Failed to load episodes.")
return
}
templates.EpisodeList(episodes, currentEpisode, id).Render(r.Context(), w)
default:
renderNotFoundPage(r, w)
}
}
func (h *Handler) HandleAPIEpisodes(w http.ResponseWriter, r *http.Request) {
path := r.URL.Path[len("/api/episodes/"):]
path = strings.Trim(path, "/")
id, err := strconv.Atoi(path)
if err != nil || id <= 0 {
http.Error(w, "invalid id", http.StatusBadRequest)
return
}
currentEpisode := r.URL.Query().Get("current")
episodes, err := h.svc.GetEpisodes(r.Context(), id)
if err != nil {
log.Printf("episodes error for %d: %v", id, err)
writeInlineLoadError(w, "Failed to load episodes.")
return
}
templates.EpisodeList(episodes, currentEpisode, id).Render(r.Context(), w)
}
func (h *Handler) HandleQuickSearch(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/json")

View File

@@ -144,3 +144,28 @@ func (s *Service) GetAnimeByProducer(ctx context.Context, producerID int, page i
func (s *Service) GetProducerByID(ctx context.Context, producerID int) (jikan.ProducerResponse, error) {
return s.jikanClient.GetProducerByID(ctx, producerID)
}
func (s *Service) GetEpisodes(ctx context.Context, animeID int) ([]jikan.Episode, error) {
var allEpisodes []jikan.Episode
page := 1
for page <= 20 {
result, err := s.jikanClient.GetEpisodes(ctx, animeID, page)
if err != nil {
if jikan.IsRetryableError(err) && len(allEpisodes) > 0 {
// Return what we have if we're getting rate limited
return allEpisodes, nil
}
return nil, err
}
allEpisodes = append(allEpisodes, result.Data...)
if !result.Pagination.HasNextPage {
break
}
page++
}
return allEpisodes, nil
}