mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-28 06:13:31 +01:00
changed how sb getaddrinfo works such that it supports storing multiple results
This commit is contained in:
parent
3e803a1f18
commit
1ef0b2e1a3
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user