nsjail/common.h
2016-03-10 16:01:16 +01:00

130 lines
3.0 KiB
C

/*
nsjail - common structures
-----------------------------------------
Copyright 2014 Google Inc. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef _COMMON_H
#define _COMMON_H
#include <limits.h>
#include <netinet/ip6.h>
#include <stdbool.h>
#include <sys/queue.h>
#include <sys/resource.h>
#include <sys/types.h>
#define ARRAYSIZE(array) (sizeof(array) / sizeof(*array))
/* Go-style defer implementation */
#define __STRMERGE(a, b) a##b
#define _STRMERGE(a, b) __STRMERGE(a, b)
#ifdef __clang__
static void __attribute__ ((unused)) _clang_cleanup_func(void (^*dfunc) (void))
{
(*dfunc) ();
}
#define defer(a) void (^_STRMERGE(__defer_f_, __COUNTER__))(void) __attribute__((cleanup(_clang_cleanup_func))) __attribute__((unused)) = ^{ a; }
#else
#define __block
#define _defer(a, count) void _STRMERGE(__defer_f_, count)(void *_defer_arg __attribute__((unused))) { a; } ; \
int _STRMERGE(_defer_var_, count) __attribute__((cleanup(_STRMERGE(__defer_f_, count)))) __attribute__((unused))
#define defer(a) _defer(a, __COUNTER__)
#endif
struct pids_t {
pid_t pid;
time_t start;
char remote_txt[64];
struct sockaddr_in6 remote_addr;
TAILQ_ENTRY(pids_t) pointers;
};
struct mounts_t {
const char *src;
const char *dst;
const char *fs_type;
const char *options;
uintptr_t flags;
TAILQ_ENTRY(mounts_t) pointers;
};
enum mode_t {
MODE_LISTEN_TCP = 0,
MODE_STANDALONE_ONCE,
MODE_STANDALONE_EXECVE,
MODE_STANDALONE_RERUN
};
struct charptr_t {
char *val;
TAILQ_ENTRY(charptr_t) pointers;
};
struct nsjconf_t {
const char *hostname;
const char *cwd;
char *const *argv;
int port;
const char *bindhost;
bool daemonize;
time_t tlimit;
bool apply_sandbox;
bool verbose;
bool keep_env;
bool keep_caps;
rlim64_t rl_as;
rlim64_t rl_core;
rlim64_t rl_cpu;
rlim64_t rl_fsize;
rlim64_t rl_nofile;
rlim64_t rl_nproc;
rlim64_t rl_stack;
unsigned long personality;
bool clone_newnet;
bool clone_newuser;
bool clone_newns;
bool clone_newpid;
bool clone_newipc;
bool clone_newuts;
enum mode_t mode;
const char *chroot;
bool is_root_rw;
bool is_silent;
bool skip_setsid;
uid_t outside_uid;
gid_t outside_gid;
uid_t inside_uid;
gid_t inside_gid;
unsigned int max_conns_per_ip;
size_t tmpfs_size;
bool mount_proc;
bool iface_no_lo;
const char *iface;
const char *iface_vs_ip;
const char *iface_vs_nm;
const char *iface_vs_gw;
TAILQ_HEAD(envlist, charptr_t) envs;
TAILQ_HEAD(pidslist, pids_t) pids;
TAILQ_HEAD(mountptslist, mounts_t) mountpts;
};
#endif /* _COMMON_H */