Functions¶
The pg_tde extension provides functions for managing different aspects of its operation:
Note
If no error is reported when running the commands below, the operation completed successfully.
Key provider management¶
A key provider is a system or service responsible for managing encryption keys. pg_tde supports the following key providers:
- local file (not recommended for production use)
- HashiCorp Vault / OpenBao
- KMIP compatible providers
Key provider management includes the following operations:
- creating a new key provider,
- changing an existing key provider,
- deleting a key provider,
- listing key providers.
Add a key provider¶
You can add a new key provider using the provided functions, which are implemented for each provider type.
There are two functions to add a key provider: one function adds it for the current database and another one - for the global scope.
- pg_tde_add_database_key_provider_<type>('provider-name', <provider specific parameters>)
- pg_tde_add_global_key_provider_<type>('provider-name', <provider specific parameters>)
When you add a new provider, the provider name must be unique in the scope. But a local database provider and a global provider can have the same name.
Change an existing provider¶
You can change an existing key provider using the provided functions, which are implemented for each provider type.
There are two functions to change existing providers: one to change a provider in the current database, and another one to change a provider in the global scope.
- pg_tde_change_database_key_provider_<type>('provider-name', <provider specific parameters>)
- pg_tde_change_global_key_provider_<type>('provider-name', <provider specific parameters>)
When you change a provider, the referred name must exist in the database local or a global scope.
The change functions require the same parameters as the add functions. They overwrite the setting for every parameter except for the name, which can’t be changed.
Provider specific parameters differ for each implementation. Refer to the respective subsection for details.
Note
The updated provider must be able to retrieve the same principal keys as the original configuration. If the new configuration cannot access existing keys, encrypted data and backups will become unreadable.
Add or modify Vault providers¶
The Vault provider connects to a HashiCorp Vault or an OpenBao server, and stores the keys on a key-value store version 2.
Use the following functions to add the Vault provider:
SELECT pg_tde_add_database_key_provider_vault_v2(
  'provider-name',
  'url',
  'mount',
  'secret_token_path',
  'ca_path'
);
SELECT pg_tde_add_global_key_provider_vault_v2(
  'provider-name',
  'url',
  'mount',
  'secret_token_path',
  'ca_path'
);
These functions change the Vault provider:
SELECT pg_tde_change_database_key_provider_vault_v2(
  'provider-name',
  'url',
  'mount',
  'secret_token_path',
  'ca_path'
);
SELECT pg_tde_change_global_key_provider_vault_v2(
  'provider-name',
  'url',
  'mount',
  'secret_token_path',
  'ca_path'
);
where:
- provider-nameis the name of the key provider
- urlis the URL of the Vault server
- mountis the mount point on the Vault server where the key provider should store the keys
- secret_token_pathis a path to the file that contains an access token with read and write access to the above mount point
- [optional] ca_pathis the path of the CA file used for SSL verification
Add or modify KMIP providers¶
The KMIP provider uses a remote KMIP server.
Use these functions to add a KMIP provider:
SELECT pg_tde_add_database_key_provider_kmip(
  'provider-name',
  'kmip-addr',
  port,
  '/path_to/client_cert.pem',
  '/path_to/client_key.pem',
  '/path_to/server_certificate.pem'
);
SELECT pg_tde_add_global_key_provider_kmip(
  'provider-name',
  'kmip-addr',
  port,
  '/path_to/client_certificate.pem',
  '/path_to/client_key.pem',
  '/path_to/server_certificate.pem'
);
These functions change the KMIP provider:
SELECT pg_tde_change_database_key_provider_kmip(
  'provider-name',
  'kmip-addr',
  port,
  '/path_to/client_cert.pem',
  '/path_to/client_key.pem',
  '/path_to/server_certificate.pem'
);
SELECT pg_tde_change_global_key_provider_kmip(
  'provider-name',
  'kmip-addr',
  port,
  '/path_to/client_certificate.pem',
  '/path_to/client_key.pem',
  '/path_to/server_certificate.pem'
);
where:
- provider-nameis the name of the provider
- kmip-addris the IP address or domain name of the KMIP server
- portis the port to communicate with the KMIP server. Most KMIP servers use port 5696.
- server-certificateis the path to the certificate file for the KMIP server.
- client-certificateis the path to the client certificate.
- client-keyis the path to the client key.
Note
The specified access parameters require permission to read and write keys at the server.
Add or modify local key file providers¶
This provider manages database keys using a local key file.
This function is intended for development or quick testing, and stores the keys unencrypted in the specified data file.
Important
Local key file providers are not recommended for production environments, they lack the security and manageability of external key management systems.
Add a local key file provider:
SELECT pg_tde_add_database_key_provider_file(
  'provider-name',
  '/path/to/the/key/provider/data.file'
);
SELECT pg_tde_add_global_key_provider_file(
  'provider-name',
  '/path/to/the/key/provider/data.file'
);
Change a local key file provider:
SELECT pg_tde_change_database_key_provider_file(
  'provider-name',
  '/path/to/the/key/provider/data.file'
);
SELECT pg_tde_change_global_key_provider_file(
  'provider-name',
  '/path/to/the/key/provider/data.file'
);
where:
- provider-nameis the name of the provider. You can specify any name, it’s for you to identify the provider.
- /path/to/the/key/provider/data.fileis the path to the key provider file.
Delete a provider¶
These functions delete an existing provider in the current database or in the global scope:
- pg_tde_delete_database_key_provider('provider-name)
- pg_tde_delete_global_key_provider('provider-name)
You can only delete key providers that are not currently in use. An error is returned if the current principal key is using the provider you are trying to delete.
If the use of global key providers is enabled via the pg_tde.inherit_global GUC, you can delete a global key provider only if it isn’t used anywhere, including any databases. If it is used in any database, an error is returned instead.
List key providers¶
These functions list the details of all key providers for the current database or for the global scope, including all configuration values:
- pg_tde_list_all_database_key_providers()
- pg_tde_list_all_global_key_providers()
Principal key management¶
Use these functions to create a new principal key at a given keyprover, and to use those keys for a specific scope such as a current database, a global or default scope. You can also use them to start using a different existing key for a specific scope.
Principal keys are stored on key providers by the name specified in this function - for example, when using the Vault provider, after creating a key named “foo”, a key named “foo” will be visible on the Vault server at the specified mount point.
pg_tde_create_key_using_database_key_provider¶
Creates a principal key using the database-local key provider with the specified name. Use this key later with pg_tde_set_key_using_database_key_provider().
SELECT pg_tde_create_key_using_database_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_create_key_using_global_key_provider¶
Creates a principal key at a global key provider with the given name. Use this key later with the pg_tde_set_* series of functions.
SELECT pg_tde_create_key_using_global_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_set_key_using_database_key_provider¶
Sets the principal key for the current database, using the specified local key provider. It also rotates internal encryption keys to use the specified principal key.
This function is typically used when working with per-database encryption through a local key provider.
SELECT pg_tde_set_key_using_database_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_set_key_using_global_key_provider¶
Sets or rotates the global principal key using the specified global key provider and the key name. This key is used for global settings like WAL encryption.
SELECT pg_tde_set_key_using_global_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_set_server_key_using_global_key_provider¶
Sets or rotates the server principal key using the specified global key provider. Use this function to set a principal key for WAL encryption.
SELECT pg_tde_set_server_key_using_global_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_set_default_key_using_global_key_provider¶
Sets or rotates the default principal key for the server using the specified global key provider.
The default key is automatically used as a principal key by any database that doesn’t have an individual key provider and key configuration.
SELECT pg_tde_set_default_key_using_global_key_provider(
  'key-name',
  'provider-name'
);
pg_tde_delete_key¶
Unsets the principal key for the current database. If the current database has any encrypted tables, and there isn’t a default principal key configured, it reports an error instead. If there are encrypted tables, but there’s also a default principal key, internal keys will be encrypted with the default key.
SELECT pg_tde_delete_key();
pg_tde_delete_default_key¶
Unsets default principal key. It’s possible only if no database uses default principal key.
SELECT pg_tde_delete_default_key();
Encryption status check¶
pg_tde_is_encrypted¶
Tells if a relation is encrypted using the pg_tde extension or not. Returns
NULL if a relation lacks storage like views, foreign tables, and partitioned
tables and indexes.
To verify that a table is encrypted, run the following statement:
SELECT pg_tde_is_encrypted(
  'table_name'
);
You can also verify if the table in a custom schema is encrypted. Pass the schema name for the function as follows:
SELECT pg_tde_is_encrypted(
  'schema.table_name'
);
This can additionally be used to verify that indexes and sequences are encrypted.
pg_tde_key_info¶
Displays information about the principal key for the current database, if it exists.
SELECT pg_tde_key_info();
pg_tde_server_key_info¶
Displays information about the principal key for the server scope, if exists.
SELECT pg_tde_server_key_info();
pg_tde_default_key_info¶
Displays the information about the default principal key, if it exists.
SELECT pg_tde_default_key_info();
pg_tde_verify_key¶
This function checks that the current database has a properly functional encryption setup, which means:
- A key provider is configured
- The key provider is accessible using the specified configuration
- There is a principal key for the database
- The principal key can be retrieved from the remote key provider
- The principal key returned from the key provider is the same as cached in the server memory
If any of the above checks fail, the function reports an error.
SELECT pg_tde_verify_key();
pg_tde_verify_server_key¶
This function checks that the server scope has a properly functional encryption setup, which means:
- A key provider is configured
- The key provider is accessible using the specified configuration
- There is a principal key for the global scope
- The principal key can be retrieved from the remote key provider
- The principal key returned from the key provider is the same as cached in the server memory
If any of the above checks fail, the function reports an error.
SELECT pg_tde_verify_server_key();
pg_tde_verify_default_key¶
This function checks that the default key is properly configured, which means:
- A key provider is configured
- The key provider is accessible using the specified configuration
- There is a principal key that can be used for any scope
- The principal key can be retrieved from the remote key provider
- The principal key returned from the key provider is the same as cached in the server memory
If any of the above checks fail, the function reports an error.
SELECT pg_tde_verify_default_key();