Access Management#
Access management in Doltgres is handled similarly to how it is handled in Postgres. Create users, roles, and grants with standard SQL statements. Access is determined by the privileges that a user has.
First Start#
By default, the first time you run the Doltgres server it will create a user named postgres with a
password password. This user is an admin with all rights to all tables.
You can change this behavior by settings the following environment variables:
DOLTGRES_USER: Set the first-run user createdDOLTGRES_PASSWORD: Set the first-run password created
Configuring Privileges#
Users and grants are stored in the auth.db file by default. This file stores privilege information
for all databases in a server.
YAML Configuration Option#
Use the auth_file: PATH line to your YAML config to change where the
privileges file is stored.
Editing Users#
Use psql or another client to connect to your running doltgres server as the admin user to
create new users and grant privileges. For example, the following statements create a new user1
user with the password ‘pass1’, and with broad permission on all tables in the current database (but
without the ability to GRANT privileges to other users):
CREATE USER user1 PASSWORD 'pass1';
GRANT ALL ON ALL TABLES IN SCHEMA public to user1;
For more details on editing users and their permissions, refer to the Postgres documentation on CREATE ROLE and GRANT statements.
Please note that not all permission functionality supported by Postgres is supported by Doltgres. If you find a gap you need addressed, please file an issue.
Statements#
For now, only some of the core statements are supported for users and privileges. Of those core statements, some are fully supported, while others only offer partial support.
Fully Supported#
CREATE ROLEDROP ROLEDROP USER
Partially Supported#
CREATE USER- Not all options are supported
GRANT- The form
GRANT <privileges> ON <privilege_level> TO <users...>does not yet support columns, an object type (tables only), or assuming a different user - The form
GRANT <roles...> TO <users...> [WITH ADMIN OPTION]is fully supported
- The form
REVOKE- The form
REVOKE <privileges...> ON <privilege_level> FROM <users...>does not yet support columns or an object type (tables only) - The form
REVOKE <roles...> FROM <users...>is fully supported - The form
REVOKE PROXY ...is not yet supported - The form
REVOKE ALL PRIVILEGES ...is not yet supported, which differs fromREVOKE ALL ON ...in functionality
- The form
Not Yet Supported#
ALTER USERALTER ROLE
pg_catalog Access to Users and Grants#
Doltgres exposes various user and grant information in the pg_catalog tables. Refer to the
Postgres documentation for more details on
the relevant tables and columns.