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"],
}
}
}
|