docs/developer/core-concepts/staff-roles.mdx
Admin users manage the store via the Admin Panel. They have roles that control what they can access.
erDiagram
AdminUser ||--o{ RoleUser : "has many"
RoleUser }o--|| Role : "belongs to"
RoleUser }o--|| Store : "scoped to"
AdminUser ||--o{ Invitation : "invites"
AdminUser {
string id
string email
}
RoleUser {
string role_id
string resource_type
string resource_id
}
Role {
string name
}
Invitation {
string email
string status
string token
datetime expires_at
}
Admin users can have different roles that control their permissions:
| Role | Description |
|---|---|
admin | Full access to all Admin Panel features |
Use the Spree CLI to create admin users:
spree user create
The CLI will prompt you for the email and password. You can also pass them directly:
spree user create --email [email protected] --password secret123
The created user gets the admin role on the default store.
You can invite new admins through the Admin Panel or programmatically.
Via Admin Panel:
The invitee receives an email with an invitation link. If they already have an account, they log in to accept. Otherwise, they create an account first.
flowchart TB
A[Admin creates invitation] --> B[Invitation email sent]
B --> C[Invitee clicks link]
C --> D{Has account?}
D -->|Yes| E[Log in]
D -->|No| F[Create account]
E --> G[Accept invitation]
F --> G
G --> H[Role assigned to store]
| Attribute | Description |
|---|---|
email | Invitee's email address |
token | Secure token for the invitation link |
status | pending or accepted |
expires_at | Expiration date (default: 2 weeks) |
resource | The store being granted access to |
role | The role to assign upon acceptance |
The invitation system publishes events you can subscribe to:
| Event | Description |
|---|---|
invitation.created | Invitation was created (triggers email) |
invitation.accepted | Invitation was accepted and role assigned |
invitation.resent | Invitation was resent to the invitee |
Spree uses CanCanCan for authorization. Permissions apply to both customers (Store API access) and admins (Admin Panel access).
See the Customize Permissions guide for details on creating custom roles and permission sets.