Skip to content

Commit

Permalink
Support reload of instances of systemd --user
Browse files Browse the repository at this point in the history
This change increased the minimum required Puppet version to 6.24.0 or 7.9.0 [PUP-5704](https://puppet.atlassian.net/browse/PUP-5704) to support arrays to the command attribute of the exec type.

Support the calling the `systemd --user daemon-reload` for a particular user.

Example run:
```puppet
  notify{'junk':
    notify => Systemd::Daemon_reload['user_foobar'],
  }

  systemd::daemon_reload{'user_steve':
    user => 'steve',
  }
```

This results on a Fedora box:

```
Notice: /Stage[main]/Main/Notify[junk]/message: defined 'message' as 'junk'
Notice: /Stage[main]/Main/Systemd::Daemon_reload[user_steve]/Package[systemd-container]: Triggered 'refresh' from 1 event
Notice: /Stage[main]/Main/Systemd::Daemon_reload[user_steve]/Exec[systemd-user_steve-systemctl-user-steve-daemon-reload]: Triggered 'refresh' from 1 event
```
and a journal (debug on) for [email protected] of

```
Mar 29 10:32:11 fedora systemd[2062]: Created slice background.slice - User Background Tasks Slice.
Mar 29 10:32:11 fedora systemd[2062]: Starting systemd-tmpfiles-clean.service - Cleanup of User's Temporary Files and Directories...
Mar 29 10:32:11 fedora systemd[2062]: Reloading requested from client PID 4379 ('systemctl')...
Mar 29 10:32:11 fedora systemd[2062]: Reloading...
Mar 29 10:32:11 fedora systemd[2062]: Reloading finished in 179 ms.
Mar 29 10:32:11 fedora systemd[2062]: Finished systemd-tmpfiles-clean.service - Cleanup of User's Temporary Files and Directories.
...

Only recent versions of `machinectl` support the shell or actually manage to connect to DBUS.
  • Loading branch information
traylenator committed Mar 29, 2024
1 parent e48766d commit 64250bb
Show file tree
Hide file tree
Showing 4 changed files with 145 additions and 6 deletions.
33 changes: 32 additions & 1 deletion REFERENCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -677,12 +677,35 @@ Default value: `['create']`

Run systemctl daemon-reload

#### Examples

##### Force reload the system systemd

```puppet
notify{ 'fake event to notify from':
notify => Systemd::Daemon_reload['special']
}
systemd::daemon_reload{ 'special': }
```

##### Force reload a systemd --user

```puppet
notify{ 'fake event to notify from':
notify => Systemd::Daemon_reload['steve_user']
}
systemd::daemon_reload{ 'steve_user':
user => 'steve',
}
```

#### Parameters

The following parameters are available in the `systemd::daemon_reload` defined type:

* [`name`](#-systemd--daemon_reload--name)
* [`enable`](#-systemd--daemon_reload--enable)
* [`user`](#-systemd--daemon_reload--user)

##### <a name="-systemd--daemon_reload--name"></a>`name`

Expand All @@ -693,11 +716,19 @@ A globally unique name for the resource
Data type: `Boolean`

Enable the reload exec

* Added in case users want to disable the reload globally using a resource collector

Default value: `true`

##### <a name="-systemd--daemon_reload--user"></a>`user`

Data type: `Optional[String[1]]`

Specify user name of `systemd --user` to reload. This not supported **below** Redhat 9,
Ubuntu 22.04 or Debian 12.

Default value: `undef`

### <a name="systemd--dropin_file"></a>`systemd::dropin_file`

Creates a drop-in file for a systemd unit
Expand Down
47 changes: 44 additions & 3 deletions manifests/daemon_reload.pp
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,56 @@
#
# @param enable
# Enable the reload exec
#
# * Added in case users want to disable the reload globally using a resource collector
#
# @param user
# Specify user name of `systemd --user` to reload. This not supported **below** Redhat 9,
# Ubuntu 22.04 or Debian 12.
#
# @example Force reload the system systemd
# notify{ 'fake event to notify from':
# notify => Systemd::Daemon_reload['special']
# }
# systemd::daemon_reload{ 'special': }
#
# @example Force reload a systemd --user
# notify{ 'fake event to notify from':
# notify => Systemd::Daemon_reload['steve_user']
# }
# systemd::daemon_reload{ 'steve_user':
# user => 'steve',
# }
#
define systemd::daemon_reload (
Boolean $enable = true,
Optional[String[1]] $user = undef,
) {
include systemd

if $enable {
exec { "${module_name}-${name}-systemctl-daemon-reload":
command => 'systemctl daemon-reload',
if $user {
if ($facts['os']['family'] == 'RedHat' and versioncmp($facts['os']['release']['major'],'9') < 0 ) or
($facts['os']['name'] == 'Debian' and versioncmp($facts['os']['release']['major'],'12') < 0 ) or
($facts['os']['name'] == 'Ubuntu' and versioncmp($facts['os']['release']['major'],'22.04') < 0 ) {
fail('systemd::daemon_reload_for a user is not supported below RedHat 9, Debian 12 or Ubuntu 22.04')
}

$_title = "${module_name}-${name}-systemctl-user-${user}-daemon-reload"
# Must use full path to systemctl here.
$_command = ['machinectl', 'shell' , "${user}@.host", '/usr/bin/systemctl', '--user', 'daemon-reload']

if $systemd::nspawn_package and ! $systemd::manage_nspawn {
fail('The manage_nspawn main class parameter must be true to provide the machinectl command')
} elsif $systemd::nspawn_package and $systemd::manage_nspawn {
Package[$systemd::nspawn_package] -> Exec[$_title]
}
} else {
$_title = "${module_name}-${name}-systemctl-daemon-reload"
$_command = ['systemctl', 'daemon-reload']
}

exec { $_title:
command => $_command,
refreshonly => true,
path => $facts['path'],
}
Expand Down
2 changes: 1 addition & 1 deletion metadata.json
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,7 @@
"requirements": [
{
"name": "puppet",
"version_requirement": ">= 7.0.0 < 9.0.0"
"version_requirement": ">= 7.9.0 < 9.0.0"
}
]
}
69 changes: 68 additions & 1 deletion spec/defines/daemon_reload_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,68 @@
context 'with defaults' do
it do
expect(subject).to contain_exec("systemd-#{title}-systemctl-daemon-reload").
with_command('systemctl daemon-reload').
with_command(%w[systemctl daemon-reload]).
with_refreshonly(true)
end

context 'with a username specfied' do
let(:params) do
{ user: 'steve' }
end

case [facts[:os]['name'], facts[:os]['family'], facts[:os]['release']['major']]
when %w[Debian Debian 10],
%w[Debian Debian 11],
['Ubuntu', 'Debian', '20.04'],
%w[VirtuozzoLinux RedHat 7],
%w[AlmaLinux RedHat 8],
%w[CentOS RedHat 7],
%w[CentOS RedHat 8],
%w[RedHat RedHat 7],
%w[RedHat RedHat 8],
%w[Rocky RedHat 8],
%w[OracleLinux RedHat 8]
it { is_expected.to compile.and_raise_error(%r{user is not supported below}) }
else
case facts[:os]['family']
when 'RedHat'
case facts[:os]['release']['major']
when '7'
it { is_expected.to compile }
else
it { is_expected.to compile.and_raise_error(%r{manage_nspawn main class parameter must be true}) }
end
end
end

context 'with manage_nspawn true on main class' do
let(:pre_condition) { 'class{"systemd": manage_nspawn => true}' }

case [facts[:os]['name'], facts[:os]['family'], facts[:os]['release']['major']]
when %w[Debian Debian 10],
%w[Debian Debian 11],
['Ubuntu', 'Debian', '20.04'],
%w[VirtuozzoLinux RedHat 7],
%w[AlmaLinux RedHat 8],
%w[CentOS RedHat 7],
%w[CentOS RedHat 8],
%w[RedHat RedHat 7],
%w[RedHat RedHat 8],
%w[Rocky RedHat 8],
%w[OracleLinux RedHat 8]
it { is_expected.to compile.and_raise_error(%r{user is not supported below}) }
else
it { is_expected.to compile }

it {
is_expected.to contain_exec('systemd-irregardless-systemctl-user-steve-daemon-reload').
with_command(['machinectl', 'shell', '[email protected]', '/usr/bin/systemctl', '--user', 'daemon-reload']).
with_refreshonly(true)
}

end
end
end
end

context 'when disabled' do
Expand All @@ -27,6 +86,14 @@
it do
expect(subject).not_to contain_exec("systemd-#{title}-systemctl-daemon-reload")
end

context 'with a username specfied' do
let(:params) do
super().merge(user: 'steve')
end

it { is_expected.not_to contain_exec('systemd-irregardless-systemctl-user-steve-daemon-reload') }
end
end
end
end
Expand Down

0 comments on commit 64250bb

Please sign in to comment.