Skip to content

Latest commit

 

History

History
3932 lines (2089 loc) · 74.3 KB

REFERENCE.md

File metadata and controls

3932 lines (2089 loc) · 74.3 KB

Reference

Table of Contents

Classes

Defined types

Resource types

Functions

  • sensuclassic_sorted_json: This function takes unsorted hash and outputs JSON object making sure the keys are sorted. Optionally you can pass a boolean as the second pa

Classes

sensuclassic

This is the main Sensu class

Parameters

The following parameters are available in the sensuclassic class.

version

Data type: Pattern[/^absent$/, /^installed$/, /^latest$/, /^present$/, /^[\d\.\-el]+$/]

Version of sensu to install. Defaults to installed to support Windows MSI packaging and to avoid surprising upgrades.

Default value: 'installed'

sensu_etc_dir

Data type: Stdlib::Absolutepath

Absolute path to the sensu etc directory. Default: '/etc/sensu' on Linux, 'C:/opt/sensu' on windows

Default value: $::osfamily

sensu_plugin_name

Data type: String

Name of the sensu-plugin package. Refers to the sensu-plugin rubygem, not the community sensu-plugins community scripts.

Default value: 'sensu-plugin'

sensu_plugin_provider

Data type: Optional[String]

String. Provider used to install the sensu-plugin package. Refers to the sensu-plugin rubygem, not the sensu-plugins community scripts. On windows, defaults to gem, all other platforms defaults to undef

Default value: $::osfamily

sensu_plugin_version

Data type: Pattern[/^absent$/, /^installed$/, /^latest$/, /^present$/, /^\d[\d\.\-\w]+$/]

Version of the sensu-plugin gem to install. Refers to the sensu-plugin rubygem, not the sensu-plugins community scripts

Default value: 'installed'

install_repo

Data type: Boolean

Whether or not to install the sensu repo

Default value: true

enterprise

Data type: Boolean

Whether or not to install and configure Sensu Enterprise

Default value: false

enterprise_dashboard

Data type: Boolean

Whether or not to install sensu-enterprise-dashboard

Default value: false

manage_repo

Data type: Boolean

Whether or not to manage apt/yum repositories

Default value: true

repo

Data type: Enum['main','unstable']

Which sensu repo to install

Default value: 'main'

repo_source

Data type: Optional[String]

Location of the yum/apt repo. Overrides the default location

Default value: undef

repo_key_id

Data type: String

The apt GPG key id

Default value: 'EE15CFF6AB6E4E290FDAB681A20F259AEB9C94BB'

repo_key_source

Data type: String

URL of the apt GPG key

Default value: 'https://sensu.global.ssl.fastly.net/apt/pubkey.gpg'

repo_release

Data type: Optional[String]

Release for the apt source. Only set this if you want to run packages from another release, which is not supported by Sensu. Only works with systems that use apt.

Default value: undef

spawn_limit

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Tune concurrency of the sensu-server pipe handler and the sensu-client check execution. This setting should not need to be tuned except in specific situations, e.g. when there are a large number of JIT clients. See #727 for more information. The default is undefined, which does not manage /etc/sensu/conf.d/spawn.json

Default value: undef

client

Data type: Boolean

Include the sensu client

Default value: true

server

Data type: Boolean

Include the sensu server

Default value: false

api

Data type: Boolean

Include the sensu api service

Default value: false

manage_services

Data type: Boolean

Manage the sensu services with puppet

Default value: true

client_service_enable

Data type: Boolean

Set enable value for sensu client service (applies when manage_services is set to true)

Default value: true

client_service_ensure

Data type: String

Set ensure value for sensu client service (applies when manage_services is set to true)

Default value: running

server_service_enable

Data type: Boolean

Set enable value for sensu server service (applies when manage_services is set to true)

Default value: true

server_service_ensure

Data type: String

Set ensure value for sensu server service (applies when manage_services is set to true)

Default value: running

manage_user

Data type: Boolean

Manage the sensu user with puppet

Default value: true

manage_plugins_dir

Data type: Boolean

Manage the sensu plugins directory. Must be false if you use sensuclassic::plugin with type 'directory'.

Default value: true

manage_handlers_dir

Data type: Boolean

Manage the sensu handlers directory

Default value: true

manage_mutators_dir

Data type: Boolean

Manage the sensu mutators directory

Default value: true

sensu_user

Data type: Optional[String]

Name of the user Sensu is running as. Default is calculated according to the underlying OS

Default value: undef

sensu_group

Data type: Optional[String]

Name of the group Sensu is running as. Default is calculated according to the underlying OS

Default value: undef

config_dir_mode

Data type: Optional[Stdlib::Filemode]

Directory mode for Sensu conf directory. Default is calculated according to the underlying OS

Default value: $::osfamily

config_file_mode

Data type: Optional[Stdlib::Filemode]

File mode for config files under Sensu conf directory . Default is calculated according to the underlying OS

Default value: $::osfamily

rabbitmq_port

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Rabbitmq port to be used by sensu

Default value: undef

rabbitmq_host

Data type: Optional[String]

Host running rabbitmq for sensu

Default value: undef

rabbitmq_user

Data type: Optional[String]

Username to connect to rabbitmq with for sensu

Default value: undef

rabbitmq_password

Data type: Optional[String]

Password to connect to rabbitmq with for sensu

Default value: undef

rabbitmq_vhost

Data type: Optional[String]

Rabbitmq vhost to be used by sensu

Default value: undef

ssl_dir

Data type: Optional[Stdlib::Absolutepath]

The path to RabbitMQ SSL directory. Defaults to $etc_dir/ssl.

Default value: undef

rabbitmq_ssl

Data type: Optional[Boolean]

Use SSL transport to connect to RabbitMQ. If rabbitmq_ssl_private_key and/or rabbitmq_ssl_cert_chain are set, then this is enabled automatically. Set rabbitmq_ssl => true without specifying a private key or cert chain to use SSL transport, but not cert auth.

Default value: undef

rabbitmq_ssl_private_key

Data type: Optional[String]

Private key to be used by sensu to connect to rabbitmq. If the value starts with 'puppet://' the file will be copied and used. Also the key itself can be given as the parameter value, or a variable, or using hiera. Absolute paths will just be used as a file reference, as you'd normally configure sensu.

Default value: undef

rabbitmq_ssl_cert_chain

Data type: Optional[String]

Private SSL cert chain to be used by sensu to connect to rabbitmq If the value starts with 'puppet://' the file will be copied and used. Also the key itself can be given as the parameter value, or a variable, or using hiera. Absolute paths will just be used as a file reference, as you'd normally configure sensu.

Default value: undef

rabbitmq_prefetch

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

The integer value for the RabbitMQ prefetch attribute

Default value: undef

rabbitmq_cluster

Data type: Variant[Undef,Hash,Array]

Array of hashes. Rabbitmq Cluster configuration and connection information for one or more Cluster

Default value: undef

rabbitmq_heartbeat

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

The integer value for the RabbitMQ heartbeat attribute

Default value: undef

redis_host

Data type: Optional[String]

Hostname of redis to be used by sensu

Default value: '127.0.0.1'

redis_port

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Redis port to be used by sensu

Default value: 6379

redis_password

Data type: Optional[String]

Password to be used to connect to Redis

Default value: undef

redis_reconnect_on_error

Data type: Boolean

Reconnect to Redis in the event of a Redis error, e.g. READONLY (not to be confused with a connection failure).

Default value: true

redis_db

Data type: Integer

The Redis instance DB to use/select

Default value: 0

redis_sentinels

Data type: Optional[Array]

Redis Sentinel configuration and connection information for one or more Sentinels

Default value: undef

redis_master

Data type: Optional[String]

Redis master name in the sentinel configuration In the end whatever sensu defaults to, which is "mymaster" currently.

Default value: undef

redis_auto_reconnect

Data type: Boolean

Reconnect to Redis in the event of a connection failure

Default value: true

redis_tls

Data type: Boolean

Enable TLS encryption when connecting to Redis

Default value: false

transport_type

Data type: Enum['rabbitmq','redis']

Transport type to be used by Sensu

Default value: 'rabbitmq'

transport_reconnect_on_error

Data type: Boolean

If the transport connection is closed, attempt to reconnect automatically when possible.

Default value: true

api_bind

Data type: String

IP to bind api service

Default value: '0.0.0.0'

api_host

Data type: String

Hostname of the sensu api service

Default value: '127.0.0.1'

api_port

Data type: Integer

Port of the sensu api service

Default value: 4567

api_user

Data type: Optional[String]

Password of the sensu api service

Default value: undef

api_password

Data type: Optional[String]

Password of the sensu api service

Default value: undef

api_ssl_port

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Port of the HTTPS (SSL) sensu api service. Enterprise only feature.

Default value: undef

api_ssl_keystore_file

Data type: Optional[String]

The file path for the SSL certificate keystore. Enterprise only feature.

Default value: undef

api_ssl_keystore_password

Data type: Optional[String]

The SSL certificate keystore password. Enterprise only feature.

Default value: undef

subscriptions

Data type: Variant[String,Array]

Default subscriptions used by the client

Default value: []

client_socket_enabled

Data type: Boolean

Boolean that determines if client socket will be enabled

Default value: true

client_address

Data type: String

Address of the client to report with checks

Default value: $::ipaddress

client_name

Data type: String

Name of the client to report with checks

Default value: $::fqdn

client_custom

Data type: Hash

Custom client variables. Any key that is used by a property of sensu_client_config will be ignored and should not be included in this parameter.

Default value: {}

client_deregister

Data type: Variant[Undef,Boolean]

Enable the deregistration event if true.

Default value: undef

client_deregistration

Data type: Variant[Undef,Hash]

(https://sensuapp.org/docs/latest/reference/clients#deregistration-attributes) used to generate check result data for the de-registration event. Client deregistration attributes are merged with some default check definition attributes by the Sensu server during client deregistration, so any valid check definition attributes – including custom check definition attributes – may be used as deregistration attributes, with the following exceptions (which are used to ensure the check result is valid): check name, output, status, and issued timestamp. The following attributes are provided as recommendations for controlling client deregistration behavior.

Default value: undef

client_registration

Data type: Variant[Undef,Hash]

(https://sensuapp.org/docs/latest/reference/clients#registration-attributes) used to generate check result data for the registration event. Client registration attributes are merged with some default check definition attributes by the Sensu server during client registration.

Default value: undef

client_keepalive

Data type: Hash

Client keepalive configuration

Default value: {}

client_http_socket

Data type: Hash

Client http_socket configuration. Must be an Hash of parameters as described in: https://sensuapp.org/docs/latest/reference/clients.html#http-socket-attributes

Default value: {}

client_servicenow

Data type: Hash

Client servicenow configuration. Supported only on Sensu Enterprise. It expects an Hash with a single key named 'configuration_item' containing an Hash of parameters, as described in: https://sensuapp.org/docs/latest/reference/clients.html#servicenow-attributes

Default value: {}

client_ec2

Data type: Hash

Client ec2 configuration. Supported only on Sensu Enterprise. It expects an Hash with valid paramters as described in: https://sensuapp.org/docs/latest/reference/clients.html#ec2-attributes

Default value: {}

client_chef

Data type: Hash

Client chef configuration. Supported only on Sensu Enterprise. It expects an Hash with valid paramters as described in: https://sensuapp.org/docs/latest/reference/clients.html#chef-attributes

Default value: {}

client_puppet

Data type: Hash

Client puppet configuration. Supported only on Sensu Enterprise. It expects an Hash with valid paramters as described in: https://sensuapp.org/docs/latest/reference/clients.html#puppet-attributes

Default value: {}

safe_mode

Data type: Boolean

Force safe mode for checks

Default value: false

plugins

Data type: Variant[String,Array,Hash]

Plugins to install on the node Strings and Arrays of strings will set 'install_path' => '/etc/sensu/plugins' as default. Example string: 'puppet:///data/sensu/plugins/plugin1.rb' Example array: [ 'puppet:///data/sensu/plugins/plugin1.rb', 'puppet:///data/sensu/plugins/plugin2.rb' ] Example hash: { 'puppet:///data/sensu/plugins/plugin1.rb' => { 'pkg_version' => '2.4.2' }, 'puppet:///data/sensu/plugins/plugin1.rb' => { 'pkg_provider' => 'sensu-gem' }

Default value: []

plugins_defaults

Data type: Hash

Defaults for Plugins to install on the node. Will be added when plugins is set to a hash. Example value: { 'install_path' => '/other/path' }

Default value: {}

plugins_dir

Data type: Optional[String]

Puppet url to plugins directory

Default value: undef

purge

Data type: Variant[Boolean,Hash[Enum['plugins','config','handlers','extensions','mutators'],Boolean]]

If unused plugins, configs, handlers, extensions and mutators should be removed from the system. If set to true, all unused plugins, configs, handlers, extensions and mutators will be removed from the system. If set to a Hash, only unused files of the specified type(s) will be removed from the system. Valid values: true, false, Hash containing any of the keys 'plugins', 'config', 'handlers', 'extensions', 'mutators' Example value: { config => true, plugins => true }

Default value: false

use_embedded_ruby

Data type: Boolean

If the embedded ruby should be used, e.g. to install the sensu-plugin gem. This value is overridden by a defined sensu_plugin_provider. Note, the embedded ruby should always be used to provide full compatibility. Using other ruby runtimes, e.g. the system ruby, is not recommended.

Default value: true

rubyopt

Data type: Optional[String]

Ruby opts to be passed to the sensu services

Default value: undef

gem_path

Data type: Optional[String]

Paths to add to GEM_PATH if we need to look for different dirs.

Default value: undef

log_level

Data type: Enum['debug','info','warn','error','fatal']

Sensu log level to be used

Default value: 'info'

log_dir

Data type: Stdlib::Absolutepath

Sensu log directory to be used

Default value: '/var/log/sensu'

init_stop_max_wait

Data type: Variant[Integer,Pattern[/^(\d+)$/]]

Number of seconds to wait for the init stop script to run

Default value: 10

gem_install_options

Data type: Optional[Any]

Optional configuration to use for the installation of the sensu plugin gem with sensuclassic_gem provider. See: https://docs.puppetlabs.com/references/latest/type.html#package-attribute-install_options Example value: [{ '-p' => 'http://user:[email protected]:8080' }]

Default value: undef

hasrestart

Data type: Boolean

Value of hasrestart attribute for sensu services. If you use your own startup scripts for upstart and want puppet to properly stop and start sensu services when those scripts change, set it to false. See also http://upstart.ubuntu.com/faq.html#reload

Default value: true

enterprise_dashboard_auth

Data type: Optional[Any]

Optional auth configuration for Enterprise Dashboard

Default value: undef

enterprise_dashboard_oidc

Data type: Optional[Any]

Optional OIDC configuration for Enterprise Dashboard

Default value: undef

enterprise_dashboard_custom

Data type: Optional[Hash]

List of custom attributes to include in the check. You can use it to pass any attribute that is not listed here explicitly. Example: { 'usersOptions' => { 'requireSilencingReason' => true } }

Default value: undef

path

Data type: Variant[Stdlib::Absolutepath,Pattern[/^\$PATH$/]]

Used to set PATH in /etc/default/sensu

Default value: '$PATH'

env_vars

Data type: Optional[Hash[String[1], Variant[String, Boolean, Integer]]]

Additional environment variables for /etc/default/sensu

Default value: {}

redact

Data type: Optional[Array]

Use to redact passwords from checks on the client side

Default value: undef

deregister_on_stop

Data type: Boolean

Whether the sensu client should deregister from the API on service stop

Default value: false

deregister_handler

Data type: Optional[String]

The handler to use when deregistering a client on stop.

Default value: undef

handlers

Data type: Hash

Hash of handlers for use with create_resources(sensuclassic::handler). Example value: { 'email' => { 'type' => 'pipe', 'command' => 'mail' } }

Default value: {}

handler_defaults

Data type: Hash

Handler defaults when not provided explicitly in $handlers. Example value: { 'filters' => ['production'] }

Default value: {}

checks

Data type: Hash

Hash of checks for use with create_resources(sensuclassic::check). Example value: { 'check-cpu' => { 'command' => 'check-cpu.rb' } }

Default value: {}

check_defaults

Data type: Hash

Check defaults when not provided explicitly in $checks. Example value: { 'occurrences' => 3 }

Default value: {}

filters

Data type: Hash

Hash of filters for use with create_resources(sensuclassic::filter). Example value: { 'occurrence' => { 'attributes' => { 'occurrences' => '1' } } }

Default value: {}

filter_defaults

Data type: Hash

Filter defaults when not provided explicitly in $filters. Example value: { 'negate' => true }

Default value: {}

package_checksum

Data type: Optional[String]

Used to set package_checksum for windows installs

Default value: undef

package_proxy_host

Data type: Optional[String]

Package proxy host. Currently only used applies to Windows not using chocolatey.

Default value: undef

package_proxy_port

Data type: Optional[Stdlib::Port]

Package proxy port. Currently only used applies to Windows not using chocolatey.

Default value: undef

windows_logrotate

Data type: Boolean

Whether or not to use logrotate on Windows OS family.

Default value: false

windows_log_size

Data type: Variant[Integer,Pattern[/^(\d+)$/]]

The integer value for the size of log files on Windows OS family. sizeThreshold in sensu-client.xml.

Default value: 10240

windows_log_number

Data type: Variant[Integer,Pattern[/^(\d+)$/]]

The integer value for the number of log files to keep on Windows OS family. keepFiles in sensu-client.xml.

Default value: 10

windows_pkg_url

Data type: Optional[String]

If specified, override the behavior of computing the package source URL from windows_repo_prefix and os major release fact. This parameter is intended to allow the end user to override the source URL used to install the Windows package. For example: "https://eol-repositories.sensuapp.org/msi/2012r2/sensu-0.29.0-11-x64.msi"

Default value: undef

windows_package_provider

Data type: Optional[String]

When something other than undef, use the specified package provider to install Windows packages. The default behavior of undef defers to the default package provider in Puppet which is expected to be the msi provider. Valid values are undef or 'chocolatey'.

Default value: undef

windows_choco_repo

Data type: Optional[String]

The URL of the Chocolatey repository, used with the chocolatey windows package provider.

Default value: undef

windows_package_name

Data type: String

The package name used to identify the package filename. Defaults to 'sensu' which matches the MSI filename published at https://eol-repositories.sensuapp.org/msi. Note, this is distinct from the windows_package_title, which is used to identify the package name as displayed in Add/Remove programs in Windows.

Default value: 'Sensu'

windows_package_title

Data type: String

The package name used to identify the package as listed in Add/Remove programs. Note this is distinct from the package filename identifier specified with windows_package_name.

Default value: 'sensu'

windows_service_user

Data type: Optional[Struct[{NotUndef[user] => String, NotUndef[password] => String}]]

The credentials to use for running the Windows service Takes the form of { 'user' => 'username', 'password' => 'secret' } replacing 'username' and 'secret' with appropriate values.

Default value: undef

confd_dir

Data type: Optional[Variant[Stdlib::Absolutepath,Array[Stdlib::Absolutepath]]]

Additional directories to load configuration snippets from.

Default value: undef

heap_size

Data type: Variant[Integer,Pattern[/^(\d+)/],Undef]

Value of the HEAP_SIZE environment variable. Note: This has effect only on Sensu Enterprise.

Default value: undef

max_open_files

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Value of the MAX_OPEN_FILES environment variable.

Default value: undef

config_file

Data type: Variant[Stdlib::Absolutepath,Undef]

Value of the CONFIG_FILE environment variable.

Default value: undef

heap_dump_path

Data type: Variant[Undef,String]

Value of the HEAP_DUMP_PATH environment variable.

Default value: undef

java_opts

Data type: Variant[Undef,String]

Value of the JAVA_OPTS environment variable.

Default value: undef

enterprise_version

Data type: Pattern[/^absent$/,/^installed$/,/^latest$/,/^present$/,/^[\d\.\-]+$/]

Default value: 'latest'

enterprise_user

Data type: Optional[String]

Default value: undef

enterprise_pass

Data type: Optional[String]

Default value: undef

enterprise_dashboard_version

Data type: String

Default value: 'latest'

enterprise_repo_key_id

Data type: String

Default value: '910442FF8781AFD0995D14B311AB27E8C3FE3269'

client_bind

Data type: String

Default value: '127.0.0.1'

client_port

Data type: Integer

Default value: 3030

purge_config

Data type: Boolean

Default value: false

purge_plugins_dir

Data type: Boolean

Default value: false

dashboard

Data type: Boolean

Default value: false

enterprise_dashboard_base_path

Data type: Optional[String]

Default value: undef

enterprise_dashboard_host

Data type: Optional[String]

Default value: undef

enterprise_dashboard_port

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Default value: undef

enterprise_dashboard_refresh

Data type: Optional[Any]

Default value: undef

enterprise_dashboard_user

Data type: Optional[String]

Default value: undef

enterprise_dashboard_pass

Data type: Optional[String]

Default value: undef

enterprise_dashboard_ssl

Data type: Optional[Any]

Default value: undef

enterprise_dashboard_audit

Data type: Optional[Any]

Default value: undef

enterprise_dashboard_github

Data type: Optional[Any]

Default value: undef

enterprise_dashboard_gitlab

Data type: Optional[Any]

Default value: undef

enterprise_dashboard_ldap

Data type: Optional[Any]

Default value: undef

windows_repo_prefix

Data type: Optional[String]

Default value: 'https://eol-repositories.sensuapp.org/msi'

extensions

Data type: Hash

Default value: {}

mutators

Data type: Hash

Default value: {}

sensuclassic::api

Manages the Sensu API

Parameters

The following parameters are available in the sensuclassic::api class.

hasrestart

Data type: Boolean

Value of hasrestart attribute for this service.

Default value: $sensuclassic::hasrestart

sensuclassic::client

Manages the Sensu client service

Parameters

The following parameters are available in the sensuclassic::client class.

hasrestart

Data type: Boolean

Value of hasrestart attribute for this service.

Default value: $sensuclassic::hasrestart

log_level

Data type: Any

Sensu log level to be used Valid values: debug, info, warn, error, fatal

Default value: $sensuclassic::log_level

windows_logrotate

Data type: Any

Whether or not to use logrotate on Windows OS family.

Default value: $sensuclassic::windows_logrotate

windows_log_size

Data type: Any

The integer value for the size of log files on Windows OS family. sizeThreshold in sensu-client.xml.

Default value: $sensuclassic::windows_log_size

windows_log_number

Data type: Any

The integer value for the number of log files to keep on Windows OS family. keepFiles in sensu-client.xml.

Default value: $sensuclassic::windows_log_number

client_service_enable

Data type: Any

Default value: $sensuclassic::client_service_enable

client_service_ensure

Data type: Any

Default value: $sensuclassic::client_service_ensure

sensuclassic::enterprise

Installs Sensu enterprise

Parameters

The following parameters are available in the sensuclassic::enterprise class.

deregister_handler

Data type: Optional[String]

The handler to use when deregistering a client on stop.

Default value: $sensuclassic::deregister_handler

deregister_on_stop

Data type: Optional[Boolean]

Whether the sensu client should deregister from the API on service stop

Default value: $sensuclassic::deregister_on_stop

gem_path

Data type: Optional[String]

Paths to add to GEM_PATH if we need to look for different dirs.

Default value: $sensuclassic::gem_path

init_stop_max_wait

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Number of seconds to wait for the init stop script to run

Default value: $sensuclassic::init_stop_max_wait

log_dir

Data type: Optional[String]

Sensu log directory to be used Valid values: Any valid log directory path, accessible by the sensu user

Default value: $sensuclassic::log_dir

log_level

Data type: Optional[String]

Sensu log level to be used Valid values: debug, info, warn, error, fatal

Default value: $sensuclassic::log_level

path

Data type: Optional[String]

Used to set PATH in /etc/default/sensu

Default value: $sensuclassic::path

rubyopt

Data type: Optional[String]

Ruby opts to be passed to the sensu services

Default value: $sensuclassic::rubyopt

use_embedded_ruby

Data type: Optional[Boolean]

If the embedded ruby should be used, e.g. to install the sensu-plugin gem. This value is overridden by a defined sensu_plugin_provider. Note, the embedded ruby should always be used to provide full compatibility. Using other ruby runtimes, e.g. the system ruby, is not recommended.

Default value: $sensuclassic::use_embedded_ruby

heap_size

Data type: Variant[Undef,Integer,Pattern[/^(\d+)/]]

Value of the HEAP_SIZE environment variable.

Default value: $sensuclassic::heap_size

max_open_files

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Value of the MAX_OPEN_FILES environment variable.

Default value: $sensuclassic::max_open_files

heap_dump_path

Data type: Variant[Undef,String]

Value of the HEAP_DUMP_PATH environment variable.

Default value: $sensuclassic::heap_dump_path

java_opts

Data type: Variant[Undef,String]

Value of the JAVA_OPTS environment variable.

Default value: $sensuclassic::java_opts

hasrestart

Data type: Boolean

Default value: $sensuclassic::hasrestart

sensuclassic::enterprise::dashboard

Installs the Sensu Enterprise Dashboard

Parameters

The following parameters are available in the sensuclassic::enterprise::dashboard class.

hasrestart

Data type: Boolean

Default value: $sensuclassic::hasrestart

sensuclassic::package

Installs the Sensu packages

Parameters

The following parameters are available in the sensuclassic::package class.

conf_dir

Data type: Optional[String]

The default configuration directory.

Default value: $sensuclassic::conf_dir

confd_dir

Data type: Variant[String,Array,Undef]

Additional directories to load configuration snippets from.

Default value: $sensuclassic::confd_dir

heap_size

Data type: Variant[Undef,Integer,Pattern[/^(\d+)/]]

Value of the HEAP_SIZE environment variable. Note: This has no effect on sensu-core.

Default value: $sensuclassic::heap_size

config_file

Data type: Variant[Stdlib::Absolutepath,Undef]

Value of the CONFIG_FILE environment variable.

Default value: $sensuclassic::config_file

deregister_handler

Data type: Optional[String]

The handler to use when deregistering a client on stop.

Default value: $sensuclassic::deregister_handler

deregister_on_stop

Data type: Optional[Boolean]

Whether the sensu client should deregister from the API on service stop

Default value: $sensuclassic::deregister_on_stop

gem_path

Data type: Optional[String]

Paths to add to GEM_PATH if we need to look for different dirs.

Default value: $sensuclassic::gem_path

init_stop_max_wait

Data type: Variant[Undef,Integer,Pattern[/^(\d+)$/]]

Number of seconds to wait for the init stop script to run

Default value: $sensuclassic::init_stop_max_wait

log_dir

Data type: Optional[String]

Sensu log directory to be used Valid values: Any valid log directory path, accessible by the sensu user

Default value: $sensuclassic::log_dir

log_level

Data type: Optional[String]

Sensu log level to be used Valid values: debug, info, warn, error, fatal

Default value: $sensuclassic::log_level

path

Data type: Optional[String]

Used to set PATH in /etc/default/sensu

Default value: $sensuclassic::path

env_vars

Data type: Optional[Hash[String[1], Variant[String, Boolean, Integer]]]

Additional environment variables for /etc/default/sensu

Default value: $sensuclassic::env_vars

rubyopt

Data type: Optional[String]

Ruby opts to be passed to the sensu services

Default value: $sensuclassic::rubyopt

use_embedded_ruby

Data type: Optional[Boolean]

If the embedded ruby should be used, e.g. to install the sensu-plugin gem. This value is overridden by a defined sensu_plugin_provider. Note, the embedded ruby should always be used to provide full compatibility. Using other ruby runtimes, e.g. the system ruby, is not recommended.

Default value: $sensuclassic::use_embedded_ruby

sensuclassic::rabbitmq::config

Sets the Sensu rabbitmq config

sensuclassic::redis::config

Sets the Sensu redis config

sensuclassic::repo::apt

Adds the Sensu repo to Apt

sensuclassic::repo::yum

Adds the Sensu YUM repo support

sensuclassic::server::service

Manages the Sensu server service

Parameters

The following parameters are available in the sensuclassic::server::service class.

hasrestart

Data type: Boolean

Value of hasrestart attribute for this service.

Default value: $sensuclassic::hasrestart

server_service_enable

Data type: Any

Default value: $sensuclassic::server_service_enable

server_service_ensure

Data type: Any

Default value: $sensuclassic::server_service_ensure

sensuclassic::transport

Configure Sensu Transport

Defined types

sensuclassic::check

This define manages Sensu checks

Hooks Since Sensu 1.1.0. Manages hooks for a check. See the documentation for the format of the Hash value.

Parameters

The following parameters are available in the sensuclassic::check defined type.

command

Data type: Optional[String]

The check command to run

Default value: undef

ensure

Data type: Enum['present','absent']

Whether the check should be present or not. Valid values: present, absent

Default value: 'present'

type

Data type: Optional[String]

Type of check. Set this to 'absent' to remove it completely.

Default value: undef

handlers

Data type: Variant[Undef,String,Array]

Array of Strings. Handlers to use for this check. Set this to 'absent' to remove it completely.

Default value: undef

contacts

Data type: Variant[Undef,String,Array]

Array of Strings. Contacts to use for the contact-routing Sensu Enterprise feature. This value corresponds with a sensuclassic::contact resource having the same name.

Default value: undef

standalone

Data type: Variant[Boolean,Enum['absent']]

When true, scheduled by the client. When false, listen for published check request. Set this to 'absent' to remove it completely.

Default value: true

cron

Data type: String

When the check should be executed, using the Cron syntax. Supersedes the interval parameter. Example: "0 0 * * *".

Default value: 'absent'

interval

Data type: Variant[Integer,Enum['absent']]

How frequently (in seconds) the check will be executed. Set this to 'absent' to remove it completely.

Default value: 60

occurrences

Data type: Variant[Undef,Pattern[/^(\d+)$/],Integer,Enum['absent']]

The number of event occurrences before the handler should take action. Set this to 'absent' to remove it completely.

Default value: undef

refresh

Data type: Variant[Undef,Enum['absent'],Integer]

The number of seconds sensu-plugin-aware handlers should wait before taking second action. Set this to 'absent' to remove it completely.

Default value: undef

source

Data type: Variant[Undef,String,Integer]

The check source, used to create a JIT Sensu client for an external resource (e.g. a network switch). Set this to 'absent' to remove it completely.

Default value: undef

subscribers

Data type: Variant[Undef,String,Array]

Array of Strings. Which subscriptions must execute this check. Set this to 'absent' to remove it completely.

Default value: undef

low_flap_threshold

Data type: Variant[Undef,Enum['absent'],Integer]

Flap detection - see Nagios Flap Detection. Set this to 'absent' to remove it completely.

Default value: undef

high_flap_threshold

Data type: Variant[Undef,Enum['absent'],Integer]

Flap detection - see Nagios Flap Detection. Set this to 'absent' to remove it completely.

Default value: undef

timeout

Data type: Variant[Undef,Enum['absent'],Numeric]

Check timeout in seconds, after it fails. Set this to 'absent' to remove it completely.

Default value: undef

aggregate

Data type: Optional[String]

Aggregates, preventing event floods. Set 'aggregate:' and 'handle:false', this prevents the server from sending to a handler, and makes the aggregated results available under /aggregates in the REST API. Set this to 'absent' to remove it completely.

Default value: undef

aggregates

Data type: Variant[Undef,String,Array]

Array of Strings. An array of aggregates to add to the check. This supercedes the above aggregate parameter. Set this to 'absent' to remove it completely.

Default value: undef

handle

Data type: Variant[Undef,Enum['absent'],Boolean]

When false, check will not be sent to handlers. Set this to 'absent' to remove it completely.

Default value: undef

publish

Data type: Variant[Undef,Enum['absent'],Boolean]

Unpublished checks. Prevents the check from being triggered on clients. This allows for the definition of commands that are not actually 'checks' per say, but actually arbitrary commands for remediation. Set this to 'absent' to remove it completely. Default: undef

Default value: undef

dependencies

Data type: Variant[Undef,String,Array]

List of checks this check depends on. Note: The validity of the other checks is not enforced by puppet Set this to 'absent' to remove it completely.

Default value: undef

content

Data type: Hash

Mapping of arbitrary attributes from the top-level of the target configuration JSON map. This parameter is intended to configure plugins and extensions which look up values outside of the check configuration scope. Example: { "mailer" => { "mail_from" => "[email protected]", "mail_to" => "[email protected]" } }

Default value: {}

custom

Data type: Optional[Hash]

List of custom attributes to include in the check. You can use it to pass any attribute that is not listed here explicitly. Example: { 'remediation' => { 'low_remediation' => { 'occurrences' => [1,2], 'severities' => [1], 'command' => "/bin/command", 'publish' => false, } } }

Default value: undef

ttl

Data type: Variant[Undef,Enum['absent'],Integer]

The time to live (TTL) in seconds until check results are considered stale. Set this to 'absent' to remove it completely.

Default value: undef

ttl_status

Data type: Variant[Undef,Enum['absent'],Integer,Pattern[/^(\d+)+$/]]

The exit code that a check with the ttl attribute should return. Set this to 'absent' to remove it completely.

Default value: undef

auto_resolve

Data type: Variant[Undef,Enum['absent'],Boolean]

When a check in a WARNING or CRITICAL state returns to an OK state, the event generated by the WARNING or CRITICAL state will be automatically resolved. Set this to 'absent' to remove it completely.

Default value: undef

force_resolve

Data type: Optional[Variant[Enum['absent'],Boolean]]

Setting force_resolve to true on a check result ensures that the event is resolved and removed from the registry, regardless of the current event action.

Default value: undef

subdue

Data type: Variant[Undef,Enum['absent'],Hash]

Check subdue configuration. Set this to 'absent' to remove it completely.

Default value: undef

proxy_requests

Data type: Variant[Undef,Enum['absent'],Hash]

Manages Proxy Check Requests Since Sensu 0.28.0. Publishes a check request to every Sensu client which matches the defined client attributes. See the documentation for the format of the Hash value.

Default value: undef

hooks

Data type: Variant[Undef,Enum['absent'],Hash]

Manages

Default value: undef

output_format

Data type: Optional[String[1]]

Docs A metric output format

Default value: undef

handle_when

Data type: Optional[Struct[{'occurrences' => Integer, 'reset' => Integer}]]

Docs The handle_when enterprise filter is used to reduce notification “noise”

Default value: undef

extension

Data type: Optional[String]

The name of a Sensu check extension to run instead of a command.

Default value: undef

truncate_output

Data type: Optional[Boolean]

If check output will be truncated for storage.

Default value: undef

truncate_output_length

Data type: Optional[Integer]

The output truncation length, the maximum number of characters.

Default value: undef

sensuclassic::config

 This define manages Sensu check configurations.

Parameters

The following parameters are available in the sensuclassic::config defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not Valid values: present, absent

Default value: 'present'

config

Data type: Optional[Hash]

Check configuration for the client to use

Default value: undef

event

Data type: Optional[Hash]

Configuration to send with the event to handlers

Default value: undef

sensuclassic::contact

Manage Contact Routing configuration with Sensu Enterprise.

Note: If the sensu::purge_config class parameter is true, unmanaged sensu::contact resources located in /etc/sensu/conf.d/contacts will be purged.

Parameters

The following parameters are available in the sensuclassic::contact defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not.

Default value: 'present'

base_path

Data type: Optional[String]

Where to place the contact JSON configuration file. Defaults to undef which defers to the behavior of the underlying sensuclassic_contact type.

Default value: undef

config

Data type: Hash

The configuration data for the contact. This is an arbitrary hash to accommodate the various communication channels. For example, { "email": { "to": "[email protected]" } }.

Default value: {}

sensuclassic::enterprise::dashboard::api

Manages the Sensu Enterprise API configuration

not mounted to /.

Parameters

The following parameters are available in the sensuclassic::enterprise::dashboard::api defined type.

host

The hostname or IP address of the Sensu API. This is used as the namevar for the underlying resource, so must be unique within the catalog.

ensure

Data type: Enum['present','absent']

Whether the dashboard API should be configured or not

Default value: present

base_path

Data type: Optional[String]

The base path to the client config file.

Default value: undef

datacenter

Data type: Optional[String]

The datacenter name.

Default value: undef

port

Data type: Optional[Integer]

The port of the Sensu API.

Default value: undef

ssl

Data type: Optional[Boolean]

Whether or not to use the HTTPS protocol.

Default value: undef

insecure

Data type: Optional[Boolean]

Whether or not to accept an insecure SSL certificate.

Default value: undef

path

Data type: Optional[String]

The path of the Sensu API. Leave empty unless your Sensu API is

Default value: undef

timeout

Data type: Optional[Integer]

The timeout for the Sensu API, in seconds.

Default value: undef

user

Data type: Optional[String]

The username of the Sensu API. Leave empty for no authentication.

Default value: undef

pass

Data type: Optional[String]

The password of the Sensu API. Leave empty for no authentication.

Default value: undef

sensuclassic::extension

This define manages Sensu extensions

Parameters

The following parameters are available in the sensuclassic::extension defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not

Default value: 'present'

source

Data type: Optional[Pattern[/^puppet:\/\//]]

Source of the puppet extension

Default value: undef

install_path

Data type: String

Path where to install the extension

Default value: '/etc/sensu/extensions'

config

Data type: Hash

Extension specific config

Default value: {}

sensuclassic::filter

Defines Sensu filters

Parameters

The following parameters are available in the sensuclassic::filter defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not

Default value: 'present'

negate

Data type: Optional[Boolean]

Negate the filter

Default value: undef

attributes

Data type: Optional[Hash]

Hash of attributes for the filter

Default value: undef

when

Data type: Optional[Hash]

Hash of when entries for the filter

Default value: undef

sensuclassic::handler

Defines Sensu handlers

Parameters

The following parameters are available in the sensuclassic::handler defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not

Default value: 'present'

type

Data type: Enum['pipe','tcp','udp','amqp','set','transport']

Type of handler

Default value: 'pipe'

command

Data type: Optional[String]

Command to run as the handler when type=pipe

Default value: undef

handlers

Data type: Optional[Array]

Handlers to use when type=set

Default value: undef

severities

Data type: Array

Severities handler is valid for

Default value: ['ok', 'warning', 'critical', 'unknown']

exchange

Data type: Optional[Hash]

Exchange information used when type=amqp Keys: host, port

Default value: undef

pipe

Data type: Optional[Hash]

Pipe information used when type=transport Keys: name, type, options

Default value: undef

socket

Data type: Optional[Hash]

Socket information when type=tcp or type=udp Keys: host, port

Default value: undef

filters

Data type: Array

Filter commands to apply

Default value: []

source

Data type: Optional[Pattern[/^puppet:\/\//]]

Source of the puppet handler

Default value: undef

install_path

Data type: String

Path to install the handler

Default value: $::osfamily

config

Data type: Optional[Hash]

Handler specific config

Default value: undef

timeout

Data type: Optional[Integer]

Handler timeout configuration

Default value: undef

handle_flapping

Data type: Boolean

If events in the flapping state should be handled.

Default value: false

handle_silenced

Data type: Boolean

If events in the silenced state should be handled.

Default value: false

mutator

Data type: Any

The handle mutator. Valid values: Any kind of data which can be added to the handler mutator.

Default value: undef

subdue

Data type: Any

The handle subdue. Valid values: Any kind of data which can be added to the handler subdue.

Default value: undef

sensuclassic::mutator

This define manages Sense mutators

Parameters

The following parameters are available in the sensuclassic::mutator defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not

Default value: 'present'

command

Data type: String

Command to run.

timeout

Data type: Optional[Numeric]

The mutator execution duration timeout in seconds (hard stop).

Default value: undef

source

Data type: Optional[String]

Source of the puppet mutator

Default value: undef

install_path

Data type: Stdlib::Absolutepath

Path to install the mutator

Default value: '/etc/sensu/mutators'

sensuclassic::plugin

Installs the Sensu community script and plugins which can be used as monitoring checks

Parameters

The following parameters are available in the sensuclassic::plugin defined type.

type

Data type: Enum['file','url','package','directory']

Plugin source Valid values: file, directory, package, url

Default value: 'file'

install_path

Data type: Stdlib::Absolutepath

The path to install the plugin

Default value: $::osfamily

purge

Data type: Boolean

When using a directory source, purge setting

Default value: true

recurse

Data type: Boolean

When using a directory source, recurse setting

Default value: true

force

Data type: Boolean

When using a directory source, force setting

Default value: true

pkg_version

Data type: Pattern[/^absent$/,/^installed$/,/^latest$/,/^present$/,/^[\d\.\-]+$/]

When using package source, version to install

Default value: 'latest'

pkg_provider

Data type: Optional[String]

When using package to install plugins, provider to use. Valid values: sensuclassic_gem, apt, aptitude, yum

Default value: $sensuclassic::sensu_plugin_provider

pkg_checksum

Data type: Optional[String]

The packake's MD5 checksum. Valid values: Any valid MD5 string of the wanted package

Default value: undef

nocheckcertificate

Data type: Boolean

When using url source, disable certificate checking for HTTPS

Default value: false

gem_install_options

Data type: Any

Optional configuration to use for the installation of the sensu plugin gem with sensuclassic_gem provider. See: https://docs.puppetlabs.com/references/latest/type.html#package-attribute-install_options Example value: [{ '-p' => 'http://user:[email protected]:8080' }]

Default value: $sensuclassic::gem_install_options

pkg_proxy_host

Data type: Optional[String]

The proxy host used to download the plugin when type is url

Default value: $sensuclassic::package_proxy_host

pkg_proxy_port

Data type: Optional[Stdlib::Port]

The proxy port used to download the plugin when type is url

Default value: $sensuclassic::package_proxy_port

sensuclassic::plugins_dir

This define verifies if install_dir exists without duplicate declarations

Parameters

The following parameters are available in the sensuclassic::plugins_dir defined type.

force

Data type: Boolean

Value of the parameter force of file resource for the managed directory.

purge

Data type: Boolean

Value of the parameter purge of file resource for the managed directory.

recurse

Data type: Boolean

Value of the parameter recurse of file resource for the managed directory.

path

Data type: String

Path of the directory to create. If not defined the $title is used.

Default value: $name

sensuclassic::subscription

This define manages Sensu subscriptions

Parameters

The following parameters are available in the sensuclassic::subscription defined type.

ensure

Data type: Enum['present','absent']

Whether the check should be present or not

Default value: 'present'

custom

Data type: Hash

Custom client variables

Default value: {}

sensuclassic::write_json

Writes arbitrary hash data to a config file. Note: you must manually notify any Sensu services to restart them when using this defined resource type.

Examples

sensuclassic::write_json { '/etc/sensu/conf.d/check.json':
  content => {"config" => {"key" => "value"}},
  notify  => [
    Service['sensu-client'],
    Service['sensu-server'],
  ],
}

Parameters

The following parameters are available in the sensuclassic::write_json defined type.

ensure

Data type: Enum['present', 'absent']

Whether the file should be present or not.

Default value: 'present'

owner

Data type: String

The file owner.

Default value: 'sensu'

group

Data type: String

The file group.

Default value: 'sensu'

mode

Data type: Stdlib::Filemode

The file mode.

Default value: '0775'

pretty

Data type: Boolean

Write the json with "pretty" indenting & formating.

Default value: true

content

Data type: Hash

The hash content that will be converted to json and written into the target config file.

Default value: {}

notify_list

Data type: Array[Variant[Data,Type]]

Array of resources to notify upon changes to the target JSON file.

Default value: []

Resource types

sensuclassic_api_config

Manages Sensu API config

Properties

The following properties are available in the sensuclassic_api_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

port

The port that the Sensu API is listening on

Default value: 4567

host

The hostname that the Sensu API is listening on

Default value: 127.0.0.1

bind

The bind IP that sensu will bind to

Default value: 0.0.0.0

user

The username used for clients to authenticate against the Sensu API

password

The password use for client authentication against the Sensu API

ssl_port

Port of the HTTPS (SSL) sensu api service. Enterprise only feature.

ssl_keystore_file

The file path for the SSL certificate keystore. Enterprise only feature.

ssl_keystore_password

The SSL certificate keystore password. Enterprise only feature.

Parameters

The following parameters are available in the sensuclassic_api_config type.

name

namevar

This value has no effect, set it to what ever you want.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/

sensuclassic_check

Manages Sensu checks

Properties

The following properties are available in the sensuclassic_check type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

command

Valid values: /.*/, absent

Command to be run by the check

dependencies

Valid values: /.*/, absent

Dependencies of this check

handlers

Valid values: /.*/, absent

List of handlers that responds to this check

contacts

Valid values: /^[\w.-]+$/, absent

Contact names to override handler configuration via Contact Routing

high_flap_threshold

Valid values: /.*/, absent

A host is determined to be flapping when the percent change exceedes this threshold.

cron

Valid values: /.*/, absent

When the check should be executed, using the Cron syntax.

interval

Valid values: /.*/, absent

How frequently the check runs in seconds

occurrences

Valid values: /.*/, absent

The number of event occurrences before the handler should take action.

refresh

Valid values: /.*/, absent

The number of seconds sensu-plugin-aware handlers should wait before taking second action.

low_flap_threshold

Valid values: /.*/, absent

A host is determined to be flapping when the percent change is below this threshold.

source

Valid values: /.*/, absent

The check source, used to create a JIT Sensu client for an external resource (e.g. a network switch).

subscribers

Valid values: /.*/, absent

Who is subscribed to this check

custom

Custom check variables

type

Valid values: /.*/, absent

What type of check is this

standalone

Valid values: /.*/, absent

Whether this is a standalone check

timeout

Valid values: /.*/, absent

Check timeout in seconds, after it fails

aggregate

Valid values: /.*/, absent

Whether check is aggregate

aggregates

Valid values: /.*/, absent

An array of aggregates to add to the check

handle

Valid values: /.*/, absent

Whether check event send to a handler

publish

Valid values: /.*/, absent

Whether check is unpublished

subdue

Valid values: /.*/, absent

Check subdue

proxy_requests

Valid values: /.*/, absent

Proxy Requests

ttl

Valid values: /.*/, absent

Check ttl in seconds

ttl_status

Valid values: /.*/, absent

Exit code for ttl

output_format

Valid values: /.*/, absent

A metric output format

handle_when

The handle_when enterprise filter is used to reduce notification 'noise'

Parameters

The following parameters are available in the sensuclassic_check type.

name

namevar

The name of the check.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/checks

sensuclassic_check_config

""

Properties

The following properties are available in the sensuclassic_check_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

Parameters

The following parameters are available in the sensuclassic_check_config type.

name

namevar

base_path
config
event
name

The check name to configure

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/checks

config

Check configuration for the client to use

event

Configuration to send with the event to handlers

sensuclassic_client_config

Manages Sensu client config

Properties

The following properties are available in the sensuclassic_client_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

client_name

""

address

""

subscriptions

Valid values: /.*/, absent

""

redact

Valid values: /.*/, absent

An array of strings that should be redacted in the sensu client config

socket

A set of attributes that configure the Sensu client socket.

safe_mode

Require checks to be defined on server and client

Default value: false

custom

Custom client attributes. Any key that is also set by a property of this type will be ignored and should not be included in this property.

deregister

Enable client de-registration

deregistration

Valid values: /.*/, absent

Client deregistration attributes

registration

Valid values: /.*/, absent

Client registration attributes

keepalive

Keepalive config

http_socket

A set of attributes that configure the Sensu client http socket.

servicenow

Configure Service Now integration on Sensu client.

ec2

Configure ec2 integration on Sensu client.

chef

Configure Chef integration on Sensu client.

puppet

Configure Puppet integration on Sensu client.

Parameters

The following parameters are available in the sensuclassic_client_config type.

name

namevar

The name of the host

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/

sensuclassic_client_subscription

Manages Sensu client subscriptions

Properties

The following properties are available in the sensuclassic_client_subscription type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

subscriptions

Subscriptions included, defaults to resource name

custom

Custom client variables

Parameters

The following parameters are available in the sensuclassic_client_subscription type.

name

namevar

The subscription name

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/

file_name

The name of the client config file

sensuclassic_contact

Manages Sensu contacts

Properties

The following properties are available in the sensuclassic_contact type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

config

Configuration hash for the contact.

Parameters

The following parameters are available in the sensuclassic_contact type.

name

Valid values: /^[\w.-]+$/

namevar

The name of the contact, e.g. "support"

base_path

The base path to the contact config file

Default value: /etc/sensu/conf.d/contacts/

sensuclassic_enterprise_dashboard_api_config

Manages Sensu Enterprise Dashboard API config

Properties

The following properties are available in the sensuclassic_enterprise_dashboard_api_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

datacenter

The name of the Sensu API (used elsewhere as the datacenter name).

port

Valid values: /[0-9]+/

The port of the Sensu API.

Default value: 4567

ssl

Determines whether or not to use the HTTPS protocol.

Default value: false

insecure

Determines whether or not to accept an insecure SSL certificate.

Default value: false

path

The path of the Sensu API. Leave empty unless your Sensu API is not mounted to /.

timeout

Valid values: /[0-9]+/

The timeout for the Sensu API, in seconds.

Default value: 5

user

Valid values: /.+/

The username of the Sensu API. Leave empty for no authentication.

pass

Valid values: /.+/

The password of the Sensu API. Leave empty for no authentication.

Parameters

The following parameters are available in the sensuclassic_enterprise_dashboard_api_config type.

host

namevar

The hostname or IP address of the Sensu API.

base_path

The base path to the client config file

Default value: /etc/sensu/

sensuclassic_enterprise_dashboard_config

Manages Sensu Enterprise Dashboard config

Properties

The following properties are available in the sensuclassic_enterprise_dashboard_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

host

The hostname or IP address on which Sensu Enterprise Dashboard will listen on.

Default value: 0.0.0.0

port

The port on which Sensu Enterprise Dashboard will listen on.

Default value: 3000

refresh

Determines the interval to poll the Sensu APIs, in seconds.

Default value: 5

user

A username to enable simple authentication and restrict access to the dashboard. Leave blank along with pass to disable simple authentication.

pass

A password to enable simple authentication and restrict access to the dashboard. Leave blank along with user to disable simple authentication.

auth

The auth definition scope, used to configure JSON Web Token (JWT) authentication signatures.

ssl

A hash of SSL attributes to enable native SSL

audit

A hash of audit attributes to enable audit logging

github

A hash of GitHub authentication attributes to enable GitHub authentication via OAuth. Overrides simple authentication.

gitlab

A hash of GitLab authentication attributes to enable GitLab authentication via OAuth. Overrides simple authentication.

ldap

A hash of Lightweight Directory Access Protocol (LDAP) authentication attributes to enable LDAP authentication. Overrides simple authentication.

oidc

The oidc definition scope, used to configure Role Based Access Controls with the RBAC for OpenID Connect (OIDC) driver. Overrides simple authentication.

custom

Custom config variables

Parameters

The following parameters are available in the sensuclassic_enterprise_dashboard_config type.

name

namevar

This value has no effect, set it to what ever you want.

base_path

The base path to the client config file

Default value: /etc/sensu/

sensuclassic_extension

Manages Sensu extensions

Properties

The following properties are available in the sensuclassic_extension type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

config

The configuration for this extension

Parameters

The following parameters are available in the sensuclassic_extension type.

name

namevar

This value has no effect, set it to what ever you want.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/extensions/

sensuclassic_filter

Manages Sensu filters

Properties

The following properties are available in the sensuclassic_filter type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

attributes

Filter attributes

when

Used to determine when a filter is applied.

negate

""

Default value: false

Parameters

The following parameters are available in the sensuclassic_filter type.

name

namevar

The name of the filter.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/filters/

sensuclassic_handler

Manages Sensu handlers

Properties

The following properties are available in the sensuclassic_handler type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

type

Type of handler

command

Command the handler should run

exchange

Exchange information used by the amqp type

pipe

Pipe information used by the transport type

socket

Socket information used by the udp type

mutator

Handler specific data massager

filters

Handler filters

severities

Severities applicable to this handler

handlers

Handlers this handler mutexes into

config

Handler specific config

timeout

Handler timeout

handle_flapping

If events in the flapping state should be handled

handle_silenced

If events in the silenced state should be handled

Parameters

The following parameters are available in the sensuclassic_handler type.

name

namevar

The name of the handler

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/handlers/

sensuclassic_mutator

Manages Sensu mutators

Properties

The following properties are available in the sensuclassic_mutator type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

command

Command the mutator should run

timeout

The mutator execution duration timeout in seconds (hard stop).

Parameters

The following parameters are available in the sensuclassic_mutator type.

name

namevar

The name of the mutator

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/mutators/

sensuclassic_rabbitmq_config

Manages Sensu RabbitMQ config

Properties

The following properties are available in the sensuclassic_rabbitmq_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

ssl_transport

Enable SSL transport to connect to RabbitMQ

Default value: false

ssl_private_key

The path on disk to the SSL private key needed to connect to RabbitMQ

Default value: ''

ssl_cert_chain

The path on disk to the SSL cert chain needed to connect to RabbitMQ

Default value: ''

port

The port that RabbitMQ is listening on

host

The hostname that RabbitMQ is listening on

user

The username to use when connecting to RabbitMQ

password

The password to use when connecting to RabbitMQ

vhost

The vhost to use when connecting to RabbitMQ

heartbeat

The RabbitMQ heartbeat value

prefetch

The RabbitMQ AMQP consumer prefetch value

cluster

Rabbitmq Cluster

Parameters

The following parameters are available in the sensuclassic_rabbitmq_config type.

name

namevar

This value has no effect, set it to what ever you want.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/

sensuclassic_redis_config

Manages Sensu Redis config

Properties

The following properties are available in the sensuclassic_redis_config type.

ensure

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

port

The port that Redis is listening on

host

The hostname that Redis is listening on

password

The password used to connect to Redis

reconnect_on_error

Attempt to reconnect to RabbitMQ on error

Default value: true

db

The Redis instance DB to use/select

Default value: 0

auto_reconnect

Reconnect to Redis in the event of a connection failure

Default value: true

tls

Valid values: true, false

Use TLS encryption to connect to Redis

Default value: false

sentinels

Redis Sentinel configuration for HA clustering

Default value: []

master

Redis master name in the sentinel configuration

Default value: absent

Parameters

The following parameters are available in the sensuclassic_redis_config type.

name

namevar

This value has no effect, set it to what ever you want.

base_path

The base path to the client config file

Default value: /etc/sensu/conf.d/

Functions

sensuclassic_sorted_json

Type: Ruby 4.x API

This function takes unsorted hash and outputs JSON object making sure the keys are sorted. Optionally you can pass a boolean as the second parameter, which controls if the output is pretty formatted.

Examples

Calling function without pretty
unsorted_hash = {
  'client_addr' => '127.0.0.1',
  'bind_addr'   => '192.168.34.56',
  'start_join'  => [
    '192.168.34.60',
    '192.168.34.61',
    '192.168.34.62',
  ],
  'ports'       => {
    'rpc'   => 8567,
    'https' => 8500,
    'http'  => -1,
  },
}
sorted_json(unsorted_hash)

{"bind_addr":"192.168.34.56","client_addr":"127.0.0.1",
"ports":{"http":-1,"https":8500,"rpc":8567},
"start_join":["192.168.34.60","192.168.34.61","192.168.34.62"]}
Calling function with pretty output
sorted_json(unsorted_hash, true)

{
    "bind_addr": "192.168.34.56",
    "client_addr": "127.0.0.1",
    "ports": {
        "http": -1,
        "https": 8500,
        "rpc": 8567
    },
    "start_join": [
        "192.168.34.60",
        "192.168.34.61",
        "192.168.34.62"
    ]
}

sensuclassic_sorted_json(Hash $hash, Optional[Boolean] $pretty)

This function takes unsorted hash and outputs JSON object making sure the keys are sorted. Optionally you can pass a boolean as the second parameter, which controls if the output is pretty formatted.

Returns: String Returns a JSON string

Examples
Calling function without pretty
unsorted_hash = {
  'client_addr' => '127.0.0.1',
  'bind_addr'   => '192.168.34.56',
  'start_join'  => [
    '192.168.34.60',
    '192.168.34.61',
    '192.168.34.62',
  ],
  'ports'       => {
    'rpc'   => 8567,
    'https' => 8500,
    'http'  => -1,
  },
}
sorted_json(unsorted_hash)

{"bind_addr":"192.168.34.56","client_addr":"127.0.0.1",
"ports":{"http":-1,"https":8500,"rpc":8567},
"start_join":["192.168.34.60","192.168.34.61","192.168.34.62"]}
Calling function with pretty output
sorted_json(unsorted_hash, true)

{
    "bind_addr": "192.168.34.56",
    "client_addr": "127.0.0.1",
    "ports": {
        "http": -1,
        "https": 8500,
        "rpc": 8567
    },
    "start_join": [
        "192.168.34.60",
        "192.168.34.61",
        "192.168.34.62"
    ]
}
hash

Data type: Hash

Hash to be sorted

pretty

Data type: Optional[Boolean]

Boolean that determines if output should be pretty format