About database objects permissions
Hyper-Converged Database (HCD) supports Role-Based Access Control (RBAC) to ensure that only authorized users can access database resources. RBAC provides a flexible and secure way to manage access to various database objects through a hierarchical permission system.
RBAC in Hyper-Converged Database (HCD)
RBAC in HCD follows a hierarchical model where permissions cascade from parent objects to child objects. Granting a permission on a keyspace automatically grants the same permission on all tables within that keyspace, unless explicitly overridden.
Key concepts
- 
Roles: Users and other roles that can be assigned permissions 
- 
Resources: Database objects like keyspaces, tables, functions, etc. 
- 
Privileges: Specific actions that can be performed (SELECT, INSERT, MODIFY, etc.) 
- 
Permissions: The combination of a privilege and a resource 
Permission hierarchy
The permission hierarchy in Hyper-Converged Database (HCD) follows this structure:
- 
Cluster-level permissions: Affect the entire database cluster 
- 
Keyspace-level permissions: Apply to all objects within a keyspace 
- 
Table-level permissions: Grant access to individual tables 
- 
Row-level permissions: Provide fine-grained access control within tables 
- 
Function and aggregate permissions: Give access to user-defined functions 
- 
Role management permissions: Control role creation and modification 
Manage permissions
After creating a role, use the following CQL commands to manage permissions:
- 
GRANTallows access
- 
REVOKEremoves access that has been granted
- 
RESTRICTexplicitly denies access even if permission is granted directly or inherited
- 
UNRESTRICTremoves a restriction
| 
 | 
Permission inheritance
Permissions in HCD follow an inheritance model:
- 
Granting a permission on a parent object automatically grants the same permission on all child objects 
- 
Child object permissions can override inherited permissions 
- 
The most restrictive permission always takes precedence 
- 
Permissions can be granted directly or inherited from role hierarchies 
Common permission patterns
- 
Read-only access: Grant SELECTon specific tables or keyspaces
- 
Data modification: Grant INSERT,UPDATE,DELETEas needed
- 
Schema management: Grant CREATE,ALTER,DROPfor structural changes
- 
Administrative access: Grant ALL PERMISSIONSfor full control
Resource types and permissions
HCD RBAC uses a modeled hierarchy where different resource types have specific permission requirements. Granting a privilege to a top-level object gives the role the same permission to all child objects.
Permissions vary depending on the object type:
- 
Data resources: Keyspaces, tables, rows, and types 
- 
Functions and aggregates: User-defined functions and aggregate functions 
- 
Search indexes: Full-text search capabilities 
- 
Roles: User and role management 
- 
Authentication schemes: Login and authentication methods 
- 
JMX resources: Monitoring and management tools 
- 
Remote procedures: Custom business logic execution 
See also
The following sections provide detailed information about specific resource types and their permission models:
- 
Data resources: Syntax for authorizing access to keyspaces, tables, rows, and types. 
- 
Functions and aggregate resources: Syntax for authorizing access to user-defined functions and aggregates. 
- 
Roles: Syntax for authorizing role management. 
- 
Proxy login and execute: Syntax for authorizing proxy logins and executions. 
- 
Authentication scheme resources: Syntax for authorizing roles for an authentication scheme. 
- 
JMX resources (MBeans) for HCD utilities: Syntax for authorizing access to MBeans from HCD utilities and third-party tools. 
- 
Remote procedure calls: Syntax for authorizing remote procedure calls. 
