aboutsummaryrefslogtreecommitdiffstats
path: root/modules/libvirtd/manifests/init.pp
blob: 6335901644a0a0d8773d3f2c1e67f54b2ae501b5 (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
class libvirtd {
    class base {
        import "download.rb"
        # make sure to use a recent enough version
        # dnsmasq-base -> for nat network
        # netcat-openbsd -> for ssh remote access
        # iptables -> for dhcp, message error was quite puzzling
        package { ["libvirt-utils","dnsmasq-base","netcat-openbsd","iptables"]:
        }

        service { libvirtd:
            ensure => running,
            path => "/etc/init.d/libvirtd",
        }

        #TODO remove once libvirt package is fixed to manage the directory
        file { "/etc/libvirt/storage":
            ensure => directory,
        }

        file { "/etc/libvirt/storage/autostart":
            ensure => directory,
        }
        
        file { "/usr/local/bin/storage_add.py":
            ensure => present,
            owner => root,
            group => root,
            mode => 755,
            source => "puppet:///modules/libvirtd/storage_add.py", 
        }
    }

    class kvm inherits base {
        # pull cyrus-sasl, should be checked
        package { "qemu":

        }
    
    }

    # see http://wiki.libvirt.org/page/SSHPolicyKitSetup
    define group_access() {
        # to pull polkit and create the directory
        include libvirtd::base
        file { "/etc/polkit-1/localauthority/50-local.d/50-$name-libvirt-remote-access.pkla":
            owner => root,
            group => root,
            mode => 644,
            ensure => present,
            content => template("libvirtd/50-template-libvirt-remote-access.pkla"),
        }
    }

    define storage($path, $autostart = true) {
        include libvirtd::base

        exec { "/usr/local/bin/storage_add.py $name $path":
            creates => "/etc/libvirt/storage/$name.xml",
            require => File['/usr/local/bin/storage_add.py'],
        }

        file { "/etc/libvirt/storage/autostart/$name.xml":
            ensure => $autostart ? {
                            true => "/etc/libvirt/storage/$name.xml",
                            false => "absent"
                      }
        }
    }
}