Create service accounts
It’s a best practice to use service accounts (i.e., non-human users) to connect external applications and services to Materialize. As an administrator of a Materialize organization, you can create service accounts manually via the Materialize Console, or programatically via Terraform.
More granular permissions for the service account can then be configured using role-based access control (RBAC).
Materialize Console
-
In the side navigation bar, click + Create New > App Password.
-
In the New app password modal, select Type > Service and name the new app password. Under User, specify the new service user you’d like to create and associate with the new app password.
-
Under Roles, select Organization Admin or Organization Member depending on the level of database access the service user needs:
-
Organization Admin
: has superuser privileges in the database. -
Organization Member
: has restricted access to the database, depending on the privileges defined via role-based access control (RBAC).
-
-
Click Create Password to create the new service account.
For general guidance on using the Materialize Console for admin tasks, see the reference documentation.
Terraform
Minimum requirements: terraform-provider-materialize
v0.8.1+
-
Create a new service user using the
materialize_role
resource:resource "materialize_role" "production_dashboard" { name = "svc_production_dashboard" region = "aws/us-east-1" }
-
Create a new
service
app password using thematerialize_app_password
resource, and associate it with the service user created in the previous step:resource "materialize_app_password" "production_dashboard" { name = "production_dashboard_app_password" type = "service" user = materialize_role.production_dashboard.name roles = ["Member"] }
-
Optionally, associate the new service user with existing roles to grant it existing database privileges.
resource "materialize_database_grant" "database_usage" { role_name = materialize_role.production_dashboard.name privilege = "USAGE" database_name = "production_analytics" region = "aws/us-east-1" }
-
Export the user and password for use in the external application or service.
output "production_dashboard_user" { value = materialize_role.production_dashboard.name } output "production_dashboard_password" { value = materialize_app_password.production_dashboard.password }
For general guidance on using the Materialize Terraform provider to manage resources in your region, see the reference documentation.