summaryrefslogtreecommitdiff
path: root/samba
diff options
context:
space:
mode:
authorJonas Smedegaard <dr@jones.dk>2002-02-14 12:46:17 +0000
committerJonas Smedegaard <dr@jones.dk>2002-02-14 12:46:17 +0000
commit61a481bd77ff9e7d52ce7545990d142729824324 (patch)
tree4593c90f3b214b2712ec1ba6b0c432a061b9628d /samba
parent7afe4d91f97e938499cace610671dc91f81d436f (diff)
cfengine: split jones and spiff groups into separat ones.
samba: Add cafe3 config.
Diffstat (limited to 'samba')
-rw-r--r--samba/smb-shares-cafe3.conf167
1 files changed, 167 insertions, 0 deletions
diff --git a/samba/smb-shares-cafe3.conf b/samba/smb-shares-cafe3.conf
new file mode 100644
index 0000000..f69d829
--- /dev/null
+++ b/samba/smb-shares-cafe3.conf
@@ -0,0 +1,167 @@
+control:
+ AddInstallable = ( samba samba_reload )
+
+ #
+ # Variables for shares
+ # You can change the paths here and it will be changed both in
+ # the conf file and in the filesystem - But once it is implemented,
+ # it is not wise to change it - the data in the shares doesn't get
+ # moved!
+ # You can change the rights on the shares in the "directories:"
+ # section.
+ #
+ netlogshare = ( /etc/samba/netlogon )
+ commonsharedir = ( /home/fsadmin )
+ datashare = ( /home/fsadmin/pc_doc )
+ softshare = ( /home/fsadmin/pc_software )
+ adminshare = ( /home/fsadmin/pc_admin )
+ profshare = ( /home/fsadmin/pc_userprofiles )
+ privpcshare = ( pc )
+ privmacshare = ( mac )
+ privxchngshare = ( xchange )
+
+ #
+ # Administrative user and group
+ #
+ adminuser = ( fsadmin )
+ admingrp = ( fsadmin )
+
+editfiles:
+ samba::
+ { /etc/samba/smb-shares-$(site).conf
+ #
+ # This file contains the shares common to a site.
+ # We check if the proper sections are there and add them if they
+ # isn't. We don't check the file line for line.
+ #
+ AutoCreate
+ #
+ # [netlogon]
+ #
+ BeginGroupIfNoLineMatching "^\[netlogon\]"
+ Append '[netlogon]'
+ Append ' comment = Network logon'
+ Append ' path = $(netlogshare)'
+ Append ' browsable = no'
+ Append ' writeable = no'
+ Append ' share modes = no'
+ EndGroup
+ #
+ # [userprofiles]
+ #
+ BeginGroupIfNoLineMatching "^\[userprofiles\]"
+ Append '[userprofiles]'
+ Append ' path = $(profshare)'
+ Append ' force user = %u'
+ Append ' browsable = yes'
+ Append ' writable = yes'
+ Append ' root preexec = /bin/mkdir $(profshare)/%U \'
+ Append ' /bin/chown %U $(profshare)/%U \'
+ Append ' /bin/chmod 700 $(profshare)/%U'
+ EndGroup
+ #
+ # [homes]
+ #
+ BeginGroupIfNoLineMatching "^\[homes\]"
+ Append '[homes]'
+ Append ' path = /home/%u/$(privpcshare)'
+ Append ' browsable = no'
+ Append ' writable = yes'
+ Append ' root preexec = /bin/mkdir /home/%u/$(privpcshare) \'
+ Append ' /bin/chown %U /home/%u/$(privpcshare) \'
+ Append ' /bin/chmod 644 /home/%u/$(privpcshare)'
+ EndGroup
+ #
+ # [programmer]
+ #
+ BeginGroupIfNoLineMatching "^\[software\]"
+ Append '[software]'
+ Append ' path = $(softshare)'
+ Append ' comment = Fælles software'
+ Append ' browsable = yes'
+ Append ' guest ok = no'
+ Append ' writeable = yes'
+ Append ' create mask = 0660'
+ Append ' directory mask = 0770'
+ Append ' valid users = @$(admingrp)'
+ Append ' force group = +$(admingrp)'
+ Append ' delete veto files = Yes'
+ Append ' veto files = /.AppleDouble/.AppleDesktop/Network Trash Folder/DesktopFolderDB/resource.frk/Icon^M/TheVolumeSettingsFolder/'
+ EndGroup
+ #
+ # [faellesdrev]
+ #
+ BeginGroupIfNoLineMatching "^\[faellesdrev\]"
+ Append '[faellesdrev]'
+ Append ' path = $(datashare)'
+ Append ' comment = Fælles drev for delte filer'
+ Append ' browsable = yes'
+ Append ' guest ok = no'
+ Append ' writeable = yes'
+ Append ' create mask = 0660'
+ Append ' directory mask = 0770'
+ Append ' valid users = @$(admingrp)'
+ Append ' force group = +$(admingrp)'
+ Append ' delete veto files = Yes'
+ Append ' veto files = /.AppleDouble/.AppleDesktop/Network Trash Folder/DesktopFolderDB/resource.frk/Icon^M/TheVolumeSettingsFolder/'
+ EndGroup
+ #
+ # [dokumenter]
+ #
+ BeginGroupIfNoLineMatching "^\[admin\]"
+ Append '[admin]'
+ Append ' path = $(adminshare)'
+ Append ' comment = Dokumentation og adminværktøjer'
+ Append ' browsable = yes'
+ Append ' guest ok = yes'
+ Append ' writeable = no'
+ Append ' valid users = @$(admingrp)'
+ Append ' force group = +$(admingrp)'
+ EndGroup
+ DefineClasses "samba_reload"
+ }
+
+ samba_reload::
+ { /etc/samba/smb-shares-$(site).conf
+ LocateLineMatching "^; EDITED BY CFENGINE .*"
+ ReplaceAll '; EDITED BY CFENGINE .*$' With '; EDITED BY CFENGINE $(date)'
+ CatchAbort
+ BeginGroupIfNoMatch "^; EDITED BY CFENGINE .*"
+ Append '; EDITED BY CFENGINE $(date)'
+ EndGroup
+ }
+
+directories:
+ any::
+ $(commonsharedir)
+ mode=755
+ owner=$(adminuser)
+ group=$(admingrp)
+ $(softshare)
+ mode=775
+ owner=$(adminuser)
+ group=$(admingrp)
+ $(datashare)
+ mode=775
+ owner=$(adminuser)
+ group=$(admingrp)
+ samba::
+ $(netlogshare)
+ mode=755
+ owner=root
+ group=root
+ $(profshare)
+ mode=775
+ owner=$(adminuser)
+ group=$(admingrp)
+ $(adminshare)
+ mode=755
+ owner=$(adminuser)
+ group=$(admingrp)
+
+processes:
+ "smbd" restart "/etc/init.d/samba restart"
+
+shellcommands:
+ samba_reload::
+ "/etc/init.d/samba force-reload"