91 lines
2.4 KiB
Go
91 lines
2.4 KiB
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"syscall"
|
|
|
|
"git.aliberksandikci.com.tr/Liderahenk/ahenk-go/pkg/utils"
|
|
|
|
"github.com/sevlyar/go-daemon"
|
|
"golang.org/x/exp/slices"
|
|
)
|
|
|
|
const PidFile = "/run/ahenk-go.pid"
|
|
const ExecutablePath = "/usr/bin/ahenk-go"
|
|
const DataDir = "/etc/ahenk-go/"
|
|
const LogFile = DataDir + "ahenk.log"
|
|
const LibDir = "/usr/share/ahenk-go/"
|
|
const PluginDir = LibDir + "/plugins/"
|
|
|
|
// Main Function that starts daemon and controls arguments
|
|
func main() {
|
|
if len(os.Args) == 2 && slices.Contains([]string{"start", "stop", "restart", "nodaemon", "tmptest"}, os.Args[1]) {
|
|
switch os.Args[1] {
|
|
case "start":
|
|
utils.CreatePath(DataDir)
|
|
cntxt := &daemon.Context{
|
|
PidFileName: PidFile,
|
|
PidFilePerm: 0644,
|
|
LogFileName: LogFile,
|
|
LogFilePerm: 0640,
|
|
WorkDir: LibDir,
|
|
Umask: 027,
|
|
Args: []string{ExecutablePath, "start"},
|
|
}
|
|
d, err := cntxt.Reborn()
|
|
if err != nil {
|
|
log.Fatal("Daemon Reborn ERROR:", err)
|
|
}
|
|
if d != nil {
|
|
return
|
|
}
|
|
defer cntxt.Release()
|
|
log.Println("- - - - - - - - - - - - - - - - - -")
|
|
log.Print("Daemon Succesfully Started")
|
|
case "stop":
|
|
i, _ := daemon.ReadPidFile(PidFile)
|
|
Stop(i, 15)
|
|
case "restart":
|
|
i, _ := daemon.ReadPidFile(PidFile)
|
|
Restart(i, 15)
|
|
case "nodaemon":
|
|
log.Print("STARTED AS NO-DAEMON")
|
|
|
|
f := utils.OpenLogFile(LogFile)
|
|
defer f.Close()
|
|
log.SetOutput(f)
|
|
case "tmptest":
|
|
log.Print("TEMPORARY TEST STARTED, log files are NOT redirecting!")
|
|
}
|
|
} else {
|
|
panic("Please enter a valid option !")
|
|
}
|
|
PluginManager()
|
|
// NEXT Make PluginManager async !
|
|
}
|
|
|
|
// FIXME there isn't any difference with Stop() function
|
|
// TODO There can be a Start() function in it but start function doesnt work properly right now
|
|
// Restart ahenk daemon with a specific PID (running from second copy)
|
|
func Restart(pid, signal int) {
|
|
Stop(pid, signal)
|
|
}
|
|
|
|
// Stop ahenk daemon with a specific PID (running from second copy)
|
|
func Stop(pid, signal int) {
|
|
log.Println("Stop Signal Caught")
|
|
|
|
// FILLME what you want to do before stopping daemon?
|
|
|
|
if err := syscall.Kill(pid, syscall.Signal(signal)); err == nil {
|
|
log.Printf("Ahenk Daemon with pid number %v Successfully stopped", pid)
|
|
f := utils.OpenLogFile(LogFile)
|
|
defer f.Close()
|
|
log.SetOutput(f)
|
|
log.Printf("Ahenk Daemon with pid number %v Successfully stopped", pid)
|
|
} else {
|
|
log.Fatal(err)
|
|
}
|
|
os.Exit(0)
|
|
}
|