Concepts
Raito Cloud
Raito Cloud refers to the Raito SaaS offering. It provides the full functionality that Raito has to offer to protect your data without slowing it down.
Raito CLI
The Raito CLI is the bridge between your infrastructure (data sources, identity stores, data catalog …) and Raito Cloud. It can run safely on your own infrastructure to handle all the connections to your infrastructure in a secure way, without the need to have credentials to your data sources in Raito Cloud.
Alternatively, there is an option to run the CLI from within Raito Cloud. This is a good option to get started with Raito quickly, but not recommended for production environments.
What
Data Source
A data source is an instance of a data warehouse, database, reporting tool, …, or any other source of data in your data landscape. Some examples are, Snowflake and BigQuery. You can have multiple data sources of the same type (e.g. multiple Snowflake accounts).
Data Objects
Data objects represent all the data elements that can be found in a specific data source. A data object always belongs to a specific data source.
Data objects are organized in a hierarchy under its data source. Each data source has its own set of data object types, which are defined by the CLI connector. Each data object type also contains the necessary information for Raito to understand its capabilities (e.g. the permissions that are applicable to that data object type).
For example, for a Snowflake data source, the hierarchy of data objects would look like this: data source > database > schema > table > column
Data
Data refers to the granular level of a data object for which you want to obtain insights. This is configurable within the usage metadata of the data source connector. As a default, Raito uses tables or views for data warehouses, files for file systems and reports or dashboards for reporting tools
Who
Identity Store
An identity store, literally represents a store of identities. It contains accounts and (optionally) groups.
Each data source has one native identity store linked to it, which cannot be changed or removed. This native identity store should contain all the user accounts that are known by the data source. It is synchronized by the CLI together with the data source.
Next to that, also external (standalone) identity stores can be imported (e.g. Okta, Active Directory, …). These can provide additional information about the users. When such an external identity store is linked to a data source, the groups from that identity store can also be used when providing access to that data source.
An identity store can also be marked as master which indicates that this is the main identity store of your company. The groups in this identity store can be used everywhere.
Account
An account is a representation of a user in a single Identity Store.
User
A user is a collection of accounts across multiple Identity Stores, typically belonging to a single (physical) person or service.
When new accounts are imported (when the identity store is synced by the Raito CLI) these accounts are automatically attached under an existing user when the email address matches or to a new user when no user was found with that email address.
An account can be transfered to another or new user manually if needed.
Group
A group is a group of accounts as defined in the identity stores.
Access
Access Control
An Access Control is what actually controls access to data objects for one or more defined users.
When a data source is synced with Raito Cloud using the Raito CLI, the access controls in the data source are mapped to access controls in Raito. For example, for every role in Snowflake, an access control is created in Raito Cloud. These imported access controls are marked as not managed by Raito to indicate that they are managed in the data source itself (and not by Raito Cloud).
Next to that, new managed by Raito access controls can be defined within Raito Cloud or existing not managed by Raito access controls can be converted to managed by Raito. These managed by Raito access controls are then converted into access controls in the data source during a sync with the Raito CLI.
For example, a managed by Raito access control in Raito would translate to a role in Snowflake. If the role already exists, it gets updated, otherwise a new role is created.
Access Control actions
Raito supports multiple actions for access controls, which behave differently
- Grant: single data source access control which can have data objects in the what-list and be used in the who-list of other grants.
- Purpose: multi data source access control which do not have data objects the what-list, but can be used in the who-list of grants and other purposes.
- Mask: single data source access control which mask data for the columns in its what-list
- Filter: single data source access control which filters data for the tables in its what-list
Access
Someone or something has access to a data object when it at least has one permission towards that data object via an unpacked grant access control.
Raito Graph
The Raito Graph is the graph structure that is built inside of Raito Cloud. It contains and interconnects the metadata of all data sources, the users and groups from the identity stores, the access controls, data usage, … This graph allows us to extract knowlegde and actionable insights out of all the metadata supplied.