service.h revision b26fa1a2fbcfee7d03b0c8fd15ec3aa64ae70b9f
#pragma once
/***
This file is part of systemd.
Copyright 2010 Lennart Poettering
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
(at your option) any later version.
systemd is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
typedef struct ServiceFDStore ServiceFDStore;
#include "exit-status.h"
#include "kill.h"
#include "path.h"
#include "ratelimit.h"
typedef enum ServiceRestart {
typedef enum ServiceType {
SERVICE_SIMPLE, /* we fork and go on right-away (i.e. modern socket activated daemons) */
SERVICE_FORKING, /* forks by itself (i.e. traditional daemons) */
SERVICE_ONESHOT, /* we fork and wait until the program finishes (i.e. programs like fsck which run and need to finish before we continue) */
SERVICE_DBUS, /* we fork and wait until a specific D-Bus name appears on the bus */
SERVICE_NOTIFY, /* we fork and wait until a daemon sends us a ready message with sd_notify() */
SERVICE_IDLE, /* much like simple, but delay exec() until all jobs are dispatched. */
} ServiceType;
typedef enum ServiceExecCommand {
typedef enum NotifyAccess {
} NotifyAccess;
typedef enum NotifyState {
} NotifyState;
typedef enum ServiceResult {
struct ServiceFDStore {
int fd;
char *fdname;
};
struct Service {
/* If set we'll read the main daemon PID from this file */
char *pid_file;
/* The exit status of the real main process */
/* The currently executed control process */
/* The currently executed main process, which may be NULL if
* the main process got started via forking mode and not by
* us */
/* The ID of the control command currently being executed */
/* Runtime data of the execution context */
int socket_fd;
int bus_endpoint_fd;
bool permissions_start_only;
bool remain_after_exit;
bool guess_main_pid;
/* If we shut down, remember why */
bool main_pid_known:1;
bool main_pid_alien:1;
bool bus_name_good:1;
bool forbid_restart:1;
bool start_timeout_defined:1;
bool reset_cpu_usage:1;
char *bus_name;
char *bus_name_owner; /* unique name of the current owner */
char *status_text;
int status_errno;
char *reboot_arg;
unsigned n_fd_store;
unsigned n_fd_store_max;
char *usb_function_descriptors;
char *usb_function_strings;
int stdin_fd;
int stdout_fd;
int stderr_fd;
};
extern const UnitVTable service_vtable;