diff options
author | David Mulder <dmulder@suse.com> | 2020-06-25 14:14:09 -0600 |
---|---|---|
committer | David Mulder <dmulder@samba.org> | 2020-08-06 16:38:35 +0000 |
commit | 42f043ab5154e4c53a6b940c764ccade688ff439 (patch) | |
tree | f83183b0270266a28b52a962a83d97b48907776c | |
parent | ae56a07ae703ce7315edc27f600f184ff584903c (diff) | |
download | samba-42f043ab5154e4c53a6b940c764ccade688ff439.tar.gz |
gpo: Apply Group Policy Hourly Scripts
Signed-off-by: David Mulder <dmulder@suse.com>
Reviewed-by: Douglas Bagnall <douglas.bagnall@catalyst.net.nz>
-rwxr-xr-x | libgpo/admx/en-US/samba.adml | 5 | ||||
-rwxr-xr-x | libgpo/admx/samba.admx | 7 | ||||
-rw-r--r-- | python/samba/gp_scripts_ext.py | 17 | ||||
-rw-r--r-- | selftest/knownfail.d/gpo | 1 |
4 files changed, 23 insertions, 7 deletions
diff --git a/libgpo/admx/en-US/samba.adml b/libgpo/admx/en-US/samba.adml index b5fc5098638..55dae86199d 100755 --- a/libgpo/admx/en-US/samba.adml +++ b/libgpo/admx/en-US/samba.adml @@ -8,12 +8,17 @@ <string id="CAT_3338C1DD_8A00_4273_8547_158D8B8C19E9">Samba</string>
<string id="CAT_7D8D7DC8_5A9D_4BE1_8227_F09CDD5AFFC6">Unix Settings</string>
<string id="POL_9320E11F_AC80_4A7D_A5C8_1C0F3F727061">Daily Scripts</string>
+ <string id="POL_825D441F_905E_4C7E_9E4B_03013697C6C1">Hourly Scripts</string>
<string id="POL_9320E11F_AC80_4A7D_A5C8_1C0F3F727061_Help">This policy setting allows you to execute commands, either local or on remote storage, daily.</string>
+ <string id="POL_825D441F_905E_4C7E_9E4B_03013697C6C1_Help">This policy setting allows you to execute commands, either local or on remote storage, hourly.</string>
</stringTable>
<presentationTable>
<presentation id="POL_9320E11F_AC80_4A7D_A5C8_1C0F3F727061">
<listBox refId="LST_2E9A4684_3C0E_415B_8FD6_D4AF68BC8AC6">Script and arguments</listBox>
</presentation>
+ <presentation id="POL_825D441F_905E_4C7E_9E4B_03013697C6C1">
+ <listBox refId="LST_1AA93D59_6372_4F1E_90BB_D4CBBBB77238">Script and arguments</listBox>
+ </presentation>
</presentationTable>
</resources>
</policyDefinitionResources>
diff --git a/libgpo/admx/samba.admx b/libgpo/admx/samba.admx index f2921ff1885..1a67bddf809 100755 --- a/libgpo/admx/samba.admx +++ b/libgpo/admx/samba.admx @@ -19,5 +19,12 @@ <list id="LST_2E9A4684_3C0E_415B_8FD6_D4AF68BC8AC6" key="Software\Policies\Samba\Unix Settings\Daily Scripts" valueName="Daily Scripts" />
</elements>
</policy>
+ <policy name="POL_825D441F_905E_4C7E_9E4B_03013697C6C1" class="Machine" displayName="$(string.POL_825D441F_905E_4C7E_9E4B_03013697C6C1)" explainText="$(string.POL_825D441F_905E_4C7E_9E4B_03013697C6C1_Help)" presentation="$(presentation.POL_825D441F_905E_4C7E_9E4B_03013697C6C1)" key="Software\Policies\Samba\Unix Settings">
+ <parentCategory ref="CAT_7D8D7DC8_5A9D_4BE1_8227_F09CDD5AFFC6" />
+ <supportedOn ref="windows:SUPPORTED_WindowsVista" />
+ <elements>
+ <list id="LST_1AA93D59_6372_4F1E_90BB_D4CBBBB77238" key="Software\Policies\Samba\Unix Settings\Hourly Scripts" valueName="Hourly Scripts" />
+ </elements>
+ </policy>
</policies>
</policyDefinitions>
diff --git a/python/samba/gp_scripts_ext.py b/python/samba/gp_scripts_ext.py index f83f367a5d7..93a5ef778cb 100644 --- a/python/samba/gp_scripts_ext.py +++ b/python/samba/gp_scripts_ext.py @@ -21,9 +21,9 @@ from tempfile import NamedTemporaryFile class gp_scripts_ext(gp_pol_ext): def __str__(self): - return 'Unix Settings/Daily Scripts' + return 'Unix Settings/Scripts' - def process_group_policy(self, deleted_gpo_list, changed_gpo_list, cdir='/etc/cron.daily'): + def process_group_policy(self, deleted_gpo_list, changed_gpo_list, cdir=None): for gpo in deleted_gpo_list: self.gp_db.set_guid(gpo[0]) if str(self) in gpo[1]: @@ -34,7 +34,9 @@ class gp_scripts_ext(gp_pol_ext): for gpo in changed_gpo_list: if gpo.file_sys_path: - section_name = 'Software\\Policies\\Samba\\Unix Settings\\Daily Scripts' + reg_key = 'Software\\Policies\\Samba\\Unix Settings' + sections = { '%s\\Daily Scripts' % reg_key : '/etc/cron.daily', + '%s\\Hourly Scripts' % reg_key : '/etc/cron.hourly' } self.gp_db.set_guid(gpo.name) pol_file = 'MACHINE/Registry.pol' path = os.path.join(gpo.file_sys_path, pol_file) @@ -42,11 +44,14 @@ class gp_scripts_ext(gp_pol_ext): if not pol_conf: continue for e in pol_conf.entries: - if e.keyname == section_name and e.data.strip(): - attribute = b64encode(e.data.encode()).decode() + if e.keyname in sections.keys() and e.data.strip(): + cron_dir = sections[e.keyname] if not cdir else cdir + attribute = '%s:%s' % (e.keyname, + b64encode(e.data.encode()).decode()) old_val = self.gp_db.retrieve(str(self), attribute) if not old_val: - with NamedTemporaryFile(mode="w+", delete=False, dir=cdir) as f: + with NamedTemporaryFile(mode="w+", delete=False, + dir=cron_dir) as f: f.write('#!/bin/sh\n%s' % e.data) os.chmod(f.name, 0o700) self.gp_db.store(str(self), attribute, f.name) diff --git a/selftest/knownfail.d/gpo b/selftest/knownfail.d/gpo deleted file mode 100644 index 27f3459db8b..00000000000 --- a/selftest/knownfail.d/gpo +++ /dev/null @@ -1 +0,0 @@ -^samba.tests.gpo.samba.tests.gpo.GPOTests.test_gp_scripts |