summaryrefslogtreecommitdiff
path: root/manifests/mysql.pp
blob: 8e33e8edf0fb766995127fd646b65f7a61bc94f6 (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
# Safe MySQL dumps, as part of a backupninja run.
#
# 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.
#
#   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).
#
#   user, dbusername, dbpassword, dbhost, databases, backupdir,
#   hotcopy, sqldump, compress, configfile: As defined in the
#   backupninja documentation, with the caveat that hotcopy, sqldump,
#   and compress take true/false rather than yes/no.
# 
define backupninja::mysql(
  $order = 10, $ensure = present, $user = false, $dbusername = false, $dbpassword = false,
  $dbhost = 'localhost', $databases = 'all', $backupdir = false, $hotcopy = false,
  $sqldump = false, $compress = false, $configfile = true,
  $vsname = false, $sqldumpoptions = '--lock-tables --complete-insert --add-drop-table --quick --quote-names',
  $nodata = false)
{
  
  $real_configfile = $configfile ? {
    true => "/etc/mysql/debian.cnf",
    default => $configfile,
  }

  include backupninja::client::defaults
  file { "${backupninja::client::defaults::configdir}/${order}_${name}.mysql":
    ensure => $ensure,
    content => template('backupninja/mysql.conf.erb'),
    owner => root,
    group => root,
    mode => 0600,
    require => File["${backupninja::client::defaults::configdir}"]
  }
}