refactor: move producer type and method out of studio.go
This commit is contained in:
@@ -27,6 +27,21 @@ type ProducerListResult struct {
|
|||||||
HasNextPage bool
|
HasNextPage bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) GetProducerByID(ctx context.Context, id int) (ProducerResponse, error) {
|
||||||
|
if id <= 0 {
|
||||||
|
return ProducerResponse{}, fmt.Errorf("invalid producer id")
|
||||||
|
}
|
||||||
|
|
||||||
|
cacheKey := fmt.Sprintf("producer:%d", id)
|
||||||
|
reqURL := fmt.Sprintf("%s/producers/%d", c.baseURL, id)
|
||||||
|
|
||||||
|
var result ProducerResponse
|
||||||
|
if err := c.getWithCache(ctx, cacheKey, producerCacheTTL, reqURL, &result); err != nil {
|
||||||
|
return ProducerResponse{}, err
|
||||||
|
}
|
||||||
|
return result, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (c *Client) GetProducers(ctx context.Context, query string, page int, limit int) (ProducerListResult, error) {
|
func (c *Client) GetProducers(ctx context.Context, query string, page int, limit int) (ProducerListResult, error) {
|
||||||
if page < 1 {
|
if page < 1 {
|
||||||
page = 1
|
page = 1
|
||||||
|
|||||||
@@ -1,44 +0,0 @@
|
|||||||
package jikan
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"fmt"
|
|
||||||
)
|
|
||||||
|
|
||||||
type ProducerResponse struct {
|
|
||||||
Data struct {
|
|
||||||
MalID int `json:"mal_id"`
|
|
||||||
Titles []struct {
|
|
||||||
Type string `json:"type"`
|
|
||||||
Title string `json:"title"`
|
|
||||||
} `json:"titles"`
|
|
||||||
Images struct {
|
|
||||||
Jpg struct {
|
|
||||||
ImageURL string `json:"image_url"`
|
|
||||||
} `json:"jpg"`
|
|
||||||
} `json:"images"`
|
|
||||||
Favorites int `json:"favorites"`
|
|
||||||
Established string `json:"established"`
|
|
||||||
About string `json:"about"`
|
|
||||||
Count int `json:"count"`
|
|
||||||
External []struct {
|
|
||||||
Name string `json:"name"`
|
|
||||||
URL string `json:"url"`
|
|
||||||
} `json:"external"`
|
|
||||||
} `json:"data"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Client) GetProducerByID(ctx context.Context, id int) (ProducerResponse, error) {
|
|
||||||
if id <= 0 {
|
|
||||||
return ProducerResponse{}, fmt.Errorf("invalid producer id")
|
|
||||||
}
|
|
||||||
|
|
||||||
cacheKey := fmt.Sprintf("producer:%d", id)
|
|
||||||
reqURL := fmt.Sprintf("%s/producers/%d", c.baseURL, id)
|
|
||||||
|
|
||||||
var result ProducerResponse
|
|
||||||
if err := c.getWithCache(ctx, cacheKey, producerCacheTTL, reqURL, &result); err != nil {
|
|
||||||
return ProducerResponse{}, err
|
|
||||||
}
|
|
||||||
return result, nil
|
|
||||||
}
|
|
||||||
@@ -22,6 +22,29 @@ type StudioAnimeResult struct {
|
|||||||
StudioName string
|
StudioName string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ProducerResponse struct {
|
||||||
|
Data struct {
|
||||||
|
MalID int `json:"mal_id"`
|
||||||
|
Titles []struct {
|
||||||
|
Type string `json:"type"`
|
||||||
|
Title string `json:"title"`
|
||||||
|
} `json:"titles"`
|
||||||
|
Images struct {
|
||||||
|
Jpg struct {
|
||||||
|
ImageURL string `json:"image_url"`
|
||||||
|
} `json:"jpg"`
|
||||||
|
} `json:"images"`
|
||||||
|
Favorites int `json:"favorites"`
|
||||||
|
Established string `json:"established"`
|
||||||
|
About string `json:"about"`
|
||||||
|
Count int `json:"count"`
|
||||||
|
External []struct {
|
||||||
|
Name string `json:"name"`
|
||||||
|
URL string `json:"url"`
|
||||||
|
} `json:"external"`
|
||||||
|
} `json:"data"`
|
||||||
|
}
|
||||||
|
|
||||||
type NamedEntity struct {
|
type NamedEntity struct {
|
||||||
MalID int `json:"mal_id"`
|
MalID int `json:"mal_id"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
|
|||||||
Reference in New Issue
Block a user