Roles in Quanta
The Roles in Quanta
Each user, in Quanta, can be assigned one or more roles.
Quanta supports node-level access control, meaning that - for each node - you can decide exactly which roles can or can not do.
Default Quanta Roles
A fresh quanta installation supports those roles by default:
Quanta roles are nothing else than nodes / folders, and they are created in the _roles folder.
- 📁 logged
- 📁 anonymous
- 📁 admin
Additionally, there are two system roles that are automatically assigned to users:
logged - assigned to logged-in user
anonymous - assigned to anonymous/guest users
Those system roles are not contained into a folder, and therefore they are not editable or alterable in any way.
Creating a custom Role
So you can create anytime a new custom role (i.e. "editor"), by adding a new node inside the _roles folder.
Assigning a Role to an user
A visual form to assign roles to users, is envisioned, but still work in progress (see this issue).
At the moment, an user's roles are stored in the data.json of the user, under the "roles".
I.e. see:
This user has been assigned the "admin" and "editor" roles.
Using roles to change a node's permissions
Node's permissions, at the moment, are:
view - view the node
add - add another node inside the node
edit - edit the node
delete - delete the node
When editing a node using the Shadow form, the "manage permissions" tab (if it's not excluded from the form) will look more or less like this:
Here you can define which role can do what - in the specific node being edited.
The Inherit value means: "no specific role has been set for this permission on this node. Use the permission that have been set on this node's father instead".
Note that if all nodes are set to inherit, the permission will be granted by default.