* src/usermod.c: Cast dates to time_t, and number of days to a
long integer. * src/usermod.c: Cast UIDs and GIDs to uid_t and gid_t after checking the ranges. * src/usermod.c: The ID argument of audit_logger is an unsigned int. * src/usermod.c: read() returns a ssize_t. * src/usermod.c: Cast the return value of malloc and make sure it receives a size_t.
This commit is contained in:
parent
2fa4cedb1e
commit
906e8c0001
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
|||||||
|
2008-06-13 Nicolas François <nicolas.francois@centraliens.net>
|
||||||
|
|
||||||
|
* src/usermod.c: Cast dates to time_t, and number of days to a
|
||||||
|
long integer.
|
||||||
|
* src/usermod.c: Cast UIDs and GIDs to uid_t and gid_t after
|
||||||
|
checking the ranges.
|
||||||
|
* src/usermod.c: The ID argument of audit_logger is an unsigned
|
||||||
|
int.
|
||||||
|
* src/usermod.c: read() returns a ssize_t.
|
||||||
|
* src/usermod.c: Cast the return value of malloc and make sure it
|
||||||
|
receives a size_t.
|
||||||
|
|
||||||
2008-06-13 Nicolas François <nicolas.francois@centraliens.net>
|
2008-06-13 Nicolas François <nicolas.francois@centraliens.net>
|
||||||
|
|
||||||
* src/logoutd.c: Ignore return value of time() when use with a
|
* src/logoutd.c: Ignore return value of time() when use with a
|
||||||
|
122
src/usermod.c
122
src/usermod.c
@ -172,7 +172,7 @@ static void date_to_str (char *buf, size_t maxsize,
|
|||||||
if ((negativ != NULL) && (date < 0)) {
|
if ((negativ != NULL) && (date < 0)) {
|
||||||
strncpy (buf, negativ, maxsize);
|
strncpy (buf, negativ, maxsize);
|
||||||
} else {
|
} else {
|
||||||
time_t t = date;
|
time_t t = (time_t) date;
|
||||||
tp = gmtime (&t);
|
tp = gmtime (&t);
|
||||||
#ifdef HAVE_STRFTIME
|
#ifdef HAVE_STRFTIME
|
||||||
strftime (buf, maxsize, "%Y-%m-%d", tp);
|
strftime (buf, maxsize, "%Y-%m-%d", tp);
|
||||||
@ -195,7 +195,7 @@ static struct group *getgr_nam_gid (const char *grname)
|
|||||||
|
|
||||||
val = strtol (grname, &errptr, 10);
|
val = strtol (grname, &errptr, 10);
|
||||||
if (*grname != '\0' && *errptr == '\0' && errno != ERANGE && val >= 0) {
|
if (*grname != '\0' && *errptr == '\0' && errno != ERANGE && val >= 0) {
|
||||||
return xgetgrgid (val);
|
return xgetgrgid ((gid_t) val);
|
||||||
}
|
}
|
||||||
return xgetgrnam (grname);
|
return xgetgrnam (grname);
|
||||||
}
|
}
|
||||||
@ -344,8 +344,9 @@ static char *new_pw_passwd (char *pw_pass)
|
|||||||
char *buf = xmalloc (strlen (pw_pass) + 2);
|
char *buf = xmalloc (strlen (pw_pass) + 2);
|
||||||
|
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "updating passwd",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 0);
|
"updating passwd",
|
||||||
|
user_newname, (unsigned int) user_newid, 0);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "lock user `%s' password", user_newname));
|
SYSLOG ((LOG_INFO, "lock user `%s' password", user_newname));
|
||||||
strcpy (buf, "!");
|
strcpy (buf, "!");
|
||||||
@ -363,8 +364,9 @@ static char *new_pw_passwd (char *pw_pass)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "updating password",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 0);
|
"updating password",
|
||||||
|
user_newname, (unsigned int) user_newid, 0);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "unlock user `%s' password", user_newname));
|
SYSLOG ((LOG_INFO, "unlock user `%s' password", user_newname));
|
||||||
s = pw_pass;
|
s = pw_pass;
|
||||||
@ -374,8 +376,9 @@ static char *new_pw_passwd (char *pw_pass)
|
|||||||
}
|
}
|
||||||
} else if (pflg) {
|
} else if (pflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "changing password",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 1);
|
"changing password",
|
||||||
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "change user `%s' password", user_newname));
|
SYSLOG ((LOG_INFO, "change user `%s' password", user_newname));
|
||||||
pw_pass = xstrdup (user_pass);
|
pw_pass = xstrdup (user_pass);
|
||||||
@ -393,8 +396,9 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
{
|
{
|
||||||
if (lflg) {
|
if (lflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "changing name",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 1);
|
"changing name",
|
||||||
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "change user name `%s' to `%s'",
|
SYSLOG ((LOG_INFO, "change user name `%s' to `%s'",
|
||||||
pwent->pw_name, user_newname));
|
pwent->pw_name, user_newname));
|
||||||
@ -407,8 +411,9 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
|
|
||||||
if (uflg) {
|
if (uflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "changing uid",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 1);
|
"changing uid",
|
||||||
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change user `%s' UID from `%d' to `%d'",
|
"change user `%s' UID from `%d' to `%d'",
|
||||||
@ -418,8 +423,8 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
if (gflg) {
|
if (gflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing primary group", user_newname,
|
"changing primary group",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change user `%s' GID from `%d' to `%d'",
|
"change user `%s' GID from `%d' to `%d'",
|
||||||
@ -428,8 +433,9 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
}
|
}
|
||||||
if (cflg) {
|
if (cflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "changing comment",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 1);
|
"changing comment",
|
||||||
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
pwent->pw_gecos = user_newcomment;
|
pwent->pw_gecos = user_newcomment;
|
||||||
}
|
}
|
||||||
@ -437,8 +443,8 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
if (dflg) {
|
if (dflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing home directory", user_newname,
|
"changing home directory",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change user `%s' home from `%s' to `%s'",
|
"change user `%s' home from `%s' to `%s'",
|
||||||
@ -447,8 +453,9 @@ static void new_pwent (struct passwd *pwent)
|
|||||||
}
|
}
|
||||||
if (sflg) {
|
if (sflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "changing user shell",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_newname, user_newid, 1);
|
"changing user shell",
|
||||||
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "change user `%s' shell from `%s' to `%s'",
|
SYSLOG ((LOG_INFO, "change user `%s' shell from `%s' to `%s'",
|
||||||
pwent->pw_name, pwent->pw_shell, user_newshell));
|
pwent->pw_name, pwent->pw_shell, user_newshell));
|
||||||
@ -471,8 +478,8 @@ static void new_spent (struct spwd *spent)
|
|||||||
if (fflg) {
|
if (fflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing inactive days", user_newname,
|
"changing inactive days",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change user `%s' inactive from `%ld' to `%ld'",
|
"change user `%s' inactive from `%ld' to `%ld'",
|
||||||
@ -488,8 +495,8 @@ static void new_spent (struct spwd *spent)
|
|||||||
user_expire * DAY, "never");
|
user_expire * DAY, "never");
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing expiration date", user_newname,
|
"changing expiration date",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change user `%s' expiration from `%s' to `%s'",
|
"change user `%s' expiration from `%s' to `%s'",
|
||||||
@ -498,7 +505,7 @@ static void new_spent (struct spwd *spent)
|
|||||||
}
|
}
|
||||||
spent->sp_pwdp = new_pw_passwd (spent->sp_pwdp);
|
spent->sp_pwdp = new_pw_passwd (spent->sp_pwdp);
|
||||||
if (pflg) {
|
if (pflg) {
|
||||||
spent->sp_lstchg = time ((time_t *) 0) / SCALE;
|
spent->sp_lstchg = (long) time ((time_t *) 0) / SCALE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -523,8 +530,9 @@ static void fail_exit (int code)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog, "modifying account",
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
user_name, -1, 0);
|
"modifying account",
|
||||||
|
user_name, AUDIT_NO_ID, 0);
|
||||||
#endif
|
#endif
|
||||||
exit (code);
|
exit (code);
|
||||||
}
|
}
|
||||||
@ -574,8 +582,8 @@ static void update_group (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing group member",
|
"changing group member",
|
||||||
user_newname, -1, 1);
|
user_newname, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change `%s' to `%s' in group `%s'",
|
"change `%s' to `%s' in group `%s'",
|
||||||
@ -587,8 +595,8 @@ static void update_group (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"removing group member", user_name, -1,
|
"removing group member",
|
||||||
1);
|
user_name, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "delete `%s' from group `%s'",
|
SYSLOG ((LOG_INFO, "delete `%s' from group `%s'",
|
||||||
user_name, ngrp->gr_name));
|
user_name, ngrp->gr_name));
|
||||||
@ -597,7 +605,8 @@ static void update_group (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"adding user to group", user_name, -1, 1);
|
"adding user to group",
|
||||||
|
user_name, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "add `%s' to group `%s'",
|
SYSLOG ((LOG_INFO, "add `%s' to group `%s'",
|
||||||
user_newname, ngrp->gr_name));
|
user_newname, ngrp->gr_name));
|
||||||
@ -669,8 +678,8 @@ static void update_gshadow (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing admin name in shadow group",
|
"changing admin name in shadow group",
|
||||||
user_name, -1, 1);
|
user_name, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change admin `%s' to `%s' in shadow group `%s'",
|
"change admin `%s' to `%s' in shadow group `%s'",
|
||||||
@ -685,8 +694,8 @@ static void update_gshadow (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing member in shadow group",
|
"changing member in shadow group",
|
||||||
user_name, -1, 1);
|
user_name, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"change `%s' to `%s' in shadow group `%s'",
|
"change `%s' to `%s' in shadow group `%s'",
|
||||||
@ -698,8 +707,8 @@ static void update_gshadow (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"removing user from shadow group",
|
"removing user from shadow group",
|
||||||
user_name, -1, 1);
|
user_name, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO,
|
SYSLOG ((LOG_INFO,
|
||||||
"delete `%s' from shadow group `%s'",
|
"delete `%s' from shadow group `%s'",
|
||||||
@ -709,8 +718,8 @@ static void update_gshadow (void)
|
|||||||
changed = true;
|
changed = true;
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"adding user to shadow group",
|
"adding user to shadow group",
|
||||||
user_newname, -1, 1);
|
user_newname, AUDIT_NO_ID, 1);
|
||||||
#endif
|
#endif
|
||||||
SYSLOG ((LOG_INFO, "add `%s' to shadow group `%s'",
|
SYSLOG ((LOG_INFO, "add `%s' to shadow group `%s'",
|
||||||
user_newname, nsgrp->sg_name));
|
user_newname, nsgrp->sg_name));
|
||||||
@ -775,7 +784,7 @@ static uid_t get_id (const char *uidstr)
|
|||||||
uidstr);
|
uidstr);
|
||||||
exit (E_BAD_ARG);
|
exit (E_BAD_ARG);
|
||||||
}
|
}
|
||||||
return val;
|
return (uid_t) val;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1320,10 +1329,11 @@ static void move_home (void)
|
|||||||
}
|
}
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK,
|
audit_logger (AUDIT_USER_CHAUTHTOK,
|
||||||
Prog,
|
Prog,
|
||||||
"moving home directory",
|
"moving home directory",
|
||||||
user_newname, user_newid,
|
user_newname,
|
||||||
1);
|
(unsigned int) user_newid,
|
||||||
|
1);
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1340,15 +1350,15 @@ static void move_home (void)
|
|||||||
}
|
}
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"moving home directory", user_newname, user_newid,
|
"moving home directory",
|
||||||
1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (uflg || gflg) {
|
if (uflg || gflg) {
|
||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing home directory owner", user_newname,
|
"changing home directory owner",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
#endif
|
#endif
|
||||||
chown (dflg ? user_newhome : user_home,
|
chown (dflg ? user_newhome : user_home,
|
||||||
uflg ? user_newid : user_id,
|
uflg ? user_newid : user_id,
|
||||||
@ -1373,7 +1383,7 @@ static void update_files (void)
|
|||||||
fd = open (LASTLOG_FILE, O_RDWR);
|
fd = open (LASTLOG_FILE, O_RDWR);
|
||||||
if (-1 != fd) {
|
if (-1 != fd) {
|
||||||
lseek (fd, (off_t) user_id * sizeof ll, SEEK_SET);
|
lseek (fd, (off_t) user_id * sizeof ll, SEEK_SET);
|
||||||
if (read (fd, (char *) &ll, sizeof ll) == sizeof ll) {
|
if (read (fd, (char *) &ll, sizeof ll) == (ssize_t) sizeof ll) {
|
||||||
lseek (fd, (off_t) user_newid * sizeof ll, SEEK_SET);
|
lseek (fd, (off_t) user_newid * sizeof ll, SEEK_SET);
|
||||||
write (fd, (char *) &ll, sizeof ll);
|
write (fd, (char *) &ll, sizeof ll);
|
||||||
}
|
}
|
||||||
@ -1386,7 +1396,7 @@ static void update_files (void)
|
|||||||
fd = open (FAILLOG_FILE, O_RDWR);
|
fd = open (FAILLOG_FILE, O_RDWR);
|
||||||
if (-1 != fd) {
|
if (-1 != fd) {
|
||||||
lseek (fd, (off_t) user_id * sizeof fl, SEEK_SET);
|
lseek (fd, (off_t) user_id * sizeof fl, SEEK_SET);
|
||||||
if (read (fd, (char *) &fl, sizeof fl) == sizeof fl) {
|
if (read (fd, (char *) &fl, sizeof fl) == (ssize_t) sizeof fl) {
|
||||||
lseek (fd, (off_t) user_newid * sizeof fl, SEEK_SET);
|
lseek (fd, (off_t) user_newid * sizeof fl, SEEK_SET);
|
||||||
write (fd, (char *) &fl, sizeof fl);
|
write (fd, (char *) &fl, sizeof fl);
|
||||||
}
|
}
|
||||||
@ -1452,8 +1462,8 @@ static void move_mailbox (void)
|
|||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
else {
|
else {
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing mail file owner", user_newname,
|
"changing mail file owner",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -1470,8 +1480,8 @@ static void move_mailbox (void)
|
|||||||
#ifdef WITH_AUDIT
|
#ifdef WITH_AUDIT
|
||||||
else {
|
else {
|
||||||
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
audit_logger (AUDIT_USER_CHAUTHTOK, Prog,
|
||||||
"changing mail file name", user_newname,
|
"changing mail file name",
|
||||||
user_newid, 1);
|
user_newname, (unsigned int) user_newid, 1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -1502,7 +1512,7 @@ int main (int argc, char **argv)
|
|||||||
(void) textdomain (PACKAGE);
|
(void) textdomain (PACKAGE);
|
||||||
|
|
||||||
sys_ngroups = sysconf (_SC_NGROUPS_MAX);
|
sys_ngroups = sysconf (_SC_NGROUPS_MAX);
|
||||||
user_groups = malloc ((1 + sys_ngroups) * sizeof (char *));
|
user_groups = (char **) malloc (sizeof (char *) * (1 + sys_ngroups));
|
||||||
user_groups[0] = (char *) 0;
|
user_groups[0] = (char *) 0;
|
||||||
|
|
||||||
OPENLOG ("usermod");
|
OPENLOG ("usermod");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user