qrexec: do not send spurious MSG_SERVICE_REFUSED
This causes closing connection (FD) to still alive client. Fixes qubesos/qubes-issues#993
This commit is contained in:
parent
0d75af86d8
commit
3f29b411d0
@ -397,6 +397,7 @@ static int handle_cmdline_body_from_client(int fd, struct msg_header *hdr)
|
|||||||
int len = hdr->len-sizeof(params);
|
int len = hdr->len-sizeof(params);
|
||||||
char buf[len];
|
char buf[len];
|
||||||
int use_default_user = 0;
|
int use_default_user = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
if (!read_all(fd, ¶ms, sizeof(params))) {
|
if (!read_all(fd, ¶ms, sizeof(params))) {
|
||||||
terminate_client(fd);
|
terminate_client(fd);
|
||||||
@ -407,6 +408,22 @@ static int handle_cmdline_body_from_client(int fd, struct msg_header *hdr)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (hdr->type == MSG_SERVICE_CONNECT) {
|
||||||
|
/* if the service was accepted, do not send spurious
|
||||||
|
* MSG_SERVICE_REFUSED when service process itself exit with non-zero
|
||||||
|
* code */
|
||||||
|
for (i = 0; i <= policy_pending_max; i++) {
|
||||||
|
if (policy_pending[i].pid &&
|
||||||
|
strncmp(policy_pending[i].params.ident, buf, len) == 0) {
|
||||||
|
policy_pending[i].pid = 0;
|
||||||
|
while (policy_pending_max > 0 &&
|
||||||
|
policy_pending[policy_pending_max].pid > 0)
|
||||||
|
policy_pending_max--;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!params.connect_port) {
|
if (!params.connect_port) {
|
||||||
struct exec_params client_params;
|
struct exec_params client_params;
|
||||||
/* allocate port and send it to the client */
|
/* allocate port and send it to the client */
|
||||||
|
Loading…
Reference in New Issue
Block a user