2020-04-28 01:02:55 +03:00
# 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 ) :
2020-06-25 23:14:09 +03:00
return ' Unix Settings/Scripts '
2020-04-28 01:02:55 +03:00
2020-06-25 23:14:09 +03:00
def process_group_policy ( self , deleted_gpo_list , changed_gpo_list , cdir = None ) :
2020-04-28 01:02:55 +03:00
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 :
2020-06-25 23:14:09 +03:00
reg_key = ' Software \\ Policies \\ Samba \\ Unix Settings '
sections = { ' %s \\ Daily Scripts ' % reg_key : ' /etc/cron.daily ' ,
2020-06-26 00:02:37 +03:00
' %s \\ Monthly Scripts ' % reg_key : ' /etc/cron.monthly ' ,
2020-06-26 00:23:14 +03:00
' %s \\ Weekly Scripts ' % reg_key : ' /etc/cron.weekly ' ,
2020-06-25 23:14:09 +03:00
' %s \\ Hourly Scripts ' % reg_key : ' /etc/cron.hourly ' }
2020-04-28 01:02:55 +03:00
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 :
2020-06-25 23:14:09 +03:00
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 ( ) )
2020-04-28 01:02:55 +03:00
old_val = self . gp_db . retrieve ( str ( self ) , attribute )
if not old_val :
2020-06-25 23:14:09 +03:00
with NamedTemporaryFile ( mode = " w+ " , delete = False ,
dir = cron_dir ) as f :
2020-04-28 01:02:55 +03:00
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 ( )