qrexec_daemon creates VMname-based link to its socket
This commit is contained in:
parent
b9e0e93a90
commit
470ddce435
@ -32,7 +32,7 @@ int write_all_vchan_ext(void *buf, int size);
|
|||||||
int buffer_space_vchan_ext();
|
int buffer_space_vchan_ext();
|
||||||
void fix_fds(int fdin, int fdout, int fderr);
|
void fix_fds(int fdin, int fdout, int fderr);
|
||||||
|
|
||||||
int get_server_socket(int domid);
|
int get_server_socket(int domid, char * domname);
|
||||||
int do_accept(int s);
|
int do_accept(int s);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -55,7 +55,7 @@ void handle_usr1(int x)
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
char domain_id[64];
|
char *remote_domain_name;
|
||||||
|
|
||||||
void init(int xid)
|
void init(int xid)
|
||||||
{
|
{
|
||||||
@ -66,7 +66,6 @@ void init(int xid)
|
|||||||
fprintf(stderr, "domain id=0?\n");
|
fprintf(stderr, "domain id=0?\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
snprintf(domain_id, sizeof(domain_id), "%d", xid);
|
|
||||||
signal(SIGUSR1, handle_usr1);
|
signal(SIGUSR1, handle_usr1);
|
||||||
switch (fork()) {
|
switch (fork()) {
|
||||||
case -1:
|
case -1:
|
||||||
@ -83,6 +82,8 @@ void init(int xid)
|
|||||||
"/var/log/qubes/qrexec.%d.log", xid);
|
"/var/log/qubes/qrexec.%d.log", xid);
|
||||||
umask(0007);
|
umask(0007);
|
||||||
logfd = open(dbg_log, O_WRONLY | O_CREAT | O_TRUNC, 0640);
|
logfd = open(dbg_log, O_WRONLY | O_CREAT | O_TRUNC, 0640);
|
||||||
|
umask(0077);
|
||||||
|
|
||||||
dup2(logfd, 1);
|
dup2(logfd, 1);
|
||||||
dup2(logfd, 2);
|
dup2(logfd, 2);
|
||||||
|
|
||||||
@ -92,11 +93,9 @@ void init(int xid)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
umask(0);
|
remote_domain_name = peer_client_init(xid, REXEC_PORT);
|
||||||
server_fd = get_server_socket(xid);
|
|
||||||
umask(0077);
|
|
||||||
peer_client_init(xid, REXEC_PORT);
|
|
||||||
setuid(getuid());
|
setuid(getuid());
|
||||||
|
server_fd = get_server_socket(xid, remote_domain_name);
|
||||||
signal(SIGPIPE, SIG_IGN);
|
signal(SIGPIPE, SIG_IGN);
|
||||||
signal(SIGCHLD, SIG_IGN);
|
signal(SIGCHLD, SIG_IGN);
|
||||||
signal(SIGUSR1, SIG_DFL);
|
signal(SIGUSR1, SIG_DFL);
|
||||||
@ -284,7 +283,7 @@ void handle_trigger_exec(int req)
|
|||||||
signal(SIGCHLD, SIG_DFL);
|
signal(SIGCHLD, SIG_DFL);
|
||||||
signal(SIGPIPE, SIG_DFL);
|
signal(SIGPIPE, SIG_DFL);
|
||||||
execl("/usr/lib/qubes/qrexec_client", "qrexec_client", "-d",
|
execl("/usr/lib/qubes/qrexec_client", "qrexec_client", "-d",
|
||||||
domain_id, "-l", lcmd, rcmd, NULL);
|
remote_domain_name, "-l", lcmd, rcmd, NULL);
|
||||||
perror("execl");
|
perror("execl");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
@ -27,15 +27,21 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include "qrexec.h"
|
#include "qrexec.h"
|
||||||
|
|
||||||
int get_server_socket(int domid)
|
int get_server_socket(int domid, char *domname)
|
||||||
{
|
{
|
||||||
struct sockaddr_un sockname;
|
struct sockaddr_un sockname;
|
||||||
int s;
|
int s;
|
||||||
char socket_address[40];
|
char socket_address[40];
|
||||||
|
char link_to_socket_name[strlen(domname) + sizeof(socket_address)];
|
||||||
|
|
||||||
snprintf(socket_address, sizeof(socket_address),
|
snprintf(socket_address, sizeof(socket_address),
|
||||||
QREXEC_DAEMON_SOCKET_DIR "/qrexec.%d", domid);
|
QREXEC_DAEMON_SOCKET_DIR "/qrexec.%d", domid);
|
||||||
|
snprintf(link_to_socket_name, sizeof link_to_socket_name,
|
||||||
|
QREXEC_DAEMON_SOCKET_DIR "/qrexec.%s", domname);
|
||||||
unlink(socket_address);
|
unlink(socket_address);
|
||||||
|
unlink(link_to_socket_name);
|
||||||
|
symlink(socket_address, link_to_socket_name);
|
||||||
|
|
||||||
s = socket(AF_UNIX, SOCK_STREAM, 0);
|
s = socket(AF_UNIX, SOCK_STREAM, 0);
|
||||||
memset(&sockname, 0, sizeof(sockname));
|
memset(&sockname, 0, sizeof(sockname));
|
||||||
sockname.sun_family = AF_UNIX;
|
sockname.sun_family = AF_UNIX;
|
||||||
|
Loading…
Reference in New Issue
Block a user