mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2025-01-07 06:27:22 +03:00
1d6d85cff4
Squashed commit of the following: commit586b0eb180
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Tue Nov 12 19:58:56 2024 +0300 next: upd more commitd729aa150f
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Tue Nov 12 16:53:15 2024 +0300 next/websvc: upd more commit0c64e6cfc6
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Mon Nov 11 21:08:51 2024 +0300 next: upd more commit05eec75222
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Fri Nov 8 19:20:02 2024 +0300 next: upd code
98 lines
2.3 KiB
Go
98 lines
2.3 KiB
Go
// Package cmd is the AdGuard Home entry point. It assembles the configuration
|
|
// file manager, sets up signal processing logic, and so on.
|
|
//
|
|
// TODO(a.garipov): Move to the upper-level internal/.
|
|
package cmd
|
|
|
|
import (
|
|
"context"
|
|
"io/fs"
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/AdguardTeam/AdGuardHome/internal/next/configmgr"
|
|
"github.com/AdguardTeam/AdGuardHome/internal/version"
|
|
"github.com/AdguardTeam/golibs/errors"
|
|
"github.com/AdguardTeam/golibs/logutil/slogutil"
|
|
"github.com/AdguardTeam/golibs/service"
|
|
)
|
|
|
|
// Main is the entry point of AdGuard Home.
|
|
func Main(embeddedFrontend fs.FS) {
|
|
ctx := context.Background()
|
|
|
|
start := time.Now()
|
|
|
|
cmdName := os.Args[0]
|
|
opts, err := parseOptions(cmdName, os.Args[1:])
|
|
exitCode, needExit := processOptions(opts, cmdName, err)
|
|
if needExit {
|
|
os.Exit(exitCode)
|
|
}
|
|
|
|
baseLogger := newBaseLogger(opts)
|
|
|
|
baseLogger.InfoContext(
|
|
ctx,
|
|
"starting adguard home",
|
|
"version", version.Version(),
|
|
"pid", os.Getpid(),
|
|
)
|
|
|
|
if opts.workDir != "" {
|
|
baseLogger.InfoContext(ctx, "changing working directory", "dir", opts.workDir)
|
|
|
|
err = os.Chdir(opts.workDir)
|
|
errors.Check(err)
|
|
}
|
|
|
|
frontend, err := frontendFromOpts(ctx, baseLogger, opts, embeddedFrontend)
|
|
errors.Check(err)
|
|
|
|
startCtx, startCancel := context.WithTimeout(ctx, defaultTimeoutStart)
|
|
defer startCancel()
|
|
|
|
confMgrConf := &configmgr.Config{
|
|
BaseLogger: baseLogger,
|
|
Logger: baseLogger.With(slogutil.KeyPrefix, "configmgr"),
|
|
Frontend: frontend,
|
|
WebAddr: opts.webAddr,
|
|
Start: start,
|
|
FileName: opts.confFile,
|
|
}
|
|
|
|
confMgr, err := configmgr.New(startCtx, confMgrConf)
|
|
errors.Check(err)
|
|
|
|
web := confMgr.Web()
|
|
err = web.Start(startCtx)
|
|
errors.Check(err)
|
|
|
|
dns := confMgr.DNS()
|
|
err = dns.Start(startCtx)
|
|
errors.Check(err)
|
|
|
|
sigHdlr := newSignalHandler(
|
|
baseLogger.With(slogutil.KeyPrefix, service.SignalHandlerPrefix),
|
|
confMgrConf,
|
|
opts.pidFile,
|
|
web,
|
|
dns,
|
|
)
|
|
|
|
os.Exit(sigHdlr.handle(ctx))
|
|
}
|
|
|
|
// Default timeouts.
|
|
//
|
|
// TODO(a.garipov): Make configurable.
|
|
const (
|
|
defaultTimeoutStart = 1 * time.Minute
|
|
defaultTimeoutShutdown = 5 * time.Second
|
|
)
|
|
|
|
// newConfigMgr returns a new configuration manager using defaultTimeout as the
|
|
// context timeout.
|
|
func newConfigMgr(ctx context.Context, c *configmgr.Config) (m *configmgr.Manager, err error) {
|
|
return configmgr.New(ctx, c)
|
|
}
|