//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see http://www.gnu.org/licenses/.
//
#ifndef BiDomainGenerator_H_
#define BiDomainGenerator_H_
#include <IntPDUFG.h>
#include <DomainTable/DomainTable.h>
#include <DomainRouting/Routing.h>
#include <map>
#include <set>
namespace BiDomainGenerator {
struct pAddr {
std::string domain;
std::string addr;
pAddr (const std::string &_domain, const std::string &_addr)
: domain(_domain), addr(_addr) {}
};
typedef std::set<RMTPort*> PortsSet;
typedef std::map<std::string, PortsSet> NTable;
typedef PortsSet::iterator PortsSetIt;
typedef NTable::iterator NTableIt;
class BiDomainGenerator: public IntPDUFG {
public:
// A new flow has been inserted/or removed
virtual void insertedFlow(const Address &addr, const unsigned short &qos, RMTPort * port);
virtual void removedFlow(const Address &addr, const unsigned short &qos, RMTPort * port);
//Routing has processes a routing update
virtual void routingUpdated();
protected:
// Called after initialize
virtual void onPolicyInit();
private:
DA * difA;
DomainTable::DomainTable * fwd;
DMRnms::Routing * rt;
std::string myPrefix;
std::string mySufix;
pAddr parseAddr(const std::string &addr);
NTable neighbours;
};
}
#endif /* STATICGENERATOR_H_ */