From 8219c1003d9bc40a77c7659eb65a5aa39b157d88 Mon Sep 17 00:00:00 2001 From: Gardouille Date: Wed, 7 Jan 2015 11:51:34 +0100 Subject: [PATCH] First try to build the module for the puppet forgelabs. --- CHANGELOG.md | 9 ++++ README.md | 89 +++++++++++++------------------ manifests/hypervisor.pp | 51 ++++++++++++++++++ manifests/hypervisor/preconfig.pp | 61 +++++++++++++++++++++ manifests/init.pp | 31 +++-------- manifests/params.pp | 18 +++++++ metadata.json | 15 ++++-- tests/hypervisor.pp | 3 ++ 8 files changed, 196 insertions(+), 81 deletions(-) create mode 100644 CHANGELOG.md create mode 100644 manifests/hypervisor.pp create mode 100644 manifests/hypervisor/preconfig.pp create mode 100644 manifests/params.pp create mode 100644 tests/hypervisor.pp diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..ee80787 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,9 @@ + +--------------------------------------- + +### 0.0.1 - 2014/01/07 + +Initial release. + +##### Changes +* Only prepare the system for Proxmox installation (proxmox::hypervisor::preconfig) diff --git a/README.md b/README.md index 20deeab..ab28aca 100644 --- a/README.md +++ b/README.md @@ -1,79 +1,62 @@ # proxmox -#### Table of Contents - -1. [Overview](#overview) -2. [Module Description - What the module does and why it is useful](#module-description) -3. [Setup - The basics of getting started with proxmox](#setup) - * [What proxmox affects](#what-proxmox-affects) - * [Setup requirements](#setup-requirements) - * [Beginning with proxmox](#beginning-with-proxmox) -4. [Usage - Configuration options and additional functionality](#usage) -5. [Reference - An under-the-hood peek at what the module is doing and how](#reference) -5. [Limitations - OS compatibility, etc.](#limitations) -6. [Development - Guide for contributing to the module](#development) - ## Overview -A one-maybe-two sentence summary of what the module does/what problem it solves. -This is your 30 second elevator pitch for your module. Consider including -OS/Puppet version it works with. +The proxmox module (will) provide a simple way to manage Proxmox hypervisor and it's virtual machines (KVM/OpenVZ) with Puppet. ## Module Description -If applicable, this section should have a brief description of the technology -the module integrates with and what that integration enables. This section -should answer the questions: "What does this module *do*?" and "Why would I use -it?" - -If your module has a range of functionality (installation, configuration, -management, etc.) this is the time to mention it. +The proxmox module automates installing Proxmox on Debian systems. ## Setup -### What proxmox affects +### What proxmox affects: -* A list of files, packages, services, or operations that the module will alter, - impact, or execute on the system it's installed on. -* This is a great place to stick any warnings. -* Can be in list or paragraph form. - -### Setup Requirements **OPTIONAL** - -If your module requires anything extra before setting up (pluginsync enabled, -etc.), mention it here. +* Package/service/configuration files for Proxmox +* A new `sources.list` file for Proxmox +* System repository +* The static table lookup for hostnames `hosts` ### Beginning with proxmox -The very basic steps needed for a user to get the module up and running. - -If your most recent release breaks compatibility or requires particular steps -for upgrading, you may wish to include an additional section here: Upgrading -(For an example, see http://forge.puppetlabs.com/puppetlabs/firewall). +To begin using proxmox module with default parameters, declare the hypervisor's class with `include proxmox::hypervisor`. ## Usage -Put the classes, types, and resources for customizing, configuring, and doing -the fancy stuff with your module here. +### Hypervisor + +``` +class { 'proxmox::hypervisor': + +} +``` + +**Note**: The module will automatically reboot the system on the PVE Kernel. You will need to start again the puppet agent. + +### VM + +... ## Reference -Here, list the classes, types, providers, facts, etc contained in your module. -This section should include all of the under-the-hood workings of your module so -people know what the module is touching on their system but don't need to mess -with things. (We are working on automating this section!) +### Classes -## Limitations +* `proxmox`: Main class, do nothing right now. -This is where you list OS compatibility, version compatibility, etc. +* `proxmox::hypervisor`: Install the Proxmox hypervisor on the system. -## Development +Limitations +----------- -Since your module is awesome, other users will want to play with it. Let them -know what the ground rules for contributing are. +This module will work only on Debian 7.x versions. -## Release Notes/Contributors/Etc **Optional** +Development +----------- + +Free to send contributions, fork it, ... + +License +------- + +WTFPL (http://wtfpl.org/) -If you aren't using changelog, put your release notes here (though you should -consider using changelog). You may also add any additional sections you feel are -necessary or important to include here. Please use the `## ` header. diff --git a/manifests/hypervisor.pp b/manifests/hypervisor.pp new file mode 100644 index 0000000..75eae5c --- /dev/null +++ b/manifests/hypervisor.pp @@ -0,0 +1,51 @@ +# == Class: proxmox::hypervisor +# +# Manage the Proxmox hypervisor. +# +# === Parameters +# +# Document parameters here. +# +# [*sample_parameter*] +# Explanation of what this parameter affects and what it defaults to. +# e.g. "Specify one or more upstream ntp servers as an array." +# +# === Variables +# +# Here you should define a list of variables that this module would require. +# +# [*sample_variable*] +# Explanation of how this variable affects the funtion of this class and if it +# has a default. e.g. "The parameter enc_ntp_servers must be set by the +# External Node Classifier as a comma separated list of hostnames." (Note, +# global variables should not be used in preference to class parameters as of +# Puppet 2.6.) +# +# === Examples +# +# class { '::proxmox::hypervisor': +# kvm_only => true, +# } +# +# === Authors +# +# Gardouille +# +# === Copyright +# +# WTFPL +# +class proxmox::hypervisor ( + $ve_package_ensure = $proxmox::params::ve_package_ensure, + $old_package_ensure = $proxmox::params::old_package_ensure, +) inherits proxmox::params { + + include '::proxmox::hypervisor::preconfig' +# include '::proxmox::hypervisor::install' +# include '::proxmox::hypervisor::config' + +# Class['proxmox::hypervisor::preconfig'] -> +# Class['proxmox::hypervisor::install'] -> +# Class['proxmox::hypervisor::config'] + +} # Public class: proxmox::hypervisor diff --git a/manifests/hypervisor/preconfig.pp b/manifests/hypervisor/preconfig.pp new file mode 100644 index 0000000..851dd49 --- /dev/null +++ b/manifests/hypervisor/preconfig.pp @@ -0,0 +1,61 @@ +# == Class: proxmox::hypervisor::preconfig +# +# Before installing Proxmox some modifications have to be applied on the system +# +class proxmox::hypervisor::preconfig { + + File { + owner => root, + group => root, + mode => 644, + } + + # Hostname should be resolvable via /etc/hosts + #/files/etc/hosts/2 + #/files/etc/hosts/2/ipaddr = "214.938.839.123" + #/files/etc/hosts/2/canonical = "hypervisor.domain.tld" + #/files/etc/hosts/2/alias[1] = "hypervisor" + #/files/etc/hosts/1/ipaddr = "127.0.0.1" + #/files/etc/hosts/1/canonical = "localhost" + augeas { "${::fqdn}": + context => "/files/etc/hosts", + changes => [ + #"ins ipaddr ${::ipaddress}", + "set 02/ipaddr ${::ipaddress}", + "set *[ipaddr = '${::ipaddress}']/canonical ${::fqdn}", + "set *[ipaddr = '${::ipaddress}']/alias[1] $hostname", + "set *[ipaddr = '127.0.0.1']/canonical localhost", + "rm *[ipaddr = '127.0.1.1']", + ], + onlyif => "match *[ipaddr = '${::ipaddress}'] size == 0", + } + -> + # Remove Enterprise repository (need a subscription) + file { '/etc/apt/sources.list.d/pve-enterprise.list': + ensure => absent, + } + -> + # Add the standard repository (~community) + apt::source {'proxmox': + ensure => present, + location => 'http://download.proxmox.com/debian', + release => $::lsbdistcodename, + repos => 'pve-no-subscription', + include_src => false, + key => '9887F95A', + key_server => 'keyserver.ubuntu.com', + } + + # Set the grub default to saved to be able to use grub-set-default during + # the installation + if ! defined(Augeas["grub_default"]) { + augeas { "grub_default": + context => "/files/etc/default/grub", + changes => [ + "set GRUB_DEFAULT saved", + ], + } + } + + +} # Private class: proxmox::hypervisor::preconfig diff --git a/manifests/init.pp b/manifests/init.pp index c8651d5..6ce593d 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -1,41 +1,24 @@ # == Class: proxmox # -# Full description of class proxmox here. -# -# === Parameters -# -# Document parameters here. -# -# [*sample_parameter*] -# Explanation of what this parameter affects and what it defaults to. -# e.g. "Specify one or more upstream ntp servers as an array." -# -# === Variables -# -# Here you should define a list of variables that this module would require. -# -# [*sample_variable*] -# Explanation of how this variable affects the funtion of this class and if -# it has a default. e.g. "The parameter enc_ntp_servers must be set by the -# External Node Classifier as a comma separated list of hostnames." (Note, -# global variables should be avoided in favor of class parameters as -# of Puppet 2.6.) +# This class do nothing right now. +# Please use proxmox::hypervisor to manage proxmox. # # === Examples # # class { 'proxmox': -# servers => [ 'pool.ntp.org', 'ntp.local.company.com' ], # } # # === Authors # -# Author Name +# Gardouille # # === Copyright # -# Copyright 2015 Your name here, unless otherwise noted. +# WTFPL # class proxmox { + notify { "hello world": } -} + +} # Public class: proxmox diff --git a/manifests/params.pp b/manifests/params.pp new file mode 100644 index 0000000..4418f92 --- /dev/null +++ b/manifests/params.pp @@ -0,0 +1,18 @@ +# == Class: proxmox::params +# +class proxmox::params { + case $::osfamily { + 'Debian': { + if $::operatingsystem == 'Debian' and versioncmp($::operatingsystemrelease, '7.0') >= 0 { + $ve_package_ensure = 'present' + $old_package_ensure = 'absent' + + } + } + default: { + fail("Proxmox only works with Debian system; osfamily (${::osfamily}) or lsbdistid (${::lsbdistid}) is unsupported") + } + } + + +} # Private class: proxmox::params diff --git a/metadata.json b/metadata.json index 8b7b487..4234a62 100644 --- a/metadata.json +++ b/metadata.json @@ -1,14 +1,21 @@ { "name": "gardouille-proxmox", - "version": "0.1.0", + "version": "0.0.1", "author": "gardouille", "summary": "Manage Proxmox hypervisor and KVM virtual machines or OpenVZ containers.", "license": "wtfpl", "source": "https://git.101010.fr/puppet/proxmox", "project_page": "https://git.101010.fr/puppet/proxmox", - "issues_url": null, + "issues_url": https://git.101010.fr/puppet/proxmox/issues, + "tags": ["proxmox", "system", "debian"], + "operatingsystem_support": [ + { + "operatingsystem":"Debian", + "operatingsystemrelease":"7.0" + } + ], "dependencies": [ - {"name":"puppetlabs-stdlib","version_requirement":">= 4.5.0"} + { "name": "puppetlabs/apt", "version_requirement": ">= 1.7.0" }, + { "name": "puppetlabs/stdlib", "version_requirement": ">= 4.5.0" }, ] } - diff --git a/tests/hypervisor.pp b/tests/hypervisor.pp new file mode 100644 index 0000000..e169ed7 --- /dev/null +++ b/tests/hypervisor.pp @@ -0,0 +1,3 @@ +class { 'proxmox::hypervisor': + +}