Permission in EzyPlatform
Updated at 1706780912000Permission for admin
To set permissions for an admin, you will navigate to the Admins > Roles
menu. By default, there are two highest admin roles:
data:image/s3,"s3://crabby-images/4dbc4/4dbc4da8790b40f9c97a68d8e297c0d0bcf2dcee" alt="Screenshot 2024-02-01 at 16.11.30.png"
- Super Administrator: The highest administrative role, with the ability to create and remove all other roles.
- DevOps: Administrative role with all the highest permissions like super admin but cannot delete super admin.
data:image/s3,"s3://crabby-images/1a070/1a070f1d7bdabadfa36f3457cf1895a85451a699" alt="Screenshot 2024-02-01 at 16.12.43.png"
Now, let's say you need to add a role that allows only drafting articles. You can click on the Add New
button and fill in the information as follows:
data:image/s3,"s3://crabby-images/bdfc4/bdfc470f91e1f802ae659af89ce8a6fd32f67c5d" alt="Screenshot 2024-02-01 at 16.14.23.png"
You will see a new role in the list called Editor
:
data:image/s3,"s3://crabby-images/77593/775930c5438802eb2a47ac206700c9a6a46eefa9" alt="Screenshot 2024-02-01 at 16.15.38.png"
Click on Editor
to go to the detailed screen:
data:image/s3,"s3://crabby-images/9141c/9141c38cad3a2184d14217b8d3969db418dd852c" alt="Screenshot 2024-02-01 at 16.15.24.png"
Now you can add a member with the Editor role by clicking the Add
button next to the Members
heading, or you can add a new admin. For example, I need to add a new admin like this:
data:image/s3,"s3://crabby-images/62346/62346b71d0cebf6a90a51e3674a33ec86141cb8f" alt="Screenshot 2024-02-01 at 16.19.55.png"
After adding an admin and returning to the Editor
role screen, I will see a new member added to the list:
data:image/s3,"s3://crabby-images/9eace/9eacee97e97225e4fb7bcfe3efdec0f5cbdafe81" alt="Screenshot 2024-02-01 at 16.22.34.png"
Now, I will log in as this admin on another browser, and the result will be as follows:
data:image/s3,"s3://crabby-images/826f9/826f9f9936e8407d5158997118de72d301c8ed4e" alt="Screenshot 2024-02-01 at 16.27.59.png"
You can see that the editor
admin will only have certain menus displayed and can do almost nothing. Now, we need to set permissions to allow the editor
admin to write articles by checking the functions and APIs that we allow the admin to perform:
data:image/s3,"s3://crabby-images/a4172/a4172bcf572f86c1aaeac1694cc6b7089b98c61f" alt="Screenshot 2024-02-01 at 16.34.02.png"
data:image/s3,"s3://crabby-images/6fd8c/6fd8c79252733d313be2801cb6b4bebec98bb074" alt="Screenshot 2024-02-01 at 16.34.14.png"
Press the Save Features
button, then go back to the editor
admin, and you will be able to see the menus related to article management and be able to write articles:
data:image/s3,"s3://crabby-images/0394c/0394c38d951776f128184bb3a2183744806c16c4" alt="Screenshot 2024-02-01 at 16.34.56.png"
Congratulations, you have successfully set permissions for the editor
admin to manage articles.
Permission for web
Similar to admin permissions, you can install EzyPlatform and experience it yourself. However, the effectiveness of permissions on the web depends on what theme you are using.
How does EzyPlatform recognize which API needs permission?
This is
thanks to the use of @EzyFeature
. When you use this annotation, for example:
@EzyFeature("post_management") public class PostController {
It understands that all APIs in PostController
belong to the post_management
feature and need to be authorized for admins or users to use.