2008-04-27 00:40:09 +00:00
|
|
|
/*
|
2021-12-05 09:35:27 -06:00
|
|
|
* SPDX-FileCopyrightText: 1990 - 1994, Julianne Frances Haugh
|
|
|
|
* SPDX-FileCopyrightText: 1996 - 2000, Marek Michałkiewicz
|
|
|
|
* SPDX-FileCopyrightText: 2001 - 2005, Tomasz Kłoczko
|
|
|
|
* SPDX-FileCopyrightText: 2005 - 2008, Nicolas François
|
2008-04-27 00:40:09 +00:00
|
|
|
*
|
2021-12-05 09:35:27 -06:00
|
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
2008-04-27 00:40:09 +00:00
|
|
|
*/
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
/*
|
2008-05-25 20:58:16 +00:00
|
|
|
* is_valid_user_name(), is_valid_group_name() - check the new user/group
|
|
|
|
* name for validity;
|
|
|
|
* return values:
|
|
|
|
* true - OK
|
|
|
|
* false - bad name
|
2007-10-07 11:44:02 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2007-11-10 23:46:11 +00:00
|
|
|
#ident "$Id$"
|
2007-10-07 11:47:01 +00:00
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
#include <ctype.h>
|
|
|
|
#include "defines.h"
|
|
|
|
#include "chkname.h"
|
2008-05-25 20:58:16 +00:00
|
|
|
|
2019-08-23 21:42:37 +01:00
|
|
|
int allow_bad_names = false;
|
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
static bool is_valid_name (const char *name)
|
2007-10-07 11:44:02 +00:00
|
|
|
{
|
2019-08-23 21:42:37 +01:00
|
|
|
if (allow_bad_names) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
/*
|
2022-08-16 13:46:22 +02:00
|
|
|
* User/group names must match gnu e-regex:
|
|
|
|
* [a-zA-Z0-9_.][a-zA-Z0-9_.-]{0,30}[a-zA-Z0-9_.$-]?
|
|
|
|
*
|
|
|
|
* as a non-POSIX, extension, allow "$" as the last char for
|
|
|
|
* sake of Samba 3.x "add machine script"
|
|
|
|
*
|
|
|
|
* Also do not allow fully numeric names or just "." or "..".
|
|
|
|
*/
|
|
|
|
int numeric;
|
2019-08-23 21:42:37 +01:00
|
|
|
|
2022-08-16 13:46:22 +02:00
|
|
|
if ('\0' == *name ||
|
|
|
|
('.' == *name && (('.' == name[1] && '\0' == name[2]) ||
|
|
|
|
'\0' == name[1])) ||
|
|
|
|
!((*name >= 'a' && *name <= 'z') ||
|
|
|
|
(*name >= 'A' && *name <= 'Z') ||
|
|
|
|
(*name >= '0' && *name <= '9') ||
|
|
|
|
*name == '_' ||
|
|
|
|
*name == '.')) {
|
2008-05-25 20:58:16 +00:00
|
|
|
return false;
|
|
|
|
}
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2022-08-16 13:46:22 +02:00
|
|
|
numeric = isdigit(*name);
|
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
while ('\0' != *++name) {
|
2022-08-16 13:46:22 +02:00
|
|
|
if (!((*name >= 'a' && *name <= 'z') ||
|
|
|
|
(*name >= 'A' && *name <= 'Z') ||
|
|
|
|
(*name >= '0' && *name <= '9') ||
|
|
|
|
*name == '_' ||
|
|
|
|
*name == '.' ||
|
|
|
|
*name == '-' ||
|
|
|
|
(*name == '$' && name[1] == '\0')
|
2008-05-25 20:58:16 +00:00
|
|
|
)) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-08-16 13:46:22 +02:00
|
|
|
numeric &= isdigit(*name);
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|
|
|
|
|
2022-08-16 13:46:22 +02:00
|
|
|
return !numeric;
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
bool is_valid_user_name (const char *name)
|
2007-10-07 11:44:02 +00:00
|
|
|
{
|
|
|
|
/*
|
|
|
|
* User names are limited by whatever utmp can
|
2008-12-22 22:08:13 +00:00
|
|
|
* handle.
|
2007-10-07 11:44:02 +00:00
|
|
|
*/
|
2009-04-22 20:42:48 +00:00
|
|
|
if (strlen (name) > USER_NAME_MAX_LENGTH) {
|
2008-05-25 20:58:16 +00:00
|
|
|
return false;
|
|
|
|
}
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
return is_valid_name (name);
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
bool is_valid_group_name (const char *name)
|
2007-10-07 11:44:02 +00:00
|
|
|
{
|
|
|
|
/*
|
2008-12-22 22:08:13 +00:00
|
|
|
* Arbitrary limit for group names.
|
|
|
|
* HP-UX 10 limits to 16 characters
|
2007-10-07 11:44:02 +00:00
|
|
|
*/
|
2008-12-23 22:42:22 +00:00
|
|
|
if ( (GROUP_NAME_MAX_LENGTH > 0)
|
|
|
|
&& (strlen (name) > GROUP_NAME_MAX_LENGTH)) {
|
2008-05-25 20:58:16 +00:00
|
|
|
return false;
|
2008-12-23 22:42:22 +00:00
|
|
|
}
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2008-05-25 20:58:16 +00:00
|
|
|
return is_valid_name (name);
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|
2008-04-27 00:40:09 +00:00
|
|
|
|