docs/documentation/platform/dynamic-secrets/clickhouse.mdx
import DynamicSecretUsernameTemplateParamField from "/snippets/documentation/platform/dynamic-secrets/dynamic-secret-username-template-field.mdx";
The Infisical ClickHouse dynamic secret allows you to generate ClickHouse database credentials on demand based on a configured role.
Create a user with the required permissions in your ClickHouse instance. This user will be used to create new accounts on-demand.
CREATE USER 'infisical' IDENTIFIED WITH sha256_password BY '<strong-password>';
GRANT CREATE USER, DROP USER, GRANT OPTION ON *.* TO 'infisical';
<ParamField path="Default TTL" type="string" required>
Default time-to-live for a generated secret (it is possible to modify this value after a secret is generated)
</ParamField>
<ParamField path="Max TTL" type="string" required>
Maximum time-to-live for a generated secret
</ParamField>
<ParamField path="Metadata" type="list">
List of key/value metadata pairs
</ParamField>
<ParamField path="Host" type="string" required>
ClickHouse server hostname or IP address (e.g., `https://your-host.clickhouse.cloud`)
</ParamField>
<ParamField path="Port" type="number" required>
ClickHouse HTTP interface port. Use `8123` for HTTP or `8443` for HTTPS / ClickHouse Cloud.
</ParamField>
<ParamField path="User" type="string" required>
Username of the service account that will be used to create dynamic credentials
</ParamField>
<ParamField path="Password" type="string" required>
Password of the service account that will be used to create dynamic credentials
</ParamField>
<ParamField path="Database Name" type="string" required>
Name of the database for which you want to create dynamic secrets. Defaults to `default`.
</ParamField>
<ParamField path="Gateway" type="string">
A gateway may be required if your ClickHouse instance is not publicly accessible (e.g. in a private VPC). Select a configured gateway to route traffic through it.
</ParamField>
<ParamField path="CA (SSL)" type="string">
Only needed if your ClickHouse instance uses a self-signed or private CA certificate. ClickHouse Cloud uses publicly trusted certificates, so no CA is required — just include `https://` in the host. Providing a CA also enables HTTPS automatically.
</ParamField>

<DynamicSecretUsernameTemplateParamField />
<ParamField path="Creation Statement" type="string">
ClickHouse statement used to create the dynamic user. The default creates a user with SHA-256 password authentication and grants `SELECT` on all tables in the configured database.
Available template variables: `{{username}}`, `{{password}}`, `{{database}}`, `{{expiration}}`.
```sql
CREATE USER '{{username}}' IDENTIFIED WITH sha256_password BY '{{password}}';
GRANT SELECT ON {{database}}.* TO '{{username}}';
```
</ParamField>
<ParamField path="Revocation Statement" type="string">
ClickHouse statement used to revoke the dynamic user when a lease expires or is manually deleted.
```sql
DROP USER IF EXISTS '{{username}}';
```
</ParamField>
<ParamField path="Renew Statement" type="string">
Optional ClickHouse statement executed when a lease is renewed. Leave blank if no action is required on renewal.
</ParamField>
<Note>
ClickHouse does not support DDL transactions, so statements are executed sequentially. Ensure that each statement is separated by a semicolon (`;`).
</Note>
<Note>
If this step fails, verify that the service user has the `CREATE USER`, `DROP USER`, and `GRANT OPTION` privileges, and that the host and port are reachable from Infisical.
</Note>



When generating these secrets, it's important to specify a Time-to-Live (TTL) duration. This will dictate how long the credentials are valid for.

<Tip>
Ensure that the TTL for the lease falls within the maximum TTL defined when configuring the dynamic secret.
</Tip>
Once you click the **Submit** button, a new secret lease will be generated and the credentials from it will be shown to you.

Once you have created one or more leases, you will be able to access them by clicking on the respective dynamic secret item on the dashboard. This will allow you to see the expiration time of the lease or delete a lease before its set time to live.
To extend the life of the generated dynamic secret leases past its initial time to live, simply click on the Renew button as illustrated below.
<Warning> Lease renewals cannot exceed the maximum TTL set when configuring the dynamic secret </Warning>