Class: Spree::Api::V3::Admin::AdminUsersController

Inherits:
ResourceController show all
Defined in:
app/controllers/spree/api/v3/admin/admin_users_controller.rb

Overview

Manages staff for the current store. “Staff” = admin users with at least one ‘Spree::RoleUser` whose `resource` is the current store. The legacy controller hard-deletes the global account on destroy; this v3 endpoint instead removes the per-store `RoleUser` rows so the user keeps their account (and access to other stores).

Constant Summary

Constants included from ScopedAuthorization

ScopedAuthorization::READ_ACTIONS

Constants inherited from BaseController

BaseController::RATE_LIMIT_RESPONSE

Constants included from Idempotent

Idempotent::IDEMPOTENCY_HEADER, Idempotent::IDEMPOTENCY_TTL, Idempotent::MAX_KEY_LENGTH, Idempotent::MUTATING_METHODS

Constants included from ErrorHandler

ErrorHandler::ERROR_CODES

Constants included from JwtAuthentication

JwtAuthentication::JWT_AUDIENCE_ADMIN, JwtAuthentication::JWT_AUDIENCE_STORE, JwtAuthentication::JWT_ISSUER, JwtAuthentication::USER_TYPE_ADMIN, JwtAuthentication::USER_TYPE_CUSTOMER

Instance Method Summary collapse

Methods inherited from ResourceController

#index, #show

Methods included from Spree::Api::V3::ApiKeyAuthentication

#authenticate_api_key!, #authenticate_secret_key!

Methods included from JwtAuthentication

#authenticate_user, #require_authentication!

Instance Method Details

#createObject

POST is not exposed — staff are created via invitations.



14
15
16
# File 'app/controllers/spree/api/v3/admin/admin_users_controller.rb', line 14

def create
  head :method_not_allowed
end

#destroyObject

DELETE /api/v3/admin/admin_users/:id Removes role assignments for the current store rather than deleting the account globally. The user keeps access to any other stores.



21
22
23
24
25
# File 'app/controllers/spree/api/v3/admin/admin_users_controller.rb', line 21

def destroy
  authorize!(:destroy, @resource)
  @resource.role_users.where(resource: current_store).destroy_all
  head :no_content
end

#updateObject

PATCH allows updating identity fields and replacing the user’s roles for this store. ‘role_ids` accepts prefixed IDs and is applied via `add_role`/`remove_role` so the change is scoped to `current_store` and never touches other-store assignments.



31
32
33
34
35
36
37
38
39
40
41
# File 'app/controllers/spree/api/v3/admin/admin_users_controller.rb', line 31

def update
  authorize!(:update, @resource)

  attrs = identity_params
  if @resource.update(attrs)
    apply_role_ids(role_ids_param) if params.key?(:role_ids)
    render json: serialize_resource(@resource)
  else
    render_validation_error(@resource.errors)
  end
end