diff options
| author | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-12-17 03:11:52 -0500 | 
|---|---|---|
| committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-12-17 03:11:52 -0500 | 
| commit | b849891b5dde5ee14ab8b7b7db74e65a4a38d993 (patch) | |
| tree | 29bb0e6fda9b4b170041913de495da057bbe3621 /src/libsystemd-shared/include | |
| parent | 004efebf9cc559ea131bb9460ee0ee198e2d5da7 (diff) | |
| parent | 881228ff72434a0e3401a16bd87f179ef0ab1619 (diff) | |
Merge branch 'notsystemd/postmove' into notsystemd/master
# Conflicts:
#	src/grp-journal/libjournal-core/.gitignore
#	src/grp-system/libcore/include/core/mount.h
Diffstat (limited to 'src/libsystemd-shared/include')
7 files changed, 98 insertions, 44 deletions
| diff --git a/src/libsystemd-shared/include/systemd-shared/bus-unit-util.h b/src/libsystemd-shared/include/systemd-shared/bus-unit-util.h index b4b68cc5d2..af99c71c3f 100644 --- a/src/libsystemd-shared/include/systemd-shared/bus-unit-util.h +++ b/src/libsystemd-shared/include/systemd-shared/bus-unit-util.h @@ -41,6 +41,7 @@ typedef struct UnitInfo {  int bus_parse_unit_info(sd_bus_message *message, UnitInfo *u);  int bus_append_unit_property_assignment(sd_bus_message *m, const char *assignment); +int bus_append_unit_property_assignment_many(sd_bus_message *m, char **l);  typedef struct BusWaitForJobs BusWaitForJobs; diff --git a/src/libsystemd-shared/include/systemd-shared/clean-ipc.h b/src/libsystemd-shared/include/systemd-shared/clean-ipc.h index 44a83afcf7..6ca57f44fd 100644 --- a/src/libsystemd-shared/include/systemd-shared/clean-ipc.h +++ b/src/libsystemd-shared/include/systemd-shared/clean-ipc.h @@ -21,4 +21,6 @@  #include <sys/types.h> -int clean_ipc(uid_t uid); +int clean_ipc(uid_t uid, gid_t gid); +int clean_ipc_by_uid(uid_t uid); +int clean_ipc_by_gid(gid_t gid); diff --git a/src/libsystemd-shared/include/systemd-shared/conf-parser.h b/src/libsystemd-shared/include/systemd-shared/conf-parser.h index dfac0a788e..b5fd4c1787 100644 --- a/src/libsystemd-shared/include/systemd-shared/conf-parser.h +++ b/src/libsystemd-shared/include/systemd-shared/conf-parser.h @@ -84,29 +84,42 @@ int config_item_table_lookup(const void *table, const char *section, const char   * ConfigPerfItem tables */  int config_item_perf_lookup(const void *table, const char *section, const char *lvalue, ConfigParserCallback *func, int *ltype, void **data, void *userdata); -int config_parse(const char *unit, -                 const char *filename, -                 FILE *f, -                 const char *sections,  /* nulstr */ -                 ConfigItemLookup lookup, -                 const void *table, -                 bool relaxed, -                 bool allow_include, -                 bool warn, -                 void *userdata); - -int config_parse_many(const char *conf_file,      /* possibly NULL */ -                      const char *conf_file_dirs, /* nulstr */ -                      const char *sections,       /* nulstr */ -                      ConfigItemLookup lookup, -                      const void *table, -                      bool relaxed, -                      void *userdata); +int config_parse( +                const char *unit, +                const char *filename, +                FILE *f, +                const char *sections,  /* nulstr */ +                ConfigItemLookup lookup, +                const void *table, +                bool relaxed, +                bool allow_include, +                bool warn, +                void *userdata); + +int config_parse_many_nulstr( +                const char *conf_file,      /* possibly NULL */ +                const char *conf_file_dirs, /* nulstr */ +                const char *sections,       /* nulstr */ +                ConfigItemLookup lookup, +                const void *table, +                bool relaxed, +                void *userdata); + +int config_parse_many( +                const char *conf_file,      /* possibly NULL */ +                const char* const* conf_file_dirs, +                const char *dropin_dirname, +                const char *sections,       /* nulstr */ +                ConfigItemLookup lookup, +                const void *table, +                bool relaxed, +                void *userdata);  /* Generic parsers */  int config_parse_int(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_unsigned(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_long(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); +int config_parse_uint16(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_uint32(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_uint64(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_double(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line,  const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); diff --git a/src/libsystemd-shared/include/systemd-shared/install.h b/src/libsystemd-shared/include/systemd-shared/install.h index 52254974c7..1b94cd59f7 100644 --- a/src/libsystemd-shared/include/systemd-shared/install.h +++ b/src/libsystemd-shared/include/systemd-shared/install.h @@ -27,6 +27,7 @@  #include "systemd-basic/unit-name.h"  typedef enum UnitFileChangeType UnitFileChangeType; +typedef enum UnitFileFlags UnitFileFlags;  typedef enum UnitFilePresetMode UnitFilePresetMode;  typedef enum UnitFileScope UnitFileScope;  typedef enum UnitFileState UnitFileState; @@ -79,6 +80,12 @@ enum UnitFileChangeType {          _UNIT_FILE_CHANGE_INVALID = INT_MIN  }; +enum UnitFileFlags { +        UNIT_FILE_RUNTIME = 1, +        UNIT_FILE_FORCE = 1 << 1, +        UNIT_FILE_DRY_RUN = 1 << 2, +}; +  /* type can either one of the UnitFileChangeTypes listed above, or a negative error.   * If source is specified, it should be the contents of the path symlink.   * In case of an error, source should be the existing symlink contents or NULL @@ -120,10 +127,10 @@ struct UnitFileInstallInfo {          char **also;          char *default_instance; +        char *symlink_target;          UnitFileType type; - -        char *symlink_target; +        bool auxiliary;  };  static inline bool UNIT_FILE_INSTALL_INFO_HAS_RULES(UnitFileInstallInfo *i) { @@ -145,65 +152,59 @@ bool unit_type_may_template(UnitType type) _const_;  int unit_file_enable(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_disable(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_reenable(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_preset(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files,                  UnitFilePresetMode mode, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_preset_all(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  UnitFilePresetMode mode, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_mask(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_unmask(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_link(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_revert( @@ -214,9 +215,9 @@ int unit_file_revert(                  unsigned *n_changes);  int unit_file_set_default(                  UnitFileScope scope, +                UnitFileFlags flags,                  const char *root_dir,                  const char *file, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes);  int unit_file_get_default( @@ -225,12 +226,11 @@ int unit_file_get_default(                  char **name);  int unit_file_add_dependency(                  UnitFileScope scope, -                bool runtime, +                UnitFileFlags flags,                  const char *root_dir,                  char **files,                  const char *target,                  UnitDependency dep, -                bool force,                  UnitFileChange **changes,                  unsigned *n_changes); diff --git a/src/libsystemd-shared/include/systemd-shared/output-mode.h b/src/libsystemd-shared/include/systemd-shared/output-mode.h index 2147470bdd..c3e7942777 100644 --- a/src/libsystemd-shared/include/systemd-shared/output-mode.h +++ b/src/libsystemd-shared/include/systemd-shared/output-mode.h @@ -23,6 +23,7 @@  typedef enum OutputMode {          OUTPUT_SHORT, +        OUTPUT_SHORT_FULL,          OUTPUT_SHORT_ISO,          OUTPUT_SHORT_PRECISE,          OUTPUT_SHORT_MONOTONIC, diff --git a/src/libsystemd-shared/include/systemd-shared/ptyfwd.h b/src/libsystemd-shared/include/systemd-shared/ptyfwd.h index ae9ef32d79..b57f421eb3 100644 --- a/src/libsystemd-shared/include/systemd-shared/ptyfwd.h +++ b/src/libsystemd-shared/include/systemd-shared/ptyfwd.h @@ -37,12 +37,18 @@ typedef enum PTYForwardFlags {          PTY_FORWARD_IGNORE_INITIAL_VHANGUP = 4,  } PTYForwardFlags; +typedef int (*PTYForwardHandler)(PTYForward *f, int rcode, void*userdata); +  int pty_forward_new(sd_event *event, int master, PTYForwardFlags flags, PTYForward **f);  PTYForward *pty_forward_free(PTYForward *f);  int pty_forward_get_last_char(PTYForward *f, char *ch);  int pty_forward_set_ignore_vhangup(PTYForward *f, bool ignore_vhangup); -int pty_forward_get_ignore_vhangup(PTYForward *f); +bool pty_forward_get_ignore_vhangup(PTYForward *f); + +bool pty_forward_is_done(PTYForward *f); + +void pty_forward_set_handler(PTYForward *f, PTYForwardHandler handler, void *userdata);  DEFINE_TRIVIAL_CLEANUP_FUNC(PTYForward*, pty_forward_free); diff --git a/src/libsystemd-shared/include/systemd-shared/seccomp-util.h b/src/libsystemd-shared/include/systemd-shared/seccomp-util.h index be33eecb85..8e209efef2 100644 --- a/src/libsystemd-shared/include/systemd-shared/seccomp-util.h +++ b/src/libsystemd-shared/include/systemd-shared/seccomp-util.h @@ -20,16 +20,47 @@  ***/  #include <seccomp.h> +#include <stdbool.h>  #include <stdint.h>  const char* seccomp_arch_to_string(uint32_t c);  int seccomp_arch_from_string(const char *n, uint32_t *ret); -int seccomp_add_secondary_archs(scmp_filter_ctx *c); +int seccomp_init_conservative(scmp_filter_ctx *ret, uint32_t default_action); -typedef struct SystemCallFilterSet { -        const char *set_name; +int seccomp_add_secondary_archs(scmp_filter_ctx c); + +bool is_seccomp_available(void); + +typedef struct SyscallFilterSet { +        const char *name;          const char *value; -} SystemCallFilterSet; +} SyscallFilterSet; + +enum { +        SYSCALL_FILTER_SET_BASIC_IO, +        SYSCALL_FILTER_SET_CLOCK, +        SYSCALL_FILTER_SET_CPU_EMULATION, +        SYSCALL_FILTER_SET_DEBUG, +        SYSCALL_FILTER_SET_DEFAULT, +        SYSCALL_FILTER_SET_IO_EVENT, +        SYSCALL_FILTER_SET_IPC, +        SYSCALL_FILTER_SET_KEYRING, +        SYSCALL_FILTER_SET_MODULE, +        SYSCALL_FILTER_SET_MOUNT, +        SYSCALL_FILTER_SET_NETWORK_IO, +        SYSCALL_FILTER_SET_OBSOLETE, +        SYSCALL_FILTER_SET_PRIVILEGED, +        SYSCALL_FILTER_SET_PROCESS, +        SYSCALL_FILTER_SET_RAW_IO, +        SYSCALL_FILTER_SET_RESOURCES, +        _SYSCALL_FILTER_SET_MAX +}; + +extern const SyscallFilterSet syscall_filter_sets[]; + +const SyscallFilterSet *syscall_filter_set_find(const char *name); + +int seccomp_add_syscall_filter_set(scmp_filter_ctx seccomp, const SyscallFilterSet *set, uint32_t action); -extern const SystemCallFilterSet syscall_filter_sets[]; +int seccomp_load_filter_set(uint32_t default_action, const SyscallFilterSet *set, uint32_t action); | 
