aboutsummaryrefslogtreecommitdiff
path: root/manifests/instance.pp
blob: 31a64315fd9173d7b983efd9b27ad11cab8a6ab9 (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
define ikiwiki::instance($base_url = $domain, $ensure = 'present', $description = false,
                $adminuser = 'yourname', $adminemail = 'me@example.org', $instance = 'ikiwiki',
                $account_creation_password = false, $add_plugins = false, $disable_plugins = false,
                $protocol = 'https', $owner = $name, $group = $name, $home = "/home/$name") {

  $desc = $description ? {
    false   => $title,
    default => $description,
  }

  case $ensure {
    'present': {
      file { "/etc/ikiwiki/$name.setup":
        ensure  => present,
        content => template('ikiwiki/ikiwiki.setup.erb'),
        owner   => root,
        group   => $owner,
        mode    => 640,
        notify  => Exec["ikiwiki_refresh_${name}_${instance}"],
      }

      exec { "ikiwiki_refresh_${name}_${instance}":
        command     => "/usr/local/sbin/ikiwiki-refresh $name $instance $owner $group",
        user        => root,
        refreshonly => true,
      }

      exec { "ssh-keygen-ikiwiki-${name}_${instance}":
        command => "ssh-keygen -t rsa -P '' -f ${home}/.ssh/id_rsa",
        creates => "${home}/.ssh/id_rsa",
        user    => $owner,
        group   => $group,
        require => File["${home}/.ssh"],
      }

      if !defined(File["${ikiwiki::sites_folder}/${name}/${instance}_src"]) {
        file { "${ikiwiki::sites_folder}/${name}/${instance}_src":
          ensure  => directory,
          owner   => $owner,
          group   => $group,
          recurse => true,
          notify  => Exec["ikiwiki_refresh_${name}_${instance}"],
          require => File["${ikiwiki::sites_folder}/${name}"],
        }
      }

      if !defined(File["${ikiwiki::sites_folder}/${name}/${instance}"]) {
        file { "${ikiwiki::sites_folder}/${name}/${instance}":
          ensure  => directory,
          owner   => $owner,
          group   => $group,
          recurse => true,
          require => File["${ikiwiki::sites_folder}/${name}"],
        }
      }

      if !defined(File["${home}/.ssh"]) {
        file { "${home}/.ssh":
          ensure  => directory,
          owner   => $owner,
          group   => $group,
          mode    => 0700,
        }
      }

      if !defined(File["${ikiwiki::sites_folder}/${name}"]) {
        file { "${ikiwiki::sites_folder}/${name}":
          ensure  => directory,
          owner   => root,
          group   => root,
        }
      }

      # See http://rtime.felk.cvut.cz/~sojka/blog/using-ikiwiki-with-gitolite/
      file { "/var/git/repositories/${name}.git/hooks/post-update":
        ensure  => present,
        owner   => $owner,
        group   => $ikiwiki::git_implementation,
        mode    => 6550,
        require => File["/etc/ikiwiki/$name.setup"],
      }

      file { "${ikiwiki::sites_folder}/${name}/${instance}/ikiwiki.cgi":
        ensure  => present,
        owner   => $owner,
        group   => $group,
        mode    => 0550,
        require => File["/etc/ikiwiki/$name.setup"],
      }
    }
    'absent': {
      file { "/etc/ikiwiki/$name.setup":
        ensure  => absent,
      }
    }
  }
}