CREATE ROLE
Creates a cluster-wide database role used for access control to database resources, such as keyspaces, tables, functions. Use roles to:
-
Create login accounts for CQL users.
-
Define a set of permissions that can be assigned to other roles and mapped to external users.
The best practices for using internal authentication are to create separate roles for various access permissions and login accounts.
See GRANT PERMISSION and for more information on assigning permissions to roles, and GRANT ROLE for information on assigning roles to other roles.
|
A full-access login account |
Syntax
CREATE ROLE [ IF NOT EXISTS ] <role_name>
( WITH PASSWORD = '<role_password>'
)
[ ( WITH | AND ) [ SUPERUSER = ( true | false ) ]
[ ( WITH | AND ) LOGIN = ( true | false ) ]
[ [ WITH | AND ] OPTIONS = { <custom_options_map> } ] ] ;
| Syntax conventions | Description |
|---|---|
UPPERCASE |
Literal keyword. |
Lowercase |
Not literal. |
|
Variable value. Replace with a user-defined value. |
|
Optional.
Square brackets ( |
|
Group.
Parentheses ( |
|
Or.
A vertical bar ( |
|
Repeatable.
An ellipsis ( |
|
Single quotation ( |
|
Map collection.
Braces ( |
Set, list, map, or tuple.
Angle brackets ( |
|
|
End CQL statement.
A semicolon ( |
|
Separate the command line options from the command arguments with two hyphens ( |
|
Search CQL only: Single quotation marks ( |
|
Search CQL only: Identify the entity and literal value to overwrite the XML element in the schema and solrConfig files. |
Parameters
| Parameter | Description | Default |
|---|---|---|
|
Identifier of the role. CQL forces all names to lowercase. If you need to preserve case or use special characters in the role name, enclose <role_name> in quotes. |
|
|
Password for the role. Enclose the password in single quotes. |
|
Optional.
Full read/write access to the database.
Only create roles with |
false |
|
|
Optional.
Allows the role to log in.
Only create roles with |
false |
|
Optional. Map of custom options. Reserved for use with authentication plug-ins. Refer to the authenticator documentation for details. |
Create a role
Create a role named cycling_admin:
CREATE ROLE IF NOT EXISTS cycling_admin
WITH PASSWORD = 'All4One2day!';
By default, a role has no permissions, cannot log in, and doesn’t have superuser status.
Permissions must be granted after creating a role. For an example, see Security quickstart.
Login privileges and superuser status must be set at role creation or with ALTER ROLE.
Create a login account
Create a role named coach that has login privileges:
CREATE ROLE IF NOT EXISTS coach
WITH LOGIN = true
AND PASSWORD = 'All4One2day!';
Verify that a role can log in
Use the LOGIN command to login as the specified role:
LOGIN coach;
When prompted, enter the password.
Once authenticated, the cqlsh prompt includes the role name:
coach@cqlsh>
Create a superuser role
Create a role with superuser status, which grants full access to all keyspaces and tables:
CREATE ROLE IF NOT EXISTS sys_admin
WITH SUPERUSER = true
AND PASSWORD = 'changeme'
AND LOGIN = true;
LOGIN isn’t required when SUPERUSER = true.
LOGIN is only required if you want to be able to log in as that role.