Set up custom roles
When account owners and administrators set up user access for an account, they assign roles (example: Editor, Viewer, Operator, and so on) to access policies and access groups, and then assign users to those policies or groups. A user can perform all the actions mapped to the role or roles that have been assigned to their access group or policy.
In addition to the pre-configured roles listed on the Roles page, account owners and administrators can create roles that better match their needs. For example, you can create a custom role that grants a user access to view account usage analytics without granting any other management access. The next section gives a step-by-step demonstration of this example.
Example: create a custom role that allows users to perform actions to work with IBM Quantum service instances
This custom role grants quantum-specific roles to users.
- From Manage → IAM → Roles, click Create.
- Enter a name, ID, description, and select Qiskit Runtimefor the service.
- Select the following roles, then click Create.
- quantum-computing.device.read
- quantum-computing.job.cancel
- quantum-computing.job.create
- quantum-computing.job.read
- quantum-computing.program.delete
- quantum-computing.program.read
- quantum-computing.user.logout
- Select quantum-computing.job.delete if you want to allow users to delete jobs.
 
Example: create a custom role for a user to view analytics only
- 
Go to Manage → IAM → Roles in IBM Cloud. Select the Qiskit Runtime service from the dropdown menu to see the roles that currently exist for this service. 
- 
Click the Create + button. 
- 
Enter a name for the custom role, such as Analytics Viewer.
- 
Enter an ID. You can input any unique string for this ID, as long as it starts with a capital letter, and contains only alphanumeric characters (no spaces) - for example, AnalyticsViewer.
- 
Enter a description for the custom role. In this example, an appropriate description might be "As an Analytics Viewer, you can view account analytics only." 
- 
In the Service dropdown menu, choose Qiskit Runtime. A table appears that contains all the actions that you can map to the role. 
- 
For this example, look for any actions that pertain to analytics, such as "Read usage filters for analytics" and "Read usage for analytics". Also include the "Read account configuration" action. To add the actions to your custom role, click Add at the end of the action's row. 
- 
Once you have added all the actions you want mapped to the role, click Create. 
- 
Go to Manage → IAM → Access groups. Click Create + to create a new access role. (It is recommended to create a new access group especially for this role, rather than add the role to your Public Access group, unless you want all your users to have the access granted by your custom role.) Once you have clicked Create + and named your new group (or, in the case of editing an existing access group, once you have clicked the name of the access group to edit), then click the Access tab. Click Assign access +. 
- 
Under Service, select Qiskit Runtime, then click Next. 
- 
Under Resources, select All resources, then click Next. (Note that if you do not scope the access to all resources, the Analytics Viewer role will not be able to see analytics from all instances.) 
- 
Under Roles and actions, check the Viewer box (under Platform) and the Analytics Viewer box (under Custom access), then click Next. 
- 
Click Add >, then click Assign. You have now created a policy that includes your custom role as well as the Viewer role. 
- 
View the access group, and click the Users tab to add a user to this group. This user will now be able to perform the actions in your custom role (as well as the other roles you assigned to the policy). 
To learn more, see the Creating custom roles and the What are IAM policies and who can assign them? topics.