Class: Spree::Api::V3::Admin::InvitationsController
- Inherits:
-
ResourceController
- Object
- ActionController::API
- BaseController
- ResourceController
- ResourceController
- Spree::Api::V3::Admin::InvitationsController
- Defined in:
- app/controllers/spree/api/v3/admin/invitations_controller.rb
Overview
Manages staff invitations for the current store. Each invitation carries an email + role; on accept, a ‘Spree::RoleUser` is created via the invitation’s ‘after_accept` callback and the invitee becomes a member of the staff list for this store.
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
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
-
#resend ⇒ Object
PATCH /api/v3/admin/invitations/:id/resend Issues a fresh token + email for an existing pending invitation.
-
#update ⇒ Object
Invitations are immutable post-create — UI calls ‘resend` for token rotation, `destroy` to revoke.
Methods inherited from ResourceController
#create, #destroy, #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
#resend ⇒ Object
PATCH /api/v3/admin/invitations/:id/resend Issues a fresh token + email for an existing pending invitation. The model’s ‘resend!` is responsible for resetting `expires_at` and dispatching the mailer.
16 17 18 19 20 21 22 |
# File 'app/controllers/spree/api/v3/admin/invitations_controller.rb', line 16 def resend @resource = find_resource (:update, @resource) @resource.resend! render json: serialize_resource(@resource) end |
#update ⇒ Object
Invitations are immutable post-create — UI calls ‘resend` for token rotation, `destroy` to revoke. Clearing the action set keeps the surface honest if a client ever fires PATCH directly.
27 28 29 |
# File 'app/controllers/spree/api/v3/admin/invitations_controller.rb', line 27 def update head :method_not_allowed end |