This article describes in detail how to implement a role based security.
Define roles in the database for a Confluence user
Use the following commands to create user, role and grant the privileges to the role:
bob; /* bob is a Confluence user whose user ID/username in Confluence is bob
create role dbrole;
grant dbrole to bob;
grant SELECT ON cwd_group to
dbrole; /* you are granting the SELECT operation for the table cwd_group to the role DB_role
- The commands work for PostgreSQL database. Contact your DB administrator for the respective commands if you are using other database.
- It is necessary for the DB user (the user which we configured for accessing database; refer to confluence.cfg.xml file in the Home directory to get this information) to have the create role permissions in the database/data source.
Set up the data source for SQL
Let's say you have an application data source already defined in server.xml (as shown), for which you want to implement this role based security.
Do the following:
- Go to UPM > Manage apps and find the SQL for Confluence app.
- Click Configure.
- Select the View and modify data source profiles tab.
- To add a role based security data source, use the dataSource parameter. Refer to the screenshot below:
The new profile (in this case, "rolebased") is available immediately. Test it on a page to ensure expected behavior.
- If the user bob tries to access the page:
Since SELECT on cwd_group table is granted to bob, only the respective data is visible but not cwd_user table data.
- If any other user (let's say random user who has no database role associated with their own account/userid) tries to access the page:
Since there is no role associated with this user, an error message is shown as: