summaryrefslogtreecommitdiff
path: root/python
diff options
context:
space:
mode:
authorDavid Mulder <dmulder@suse.com>2020-04-27 16:02:55 -0600
committerDavid Mulder <dmulder@samba.org>2020-06-23 16:32:30 +0000
commita9d1ccc5699a4e8c66012f769cec8fba6ce84a59 (patch)
tree77f61283a1c60b6d447d478dad336c28f98ac075 /python
parentcd52a280913a6536b4923da7214977c762f664ed (diff)
downloadsamba-a9d1ccc5699a4e8c66012f769cec8fba6ce84a59.tar.gz
gpo: Run Group Policy Scripts
Signed-off-by: David Mulder <dmulder@suse.com> Reviewed-by: Alexander Bokovoy <ab@samba.org>
Diffstat (limited to 'python')
-rw-r--r--python/samba/gp_scripts_ext.py53
1 files changed, 53 insertions, 0 deletions
diff --git a/python/samba/gp_scripts_ext.py b/python/samba/gp_scripts_ext.py
new file mode 100644
index 00000000000..f83f367a5d7
--- /dev/null
+++ b/python/samba/gp_scripts_ext.py
@@ -0,0 +1,53 @@
+# gp_scripts_ext samba gpo policy
+# Copyright (C) David Mulder <dmulder@suse.com> 2020
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+import os, re
+from samba.gpclass import gp_pol_ext
+from base64 import b64encode
+from tempfile import NamedTemporaryFile
+
+class gp_scripts_ext(gp_pol_ext):
+ def __str__(self):
+ return 'Unix Settings/Daily Scripts'
+
+ def process_group_policy(self, deleted_gpo_list, changed_gpo_list, cdir='/etc/cron.daily'):
+ for gpo in deleted_gpo_list:
+ self.gp_db.set_guid(gpo[0])
+ if str(self) in gpo[1]:
+ for attribute, script in gpo[1][str(self)].items():
+ os.unlink(script)
+ self.gp_db.delete(str(self), attribute)
+ self.gp_db.commit()
+
+ for gpo in changed_gpo_list:
+ if gpo.file_sys_path:
+ section_name = 'Software\\Policies\\Samba\\Unix Settings\\Daily Scripts'
+ self.gp_db.set_guid(gpo.name)
+ pol_file = 'MACHINE/Registry.pol'
+ path = os.path.join(gpo.file_sys_path, pol_file)
+ pol_conf = self.parse(path)
+ 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()
+ old_val = self.gp_db.retrieve(str(self), attribute)
+ if not old_val:
+ with NamedTemporaryFile(mode="w+", delete=False, dir=cdir) as f:
+ f.write('#!/bin/sh\n%s' % e.data)
+ os.chmod(f.name, 0o700)
+ self.gp_db.store(str(self), attribute, f.name)
+ self.gp_db.commit()