Add more methods to manage movies through API
parent
eef60a8420
commit
3a969d5344
|
@ -8,6 +8,7 @@ Sequel.migration do
|
||||||
create_table(:movies) do
|
create_table(:movies) do
|
||||||
primary_key :id
|
primary_key :id
|
||||||
String :data, text: true, null: false
|
String :data, text: true, null: false
|
||||||
|
FalseClass :added, null: false, default: false
|
||||||
FalseClass :viewed, null: false, default: false
|
FalseClass :viewed, null: false, default: false
|
||||||
FalseClass :downloaded, null: false, default: false
|
FalseClass :downloaded, null: false, default: false
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,13 +18,11 @@ module Librarix
|
||||||
end
|
end
|
||||||
|
|
||||||
def json_params
|
def json_params
|
||||||
begin
|
|
||||||
JSON.parse(request.body.read)
|
JSON.parse(request.body.read)
|
||||||
rescue
|
rescue
|
||||||
halt 400, { message:'Invalid JSON' }.to_json
|
halt 400, { message:'Invalid JSON' }.to_json
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
before do
|
before do
|
||||||
content_type 'application/json'
|
content_type 'application/json'
|
||||||
|
@ -38,24 +36,27 @@ module Librarix
|
||||||
|
|
||||||
namespace '/movies' do
|
namespace '/movies' do
|
||||||
get '' do
|
get '' do
|
||||||
Librarix::Filter.new(params).movies.to_json
|
Librarix::Models::Movie.where(added: true).all.to_json
|
||||||
end
|
end
|
||||||
|
|
||||||
post '' do
|
get '/popular' do
|
||||||
id = json_params['tmdb_id'].to_i
|
Librarix::Models::Movie.popular.to_json
|
||||||
movie = Tmdb::Movie.detail(id)
|
|
||||||
|
|
||||||
if movie['status_code'] != 34 && !Librarix::Redis::Movie.new(id).added?
|
|
||||||
Librarix::Redis::Movie.new(id).add.to_json
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
get '/search' do
|
||||||
end
|
end
|
||||||
|
|
||||||
get '/:id' do |id|
|
get '/:id' do |id|
|
||||||
Librarix::Models::Movie.find(id: id).to_json
|
Librarix::Models::Movie.find_or_fetch(id).to_json
|
||||||
|
end
|
||||||
|
|
||||||
|
post '/:id' do
|
||||||
|
Librarix::Models::Movie.find_or_fetch(id).add!
|
||||||
|
{success: true}.to_json
|
||||||
end
|
end
|
||||||
|
|
||||||
get '/:id/fetch' do |id|
|
get '/:id/fetch' do |id|
|
||||||
Librarix::Models::Movie.fetch(85).to_json
|
Librarix::Models::Movie.fetch(id).to_json
|
||||||
end
|
end
|
||||||
|
|
||||||
patch '/:id/view' do |id|
|
patch '/:id/view' do |id|
|
||||||
|
|
|
@ -1,4 +1,16 @@
|
||||||
class Librarix::Models::Movie < Sequel::Model
|
class Librarix::Models::Movie < Sequel::Model
|
||||||
|
def self.popular
|
||||||
|
unrestrict_primary_key
|
||||||
|
|
||||||
|
Tmdb::Search.new('/movie/popular').fetch.map do |m|
|
||||||
|
find_or_create(id: m['id']) { |movie| movie.data = m }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.find_or_fetch(id)
|
||||||
|
find(id: id) || fetch(id)
|
||||||
|
end
|
||||||
|
|
||||||
def self.fetch(id)
|
def self.fetch(id)
|
||||||
unrestrict_primary_key
|
unrestrict_primary_key
|
||||||
|
|
||||||
|
@ -14,10 +26,15 @@ class Librarix::Models::Movie < Sequel::Model
|
||||||
|
|
||||||
def fetch!
|
def fetch!
|
||||||
tmdb_data = Tmdb::Movie.detail(id)
|
tmdb_data = Tmdb::Movie.detail(id)
|
||||||
|
return if tmdb_data['status_code'] == 34
|
||||||
|
|
||||||
self.data = tmdb_data
|
self.data = tmdb_data
|
||||||
save
|
save
|
||||||
|
|
||||||
genres_id = data['genres'].map { |g| g['id'] }
|
genres_id = data['genres'].map { |g| g['id'] }
|
||||||
|
|
||||||
|
Librarix::Models::Genre.fetch if Librarix::Models::Genre.empty?
|
||||||
|
|
||||||
Librarix::Models::Genre.where(id: genres_id).all.each do |genre|
|
Librarix::Models::Genre.where(id: genres_id).all.each do |genre|
|
||||||
add_genre(genre) unless genres.include?(genre)
|
add_genre(genre) unless genres.include?(genre)
|
||||||
end
|
end
|
||||||
|
@ -25,6 +42,11 @@ class Librarix::Models::Movie < Sequel::Model
|
||||||
self
|
self
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def add!
|
||||||
|
self.added = true
|
||||||
|
save
|
||||||
|
end
|
||||||
|
|
||||||
def download!
|
def download!
|
||||||
self.downloaded = !downloaded
|
self.downloaded = !downloaded
|
||||||
save
|
save
|
||||||
|
|
Loading…
Reference in New Issue