mirror of
https://github.com/openfoodfoundation/openfoodnetwork
synced 2026-01-24 20:36:49 +00:00
74 lines
2.1 KiB
Ruby
74 lines
2.1 KiB
Ruby
module Api
|
|
class EnterprisesController < Spree::Api::BaseController
|
|
|
|
before_filter :override_owner, only: [:create, :update]
|
|
before_filter :check_type, only: :update
|
|
before_filter :override_sells, only: [:create, :update]
|
|
before_filter :override_visible, only: [:create, :update]
|
|
respond_to :json
|
|
|
|
def managed
|
|
@enterprises = Enterprise.ransack(params[:q]).result.managed_by(current_api_user)
|
|
render params[:template] || :bulk_index
|
|
end
|
|
|
|
def accessible
|
|
@enterprises = Enterprise.ransack(params[:q]).result.accessible_by(current_api_user)
|
|
render params[:template] || :bulk_index
|
|
end
|
|
|
|
def create
|
|
authorize! :create, Enterprise
|
|
|
|
@enterprise = Enterprise.new(params[:enterprise])
|
|
if @enterprise.save
|
|
render text: @enterprise.id, :status => 201
|
|
else
|
|
invalid_resource!(@enterprise)
|
|
end
|
|
end
|
|
|
|
def update
|
|
@enterprise = Enterprise.find_by_permalink(params[:id]) || Enterprise.find(params[:id])
|
|
authorize! :update, @enterprise
|
|
|
|
if @enterprise.update_attributes(params[:enterprise])
|
|
render text: @enterprise.id, :status => 200
|
|
else
|
|
invalid_resource!(@enterprise)
|
|
end
|
|
end
|
|
|
|
def update_image
|
|
@enterprise = Enterprise.find_by_permalink(params[:id]) || Enterprise.find(params[:id])
|
|
authorize! :update, @enterprise
|
|
|
|
if params[:logo] && @enterprise.update_attributes( { logo: params[:logo] } )
|
|
render text: @enterprise.logo.url(:medium), :status => 200
|
|
elsif params[:promo] && @enterprise.update_attributes( { promo_image: params[:promo] } )
|
|
render text: @enterprise.promo_image.url(:medium), :status => 200
|
|
else
|
|
invalid_resource!(@enterprise)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def override_owner
|
|
params[:enterprise][:owner_id] = current_api_user.id
|
|
end
|
|
|
|
def check_type
|
|
params[:enterprise].delete :type unless current_api_user.admin?
|
|
end
|
|
|
|
def override_sells
|
|
params[:enterprise][:sells] = 'unspecified'
|
|
end
|
|
|
|
def override_visible
|
|
params[:enterprise][:visible] = false
|
|
end
|
|
end
|
|
end
|