X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.h;h=c9b653d82e6081389e801fa5b0afc3090cde7404;hb=25fa306ed58b0b7fe30ca9be37c66a7b3b2de70e;hp=ab3082bb05ed8ba3d2b8ee9e92cf96120ceb7c1b;hpb=6af00e06e4e9efacc5a9941eb3b9fffa1c816ee6;p=elogind.git diff --git a/src/core/busname.h b/src/core/busname.h index ab3082bb0..c9b653d82 100644 --- a/src/core/busname.h +++ b/src/core/busname.h @@ -25,12 +25,16 @@ typedef struct BusName BusName; typedef struct BusNamePolicy BusNamePolicy; #include "unit.h" +#include "bus-common.h" typedef enum BusNameState { BUSNAME_DEAD, + BUSNAME_MAKING, BUSNAME_REGISTERED, BUSNAME_LISTENING, BUSNAME_RUNNING, + BUSNAME_SIGTERM, + BUSNAME_SIGKILL, BUSNAME_FAILED, _BUSNAME_STATE_MAX, _BUSNAME_STATE_INVALID = -1 @@ -39,11 +43,31 @@ typedef enum BusNameState { typedef enum BusNameResult { BUSNAME_SUCCESS, BUSNAME_FAILURE_RESOURCES, + BUSNAME_FAILURE_TIMEOUT, + BUSNAME_FAILURE_EXIT_CODE, + BUSNAME_FAILURE_SIGNAL, + BUSNAME_FAILURE_CORE_DUMP, BUSNAME_FAILURE_SERVICE_FAILED_PERMANENT, _BUSNAME_RESULT_MAX, _BUSNAME_RESULT_INVALID = -1 } BusNameResult; +typedef enum BusNamePolicyType { + BUSNAME_POLICY_TYPE_USER, + BUSNAME_POLICY_TYPE_GROUP, + _BUSNAME_POLICY_TYPE_MAX, + _BUSNAME_POLICY_TYPE_INVALID = -1 +} BusNamePolicyType; + +struct BusNamePolicy { + BusNamePolicyType type; + BusPolicyAccess access; + + char *name; + + LIST_FIELDS(BusNamePolicy, policy); +}; + struct BusName { Unit meta; @@ -58,37 +82,15 @@ struct BusName { BusNameState state, deserialized_state; BusNameResult result; - sd_event_source *event_source; + usec_t timeout_usec; - LIST_HEAD(BusNamePolicy, policy); -}; - -typedef enum BusNamePolicyType { - BUSNAME_POLICY_TYPE_USER, - BUSNAME_POLICY_TYPE_GROUP, - BUSNAME_POLICY_TYPE_WORLD, - _BUSNAME_POLICY_TYPE_MAX, - _BUSNAME_POLICY_TYPE_INVALID = -1 -} BusNamePolicyType; + sd_event_source *starter_event_source; + sd_event_source *timer_event_source; -typedef enum BusNamePolicyAccess { - BUSNAME_POLICY_ACCESS_SEE, - BUSNAME_POLICY_ACCESS_TALK, - BUSNAME_POLICY_ACCESS_OWN, - _BUSNAME_POLICY_ACCESS_MAX, - _BUSNAME_POLICY_ACCESS_INVALID = -1 -} BusNamePolicyAccess; + pid_t control_pid; -struct BusNamePolicy { - BusNamePolicyType type; - BusNamePolicyAccess access; - - union { - uid_t uid; - gid_t gid; - }; - - LIST_FIELDS(BusNamePolicy, policy); + LIST_HEAD(BusNamePolicy, policy); + BusPolicyAccess policy_world; }; extern const UnitVTable busname_vtable; @@ -98,6 +100,3 @@ BusNameState busname_state_from_string(const char *s) _pure_; const char* busname_result_to_string(BusNameResult i) _const_; BusNameResult busname_result_from_string(const char *s) _pure_; - -const char* busname_policy_access_to_string(BusNamePolicyAccess i) _const_; -BusNamePolicyAccess busname_policy_access_from_string(const char *s) _pure_;