Skip to content

Commit c5a9455

Browse files
authored
docs: Add an example for PGRST_APP_SETTINGS_* (#3804)
1 parent d78877c commit c5a9455

File tree

1 file changed

+4
-0
lines changed

1 file changed

+4
-0
lines changed

docs/references/configuration.rst

+4
Original file line numberDiff line numberDiff line change
@@ -191,6 +191,10 @@ app.settings.*
191191

192192
Arbitrary settings that can be used to pass in secret keys directly as strings, or via OS environment variables. For instance: :code:`app.settings.jwt_secret = "$(MYAPP_JWT_SECRET)"` will take :code:`MYAPP_JWT_SECRET` from the environment and make it available to PostgreSQL functions as :code:`current_setting('app.settings.jwt_secret')`.
193193

194+
When using the environment variable `PGRST_APP_SETTINGS_*` form, the remainder of the variable is used as the new name. Case is not important : :code:`PGRST_APP_SETTINGS_MY_ENV_VARIABLE=some_value` can be accessed in postgres as :code:`current_setting('app.settings.my_env_variable')`.
195+
196+
The :code:`current_setting` function has `an optional boolean second <https://www.postgresql.org/docs/current/functions-admin.html#FUNCTIONS-ADMIN-SET>`_ argument to avoid it from raising an error if the value was not defined. Default values to :code:`app.settings` can then be given by combining this argument with :code:`coalesce` and :code:`nullif` : :code:`coalesce(nullif(current_setting('app.settings.my_custom_variable', true), ''), 'default value')`. The use of :code:`nullif` is necessary because if set in a transaction, the setting is sometimes not "rolled back" to :code:`null`. See also :ref:`this section <guc_req_headers_cookies_claims>` for more information on this behaviour.
197+
194198
.. _db-aggregates-enabled:
195199

196200
db-aggregates-enabled

0 commit comments

Comments
 (0)