aboutsummaryrefslogtreecommitdiffstats
path: root/manifests/honeycomb/configure_role_mappings.pp
blob: 826f6e67b3527d72feb1182f267ede72e0a4187f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# == Define: fdio::honeycomb::configure_role_mappings
#
# Defined type to configure interface role mapping in OpenDaylight
#
# === Parameters:
# [*honeycomb_username*]
#   User name for Honeycomb.
#
# [*honeycomb_password*]
#   Password for Honeycomb.
#
# [*honeycomb_url*]
#   Honeycomb restconf binding URL.
#
# [*interface_role_mapping*]
#   List of interface role mapping in the format
#              of <VPP interface name>:<role name>
#   Example:
#      [ 'GigabitEthernet0/5/0:public-interface',
#        'GigabitEthernet0/6/0:tenant-interface' ]
#
define fdio::honeycomb::configure_role_mappings (
  $honeycomb_username,
  $honeycomb_password,
  $honeycomb_url,
  $interface_role_mapping = $title,
) {
  $mapping = split($interface_role_mapping, ':')
  $vpp_int = regsubst($mapping[0], '/', '%2F', 'G')
  $role_name = $mapping[1]
  $config_url = "${honeycomb_url}/restconf/config/ietf-interfaces:interfaces/interface/${vpp_int}"

  exec { "Register interface ${mapping[0]} with role ${role_name}":
    command   => "curl -XPOST --fail -H 'Content-Type: application/json' -u ${honeycomb_username}:${honeycomb_password} ${config_url} -d \"{'description': '${role_name}'}\"",
    tries     => 5,
    try_sleep => 30,
    path      => '/usr/sbin:/usr/bin:/sbin:/bin',
    unless    => "curl -u ${honeycomb_username}:${honeycomb_password} ${config_url} | grep '${role_name}'",
  }
}