aboutsummaryrefslogtreecommitdiff
path: root/manifests/duplicity.pp
blob: 8660bcc27d20af23b7c28f403b10574f10e2649a (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
# local backups using duplicity
define backup::duplicity(
    $encryptkey            = false,
    $password              = false,
    $order                 = 50,
    $ensure                = present,
    $full_if_older_than    = "1M",
    $remove_older_than     = "45D",
    $remove_all_but_n_full = "1",
    $periodic_check        = absent,
    $directory             = "${backup::params::backupdir}/duplicity"
) {

  case $encryptkey { false: { err("need to define a key!") } }
  case $password { false: { err("need to define password!") } }

  $exclude_unencrypted = $backup::params::exclude_unencrypted
  $include_unencrypted = $backup::params::include_unencrypted

  include backupninja

  # backup dest folder
  file { "${backup::params::backupdir}/duplicity":
    ensure  => directory,
    owner   => "root",
    group   => "root",
  }

  # the backupninja rule for this duplicity backup
  file { "${backupninja::configdir}/${order}_duplicity-${title}.sh":
    ensure  => $ensure,
    content => template('backup/duplicity.conf.erb'),
    owner   => root,
    group   => root,
    mode    => 0600,
    require => File["${backupninja::configdir}"],
  }

  # check duplicity backups once a week
  cron { "duplicity_check-$title.$domain":
    command  => "/bin/bash ${backupninja::configdir}/${order}_duplicity-${title}.sh --check",
    user     => root,
    hour     => "0",
    minute   => "0",
    weekday  => "0",
    ensure   => $periodic_check,
  }
}