00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #include <signal.h>
00023 #include <errno.h>
00024 #include <string.h>
00025 #include <sys/types.h>
00026 #include <sys/time.h>
00027 #include <sys/unistd.h>
00028 #include <sys/select.h>
00029
00030 #include <libdaemon/dfork.h>
00031 #include <libdaemon/dsignal.h>
00032 #include <libdaemon/dlog.h>
00033 #include <libdaemon/dpid.h>
00034 #include <libdaemon/dexec.h>
00035
00036 int main(int argc, char *argv[]) {
00037 pid_t pid;
00038
00039
00040 daemon_pid_file_ident = daemon_log_ident = daemon_ident_from_argv0(argv[0]);
00041
00042
00043 if (argc >= 2 && !strcmp(argv[1], "-k")) {
00044 int ret;
00045
00046
00047
00048
00049 #ifdef DAEMON_PID_FILE_KILL_WAIT_AVAILABLE
00050 if ((ret = daemon_pid_file_kill_wait(SIGINT, 5)) < 0)
00051 #else
00052 if ((ret = daemon_pid_file_kill(SIGINT)) < 0)
00053 #endif
00054 daemon_log(LOG_WARNING, "Failed to kill daemon");
00055
00056 return ret < 0 ? 1 : 0;
00057 }
00058
00059
00060 if ((pid = daemon_pid_file_is_running()) >= 0) {
00061 daemon_log(LOG_ERR, "Daemon already running on PID file %u", pid);
00062 return 1;
00063
00064 }
00065
00066
00067 daemon_retval_init();
00068
00069
00070 if ((pid = daemon_fork()) < 0) {
00071
00072
00073 daemon_retval_done();
00074 return 1;
00075
00076 } else if (pid) {
00077 int ret;
00078
00079
00080 if ((ret = daemon_retval_wait(20)) < 0) {
00081 daemon_log(LOG_ERR, "Could not recieve return value from daemon process.");
00082 return 255;
00083 }
00084
00085 daemon_log(ret != 0 ? LOG_ERR : LOG_INFO, "Daemon returned %i as return value.", ret);
00086 return ret;
00087
00088 } else {
00089 int fd, quit = 0;
00090 fd_set fds;
00091
00092
00093 if (daemon_pid_file_create() < 0) {
00094 daemon_log(LOG_ERR, "Could not create PID file (%s).", strerror(errno));
00095
00096
00097 daemon_retval_send(1);
00098 goto finish;
00099 }
00100
00101
00102 if (daemon_signal_init(SIGINT, SIGQUIT, SIGHUP, 0) < 0) {
00103 daemon_log(LOG_ERR, "Could not register signal handlers (%s).", strerror(errno));
00104 daemon_retval_send(2);
00105 goto finish;
00106 }
00107
00108
00109
00110
00111
00112 daemon_retval_send(0);
00113
00114 daemon_log(LOG_INFO, "Sucessfully started");
00115
00116
00117
00118 FD_ZERO(&fds);
00119 FD_SET(fd = daemon_signal_fd(), &fds);
00120
00121 while (!quit) {
00122 fd_set fds2 = fds;
00123
00124
00125 if (select(FD_SETSIZE, &fds2, 0, 0, 0) < 0) {
00126
00127
00128 if (errno == EINTR)
00129 continue;
00130
00131 daemon_log(LOG_ERR, "select(): %s", strerror(errno));
00132 break;
00133 }
00134
00135
00136 if (FD_ISSET(fd, &fds)) {
00137 int sig;
00138
00139
00140 if ((sig = daemon_signal_next()) <= 0) {
00141 daemon_log(LOG_ERR, "daemon_signal_next() failed.");
00142 break;
00143 }
00144
00145
00146 switch (sig) {
00147
00148 case SIGINT:
00149 case SIGQUIT:
00150 daemon_log(LOG_WARNING, "Got SIGINT or SIGQUIT");
00151 quit = 1;
00152 break;
00153
00154 case SIGHUP:
00155 daemon_log(LOG_INFO, "Got a HUP");
00156 daemon_exec("/", NULL, "/bin/ls", "ls", (char*) NULL);
00157 break;
00158
00159 }
00160 }
00161 }
00162
00163
00164 finish:
00165 daemon_log(LOG_INFO, "Exiting...");
00166
00167 daemon_signal_done();
00168 daemon_pid_file_remove();
00169
00170 return 0;
00171 }
00172 }