/api/app/controllers/spree/api/v1/users_controller.rb
Ruby | 60 lines | 49 code | 11 blank | 0 comment | 2 complexity | e59972b79a71dbb575c7474237a1e474 MD5 | raw file
- module Spree
- module Api
- module V1
- class UsersController < Spree::Api::BaseController
- rescue_from Spree::Core::DestroyWithOrdersError, with: :error_during_processing
- def index
- @users = Spree.user_class.accessible_by(current_ability,:read).ransack(params[:q]).result.page(params[:page]).per(params[:per_page])
- respond_with(@users)
- end
- def show
- respond_with(user)
- end
- def new
- end
- def create
- authorize! :create, Spree.user_class
- @user = Spree.user_class.new(user_params)
- if @user.save
- respond_with(@user, status: 201, default_template: :show)
- else
- invalid_resource!(@user)
- end
- end
- def update
- authorize! :update, user
- if user.update_attributes(user_params)
- respond_with(user, status: 200, default_template: :show)
- else
- invalid_resource!(user)
- end
- end
- def destroy
- authorize! :destroy, user
- user.destroy
- respond_with(user, status: 204)
- end
- private
- def user
- @user ||= Spree.user_class.accessible_by(current_ability, :read).find(params[:id])
- end
- def user_params
- params.require(:user).permit(permitted_user_attributes |
- [bill_address_attributes: permitted_address_attributes,
- ship_address_attributes: permitted_address_attributes])
- end
- end
- end
- end
- end