Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
lib/chkname.c: login_name_max_size(): Put limits for LOGIN_NAME_MAX a…
…nd sysconf(_SC_LOGIN_NAME_MAX) GNU Hurd recommends having no system limits. When a program needs a limit, because it needs to validate user input, it is recommended that each program defines its own limit macros. The rationale is that this avoids hard-coded limits in ABIs, which cannot be modified ever. However, that doesn't mean that programs should have no limits at all. We use this limit for validating user input, and so we shouldn't allow anything just because the system doesn't want to set a limit. So, when sysconf(2) returns -1, either due to an error or due to a claim for no limits, we must fall back to the LOGIN_NAME_MAX value. And if the system doesn't define that value, we must define it ourselves (we're more or less free to choose any value, so let's pick the one that glibc provides nowadays). Fixes: 6a1f45d (2024-02-04: "lib/chkname.c: Support unlimited user name lengths") Closes: <#1166> Co-developed-by: Chris Hofstaedtler <[email protected]> Cc: Tobias Stoeckmann <[email protected]> Cc: Samuel Thibault <[email protected]> Signed-off-by: Alejandro Colomar <[email protected]>
- Loading branch information