2009-07-08 13:19:16 -07:00
|
|
|
/*
|
2012-05-02 15:21:36 -07:00
|
|
|
* Copyright (c) 2008, 2009, 2010, 2011, 2012 Nicira, Inc.
|
2009-07-08 13:19:16 -07:00
|
|
|
*
|
2009-06-15 15:11:30 -07:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
2009-07-08 13:19:16 -07:00
|
|
|
*
|
2009-06-15 15:11:30 -07:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2009-07-08 13:19:16 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DAEMON_H
|
|
|
|
#define DAEMON_H 1
|
|
|
|
|
2009-08-04 22:41:46 -07:00
|
|
|
#include <limits.h>
|
2009-07-08 13:19:16 -07:00
|
|
|
#include <stdbool.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
2014-01-16 16:16:24 -08:00
|
|
|
/* This file provides an interface for utilities to run in the background
|
|
|
|
* as daemons on POSIX platforms like Linux or as services on Windows platform.
|
|
|
|
* Some of the functionalities defined in this file are only applicable to
|
|
|
|
* POSIX platforms and some are applicable only on Windows. As such, the
|
|
|
|
* function definitions unique to each platform are separated out with
|
|
|
|
* ifdef macros. More descriptive comments on individual functions are provided
|
2014-04-23 14:22:38 -07:00
|
|
|
* in daemon-unix.c (for POSIX platforms) and daemon-windows.c (for Windows).
|
2014-01-16 16:16:24 -08:00
|
|
|
|
|
|
|
* The DAEMON_OPTION_ENUMS, DAEMON_LONG_OPTIONS and DAEMON_OPTION_HANDLERS
|
|
|
|
* macros are useful for parsing command-line options in individual utilities.
|
2014-04-15 10:14:05 -07:00
|
|
|
* For e.g., the command-line option "--monitor" is recognized on Linux
|
|
|
|
* and results in calling the daemon_set_monitor() function. The same option is
|
|
|
|
* not recognized on Windows platform.
|
2014-01-16 16:16:24 -08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _WIN32
|
2011-01-28 12:39:15 -08:00
|
|
|
#define DAEMON_OPTION_ENUMS \
|
|
|
|
OPT_DETACH, \
|
2016-06-20 14:19:40 -07:00
|
|
|
OPT_NO_SELF_CONFINEMENT, \
|
2011-01-28 12:39:15 -08:00
|
|
|
OPT_NO_CHDIR, \
|
|
|
|
OPT_OVERWRITE_PIDFILE, \
|
|
|
|
OPT_PIDFILE, \
|
2015-09-11 11:26:39 -07:00
|
|
|
OPT_MONITOR, \
|
|
|
|
OPT_USER_GROUP
|
2009-08-04 22:41:46 -07:00
|
|
|
|
2015-09-11 11:26:39 -07:00
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
|
|
{"detach", no_argument, NULL, OPT_DETACH}, \
|
2016-06-20 14:19:40 -07:00
|
|
|
{"no-self-confinement", no_argument, NULL, OPT_NO_SELF_CONFINEMENT}, \
|
2015-09-11 11:26:39 -07:00
|
|
|
{"no-chdir", no_argument, NULL, OPT_NO_CHDIR}, \
|
|
|
|
{"pidfile", optional_argument, NULL, OPT_PIDFILE}, \
|
2011-05-04 13:49:42 -07:00
|
|
|
{"overwrite-pidfile", no_argument, NULL, OPT_OVERWRITE_PIDFILE}, \
|
2015-09-11 11:26:39 -07:00
|
|
|
{"monitor", no_argument, NULL, OPT_MONITOR}, \
|
|
|
|
{"user", required_argument, NULL, OPT_USER_GROUP}
|
2009-07-08 13:19:16 -07:00
|
|
|
|
|
|
|
#define DAEMON_OPTION_HANDLERS \
|
2009-08-05 14:20:24 -07:00
|
|
|
case OPT_DETACH: \
|
2009-07-08 13:19:16 -07:00
|
|
|
set_detach(); \
|
|
|
|
break; \
|
|
|
|
\
|
2016-06-20 14:19:40 -07:00
|
|
|
case OPT_NO_SELF_CONFINEMENT: \
|
|
|
|
daemon_disable_self_confinement(); \
|
|
|
|
break; \
|
|
|
|
\
|
2009-08-04 22:41:46 -07:00
|
|
|
case OPT_NO_CHDIR: \
|
|
|
|
set_no_chdir(); \
|
|
|
|
break; \
|
|
|
|
\
|
2009-08-05 14:20:24 -07:00
|
|
|
case OPT_PIDFILE: \
|
2009-07-08 13:19:16 -07:00
|
|
|
set_pidfile(optarg); \
|
|
|
|
break; \
|
|
|
|
\
|
2009-08-05 14:20:24 -07:00
|
|
|
case OPT_OVERWRITE_PIDFILE: \
|
2009-07-08 13:19:16 -07:00
|
|
|
ignore_existing_pidfile(); \
|
2010-01-15 12:13:46 -08:00
|
|
|
break; \
|
|
|
|
\
|
|
|
|
case OPT_MONITOR: \
|
|
|
|
daemon_set_monitor(); \
|
2015-09-11 11:26:39 -07:00
|
|
|
break; \
|
|
|
|
\
|
|
|
|
case OPT_USER_GROUP: \
|
|
|
|
daemon_set_new_user(optarg); \
|
2009-07-08 13:19:16 -07:00
|
|
|
break;
|
|
|
|
|
2018-07-24 12:53:20 -07:00
|
|
|
#define DAEMON_OPTION_CASES \
|
|
|
|
case OPT_DETACH: \
|
|
|
|
case OPT_NO_SELF_CONFINEMENT: \
|
|
|
|
case OPT_NO_CHDIR: \
|
|
|
|
case OPT_PIDFILE: \
|
|
|
|
case OPT_OVERWRITE_PIDFILE: \
|
|
|
|
case OPT_MONITOR: \
|
|
|
|
case OPT_USER_GROUP:
|
|
|
|
|
2014-01-16 16:16:24 -08:00
|
|
|
void set_detach(void);
|
|
|
|
void daemon_set_monitor(void);
|
2009-08-04 22:41:46 -07:00
|
|
|
void set_no_chdir(void);
|
2014-01-16 16:16:24 -08:00
|
|
|
void ignore_existing_pidfile(void);
|
|
|
|
pid_t read_pidfile(const char *name);
|
|
|
|
#else
|
2014-04-15 10:14:05 -07:00
|
|
|
#define DAEMON_OPTION_ENUMS \
|
|
|
|
OPT_DETACH, \
|
2016-06-20 14:19:40 -07:00
|
|
|
OPT_NO_SELF_CONFINEMENT, \
|
2014-04-18 11:04:14 -07:00
|
|
|
OPT_NO_CHDIR, \
|
2014-04-15 13:26:53 -07:00
|
|
|
OPT_PIDFILE, \
|
2014-04-15 10:14:05 -07:00
|
|
|
OPT_PIPE_HANDLE, \
|
|
|
|
OPT_SERVICE, \
|
2015-10-01 08:57:24 -07:00
|
|
|
OPT_SERVICE_MONITOR, \
|
|
|
|
OPT_USER_GROUP
|
2014-01-16 16:16:24 -08:00
|
|
|
|
2014-04-15 10:14:05 -07:00
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
|
|
{"detach", no_argument, NULL, OPT_DETACH}, \
|
2016-06-29 18:12:07 -07:00
|
|
|
{"no-self-confinement", no_argument, NULL, OPT_NO_SELF_CONFINEMENT}, \
|
2014-04-18 11:04:14 -07:00
|
|
|
{"no-chdir", no_argument, NULL, OPT_NO_CHDIR}, \
|
2014-04-15 13:26:53 -07:00
|
|
|
{"pidfile", optional_argument, NULL, OPT_PIDFILE}, \
|
2014-04-15 10:14:05 -07:00
|
|
|
{"pipe-handle", required_argument, NULL, OPT_PIPE_HANDLE}, \
|
|
|
|
{"service", no_argument, NULL, OPT_SERVICE}, \
|
2015-10-01 08:57:24 -07:00
|
|
|
{"service-monitor", no_argument, NULL, OPT_SERVICE_MONITOR}, \
|
2015-09-11 11:26:39 -07:00
|
|
|
{"user", required_argument, NULL, OPT_USER_GROUP}
|
2014-01-16 16:16:24 -08:00
|
|
|
|
|
|
|
#define DAEMON_OPTION_HANDLERS \
|
2014-04-15 10:14:05 -07:00
|
|
|
case OPT_DETACH: \
|
2018-10-05 17:54:52 +03:00
|
|
|
set_detach(); \
|
2014-04-15 10:14:05 -07:00
|
|
|
break; \
|
|
|
|
\
|
2016-06-20 14:19:40 -07:00
|
|
|
case OPT_NO_SELF_CONFINEMENT: \
|
|
|
|
daemon_disable_self_confinement(); \
|
|
|
|
break; \
|
|
|
|
\
|
2014-04-18 11:04:14 -07:00
|
|
|
case OPT_NO_CHDIR: \
|
|
|
|
break; \
|
|
|
|
\
|
2014-04-15 13:26:53 -07:00
|
|
|
case OPT_PIDFILE: \
|
|
|
|
set_pidfile(optarg); \
|
|
|
|
break; \
|
|
|
|
\
|
2014-04-15 10:14:05 -07:00
|
|
|
case OPT_PIPE_HANDLE: \
|
|
|
|
set_pipe_handle(optarg); \
|
|
|
|
break; \
|
|
|
|
\
|
2014-01-16 16:16:24 -08:00
|
|
|
case OPT_SERVICE: \
|
2018-10-05 17:54:52 +03:00
|
|
|
set_detach(); \
|
2014-01-16 16:16:24 -08:00
|
|
|
break; \
|
|
|
|
\
|
|
|
|
case OPT_SERVICE_MONITOR: \
|
2015-09-11 11:26:39 -07:00
|
|
|
break; \
|
|
|
|
\
|
|
|
|
case OPT_USER_GROUP: \
|
2015-10-01 08:57:24 -07:00
|
|
|
daemon_set_new_user(optarg);
|
2014-01-16 16:16:24 -08:00
|
|
|
|
2018-07-24 12:53:20 -07:00
|
|
|
#define DAEMON_OPTION_CASES \
|
|
|
|
case OPT_DETACH: \
|
|
|
|
case OPT_NO_SELF_CONFINEMENT: \
|
|
|
|
case OPT_NO_CHDIR: \
|
|
|
|
case OPT_PIDFILE: \
|
|
|
|
case OPT_PIPE_HANDLE: \
|
|
|
|
case OPT_SERVICE: \
|
|
|
|
case OPT_SERVICE_MONITOR: \
|
|
|
|
case OPT_USER_GROUP:
|
|
|
|
|
2014-01-16 16:16:24 -08:00
|
|
|
void control_handler(DWORD request);
|
2014-04-15 10:14:05 -07:00
|
|
|
void set_pipe_handle(const char *pipe_handle);
|
2018-10-05 17:54:52 +03:00
|
|
|
void set_detach(void);
|
2014-01-16 16:16:24 -08:00
|
|
|
#endif /* _WIN32 */
|
|
|
|
|
2009-11-16 15:09:50 -08:00
|
|
|
bool get_detach(void);
|
2012-01-27 09:53:17 -08:00
|
|
|
void daemon_save_fd(int fd);
|
2009-07-08 13:19:16 -07:00
|
|
|
void daemonize(void);
|
2015-09-11 11:26:39 -07:00
|
|
|
void daemonize_start(bool access_datapath);
|
2009-12-17 10:56:01 -08:00
|
|
|
void daemonize_complete(void);
|
2015-09-11 11:26:39 -07:00
|
|
|
void daemon_set_new_user(const char * user_spec);
|
|
|
|
void daemon_become_new_user(bool access_datapath);
|
2009-07-08 13:19:16 -07:00
|
|
|
void daemon_usage(void);
|
2016-06-20 14:19:40 -07:00
|
|
|
void daemon_disable_self_confinement(void);
|
|
|
|
bool daemon_should_self_confine(void);
|
2014-01-16 16:16:24 -08:00
|
|
|
void service_start(int *argcp, char **argvp[]);
|
|
|
|
void service_stop(void);
|
|
|
|
bool should_service_stop(void);
|
2014-04-15 13:26:53 -07:00
|
|
|
void set_pidfile(const char *name);
|
2014-04-23 10:28:00 -07:00
|
|
|
void close_standard_fds(void);
|
2012-05-21 11:08:13 -07:00
|
|
|
|
2009-07-08 13:19:16 -07:00
|
|
|
#endif /* daemon.h */
|