themoviedb-api 0.7.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +90 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/.travis.yml +6 -0
- data/Gemfile +4 -0
- data/Gemfile.lock +64 -0
- data/README.md +6 -0
- data/lib/tmdb.rb +62 -0
- data/lib/tmdb/account.rb +4 -0
- data/lib/tmdb/api.rb +26 -0
- data/lib/tmdb/authentication.rb +4 -0
- data/lib/tmdb/backdrop.rb +4 -0
- data/lib/tmdb/certification.rb +27 -0
- data/lib/tmdb/change.rb +44 -0
- data/lib/tmdb/change_item.rb +4 -0
- data/lib/tmdb/collection.rb +32 -0
- data/lib/tmdb/company.rb +21 -0
- data/lib/tmdb/configuration.rb +10 -0
- data/lib/tmdb/country.rb +4 -0
- data/lib/tmdb/credit.rb +26 -0
- data/lib/tmdb/discover.rb +27 -0
- data/lib/tmdb/error.rb +4 -0
- data/lib/tmdb/find.rb +47 -0
- data/lib/tmdb/genre.rb +32 -0
- data/lib/tmdb/image.rb +25 -0
- data/lib/tmdb/job.rb +13 -0
- data/lib/tmdb/keyword.rb +21 -0
- data/lib/tmdb/language.rb +4 -0
- data/lib/tmdb/list.rb +4 -0
- data/lib/tmdb/media.rb +4 -0
- data/lib/tmdb/movie.rb +173 -0
- data/lib/tmdb/multi.rb +4 -0
- data/lib/tmdb/network.rb +10 -0
- data/lib/tmdb/person.rb +91 -0
- data/lib/tmdb/poster.rb +4 -0
- data/lib/tmdb/rating.rb +4 -0
- data/lib/tmdb/release.rb +4 -0
- data/lib/tmdb/resource.rb +30 -0
- data/lib/tmdb/review.rb +10 -0
- data/lib/tmdb/search.rb +69 -0
- data/lib/tmdb/struct.rb +30 -0
- data/lib/tmdb/translation.rb +4 -0
- data/lib/tmdb/tv.rb +165 -0
- data/lib/tmdb/tv/episode.rb +89 -0
- data/lib/tmdb/tv/season.rb +91 -0
- data/lib/tmdb/utils.rb +50 -0
- data/lib/tmdb/version.rb +3 -0
- data/lib/tmdb/video.rb +4 -0
- data/spec/api_spec.rb +44 -0
- data/spec/certification_spec.rb +62 -0
- data/spec/change_spec.rb +71 -0
- data/spec/collection_spec.rb +69 -0
- data/spec/company_spec.rb +50 -0
- data/spec/configuration_spec.rb +43 -0
- data/spec/credit_spec.rb +49 -0
- data/spec/discover_spec.rb +54 -0
- data/spec/find_spec.rb +105 -0
- data/spec/genre_spec.rb +75 -0
- data/spec/job_spec.rb +39 -0
- data/spec/keyword_spec.rb +52 -0
- data/spec/movie_spec.rb +362 -0
- data/spec/network_spec.rb +33 -0
- data/spec/person_spec.rb +201 -0
- data/spec/resource_spec.rb +47 -0
- data/spec/review_spec.rb +33 -0
- data/spec/search_spec.rb +161 -0
- data/spec/spec_helper.rb +37 -0
- data/spec/tv/episode_spec.rb +154 -0
- data/spec/tv/season_spec.rb +144 -0
- data/spec/tv_spec.rb +352 -0
- data/spec/vcr/certification/movie_list.yml +305 -0
- data/spec/vcr/certification/tv_list.yml +318 -0
- data/spec/vcr/change/movie.yml +58 -0
- data/spec/vcr/change/person.yml +58 -0
- data/spec/vcr/change/tv.yml +58 -0
- data/spec/vcr/collection/backdrops.yml +58 -0
- data/spec/vcr/collection/detail.yml +73 -0
- data/spec/vcr/collection/posters.yml +58 -0
- data/spec/vcr/company/detail.yml +56 -0
- data/spec/vcr/company/movies.yml +363 -0
- data/spec/vcr/configuration/get.yml +50 -0
- data/spec/vcr/credit/detail.yml +61 -0
- data/spec/vcr/discover/movie.yml +361 -0
- data/spec/vcr/discover/tv.yml +401 -0
- data/spec/vcr/find/movie.yml +64 -0
- data/spec/vcr/find/people.yml +114 -0
- data/spec/vcr/find/tv_episode.yml +66 -0
- data/spec/vcr/find/tv_season.yml +66 -0
- data/spec/vcr/find/tv_serie.yml +79 -0
- data/spec/vcr/genre/movie_list.yml +57 -0
- data/spec/vcr/genre/movies.yml +330 -0
- data/spec/vcr/genre/tv_list.yml +58 -0
- data/spec/vcr/job/list.yml +128 -0
- data/spec/vcr/keyword/detail.yml +56 -0
- data/spec/vcr/keyword/movies.yml +344 -0
- data/spec/vcr/movie/alternative_titles.yml +69 -0
- data/spec/vcr/movie/backdrops.yml +58 -0
- data/spec/vcr/movie/cast.yml +225 -0
- data/spec/vcr/movie/changes.yml +57 -0
- data/spec/vcr/movie/crew.yml +225 -0
- data/spec/vcr/movie/detail.yml +69 -0
- data/spec/vcr/movie/director.yml +225 -0
- data/spec/vcr/movie/keywords.yml +57 -0
- data/spec/vcr/movie/latest.yml +60 -0
- data/spec/vcr/movie/lists.yml +157 -0
- data/spec/vcr/movie/now_playing.yml +331 -0
- data/spec/vcr/movie/popular.yml +361 -0
- data/spec/vcr/movie/posters.yml +58 -0
- data/spec/vcr/movie/releases.yml +57 -0
- data/spec/vcr/movie/reviews.yml +56 -0
- data/spec/vcr/movie/similar.yml +354 -0
- data/spec/vcr/movie/top_rated.yml +343 -0
- data/spec/vcr/movie/translations.yml +96 -0
- data/spec/vcr/movie/upcoming.yml +313 -0
- data/spec/vcr/movie/videos.yml +57 -0
- data/spec/vcr/network/detail.yml +56 -0
- data/spec/vcr/person/changes.yml +61 -0
- data/spec/vcr/person/combined_credits.yml +317 -0
- data/spec/vcr/person/detail.yml +72 -0
- data/spec/vcr/person/external_ids.yml +56 -0
- data/spec/vcr/person/images.yml +56 -0
- data/spec/vcr/person/latest.yml +61 -0
- data/spec/vcr/person/movie_credits.yml +293 -0
- data/spec/vcr/person/popular.yml +1116 -0
- data/spec/vcr/person/tagged_images.yml +458 -0
- data/spec/vcr/person/tv_credits.yml +82 -0
- data/spec/vcr/resource/configuration_get.yml +50 -0
- data/spec/vcr/review/detail.yml +66 -0
- data/spec/vcr/search/collection.yml +58 -0
- data/spec/vcr/search/company.yml +70 -0
- data/spec/vcr/search/keyword.yml +61 -0
- data/spec/vcr/search/list.yml +70 -0
- data/spec/vcr/search/movie.yml +335 -0
- data/spec/vcr/search/multi.yml +219 -0
- data/spec/vcr/search/person.yml +117 -0
- data/spec/vcr/search/tv.yml +300 -0
- data/spec/vcr/tv/airing_today.yml +503 -0
- data/spec/vcr/tv/alternative_titles.yml +59 -0
- data/spec/vcr/tv/backdrops.yml +58 -0
- data/spec/vcr/tv/cast.yml +86 -0
- data/spec/vcr/tv/changes.yml +58 -0
- data/spec/vcr/tv/content_ratings.yml +56 -0
- data/spec/vcr/tv/crew.yml +86 -0
- data/spec/vcr/tv/detail.yml +71 -0
- data/spec/vcr/tv/episode/cast.yml +70 -0
- data/spec/vcr/tv/episode/changes.yml +66 -0
- data/spec/vcr/tv/episode/crew.yml +70 -0
- data/spec/vcr/tv/episode/detail.yml +68 -0
- data/spec/vcr/tv/episode/external_ids.yml +56 -0
- data/spec/vcr/tv/episode/guest_stars.yml +70 -0
- data/spec/vcr/tv/episode/posters.yml +58 -0
- data/spec/vcr/tv/episode/videos.yml +56 -0
- data/spec/vcr/tv/external_ids.yml +56 -0
- data/spec/vcr/tv/keywords.yml +59 -0
- data/spec/vcr/tv/latest.yml +97 -0
- data/spec/vcr/tv/on_the_air.yml +421 -0
- data/spec/vcr/tv/popular.yml +401 -0
- data/spec/vcr/tv/posters.yml +58 -0
- data/spec/vcr/tv/season/cast.yml +69 -0
- data/spec/vcr/tv/season/changes.yml +69 -0
- data/spec/vcr/tv/season/crew.yml +69 -0
- data/spec/vcr/tv/season/detail.yml +649 -0
- data/spec/vcr/tv/season/external_ids.yml +56 -0
- data/spec/vcr/tv/season/posters.yml +58 -0
- data/spec/vcr/tv/season/videos.yml +72 -0
- data/spec/vcr/tv/similar.yml +441 -0
- data/spec/vcr/tv/top_rated.yml +454 -0
- data/spec/vcr/tv/translations.yml +95 -0
- data/spec/vcr/tv/videos.yml +57 -0
- data/themoviedb-api.gemspec +30 -0
- metadata +433 -0
data/lib/tmdb/country.rb
ADDED
data/lib/tmdb/credit.rb
ADDED
@@ -0,0 +1,26 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Credit < Struct
|
3
|
+
|
4
|
+
def self.detail(id, filters={})
|
5
|
+
result = Resource.new("/credit/#{id}", filters).get
|
6
|
+
|
7
|
+
media = result['media']
|
8
|
+
|
9
|
+
credit = self.new(result.except('media', 'person'))
|
10
|
+
credit.media = Media.new(media.except('episodes', 'seasons'))
|
11
|
+
|
12
|
+
credit.media.episodes = media['episodes'].map do |episode|
|
13
|
+
Tv::Episode.new(episode)
|
14
|
+
end
|
15
|
+
|
16
|
+
credit.media.seasons = media['seasons'].map do |season|
|
17
|
+
Tv::Season.new(season)
|
18
|
+
end
|
19
|
+
|
20
|
+
credit.person = Person.new(result['person'])
|
21
|
+
|
22
|
+
credit
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Discover < Struct
|
3
|
+
|
4
|
+
def self.movie(filters={})
|
5
|
+
result = Resource.new('/discover/movie', filters).get
|
6
|
+
|
7
|
+
discover = self.new(result.except('results'))
|
8
|
+
discover.results = result['results'].map do |result|
|
9
|
+
Movie.new(result)
|
10
|
+
end
|
11
|
+
|
12
|
+
discover
|
13
|
+
end
|
14
|
+
|
15
|
+
def self.tv(filters={})
|
16
|
+
result = Resource.new('/discover/tv', filters).get
|
17
|
+
|
18
|
+
discover = self.new(result.except('results'))
|
19
|
+
discover.results = result['results'].map do |result|
|
20
|
+
TV.new(result)
|
21
|
+
end
|
22
|
+
|
23
|
+
discover
|
24
|
+
end
|
25
|
+
|
26
|
+
end
|
27
|
+
end
|
data/lib/tmdb/error.rb
ADDED
data/lib/tmdb/find.rb
ADDED
@@ -0,0 +1,47 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Find < Struct
|
3
|
+
|
4
|
+
def self.movie(id, filters={})
|
5
|
+
result = Resource.new("/find/#{id}", filters).get
|
6
|
+
|
7
|
+
result['movie_results'].map do |entry|
|
8
|
+
Movie.new(entry)
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
def self.people(id, filters={})
|
13
|
+
result = Resource.new("/find/#{id}", filters).get
|
14
|
+
|
15
|
+
result['person_results'].map do |entry|
|
16
|
+
person = Person.new(entry)
|
17
|
+
person.convert_known_for!
|
18
|
+
person
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def self.tv_serie(id, filters={})
|
23
|
+
result = Resource.new("/find/#{id}", filters).get
|
24
|
+
|
25
|
+
result['tv_results'].map do |entry|
|
26
|
+
TV.new(entry)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def self.tv_season(id, filters={})
|
31
|
+
result = Resource.new("/find/#{id}", filters).get
|
32
|
+
|
33
|
+
result['tv_episode_results'].map do |entry|
|
34
|
+
TV.new(entry)
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
def self.tv_episode(id, filters={})
|
39
|
+
result = Resource.new("/find/#{id}", filters).get
|
40
|
+
|
41
|
+
result['tv_season_results'].map do |entry|
|
42
|
+
TV.new(entry)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
47
|
+
end
|
data/lib/tmdb/genre.rb
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Genre < Struct
|
3
|
+
|
4
|
+
def self.movie_list(filters={})
|
5
|
+
result = Resource.new('/genre/movie/list', filters).get
|
6
|
+
|
7
|
+
result['genres'].map do |genre|
|
8
|
+
self.new(genre)
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
def self.tv_list(filters={})
|
13
|
+
result = Resource.new('/genre/tv/list', filters).get
|
14
|
+
|
15
|
+
result['genres'].map do |genre|
|
16
|
+
self.new(genre)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.movies(genre_id, filters={})
|
21
|
+
result = Resource.new("/genre/#{genre_id}/movies", filters).get
|
22
|
+
|
23
|
+
genre = self.new(result.except('results'))
|
24
|
+
genre.results = result['results'].map do |movie|
|
25
|
+
Movie.new(movie)
|
26
|
+
end
|
27
|
+
|
28
|
+
genre
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
end
|
data/lib/tmdb/image.rb
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Image < Struct
|
3
|
+
|
4
|
+
def convert_media_multiple!
|
5
|
+
results.each do |result|
|
6
|
+
media_type = find_media_type(result)
|
7
|
+
result.media = media_type.new(result.media.to_h)
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
private
|
12
|
+
|
13
|
+
def find_media_type(obj)
|
14
|
+
case obj.media_type
|
15
|
+
when 'movie'
|
16
|
+
Movie
|
17
|
+
when 'tv'
|
18
|
+
TV
|
19
|
+
else
|
20
|
+
Multi
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
data/lib/tmdb/job.rb
ADDED
data/lib/tmdb/keyword.rb
ADDED
@@ -0,0 +1,21 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Keyword < Struct
|
3
|
+
|
4
|
+
def self.detail(keyword_id, filters={})
|
5
|
+
result = Resource.new("/keyword/#{keyword_id}", filters).get
|
6
|
+
self.new(result)
|
7
|
+
end
|
8
|
+
|
9
|
+
def self.movies(keyword_id, filters={})
|
10
|
+
result = Resource.new("/keyword/#{keyword_id}/movies", filters).get
|
11
|
+
|
12
|
+
keyword = self.new(result.except('results'))
|
13
|
+
keyword.results = result['results'].map do |movie|
|
14
|
+
Movie.new(movie)
|
15
|
+
end
|
16
|
+
|
17
|
+
keyword
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
end
|
data/lib/tmdb/list.rb
ADDED
data/lib/tmdb/media.rb
ADDED
data/lib/tmdb/movie.rb
ADDED
@@ -0,0 +1,173 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Movie < Struct
|
3
|
+
|
4
|
+
def self.detail(id, filters={})
|
5
|
+
result = Resource.new("/movie/#{id}", filters).get
|
6
|
+
|
7
|
+
create_new_instance_with_normalized_data(result)
|
8
|
+
end
|
9
|
+
|
10
|
+
def self.alternative_titles(id, filters={})
|
11
|
+
result = Resource.new("/movie/#{id}/alternative_titles", filters).get
|
12
|
+
|
13
|
+
result['titles'].map do |entry|
|
14
|
+
self.new(entry)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
def self.cast(id, filters={})
|
19
|
+
result = Resource.new("/movie/#{id}/credits", filters).get
|
20
|
+
|
21
|
+
result['cast'].map do |entry|
|
22
|
+
Person.new(entry)
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
def self.crew(id, filters={})
|
27
|
+
result = Resource.new("/movie/#{id}/credits", filters).get
|
28
|
+
|
29
|
+
result['crew'].map do |entry|
|
30
|
+
Person.new(entry)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.director(id, filters={})
|
35
|
+
result = Resource.new("/movie/#{id}/credits", filters).get
|
36
|
+
|
37
|
+
result['crew'].select{ |x| x['job'] == 'Director' }.map do |entry|
|
38
|
+
Person.new(entry)
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
def self.backdrops(id, filters={})
|
43
|
+
result = Resource.new("/movie/#{id}/images", filters).get
|
44
|
+
|
45
|
+
result['backdrops'].map do |entry|
|
46
|
+
Backdrop.new(entry)
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
def self.posters(id, filters={})
|
51
|
+
result = Resource.new("/movie/#{id}/images", filters).get
|
52
|
+
|
53
|
+
result['posters'].map do |entry|
|
54
|
+
Poster.new(entry)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
def self.videos(id, filters={})
|
59
|
+
result = Resource.new("/movie/#{id}/videos", filters).get
|
60
|
+
|
61
|
+
result['results'].map do |entry|
|
62
|
+
Video.new(entry)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
def self.keywords(id, filters={})
|
67
|
+
result = Resource.new("/movie/#{id}/keywords", filters).get
|
68
|
+
|
69
|
+
result['keywords'].map do |entry|
|
70
|
+
Keyword.new(entry)
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
def self.releases(id, filters={})
|
75
|
+
result = Resource.new("/movie/#{id}/releases", filters).get
|
76
|
+
|
77
|
+
result['countries'].map do |entry|
|
78
|
+
Release.new(entry)
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
def self.translations(id, filters={})
|
83
|
+
result = Resource.new("/movie/#{id}/translations", filters).get
|
84
|
+
|
85
|
+
result['translations'].map do |entry|
|
86
|
+
Translation.new(entry)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
def self.similar(id, filters={})
|
91
|
+
result = Resource.new("/movie/#{id}/similar", filters).get
|
92
|
+
self.new(result)
|
93
|
+
end
|
94
|
+
|
95
|
+
def self.reviews(id, filters={})
|
96
|
+
result = Resource.new("/movie/#{id}/reviews", filters).get
|
97
|
+
Review.new(result)
|
98
|
+
end
|
99
|
+
|
100
|
+
def self.lists(id, filters={})
|
101
|
+
result = Resource.new("/movie/#{id}/lists", filters).get
|
102
|
+
Tmdb::List.new(result)
|
103
|
+
end
|
104
|
+
|
105
|
+
def self.changes(id, filters={})
|
106
|
+
result = Resource.new("/movie/#{id}/changes", filters).get
|
107
|
+
|
108
|
+
result['changes'].map do |entry|
|
109
|
+
change = Change.new(entry)
|
110
|
+
change.convert_items!
|
111
|
+
change
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
def self.latest(filters={})
|
116
|
+
result = Resource.new('/movie/latest', filters).get
|
117
|
+
|
118
|
+
create_new_instance_with_normalized_data(result)
|
119
|
+
end
|
120
|
+
|
121
|
+
def self.upcoming(filters={})
|
122
|
+
result = Resource.new('/movie/upcoming', filters).get
|
123
|
+
self.new(result)
|
124
|
+
end
|
125
|
+
|
126
|
+
def self.now_playing(filters={})
|
127
|
+
result = Resource.new('/movie/now_playing', filters).get
|
128
|
+
self.new(result)
|
129
|
+
end
|
130
|
+
|
131
|
+
def self.popular(filters={})
|
132
|
+
result = Resource.new('/movie/popular', filters).get
|
133
|
+
self.new(result)
|
134
|
+
end
|
135
|
+
|
136
|
+
def self.top_rated(filters={})
|
137
|
+
result = Resource.new('/movie/top_rated', filters).get
|
138
|
+
self.new(result)
|
139
|
+
end
|
140
|
+
|
141
|
+
def self.create_new_instance_with_normalized_data(result)
|
142
|
+
movie = self.new(
|
143
|
+
result.except(
|
144
|
+
'genres',
|
145
|
+
'production_companies',
|
146
|
+
'production_countries',
|
147
|
+
'spoken_languages'
|
148
|
+
)
|
149
|
+
)
|
150
|
+
|
151
|
+
movie.genres = result['genres'].map do |genre|
|
152
|
+
Genre.new(genre)
|
153
|
+
end
|
154
|
+
|
155
|
+
movie.production_companies = result['production_companies'].map do |company|
|
156
|
+
Company.new(company)
|
157
|
+
end
|
158
|
+
|
159
|
+
movie.production_countries = result['production_countries'].map do |country|
|
160
|
+
Country.new(country)
|
161
|
+
end
|
162
|
+
|
163
|
+
movie.spoken_languages = result['spoken_languages'].map do |language|
|
164
|
+
Language.new(language)
|
165
|
+
end
|
166
|
+
|
167
|
+
movie
|
168
|
+
end
|
169
|
+
|
170
|
+
private_class_method :create_new_instance_with_normalized_data
|
171
|
+
|
172
|
+
end
|
173
|
+
end
|
data/lib/tmdb/multi.rb
ADDED
data/lib/tmdb/network.rb
ADDED
data/lib/tmdb/person.rb
ADDED
@@ -0,0 +1,91 @@
|
|
1
|
+
module Tmdb
|
2
|
+
class Person < Struct
|
3
|
+
|
4
|
+
def self.detail(id, filters={})
|
5
|
+
result = Resource.new("/person/#{id}", filters).get
|
6
|
+
self.new(result)
|
7
|
+
end
|
8
|
+
|
9
|
+
def self.movie_credits(id, filters={})
|
10
|
+
result = Resource.new("/person/#{id}/movie_credits", filters).get
|
11
|
+
self.new(result)
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.tv_credits(id, filters={})
|
15
|
+
result = Resource.new("/person/#{id}/tv_credits", filters).get
|
16
|
+
self.new(result)
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.combined_credits(id, filters={})
|
20
|
+
result = Resource.new("/person/#{id}/combined_credits", filters).get
|
21
|
+
self.new(result)
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.external_ids(id, filters={})
|
25
|
+
result = Resource.new("/person/#{id}/external_ids", filters).get
|
26
|
+
self.new(result)
|
27
|
+
end
|
28
|
+
|
29
|
+
def self.images(id, filters={})
|
30
|
+
result = Resource.new("/person/#{id}/images", filters).get
|
31
|
+
Image.new(result)
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.tagged_images(id, filters={})
|
35
|
+
result = Resource.new("/person/#{id}/tagged_images", filters).get
|
36
|
+
image = Image.new(result)
|
37
|
+
image.convert_media_multiple!
|
38
|
+
image
|
39
|
+
end
|
40
|
+
|
41
|
+
def self.changes(id, filters={})
|
42
|
+
result = Resource.new("/person/#{id}/changes", filters).get
|
43
|
+
|
44
|
+
result['changes'].map do |entry|
|
45
|
+
change = Change.new(entry)
|
46
|
+
change.convert_items!
|
47
|
+
change
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
def self.popular(filters={})
|
52
|
+
result = Resource.new('/person/popular', filters).get
|
53
|
+
person = self.new(result)
|
54
|
+
person.convert_known_for_multiple!
|
55
|
+
person
|
56
|
+
end
|
57
|
+
|
58
|
+
def self.latest(filters={})
|
59
|
+
result = Resource.new('/person/latest', filters).get
|
60
|
+
self.new(result)
|
61
|
+
end
|
62
|
+
|
63
|
+
def convert_known_for!
|
64
|
+
known_for.map! do |multi|
|
65
|
+
known_person_reference(multi)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
def convert_known_for_multiple!
|
70
|
+
results.each do |result|
|
71
|
+
result.known_for.map! do |multi|
|
72
|
+
known_person_reference(multi)
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
private
|
78
|
+
|
79
|
+
def known_person_reference(obj)
|
80
|
+
case obj.media_type
|
81
|
+
when 'movie'
|
82
|
+
Movie.new(obj.to_h)
|
83
|
+
when 'tv'
|
84
|
+
TV.new(obj.to_h)
|
85
|
+
else
|
86
|
+
Multi.new(obj.to_h)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
end
|
91
|
+
end
|