summaryrefslogtreecommitdiff
path: root/src/common/wait_error.c
diff options
context:
space:
mode:
authorMichael Paquier <michael@paquier.xyz>2022-11-14 10:21:42 +0900
committerMichael Paquier <michael@paquier.xyz>2022-11-14 10:21:42 +0900
commit783e8c69cbcd2b7d6fce1f0c5b568b1c8b686d54 (patch)
treec270d46c2420382763a31068f963c8b8015a6633 /src/common/wait_error.c
parent45d5ecab49f6c0df607d3ca2ce1995229f416d1a (diff)
Invent open_auth_file() in hba.c to refactor authentication file opening
This adds a check on the recursion depth when including authentication configuration files, something that has never been done when processing '@' files for database and user name lists in pg_hba.conf. On HEAD, this was leading to a rather confusing error, as of: FATAL: exceeded maxAllocatedDescs (NN) while trying to open file "/path/blah.conf" This refactors the code so as the error reported is now the following, which is the same as for GUCs: FATAL: could not open file "/path/blah.conf": maximum nesting depth exceeded This reduces a bit the verbosity of the error message used for files included in user and database lists, reporting only the file name of what's failing to load, without mentioning the relative or absolute path specified after '@' in a HBA file. The absolute path is built upon what '@' defines anyway, so there is no actual loss of information. This makes the future inclusion logic much simpler. A follow-up patch will add an error context to be able to track on which line of which file the inclusion is failing, to close the loop, providing all the information needed to know the full chain of events. This logic has been extracted from a larger patch written by Julien, rewritten by me to have a unique code path calling AllocateFile() on authentication files, and is useful on its own. This new interface will be used later for authentication files included with @include[_dir,_if_exists], in a follow-up patch. Author: Michael Paquier, Julien Rouhaud Discussion: https://www.postgresql.org/message-id/Y2xUBJ+S+Z0zbxRW@paquier.xyz
Diffstat (limited to 'src/common/wait_error.c')
0 files changed, 0 insertions, 0 deletions