aboutsummaryrefslogtreecommitdiff
path: root/manifests/openvpn.pp
diff options
context:
space:
mode:
authorPietro Ferrari <pietro@riseup.net>2008-11-11 00:16:41 +0000
committerPietro Ferrari <pietro@riseup.net>2008-11-11 00:16:41 +0000
commitb43b2a2d5b0c424f3fce801f9158af60df20978a (patch)
treeb1e48d613ee0d76a686a83c2ccdec4f769060c89 /manifests/openvpn.pp
parent0a4679409748b22f464526ec2c4aad1771c80b80 (diff)
downloadpuppet-virtual-b43b2a2d5b0c424f3fce801f9158af60df20978a.tar.gz
puppet-virtual-b43b2a2d5b0c424f3fce801f9158af60df20978a.tar.bz2
merge some changes from immerda repository. specially xen related.
Diffstat (limited to 'manifests/openvpn.pp')
-rw-r--r--manifests/openvpn.pp54
1 files changed, 54 insertions, 0 deletions
diff --git a/manifests/openvpn.pp b/manifests/openvpn.pp
new file mode 100644
index 0000000..ecdb8a7
--- /dev/null
+++ b/manifests/openvpn.pp
@@ -0,0 +1,54 @@
+# openvpn.pp -- create a "virtual" OpenVPN Server within a vserver
+# Copyright (C) 2007 David Schmitt <david@schmitt.edv-bus.at>
+# See LICENSE for the full license granted to you.
+
+# configures the specified vserver for openvpn hosting
+# see also http://oldwiki.linux-vserver.org/some_hints_from_john
+# and http://linux-vserver.org/Frequently_Asked_Questions#Can_I_run_an_OpenVPN_Server_in_a_guest.3F
+
+class virtual::openvpn::base {
+ include openvpn
+ modules_dir { "virtual/openvpn": }
+}
+
+class virtual::openvpn::host_base inherits virtual::openvpn::base {
+ file {
+ "/var/lib/puppet/modules/virtual/openvpn/create_interface":
+ source => "puppet://$servername/virtual/create_openvpn_interface",
+ mode => 0755, owner => root, group => 0;
+ "/var/lib/puppet/modules/virtual/openvpn/destroy_interface":
+ source => "puppet://$servername/virtual/destroy_openvpn_interface",
+ mode => 0755, owner => root, group => 0;
+ }
+}
+
+define virtual::openvpn::host() {
+ include virtual::openvpn::host_base
+ exec { "mktun for ${name}":
+ command => "./MAKEDEV tun",
+ cwd => "/etc/vservers/${name}/vdir/dev",
+ creates => "/etc/vservers/${name}/vdir/dev/net/tun";
+ }
+}
+
+# this configures a specific tun interface for the given subnet
+define virtual::openvpn::interface($subnet) {
+ # create and setup the interface if it doesn't exist already
+ # this is a "bit" coarse grained but works for me
+ ifupdown::manual {
+ $name:
+ up => "/var/lib/puppet/modules/virtual/openvpn/create_interface ${name} ${subnet}",
+ down => "/var/lib/puppet/modules/virtual/openvpn/destroy_interface ${name} ${subnet}"
+ }
+}
+
+# actually setup the openvpn server within a vserver
+define virtual::openvpn::server($config) {
+ include virtual::openvpn::base
+ file {
+ "/etc/openvpn/${name}.conf":
+ ensure => present, content => $config,
+ mode => 0644, owner => root, group => 0,
+ notify => Service['openvpn'];
+ }
+}