mirror of
https://github.com/slackhq/nebula.git
synced 2026-05-16 12:57:38 +02:00
Some checks failed
smoke-extra / Run windows smoke test (push) Waiting to run
Build and test / Build and test on macos-latest (push) Waiting to run
Build and test / Build and test on windows-latest (push) Waiting to run
gofmt / Run gofmt (push) Successful in 11s
smoke-extra / freebsd-amd64 (push) Failing after 13s
smoke-extra / linux-amd64-ipv6disable (push) Failing after 12s
smoke-extra / netbsd-amd64 (push) Failing after 14s
smoke-extra / openbsd-amd64 (push) Failing after 12s
smoke-extra / linux-386 (push) Failing after 12s
smoke / Run multi node smoke test (push) Failing after 1m27s
Build and test / Build all and test on ubuntu-linux (push) Failing after 20m14s
Build and test / Build and test on linux with boringcrypto (push) Failing after 5m14s
Build and test / Build and test on linux with pkcs11 (push) Failing after 3m12s
120 lines
2.8 KiB
Go
120 lines
2.8 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/kardianos/service"
|
|
"github.com/slackhq/nebula"
|
|
"github.com/slackhq/nebula/config"
|
|
"github.com/slackhq/nebula/logging"
|
|
)
|
|
|
|
var logger service.Logger
|
|
|
|
type program struct {
|
|
configPath *string
|
|
configTest *bool
|
|
build string
|
|
control *nebula.Control
|
|
}
|
|
|
|
func (p *program) Start(s service.Service) error {
|
|
// Start should not block.
|
|
logger.Info("Nebula service starting.")
|
|
|
|
l := newPlatformLogger()
|
|
|
|
c := config.NewC(l)
|
|
err := c.Load(*p.configPath)
|
|
if err != nil {
|
|
return fmt.Errorf("failed to load config: %s", err)
|
|
}
|
|
|
|
if err := logging.ApplyConfig(l, c); err != nil {
|
|
return fmt.Errorf("failed to apply logging config: %s", err)
|
|
}
|
|
c.RegisterReloadCallback(func(c *config.C) {
|
|
if err := logging.ApplyConfig(l, c); err != nil {
|
|
l.Error("Failed to reconfigure logger on reload", "error", err)
|
|
}
|
|
})
|
|
|
|
p.control, err = nebula.Main(c, *p.configTest, Build, l, nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
p.control.Start()
|
|
return nil
|
|
}
|
|
|
|
func (p *program) Stop(s service.Service) error {
|
|
logger.Info("Nebula service stopping.")
|
|
p.control.Stop()
|
|
return nil
|
|
}
|
|
|
|
func doService(configPath *string, configTest *bool, build string, serviceFlag *string) error {
|
|
if *configPath == "" {
|
|
p, err := config.DefaultPath()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
*configPath = p
|
|
}
|
|
|
|
svcConfig := &service.Config{
|
|
Name: "Nebula",
|
|
DisplayName: "Nebula Network Service",
|
|
Description: "Nebula network connectivity daemon for encrypted communications",
|
|
Arguments: []string{"-service", "run", "-config", *configPath},
|
|
}
|
|
|
|
prg := &program{
|
|
configPath: configPath,
|
|
configTest: configTest,
|
|
build: build,
|
|
}
|
|
|
|
// Here are what the different loggers are doing:
|
|
// - `log` is the standard go log utility, meant to be used while the process is still attached to stdout/stderr
|
|
// - `logger` is the service log utility that may be attached to a special place depending on OS (Windows will have it attached to the event log)
|
|
// - in program.Start we build a *slog.Logger via newPlatformLogger; on non-Windows that is a stdout-backed slog logger, on Windows it routes records through the service logger
|
|
s, err := service.New(prg, svcConfig)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
errs := make(chan error, 5)
|
|
logger, err = s.Logger(errs)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
go func() {
|
|
for {
|
|
err := <-errs
|
|
if err != nil {
|
|
// Route any errors from the system logger to stdout as a best effort to notice issues there
|
|
log.Print(err)
|
|
}
|
|
}
|
|
}()
|
|
|
|
switch *serviceFlag {
|
|
case "run":
|
|
if err := s.Run(); err != nil {
|
|
// Route any errors to the system logger
|
|
logger.Error(err)
|
|
}
|
|
default:
|
|
if err := service.Control(s, *serviceFlag); err != nil {
|
|
log.Printf("Valid actions: %q\n", service.ControlAction)
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|