Disregard jails in jail.conf that have bad parameters (parameter/variable

clash, or redefining name/jid).  The current behvaior, of merely warning
and moving on, can lead to unexpected behavior when a jail is created
without the offending parameter defined at all.
This commit is contained in:
Jamie Gritton 2020-08-27 17:04:55 +00:00
parent 555e998919
commit 0eb6603f6b
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=364874

View File

@ -369,11 +369,13 @@ add_param(struct cfjail *j, const struct cfparam *p, enum intparam ipnum,
if ((flags ^ dp->flags) & PF_VAR) {
jail_warnx(j, "variable \"$%s\" cannot have the same "
"name as a parameter.", name);
j->flags |= JF_FAILED;
return;
}
if (dp->flags & PF_IMMUTABLE) {
jail_warnx(j, "cannot redefine parameter \"%s\".",
dp->name);
j->flags |= JF_FAILED;
return;
}
if (strcmp(dp->name, name)) {
@ -405,6 +407,7 @@ add_param(struct cfjail *j, const struct cfparam *p, enum intparam ipnum,
"cannot have the same "
"name as a parameter.",
name);
j->flags |= JF_FAILED;
return;
}
j->intparams[ipnum] = np;