diff --git a/config/config.go b/config/config.go index 4d0cafd75..a13cd265b 100644 --- a/config/config.go +++ b/config/config.go @@ -35,6 +35,7 @@ type Config struct { DisableWatches bool VerifyUnits bool UnitsDirectory string + SystemdUser bool AuthorizedKeysFile string } diff --git a/fleetd/fleetd.go b/fleetd/fleetd.go index 0ea8dbfcb..0d703e01b 100644 --- a/fleetd/fleetd.go +++ b/fleetd/fleetd.go @@ -87,6 +87,7 @@ func main() { cfgset.String("metadata", "", "List of key-value metadata to assign to the fleet machine") cfgset.String("agent_ttl", agent.DefaultTTL, "TTL in seconds of fleet machine state in etcd") cfgset.String("units_directory", "/run/fleet/units/", "Path to the fleet units directory") + cfgset.Bool("systemd_user", false, "When true use systemd --user)") cfgset.Int("token_limit", 100, "Maximum number of entries per page returned from API requests") cfgset.Bool("disable_engine", false, "Disable the engine entirely, use with care") cfgset.Bool("disable_watches", false, "Disable the use of etcd watches. Increases scheduling latency") @@ -227,6 +228,7 @@ func getConfig(flagset *flag.FlagSet, userCfgFile string) (*config.Config, error DisableWatches: (*flagset.Lookup("disable_watches")).Value.(flag.Getter).Get().(bool), VerifyUnits: (*flagset.Lookup("verify_units")).Value.(flag.Getter).Get().(bool), UnitsDirectory: (*flagset.Lookup("units_directory")).Value.(flag.Getter).Get().(string), + SystemdUser: (*flagset.Lookup("systemd_user")).Value.(flag.Getter).Get().(bool), TokenLimit: (*flagset.Lookup("token_limit")).Value.(flag.Getter).Get().(int), AuthorizedKeysFile: (*flagset.Lookup("authorized_keys_file")).Value.(flag.Getter).Get().(string), } diff --git a/server/server.go b/server/server.go index 36d4ec7b7..bf1c49f04 100644 --- a/server/server.go +++ b/server/server.go @@ -75,7 +75,7 @@ func New(cfg config.Config, listeners []net.Listener) (*Server, error) { return nil, err } - mgr, err := systemd.NewSystemdUnitManager(cfg.UnitsDirectory) + mgr, err := systemd.NewSystemdUnitManager(cfg.UnitsDirectory, cfg.SystemdUser) if err != nil { return nil, err } diff --git a/systemd/manager.go b/systemd/manager.go index b37d3aaf2..4c8aa1561 100644 --- a/systemd/manager.go +++ b/systemd/manager.go @@ -36,8 +36,8 @@ type systemdUnitManager struct { mutex sync.RWMutex } -func NewSystemdUnitManager(uDir string) (*systemdUnitManager, error) { - systemd, err := dbus.New() +func NewSystemdUnitManager(uDir string, systemdUser bool) (*systemdUnitManager, error) { + systemd, err := createDbusConnection(systemdUser) if err != nil { return nil, err } @@ -60,6 +60,13 @@ func NewSystemdUnitManager(uDir string) (*systemdUnitManager, error) { return &mgr, nil } +func createDbusConnection(systemdUser bool) (*dbus.Conn, error) { + if systemdUser { + return dbus.NewUserConnection() + } + return dbus.New() +} + func hashUnitFiles(dir string) (map[string]unit.Hash, error) { uNames, err := lsUnitsDir(dir) if err != nil {