ist.palcom.routing.util
Class DSDVRoutingManager

java.lang.Object
  extended by ist.palcom.routing.util.AbstractRoutingManager
      extended by ist.palcom.routing.util.DSDVRoutingManager
All Implemented Interfaces:
IHgraphNode, RoutingManager

public class DSDVRoutingManager
extends AbstractRoutingManager

The DSDVRoutingManager is a table-driven routing manager (DSDV tables) where the nodes in the network periodically exchange routing information. The direction of the traffic is chosen based on number of nodes between sender and receiver and not on actually bandwidth for instance.


Field Summary
 
Fields inherited from class ist.palcom.routing.util.AbstractRoutingManager
_node, manager, pubSubManager, recieverThread, registeredThreads, scheduler
 
Fields inherited from interface ist.palcom.hgraph.IHgraphNode
CHILD_NAME_CLASH, CIRCULARITY_CLASH, COMMAND_OR_NODE_MISSING, ERROR, HANDLER_MISSING, INVOKATOR_MISSING, LISTENER_MISSING, NODE_NOT_CHILD, PATH_MISSING, SIBLING_ALREADY_EXISTS, SIBLING_NONEXISTENT, SIBLING_REFERENCE_ALREADY_EXISTS, SIBLING_REFERENCE_NONEXISTENT, STATUS_OK, VALUE_ALREADY_EXISTS, VALUE_NOT_PRESENT
 
Constructor Summary
DSDVRoutingManager(PalcomScheduler scheduler, MediaManager manager, RoutingPubSubManager pubSubManager, URN deviceURN)
           
 
Method Summary
protected  void addLocalPeer(URN routingURN, Selector routingSelector)
          Add a peer to the DSDV-table and ensure no duplicates.
protected  DSDVTable getDSDVChangedPeers()
           
protected  DSDVTable getDSDVTable()
           
protected  void handleRoutingMessage(AbstractRoutingMessage message)
          This method handle different types of routing messages
 void send(Message message, URL receiverURL)
           
 boolean send(Message message, URN senderURN, Selector senderSelector, URN receiverURN, Selector receiverSelector)
          Send message lookups the receiver URN in the DSDV-table and route the message to the next routingManager.
protected  boolean sendDirect(Message message, URN senderURN, Selector senderSelector, URN receiverURN, Selector receiverSelector)
           
protected  void startRouting()
          Main method
protected  void updateStatus(URN urn)
           
protected  void updateTable(DSDVTable original, DSDVTable updater, URN updateSenderURN, Selector updateSenderSelector)
          This method takes one original DSDVTable and update it with another DSDVTable.
 
Methods inherited from class ist.palcom.routing.util.AbstractRoutingManager
addErrorHandler, addNodeChild, getChildIterator, getFuncFunc, getLocalDeviceCache, getNodeName, getNodeParent, getPath, getRoutingSelector, getRoutingURN, getSiblingFunc, getValueFunc, hasChildNamed, isAncestorOf, registerAsListener, registerForHeartBeats, removeNodeChild, send, sendBroadcast, sendGroupJoinMessage, sendGroupLeaveMessage, sendHeartAttack, sendHeartBeat, setDiscoverySelector, setLocalDeviceCache, setLocalDeviceID, setLocalDiscoveryVersion, setLocalStatusFlag, setLocalStatusFlag, setNodeName, setNodeParent, startReceiving, stop, stopReceiving, stopReceiving, toXML, toXMLFull, toXMLFullRecursively, toXMLRecursively, unregisterDevice, updatePath
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

DSDVRoutingManager

public DSDVRoutingManager(PalcomScheduler scheduler,
                          MediaManager manager,
                          RoutingPubSubManager pubSubManager,
                          URN deviceURN)
Parameters:
manager -
Method Detail

startRouting

protected void startRouting()
Main method

Specified by:
startRouting in class AbstractRoutingManager

send

public void send(Message message,
                 URL receiverURL)

send

public boolean send(Message message,
                    URN senderURN,
                    Selector senderSelector,
                    URN receiverURN,
                    Selector receiverSelector)
Send message lookups the receiver URN in the DSDV-table and route the message to the next routingManager. If the routingManager can't lookup the receiver URN, the message isn't send and the method return false.

Specified by:
send in interface RoutingManager
Specified by:
send in class AbstractRoutingManager

sendDirect

protected boolean sendDirect(Message message,
                             URN senderURN,
                             Selector senderSelector,
                             URN receiverURN,
                             Selector receiverSelector)

handleRoutingMessage

protected void handleRoutingMessage(AbstractRoutingMessage message)
This method handle different types of routing messages

Specified by:
handleRoutingMessage in class AbstractRoutingManager
Parameters:
message - - message send between the nodes in the network to update/establish routing.

updateStatus

protected void updateStatus(URN urn)

addLocalPeer

protected void addLocalPeer(URN routingURN,
                            Selector routingSelector)
Add a peer to the DSDV-table and ensure no duplicates. Only local peers are added (metric 0).


updateTable

protected void updateTable(DSDVTable original,
                           DSDVTable updater,
                           URN updateSenderURN,
                           Selector updateSenderSelector)
This method takes one original DSDVTable and update it with another DSDVTable. Table entries with highest sequence number and best connection to a peer remains.


getDSDVTable

protected DSDVTable getDSDVTable()

getDSDVChangedPeers

protected DSDVTable getDSDVChangedPeers()