X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.h;h=c9b653d82e6081389e801fa5b0afc3090cde7404;hb=f1f00dbb7f3741b30d4a26b1a8b65ec46ff1fde3;hp=7f591974de03cbe0e4c28be8d4df8c40b0f6234c;hpb=3f9da416457c4265b8f1179516a32ad1a987ff7d;p=elogind.git diff --git a/src/core/busname.h b/src/core/busname.h index 7f591974d..c9b653d82 100644 --- a/src/core/busname.h +++ b/src/core/busname.h @@ -25,11 +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 @@ -38,55 +43,54 @@ 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; char *name; int starter_fd; + bool activating; + bool accept_fd; + UnitRef service; BusNameState state, deserialized_state; BusNameResult result; - sd_event_source *event_source; + usec_t timeout_usec; - bool accept_fd; + sd_event_source *starter_event_source; + sd_event_source *timer_event_source; - 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; + pid_t control_pid; -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; - -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; @@ -96,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_;