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:
parent
66e58c20dd
commit
de90a634cb
@ -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);
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user