Fix parsing of mdmfs(8) option "-w <user>:<group>" in case <user> or

<group> is a numeric user/group ID instead of a user/group name (as
explicitly intended to be allowed by both the manual page and the
implementation).

Before this fix, mdmfs(8) aborted:

| # mdmfs -s 32m -w 0:0 md /var/tmp/foo
| Assertion failed: (mip->mi_have_uid), function extract_ugid, file /usr/src/sbin/mdmfs/mdmfs.c, line 555.
| Abort trap (core dumped)

The "mi_have_[ug]id" fields were only set in case a name lookup was
successful. Instead they also have to be set in case the string to
integer conversion was successful.

Additionally, as a result of this fix, two assertions at the end of
the function are now always true and hence can be just be removed. It
is guarrantied that both the UID and the GID are set when the function
returns regularily, else it would have been already bailed out with
usage()/exit(3) or errx(3) before.

Spotted by:	Christoph Schug <chris@schug.net>
MFC after:	3 days
This commit is contained in:
Ralf S. Engelschall 2005-10-14 11:21:21 +00:00
parent 66e58c20dd
commit de90a634cb
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=151315

View File

@ -497,6 +497,10 @@ do_newfs(const char *args)
*
* In other words, this derives a user and group id from a string
* formatted like the last argument to chown(1).
*
* Notice: At this point we don't support only a username or only a
* group name. do_mtptsetup already does, so when this feature is
* desired, this is the only routine that needs to be changed.
*/
static void
extract_ugid(const char *str, struct mtpt_info *mip)
@ -530,8 +534,8 @@ extract_ugid(const char *str, struct mtpt_info *mip)
if (pw == NULL)
errx(1, "invalid user: %s", user);
*uid = pw->pw_uid;
mip->mi_have_uid = true;
}
mip->mi_have_uid = true;
/* Derive gid. */
*gid = strtoul(group, &p, 10);
@ -542,18 +546,10 @@ extract_ugid(const char *str, struct mtpt_info *mip)
if (gr == NULL)
errx(1, "invalid group: %s", group);
*gid = gr->gr_gid;
mip->mi_have_gid = true;
}
mip->mi_have_gid = true;
free(ug);
/*
* At this point we don't support only a username or only a
* group name. do_mtptsetup already does, so when this
* feature is desired, this is the only routine that needs to
* be changed.
*/
assert(mip->mi_have_uid);
assert(mip->mi_have_gid);
}
/*