Puppet Class: alkivi_backup::server

Defined in:
manifests/server.pp

Overview

Parameters:

  • customers (Any) (defaults to: {})
  • extra (Any) (defaults to: {})


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
64
65
66
67
68
69
70
71
72
# File 'manifests/server.pp', line 1

class alkivi_backup::server (
  $customers = {},
  $extra     = {},
) {
  validate_hash($customers)
  validate_hash($extra)

  $customers.each |$name, $dataHash| {
    if($dataHash['remote_backup'])
    {
      validate_string($dataHash['local_user'])

      user { $dataHash['local_user']:
        ensure => present,
        home   => "/home/alkivi-backup/$name",
      }

      file { "/home/alkivi-backup/$name":
        ensure => directory,
        owner  => $dataHash['local_user'],
        group  => $dataHash['local_user'],
        mode   => '0770',
      }

      file { "/home/alkivi-backup/$name/.ssh":
        ensure  => directory,
        owner   => $dataHash['local_user'],
        group   => $dataHash['local_user'],
        mode    => '0700',
        require => File["/home/alkivi-backup/$name"],
      }

      file { "/home/alkivi-backup/$name/.ssh/authorized_keys":
        ensure  => present,
        owner   => $dataHash['local_user'],
        group   => $dataHash['local_user'],
        mode    => '0644',
        require => File["/home/alkivi-backup/$name/.ssh"],
      }
    }
  }

  $extra.each |$name, $login| {
    user { $login:
      ensure => present,
      home   => "/home/alkivi-backup/$name",
    }

    file { "/home/alkivi-backup/$name":
      ensure => directory,
      owner  => $login,
      group  => $login,
      mode   => '0770',
    }

    file { "/home/alkivi-backup/$name/.ssh":
      ensure  => directory,
      owner   => $login,
      group   => $login,
      mode    => '0700',
      require => File["/home/alkivi-backup/$name"],
    }

    file { "/home/alkivi-backup/$name/.ssh/authorized_keys":
      ensure  => present,
      owner   => $login,
      group   => $login,
      mode    => '0644',
      require => File["/home/alkivi-backup/$name/.ssh"],
    }
  }
}