KinopoiskAPI 0.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: a41c8734f9653823ce0e560fa5b777755c467d60
4
+ data.tar.gz: d87d914b44b4216a11ddf62517be3d81247a6d93
5
+ SHA512:
6
+ metadata.gz: ffe472ac7542471a208e31fe938b95ece6582f60f959bf3947cc3ca8c47f20e8d9d55dc4407d4fa13bce8ebf0217411d3ce4cb1fbe3d5cad935e87dafaca8c24
7
+ data.tar.gz: a9f8a7b3616e080cb1f87dcda2eac021e6b7becee04e9ab8f6a16a5a76923b198965e818dc45ced33604558cd70b2cd8c69576ed08b2893b101d2fd305fc26ee
@@ -0,0 +1,13 @@
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities.
4
+
5
+ We are committed to making participation in this project a harassment-free experience for everyone, regardless of level of experience, gender, gender identity and expression, sexual orientation, disability, personal appearance, body size, race, ethnicity, age, or religion.
6
+
7
+ Examples of unacceptable behavior by participants include the use of sexual language or imagery, derogatory comments or personal attacks, trolling, public or private harassment, insults, or other unprofessional conduct.
8
+
9
+ Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct. Project maintainers who do not follow the Code of Conduct may be removed from the project team.
10
+
11
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by opening an issue or contacting one or more of the project maintainers.
12
+
13
+ This Code of Conduct is adapted from the [Contributor Covenant](http://contributor-covenant.org), version 1.0.0, available at [http://contributor-covenant.org/version/1/0/0/](http://contributor-covenant.org/version/1/0/0/)
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in KinopoiskAPI.gemspec
4
+ gemspec
@@ -0,0 +1,27 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'KinopoiskAPI/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = 'KinopoiskAPI'
8
+ spec.version = KinopoiskAPI::VERSION
9
+ spec.authors = ['proFox']
10
+ spec.email = ['admin@byprofox.com']
11
+
12
+ spec.summary = %q{Gem for operation with Kinopoisk API}
13
+ spec.description = %q{Gem is based on the API from the author: http://docs.kinopoiskapi.apiary.io}
14
+ spec.homepage = 'https://github.com/afuno/Kinopoisk-API-Gem/'
15
+ spec.license = 'MIT'
16
+
17
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
18
+ # spec.bindir = "exe"
19
+ # spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
20
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
21
+ # spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
22
+ spec.require_paths = ["lib"]
23
+
24
+ spec.add_development_dependency "bundler", "~> 1.10"
25
+ spec.add_development_dependency "rake", "~> 10.0"
26
+ spec.add_development_dependency "rspec"
27
+ end
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 Anton
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 proFox
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,284 @@
1
+ # КиноПоиск API (Gem)
2
+
3
+ Этот gem создан для упрощения работы с КиноПоиск API в проектах Ruby on Rails.
4
+
5
+ Гем основан официальном API от кинопоиска. Используется не официально, прикидываясь андройдом.
6
+ Данный гем являеться форком проекта afuno/Kinopoisk-API-Gem, но т.к http://api.kinopoisk.cf/ не работает, то пришлось переделать для работы на прямую с кинопоиском.
7
+
8
+ Используется версия api 3.11.0
9
+
10
+ ## Установка
11
+
12
+ Добавьте эту строку в Gemfile вашего приложения:
13
+
14
+ ```ruby
15
+ gem 'KinopoiskAPI' , github: 'alpha-ver/Kinopoisk-API-Gem', branch: 'master'
16
+ ```
17
+
18
+ Затем выполните:
19
+
20
+ $ bundle
21
+
22
+
23
+ ## Использование
24
+
25
+ ### Фильм
26
+
27
+ ```ruby
28
+ film = KinopoiskAPI::Film.new(733493)
29
+ ```
30
+ ```ruby
31
+ # Вся информация о фильме
32
+ film.all
33
+ ```
34
+ ```ruby
35
+ # Название фильма на русском
36
+ film.title[:ru]
37
+ ```
38
+ ```ruby
39
+ # Название фильма на английском
40
+ film.title[:en]
41
+ ```
42
+
43
+ Доступен вывод следующей информации:
44
+
45
+ * **id** - КиноПоиск ID
46
+ * **url** - URL адрес страницы на КиноПоиск
47
+ * **title** - Названия:
48
+ * **ru** - На русском
49
+ * **en** - На английском
50
+ * **slogan** - Слоган
51
+ * **description** - Описание
52
+ * **poster** - Полный адрес на постер (в формате JPG)
53
+ * **year** - Год выхода
54
+ * **kinopoisk** - Массив следующих данных для КиноПоиск:
55
+ * **rating** - Рейтинг
56
+ * **quantity** - Количество оценивших
57
+ * **good_reviews_in_percentage** - Количество положительных рецензий в процентах
58
+ * **number_of_good_reviews** - Количество положительных рецензий
59
+ * **waiting_in_percentage** - Количество ожидающих в процентах
60
+ * **number_of_waiting** - Количество ожидающих
61
+ * **film_critics_in_percentage** - Положительны рейтинг критиков в мире в процентах
62
+ * **film_critics** - Количество положительных оценок критиков в мире
63
+ * **rf_critics_in_percentage** - Положительны рейтинг критиков в РФ в процентах
64
+ * **rf_critics** - Количество положительных оценок критиков в РФ
65
+ * **imdb** - Массив следующих данных для IMDb:
66
+ * **id** - IMDb ID
67
+ * **rating** - Рейтинг
68
+ * **quantity** - Количество оценивших
69
+ * **number_of_reviews** - Количество рецензий
70
+ * **duration** - Продолжительность фильма
71
+ * **countries** - Массив со странами
72
+ * **genres** - Массив с жанрами
73
+ * **video** - Полный адрес на трейлер
74
+ * **is_sequel_or_prequel** - Имеет ли сиквелы или приквелы
75
+ * **is_similar_films** - Имеет ли родственные фильмы
76
+ * **is_imax** - Есть ли IMAX
77
+ * **is_3d** - Есть ли 3D
78
+ * **rating_mpaa** - Рейтинг MPAA
79
+ * **minimal_age** - Минимальный рекомендуемый возраст
80
+ * **premiere** - Массив данных о премьере:
81
+ * **ru** - Дата премьеры в РФ
82
+ * **world** - Дата премьеры в мире
83
+ * **world_country** - Страна премьеры
84
+ * **status** - Проверка полученного JSON (true или false)
85
+
86
+ ### Режисеры, актеры, операторы и т. д.
87
+
88
+ ```ruby
89
+ staff = KinopoiskAPI::Staff.new(733493)
90
+ ```
91
+ ```ruby
92
+ # Все имена всех профессий
93
+ staff.all
94
+ ```
95
+ ```ruby
96
+ # Все имена одной профессии
97
+ staff.profession('writer')
98
+ ```
99
+
100
+ Доступен вывод следующей информации:
101
+
102
+ * **id** - Идентификатор имени на сайте КиноПоиск
103
+ * **url** - URL на страницу именина КиноПоиск
104
+ * **full_name** - Имена:
105
+ * **ru** - На русском
106
+ * **en** - На английском
107
+ * **poster** - Полный адрес на постер (в формате JPG)
108
+ * **profession** - Профессия на русском (актер, режиссер и т. д.)
109
+ * **status** - Проверка полученного JSON (true или false)
110
+
111
+ ### Галерея
112
+
113
+ ```ruby
114
+ gallery = KinopoiskAPI::Gallery.new(733493)
115
+ ```
116
+ ```ruby
117
+ # Все изображения из всех разделов
118
+ gallery.all
119
+ ```
120
+ ```ruby
121
+ # Все изображения из конкретного раздела
122
+ gallery.section('poster')
123
+ ```
124
+
125
+ Доступен вывод следующей информации:
126
+
127
+ * **image** - Полный адрес на полное изображение (в формате JPG)
128
+ * **preview** - Полный адрес на превью (в формате JPG)
129
+ * **status** - Проверка полученного JSON (true или false)
130
+
131
+ ### Похожие
132
+
133
+ ```ruby
134
+ similar = KinopoiskAPI::Similar.new(733493)
135
+ ```
136
+ ```ruby
137
+ # Все похожие фильмы
138
+ similar.all
139
+ ```
140
+
141
+ Доступен вывод следующей информации:
142
+
143
+ * **title** - Названия:
144
+ * **ru** - На русском
145
+ * **en** - На английском
146
+ * **year** - Год выхода
147
+ * **rating** - Рейтинг
148
+ * **number_of_rated** - Количество оценивших
149
+ * **poster** - Полный адрес на постер (в формате JPG)
150
+ * **duration** - Продолжительность фильма
151
+ * **countries** - Массив со странами
152
+ * **genres** - Массив с жанрами
153
+ * **status** - Проверка полученного JSON (true или false)
154
+
155
+ ### Жанры
156
+
157
+ ```ruby
158
+ genres = KinopoiskAPI::Genres.new
159
+ ```
160
+ ```ruby
161
+ # Все жанры
162
+ genres.all
163
+ ```
164
+
165
+ Доступен вывод следующей информации:
166
+
167
+ * **id** - Идентификатор жанра на сайте КиноПоиск
168
+ * **name** - Жанр на русском
169
+ * **status** - Проверка полученного JSON (true или false)
170
+
171
+ ### Сегодня в кино
172
+
173
+ ```ruby
174
+ today = KinopoiskAPI::TodayFilms.new
175
+ ```
176
+ ```ruby
177
+ # Список фильмов
178
+ today.all
179
+ ```
180
+
181
+ Доступен вывод следующей информации:
182
+
183
+ * **id** - Идентификатор жанра на сайте КиноПоиск
184
+ * **status** - Проверка полученного JSON (true или false)
185
+
186
+
187
+
188
+
189
+ ### Глобавльный поиск
190
+
191
+ ```ruby
192
+ global_search = KinopoiskAPI::GlobalSearch.new('Звездные')
193
+ ```
194
+ ```ruby
195
+ # Скорее всего вы искали этот фильм
196
+ global_search.exactly
197
+ ```
198
+ ```ruby
199
+ # Возможно, вы искали эти фильмы
200
+ global_search.maybe
201
+ ```
202
+ ```ruby
203
+ # Или даже этих людей
204
+ global_search.names
205
+ ```
206
+
207
+ Доступен вывод следующей информации:
208
+
209
+ * **all** - Полный массив данных
210
+ * **keyword** - Ключевое слово (запрос)
211
+ * **number_of_films** - Количество найденных фильмов по ключевому слову
212
+ * **number_of_names** - Количество найденных имен по ключевому слову
213
+ * **exactly** - Один, наиболее подходящий фильм:
214
+ * **title** - Названия:
215
+ * **ru** - На русском
216
+ * **en** - На английском
217
+ * **info** - Краткая информация
218
+ * **duration** - Продолжительность фильма
219
+ * **year** - Год выхода
220
+ * **countries** - Массив со странами
221
+ * **genres** - Массив с жанрами
222
+ * **rating** - Рейтинг
223
+ * **number_of_rated** - Количество оценивших
224
+ * **poster** - Полный адрес на постер (в формате JPG)
225
+ * **maybe** - Список фильмов, которые также подходят под запрос:
226
+ * **title** - Названия:
227
+ * **ru** - На русском
228
+ * **en** - На английском
229
+ * **info** - Краткая информация
230
+ * **duration** - Продолжительность фильма
231
+ * **year** - Год выхода
232
+ * **countries** - Массив со странами
233
+ * **genres** - Массив с жанрами
234
+ * **rating** - Рейтинг
235
+ * **number_of_rated** - Количество оценивших
236
+ * **poster** - Полный адрес на постер (в формате JPG)
237
+ * **names** - Список имен, которые также подходят под запрос:
238
+ * **full_name** - Имена:
239
+ * **ru** - На русском
240
+ * **en** - На английском
241
+ * **info** - Краткая информация
242
+ * **poster** - Полный адрес на постер (в формате JPG)
243
+ * **status** - Проверка полученного JSON (true или false)
244
+
245
+ ### Рецензии
246
+
247
+ ```ruby
248
+ reviews = KinopoiskAPI::Reviews.new(733493)
249
+ ```
250
+ ```ruby
251
+ # Количество рецензий
252
+ reviews.quantity[:reviews]
253
+ ```
254
+ ```ruby
255
+ # Рецензии
256
+ reviews.reviews
257
+ ```
258
+
259
+ Доступен вывод следующей информации:
260
+
261
+ * **all** - Полный массив данных
262
+ * **pages** - Количество страниц
263
+ * **page** - Текущая страница
264
+ * **quantity** - Массив следующих данных:
265
+ * **reviews** - Количество рецензий
266
+ * **good_reviews** - Количество положительных рецензий
267
+ * **good_reviews_in_percent** - Количество положительных рецензий в процентах
268
+ * **bad_reviews** - Количество отризательных рецензий
269
+ * **neutral_reviews** - Количество нейтральных рецензий
270
+ * **reviews** - Список рецензий:
271
+ * **id** - Идентификатор на КиноПоиск
272
+ * **type** - Тип: положительный, негативный или нейтральный
273
+ * **data** - Дата и время публикации
274
+ * **author** - Массив данных об авторе:
275
+ * **name** - Имя (или никнейм) автора рецензии
276
+ * **avatar** - Полный адрес на аватар (в формате JPG)
277
+ * **title** - Заголовок
278
+ * **description** - Описание
279
+ * **status** - Проверка полученного JSON (true или false)
280
+
281
+ ## License
282
+
283
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
284
+
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "KinopoiskAPI"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
@@ -0,0 +1,7 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+
5
+ bundle install
6
+
7
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,149 @@
1
+ require 'net/http'
2
+ require 'KinopoiskAPI/agent'
3
+ require 'KinopoiskAPI/film'
4
+ require 'KinopoiskAPI/staff'
5
+ require 'KinopoiskAPI/gallery'
6
+ require 'KinopoiskAPI/similar'
7
+ require 'KinopoiskAPI/genres'
8
+ require 'KinopoiskAPI/reviews'
9
+ require 'KinopoiskAPI/global_search'
10
+ require 'KinopoiskAPI/today_films'
11
+ require 'KinopoiskAPI/version'
12
+
13
+ module KinopoiskAPI
14
+ DOMAINS = {
15
+ api: 'https://ext.kinopoisk.ru/ios/3.11.0',
16
+ salt: 'a17qbcw1du0aedm',
17
+ headers: {
18
+ 'Android-Api-Version' => '19',
19
+ 'User-Agent' => 'Android client (4.4 / api19), ru.kinopoisk/4.0.2 (52)',
20
+ 'device' => 'android'
21
+ },
22
+ kinopoisk: {
23
+ main: 'https://www.kinopoisk.ru',
24
+ poster: {
25
+ film: 'https://st.kp.yandex.net/images/film_iphone/iphone360',
26
+ name: 'https://st.kp.yandex.net/images/actor_iphone/iphone360',
27
+ gallery: 'https://st.kp.yandex.net/images'
28
+ }
29
+ }
30
+ }
31
+
32
+ METHODS = {
33
+ get_film: {
34
+ method: 'getKPFilmDetailView',
35
+ id: 'filmID'
36
+ },
37
+ get_gallery: {
38
+ method: 'getGallery',
39
+ id: 'filmID'
40
+ },
41
+ get_similar: {
42
+ method: 'getKPFilmsList',
43
+ type: 'kp_similar_films',
44
+ id: 'filmID'
45
+ },
46
+ get_name: {
47
+ method: 'getStaffList',
48
+ id: 'filmID'
49
+ },
50
+ get_genres: {
51
+ method: 'getKPGenresView'
52
+ },
53
+ get_top_genre: {
54
+ method: 'getTopGenre'
55
+ },
56
+ get_reviews: {
57
+ method: 'getKPReviews',
58
+ id: 'filmID'
59
+ },
60
+ get_review_detail: {
61
+ method: 'getReviewDetail',
62
+ id: 'reviewID'
63
+ },
64
+ get_people_detail: {
65
+ method: 'getPeopleDetail'
66
+ },
67
+ get_today_films: {
68
+ method: 'getKPTodayFilms'
69
+ },
70
+ get_cinemas: {
71
+ method: 'getCinemas'
72
+ },
73
+ get_cinema_detail: {
74
+ method: 'getCinemaDetail',
75
+ id: 'cinemaID'
76
+ },
77
+ get_seance: {
78
+ method: 'getSeance',
79
+ id: 'filmID'
80
+ },
81
+ get_dates_for_detail_cinema: {
82
+ method: 'getDatesForDetailCinema',
83
+ id: 'filmID'
84
+ },
85
+ get_soon_films: {
86
+ method: 'getSoonFilms'
87
+ },
88
+ get_soon_dvd: {
89
+ method: 'getSoonDVD'
90
+ },
91
+ get_dates_for_soon_films: {
92
+ method: 'getDatesForSoonFilms'
93
+ },
94
+ get_dates_for_soon_dvd: {
95
+ method: 'getDatesForSoonDVD'
96
+ },
97
+ get_top: {
98
+ method: 'getTop'
99
+ },
100
+ get_best_films: {
101
+ method: 'getBestFilms'
102
+ },
103
+ search_global: {
104
+ method: 'getKPGlobalSearch',
105
+ keyword: 'keyword'
106
+ },
107
+ search_films: {
108
+ method: 'getKPSearchInFilms',
109
+ keyword: 'keyword'
110
+ },
111
+ search_people: {
112
+ method: 'searchPeople',
113
+ keyword: 'keyword'
114
+ },
115
+ search_cinemas: {
116
+ method: 'searchCinemas',
117
+ keyword: 'keyword'
118
+ },
119
+ news: {
120
+ method: 'getNews'
121
+ },
122
+ get_news_detail: {
123
+ method: 'getNewsDetail'
124
+ }
125
+ }
126
+
127
+ def self.api_access(url)
128
+ #uri = URI.parse(url)
129
+ #http = Net::HTTP.new(uri.host, uri.port)
130
+ #response = http.request_head(uri.path)
131
+ #
132
+ #if response.code == '200'
133
+ # true
134
+ #else
135
+ # false
136
+ #end
137
+ raise ToDo
138
+ end
139
+
140
+ def self.valid_json?(json)
141
+ begin
142
+ JSON.parse(json)
143
+ return true
144
+ rescue JSON::ParserError => e
145
+ return false
146
+ end
147
+ end
148
+
149
+ end