Puppet Class: datadog_agent::integrations::generic
- Inherits:
- datadog_agent::params
- Defined in:
- manifests/integrations/generic.pp
Overview
Class: datadog_agent::integrations::generic
This class will install a configuration file for an integration
Parameters:
$integration_name:
This will be used to build the filename. It must correspond to an
integration that is supported by dd-agent, see the dd-agent for
a current list.
$integration_contents:
String containing a rendered template.
Sample Usage:
class { ‘datadog_agent::integrations::generic’:
integration_name => 'custom',
integration_contents => template(my_custom_template),
}
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'manifests/integrations/generic.pp', line 20
class datadog_agent::integrations::generic(
Optional[String] $integration_name = undef,
Optional[String] $integration_contents = undef,
) inherits datadog_agent::params {
require ::datadog_agent
$legacy_dst = "${datadog_agent::params::legacy_conf_dir}/${integration_name}.yaml"
if $::datadog_agent::_agent_major_version > 5 {
$dst_dir = "${datadog_agent::params::conf_dir}/${integration_name}.d"
file { $legacy_dst:
ensure => 'absent'
}
file { $dst_dir:
ensure => directory,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => $datadog_agent::params::permissions_directory,
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
$dst = "${dst_dir}/conf.yaml"
} else {
$dst = $legacy_dst
}
file { $dst:
ensure => file,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => $datadog_agent::params::permissions_protected_file,
content => $integration_contents,
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
}
|