X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.h;h=c9b653d82e6081389e801fa5b0afc3090cde7404;hb=652212b0c2b60b9ef9b2e24eae82401f880fa21a;hp=0009c6a65e2330d40c99b34f6783b9e446110600;hpb=5892a914d173e4b968d2a14fbf717373dee3999a;p=elogind.git diff --git a/src/core/busname.h b/src/core/busname.h index 0009c6a65..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,56 +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; @@ -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_;