Puppet Class: datadog_agent::integrations::kong
- Inherits:
- datadog_agent::params
- Defined in:
- manifests/integrations/kong.pp
Overview
Class: datadog_agent::integrations::kong
This class will install the necessary configuration for the Kong integration
Note: if you’re Cassandra data-store is large in size the ‘/status` page may take a long time to return. <github.com/Mashape/kong/issues/1323>
Parameters:
$instances:
Array of hashes for all Kong instances and associated tags. See example
Sample Usage:
class { 'datadog_agent::integrations::kong':
instances => [
{
'status_url' => http://localhost:8001/status/',
},
{
'status_url' => 'http://localhost:8001/status/',
'tags' => ['instance:foo'],
},
],
}
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 56 57 58 59 60 61 62 63 64 65 66 |
# File 'manifests/integrations/kong.pp', line 27
class datadog_agent::integrations::kong (
$instances = [
{
'status_url' => 'http://localhost:8001/status/',
'tags' => []
}
]
) inherits datadog_agent::params {
require ::datadog_agent
$legacy_dst = "${datadog_agent::params::legacy_conf_dir}/kong.yaml"
if $::datadog_agent::_agent_major_version > 5 {
$dst_dir = "${datadog_agent::params::conf_dir}/kong.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_file,
content => template('datadog_agent/agent-conf.d/kong.yaml.erb'),
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
}
|