Source: ../../contrib/olsr/io.hh
|
|
|
|
// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*-
// vim:set sts=4 ts=8 sw=4:
// Copyright (c) 2001-2009 XORP, Inc.
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License, Version 2, June
// 1991 as published by the Free Software Foundation. Redistribution
// and/or modification of this program under the terms of any other
// version of the GNU General Public License is not permitted.
//
// 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. For more details,
// see the GNU General Public License, Version 2, a copy of which can be
// found in the XORP LICENSE.gpl file.
//
// XORP Inc, 2953 Bunker Hill Lane, Suite 204, Santa Clara, CA 95054, USA;
// http://xorp.net
// $XORP: xorp/contrib/olsr/io.hh,v 1.4 2009/01/05 18:30:46 jtc Exp $
#ifndef __OLSR_IO_HH__
#define __OLSR_IO_HH__
/**
* @short Abstract interface to low level IO operations.
*
* An abstract class that defines packet reception and
* transmission. The details of how packets are received or transmitted
* are therefore hidden from the internals of the OLSR code.
*/
class IO : public ServiceBase {
public:
IO() {}
virtual ~IO() {}
/**
* Enable an IPv4 address and port for OLSR datagram reception and
* transmission.
*
* @param interface the interface to enable.
* @param vif the vif to enable.
* @param address the address to enable.
* @param port the port to enable.
* @param all_nodes_address the all-nodes address to enable.
* @return true if the address was enabled, otherwise false.
*/
virtual bool enable_address(const string& interface, const string& vif,
const IPv4& address, const uint16_t& port,
const IPv4& all_nodes_address) = 0;
/**
* Disable an IPv4 address and port for OLSR datagram reception.
*
* @param interface the interface to disable.
* @param vif the vif to disable.
* @param address the address to disable.
* @param port the port to disable.
* @return true if the address was disabled, otherwise false.
*/
virtual bool disable_address(const string& interface, const string& vif,
const IPv4& address, const uint16_t& port) = 0;
/**
* Test whether this interface is enabled.
*
* @param interface the interface to test.
* @return true if it exists and is enabled, otherwise false.
*/
virtual bool is_interface_enabled(const string& interface) const = 0;
/**
* Test whether this interface/vif is enabled.
*
* @param interface the interface to test.
* @param vif the vif to test.
* @return true if it exists and is enabled, otherwise false.
*/
virtual bool is_vif_enabled(const string& interface,
const string& vif) const = 0;
/**
* Test whether this interface/vif is broadcast capable.
*
* @param interface the interface to test.
* @param vif the vif to test.
* @return true if it is broadcast capable, otherwise false.
*/
virtual bool is_vif_broadcast_capable(const string& interface,
const string& vif) = 0;
/**
* Test whether this interface/vif is multicast capable.
*
* @param interface the interface to test.
* @param vif the vif to test.
* @return true if it is multicast capable, otherwise false.
*/
virtual bool is_vif_multicast_capable(const string& interface,
const string& vif) = 0;
/**
* Test whether this interface/vif is a loopback interface.
*
* @param interface the interface to test.
* @param vif the vif to test.
* @return true if it is a loopback interface, otherwise false.
*/
virtual bool is_vif_loopback(const string& interface,
const string& vif) = 0;
/**
* Test whether this interface/vif/address is enabled.
*
* @param interface the interface to test.
* @param vif the vif to test.
* @param address the address to test.
* @return true if it exists and is enabled, otherwise false.
*/
virtual bool is_address_enabled(const string& interface,
const string& vif, const IPv4& address) const = 0;
/**
* Callback for interface status from the FEA.
*/
typedef XorpCallback2<void, const string&,
bool>::RefPtr InterfaceStatusCb;
/**
* Callback for vif status from the FEA.
*/
typedef XorpCallback3<void, const string&, const string&,
bool>::RefPtr VifStatusCb;
/**
* Callback for address status from the FEA.
*/
typedef XorpCallback4<void, const string&, const string&, IPv4,
bool>::RefPtr AddressStatusCb;
/**
* Callback for packet reception from the FEA.
*/
typedef XorpCallback8<void, const string&, const string&,
IPv4, uint16_t, IPv4, uint16_t,
uint8_t*,
uint32_t>::RefPtr ReceiveCallback;
/**
* Get all addresses associated with this interface/vif.
*
* @param interface the name of the interface
* @param vif the name of the vif
* @param addresses (out argument) list of associated addresses
* @return true if there are no errors.
*/
virtual bool get_addresses(const string& interface, const string& vif,
list<IPv4>& addresses) const = 0;
/**
* Get the broadcast address associated with this interface/vif/address.
*
* @param interface the name of the interface
* @param vif the name of the vif
* @param address IPv4 binding address
* @param bcast_address (out argument) primary broadcast address
* @return true if there are no errors.
*/
virtual bool get_broadcast_address(const string& interface,
const string& vif,
const IPv4& address,
IPv4& bcast_address) const = 0;
/**
* Get the ID of the interface, as seen by libfeaclient.
*
* @param interface the name of the interface.
* @param interface_id (out argument) interface ID.
* @return the interface id for this interface.
*/
virtual bool get_interface_id(const string& interface,
uint32_t& interface_id) = 0;
/**
* Get the MTU for an interface.
*
* @param interface the name of the interface.
* @return the mtu for this interface.
*/
virtual uint32_t get_mtu(const string& interface) = 0;
/**
* Add a callback for tracking the interface status.
*
* The callback will be invoked whenever the status of the interface
* is changed from disabled to enabled or vice-versa.
*
* @param cb the callback to register.
*/
inline void register_interface_status(InterfaceStatusCb cb) {
_interface_status_cb = cb;
};
/**
* Add a callback for tracking the interface/vif status.
*
* The callback will be invoked whenever the status of the interface/vif
* is changed from disabled to enabled or vice-versa.
*
* @param cb the callback to register.
*/
inline void register_vif_status(VifStatusCb cb) {
_vif_status_cb = cb;
};
/**
* Add a callback for tracking the interface/vif/address status.
*
* The callback will be invoked whenever the status of the tuple
* (interface, vif, address) is changed from disabled to enabled
* or vice-versa.
*
* @param cb the callback to register.
*/
inline void register_address_status(AddressStatusCb cb) {
_address_status_cb = cb;
};
/**
* Register for receiving datagrams.
*
* @param cb the callback to register.
*/
inline void register_receive(ReceiveCallback cb) { _receive_cb = cb; };
protected:
ReceiveCallback _receive_cb;
InterfaceStatusCb _interface_status_cb;
VifStatusCb _vif_status_cb;
AddressStatusCb _address_status_cb;
public:
struct interface_vif {
string _interface_name;
string _vif_name;
};
/**
* Send a UDP datagram from src:sport to dst:dport, on
* the given interface, if possible.
*
* @param interface the interface to transmit from.
* @param vif the vif to transmit from.
* @param src the IPv4 source address to transmit from.
* @param sport the UDP source port to transmit from.
* @param dst the IPv4 destination address to send to.
* @param dport the UDP destination port to send to.
* @param data the datagram to transmit.
* @param len the length of the datagram to transmit.
* @return true if the datagram was sent OK, otherwise false.
*/
virtual bool send(const string& interface, const string& vif,
const IPv4& src, const uint16_t& sport,
const IPv4& dst, const uint16_t& dport,
uint8_t* data, const uint32_t& len) = 0;
/**
* Add route.
*
* @param net network
* @param nexthop
* @param faceid interface ID towards the nexthop
* @param metric to network
* @param policytags policy info to the RIB.
* @return true if the route was added OK, otherwise false.
*/
virtual bool add_route(IPv4Net net, IPv4 nexthop, uint32_t faceid,
uint32_t metric,
const PolicyTags& policytags) = 0;
/**
* Replace route.
*
* @param net network
* @param nexthop
* @param faceid interface ID towards the nexthop
* @param metric to network
* @param policytags policy info to the RIB.
* @return true if the route was replaced OK, otherwise false.
*/
virtual bool replace_route(IPv4Net net, IPv4 nexthop, uint32_t faceid,
uint32_t metric,
const PolicyTags& policytags) = 0;
/**
* Delete route.
*
* @param net network
* @return true if the route was deleted OK, otherwise false.
*/
virtual bool delete_route(IPv4Net net) = 0;
/**
* Store a mapping of the OLSR internal interface ID to
* interface/vif. This will be required by when installing a route.
*
* @param interface_id the ID of the interface, as seen by libfeaclient.
* @param interface the name of the interface mapped to interface_id.
* @param vif the name of vif mapped to interface_id.
*/
inline void set_interface_mapping(uint32_t interface_id,
const string& interface, const string& vif) {
interface_vif iv;
iv._interface_name = interface;
iv._vif_name = vif;
_interface_vif[interface_id] = iv;
};
/**
* Given an OLSR interface ID, return the interface/vif.
*
* @param interface_id the ID of the interface, as seen by libfeaclient.
* @param interface the name of the interface mapped to interface_id.
* @param vif the name of vif mapped to interface_id.
* @return true if interface_id was found, otherwise false.
*/
inline bool get_interface_vif_by_interface_id(uint32_t interface_id,
string& interface, string& vif) {
if (0 == _interface_vif.count(interface_id))
return false;
interface_vif iv = _interface_vif[interface_id];
interface = iv._interface_name;
vif = iv._vif_name;
return true;
};
protected:
map<uint32_t, interface_vif> _interface_vif;
};
#endif // __OLSR_IO_HH__
Generated by: pavlin on kobe.xorp.net on Wed Jan 7 19:11:15 2009, using kdoc 2.0a54+XORP.