Add VALIDATE_NOT_OK_NOPASS for when user is not allowed to run a command
but the NOPASSWD flag was set. Make runasspec, runaslist, runasuser, and nopasswd typeless in parse.yacc Add support for '!' in the runas list Fix double printing of '%' and '+' for groups and netgroups respectively Add *_matched macros (no need for local stack variable). Should only be used directly after a pop (since top must be >= 2).
This commit is contained in:
@@ -184,6 +184,7 @@ void log_error(code)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VALIDATE_NOT_OK:
|
case VALIDATE_NOT_OK:
|
||||||
|
case VALIDATE_NOT_OK_NOPASS:
|
||||||
(void) sprintf(p,
|
(void) sprintf(p,
|
||||||
"command not allowed ; TTY=%s ; PWD=%s ; USER=%s ; COMMAND=",
|
"command not allowed ; TTY=%s ; PWD=%s ; USER=%s ; COMMAND=",
|
||||||
tty, cwd, runas_user);
|
tty, cwd, runas_user);
|
||||||
@@ -580,6 +581,7 @@ void inform_user(code)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VALIDATE_NOT_OK:
|
case VALIDATE_NOT_OK:
|
||||||
|
case VALIDATE_NOT_OK_NOPASS:
|
||||||
(void) fprintf(stderr,
|
(void) fprintf(stderr,
|
||||||
"Sorry, user %s is not allowed to execute \"%s",
|
"Sorry, user %s is not allowed to execute \"%s",
|
||||||
user_name, cmnd);
|
user_name, cmnd);
|
||||||
@@ -719,6 +721,7 @@ static int appropriate(code)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VALIDATE_NOT_OK:
|
case VALIDATE_NOT_OK:
|
||||||
|
case VALIDATE_NOT_OK_NOPASS:
|
||||||
#ifdef SEND_MAIL_WHEN_NOT_OK
|
#ifdef SEND_MAIL_WHEN_NOT_OK
|
||||||
return (1);
|
return (1);
|
||||||
#else
|
#else
|
||||||
|
5
parse.c
5
parse.c
@@ -178,7 +178,10 @@ int validate(check_cmnd)
|
|||||||
return(VALIDATE_OK);
|
return(VALIDATE_OK);
|
||||||
} else if (cmnd_matches == FALSE) {
|
} else if (cmnd_matches == FALSE) {
|
||||||
/* User was explicitly denied acces to cmnd on host. */
|
/* User was explicitly denied acces to cmnd on host. */
|
||||||
return(VALIDATE_NOT_OK);
|
if (no_passwd == TRUE)
|
||||||
|
return(VALIDATE_NOT_OK_NOPASS);
|
||||||
|
else
|
||||||
|
return(VALIDATE_NOT_OK);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
78
parse.yacc
78
parse.yacc
@@ -199,10 +199,6 @@ void yyerror(s)
|
|||||||
|
|
||||||
%type <BOOLEAN> cmnd
|
%type <BOOLEAN> cmnd
|
||||||
%type <BOOLEAN> opcmnd
|
%type <BOOLEAN> opcmnd
|
||||||
%type <BOOLEAN> runasspec
|
|
||||||
%type <BOOLEAN> runaslist
|
|
||||||
%type <BOOLEAN> runasuser
|
|
||||||
%type <BOOLEAN> nopasswd
|
|
||||||
|
|
||||||
%%
|
%%
|
||||||
|
|
||||||
@@ -287,8 +283,8 @@ cmndspec : { /* Push a new entry onto the stack if needed */
|
|||||||
pushcp;
|
pushcp;
|
||||||
cmnd_matches = -1;
|
cmnd_matches = -1;
|
||||||
} runasspec nopasswd opcmnd {
|
} runasspec nopasswd opcmnd {
|
||||||
/* XXX - test runas_matches and cmnd_matches instead? */
|
if (printmatches == TRUE &&
|
||||||
if (($2 == -1 || $4 == -1) && printmatches == TRUE) {
|
(runas_matches == -1 || cmnd_matches == -1)) {
|
||||||
cm_list[cm_list_len].runas_len = 0;
|
cm_list[cm_list_len].runas_len = 0;
|
||||||
cm_list[cm_list_len].cmnd_len = 0;
|
cm_list[cm_list_len].cmnd_len = 0;
|
||||||
cm_list[cm_list_len].nopasswd = FALSE;
|
cm_list[cm_list_len].nopasswd = FALSE;
|
||||||
@@ -310,7 +306,6 @@ opcmnd : cmnd { ; }
|
|||||||
push;
|
push;
|
||||||
}
|
}
|
||||||
} opcmnd {
|
} opcmnd {
|
||||||
int cmnd_matched = cmnd_matches;
|
|
||||||
pop;
|
pop;
|
||||||
if (cmnd_matched == TRUE)
|
if (cmnd_matched == TRUE)
|
||||||
cmnd_matches = FALSE;
|
cmnd_matches = FALSE;
|
||||||
@@ -328,25 +323,41 @@ runasspec : /* empty */ {
|
|||||||
if (runas_matches == -1)
|
if (runas_matches == -1)
|
||||||
runas_matches =
|
runas_matches =
|
||||||
(strcmp(RUNAS_DEFAULT, runas_user) == 0);
|
(strcmp(RUNAS_DEFAULT, runas_user) == 0);
|
||||||
$$ = runas_matches;
|
|
||||||
}
|
|
||||||
| RUNAS runaslist {
|
|
||||||
runas_matches = ($2 > 0);
|
|
||||||
$$ = runas_matches;
|
|
||||||
}
|
}
|
||||||
|
| RUNAS runaslist { ; }
|
||||||
;
|
;
|
||||||
|
|
||||||
runaslist : runasuser {
|
runaslist : oprunasuser
|
||||||
$$ = $1;
|
| runaslist ',' oprunasuser
|
||||||
}
|
|
||||||
| runaslist ',' runasuser {
|
|
||||||
$$ = $1 + $3;
|
|
||||||
}
|
|
||||||
;
|
;
|
||||||
|
|
||||||
|
oprunasuser : runasuser {
|
||||||
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
|
user_matches == TRUE)
|
||||||
|
append("", &cm_list[cm_list_len].runas,
|
||||||
|
&cm_list[cm_list_len].runas_len,
|
||||||
|
&cm_list[cm_list_len].runas_size, ':');
|
||||||
|
}
|
||||||
|
| '!' {
|
||||||
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
|
user_matches == TRUE) {
|
||||||
|
append("!", &cm_list[cm_list_len].runas,
|
||||||
|
&cm_list[cm_list_len].runas_len,
|
||||||
|
&cm_list[cm_list_len].runas_size, ':');
|
||||||
|
pushcp;
|
||||||
|
} else {
|
||||||
|
push;
|
||||||
|
}
|
||||||
|
} oprunasuser {
|
||||||
|
pop;
|
||||||
|
if (runas_matched == TRUE)
|
||||||
|
runas_matches = FALSE;
|
||||||
|
else if (runas_matched == FALSE)
|
||||||
|
runas_matches = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
runasuser : NAME {
|
runasuser : NAME {
|
||||||
$$ = (strcmp($1, runas_user) == 0);
|
runas_matches = (strcmp($1, runas_user) == 0);
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append($1, &ga_list[ga_list_len-1].entries,
|
append($1, &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
@@ -355,20 +366,17 @@ runasuser : NAME {
|
|||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append($1, &cm_list[cm_list_len].runas,
|
append($1, &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
(void) free($1);
|
(void) free($1);
|
||||||
}
|
}
|
||||||
| USERGROUP {
|
| USERGROUP {
|
||||||
$$ = usergr_matches($1, runas_user);
|
runas_matches = usergr_matches($1, runas_user);
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append($1, &ga_list[ga_list_len-1].entries,
|
append($1, &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
&ga_list[ga_list_len-1].entries_size, ',');
|
&ga_list[ga_list_len-1].entries_size, ',');
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE) {
|
user_matches == TRUE) {
|
||||||
append("%", &cm_list[cm_list_len].runas,
|
|
||||||
&cm_list[cm_list_len].runas_len,
|
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
|
||||||
append($1, &cm_list[cm_list_len].runas,
|
append($1, &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, 0);
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
@@ -376,16 +384,13 @@ runasuser : NAME {
|
|||||||
(void) free($1);
|
(void) free($1);
|
||||||
}
|
}
|
||||||
| NETGROUP {
|
| NETGROUP {
|
||||||
$$ = netgr_matches($1, NULL, runas_user);
|
runas_matches = netgr_matches($1, NULL, runas_user);
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append($1, &ga_list[ga_list_len-1].entries,
|
append($1, &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
&ga_list[ga_list_len-1].entries_size, ',');
|
&ga_list[ga_list_len-1].entries_size, ',');
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE) {
|
user_matches == TRUE) {
|
||||||
append("+", &cm_list[cm_list_len].runas,
|
|
||||||
&cm_list[cm_list_len].runas_len,
|
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
|
||||||
append($1, &cm_list[cm_list_len].runas,
|
append($1, &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, 0);
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
@@ -396,9 +401,9 @@ runasuser : NAME {
|
|||||||
/* could be an all-caps username */
|
/* could be an all-caps username */
|
||||||
if (find_alias($1, RUNAS_ALIAS) == TRUE ||
|
if (find_alias($1, RUNAS_ALIAS) == TRUE ||
|
||||||
strcmp($1, runas_user) == 0)
|
strcmp($1, runas_user) == 0)
|
||||||
$$ = TRUE;
|
runas_matches = TRUE;
|
||||||
else
|
else
|
||||||
$$ = FALSE;
|
runas_matches = FALSE;
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append($1, &ga_list[ga_list_len-1].entries,
|
append($1, &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
@@ -407,11 +412,11 @@ runasuser : NAME {
|
|||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append($1, &cm_list[cm_list_len].runas,
|
append($1, &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
(void) free($1);
|
(void) free($1);
|
||||||
}
|
}
|
||||||
| ALL {
|
| ALL {
|
||||||
$$ = TRUE;
|
runas_matches = TRUE;
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append("ALL", &ga_list[ga_list_len-1].entries,
|
append("ALL", &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
@@ -420,7 +425,7 @@ runasuser : NAME {
|
|||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append("ALL", &cm_list[cm_list_len].runas,
|
append("ALL", &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
|
|
||||||
@@ -428,13 +433,13 @@ nopasswd : /* empty */ {
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
| NOPASSWD {
|
| NOPASSWD {
|
||||||
no_passwd = $$ = TRUE;
|
no_passwd = TRUE;
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
cm_list[cm_list_len].nopasswd = TRUE;
|
cm_list[cm_list_len].nopasswd = TRUE;
|
||||||
}
|
}
|
||||||
| PASSWD {
|
| PASSWD {
|
||||||
no_passwd = $$ = FALSE;
|
no_passwd = FALSE;
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
cm_list[cm_list_len].nopasswd = FALSE;
|
cm_list[cm_list_len].nopasswd = FALSE;
|
||||||
@@ -570,7 +575,8 @@ runasalias : ALIAS {
|
|||||||
ga_list[ga_list_len-1].alias = estrdup($1);
|
ga_list[ga_list_len-1].alias = estrdup($1);
|
||||||
}
|
}
|
||||||
} '=' runaslist {
|
} '=' runaslist {
|
||||||
if ($4 > 0 && add_alias($1, RUNAS_ALIAS) == FALSE)
|
if (runas_matches > 0 &&
|
||||||
|
add_alias($1, RUNAS_ALIAS) == FALSE)
|
||||||
YYERROR;
|
YYERROR;
|
||||||
pop;
|
pop;
|
||||||
(void) free($1);
|
(void) free($1);
|
||||||
|
1
sudo.c
1
sudo.c
@@ -375,6 +375,7 @@ int main(argc, argv)
|
|||||||
case VALIDATE_NOT_OK:
|
case VALIDATE_NOT_OK:
|
||||||
check_user();
|
check_user();
|
||||||
|
|
||||||
|
case VALIDATE_NOT_OK_NOPASS:
|
||||||
#ifndef DONT_LEAK_PATH_INFO
|
#ifndef DONT_LEAK_PATH_INFO
|
||||||
log_error(rtn);
|
log_error(rtn);
|
||||||
if (cmnd_status == NOT_FOUND_DOT)
|
if (cmnd_status == NOT_FOUND_DOT)
|
||||||
|
11
sudo.h
11
sudo.h
@@ -65,9 +65,13 @@ extern struct matchstack *match;
|
|||||||
extern int top;
|
extern int top;
|
||||||
|
|
||||||
#define user_matches (match[top-1].user)
|
#define user_matches (match[top-1].user)
|
||||||
|
#define user_matched (match[top-2].user)
|
||||||
#define cmnd_matches (match[top-1].cmnd)
|
#define cmnd_matches (match[top-1].cmnd)
|
||||||
|
#define cmnd_matched (match[top-2].cmnd)
|
||||||
#define host_matches (match[top-1].host)
|
#define host_matches (match[top-1].host)
|
||||||
|
#define host_matched (match[top-2].host)
|
||||||
#define runas_matches (match[top-1].runas)
|
#define runas_matches (match[top-1].runas)
|
||||||
|
#define runas_matched (match[top-2].runas)
|
||||||
#define no_passwd (match[top-1].nopass)
|
#define no_passwd (match[top-1].nopass)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -131,9 +135,10 @@ struct generic_alias {
|
|||||||
#endif /* LOGGING & SLOG_SYSLOG */
|
#endif /* LOGGING & SLOG_SYSLOG */
|
||||||
|
|
||||||
#define VALIDATE_OK 0x00
|
#define VALIDATE_OK 0x00
|
||||||
#define VALIDATE_NO_USER 0x01
|
#define VALIDATE_OK_NOPASS 0x01
|
||||||
#define VALIDATE_NOT_OK 0x02
|
#define VALIDATE_NO_USER 0x02
|
||||||
#define VALIDATE_OK_NOPASS 0x03
|
#define VALIDATE_NOT_OK 0x03
|
||||||
|
#define VALIDATE_NOT_OK_NOPASS 0x04
|
||||||
#define VALIDATE_ERROR -1
|
#define VALIDATE_ERROR -1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
472
sudo.tab.c
472
sudo.tab.c
@@ -212,84 +212,89 @@ typedef union {
|
|||||||
#define ERROR 273
|
#define ERROR 273
|
||||||
#define YYERRCODE 256
|
#define YYERRCODE 256
|
||||||
short yylhs[] = { -1,
|
short yylhs[] = { -1,
|
||||||
0, 0, 7, 7, 9, 7, 7, 7, 7, 7,
|
0, 0, 3, 3, 5, 3, 3, 3, 3, 3,
|
||||||
10, 10, 15, 16, 16, 16, 16, 16, 16, 17,
|
6, 6, 11, 12, 12, 12, 12, 12, 12, 13,
|
||||||
17, 19, 18, 2, 20, 2, 3, 3, 4, 4,
|
13, 16, 14, 2, 18, 2, 15, 15, 19, 19,
|
||||||
5, 5, 5, 5, 5, 6, 6, 6, 1, 1,
|
20, 22, 20, 21, 21, 21, 21, 21, 17, 17,
|
||||||
1, 12, 12, 22, 21, 23, 23, 13, 13, 25,
|
17, 1, 1, 1, 8, 8, 24, 23, 25, 25,
|
||||||
24, 26, 26, 14, 14, 28, 27, 11, 11, 30,
|
9, 9, 27, 26, 28, 28, 10, 10, 30, 29,
|
||||||
29, 31, 31, 8, 8, 8, 8, 8,
|
7, 7, 32, 31, 33, 33, 4, 4, 4, 4,
|
||||||
|
4,
|
||||||
};
|
};
|
||||||
short yylen[] = { 2,
|
short yylen[] = { 2,
|
||||||
1, 2, 1, 2, 0, 3, 2, 2, 2, 2,
|
1, 2, 1, 2, 0, 3, 2, 2, 2, 2,
|
||||||
1, 3, 3, 1, 1, 1, 1, 1, 1, 1,
|
1, 3, 3, 1, 1, 1, 1, 1, 1, 1,
|
||||||
3, 0, 4, 1, 0, 3, 0, 2, 1, 3,
|
3, 0, 4, 1, 0, 3, 0, 2, 1, 3,
|
||||||
1, 1, 1, 1, 1, 0, 1, 1, 1, 1,
|
1, 0, 3, 1, 1, 1, 1, 1, 0, 1,
|
||||||
1, 1, 3, 0, 4, 1, 3, 1, 3, 0,
|
1, 1, 1, 1, 1, 3, 0, 4, 1, 3,
|
||||||
4, 1, 3, 1, 3, 0, 4, 1, 3, 0,
|
1, 3, 0, 4, 1, 3, 1, 3, 0, 4,
|
||||||
4, 1, 3, 1, 1, 1, 1, 1,
|
1, 3, 0, 4, 1, 3, 1, 1, 1, 1,
|
||||||
|
1,
|
||||||
};
|
};
|
||||||
short yydefred[] = { 0,
|
short yydefred[] = { 0,
|
||||||
0, 3, 0, 0, 0, 0, 0, 1, 0, 4,
|
0, 3, 0, 0, 0, 0, 0, 1, 0, 4,
|
||||||
44, 0, 42, 50, 0, 48, 60, 0, 58, 56,
|
47, 0, 45, 53, 0, 51, 63, 0, 61, 59,
|
||||||
0, 54, 2, 67, 66, 65, 64, 68, 0, 0,
|
0, 57, 2, 70, 69, 68, 67, 71, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 19, 15, 18,
|
0, 0, 0, 0, 0, 0, 0, 19, 15, 18,
|
||||||
16, 17, 14, 0, 11, 0, 0, 43, 0, 49,
|
16, 17, 14, 0, 11, 0, 0, 46, 0, 52,
|
||||||
0, 59, 0, 55, 0, 22, 46, 0, 40, 41,
|
0, 62, 0, 58, 0, 22, 49, 0, 43, 44,
|
||||||
39, 52, 0, 62, 0, 34, 33, 32, 31, 35,
|
42, 55, 0, 65, 0, 37, 36, 35, 34, 38,
|
||||||
0, 29, 12, 0, 20, 0, 0, 0, 0, 0,
|
32, 0, 29, 31, 12, 0, 20, 0, 0, 0,
|
||||||
22, 0, 0, 47, 53, 63, 30, 21, 0, 37,
|
0, 0, 0, 22, 0, 0, 50, 56, 66, 33,
|
||||||
38, 0, 25, 24, 23, 0, 26,
|
30, 21, 0, 40, 41, 0, 25, 24, 23, 0,
|
||||||
|
26,
|
||||||
};
|
};
|
||||||
short yydgoto[] = { 7,
|
short yydgoto[] = { 7,
|
||||||
94, 95, 83, 71, 72, 92, 8, 29, 9, 44,
|
98, 99, 8, 29, 9, 44, 18, 12, 15, 21,
|
||||||
18, 12, 15, 21, 45, 46, 74, 75, 76, 96,
|
45, 46, 76, 77, 86, 78, 96, 100, 72, 73,
|
||||||
13, 30, 58, 16, 32, 63, 22, 36, 19, 34,
|
74, 82, 13, 30, 58, 16, 32, 63, 22, 36,
|
||||||
65,
|
19, 34, 65,
|
||||||
};
|
};
|
||||||
short yysindex[] = { -248,
|
short yysindex[] = { -248,
|
||||||
-258, 0, -246, -245, -243, -241, -248, 0, -211, 0,
|
-256, 0, -243, -237, -232, -231, -248, 0, -220, 0,
|
||||||
0, -41, 0, 0, -38, 0, 0, -31, 0, 0,
|
0, -19, 0, 0, -15, 0, 0, -14, 0, 0,
|
||||||
-30, 0, 0, 0, 0, 0, 0, 0, -220, -32,
|
-13, 0, 0, 0, 0, 0, 0, 0, -230, -8,
|
||||||
-246, -20, -245, -18, -243, -17, -241, 0, 0, 0,
|
-243, -7, -237, -6, -232, -5, -231, 0, 0, 0,
|
||||||
0, 0, 0, -25, 0, -16, -220, 0, -253, 0,
|
0, 0, 0, -11, 0, -3, -230, 0, -253, 0,
|
||||||
-211, 0, -197, 0, -220, 0, 0, -14, 0, 0,
|
-220, 0, -33, 0, -230, 0, 0, 16, 0, 0,
|
||||||
0, 0, -10, 0, 3, 0, 0, 0, 0, 0,
|
0, 0, 17, 0, 19, 0, 0, 0, 0, 0,
|
||||||
9, 0, 0, 10, 0, -208, -220, -253, -211, -197,
|
0, 20, 0, 0, 0, 21, 0, -201, -230, -253,
|
||||||
0, -197, -239, 0, 0, 0, 0, 0, 9, 0,
|
-220, -33, -33, 0, -33, -255, 0, 0, 0, 0,
|
||||||
0, -27, 0, 0, 0, -27, 0,
|
0, 0, 20, 0, 0, -26, 0, 0, 0, -26,
|
||||||
|
0,
|
||||||
};
|
};
|
||||||
short yyrindex[] = { -187,
|
short yyrindex[] = { -211,
|
||||||
0, 0, 0, 0, 0, 0, -187, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, -211, 0, 0, 0,
|
||||||
0, 86, 0, 0, 103, 0, 0, 120, 0, 0,
|
0, 86, 0, 0, 103, 0, 0, 120, 0, 0,
|
||||||
137, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
137, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 154, 0, 0, 0, 0, 0, 0,
|
0, 0, 0, 154, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 1, 0, 0,
|
0, 0, 0, 0, 0, 0, 0, 1, 0, 0,
|
||||||
0, 0, 18, 0, 35, 0, 0, 0, 0, 0,
|
0, 0, 18, 0, 35, 0, 0, 0, 0, 0,
|
||||||
52, 0, 0, 69, 0, -33, 0, 0, 0, 0,
|
0, 52, 0, 0, 0, 69, 0, -27, 0, 0,
|
||||||
0, 0, -23, 0, 0, 0, 0, 0, -28, 0,
|
0, 0, 0, 0, 0, -2, 0, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0,
|
0, 0, -21, 0, 0, 0, 0, 0, 0, 0,
|
||||||
};
|
|
||||||
short yygindex[] = { 0,
|
|
||||||
-42, -40, 0, -24, -19, 0, 55, -48, 0, 0,
|
|
||||||
0, 0, 0, 0, 11, -45, 0, -13, 0, 0,
|
|
||||||
36, 0, 0, 39, 0, 0, 40, 0, 43, 0,
|
|
||||||
0,
|
0,
|
||||||
};
|
};
|
||||||
|
short yygindex[] = { 0,
|
||||||
|
-44, -34, 60, -48, 0, 0, 0, 0, 0, 0,
|
||||||
|
13, -45, 0, -12, 0, 0, 0, 0, -10, -66,
|
||||||
|
0, 0, 39, 0, 0, 38, 0, 0, 36, 0,
|
||||||
|
42, 0, 0,
|
||||||
|
};
|
||||||
#define YYTABLESIZE 426
|
#define YYTABLESIZE 426
|
||||||
short yytable[] = { 27,
|
short yytable[] = { 71,
|
||||||
45, 57, 64, 59, 28, 93, 62, 1, 10, 36,
|
48, 57, 64, 59, 62, 27, 97, 1, 94, 95,
|
||||||
11, 14, 60, 17, 61, 20, 31, 51, 2, 33,
|
10, 28, 60, 11, 61, 90, 91, 54, 2, 14,
|
||||||
3, 4, 5, 6, 90, 91, 35, 37, 47, 77,
|
3, 4, 5, 6, 17, 20, 38, 39, 40, 41,
|
||||||
86, 84, 55, 78, 61, 85, 38, 39, 40, 41,
|
39, 42, 89, 87, 64, 88, 24, 43, 31, 25,
|
||||||
49, 42, 51, 53, 56, 24, 79, 43, 25, 26,
|
26, 27, 33, 35, 37, 5, 55, 28, 5, 5,
|
||||||
27, 57, 80, 81, 82, 97, 28, 89, 45, 66,
|
5, 60, 47, 49, 51, 53, 5, 56, 48, 79,
|
||||||
87, 23, 67, 68, 69, 73, 48, 88, 13, 5,
|
80, 85, 81, 83, 84, 101, 23, 75, 13, 48,
|
||||||
70, 50, 5, 5, 5, 51, 54, 52, 0, 0,
|
50, 92, 54, 0, 93, 54, 52, 0, 0, 0,
|
||||||
5, 0, 0, 0, 0, 8, 0, 0, 0, 0,
|
0, 0, 0, 0, 0, 8, 0, 0, 0, 0,
|
||||||
0, 0, 61, 0, 0, 0, 0, 0, 0, 0,
|
0, 0, 64, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 9, 0, 0, 0, 0, 0, 0, 57,
|
0, 0, 9, 0, 0, 0, 0, 0, 0, 60,
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 7,
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 7,
|
||||||
0, 0, 0, 0, 0, 0, 13, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 13, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 10, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 10, 0, 0, 0,
|
||||||
@@ -301,17 +306,17 @@ short yytable[] = { 27,
|
|||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
0, 0, 0, 27, 0, 0, 0, 0, 28, 59,
|
0, 0, 0, 66, 0, 0, 67, 68, 69, 27,
|
||||||
27, 27, 27, 36, 27, 28, 28, 28, 60, 28,
|
59, 0, 0, 0, 70, 28, 27, 27, 27, 60,
|
||||||
61, 0, 36, 0, 36, 0, 0, 0, 0, 0,
|
27, 61, 28, 28, 28, 0, 28, 0, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 45, 45, 0, 0,
|
0, 0, 0, 0, 39, 0, 48, 48, 0, 0,
|
||||||
45, 45, 45, 0, 0, 0, 0, 45, 45, 45,
|
48, 48, 48, 39, 0, 39, 0, 48, 48, 48,
|
||||||
45, 45, 45, 51, 51, 0, 0, 51, 51, 51,
|
48, 48, 48, 54, 54, 0, 0, 54, 54, 54,
|
||||||
0, 0, 0, 0, 51, 51, 51, 51, 51, 51,
|
0, 0, 0, 0, 54, 54, 54, 54, 54, 54,
|
||||||
61, 61, 0, 0, 61, 61, 61, 0, 0, 0,
|
64, 64, 0, 0, 64, 64, 64, 0, 0, 0,
|
||||||
0, 61, 61, 61, 61, 61, 61, 57, 57, 0,
|
0, 64, 64, 64, 64, 64, 64, 60, 60, 0,
|
||||||
0, 57, 57, 57, 0, 0, 0, 0, 57, 57,
|
0, 60, 60, 60, 0, 0, 0, 0, 60, 60,
|
||||||
57, 57, 57, 57, 13, 13, 0, 0, 13, 13,
|
60, 60, 60, 60, 13, 13, 0, 0, 13, 13,
|
||||||
13, 0, 0, 0, 0, 13, 13, 13, 13, 13,
|
13, 0, 0, 0, 0, 13, 13, 13, 13, 13,
|
||||||
13, 8, 8, 0, 0, 8, 8, 8, 0, 0,
|
13, 8, 8, 0, 0, 8, 8, 8, 0, 0,
|
||||||
0, 0, 8, 8, 8, 8, 8, 8, 9, 9,
|
0, 0, 8, 8, 8, 8, 8, 8, 9, 9,
|
||||||
@@ -324,15 +329,15 @@ short yytable[] = { 27,
|
|||||||
6, 6, 6, 6, 6, 6,
|
6, 6, 6, 6, 6, 6,
|
||||||
};
|
};
|
||||||
short yycheck[] = { 33,
|
short yycheck[] = { 33,
|
||||||
0, 47, 51, 257, 33, 33, 49, 256, 267, 33,
|
0, 47, 51, 257, 49, 33, 33, 256, 264, 265,
|
||||||
257, 257, 266, 257, 268, 257, 58, 0, 267, 58,
|
267, 33, 266, 257, 268, 82, 83, 0, 267, 257,
|
||||||
269, 270, 271, 272, 264, 265, 58, 58, 61, 44,
|
269, 270, 271, 272, 257, 257, 257, 258, 259, 260,
|
||||||
79, 77, 58, 44, 0, 78, 257, 258, 259, 260,
|
33, 262, 81, 79, 0, 80, 257, 268, 58, 260,
|
||||||
61, 262, 61, 61, 61, 257, 44, 268, 260, 261,
|
261, 262, 58, 58, 58, 257, 58, 268, 260, 261,
|
||||||
262, 0, 44, 44, 263, 96, 268, 82, 58, 257,
|
262, 0, 61, 61, 61, 61, 268, 61, 58, 44,
|
||||||
80, 7, 260, 261, 262, 55, 31, 81, 0, 257,
|
44, 263, 44, 44, 44, 100, 7, 55, 0, 31,
|
||||||
268, 33, 260, 261, 262, 58, 37, 35, -1, -1,
|
33, 84, 37, -1, 85, 58, 35, -1, -1, -1,
|
||||||
268, -1, -1, -1, -1, 0, -1, -1, -1, -1,
|
-1, -1, -1, -1, -1, 0, -1, -1, -1, -1,
|
||||||
-1, -1, 58, -1, -1, -1, -1, -1, -1, -1,
|
-1, -1, 58, -1, -1, -1, -1, -1, -1, -1,
|
||||||
-1, -1, 0, -1, -1, -1, -1, -1, -1, 58,
|
-1, -1, 0, -1, -1, -1, -1, -1, -1, 58,
|
||||||
-1, -1, -1, -1, -1, -1, -1, -1, -1, 0,
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, 0,
|
||||||
@@ -346,11 +351,11 @@ short yycheck[] = { 33,
|
|||||||
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
-1, -1, -1, 257, -1, -1, -1, -1, 257, 257,
|
-1, -1, -1, 257, -1, -1, 260, 261, 262, 257,
|
||||||
264, 265, 266, 257, 268, 264, 265, 266, 266, 268,
|
257, -1, -1, -1, 268, 257, 264, 265, 266, 266,
|
||||||
268, -1, 266, -1, 268, -1, -1, -1, -1, -1,
|
268, 268, 264, 265, 266, -1, 268, -1, -1, -1,
|
||||||
-1, -1, -1, -1, -1, -1, 256, 257, -1, -1,
|
-1, -1, -1, -1, 257, -1, 256, 257, -1, -1,
|
||||||
260, 261, 262, -1, -1, -1, -1, 267, 268, 269,
|
260, 261, 262, 266, -1, 268, -1, 267, 268, 269,
|
||||||
270, 271, 272, 256, 257, -1, -1, 260, 261, 262,
|
270, 271, 272, 256, 257, -1, -1, 260, 261, 262,
|
||||||
-1, -1, -1, -1, 267, 268, 269, 270, 271, 272,
|
-1, -1, -1, -1, 267, 268, 269, 270, 271, 272,
|
||||||
256, 257, -1, -1, 260, 261, 262, -1, -1, -1,
|
256, 257, -1, -1, 260, 261, 262, -1, -1, -1,
|
||||||
@@ -416,8 +421,11 @@ char *yyrule[] = {
|
|||||||
"opcmnd : '!' $$3 opcmnd",
|
"opcmnd : '!' $$3 opcmnd",
|
||||||
"runasspec :",
|
"runasspec :",
|
||||||
"runasspec : RUNAS runaslist",
|
"runasspec : RUNAS runaslist",
|
||||||
"runaslist : runasuser",
|
"runaslist : oprunasuser",
|
||||||
"runaslist : runaslist ',' runasuser",
|
"runaslist : runaslist ',' oprunasuser",
|
||||||
|
"oprunasuser : runasuser",
|
||||||
|
"$$4 :",
|
||||||
|
"oprunasuser : '!' $$4 oprunasuser",
|
||||||
"runasuser : NAME",
|
"runasuser : NAME",
|
||||||
"runasuser : USERGROUP",
|
"runasuser : USERGROUP",
|
||||||
"runasuser : NETGROUP",
|
"runasuser : NETGROUP",
|
||||||
@@ -431,24 +439,24 @@ char *yyrule[] = {
|
|||||||
"cmnd : COMMAND",
|
"cmnd : COMMAND",
|
||||||
"hostaliases : hostalias",
|
"hostaliases : hostalias",
|
||||||
"hostaliases : hostaliases ':' hostalias",
|
"hostaliases : hostaliases ':' hostalias",
|
||||||
"$$4 :",
|
"$$5 :",
|
||||||
"hostalias : ALIAS $$4 '=' hostlist",
|
"hostalias : ALIAS $$5 '=' hostlist",
|
||||||
"hostlist : hostspec",
|
"hostlist : hostspec",
|
||||||
"hostlist : hostlist ',' hostspec",
|
"hostlist : hostlist ',' hostspec",
|
||||||
"cmndaliases : cmndalias",
|
"cmndaliases : cmndalias",
|
||||||
"cmndaliases : cmndaliases ':' cmndalias",
|
"cmndaliases : cmndaliases ':' cmndalias",
|
||||||
"$$5 :",
|
"$$6 :",
|
||||||
"cmndalias : ALIAS $$5 '=' cmndlist",
|
"cmndalias : ALIAS $$6 '=' cmndlist",
|
||||||
"cmndlist : cmnd",
|
"cmndlist : cmnd",
|
||||||
"cmndlist : cmndlist ',' cmnd",
|
"cmndlist : cmndlist ',' cmnd",
|
||||||
"runasaliases : runasalias",
|
"runasaliases : runasalias",
|
||||||
"runasaliases : runasaliases ':' runasalias",
|
"runasaliases : runasaliases ':' runasalias",
|
||||||
"$$6 :",
|
"$$7 :",
|
||||||
"runasalias : ALIAS $$6 '=' runaslist",
|
"runasalias : ALIAS $$7 '=' runaslist",
|
||||||
"useraliases : useralias",
|
"useraliases : useralias",
|
||||||
"useraliases : useraliases ':' useralias",
|
"useraliases : useraliases ':' useralias",
|
||||||
"$$7 :",
|
"$$8 :",
|
||||||
"useralias : ALIAS $$7 '=' userlist",
|
"useralias : ALIAS $$8 '=' userlist",
|
||||||
"userlist : user",
|
"userlist : user",
|
||||||
"userlist : userlist ',' user",
|
"userlist : userlist ',' user",
|
||||||
"user : NAME",
|
"user : NAME",
|
||||||
@@ -482,7 +490,7 @@ short *yyss;
|
|||||||
short *yysslim;
|
short *yysslim;
|
||||||
YYSTYPE *yyvs;
|
YYSTYPE *yyvs;
|
||||||
int yystacksize;
|
int yystacksize;
|
||||||
#line 629 "parse.yacc"
|
#line 635 "parse.yacc"
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@@ -859,7 +867,7 @@ void init_parser()
|
|||||||
if (printmatches == TRUE)
|
if (printmatches == TRUE)
|
||||||
expand_match_list();
|
expand_match_list();
|
||||||
}
|
}
|
||||||
#line 863 "sudo.tab.c"
|
#line 871 "sudo.tab.c"
|
||||||
/* allocate initial stack or double stack size, up to YYMAXDEPTH */
|
/* allocate initial stack or double stack size, up to YYMAXDEPTH */
|
||||||
#if defined(__cplusplus) || __STDC__
|
#if defined(__cplusplus) || __STDC__
|
||||||
static int yygrowstack(void)
|
static int yygrowstack(void)
|
||||||
@@ -1040,19 +1048,19 @@ yyreduce:
|
|||||||
switch (yyn)
|
switch (yyn)
|
||||||
{
|
{
|
||||||
case 3:
|
case 3:
|
||||||
#line 214 "parse.yacc"
|
#line 210 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
#line 216 "parse.yacc"
|
#line 212 "parse.yacc"
|
||||||
{ yyerrok; }
|
{ yyerrok; }
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
#line 217 "parse.yacc"
|
#line 213 "parse.yacc"
|
||||||
{ push; }
|
{ push; }
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
#line 217 "parse.yacc"
|
#line 213 "parse.yacc"
|
||||||
{
|
{
|
||||||
while (top && user_matches != TRUE) {
|
while (top && user_matches != TRUE) {
|
||||||
pop;
|
pop;
|
||||||
@@ -1060,23 +1068,23 @@ case 6:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 7:
|
case 7:
|
||||||
#line 223 "parse.yacc"
|
#line 219 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 8:
|
case 8:
|
||||||
#line 225 "parse.yacc"
|
#line 221 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 9:
|
case 9:
|
||||||
#line 227 "parse.yacc"
|
#line 223 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 10:
|
case 10:
|
||||||
#line 229 "parse.yacc"
|
#line 225 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 13:
|
case 13:
|
||||||
#line 237 "parse.yacc"
|
#line 233 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (user_matches == TRUE) {
|
if (user_matches == TRUE) {
|
||||||
push;
|
push;
|
||||||
@@ -1088,13 +1096,13 @@ case 13:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 14:
|
case 14:
|
||||||
#line 248 "parse.yacc"
|
#line 244 "parse.yacc"
|
||||||
{
|
{
|
||||||
host_matches = TRUE;
|
host_matches = TRUE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 15:
|
case 15:
|
||||||
#line 251 "parse.yacc"
|
#line 247 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (addr_matches(yyvsp[0].string))
|
if (addr_matches(yyvsp[0].string))
|
||||||
host_matches = TRUE;
|
host_matches = TRUE;
|
||||||
@@ -1102,7 +1110,7 @@ case 15:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 16:
|
case 16:
|
||||||
#line 256 "parse.yacc"
|
#line 252 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (netgr_matches(yyvsp[0].string, host, NULL))
|
if (netgr_matches(yyvsp[0].string, host, NULL))
|
||||||
host_matches = TRUE;
|
host_matches = TRUE;
|
||||||
@@ -1110,7 +1118,7 @@ case 16:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 17:
|
case 17:
|
||||||
#line 261 "parse.yacc"
|
#line 257 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (strcasecmp(shost, yyvsp[0].string) == 0)
|
if (strcasecmp(shost, yyvsp[0].string) == 0)
|
||||||
host_matches = TRUE;
|
host_matches = TRUE;
|
||||||
@@ -1118,7 +1126,7 @@ case 17:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 18:
|
case 18:
|
||||||
#line 266 "parse.yacc"
|
#line 262 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (strcasecmp(host, yyvsp[0].string) == 0)
|
if (strcasecmp(host, yyvsp[0].string) == 0)
|
||||||
host_matches = TRUE;
|
host_matches = TRUE;
|
||||||
@@ -1126,7 +1134,7 @@ case 18:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 19:
|
case 19:
|
||||||
#line 271 "parse.yacc"
|
#line 267 "parse.yacc"
|
||||||
{
|
{
|
||||||
/* could be an all-caps hostname */
|
/* could be an all-caps hostname */
|
||||||
if (find_alias(yyvsp[0].string, HOST_ALIAS) == TRUE ||
|
if (find_alias(yyvsp[0].string, HOST_ALIAS) == TRUE ||
|
||||||
@@ -1136,7 +1144,7 @@ case 19:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 22:
|
case 22:
|
||||||
#line 284 "parse.yacc"
|
#line 280 "parse.yacc"
|
||||||
{ /* Push a new entry onto the stack if needed */
|
{ /* Push a new entry onto the stack if needed */
|
||||||
if (user_matches == TRUE && host_matches == TRUE &&
|
if (user_matches == TRUE && host_matches == TRUE &&
|
||||||
cmnd_matches != -1 && runas_matches == TRUE)
|
cmnd_matches != -1 && runas_matches == TRUE)
|
||||||
@@ -1145,10 +1153,10 @@ case 22:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 23:
|
case 23:
|
||||||
#line 289 "parse.yacc"
|
#line 285 "parse.yacc"
|
||||||
{
|
{
|
||||||
/* XXX - test runas_matches and cmnd_matches instead? */
|
if (printmatches == TRUE &&
|
||||||
if ((yyvsp[-2].BOOLEAN == -1 || yyvsp[0].BOOLEAN == -1) && printmatches == TRUE) {
|
(runas_matches == -1 || cmnd_matches == -1)) {
|
||||||
cm_list[cm_list_len].runas_len = 0;
|
cm_list[cm_list_len].runas_len = 0;
|
||||||
cm_list[cm_list_len].cmnd_len = 0;
|
cm_list[cm_list_len].cmnd_len = 0;
|
||||||
cm_list[cm_list_len].nopasswd = FALSE;
|
cm_list[cm_list_len].nopasswd = FALSE;
|
||||||
@@ -1156,11 +1164,11 @@ case 23:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 24:
|
case 24:
|
||||||
#line 299 "parse.yacc"
|
#line 295 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 25:
|
case 25:
|
||||||
#line 300 "parse.yacc"
|
#line 296 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE) {
|
user_matches == TRUE) {
|
||||||
@@ -1176,9 +1184,8 @@ case 25:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 26:
|
case 26:
|
||||||
#line 312 "parse.yacc"
|
#line 308 "parse.yacc"
|
||||||
{
|
{
|
||||||
int cmnd_matched = cmnd_matches;
|
|
||||||
pop;
|
pop;
|
||||||
if (cmnd_matched == TRUE)
|
if (cmnd_matched == TRUE)
|
||||||
cmnd_matches = FALSE;
|
cmnd_matches = FALSE;
|
||||||
@@ -1188,7 +1195,7 @@ case 26:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 27:
|
case 27:
|
||||||
#line 323 "parse.yacc"
|
#line 318 "parse.yacc"
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* If this is the first entry in a command list
|
* If this is the first entry in a command list
|
||||||
@@ -1197,93 +1204,50 @@ case 27:
|
|||||||
if (runas_matches == -1)
|
if (runas_matches == -1)
|
||||||
runas_matches =
|
runas_matches =
|
||||||
(strcmp(RUNAS_DEFAULT, runas_user) == 0);
|
(strcmp(RUNAS_DEFAULT, runas_user) == 0);
|
||||||
yyval.BOOLEAN = runas_matches;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 28:
|
case 28:
|
||||||
#line 333 "parse.yacc"
|
#line 327 "parse.yacc"
|
||||||
{
|
{ ; }
|
||||||
runas_matches = (yyvsp[0].BOOLEAN > 0);
|
|
||||||
yyval.BOOLEAN = runas_matches;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 29:
|
|
||||||
#line 339 "parse.yacc"
|
|
||||||
{
|
|
||||||
yyval.BOOLEAN = yyvsp[0].BOOLEAN;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 30:
|
|
||||||
#line 342 "parse.yacc"
|
|
||||||
{
|
|
||||||
yyval.BOOLEAN = yyvsp[-2].BOOLEAN + yyvsp[0].BOOLEAN;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 31:
|
case 31:
|
||||||
#line 348 "parse.yacc"
|
#line 334 "parse.yacc"
|
||||||
{
|
{
|
||||||
yyval.BOOLEAN = (strcmp(yyvsp[0].string, runas_user) == 0);
|
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
|
||||||
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
|
||||||
&ga_list[ga_list_len-1].entries_size, ',');
|
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
append("", &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, ':');
|
||||||
(void) free(yyvsp[0].string);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 32:
|
case 32:
|
||||||
#line 361 "parse.yacc"
|
#line 341 "parse.yacc"
|
||||||
{
|
{
|
||||||
yyval.BOOLEAN = usergr_matches(yyvsp[0].string, runas_user);
|
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
|
||||||
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
|
||||||
&ga_list[ga_list_len-1].entries_size, ',');
|
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE) {
|
user_matches == TRUE) {
|
||||||
append("%", &cm_list[cm_list_len].runas,
|
append("!", &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, ':');
|
||||||
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
pushcp;
|
||||||
&cm_list[cm_list_len].runas_len,
|
} else {
|
||||||
&cm_list[cm_list_len].runas_size, 0);
|
push;
|
||||||
}
|
}
|
||||||
(void) free(yyvsp[0].string);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 33:
|
case 33:
|
||||||
#line 378 "parse.yacc"
|
#line 351 "parse.yacc"
|
||||||
{
|
{
|
||||||
yyval.BOOLEAN = netgr_matches(yyvsp[0].string, NULL, runas_user);
|
pop;
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (runas_matched == TRUE)
|
||||||
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
runas_matches = FALSE;
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
else if (runas_matched == FALSE)
|
||||||
&ga_list[ga_list_len-1].entries_size, ',');
|
runas_matches = TRUE;
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
|
||||||
user_matches == TRUE) {
|
|
||||||
append("+", &cm_list[cm_list_len].runas,
|
|
||||||
&cm_list[cm_list_len].runas_len,
|
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
|
||||||
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
|
||||||
&cm_list[cm_list_len].runas_len,
|
|
||||||
&cm_list[cm_list_len].runas_size, 0);
|
|
||||||
}
|
|
||||||
(void) free(yyvsp[0].string);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 34:
|
case 34:
|
||||||
#line 395 "parse.yacc"
|
#line 359 "parse.yacc"
|
||||||
{
|
{
|
||||||
/* could be an all-caps username */
|
runas_matches = (strcmp(yyvsp[0].string, runas_user) == 0);
|
||||||
if (find_alias(yyvsp[0].string, RUNAS_ALIAS) == TRUE ||
|
|
||||||
strcmp(yyvsp[0].string, runas_user) == 0)
|
|
||||||
yyval.BOOLEAN = TRUE;
|
|
||||||
else
|
|
||||||
yyval.BOOLEAN = FALSE;
|
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
@@ -1292,14 +1256,69 @@ case 34:
|
|||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 35:
|
case 35:
|
||||||
#line 413 "parse.yacc"
|
#line 372 "parse.yacc"
|
||||||
{
|
{
|
||||||
yyval.BOOLEAN = TRUE;
|
runas_matches = usergr_matches(yyvsp[0].string, runas_user);
|
||||||
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
|
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
||||||
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
|
&ga_list[ga_list_len-1].entries_size, ',');
|
||||||
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
|
user_matches == TRUE) {
|
||||||
|
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
||||||
|
&cm_list[cm_list_len].runas_len,
|
||||||
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
|
}
|
||||||
|
(void) free(yyvsp[0].string);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 36:
|
||||||
|
#line 386 "parse.yacc"
|
||||||
|
{
|
||||||
|
runas_matches = netgr_matches(yyvsp[0].string, NULL, runas_user);
|
||||||
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
|
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
||||||
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
|
&ga_list[ga_list_len-1].entries_size, ',');
|
||||||
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
|
user_matches == TRUE) {
|
||||||
|
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
||||||
|
&cm_list[cm_list_len].runas_len,
|
||||||
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
|
}
|
||||||
|
(void) free(yyvsp[0].string);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 37:
|
||||||
|
#line 400 "parse.yacc"
|
||||||
|
{
|
||||||
|
/* could be an all-caps username */
|
||||||
|
if (find_alias(yyvsp[0].string, RUNAS_ALIAS) == TRUE ||
|
||||||
|
strcmp(yyvsp[0].string, runas_user) == 0)
|
||||||
|
runas_matches = TRUE;
|
||||||
|
else
|
||||||
|
runas_matches = FALSE;
|
||||||
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
|
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
||||||
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
|
&ga_list[ga_list_len-1].entries_size, ',');
|
||||||
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
|
user_matches == TRUE)
|
||||||
|
append(yyvsp[0].string, &cm_list[cm_list_len].runas,
|
||||||
|
&cm_list[cm_list_len].runas_len,
|
||||||
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
|
(void) free(yyvsp[0].string);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 38:
|
||||||
|
#line 418 "parse.yacc"
|
||||||
|
{
|
||||||
|
runas_matches = TRUE;
|
||||||
if (printmatches == TRUE && in_alias == TRUE)
|
if (printmatches == TRUE && in_alias == TRUE)
|
||||||
append("ALL", &ga_list[ga_list_len-1].entries,
|
append("ALL", &ga_list[ga_list_len-1].entries,
|
||||||
&ga_list[ga_list_len-1].entries_len,
|
&ga_list[ga_list_len-1].entries_len,
|
||||||
@@ -1308,35 +1327,35 @@ case 35:
|
|||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
append("ALL", &cm_list[cm_list_len].runas,
|
append("ALL", &cm_list[cm_list_len].runas,
|
||||||
&cm_list[cm_list_len].runas_len,
|
&cm_list[cm_list_len].runas_len,
|
||||||
&cm_list[cm_list_len].runas_size, ':');
|
&cm_list[cm_list_len].runas_size, 0);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 36:
|
case 39:
|
||||||
#line 427 "parse.yacc"
|
#line 432 "parse.yacc"
|
||||||
{
|
{
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 37:
|
case 40:
|
||||||
#line 430 "parse.yacc"
|
#line 435 "parse.yacc"
|
||||||
{
|
{
|
||||||
no_passwd = yyval.BOOLEAN = TRUE;
|
no_passwd = TRUE;
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
cm_list[cm_list_len].nopasswd = TRUE;
|
cm_list[cm_list_len].nopasswd = TRUE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 38:
|
case 41:
|
||||||
#line 436 "parse.yacc"
|
#line 441 "parse.yacc"
|
||||||
{
|
{
|
||||||
no_passwd = yyval.BOOLEAN = FALSE;
|
no_passwd = FALSE;
|
||||||
if (printmatches == TRUE && host_matches == TRUE &&
|
if (printmatches == TRUE && host_matches == TRUE &&
|
||||||
user_matches == TRUE)
|
user_matches == TRUE)
|
||||||
cm_list[cm_list_len].nopasswd = FALSE;
|
cm_list[cm_list_len].nopasswd = FALSE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 39:
|
case 42:
|
||||||
#line 444 "parse.yacc"
|
#line 449 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (printmatches == TRUE && in_alias == TRUE) {
|
if (printmatches == TRUE && in_alias == TRUE) {
|
||||||
append("ALL", &ga_list[ga_list_len-1].entries,
|
append("ALL", &ga_list[ga_list_len-1].entries,
|
||||||
@@ -1355,8 +1374,8 @@ case 39:
|
|||||||
yyval.BOOLEAN = TRUE;
|
yyval.BOOLEAN = TRUE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 40:
|
case 43:
|
||||||
#line 461 "parse.yacc"
|
#line 466 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (printmatches == TRUE && in_alias == TRUE) {
|
if (printmatches == TRUE && in_alias == TRUE) {
|
||||||
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
append(yyvsp[0].string, &ga_list[ga_list_len-1].entries,
|
||||||
@@ -1377,8 +1396,8 @@ case 40:
|
|||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 41:
|
case 44:
|
||||||
#line 480 "parse.yacc"
|
#line 485 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (printmatches == TRUE && in_alias == TRUE) {
|
if (printmatches == TRUE && in_alias == TRUE) {
|
||||||
append(yyvsp[0].command.cmnd, &ga_list[ga_list_len-1].entries,
|
append(yyvsp[0].command.cmnd, &ga_list[ga_list_len-1].entries,
|
||||||
@@ -1413,12 +1432,12 @@ case 41:
|
|||||||
(void) free(yyvsp[0].command.args);
|
(void) free(yyvsp[0].command.args);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 44:
|
case 47:
|
||||||
#line 519 "parse.yacc"
|
#line 524 "parse.yacc"
|
||||||
{ push; }
|
{ push; }
|
||||||
break;
|
break;
|
||||||
case 45:
|
case 48:
|
||||||
#line 519 "parse.yacc"
|
#line 524 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (host_matches == TRUE &&
|
if (host_matches == TRUE &&
|
||||||
add_alias(yyvsp[-3].string, HOST_ALIAS) == FALSE)
|
add_alias(yyvsp[-3].string, HOST_ALIAS) == FALSE)
|
||||||
@@ -1426,8 +1445,8 @@ case 45:
|
|||||||
pop;
|
pop;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 50:
|
case 53:
|
||||||
#line 535 "parse.yacc"
|
#line 540 "parse.yacc"
|
||||||
{
|
{
|
||||||
push;
|
push;
|
||||||
if (printmatches == TRUE) {
|
if (printmatches == TRUE) {
|
||||||
@@ -1438,8 +1457,8 @@ case 50:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 51:
|
case 54:
|
||||||
#line 543 "parse.yacc"
|
#line 548 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (cmnd_matches == TRUE &&
|
if (cmnd_matches == TRUE &&
|
||||||
add_alias(yyvsp[-3].string, CMND_ALIAS) == FALSE)
|
add_alias(yyvsp[-3].string, CMND_ALIAS) == FALSE)
|
||||||
@@ -1451,12 +1470,12 @@ case 51:
|
|||||||
in_alias = FALSE;
|
in_alias = FALSE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 52:
|
case 55:
|
||||||
#line 556 "parse.yacc"
|
#line 561 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 56:
|
case 59:
|
||||||
#line 564 "parse.yacc"
|
#line 569 "parse.yacc"
|
||||||
{
|
{
|
||||||
push;
|
push;
|
||||||
if (printmatches == TRUE) {
|
if (printmatches == TRUE) {
|
||||||
@@ -1467,10 +1486,11 @@ case 56:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 57:
|
case 60:
|
||||||
#line 572 "parse.yacc"
|
#line 577 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (yyvsp[0].BOOLEAN > 0 && add_alias(yyvsp[-3].string, RUNAS_ALIAS) == FALSE)
|
if (runas_matches > 0 &&
|
||||||
|
add_alias(yyvsp[-3].string, RUNAS_ALIAS) == FALSE)
|
||||||
YYERROR;
|
YYERROR;
|
||||||
pop;
|
pop;
|
||||||
(void) free(yyvsp[-3].string);
|
(void) free(yyvsp[-3].string);
|
||||||
@@ -1479,12 +1499,12 @@ case 57:
|
|||||||
in_alias = FALSE;
|
in_alias = FALSE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 60:
|
case 63:
|
||||||
#line 587 "parse.yacc"
|
#line 593 "parse.yacc"
|
||||||
{ push; }
|
{ push; }
|
||||||
break;
|
break;
|
||||||
case 61:
|
case 64:
|
||||||
#line 587 "parse.yacc"
|
#line 593 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (user_matches == TRUE &&
|
if (user_matches == TRUE &&
|
||||||
add_alias(yyvsp[-3].string, USER_ALIAS) == FALSE)
|
add_alias(yyvsp[-3].string, USER_ALIAS) == FALSE)
|
||||||
@@ -1493,36 +1513,36 @@ case 61:
|
|||||||
(void) free(yyvsp[-3].string);
|
(void) free(yyvsp[-3].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 62:
|
case 65:
|
||||||
#line 597 "parse.yacc"
|
#line 603 "parse.yacc"
|
||||||
{ ; }
|
{ ; }
|
||||||
break;
|
break;
|
||||||
case 64:
|
case 67:
|
||||||
#line 601 "parse.yacc"
|
#line 607 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (strcmp(yyvsp[0].string, user_name) == 0)
|
if (strcmp(yyvsp[0].string, user_name) == 0)
|
||||||
user_matches = TRUE;
|
user_matches = TRUE;
|
||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 65:
|
case 68:
|
||||||
#line 606 "parse.yacc"
|
#line 612 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (usergr_matches(yyvsp[0].string, user_name))
|
if (usergr_matches(yyvsp[0].string, user_name))
|
||||||
user_matches = TRUE;
|
user_matches = TRUE;
|
||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 66:
|
case 69:
|
||||||
#line 611 "parse.yacc"
|
#line 617 "parse.yacc"
|
||||||
{
|
{
|
||||||
if (netgr_matches(yyvsp[0].string, NULL, user_name))
|
if (netgr_matches(yyvsp[0].string, NULL, user_name))
|
||||||
user_matches = TRUE;
|
user_matches = TRUE;
|
||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 67:
|
case 70:
|
||||||
#line 616 "parse.yacc"
|
#line 622 "parse.yacc"
|
||||||
{
|
{
|
||||||
/* could be an all-caps username */
|
/* could be an all-caps username */
|
||||||
if (find_alias(yyvsp[0].string, USER_ALIAS) == TRUE ||
|
if (find_alias(yyvsp[0].string, USER_ALIAS) == TRUE ||
|
||||||
@@ -1531,13 +1551,13 @@ case 67:
|
|||||||
(void) free(yyvsp[0].string);
|
(void) free(yyvsp[0].string);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 68:
|
case 71:
|
||||||
#line 623 "parse.yacc"
|
#line 629 "parse.yacc"
|
||||||
{
|
{
|
||||||
user_matches = TRUE;
|
user_matches = TRUE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#line 1541 "sudo.tab.c"
|
#line 1561 "sudo.tab.c"
|
||||||
}
|
}
|
||||||
yyssp -= yym;
|
yyssp -= yym;
|
||||||
yystate = *yyssp;
|
yystate = *yyssp;
|
||||||
|
Reference in New Issue
Block a user