module-icinga2/README.md

1099 lines
45 KiB
Markdown
Raw Normal View History

puppet-icinga2
==========
Table of Contents
-----------------
1. [Overview - What is the Icinga 2 module?](#overview)
2. [Module Description - What does the module do?](#module-description)
3. [Setup - The basics of getting started with the Icinga 2 module](#setup)
4. [Usage - How to use the module for various tasks](#usage)
* [Object type usage](#object_type_usage)
* [Objects](#objects)
5. [Reference - The classes and defined types available in this module](#reference)
6. [Limitations - OS compatibility, etc.](#limitations)
7. [Development - Guide for contributing to the module](#development)
8. [Contributors - List of module contributors](#contributors)
[Overview](id:overview)
--------
This module installs and configures the [Icinga 2 monitoring system](https://www.icinga.org/icinga2/). It can also install and configure [NRPE](http://exchange.nagios.org/directory/Addons/Monitoring-Agents/NRPE--2D-Nagios-Remote-Plugin-Executor/details) on client systems that are being monitored by an Icinga 2 server.
[Module Description](id:module-description)
-------------------
Coming soon...
[Setup](id:setup)
-----
This module should be used with Puppet 3.6 or later. It may work with earlier versions of Puppet 3 but it has not been tested.
This module requires Facter 2.2 or later, specifically because it uses the `operatingsystemmajrelease` fact.
This module requires the [Puppet Labs stdlib module](https://github.com/puppetlabs/puppetlabs-stdlib).
For Ubuntu systems, this module requires the [Puppet Labs apt module](https://github.com/puppetlabs/puppetlabs-apt).
On EL-based systems (CentOS, Red Hat Enterprise Linux, Fedora, etc.), the [EPEL package repository](https://fedoraproject.org/wiki/EPEL) is required. You can also use the [icinga2::nrpe class](#nrpe-usage) to set up NRPE on CentOS 5. It is discouraged to set up Icinga2 Server on this old of a distribution. You are encouraged to use at least CentOS 6 or higher.
####Note for RedHat
If you are using RedHat Satellite server, set
<pre>
$manage_repos = false
</pre>
in `icinga2::server` class and make sure, you have a channel set up with the contents of the icinga2 repository and the needed packages from EPEL. If you leave it at true, the EPEL repository will be used directly.
If you would like to use the `icinga2::object` defined types as [exported resources](https://docs.puppetlabs.com/guides/exported_resources.html), you'll need to have your Puppet master set up with PuppetDB. See the Puppet Labs documentation for more info: [Docs: PuppetDB](https://docs.puppetlabs.com/puppetdb/)
###Server requirements
Icinga 2 requires either a [MySQL](http://www.mysql.com/) or a [Postgres](http://www.postgresql.org/) database.
Currently, this module does not set up any databases. You'll have to create one before installing Icinga 2 via the module.
2014-10-10 08:34:48 +02:00
If you would like to set up your own database, either of the Puppet Labs [MySQL](https://github.com/puppetlabs/puppetlabs-mysql) or [Postgres](https://github.com/puppetlabs/puppetlabs-postgresql) modules can be used.
The example below shows the [Puppet Labs Postgres module](https://github.com/puppetlabs/puppetlabs-postgresql) being used to install Postgres and create a database and database user for Icinga 2:
<pre>
class { 'postgresql::server': }
postgresql::server::db { 'icinga2_data':
user => 'icinga2',
password => postgresql_password('icinga2', 'password'),
}
</pre>
For production use, you'll probably want to get the database password via a [Hiera lookup](http://docs.puppetlabs.com/hiera/1/puppet.html) so the password isn't sitting in your site manifests in plain text.
####Note For CentOS 5
You must be running CentOS 5.11 and _no later_ in order to satisfy dependencies.
If you are attempting to install Icinga2 server on CentOS 5 (discouraged) and would like to use PostgreSQL, you must provide a non-EOL'd version of it. If you are installing PostgreSQL for the first time, you can tell the module to manage the pgsql YUM repository like so:
<pre>
class { 'postgresql::globals':
manage_package_repo => true,
version => '9.3',
}->
class { 'postgresql::server': }
</pre>
CentOS 5 provides PostgreSQL 9.1 by default, which was end-of-life'd in 2010. Without having the module manage the repo, it will gladly install this crippled version for you which isn't what you want.
**You will still need to declare a database for Icinga2 to access.**
[Usage](id:usage)
-----
2014-09-29 04:57:02 +02:00
###General Usage
####`icinga2::conf`
This defined type creates custom files in the `/etc/icinga2/conf.d` directory.
The `icinga2::conf` type has `target_dir`, `target_file_name`, `target_file_owner`, `target_file_group` and `target_file_mode` parameters just like the `icinga2::object` types.
2014-10-10 08:34:48 +02:00
The content of the file can be managed with two parameters:
* `template` is an ERB tmplate to use for the content (ie. `site/icinga2/baseservices.conf.erb`)
* `source` is the file server source URL for a static file (ie. `puppet:///modules/site/icinga2/baseservices.conf`)
To dynamically manage the variables of your template, use the `options_hash` parameter. It can be given a hash of data that is accessible in the template.
Example usage:
<pre>
icinga2::conf { 'baseservices':
template => 'site/icinga2/baseservices.conf.erb',
options_hash => {
enable_notifications => true,
check_interval => '5',
groups => [ 'all-servers' , 'linux-servers' ],
}
}
</pre>
2014-09-29 04:57:02 +02:00
###Server usage
To install Icinga 2, first set up a MySQL or Postgres database.
2014-11-20 06:14:46 +01:00
Once the database is set up, use the `icinga2::server` class with the `db_` database connection parameters:
<pre>
#Install Icinga 2:
2014-10-10 08:34:48 +02:00
class { 'icinga2::server':
server_db_type => 'pgsql',
db_host => 'localhost',
db_port => '5432',
db_name => 'icinga2_data',
db_user => 'icinga2',
db_password => 'password',
}
</pre>
When the `server_db_type` parameter is set, the right IDO database connection packages are automatically installed and the database schema is loaded.
**Note:** For production use, you'll probably want to get the database password via a [Hiera lookup](http://docs.puppetlabs.com/hiera/1/puppet.html) so the password isn't sitting in your site manifests in plain text:
<pre>
#Install Icinga 2:
class { 'icinga2::server':
server_db_type => 'pgsql',
db_host => 'localhost',
db_port => '5432',
db_name => 'icinga2_data',
db_user => 'icinga2',
db_password => hiera('icinga_db_password_key_here'),
}
</pre>
You'll also need to add an IDO connection object that has the same database settings and credentials as what you entered for your `icinga2::server` class.
You can do this by applying either the `icinga2::object::idomysqlconnection` or `icinga2::object::idopgsqlconnection` class to your Icinga 2 server, depending on which database you're using.
An example `icinga2::object::idopgsqlconnection` class is below:
<pre>
icinga2::object::idopgsqlconnection { 'postgres_connection':
target_dir => '/etc/icinga2/features-enabled',
target_file_name => 'ido-pgsql.conf',
host => '127.0.0.1',
port => 5432,
user => 'icinga2',
password => 'password',
database => 'icinga2_data',
categories => ['DbCatConfig', 'DbCatState', 'DbCatAcknowledgement', 'DbCatComment', 'DbCatDowntime', 'DbCatEventHandler' ],
}
</pre>
In a future version, the module will automatically create the IDO connection objects.
**Using the Debmon repository on Debian systems**
If you would like to use the [Debmon repository](http://debmon.org/packages) for Debian 7 systems, set `use_debmon_repo` to true when you call the `icinga2::server` class:
<pre>
class { 'icinga2::server':
server_db_type => 'pgsql',
# default to false
2015-01-08 13:18:14 +01:00
use_debmon_repo => true,
db_host => 'localhost'
db_port => '5432'
db_name => 'icinga2_data'
db_user => 'icinga2'
db_password => 'password',
}
</pre>
**NRPE and Nagios plugin packages**
If you will be installing NRPE or the Nagios plugins packages with the `icinga2::nrpe` class on a node that also has the `icinga2::server` class applied, be sure to set the `$server_install_nagios_plugins` parameter in your call to `icinga2::server` to `false`:
<pre>
#Install Icinga 2:
class { 'icinga2::server':
...
server_install_nagios_plugins => false,
...
}
</pre>
2014-11-20 06:17:33 +01:00
This will stop the `icinga2::server` class from trying to install the plugins packages and will prevent a duplicate resource error, since the `icinga2::nrpe` class will already be installing the plugin packages.
**`mail` binaries**
If you would like to install packages to make a `mail` command binary available so that Icinga 2 can send out email notifications, set the `install_mail_utils_package` parameter to **true**:
<pre>
2014-10-10 08:34:48 +02:00
class { 'icinga2::server':
...
install_mail_utils_package => true,
...
}
</pre>
**Enabling and disabling Icinga 2 features**
2015-01-06 05:10:55 +01:00
To manage the features that are enabled or disabled on an Icinga 2 server, you can specify them with the `server_enabled_features` and `server_disabled_features` parameters.
The parameters should be given as arrays of single-quoted strings.
**Note:** Even if you're only specifying one feature, you will still need to specify it as an array.
**Note:** If a feature is listed in both the `server_enabled_features` and `server_disabled_features` arrays, the feature will be **disabled**.
````
class { 'icinga2::server':
...
server_enabled_features => ['checker','notification'],
server_disabled_features => ['graphite','livestatus'],
}
````
###NRPE usage
To install NRPE and allow the local machine and Icinga 2 servers (or Icinga 1 or plain old Nagios servers) with various IP addresess to connect:
<pre>
class { 'icinga2::nrpe':
nrpe_allowed_hosts => ['10.0.1.79', '10.0.1.80', '10.0.1.85', '127.0.0.1'],
}
</pre>
By default the NRPE daemon will not allow clients to specify arguments to the commands that are executed. To enable NRPE to allow client argument processing you can call the icinga2::nrpe class with the **allow_command_argument_processing** parameter.
Valid parameter values are: 0=do not allow arguments, 1=allow command arguments
**WARNING! - ENABLING THIS OPTION IS A SECURITY RISK!**
````
class { 'icinga2::nrpe':
allow_command_argument_processing => 1,
}
````
If you'd like to purge NRPE config files that are not managed by Puppet you can set $nrpe_purge_unmanaged to true.
```
class { 'icinga2::nrpe':
nrpe_purge_unmanaged => true,
}
```
**Note:** If you would like to install NRPE on a node that also has the `icinga2::server` class applied, be sure to set the `$server_install_nagios_plugins` parameter in your call to `icinga2::server` to `false`:
<pre>
#Install Icinga 2:
2014-10-10 08:34:48 +02:00
class { 'icinga2::server':
server_db_type => 'pgsql',
server_install_nagios_plugins => false,
}
</pre>
This will stop the `icinga2::server` class from trying to install the plugins pacakges, since the `icinga2::nrpe` class will already be installing them and will prevent a resulting duplicate resource error.
### Check Plugins
2014-11-20 06:39:22 +01:00
Agents installed on nodes (such as NRPE) that Icinga is performing active checks against often require additional or custom check plugins. In order to deploy these check pluings on a node you can call the checkplugin defined resource.
The checkplugin defined resource can distribute files via both content (templates) and source (files). By default the checkpluin resource will assume your distribution method is content (template) and that your template resides in the icinga2 module
To reference a template that resides in another module you can update the $checkplugin_template_module parameter with the module your template resides
````
$checkplugin_template_module => 'SomeModule',
````
Example 1: Distribute check plugin that is a template
````
icinga2::checkplugin { 'check_diskstats':
checkplugin_template => 'checkplugins/check_diskstats.erb',
}
````
Example 2: Distribute check plugin that is a static file
````
icinga2::checkplugin { 'check_diskstats':
checkplugin_file_distribution_method => 'source',
checkplugin_source_file => 'puppet:///modules/checkplugins/check_diskstats',
}
````
Example 3: Distribute check plugin in a manifest
```
icinga2::checkplugin { 'check_diskstats':
checkplugin_file_distribution_method => 'inline',
checkplugin_source_inline => 'command[check_disks]=/usr/lib64/nagios/plugins/check_disk -w 20 -c 10 -p /',
}
```
Example 4: Distribute check plugin stored in Hiera(-yaml)
```
---
icinga2::checkplugin:
check_diskstats:
checkplugin_file_distribution_method: 'inline'
checkplugin_source_inline: 'command[check_disks]=/usr/lib64/nagios/plugins/check_disk -w 20 -c 10 -p /'
```
###[Object type usage](id:object_type_usage)
This module includes several defined types that can be used to automatically generate Icinga 2 format object definitions. They function in a similar way to [the built-in Nagios types that are included in Puppet](http://docs.puppetlabs.com/guides/exported_resources.html#exported-resources-with-nagios).
####Default object file locations, owner, group and mode
The default file location for each object type is controlled by the `target_file_dir` parameter. For each object type, it defaults to a subdirectory under `/etc/icinga2/objects`.
The default locations are under `/etc/icinga2/objects` and not `/etc/icinga2/conf.d/` so that user-defined objects can be kept completely separate from the objects included with Icinga 2. However, you can change the `target_file_dir` parameter to `/etc/icinga2/conf.d` if needed.
The default file owner and group are controlled by the `target_file_owner` and `target_file_group` parameters. Both default to `root`.
The default file mode is controlled by the `target_file_mode` parameter. It defaults to `0644`.
####Purging unmanaged object files
The `purge_unmanaged_object_files` parameter of the `icinga2::server` class controls whether object files in `/etc/icinga2/objects` that are not managed by Puppet get purged. It defaults to `false`.
**Note:** This will purge unmanaged subdirectories as well as unmanaged files!
####Exported resources
2014-09-29 04:03:26 +02:00
Like the built-in Nagios types, the Icinga 2 objects in this module can be exported to PuppetDB as virtual resources and collected on your Icinga 2 server.
Nodes that are being monitored can have the `@@` virtual resources applied to them:
<pre>
@@icinga2::object::host { $::fqdn:
display_name => $::fqdn,
ipv4_address => $::ipaddress_eth0,
groups => ['linux_servers', 'mysql_servers'],
vars => {
os => 'linux',
virtual_machine => 'true',
distro => $::operatingsystem,
},
target_dir => '/etc/icinga2/objects/hosts',
target_file_name => "${fqdn}.conf"
}
</pre>
Then, on your Icinga 2 server, you can collect the exported virtual resources (notice the camel casing in the class name):
<pre>
#Collect all @@icinga2::object::host resources from PuppetDB that were exported by other machines:
Icinga2::Object::Host <<| |>> { }
</pre>
Unlike the built-in Nagios types, the file `ensure` status, owner, group and mode of the automatically generated files can be controlled via the `target_file_ensure` `target_file_owner`, `target_file_group` and `target_file_mode` parameters:
<pre>
@@icinga2::object::host { $::fqdn:
display_name => $::fqdn,
ipv4_address => $::ipaddress_eth0,
groups => ['linux_servers', 'mysql_servers'],
vars => {
os => 'linux',
virtual_machine => 'true',
distro => $::operatingsystem,
},
target_dir => '/etc/icinga2/objects/hosts',
target_file_name => "${fqdn}.conf"
target_file_ensure =>
target_file_owner => 'root',
target_file_group => 'root',
target_file_mode => '0644'
}
</pre>
####`undef` and default object values
Most of the object parameters *in the Puppet module* are set to **undef**.
This means that they will not be added to the rendered object definition files.
**However**, this doesn't mean that the values are undefined in Icinga 2. Icinga 2 itself has built-in default values for many object parameters and falls back to them if one isn't present in an object definition. See the docs for individual object types in [Configuring Icinga 2](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc#!/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2) for more info about which object parameters have what default values.
####Notifying the Icinga 2 service
By default, each object defined type will automatically notify and restart the Icinga 2 service. However, if you're using the module to just generate object files and not using it to manage the service, you'll likely get compilation errors about the `icinga2` service not being in the catalog.
Each object defined type has a boolean parameter, `refresh_icinga2_service`, that controls whether the object file will notify the service. To **not** notify the service, set it to `false`:
<pre>
icinga2::object::apply_dependency { 'usermail_dep_on_icinga2mail':
parent_host_name => 'icinga2mail.local',
target_file_owner => vagrant,
assign_where => 'match("^usermail*", host.name)',
refresh_icinga2_service => false,
}
</pre>
####[Objects](id:objects)
2014-09-29 04:21:34 +02:00
Object types:
* [icinga2::object::apilistener](#icinga2objectapilistener)
* [icinga2::object::applyservicetohost](#icinga2objectapplyservicetohost)
* [icinga2::object::applynotificationtohost](#icinga2objectapplynotificationtohost)
* [icinga2::object::applynotificationtoservice](#icinga2objectapplynotificationtoservice)
* [icinga2::object::checkcommand](#icinga2objectcheckcommand)
* [icinga2::object::compatlogger](#icinga2objectcompatlogger)
* [icinga2::object::checkercomponent](#icinga2objectcheckercomponent)
* [icinga2::object::checkresultreader](#icinga2objectcheckresultreader)
* [icinga2::object::endpoint](#icinga2objectendpoint)
* [icinga2::object::eventcommand](#icinga2objecteventcommand)
2014-11-13 21:14:39 +01:00
* [icinga2::object::externalcommandlistener](#icinga2objectexternalcommandlistener)
2014-11-26 13:51:44 +01:00
* [icinga2::object::filelogger](#icinga2objectfilelogger)
* [icinga2::object::host](#icinga2objecthost)
* [icinga2::object::hostgroup](#icinga2objecthostgroup)
* [icinga2::object::icingastatuswriter](#icinga2objecticingastatuswriter)
* [icinga2::object::idomysqlconnection](#icinga2objectidomysqlconnection)
* [icinga2::object::idopgsqlconnection](#icinga2objectidopgsqlconnection)
* [icinga2::object::livestatuslistener](#icinga2objectlivestatuslistener)
* [icinga2::object::notification](#icinga2objectnotification)
* [icinga2::object::notificationcommand](#icinga2objectnotificationcommand)
Squashed commit of the following: commit d0bbdbd2011b4941150d3aff00306e7b7cc15b02 Merge: 65c7422 e12b55c Author: Nick Chappell <nick@intronic.org> Date: Sat Jan 24 20:25:50 2015 -0800 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into cropalato-7228 commit e12b55cf8c2ca266572d809a540ce9064e3d97b2 Merge: 58b2cd8 ad3b05d Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:42:58 2015 -0500 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into 7228 commit 58b2cd8f2dc4a06b1450bb246c83d484b29903b9 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. * fixed default parameter value Fix the exec resource commands so they use the new commands in 2.2 to enable/disable features instead of the old ones from 2.1 and before. refs#7714 : https://dev.icinga.org/issues/7714 Fixed a bug where features were not actually being enabled/disabled because the order of the words in the subcommands was wrong. refs#7916 : https://dev.icinga.org/issues/7916 Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Update object_host.conf.erb Added routine for cases where the value of a vars variable is a hash. Merged from: https://github.com/Icinga/puppet-icinga2/pull/58 refs#8156: https://dev.icinga.org/issues/8156 Changelog update. refs#8156: https://dev.icinga.org/issues/8156 Removed an extra .each line. Adding EndPoint Object. #7232 Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed default parameter value Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 Fixed a typo in the ERB template for the Endpoint object. 'Endpoint' should only have a capital E, not a capital P. Fixed typo in file path. Changelog update. Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value Changelog update. typo. updating validation of interval to allow resending of alerts to be disabled Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 fixing typo in interval name in templates Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value typo. Changelog update. Adding support for RedHat Changelog update. Updated metadata.json to reflect that Red Hat is supported. Updated the version number in metadata.json to reflect the current version. Typo. Added a Gemfile that has gems listed for basic Puppet unit tests. Added a .gitignore rule. Added a Rake file with a unit_tests task that runs the lint task. Added some config options for puppet-lint. Added an ApiListener object defined type. refs#7231 : https://dev.icinga.org/issues/7231 Changelog update. Fixed typo in README.md Add a target_file_ensure parameter to the ApiListener object defined type. Added a full variable scope. Fix C/C++ style comments so they use # instead. Use 2 spaces instead of a tab character. Removed a trailing space. Removed trailing whitespace. Fixed whitespace alignment in the icinga2::server::config class. Fixed whitespace alignment in the icinga2::server::install class. Disable puppet-lint variable scope checks. Disable puppet-lint class autoloader layout checks. Fixing target_dir defult value. commit ad3b05dd39bba6b5f82211cccbb0aca209bd777e Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:25:57 2015 -0500 Fixing target_dir defult value. commit 0cdb176f6920dde33b91207ac3ecb0457de7fb08 Merge: 88b3fb1 f238155 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:19:57 2015 -0500 Merge remote-tracking branch 'upstream/develop' into 7228 commit 88b3fb1e3ed4d5d7a2c98b0e43e10ee4e1dbc1b2 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Tue Dec 2 15:14:21 2014 -0500 * fixed default parameter value commit d369b81f8472c5931b8a073cc26518bf1ecb84a4 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. commit 6bf34cb4af2322020c7553016af17b84effd6dc3 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:07:52 2014 -0500 Adding NotificationComponent Object. #7228.
2015-01-25 05:45:09 +01:00
* [icinga2::object::notificationcomponent](#icinga2objectnotificationcomponent)
* [icinga2::object::perfdatawriter](#icinga2objectperfdatawriter)
2014-11-12 14:47:26 +01:00
* [icinga2::object::scheduleddowntime](#icinga2objectscheduleddowntime)
* [icinga2::object::service](#icinga2objectservice)
* [icinga2::object::servicegroup](#icinga2objectservicegroup)
2014-11-13 20:52:56 +01:00
* [icinga2::object::statusdatawriter](#icinga2objectstatusdatawriter)
* [icinga2::object::syslogger](#icinga2objectsyslogger)
* [icinga2::object::timeperiod](#icinga2objecttimeperiod)
* [icinga2::object::user](#icinga2objectuser)
* [icinga2::object::usergroup](#icinga2objectusergroup)
####[`icinga2::object::apilistener`](id:icinga2objectapilistener)
The `apilistener` defined type can create `ApiLister` objects that set the bind address and port for Icinga 2's API listener, as well as the locations of the machine's Icinga 2 cert, key and Icinga 2 CA key:
<pre>
#Create an API listener object:
icinga2::object::apilistener { 'master-api':
bind_host => $ipaddress_eth1,
accept_commands => true,
}
</pre>
The `accept_config` and `accept_commands` parameters default to **false**.
See the Icinga 2 documention for more info: [http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-apilistener](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-apilistener)
####[`icinga2::object::apply_service_to_host`](id:object_apply_service_to_host)
The `apply_service_to_host` defined type can create `apply` objects to apply services to hosts:
<pre>
#Create an apply that checks the number of zombie processes:
icinga2::object::apply_service_to_host { 'check_zombie_procs':
display_name => 'Zombie procs',
check_command => 'nrpe',
vars => {
nrpe_command => 'check_zombie_procs',
},
assign_where => '"linux_servers" in host.groups',
ignore_where => 'host.name == "localhost"',
target_dir => '/etc/icinga2/objects/applys'
}
</pre>
This defined type has the same available parameters that the `icinga2::object::service` defined type does.
The `assign_where` and `ignore_where` parameter values are meant to be provided as strings. Since Icinga 2 requires that string literals be double-quoted, the whole string in your Puppet site manifests will have to be single-quoted (leaving the double quotes intact inside):
<pre>
assign_where => '"linux_servers" in host.groups',
</pre>
If you would like to use Puppet or Facter variables in an `assign_where` or `ignore_where` parameter's value, you'll first need to double-quote the whole value for [Puppet's variable interpolation](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#double-quoted-strings) to work. Then, you'll need to escape the double quotes that surround the Icinga 2 string literals inside:
<pre>
assign_where => "\"linux_servers\" in host.${facter_variable}"",
</pre>
####[`icinga2::object::applynotificationtohost`](id:object_apply_notification_to_host)
The `apply_notification_to_host` defined type can create `apply` objects to apply notifications to hosts:
This defined type has the same available attributes that the `icinga2::object::notification` defined type does. With the addition of assign_where and ignore_where
````
#Create an apply that will send notifications to PagerDuty
icinga2::object::apply_notification_to_host { 'pagerduty-host':
assign_where => 'host.vars.enable_pagerduty == "true"',
command => 'notify-host-by-pagerduty',
users => [ 'pagerduty' ],
states => [ 'Up', 'Down' ],
types => [ 'Problem', 'Acknowledgement', 'Recovery', 'Custom' ],
period => '24x7',
}
````
####[`icinga2::object::applynotificationtoservice`](id:object_apply_notification_to_service)
The `apply_notification_to_service` defined type can create `apply` objects to apply notifications to service:
This defined type has the same available attributes that the `icinga2::object::notification` defined type does. With the addition of assign_where and ignore_where
````
icinga2::object::apply_notification_to_service { 'pagerduty-service':
assign_where => 'service.vars.enable_pagerduty == "true"',
command => 'notify-service-by-pagerduty',
users => [ 'pagerduty' ],
states => [ 'OK', 'Warning', 'Critical', 'Unknown' ],
types => [ 'Problem', 'Acknowledgement', 'Recovery', 'Custom' ],
period => '24x7',
}
````
####[`icinga2::object::checkcommand`](id:object_checkcommand)
The `checkcommand` defined type can create `checkcommand` objects.
2014-10-19 04:44:31 +02:00
Example:
<pre>
2014-10-19 04:44:31 +02:00
#Create an HTTP check command:
icinga2::object::checkcommand { 'check_http':
command => ['"/check_http"'],
arguments => {'"-H"' => '"$http_vhost$"',
'"-I"' => '"$http_address$"',
'"-u"' => '"$http_uri$"',
'"-p"' => '"$http_port$"',
'"-S"' => {
'set_if' => '"$http_ssl$"'
},
'"--sni"' => {
'set_if' => '"$http_sni$"'
},
'"-a"' => {
'value' => '"$http_auth_pair$"',
'description' => '"Username:password on sites with basic authentication"'
},
'"--no-body"' => {
'set_if' => '"$http_ignore_body$"'
},
'"-r"' => '"$http_expect_body_regex$"',
'"-w"' => '"$http_warn_time$"',
'"-c"' => '"$http_critical_time$"',
'"-e"' => '"$http_expect$"'
},
vars => {
'vars.http_address' => '"$address$"',
'vars.http_ssl' => 'false',
'vars.http_sni' => 'false'
}
}
</pre>
2014-10-19 04:44:31 +02:00
Available parameters are:
* `template_to_import`
* `command`
* `cmd_path`
* `arguments`
* `env`
* `vars`
* `timeout`
* `target_dir`
* `target_file_name`
* `target_file_owner`
* `target_file_group`
* `target_file_mode`
####`icinga2::object::compatlogger`
The `compatlogger` defined type can create `compatlogger` objects.
<pre>
icinga2::object::compatlogger { 'daily-log':
log_dir => '/var/log/icinga2/compat',
rotation_method => 'DAILY'
}
</pre>
Both patameters as optionals. The parameter `rotation_method` can one of `HOURLY`, `DAILY`, `WEEKLY` or `MONTHY`.
See [CompatLogger](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-compatlogger) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####[`icinga2::object::checkercomponent`](id:object_checkercomponent)
The `checkercomponent` defined type can create `checkercomponent` objects.
Example:
<pre>
icinga2::object::checkercomponent {'checker':}
</pre>
This object support the following parameters:
* `ensure` - Optional parameter used to remove or create the file, Default value is 'file'. Use 'absent' to remove the file.
* `object_name` - Optional. Used to define file name. default value is 'checker'
* `target_dir` - Optional. Define where the conf fil will be created. Default value is '/etc/icinga2/conf.d'
* `target_file_name` - Optional. Define the file name. Default value is '${object_name}.conf'.
* `target_file_owner` - Optional. File Owner. Default value is 'root'.
* `target_file_group` - Optional. File Group. Default value is 'root'.
* `target_file_mode` - Optional. File Mode. Default value is '0644'.
See [CheckerComponent](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-checkercomponent) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for more details about this object.
####[`icinga2::object::checkresultreader`](id:object_checkresultreader)
The `checkresultreader` defined type can create `checkresultreader` objects.
Example:
<pre>
icinga2::object::checkresultreader {'reader':
spool_dir => '/data/check-results'
}
</pre>
See [CheckResultReader](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-checkresultreader) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####[`icinga2::object::endpoint`](id:object_endpoint)
The `endpoint` defined type can create `endpoint` objects.
<pre>
icinga2::object::endpoint { 'icinga2b':
host => '192.168.5.46',
port => 5665
}
</pre>
See [EndPoint](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-endpoint) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####`icinga2::object::eventcommand`
The `eventcommand` defined type can create `eventcommand` objects.
<pre>
#Create the http restart command:
icinga2::object::eventcommand { 'restart-httpd-event':
command => [ '"/opt/bin/restart-httpd.sh"' ]
}
</pre>
This object use the same parameter defined to `checkcommand`.
2014-11-13 21:14:39 +01:00
####`icinga2::object::externalcommandlistener`
The `externalcommandlistener` defined type can create `ExternalCommandListener` objects.
<pre>
icinga2::object::externalcommandlistener { 'external':
command_path => '/var/run/icinga2/cmd/icinga2.cmd'
}
</pre>
See [ExternalCommandListener](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-externalcommandlistener) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
2014-11-26 13:51:44 +01:00
####[`icinga2::object::filelogger`](id:object_filelogger)
This defined type creates file logger objects.
Example:
<pre>
icinga2::object::filelogger { 'debug-file':
severity => 'debug',
path => '/var/log/icinga2/debug.log',
}
</pre>
See [FileLogger](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-filelogger) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####[`icinga2::object::host`](id:object_host)
This defined type creates host objects.
Example:
<pre>
@@icinga2::object::host { $::fqdn:
display_name => $::fqdn,
ipv4_address => $::ipaddress_eth1,
groups => ["linux_servers", 'mysql_servers', 'postgres_servers', 'clients', 'smtp_servers', 'ssh_servers', 'http_servers', 'imap_servers'],
vars => {
os => 'linux',
virtual_machine => 'true',
distro => $::operatingsystem,
},
target_dir => '/etc/icinga2/objects/hosts',
target_file_name => "${fqdn}.conf"
}
</pre>
Notes on specific parameters:
* `groups`: must be specified as a [Puppet array](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#arrays), even if there's only one element
* `vars`: must be specified as a [Puppet hash](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#hashes), with the Icinga 2 variable as the **key** and the variable's value as the **value**
**Note:** The `ipv6_address` parameter is set to **undef** by default. This is because `facter` can return either IPv4 or IPv6 addresses for the `ipaddress_ethX` facts. The default value for the `ipv6_address` parameter is set to **undef** and not `ipaddress_eth0` so that an IPv4 address isn't unintentionally set as the value for `address6` in the rendered host object definition.
If you would like to use an IPv6 address, make sure to set the `ipv6_address` parameter to the `ipaddress_ethX` fact that will give you the right IPv6 address for the machine:
<pre>
@@icinga2::object::host { $::fqdn:
display_name => $::fqdn,
ipv6_address => $::ipaddress_eth1,
....
}
</pre>
2014-09-29 04:21:34 +02:00
####[`icinga2::object::hostgroup`](id:object_hostgroup)
Coming soon...
####[`icinga2::object::icingastatuswriter`](id:object_icingastatuswriter)
This defined type creates an **IcingaStatusWriter** objects.
Example usage:
<pre>
icinga2::object::icingastatuswriter { 'status':
status_path => '/cache/icinga2/status.json',
update_interval => '15s',
}
</pre>
See [IcingaStatusWriter](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-icingastatuswriter) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for more details about the object.
####[`icinga2::object::idomysqlconnection`](id:object_idomysqlconnection)
This defined type creates an **IdoMySqlConnection** objects.
Though you can create the file anywhere and with any name via the `target_dir` and `target_file_name` parameters, you should set the `target_dir` parameter to `/etc/icinga2/features-enabled`, as that's where Icinga 2 will look for DB connection objects by default.
Example usage:
<pre>
icinga2::object::idomysqlconnection { 'mysql_connection':
target_dir => '/etc/icinga2/features-enabled',
target_file_name => 'ido-mysql.conf',
host => '127.0.0.1',
port => 3306,
user => 'icinga2',
password => 'password',
database => 'icinga2_data',
categories => ['DbCatConfig', 'DbCatState', 'DbCatAcknowledgement', 'DbCatComment', 'DbCatDowntime', 'DbCatEventHandler' ],
}
</pre>
Some parameters require specific data types to be given:
* `port`: needs to be a [number](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#numbers), not a quoted string
* `cleanup`: If changed from the default value, needs to be given as a [hash](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#hashes) with the keys being the cleanup item names and the maximum age as a number (not a quoted string); default values are set to the default values shown in the [Cleanup Items section of the IdomysqlConnection object documentation](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idomysqlconnection)
* `categories`: needs to be given as an [array](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#arrays) with [single-quoted strings](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#single-quoted-strings) as the elements; default values are set to the default values shown in the [Data Categories section of the IdomysqlConnection object documentation](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idomysqlconnection)
All other parameters are given as [single-quoted strings](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#single-quoted-strings).
This defined type supports all of the parameters that **IdoMySqlConnection** objects have available.
See [IdoMySqlConnection](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idomysqlconnection) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####[`icinga2::object::idopgsqlconnection`](id:object_idopgsqlconnection)
This defined type creates an **IdoPgSqlConnection** objects.
Though you can create the file anywhere and with any name via the `target_dir` and `target_file_name` parameters, you should set the `target_dir` parameter to `/etc/icinga2/features-enabled`, as that's where Icinga 2 will look for DB connection objects by default.
Example usage:
<pre>
icinga2::object::idopgsqlconnection { 'postgres_connection':
target_dir => '/etc/icinga2/features-enabled',
target_file_name => 'ido-pgsql.conf',
host => '127.0.0.1',
port => 5432,
user => 'icinga2',
password => 'password',
database => 'icinga2_data',
categories => ['DbCatConfig', 'DbCatState', 'DbCatAcknowledgement', 'DbCatComment', 'DbCatDowntime', 'DbCatEventHandler' ],
}
</pre>
Some parameters require specific data types to be given:
* `port`: needs to be a [number](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#numbers), not a quoted string
* `cleanup`: If changed from the default value, needs to be given as a [hash](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#hashes) with the keys being the cleanup item names and the maximum age as a number (not a quoted string); default values are set to the default values shown in the [Cleanup Items section of the IdopgsqlConnection object documentation](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idopgsqlconnection)
* `categories`: needs to be given as an [array](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#arrays) with [single-quoted strings](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#single-quoted-strings) as the elements; default values are set to the default values shown in the [Data Categories section of the IdopgsqlConnection object documentation](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idopgsqlconnection)
All other parameters are given as [single-quoted strings](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#single-quoted-strings).
This defined type supports all of the parameters that **IdoMySqlConnection** objects have available.
See [IdoPgSqlConnection](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idopgsqlconnection) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####[`icinga2::object::livestatuslistener`](id:object_livestatuslistener)
This defined type creates a **LivestatusListener** objects.
Example usage:
<pre>
icinga2::object::livestatuslistener { 'livestatus-unix':
socket_type => 'unix',
socket_path => '/var/run/icinga2/cmd/livestatus'
}
</pre>
See [LivestatusListener](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-livestatuslistener) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
####`icinga2::object::notification`
The `notification` defined type can create `notification` objects.
<pre>
#Defining Create the mail notification command:
icinga2::object::notification { 'localhost-ping-notification':
host_name => 'localhost',
service_name => 'ping4',
command => 'mail-service-notification',
types => [ 'Problem', 'Recovery' ]
}
</pre>
Available parameters are:
* `host_name`: Required.
* `service_name`: Optional.
* `vars`: Optional.
* `users`: Optional.
* `user_groups`: Optional.
* `times`: Optional.
* `command`: Required.
* `interval`: Optional.
* `period`: Optional.
* `types`: Optional.
* `states`: Optional.
* `target_file_name`: Optional.
* `target_file_owner`: Optional.
* `target_file_group`: Optional.
* `target_file_mode`: Optional.
Notes on specific parameters:
* `vars`: needs to be a hash
* `users`,`user_groups`,`types`,`states`: should be an array, see [Notification](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-notification) for list of valid state and type filters
* `times`: needs to be a hash with `begin` and `end` attributes
* `interval`: needs to be a [number](https://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#numbers), not a quoted string
####`icinga2::object::notificationcommand`
The `notificationcommand` defined type can create `notificationcommand` objects.
<pre>
#Create the mail notification command:
icinga2::object::notificationcommand { 'mail-service-notification':
command => ['"/icinga2/scripts/mail-notification.sh"'],
cmd_path => 'SysconfDir',
env => {
'NOTIFICATIONTYPE' => '"$notification.type$"',
'SERVICEDESC' => '"$service.name$"',
'HOSTALIAS' => '"$host.display_name$"',
'HOSTADDRESS' => '"$address$"',
'SERVICESTATE' => '"$service.state$"',
'LONGDATETIME' => '"$icinga.long_date_time$"',
'SERVICEOUTPUT' => '"$service.output$"',
'NOTIFICATIONAUTHORNAME' => '"$notification.author$"',
'NOTIFICATIONCOMMENT' => '"$notification.comment$"',
'HOSTDISPLAYNAME' => '"$host.display_name$"',
'SERVICEDISPLAYNAME' => '"$service.display_name$"',
'USEREMAIL' => '"$user.email$"'
}
}
</pre>
This object use the same parameter defined to `checkcommand`.
Squashed commit of the following: commit d0bbdbd2011b4941150d3aff00306e7b7cc15b02 Merge: 65c7422 e12b55c Author: Nick Chappell <nick@intronic.org> Date: Sat Jan 24 20:25:50 2015 -0800 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into cropalato-7228 commit e12b55cf8c2ca266572d809a540ce9064e3d97b2 Merge: 58b2cd8 ad3b05d Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:42:58 2015 -0500 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into 7228 commit 58b2cd8f2dc4a06b1450bb246c83d484b29903b9 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. * fixed default parameter value Fix the exec resource commands so they use the new commands in 2.2 to enable/disable features instead of the old ones from 2.1 and before. refs#7714 : https://dev.icinga.org/issues/7714 Fixed a bug where features were not actually being enabled/disabled because the order of the words in the subcommands was wrong. refs#7916 : https://dev.icinga.org/issues/7916 Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Update object_host.conf.erb Added routine for cases where the value of a vars variable is a hash. Merged from: https://github.com/Icinga/puppet-icinga2/pull/58 refs#8156: https://dev.icinga.org/issues/8156 Changelog update. refs#8156: https://dev.icinga.org/issues/8156 Removed an extra .each line. Adding EndPoint Object. #7232 Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed default parameter value Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 Fixed a typo in the ERB template for the Endpoint object. 'Endpoint' should only have a capital E, not a capital P. Fixed typo in file path. Changelog update. Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value Changelog update. typo. updating validation of interval to allow resending of alerts to be disabled Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 fixing typo in interval name in templates Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value typo. Changelog update. Adding support for RedHat Changelog update. Updated metadata.json to reflect that Red Hat is supported. Updated the version number in metadata.json to reflect the current version. Typo. Added a Gemfile that has gems listed for basic Puppet unit tests. Added a .gitignore rule. Added a Rake file with a unit_tests task that runs the lint task. Added some config options for puppet-lint. Added an ApiListener object defined type. refs#7231 : https://dev.icinga.org/issues/7231 Changelog update. Fixed typo in README.md Add a target_file_ensure parameter to the ApiListener object defined type. Added a full variable scope. Fix C/C++ style comments so they use # instead. Use 2 spaces instead of a tab character. Removed a trailing space. Removed trailing whitespace. Fixed whitespace alignment in the icinga2::server::config class. Fixed whitespace alignment in the icinga2::server::install class. Disable puppet-lint variable scope checks. Disable puppet-lint class autoloader layout checks. Fixing target_dir defult value. commit ad3b05dd39bba6b5f82211cccbb0aca209bd777e Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:25:57 2015 -0500 Fixing target_dir defult value. commit 0cdb176f6920dde33b91207ac3ecb0457de7fb08 Merge: 88b3fb1 f238155 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:19:57 2015 -0500 Merge remote-tracking branch 'upstream/develop' into 7228 commit 88b3fb1e3ed4d5d7a2c98b0e43e10ee4e1dbc1b2 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Tue Dec 2 15:14:21 2014 -0500 * fixed default parameter value commit d369b81f8472c5931b8a073cc26518bf1ecb84a4 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. commit 6bf34cb4af2322020c7553016af17b84effd6dc3 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:07:52 2014 -0500 Adding NotificationComponent Object. #7228.
2015-01-25 05:45:09 +01:00
####[`icinga2::object::notificationcomponent`](id:object_notificationcomponent)
The `notificationcomponent` defined type can create `notificationcomponent` objects.
Example:
<pre>
icinga2::object::notificationcomponent {'notification':}
</pre>
This object support the following parameters:
* `ensure` - Optional parameter used to remove or create the file, Default value is 'file'. Use 'absent' to remove the file.
* `object_name` - Optional. Used to define file name. default value is 'checker'
* `enable_ha` - Optional. Enable the high availability functionality. Only valid in a cluster setup. Default value is true.
2015-01-25 05:45:25 +01:00
* `target_dir` - Optional. Define where the conf fil will be created. Default value is '/etc/icinga2/features-available'
Squashed commit of the following: commit d0bbdbd2011b4941150d3aff00306e7b7cc15b02 Merge: 65c7422 e12b55c Author: Nick Chappell <nick@intronic.org> Date: Sat Jan 24 20:25:50 2015 -0800 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into cropalato-7228 commit e12b55cf8c2ca266572d809a540ce9064e3d97b2 Merge: 58b2cd8 ad3b05d Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:42:58 2015 -0500 Merge branch '7228' of https://github.com/cropalato/puppet-icinga2 into 7228 commit 58b2cd8f2dc4a06b1450bb246c83d484b29903b9 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. * fixed default parameter value Fix the exec resource commands so they use the new commands in 2.2 to enable/disable features instead of the old ones from 2.1 and before. refs#7714 : https://dev.icinga.org/issues/7714 Fixed a bug where features were not actually being enabled/disabled because the order of the words in the subcommands was wrong. refs#7916 : https://dev.icinga.org/issues/7916 Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Added refresh_icinga2_service parameters to each of the object defined types so that they can be used by themselves if the module isn't being used to also manage the Icinga 2 service. refs# 7856 : https://dev.icinga.org/issues/7856 CHANGELOG update for https://dev.icinga.org/issues/7856 refs #7856 : https://dev.icinga.org/issues/7856 Added a README note about the refresh_icinga2_service parameter. refs#7856 : https://dev.icinga.org/issues/7856 CHANGELOG release version date. Update object_host.conf.erb Added routine for cases where the value of a vars variable is a hash. Merged from: https://github.com/Icinga/puppet-icinga2/pull/58 refs#8156: https://dev.icinga.org/issues/8156 Changelog update. refs#8156: https://dev.icinga.org/issues/8156 Removed an extra .each line. Adding EndPoint Object. #7232 Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed typo Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 * fixed default parameter value Merged from: https://github.com/Icinga/puppet-icinga2/pull/63 refs#7232: https://dev.icinga.org/issues/7232 Fixed a typo in the ERB template for the Endpoint object. 'Endpoint' should only have a capital E, not a capital P. Fixed typo in file path. Changelog update. Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value Changelog update. typo. updating validation of interval to allow resending of alerts to be disabled Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 fixing typo in interval name in templates Merged from: https://github.com/Icinga/puppet-icinga2/pull/70 refs#8153: https://dev.icinga.org/issues/8153 Adding IcingaStatusWriter object. #7230 * fixed typo Changelog update. Adding FileLogger object. #7229. * fixed default parameter value typo. Changelog update. Adding support for RedHat Changelog update. Updated metadata.json to reflect that Red Hat is supported. Updated the version number in metadata.json to reflect the current version. Typo. Added a Gemfile that has gems listed for basic Puppet unit tests. Added a .gitignore rule. Added a Rake file with a unit_tests task that runs the lint task. Added some config options for puppet-lint. Added an ApiListener object defined type. refs#7231 : https://dev.icinga.org/issues/7231 Changelog update. Fixed typo in README.md Add a target_file_ensure parameter to the ApiListener object defined type. Added a full variable scope. Fix C/C++ style comments so they use # instead. Use 2 spaces instead of a tab character. Removed a trailing space. Removed trailing whitespace. Fixed whitespace alignment in the icinga2::server::config class. Fixed whitespace alignment in the icinga2::server::install class. Disable puppet-lint variable scope checks. Disable puppet-lint class autoloader layout checks. Fixing target_dir defult value. commit ad3b05dd39bba6b5f82211cccbb0aca209bd777e Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:25:57 2015 -0500 Fixing target_dir defult value. commit 0cdb176f6920dde33b91207ac3ecb0457de7fb08 Merge: 88b3fb1 f238155 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Mon Jan 12 11:19:57 2015 -0500 Merge remote-tracking branch 'upstream/develop' into 7228 commit 88b3fb1e3ed4d5d7a2c98b0e43e10ee4e1dbc1b2 Author: Ricardo Melo <ricardo.melo@gameloft.com> Date: Tue Dec 2 15:14:21 2014 -0500 * fixed default parameter value commit d369b81f8472c5931b8a073cc26518bf1ecb84a4 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:22:51 2014 -0500 Added enable_ha parameter. commit 6bf34cb4af2322020c7553016af17b84effd6dc3 Author: ricardo@cropalato.com.br <ricardo@cropalato.com.br> Date: Tue Nov 25 18:07:52 2014 -0500 Adding NotificationComponent Object. #7228.
2015-01-25 05:45:09 +01:00
* `target_file_name` - Optional. Define the file name. Default value is '${object_name}.conf'.
* `target_file_owner` - Optional. File Owner. Default value is 'root'.
* `target_file_group` - Optional. File Group. Default value is 'root'.
* `target_file_mode` - Optional. File Mode. Default value is '0644'.
See [NotificationComponent](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-notificationcomponent) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for more details about this object.
Should be enable/disable using `icinga2::server::features::enable` or `icinga2::server::features::disable`.
####[`icinga2::object::perfdatawriter`](id:object_perfdatawriter)
2014-11-17 06:03:35 +01:00
This defined type creates a **PerfdataWriter** object
Example usage:
<pre>
icinga2::object::perfdatawriter { 'pnp':
host_perfdata_path => '/var/spool/icinga2/perfdata/host-perfdata',
service_perfdata_path => '/var/spool/icinga2/perfdata/service-perfdata',
host_format_template => 'DATATYPE::HOSTPERFDATA\tTIMET::$icinga.timet$\tHOSTNAME::$host.name$\tHOSTPERFDATA::$host.perfdata$\tHOSTCHECKCOMMAND::$host.check_command$\tHOSTSTATE::$host.state$\tHOSTSTATETYPE::$host.state_type$',
service_format_template => 'DATATYPE::SERVICEPERFDATA\tTIMET::$icinga.timet$\tHOSTNAME::$host.name$\tSERVICEDESC::$service.name$\tSERVICEPERFDATA::$service.perfdata$\tSERVICECHECKCOMMAND::$service.check_command$\tHOSTSTATE::$host.state$\tHOSTSTATETYPE::$host.state_type$\tSERVICESTATE::$service.state$\tSERVICESTATETYPE::$service.state_type$',
rotation_interval => '15s'
}
</pre>
See [PerfdataWriter](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-perfdatawriter) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
2014-11-12 15:21:18 +01:00
####[`icinga2::object::scheduleddowntime`](id:object_scheduleddowntime)
This defined type creates **ScheduledDowntime** objects
<pre>
icinga2::object::scheduleddowntime {'some-downtime':
host_name => 'localhost',
service_name => 'ping4',
author => 'icingaadmin',
comment => 'Some comment',
fixed => false,
duration => '30m',
ranges => { 'sunday' => '02:00-03:00' }
}
</pre>
####[`icinga2::object::service`](id:object_service)
Coming soon...
####[`icinga2::object::servicegroup`](id:object_servicegroup)
This defined type creates an **ServiceGroup** objects.
Example usage:
<pre>
icinga2::object::servicegroup { 'web_services':
display_name => 'web services',
target_dir => '/etc/icinga2/objects/servicegroups',
}
</pre>
See [ServiceGroup](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-servicegroup) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc) for a full list of parameters.
2014-11-13 20:52:56 +01:00
####[`icinga2::object::statusdatawriter`](id:object_statusdatawriter)
This defined type creates **StatusDataWriter** objects.
Example usage:
<pre>
icinga2::object::statusdatawriter { 'status':
status_path => '/var/cache/icinga2/status.dat',
objects_path => '/var/cache/icinga2/objects.path',
update_interval => 30s
}
</pre>
See [StatusDataWriter](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-statusdatawriter) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-sysloglogger) for more info.
####[`icinga2::object::sysloglogger`](id:object_syslogger)
This defined type creates **SyslogLogger** objects.
`severity` can be set to **debug**, **notice**, **information**, **warning** or **critical**.
Example usage:
<pre>
icinga2::object::sysloglogger { 'syslog-warning':
severity => 'warning',
target_dir => '/etc/icinga2/features-enabled',
}
</pre>
See [SyslogLogger](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-servicegroup) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-sysloglogger) for more info.
####[`icinga2::object::user`](id:object_user)
Coming soon...
####[`icinga2::object::usergroup`](id:object_usergroup)
You can use this defined type to create user groups. Example:
<pre>
#Create an admins user group:
icinga2::object::hostgroup { 'admins':
display_name => 'admins',
target_dir => '/etc/icinga2/objects/usergroups',
}
</pre>
####[`icinga2::object::timeperiod`](id:object_timeperiod)
This defined type creates **TimePeriod** objects
Example usage:
````
icinga2::object::timeperiod { 'bra-office-hrs':
timeperiod_display_name => 'Brazilian WorkTime Hours',
ranges => {
'monday' => '12:00-21:00',
'tuesday' => '12:00-21:00',
'wednesday' => '12:00-21:00',
'thursday' => '12:00-21:00',
'friday' => '12:00-21:00'
}
}
````
See [TimePeriod](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-timeperiod) on [docs.icinga.org](http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-timeperiod) for more info.
####[`icinga2::object::graphitewriter`](id:object_graphitewriter)
This defined type creates an **GraphiteWriter** object
Though you can create the file anywhere and with any name via the target_dir and target_file_name parameters, you should set the target_dir parameter to /etc/icinga2/features-enabled, as that's where Icinga 2 will look for graphitewriter connection objects by default.
Example Usage:
````
icinga2::object::graphitewriter { 'graphite_relay':
target_dir => '/etc/icinga2/features-enabled',
target_file_name => 'graphite.conf',
graphite_host => '127.0.0.1',
graphite_port => 2003,
}
````
[Reference](id:reference)
---------
Classes:
Coming soon...
Defined types:
Coming soon...
[Limitations](id:limitations)
------------
Coming soon...
[Development](id:contributors)
------------
###Contributing
To submit a pull request via Github, fork [Icinga/puppet-icinga2](https://github.com/Icinga/puppet-icinga2) and make your changes in a feature branch off of the **develop** branch.
If your changes require any discussion, create an account on [https://www.icinga.org/register/](https://www.icinga.org/register/). Once you have an account, log onto [dev.icinga.org](https://dev.icinga.org/). Create an issue under the **Icinga Tools** project and add it to the **Puppet** category.
If applicable for the changes you're making, add documentation to the `README.md` file.
###Support
Check the project website at http://www.icinga.org for status updates and
https://support.icinga.org if you want to contact us.
[Contributors](id:contributors)
------------
Coming soon...