decap_group

Tunnel decapsulation group management.

This module manages tunnel decapsulation for traffic arriving at the switch (on any interface). This allows the switch to act as a tunnel endpoint.

By configuring a “decap group”, the switch will decapsulate traffic matching the specified outer (tunnel) header destination IP address and IP protocol. Presently only GRE traffic (protocol 47) is supported by decap groups. Traffic arriving at the switch matching the group’s parameters will be decapsulated and forwarded normally based on the inner protocol headers.

In this example, a decap group named “gre_tunnel1” is configured for GRE traffic arriving at the switch with a tunnel destination address of 172.12.0.1. That address may either be bound to a local switch interface or announced by the switch in routing protocols.

// Configures a decapsulation group to unwrap received GRE traffic
eos::decap_group_t tunnel("gre_tunnel1",
                          eos::ip_addr_t("172.12.0.1"),
                          eos::PROTOCOL_TYPE_GRE);
mgr->decap_group_set(tunnel);

namespace eos
class decap_group_iter_t
#include <decap_group.h>

An iterator that yields a decap_group_t for each configured decap group.

Private Functions

decap_group_iter_t(decap_group_iter_impl * const)

Friends

friend class decap_group_iter_impl
class decap_group_mgr
#include <decap_group.h>

A manager of ‘ip decap-group’ configurations.

Create one of these via sdk object prior to starting the agent main loop. When your eos::agent_handler::on_initialized virtual function is called, the manager is valid for use.

Public Functions

virtual ~decap_group_mgr()
virtual void resync_init() = 0

Enter resync mode.

At this point the decap_group_mgr will start tracking which groups you’ve added.

virtual void resync_complete() = 0

Exit resync mode.

All decap groups in Sysdb that you haven’t re-added during this resync period will now be deleted.

virtual decap_group_iter_t decap_group_iter() const = 0

Iterates over all the decap groups currently configured.

virtual decap_group_t decap_group(std::string const & decap_group_name) const = 0

Returns the current configuration of a decap group

If no decap group exists, this returns an empty decap_group_t()

virtual void decap_group_set(decap_group_t const &) = 0

Adds the specified decap group to the system configuration.

Either creates or updates a decap group (keyed by the group name).

virtual void decap_group_del(std::string const & decap_group_name) = 0

Removes the named decap group from the configuration.

If the specified group name does not exist, no action is taken.

Protected Functions

decap_group_mgr()

Private Members

decap_group_mgr

Type definitions in decap_group

namespace eos

Enums

decap_protocol_type_t enum

Inner (IP) protocol to match for a decap group, only the GRE protocol is presently supported.

Values:

  • PROTOCOL_TYPE_NULL -
  • PROTOCOL_TYPE_GRE -
class decap_group_t
#include <decap_group.h>

An IP decap group configuration model. At this time, all decap groups are configured in the default VRF.

Public Functions

decap_group_t()
decap_group_t(std::string const & group_name, ip_addr_t const & destination_addr, decap_protocol_type_t protocol_type)
std::string group_name() const

Getter for ‘group_name’: the decap group name. Used to uniquely identify this group.

ip_addr_t destination_addr() const

Getter for ‘destination_addr’: match this destination IP on the outermost IP header.

void destination_addr_is(ip_addr_t const & destination_addr)

Setter for ‘destination_addr’.

decap_protocol_type_t protocol_type() const

Getter for ‘protocol_type’: decapsulate only packets matching this outer IP protocol type.

void protocol_type_is(decap_protocol_type_t protocol_type)

Setter for ‘protocol_type’.

bool operator==(decap_group_t const & other) const
bool operator!=(decap_group_t const & other) const
bool operator<(decap_group_t const & other) const
uint32_t hash() const

The hash function for type decap_group_t.

std::string to_string() const

Returns a string representation of the current object’s values.

Private Members

std::string group_name_
ip_addr_t destination_addr_
decap_protocol_type_t protocol_type_

Friends

friend std::ostream & operator<<

A utility stream operator that adds a string representation of decap_group_t to the ostream.

Table Of Contents

Previous topic

class_map

Next topic

directflow