changed how sb getaddrinfo works such that it supports storing multiple results

This commit is contained in:
Cristian Toader 2013-09-02 11:44:04 +03:00
parent 3e803a1f18
commit 1ef0b2e1a3
3 changed files with 63 additions and 32 deletions

View File

@ -54,8 +54,7 @@
#include <poll.h> #include <poll.h>
static sandbox_cfg_t *filter_dynamic = NULL; static sandbox_cfg_t *filter_dynamic = NULL;
static sb_addr_info_t *sb_addr_info = NULL;
static struct addrinfo *sb_addr_info= NULL;
/** Variable used for storing all syscall numbers that will be allowed with the /** Variable used for storing all syscall numbers that will be allowed with the
* stage 1 general Tor sandbox. * stage 1 general Tor sandbox.
@ -914,54 +913,57 @@ sandbox_cfg_allow_execve_array(sandbox_cfg_t **cfg, ...)
int int
sandbox_getaddrinfo(const char *name, struct addrinfo **res) sandbox_getaddrinfo(const char *name, struct addrinfo **res)
{ {
char hname[256]; sb_addr_info_t *el;
if (!res) {
return -2;
}
*res = NULL; *res = NULL;
*res = (struct addrinfo *)malloc(sizeof(struct addrinfo));
if (*res == NULL) { for (el = sb_addr_info; el; el = el->next) {
return -2; if(!strcmp(el->name, name)) {
*res = (struct addrinfo *)malloc(sizeof(struct addrinfo));
if (!res) {
return -2;
}
memcpy(*res, el->info, sizeof(struct addrinfo));
return 0;
}
} }
if (gethostname(hname, sizeof(hname)) < 0) { return -1;
return -1;
}
if (strcmp(name, hname) || sb_addr_info == NULL) {
log_err(LD_BUG,"(Sandbox) failed for hname %s!", name);
return -1;
}
memcpy(*res, sb_addr_info, sizeof(struct addrinfo));
return 0;
} }
static int int
init_addrinfo(void) sandbox_add_addrinfo(const char* name)
{ {
int ret; int ret;
struct addrinfo hints; struct addrinfo hints;
char hname[256]; sb_addr_info_t *el = NULL;
sb_addr_info = NULL; el = (sb_addr_info_t*) malloc(sizeof(sb_addr_info_t));
if(!el) {
if (gethostname(hname, sizeof(hname)) < 0) { log_err(LD_BUG,"(Sandbox) failed to allocate addr info!");
return -1; ret = -2;
goto out;
} }
memset(&hints, 0, sizeof(hints)); memset(&hints, 0, sizeof(hints));
hints.ai_family = AF_INET; hints.ai_family = AF_INET;
hints.ai_socktype = SOCK_STREAM; hints.ai_socktype = SOCK_STREAM;
ret = getaddrinfo(hname, NULL, &hints, &sb_addr_info); ret = getaddrinfo(name, NULL, &hints, &(el->info));
if (ret) { if (ret) {
sb_addr_info = NULL; log_err(LD_BUG,"(Sandbox) failed to getaddrinfo");
return -2; ret = -2;
goto out;
} }
return 0; el->name = strdup(name);
el->next = sb_addr_info;
sb_addr_info = el;
out:
return ret;
} }
static int static int
@ -1151,7 +1153,7 @@ initialise_libseccomp_sandbox(sandbox_cfg_t* cfg)
if (install_sigsys_debugging()) if (install_sigsys_debugging())
return -1; return -1;
if (init_addrinfo() || prot_strings(cfg)) { if (prot_strings(cfg)) {
return -4; return -4;
} }

View File

@ -62,6 +62,21 @@ struct pfd_elem {
/** Typedef to structure used to manage a sandbox configuration. */ /** Typedef to structure used to manage a sandbox configuration. */
typedef struct pfd_elem sandbox_cfg_t; typedef struct pfd_elem sandbox_cfg_t;
/**
* Structure used for keeping a linked list of getaddrinfo pre-recorded
* results.
*/
struct sb_addr_info_el {
/** Name of the address info result. */
char *name;
/** Pre-recorded getaddrinfo result. */
struct addrinfo *info;
/** Next element in the list. */
struct sb_addr_info_el *next;
};
/** Typedef to structure used to manage an addrinfo list. */
typedef struct sb_addr_info_el sb_addr_info_t;
/** Function pointer defining the prototype of a filter function.*/ /** Function pointer defining the prototype of a filter function.*/
typedef int (*sandbox_filter_func_t)(scmp_filter_ctx ctx, typedef int (*sandbox_filter_func_t)(scmp_filter_ctx ctx,
sandbox_cfg_t *filter); sandbox_cfg_t *filter);
@ -93,6 +108,9 @@ typedef struct {
#endif // __linux__ #endif // __linux__
/** Pre-calls getaddrinfo in order to pre-record result. */
int sandbox_add_addrinfo(const char *addr);
/** Replacement for getaddrinfo(), using pre-recorded results. */ /** Replacement for getaddrinfo(), using pre-recorded results. */
int sandbox_getaddrinfo(const char *name, struct addrinfo **res); int sandbox_getaddrinfo(const char *name, struct addrinfo **res);

View File

@ -2639,6 +2639,15 @@ find_flashcard_path(PWCHAR path, size_t size)
} }
#endif #endif
static void
init_addrinfo(void) {
char hname[256];
// host name to sandbox
gethostname(hname, sizeof(hname));
sandbox_add_addrinfo(hname);
}
static sandbox_cfg_t* static sandbox_cfg_t*
sandbox_init_filter() sandbox_init_filter()
{ {
@ -2713,6 +2722,8 @@ sandbox_init_filter()
sandbox_cfg_allow_execve(&cfg, "/usr/local/bin/tor"); sandbox_cfg_allow_execve(&cfg, "/usr/local/bin/tor");
init_addrinfo();
return cfg; return cfg;
} }