struct pakfire_jail;
-enum pakfire_jail_flags {
- PAKFIRE_JAIL_NONE = 0,
-};
-
-int pakfire_jail_create(struct pakfire_jail** jail, struct pakfire* pakfire, int flags);
+int pakfire_jail_create(struct pakfire_jail** jail, struct pakfire* pakfire);
struct pakfire_jail* pakfire_jail_ref(struct pakfire_jail* jail);
struct pakfire_jail* pakfire_jail_unref(struct pakfire_jail* jail);
// Resource Limits
int pakfire_jail_nice(struct pakfire_jail* jail, int nice);
+// Timeout
+int pakfire_jail_set_timeout(struct pakfire_jail* jail, unsigned int timeout);
+
// Environment
const char* pakfire_jail_get_env(struct pakfire_jail* jail, const char* key);
int pakfire_jail_set_env(struct pakfire_jail* jail, const char* key, const char* value);
int pakfire_jail_import_env(struct pakfire_jail* jail, const char* env[]);
+// Standard Input
+typedef int (*pakfire_jail_stdin_callback)
+ (struct pakfire_jail* jail, void* data, int fd);
+void pakfire_jail_set_stdin_callback(struct pakfire_jail* jail,
+ pakfire_jail_stdin_callback callback, void* data);
+
+// Standard Output
+typedef int (*pakfire_jail_stdout_callback)
+ (struct pakfire_jail* jail, void* data, const char* line, const size_t length);
+void pakfire_jail_set_stdout_callback(struct pakfire_jail* jail,
+ pakfire_jail_stdout_callback callback, void* data);
+
// Execute
typedef int (*pakfire_jail_communicate_in)
(struct pakfire* pakfire, void* data, int fd);
typedef int (*pakfire_jail_communicate_out)
(struct pakfire* pakfire, void* data, int priority, const char* line, const size_t length);
+enum pakfire_jail_exec_flags {
+ PAKFIRE_JAIL_PTY_FORWARDING = (1 << 0),
+ PAKFIRE_JAIL_HAS_NETWORKING = (1 << 1),
+ PAKFIRE_JAIL_NOENT_OK = (1 << 2),
+ PAKFIRE_JAIL_HAS_LOOP_DEVICES = (1 << 3),
+};
+
int pakfire_jail_exec(
struct pakfire_jail* jail,
const char* argv[],
pakfire_jail_communicate_in callback_in,
pakfire_jail_communicate_out callback_out,
- void* data);
+ void* data,
+ int flags);
#ifdef PAKFIRE_PRIVATE
#include <pakfire/cgroup.h>
// Capture
-int pakfire_jail_capture_stdout(struct pakfire* pakfire, void* data,
- int priority, const char* line, size_t length);
+int pakfire_jail_capture_stdout(struct pakfire_jail* jail,
+ void* data, const char* line, size_t length);
// Resource limits
int pakfire_jail_set_cgroup(struct pakfire_jail* jail, struct pakfire_cgroup* cgroup);
int pakfire_jail_shell(struct pakfire_jail* jail);
int pakfire_jail_ldconfig(struct pakfire* pakfire);
+int pakfire_jail_run_systemd_tmpfiles(struct pakfire* pakfire);
#endif /* PAKFIRE_PRIVATE */