aboutsummaryrefslogtreecommitdiff
path: root/manifests/labelmount.pp
blob: 6b1f77231f4b4d936be53404fd615ffb0772c2e4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# Mount a labelled partition on a directory as part of a backupninja run.
#
# This type will automatically create an unmount action with an order of 99
# for the destination directory you specify here.
#
# Valid attributes for this type are:
#
#   order: The prefix to give to the handler config filename, to set
#      order in which the actions are executed during the backup run.  Note
#      that the value given here should be less than any action which
#      requires the filesystem to be mounted!
#
#   ensure: Allows you to delete an entry if you don't want it any more
#      (but be sure to keep the configdir, name, and order the same, so
#      that we can find the correct file to remove).
#
#   label: The partition label to mount.
#
#   dest: The directory to mount the partition onto.
# 
define backupninja::labelmount($order = 10,
                               $ensure = present,
                               $label,
                               $dest
                              ) {
	include backupninja::client::defaults
	file { "${backupninja::client::defaults::configdir}/${order}_${name}.labelmount":
		ensure => $ensure,
		content => template('backupninja/labelmount.conf.erb'),
		owner => root,
		group => root,
		mode => 0600,
		require => File["${backupninja::client::defaults::configdir}"]
	}

	file { "${backupninja::client::defaults::configdir}/99_${name}.umount":
		ensure => $ensure,
		content => template('backupninja/umount.conf.erb'),
		owner => root,
		group => root,
		mode => 0600,
		require => File["${backupninja::client::defaults::configdir}"]
	}
	
	# Copy over the handler scripts themselves, since they're not in the
	# standard distribution, and are unlikely to end up there any time
	# soon because backupninja's "build" system is balls.
	file { "/usr/share/backupninja/labelmount":
		content => template('backupninja/labelmount.handler'),
		owner => root,
		group => root,
		mode => 0755,
		require => Package[backupninja]
	}

	file { "/usr/share/backupninja/umount":
		content => template('backupninja/umount.handler'),
		owner => root,
		group => root,
		mode => 0755,
		require => Package[backupninja]
	}
}