Implement serviceSignal, serviceStop, serviceRestart
This commit is contained in:
parent
0ca3c5c103
commit
e68a29c15e
4
daemon.h
4
daemon.h
@ -67,6 +67,7 @@ extern char *serviceEnviron[EnvironLen];
|
||||
enum State {
|
||||
Stop,
|
||||
Start,
|
||||
Restart,
|
||||
};
|
||||
|
||||
enum { LineCap = 512 };
|
||||
@ -96,6 +97,9 @@ extern struct Services {
|
||||
|
||||
int serviceAdd(const char *name, const char *command);
|
||||
void serviceStart(struct Service *service);
|
||||
void serviceStop(struct Service *service);
|
||||
void serviceRestart(struct Service *service);
|
||||
void serviceSignal(struct Service *service, int signal);
|
||||
|
||||
extern char configError[];
|
||||
int configParse(const char *path);
|
||||
|
29
service.c
29
service.c
@ -19,6 +19,8 @@
|
||||
#include <fcntl.h>
|
||||
#include <limits.h>
|
||||
#include <paths.h>
|
||||
#include <signal.h>
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
@ -108,7 +110,7 @@ err:
|
||||
}
|
||||
|
||||
void serviceStart(struct Service *service) {
|
||||
if (service->state == Start) return;
|
||||
if (service->state != Stop) return;
|
||||
|
||||
if (service->intent == Start) {
|
||||
struct timespec backoff = service->restartInterval;
|
||||
@ -164,3 +166,28 @@ void serviceStart(struct Service *service) {
|
||||
);
|
||||
err(StopExit, "%s", _PATH_BSHELL);
|
||||
}
|
||||
|
||||
void serviceSignal(struct Service *service, int signal) {
|
||||
if (service->state != Start) return;
|
||||
int error = kill(service->pid, signal);
|
||||
if (error) {
|
||||
syslog(
|
||||
LOG_ERR, "signal %s %s[%ju]: %m",
|
||||
sys_signame[signal], service->name, (uintmax_t)service->pid
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
void serviceStop(struct Service *service) {
|
||||
service->intent = Stop;
|
||||
serviceSignal(service, SIGTERM);
|
||||
}
|
||||
|
||||
void serviceRestart(struct Service *service) {
|
||||
if (service->state == Start) {
|
||||
service->intent = Restart;
|
||||
serviceSignal(service, SIGTERM);
|
||||
} else {
|
||||
serviceStart(service);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user