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
|
|
|
|
* in daemon.c (for Linux) and daemon-windows.c (for Windows).
|
|
|
|
|
|
|
|
* The DAEMON_OPTION_ENUMS, DAEMON_LONG_OPTIONS and DAEMON_OPTION_HANDLERS
|
|
|
|
* macros are useful for parsing command-line options in individual utilities.
|
|
|
|
* For e.g., the command-line option "--detach" is recognized on Linux
|
|
|
|
* and results in calling the set_detach() function. The same option is not
|
|
|
|
* recognized on Windows platform.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _WIN32
|
2011-01-28 12:39:15 -08:00
|
|
|
#define DAEMON_OPTION_ENUMS \
|
|
|
|
OPT_DETACH, \
|
|
|
|
OPT_NO_CHDIR, \
|
|
|
|
OPT_OVERWRITE_PIDFILE, \
|
|
|
|
OPT_PIDFILE, \
|
2010-01-15 12:13:46 -08:00
|
|
|
OPT_MONITOR
|
2009-08-04 22:41:46 -07:00
|
|
|
|
2011-05-04 13:49:42 -07:00
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
|
|
{"detach", no_argument, NULL, OPT_DETACH}, \
|
|
|
|
{"no-chdir", no_argument, NULL, OPT_NO_CHDIR}, \
|
|
|
|
{"pidfile", optional_argument, NULL, OPT_PIDFILE}, \
|
|
|
|
{"overwrite-pidfile", no_argument, NULL, OPT_OVERWRITE_PIDFILE}, \
|
|
|
|
{"monitor", no_argument, NULL, OPT_MONITOR}
|
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; \
|
|
|
|
\
|
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(); \
|
2009-07-08 13:19:16 -07:00
|
|
|
break;
|
|
|
|
|
2014-01-16 16:16:24 -08:00
|
|
|
void set_detach(void);
|
|
|
|
void daemon_set_monitor(void);
|
2009-07-08 13:19:16 -07:00
|
|
|
void set_pidfile(const char *name);
|
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
|
|
|
|
#define DAEMON_OPTION_ENUMS \
|
|
|
|
OPT_SERVICE, \
|
|
|
|
OPT_SERVICE_MONITOR
|
|
|
|
|
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
|
|
{"service", no_argument, NULL, OPT_SERVICE}, \
|
|
|
|
{"service-monitor", no_argument, NULL, OPT_SERVICE_MONITOR}
|
|
|
|
|
|
|
|
#define DAEMON_OPTION_HANDLERS \
|
|
|
|
case OPT_SERVICE: \
|
|
|
|
break; \
|
|
|
|
\
|
|
|
|
case OPT_SERVICE_MONITOR: \
|
|
|
|
break;
|
|
|
|
|
|
|
|
void control_handler(DWORD request);
|
|
|
|
#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);
|
2009-12-17 10:56:01 -08:00
|
|
|
void daemonize_start(void);
|
|
|
|
void daemonize_complete(void);
|
2009-07-08 13:19:16 -07:00
|
|
|
void daemon_usage(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);
|
2012-05-21 11:08:13 -07:00
|
|
|
|
2009-07-08 13:19:16 -07:00
|
|
|
#endif /* daemon.h */
|