Skip to main content

Access Control Mechanisms

Data Access Restrictions establish a foundation by focusing on fundamental principles and tactics used to limit and manage access to sensitive data. In contrast, Role-Based Access Control (RBAC) delves into a comprehensive security model that assigns roles and privileges to users, orchestrating a controlled environment for accessing essential resources. Together, these concepts create a robust system, ensuring data security and controlled user interactions.

Data Access Restrictions

Data Access Restrictions are fundamental to safeguarding sensitive data's confidentiality, integrity, and availability. The implementation of Data Access Restrictions in Qodly provides numerous benefits:

  • Enhanced Security: Limits data access to authorized individuals, reducing the risk of unauthorized data breaches.
  • Compliance: Ensures adherence to industry regulations and data protection laws.
  • Customization: Enables a tailored user experience based on roles and privilege levels.
  • Auditability: Facilitates tracking and monitoring of user interactions with sensitive data for security analysis.

Role-Based Access Control (RBAC)

Role-Based Access Control (RBAC) is a core security model in Qodly, ensuring controlled and secure resource access. The implementation of RBAC in Qodly provides several benefits:

  • Granular Access Control: Fine-grained control over user access to resources.
  • Simplified Management: Streamlined access management through role assignments.
  • Security and Compliance: Enforces security policies and complies with data protection regulations.
  • Scalability: Efficiently scales as the application grows by adding new roles and adjusting privilege assignments.

Key Concepts

ORDA Concepts

Central to Qodly's data manipulation are the principles of Object-Relational Data Access (ORDA). Data organization revolves around the DataStore and DataClasses, which serve as pivotal resources. ORDA introduces attributes and functions within classes, streamlining the data management process.

Resources

Qodly encompasses a range of resources including the DataStore, DataClasses, Attributes, and Functions. Each of these resources has the potential for linked privileges that govern permissible actions.

ResourceDescription
DatastoreRepresents the entire data storage system, including all dataclasses and entities.
DataclassesRefer to specific data structures in the datastore.
AttributesDefine the properties of Dataclasses.
FunctionsRepresent custom functions defined within the data model.

Permissions

Permissions define essential actions on resources, covering tasks such as creation, reading, updating, deletion, description, execution (for functions), and promotion (also for functions).

PermissionDatastoreDataclassAttributeFunction
CreateCreate an Entity in any Dataclass.Create a new Entity in the chosen Dataclass.Create a new Entity with a value different from the default allowed for the chosen Attribute.n/a
ReadRead Attributes in any Dataclass.Read attributes in the chosen Dataclass.Read the content of the chosen Attribute.n/a
UpdateUpdate Attributes in any Dataclass.Update attributes in the chosen Dataclass.Update the content of the chosen Attribute.n/a
DeleteDelete data throughout the Model.Delete data in the chosen Dataclass.Delete a non-null value for the chosen Attribute.n/a
DescribeProvides metadata access throughout the Model.Provides metadata access for the chosen Dataclass.Provides metadata access for the selected Attribute.Provides metadata access for the chosen Dataclass function.
ExecuteExecute all functions throughout the Model, including DataStore, Dataclasses, Entity selections, and Entities.Execute any function on the chosen dataclass (Dataclass functions, entity functions, and entity selection functions).n/aExecute the selected function.
Promoten/an/an/aTemporarily adds a specific privilege to the session during function execution, primarily for secure privilege escalation.

Data Access Granularity Hierarchy

At the core of Qodly's data security lies a well-defined granularity hierarchy that lets you control who accesses your resources and how. This hierarchy ensures that data access restrictions can be set at different levels, catering to the specific needs of your application and users. Let's explore the granularity levels in detail:

  1. DataStore Level: This top-level granularity encompasses the entire DataStore. Permissions established here have a wide-reaching impact, influencing all resources within the DataStore.
Example

Visualize a vast store housing diverse data – the DataStore. At this level, it functions as the gateway, determining who gains entry. It serves as the chief access controller, where regulations are established to govern everything within.

  1. DataClass Level: Moving a step deeper, we enter the DataClass level. Permissions set here exhibit inheritance behavior, extending to all resources encapsulated within the DataClass. This ensures a cohesive, consistent access control approach for interconnected data entities.
Example

Imagine stepping inside the store, with each section representing a DataClass. Here, you set rules for entire sections, dictating access to everything within them. For instance, in the "Packages" section, you can control who can view or modify related data. It's akin to holding keys to distinct sections of the store.

  1. Attribute/Function Level: Delving further into granularity, we encounter the Attribute/Function level. This level offers precision, enabling you to define access to specific attributes or functions within a DataClass. By focusing on these specifics, you customize access rights to suit your application's intricate needs.
Example

Inside each section, there are shelves with items (attributes) and tools (functions). Here, you can be super specific. Imagine you have a "Price" shelf. You can decide who can see or touch it. Maybe only the managers can adjust the prices. It's like giving keys to certain shelves.