2008-03-20 04:45:55 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
|
|
|
/*
|
2009-03-31 18:44:18 +05:30
|
|
|
* Check user and group names for illegal characters
|
2008-03-20 04:45:55 +05:30
|
|
|
*
|
|
|
|
* Copyright (C) 2008 Tito Ragusa <farmatito@tiscali.it>
|
|
|
|
*
|
2010-08-16 23:44:46 +05:30
|
|
|
* Licensed under GPLv2 or later, see file LICENSE in this source tree.
|
2008-03-20 04:45:55 +05:30
|
|
|
*/
|
|
|
|
|
|
|
|
#include "libbb.h"
|
|
|
|
|
|
|
|
/* To avoid problems, the username should consist only of
|
|
|
|
* letters, digits, underscores, periods, at signs and dashes,
|
|
|
|
* and not start with a dash (as defined by IEEE Std 1003.1-2001).
|
|
|
|
* For compatibility with Samba machine accounts $ is also supported
|
|
|
|
* at the end of the username.
|
|
|
|
*/
|
|
|
|
|
2008-06-27 08:22:20 +05:30
|
|
|
void FAST_FUNC die_if_bad_username(const char *name)
|
2008-03-20 04:45:55 +05:30
|
|
|
{
|
2011-08-09 07:35:13 +05:30
|
|
|
const char *start = name;
|
|
|
|
|
|
|
|
/* 1st char being dash or dot isn't valid:
|
|
|
|
* for example, name like ".." can make adduser
|
|
|
|
* chown "/home/.." recursively - NOT GOOD.
|
|
|
|
* Name of just a single "$" is also rejected.
|
2010-02-07 02:20:59 +05:30
|
|
|
*/
|
2011-08-09 07:35:13 +05:30
|
|
|
goto skip;
|
2010-02-07 02:20:59 +05:30
|
|
|
|
2008-03-20 04:45:55 +05:30
|
|
|
do {
|
2011-08-09 07:35:13 +05:30
|
|
|
unsigned char ch;
|
|
|
|
|
|
|
|
/* These chars are valid unless they are at the 1st pos: */
|
|
|
|
if (*name == '-'
|
|
|
|
|| *name == '.'
|
|
|
|
/* $ is allowed if it's the last char: */
|
|
|
|
|| (*name == '$' && !name[1])
|
|
|
|
) {
|
2008-03-20 04:55:00 +05:30
|
|
|
continue;
|
2011-08-09 07:35:13 +05:30
|
|
|
}
|
2008-03-20 04:55:00 +05:30
|
|
|
skip:
|
2011-08-09 07:35:13 +05:30
|
|
|
ch = *name;
|
|
|
|
if (ch == '_'
|
|
|
|
/* || ch == '@' -- we disallow this too. Think about "user@host" */
|
|
|
|
/* open-coded isalnum: */
|
|
|
|
|| (ch >= '0' && ch <= '9')
|
|
|
|
|| ((ch|0x20) >= 'a' && (ch|0x20) <= 'z')
|
2008-03-20 04:55:00 +05:30
|
|
|
) {
|
|
|
|
continue;
|
|
|
|
}
|
2011-08-09 07:35:13 +05:30
|
|
|
bb_error_msg_and_die("illegal character with code %u at position %u",
|
|
|
|
(unsigned)ch, (unsigned)(name - start));
|
2008-03-20 04:45:55 +05:30
|
|
|
} while (*++name);
|
2011-08-09 07:35:13 +05:30
|
|
|
|
|
|
|
/* The minimum size of the login name is one char or two if
|
|
|
|
* last char is the '$'. Violations of this are caught above.
|
|
|
|
* The maximum size of the login name is LOGIN_NAME_MAX
|
|
|
|
* including the terminating null byte.
|
|
|
|
*/
|
|
|
|
if (name - start >= LOGIN_NAME_MAX)
|
|
|
|
bb_error_msg_and_die("name is too long");
|
2008-03-20 04:45:55 +05:30
|
|
|
}
|