login-utils/chfn.1 \
login-utils/chsh.1
-chfn_chsh_sources =
+chfn_chsh_sources = \
+ login-utils/ch-common.h \
+ login-utils/ch-common.c
chfn_chsh_cflags = $(SUID_CFLAGS) $(AM_CFLAGS)
chfn_chsh_ldflags = $(SUID_LDFLAGS) $(AM_LDFLAGS)
chfn_chsh_ldadd = libcommon.la
--- /dev/null
+/*
+ * chfn and chsh shared functions
+ *
+ * this program is free software. you can redistribute it and
+ * modify it under the terms of the gnu general public license.
+ * there is no warranty.
+ */
+
+#include <ctype.h>
+#include <string.h>
+
+#include "c.h"
+#include "nls.h"
+
+#include "ch-common.h"
+
+/*
+ * illegal_passwd_chars () -
+ * check whether a string contains illegal characters
+ */
+int illegal_passwd_chars(const char *str)
+{
+ const char illegal[] = ",:=\"\n";
+ const size_t len = strlen(str);
+ size_t i;
+
+ if (strpbrk(str, illegal))
+ return 1;
+ for (i = 0; i < len; i++) {
+ if (iscntrl(str[i]))
+ return 1;
+ }
+ return 0;
+}
--- /dev/null
+#ifndef UTIL_LINUX_CH_COMMON_H
+#define UTIL_LINUX_CH_COMMON_H
+
+extern int illegal_passwd_chars(const char *str);
+
+#endif /* UTIL_LINUX_CH_COMMON */
#include "xalloc.h"
#include "logindefs.h"
+#include "ch-common.h"
+
#ifdef HAVE_LIBSELINUX
# include <selinux/selinux.h>
# include <selinux/av_permissions.h>
*/
static int check_gecos_string(const char *msg, char *gecos)
{
- unsigned int i, c;
const size_t len = strlen(gecos);
if (MAX_FIELD_SIZE < len) {
warnx(_("field %s is too long"), msg);
return -1;
}
- for (i = 0; i < len; i++) {
- c = gecos[i];
- if (c == ',' || c == ':' || c == '=' || c == '"' || c == '\n') {
- warnx(_("%s: '%c' is not allowed"), msg, c);
- return -1;
- }
- if (iscntrl(c)) {
- warnx(_("%s: control characters are not allowed"), msg);
- return -1;
- }
+ if (illegal_passwd_chars(gecos)) {
+ warnx(_("%s: has illegal characters"), gecos);
+ return -1;
}
return 0;
}
#include "setpwnam.h"
#include "xalloc.h"
+#include "ch-common.h"
+
#ifdef HAVE_LIBSELINUX
# include <selinux/selinux.h>
# include <selinux/av_permissions.h>
*/
static int check_shell(char *shell)
{
- unsigned int i, c;
-
if (!shell)
return -1;
printf(_("\"%s\" is not executable"), shell);
return -1;
}
- /* keep /etc/passwd clean. */
- for (i = 0; i < strlen(shell); i++) {
- c = shell[i];
- if (c == ',' || c == ':' || c == '=' || c == '"' || c == '\n') {
- warnx(_("'%c' is not allowed"), c);
- return -1;
- }
- if (iscntrl(c)) {
- warnx(_("control characters are not allowed"));
- return -1;
- }
+ if (illegal_passwd_chars(shell)) {
+ warnx(_("%s: has illegal characters"), shell);
+ return -1;
}
#ifdef ONLY_LISTED_SHELLS
if (!get_shell_list(shell)) {