summaryrefslogtreecommitdiffstats
path: root/docs/links
AgeCommit message (Expand)AuthorFilesLines
2018-09-18docs: Added Related Projects and Archivejdenisco1-10/+13
2018-08-14DOCS: Moved multiarch and build system, Incorprated Scott's changesJohn DeNisco1-3/+3
2018-08-13DOCS: Cleanup Getting StartedJohn DeNisco1-0/+33
96' href='#n96'>96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195
/*
 * Copyright (c) 2017 Cisco and/or its affiliates.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef __VOM_BRIDGE_DOMAIN_ARP_ENTRY_H__
#define __VOM_BRIDGE_DOMAIN_ARP_ENTRY_H__

#include "vom/bridge_domain.hpp"
#include "vom/interface.hpp"
#include "vom/singular_db.hpp"
#include "vom/types.hpp"

namespace VOM {
/**
 * A entry in the ARP termination table of a Bridge Domain
 */
class bridge_domain_arp_entry : public object_base
{
public:
  /**
   * The key for a bridge_domain ARP entry;
   *  the BD, IP address and MAC address
   */
  typedef std::pair<bridge_domain::key_t, boost::asio::ip::address> key_t;

  /**
   * Construct a bridge domain ARP Entry in the given bridge domain
   */
  bridge_domain_arp_entry(const bridge_domain& bd,
                          const boost::asio::ip::address& ip_addr,
                          const mac_address_t& mac);

  /**
   * Construct a bridge domain ARP entry in the default table
   */
  bridge_domain_arp_entry(const boost::asio::ip::address& ip_addr,
                          const mac_address_t& mac);

  /**
   * Copy Construct
   */
  bridge_domain_arp_entry(const bridge_domain_arp_entry& r);

  /**
   * Destructor
   */
  ~bridge_domain_arp_entry();

  /**
   * Return the object's key
   */
  const key_t key() const;

  /**
   * comparison operator
   */
  bool operator==(const bridge_domain_arp_entry& bdae) const;

  /**
   * Return the matching 'singular instance'
   */
  std::shared_ptr<bridge_domain_arp_entry> singular() const;

  /**
   * Find the instnace of the bridge_domain domain in the OM
   */
  static std::shared_ptr<bridge_domain_arp_entry> find(const key_t& k);

  /**
   * Dump all bridge_domain-doamin into the stream provided
   */
  static void dump(std::ostream& os);

  /**
   * replay the object to create it in hardware
   */
  void replay(void);

  /**
   * Convert to string for debugging
   */
  std::string to_string() const;

private:
  /**
   * Class definition for listeners to OM events
   */
  class event_handler : public OM::listener, public inspect::command_handler
  {
  public:
    event_handler();
    virtual ~event_handler() = default;

    /**
     * Handle a populate event
     */
    void handle_populate(const client_db::key_t& key);

    /**
     * Handle a replay event
     */
    void handle_replay();

    /**
     * Show the object in the Singular DB
     */
    void show(std::ostream& os);

    /**
     * Get the sortable Id of the listener
     */
    dependency_t order() const;
  };

  /**
   * event_handler to register with OM
   */
  static event_handler m_evh;

  /**
   * Commit the acculmulated changes into VPP. i.e. to a 'HW" write.
   */
  void update(const bridge_domain_arp_entry& obj);

  /**
   * Find or add the instnace of the bridge_domain domain in the OM
   */
  static std::shared_ptr<bridge_domain_arp_entry> find_or_add(
    const bridge_domain_arp_entry& temp);

  /*
   * It's the VPPHW class that updates the objects in HW
   */
  friend class OM;

  /**
   * It's the singular_db class that calls replay()
   */
  friend class singular_db<key_t, bridge_domain_arp_entry>;

  /**
   * Sweep/reap the object if still stale
   */
  void sweep(void);

  /**
   * HW configuration for the result of creating the bridge_domain
   */
  HW::item<bool> m_hw;

  /**
   * The bridge_domain domain the bridge_domain is in.
   */
  std::shared_ptr<bridge_domain> m_bd;

  /**
   * The IP address
   */
  boost::asio::ip::address m_ip_addr;

  /**
   * The mac to return
   */
  mac_address_t m_mac;

  /**
   * A map of all bridge_domains
   */
  static singular_db<key_t, bridge_domain_arp_entry> m_db;
};

std::ostream& operator<<(std::ostream& os,
                         const bridge_domain_arp_entry::key_t& key);
}; // namespace

/*
 * fd.io coding-style-patch-verification: ON
 *
 * Local Variables:
 * eval: (c-set-style "mozilla")
 * End:
 */

#endif