X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.h;h=65d57f710a7745dbd3583623f3828e947abd6ce0;hb=5261ba901845c084de5a8fd06500ed09bfb0bd80;hp=f79f510ea2da880194b1d1f043a8c3a238af4c99;hpb=54d76c92868838e17d6aad0a3bb0cc7a5b11e35f;p=elogind.git diff --git a/src/core/busname.h b/src/core/busname.h index f79f510ea..65d57f710 100644 --- a/src/core/busname.h +++ b/src/core/busname.h @@ -28,8 +28,12 @@ typedef struct BusNamePolicy BusNamePolicy; 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,31 +42,18 @@ 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; -struct BusName { - Unit meta; - - char *name; - int starter_fd; - - UnitRef service; - - BusNameState state, deserialized_state; - BusNameResult result; - - sd_event_source *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; @@ -79,14 +70,36 @@ struct BusNamePolicy { BusNamePolicyType type; BusNamePolicyAccess access; - union { - uid_t uid; - gid_t gid; - }; + 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; + + usec_t timeout_usec; + + sd_event_source *starter_event_source; + sd_event_source *timer_event_source; + + pid_t control_pid; + + LIST_HEAD(BusNamePolicy, policy); + BusNamePolicyAccess policy_world; +}; + extern const UnitVTable busname_vtable; const char* busname_state_to_string(BusNameState i) _const_;