Merge 93c5999cb0
into d739948989
This commit is contained in:
commit
b905c2fbb2
|
@ -86,6 +86,7 @@ func init() {
|
|||
|
||||
rootCommand.AddCommand(versionCommand)
|
||||
rootCommand.AddCommand(configureCmd)
|
||||
rootCommand.AddCommand(serviceCmd)
|
||||
rootCommand.AddCommand(newDiagnosticsCommand())
|
||||
}
|
||||
|
||||
|
|
79
cmd/service_install.go
Normal file
79
cmd/service_install.go
Normal file
|
@ -0,0 +1,79 @@
|
|||
package cmd
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"os/exec"
|
||||
|
||||
"github.com/apex/log"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
var (
|
||||
serviceFile = "/etc/systemd/system/wings.service"
|
||||
serviceContent = `[Unit]
|
||||
Description=Pterodactyl Wings Daemon
|
||||
After=docker.service
|
||||
Requires=docker.service
|
||||
PartOf=docker.service
|
||||
|
||||
[Service]
|
||||
User=root
|
||||
WorkingDirectory=/etc/pterodactyl
|
||||
LimitNOFILE=4096
|
||||
PIDFile=/var/run/wings/daemon.pid
|
||||
ExecStart=/usr/local/bin/wings
|
||||
Restart=on-failure
|
||||
StartLimitInterval=180
|
||||
StartLimitBurst=30
|
||||
RestartSec=5s
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target`
|
||||
serviceCmd = &cobra.Command{
|
||||
Use: "service-install",
|
||||
Short: "Use to install wings.service automatically",
|
||||
Run: installService,
|
||||
}
|
||||
)
|
||||
|
||||
func installService(cmd *cobra.Command, args []string) {
|
||||
if _, err := os.Stat(serviceFile); err == nil {
|
||||
log.WithField("error", "service file exists").Fatal("service aready installed")
|
||||
return
|
||||
}
|
||||
|
||||
f, cf_err := os.Create(serviceFile)
|
||||
|
||||
if cf_err != nil {
|
||||
log.WithField("error", cf_err).Fatal("error while creating service file")
|
||||
return
|
||||
}
|
||||
|
||||
content := []byte(serviceContent)
|
||||
|
||||
_, wf_err := f.Write(content)
|
||||
|
||||
if wf_err != nil {
|
||||
log.WithField("error", wf_err).Fatal("error while write service file")
|
||||
return
|
||||
}
|
||||
|
||||
enable_command := exec.Command("systemctl", "enable", "--now", serviceFile)
|
||||
cmd_enable_err := enable_command.Start()
|
||||
|
||||
if cmd_enable_err != nil {
|
||||
log.WithField("error", cmd_enable_err).Fatal("error while enabling service")
|
||||
return
|
||||
}
|
||||
|
||||
daemon_reload_command := exec.Command("systemctl", "daemon-reload")
|
||||
cmd_reload_err := daemon_reload_command.Start()
|
||||
|
||||
if cmd_reload_err != nil {
|
||||
log.WithField("error", cmd_reload_err).Fatal("error while reloading daemon")
|
||||
return
|
||||
}
|
||||
|
||||
fmt.Println("service created success!")
|
||||
}
|
Loading…
Reference in New Issue
Block a user