24 #include <ovsdb_types.h> 
   26 using namespace OVSDB;
 
   29         const std::string &logical_switch) : 
OvsdbDBEntry(table),
 
   30     logical_switch_name_(logical_switch), route_table_(NULL),
 
   31     oper_route_table_(NULL) {
 
  115         struct ovsdb_idl_row *row) {
 
  117     const char *logical_switch =
 
  120     if (logical_switch == NULL)
 
  125     if (vrf_ovsdb == NULL) {
 
  141             key.dest_ip_ = std::string(dest_ip);
 
  146             key.dest_ip_ = std::string(dest_ip);
 
  174     if (vrf->
vn() == NULL) {
 
  178     if (ovsdb_entry != NULL) {
 
  198     if (
false == args.
Get(
"mac", &
mac_)) {
 
  204         std::string resp_ctx, 
const std::string &ip, uint32_t port,
 
  205         const std::string &logical_switch, 
const std::string &mac) :
 
  237     OvsdbVrfEntry ventry;
 
  242     ventry.set_unicast_remote_table(
task.EncodeFirstPage());
 
  243     OvsdbVrfResp *vrf_resp = 
static_cast<OvsdbVrfResp *
>(resp);
 
  245     std::vector<OvsdbVrfEntry> &vrf_list =
 
  246         const_cast<std::vector<OvsdbVrfEntry>&
>(vrf_resp->get_vrfs());
 
  247     vrf_list.push_back(ventry);
 
  258 void OvsdbVrfReq::HandleRequest()
 const {
 
  261                                 get_session_remote_port(),
 
  262                                 get_logical_switch(), get_mac());
 
bool Add(const std::string &key, const std::string &val)
bool Get(const std::string &key, std::string *val) const
DBTableBase * GetDBTable()
std::string StateString() const
KSyncEntry * Find(const KSyncEntry *key)
void SafeNotifyEvent(KSyncEntry *entry, KSyncEntry::KSyncEvent event)
KSyncEntry * CreateStale(const KSyncEntry *key)
VrfOvsdbObject * vrf_ovsdb()
OvsdbClientIdl * client_idl()
KSyncObject * GetObject() const
OvsdbClientIdlPtr client_idl_
void NotifyAddOvsdb(OvsdbDBEntry *key, struct ovsdb_idl_row *row)
void NotifyDeleteOvsdb(OvsdbDBEntry *key, struct ovsdb_idl_row *row)
OvsdbClientIdl * client_idl()
KSyncObject * GetObject(OvsdbClientSession *session)
OvsdbVrfSandeshTask(std::string resp_ctx, AgentSandeshArguments &args)
std::string logical_switch_
void EncodeArgs(AgentSandeshArguments &args)
void UpdateResp(KSyncEntry *kentry, SandeshResponse *resp)
virtual ~OvsdbVrfSandeshTask()
FilterResp Filter(KSyncEntry *entry)
SandeshResponse * Alloc()
virtual void OvsdbRegisterDBTable(DBTable *tbl)
UnicastMacRemoteTable * route_table_
const std::string & logical_switch_name()
KSyncEntry * UnresolvedReference()
std::string logical_switch_name_
void TriggerAck(UnicastMacRemoteTable *table)
AgentRouteTable * oper_route_table_
VrfOvsdbEntry(OvsdbDBObject *table, const std::string &logical_switch)
bool IsLess(const KSyncEntry &) const
DBFilterResp OvsdbDBEntryFilter(const DBEntry *entry, const OvsdbDBEntry *ovsdb_entry)
KSyncEntry * DBToKSyncEntry(const DBEntry *)
OvsdbDBEntry * AllocOvsEntry(struct ovsdb_idl_row *row)
void OvsdbNotify(OvsdbClientIdl::Op, struct ovsdb_idl_row *)
VrfOvsdbObject(OvsdbClientIdl *idl)
KSyncEntry * Alloc(const KSyncEntry *key, uint32_t index)
virtual ~VrfOvsdbObject()
The TaskScheduler keeps track of what tasks are currently schedulable. When a task is enqueued it is ...
void Enqueue(Task *task)
Enqueues a task for running. Starts task if all policy rules are met else puts task in waitq....
static TaskScheduler * GetInstance()
const boost::uuids::uuid & GetUuid() const
AgentRouteTable * GetBridgeRouteTable() const
char * ovsdb_wrapper_ucast_mac_remote_dst_ip(struct ovsdb_idl_row *row)
char * ovsdb_wrapper_ucast_mac_remote_logical_switch(struct ovsdb_idl_row *row)
char * ovsdb_wrapper_ucast_mac_remote_mac(struct ovsdb_idl_row *row)
static std::string UuidToString(const boost::uuids::uuid &id)