|
# == Class: puppet
|
|
#
|
|
# This class installs and configures the puppet agent.
|
|
#
|
|
# === Parameters:
|
|
#
|
|
# $version:: Specify a specific version of a package to install.
|
|
# The version should be the exact match for your distro.
|
|
# You can also use certain values like 'latest'.
|
|
#
|
|
# $user:: Override the name of the puppet user.
|
|
#
|
|
# $group:: Override the name of the puppet group.
|
|
#
|
|
# $dir:: Override the puppet directory.
|
|
#
|
|
# $port:: Override the port of the master we connect to.
|
|
# type:integer
|
|
#
|
|
# $listen:: Should the puppet agent listen for connections.
|
|
# type:boolean
|
|
# $pluginsync:: Enable pluginsync.
|
|
# type:boolean
|
|
#
|
|
# $splay:: Switch to enable a random amount of time to sleep before
|
|
# each run.
|
|
# type:boolean
|
|
#
|
|
# $runinterval:: Set up the interval (in seconds) to run the puppet agent.
|
|
# type:integer
|
|
#
|
|
# $runmode:: Select the mode to setup the puppet agent. Can be either
|
|
# 'cron' or 'service'.
|
|
#
|
|
# $agent_noop:: Run the agent in noop mode.
|
|
# type:boolean
|
|
#
|
|
# $show_diff:: Show and report changed files with diff output
|
|
#
|
|
# $ca_server:: Use a different ca server. Should be either a string
|
|
# with the location of the ca_server or 'false'.
|
|
#
|
|
# $agent_template:: Use a custom template for the agent puppet configuration.
|
|
#
|
|
# $auth_template:: Use a custom template for the auth configuration.
|
|
#
|
|
# $nsauth_template:: Use a custom template for the nsauth configuration.
|
|
#
|
|
# $client_package:: Install a custom package to provide the puppet client
|
|
#
|
|
# == puppet::server parameters
|
|
#
|
|
# $server:: Should a puppet master be installed as well as the client
|
|
# type:boolean
|
|
#
|
|
# $server_user:: Name of the puppetmaster user.
|
|
#
|
|
# $server_group:: Name of the puppetmaster group.
|
|
#
|
|
# $server_dir:: Puppet configuration directory
|
|
#
|
|
# $server_port:: Puppet master port
|
|
# type:integer
|
|
#
|
|
# $server_vardir:: Puppet data directory.
|
|
#
|
|
# $server_ca:: Provide puppet CA
|
|
# type:boolean
|
|
#
|
|
# $server_reports List of report types to include on the puppetmaster
|
|
#
|
|
# $server_passenger:: If set to true, we will configure apache with
|
|
# passenger. If set to false, we will enable the
|
|
# default puppetmaster service unless
|
|
# service_fallback is set to false. See 'Advanced
|
|
# server parameters' for more information.
|
|
# type:boolean
|
|
#
|
|
# $server_external_nodes:: External nodes classifier executable
|
|
#
|
|
# $server_template:: Which template should be used for master configuration
|
|
#
|
|
# $server_git_repo:: Use git repository as a source of modules
|
|
# type:boolean
|
|
#
|
|
# $server_environments:: Environments to setup (creates directories)
|
|
# type:array
|
|
#
|
|
# $server_envs_dir:: Directory that holds puppet environments
|
|
#
|
|
# $server_manifest_path:: Path to puppet site.pp manifest
|
|
#
|
|
# $server_common_modules_path:: Common modules paths
|
|
# type:array
|
|
#
|
|
# $server_git_repo_path:: Git repository path
|
|
#
|
|
# $server_post_hook_content:: Which template to use for git post hook
|
|
#
|
|
# $server_post_hook_name:: Name of a git hook
|
|
#
|
|
# $server_storeconfigs_backend:: Do you use storeconfigs? (note: not required)
|
|
# false if you don't, "active_record" for 2.X
|
|
# style db, "puppetdb" for puppetdb
|
|
#
|
|
# $server_app_root:: Directory where the application lives
|
|
#
|
|
# $server_ssl_dir:: SSL directory
|
|
#
|
|
# $server_package:: Custom package name for puppet master
|
|
#
|
|
# === Advanced server parameters:
|
|
#
|
|
# $server_httpd_service:: Apache/httpd service name to notify on configuration
|
|
# changes. Defaults to 'httpd' based on the default
|
|
# apache module included with foreman-installer.
|
|
#
|
|
# $server_service_fallback:: If passenger is not used, do we want to fallback
|
|
# to using the puppetmaster service? Set to false
|
|
# if you disabled passenger and you do NOT want to
|
|
# use the puppetmaster service. Defaults to true.
|
|
# type:boolean
|
|
#
|
|
# $server_passenger_max_pool:: The PassengerMaxPoolSize parameter. If your host is
|
|
# low on memory, it may be a good thing to lower
|
|
# this. Defaults to 12.
|
|
# type:integer
|
|
#
|
|
# $server_config_version:: How to determine the configuration version. When
|
|
# using git_repo, by default a git describe approach
|
|
# will be installed.
|
|
#
|
|
# $server_facts:: Should foreman receive facts from puppet
|
|
# type:boolean
|
|
#
|
|
# $server_foreman_url:: Foreman URL
|
|
#
|
|
# $server_puppet_basedir:: Where is the puppet code base located
|
|
#
|
|
# $server_puppet_home:: Puppet var directory
|
|
#
|
|
# $server_reports:: List of report types to include on the puppetmaster
|
|
#
|
|
# $server_enc_api:: What version of enc script to deploy. Valid values are
|
|
# 'v2' for latest, and 'v1' for Foreman =< 1.2
|
|
#
|
|
# $server_report_api:: What version of report processor to deploy. Valid values
|
|
# are 'v2' for latest, and 'v1' for Foreman =< 1.2
|
|
#
|
|
# === Usage:
|
|
#
|
|
# * Simple usage:
|
|
#
|
|
# include puppet
|
|
#
|
|
# * Installing a puppetmaster
|
|
#
|
|
# class {'puppet':
|
|
# server => true,
|
|
# }
|
|
#
|
|
# * Advanced usage:
|
|
#
|
|
# class {'puppet':
|
|
# agent_noop => true,
|
|
# version => '2.7.20-1',
|
|
# }
|
|
#
|
|
class puppet (
|
|
$version = $puppet::params::version,
|
|
$user = $puppet::params::user,
|
|
$group = $puppet::params::group,
|
|
$dir = $puppet::params::dir,
|
|
$port = $puppet::params::port,
|
|
$listen = $puppet::params::listen,
|
|
$pluginsync = $puppet::params::pluginsync,
|
|
$splay = $puppet::params::splay,
|
|
$runinterval = $puppet::params::runinterval,
|
|
$runmode = $puppet::params::runmode,
|
|
$agent_noop = $puppet::params::agent_noop,
|
|
$show_diff = $puppet::params::show_diff,
|
|
$ca_server = $puppet::params::ca_server,
|
|
$agent_template = $puppet::params::agent_template,
|
|
$auth_template = $puppet::params::auth_template,
|
|
$nsauth_template = $puppet::params::nsauth_template,
|
|
$client_package = $puppet::params::client_package,
|
|
$server = $puppet::params::server,
|
|
$server_user = $puppet::params::user,
|
|
$server_group = $puppet::params::group,
|
|
$server_dir = $puppet::params::dir,
|
|
$server_port = $puppet::params::port,
|
|
$server_vardir = $puppet::params::server_vardir,
|
|
$server_ca = $puppet::params::server_ca,
|
|
$server_reports = $puppet::params::server_reports,
|
|
$server_passenger = $puppet::params::server_passenger,
|
|
$server_service_fallback = $puppet::params::server_service_fallback,
|
|
$server_passenger_max_pool = $puppet::params::server_passenger_max_pool,
|
|
$server_httpd_service = $puppet::params::server_httpd_service,
|
|
$server_external_nodes = $puppet::params::server_external_nodes,
|
|
$server_template = $puppet::params::server_template,
|
|
$server_config_version = $puppet::params::server_config_version,
|
|
$server_git_repo = $puppet::params::server_git_repo,
|
|
$server_environments = $puppet::params::server_environments,
|
|
$server_envs_dir = $puppet::params::server_envs_dir,
|
|
$server_manifest_path = $puppet::params::server_manifest_path,
|
|
$server_common_modules_path = $puppet::params::server_common_modules_path,
|
|
$server_git_repo_path = $puppet::params::server_git_repo_path,
|
|
$server_post_hook_content = $puppet::params::server_post_hook_content,
|
|
$server_post_hook_name = $puppet::params::server_post_hook_name,
|
|
$server_storeconfigs_backend = $puppet::params::server_storeconfigs_backend,
|
|
$server_app_root = $puppet::params::server_app_root,
|
|
$server_ssl_dir = $puppet::params::server_ssl_dir,
|
|
$server_package = $puppet::params::server_package,
|
|
$server_foreman_url = $foreman::params::foreman_url,
|
|
$server_facts = $foreman::params::facts,
|
|
$server_puppet_home = $foreman::params::puppet_home,
|
|
$server_puppet_basedir = $foreman::params::puppet_basedir,
|
|
$server_enc_api = 'v2',
|
|
$server_report_api = 'v2'
|
|
) inherits puppet::params {
|
|
|
|
validate_bool($listen)
|
|
validate_bool($pluginsync)
|
|
validate_bool($splay)
|
|
validate_bool($agent_noop)
|
|
validate_bool($server)
|
|
validate_bool($server_ca)
|
|
validate_bool($server_passenger)
|
|
validate_bool($server_git_repo)
|
|
validate_bool($server_service_fallback)
|
|
validate_bool($server_facts)
|
|
|
|
validate_string($server_external_nodes)
|
|
|
|
class { 'puppet::install': } ~>
|
|
class { 'puppet::config': } ->
|
|
Class['puppet']
|
|
|
|
if $server == true {
|
|
class { 'puppet::server':
|
|
require => Class['puppet::config'],
|
|
}
|
|
}
|
|
}
|