Create Api::BaseController to allow use of ActiveModelSerializers

Also add index action to Api::CustomersController
This commit is contained in:
Rob Harrington
2018-04-27 16:04:58 +10:00
parent 29922d4be9
commit ffa8a8c7d6
7 changed files with 64 additions and 9 deletions

View File

@@ -0,0 +1,13 @@
# Base controller for OFN's API
# Includes the minimum machinery required by ActiveModelSerializers
module Api
class BaseController < Spree::Api::BaseController
# Need to include these because Spree::Api::BaseContoller inherits
# from ActionController::Metal rather than ActionController::Base
# and they are required by ActiveModelSerializers
include ActionController::Serialization
include ActionController::UrlFor
include Rails.application.routes.url_helpers
use_renderers :json
end
end

View File

@@ -1,13 +1,16 @@
module Api
class CustomersController < Spree::Api::BaseController
respond_to :json
class CustomersController < BaseController
def index
@customers = current_api_user.customers
render json: @customers, each_serializer: CustomerSerializer
end
def update
@customer = Customer.find(params[:id])
authorize! :update, @customer
if @customer.update_attributes(params[:customer])
render text: @customer.id, :status => 200
render json: @customer, serializer: CustomerSerializer, status: 200
else
invalid_resource!(@customer)
end

View File

@@ -1,5 +1,5 @@
module Api
class StatusesController < BaseController
class StatusesController < ::BaseController
respond_to :json
def job_queue

View File

@@ -0,0 +1,5 @@
module Api
class CustomerSerializer < ActiveModel::Serializer
attributes :id, :enterprise_id, :name, :code, :email, :allow_charges
end
end

View File

@@ -217,7 +217,7 @@ Openfoodnetwork::Application.routes.draw do
get :job_queue
end
resources :customers, only: [:update]
resources :customers, only: [:index, :update]
post '/product_images/:product_id', to: 'product_images#update_product_image'
end

View File

@@ -3,13 +3,32 @@ require 'spec_helper'
module Api
describe CustomersController, type: :controller do
include AuthenticationWorkflow
include OpenFoodNetwork::ApiHelper
render_views
let(:user) { create(:user) }
let(:customer) { create(:customer, user: user) }
let(:params) { { format: :json, id: customer.id, customer: { code: '123' } } }
describe "index" do
let!(:customer1) { create(:customer) }
let!(:customer2) { create(:customer) }
before do
user.customers << customer1
allow(controller).to receive(:spree_current_user) { user }
end
it "lists customers associated with the current user" do
spree_get :index
expect(response.status).to eq 200
expect(json_response.length).to eq 1
expect(json_response.first[:id]).to eq customer1.id
end
end
describe "#update" do
let(:customer) { create(:customer, user: user) }
let(:params) { { format: :json, id: customer.id, customer: { code: '123' } } }
context "as a user who is not associated with the customer" do
before do
allow(controller).to receive(:spree_current_user) { create(:user) }
@@ -30,7 +49,7 @@ module Api
it "returns the id of the updated customer" do
spree_post :update, params
expect(response.status).to eq 200
expect(response.body).to eq customer.id.to_s
expect(json_response[:id]).to eq customer.id
end
end
@@ -40,7 +59,7 @@ module Api
it "returns a 422, with an error message" do
spree_post :update, params
expect(response.status).to be 422
expect(JSON.parse(response.body)['error']).to be
expect(json_response[:error]).to be
end
end
end

View File

@@ -0,0 +1,15 @@
module OpenFoodNetwork
module ApiHelper
def json_response
json_response = JSON.parse(response.body)
case json_response
when Hash
json_response.with_indifferent_access
when Array
json_response.map(&:with_indifferent_access)
else
json_response
end
end
end
end