All Packages This Package Class Hierarchy Class Search Index
java.lang.Object | +----edu.utah.janos.antsr.core.Capsule
Summary |
public abstract class Capsule extends java.lang.Object { // Fields 15 static final byte ANEPVERSION; static final short ANTSRTYPE; static final int ANTSRVERSION; static final short ANTSTYPE; static final short DESTOPTTYPE; static final int HEADERLENGTH; static final int IPV4SCHEME; public static final int MAX_TTL; static final short SRCOPTTYPE; private int dst; private int previous; private boolean primed; private int src; private int ttl; private Xdr xdr; // Constructors 1 public Capsule(); // Methods 24 public static Capsule create(Class, Xdr) throws Exception; static final Capsule dequeueCapsule(Node, CommQueue); public static int findExtension(String); public static byte[] findMID(String); public static byte[] findPID(String); static final int peekPrevious(BufferHandle); public Xdr decode(); void decodeWith(Xdr); public Xdr encode(); public Xdr encodeCapsuleForSend(Node); final void enqueueCapsule(CommQueue); public abstract boolean evaluate(Node); public int getDst(); public int getPrevious(); public int getSrc(); public int getTTL(); public int length(); protected abstract byte[] mid(); protected abstract byte[] pid(); public final void prime(Capsule); final void prime(int, int); public void setDst(int); void setPrevious(int); public String toString(); }
A capsule is a combination of a packet and its forwarding routine; the forwarding routine is executed at every active node the packet visits in the network.
This is an abstract, an actual Capsule is created by subclassing this class and filling in the missing routines.
Subclasses must implement the mid(), pid(), and evalutate() methods.
All ANTSR capsules have the following format:
16-byte MethodID (The MD5 hash over the class bytecode) 4-byte logical source address 4-byte logical destination address 4-byte logical previous-hop address 4-byte TTL field. ... Capsule-specific data ...
Cross Reference |
Fields |
· ANEPVERSION | Summary | Top |
static final byte ANEPVERSION
· ANTSTYPE | Summary | Top |
static final short ANTSTYPE
· ANTSRTYPE | Summary | Top |
static final short ANTSRTYPE
· SRCOPTTYPE | Summary | Top |
static final short SRCOPTTYPE
· DESTOPTTYPE | Summary | Top |
static final short DESTOPTTYPE
· IPV4SCHEME | Summary | Top |
static final int IPV4SCHEME
· ANTSRVERSION | Summary | Top |
static final int ANTSRVERSION
· HEADERLENGTH | Summary | Top |
static final int HEADERLENGTH
· MAX_TTL | Summary | Top |
public static final int MAX_TTL
· src | Summary | Top |
private int src
All capsules originate from some source node. This is the 32-bit IP address of that source.
The source is set implicitly by the node that injects the capsule into the network and is never changed after that.
XXX what is this used for by the Node? Or is it just a convenience for subclasses? If that's all then nuke it.
See Also: getSrc
· dst | Summary | Top |
private int dst
The destination for this capsule. Forwarding code may read/write this field.
· previous | Summary | Top |
private int previous
32-bit IP address of previous active node. This is used by the code loading protocol to dynamically find the code to process a new packet type.
XXX security implications of giving this package access?
See Also: getPrevious, setPrevious
· xdr | Summary | Top |
private Xdr xdr
The xdr stream representing the buffer that underlies a Capsule.
For incoming packets, this field is set by the Protocol receive() function.
For outgoing packets, this field is set by the encode() method which creates a new Xdr.
· ttl | Summary | Top |
private int ttl
Time to live for a packet. Used to control packet propagation.
XXX a byte would suffice?
See Also: getTTL
· primed | Summary | Top |
private boolean primed
Has this capsule been primed yet?
Constructors |
· Capsule | Summary | Top |
public Capsule()
Create a dull capsule.
Methods |
· mid | Summary | Top |
protected abstract byte[] mid()
Return the MethodID associated with this capsule.
See On_IDs.txt for more info on MethodIDs.
- Returns:
- the byte[] representing the MD5 checksum.
See Also: InChannel
· pid | Summary | Top |
protected abstract byte[] pid()
Return the ProtocolID associated with this capsule.
See On_IDs.txt for more info on ProtocolIDs.
- Returns:
- the byte[] representing the MD5 checksum.
See Also: findPID
· getPrevious | Summary | Top |
public int getPrevious()
Get the 32-bit IP address of the active node this packet just came from. Used to find code to process this packet.
· setPrevious | Summary | Top |
void setPrevious(int previous)
Set the 32-bit IP address of the active node this packet "came from". Used by the outgoing channel encode() operation.
See Also: Channel
· getTTL | Summary | Top |
public int getTTL()
Return the TTL-like counter for this capsule.
- Returns:
- a TTL value for this Capsule.
· findMID | Summary | Top |
public static byte[] findMID(String name)
Access point to initialze capsule methodIDs. Given Capsule class name, returns the appropriate MID.
XXX its probably bad that the actual underlying byte[] is returned and not a copy... Who uses this?
Parameter Description name the name of the Capsule class
- Returns:
- the MD5 checksum (MID) associated with the given Capsule class.
· findPID | Summary | Top |
public static byte[] findPID(String name)
Access point to initialze capsule protocolID. Given Capsule class name, returns the appropriate PID.
Parameter Description name the name of the Capsule class
- Returns:
- the MD5 checksum (PID) associated with the given Capsule class.
See Also: InChannel
· findExtension | Summary | Top |
public static int findExtension(String name)
Find a given extension. Given the name for an extension, return the local "index" of that extension.
XXX This interface will need to be replaced to allow extensions to be referenced counted (and unloaded).
Parameter Description name The name of the extension to load.
- Returns:
- The local "index" of the given extension.
See Also: findNamedExtension, getExtension
· evaluate | Summary | Top |
public abstract boolean evaluate(Node node)
The forwarding routine for the Capsule. This is invoked by the router when a capsule is received.
This method should not access other Java classes, and should only interact with the local system through the local node interface. This routine should "terminate quickly."
XXX perhaps default to forwarding the Capsule?
Parameter Description node the local node interface
- Returns:
- an indicationof whether the forwarding was successful.
· getSrc | Summary | Top |
public int getSrc()
Return the source IP address of this capsule.
- Returns:
- the source IP address of this capsule.
· getDst | Summary | Top |
public int getDst()
Return the destination IP address of this capsule.
- Returns:
- the destination IP address of this capsule.
· setDst | Summary | Top |
public void setDst(int dst)
Set the destination IP address of this capsule.
Parameter Description dst the destination IP address of this capsule.
· length | Summary | Top |
public int length()
Return the length of the capsule header that all capsule encodings will include.
- Returns:
- the length of the capsule header
· encode | Summary | Top |
public Xdr encode()
Encode this capsule's header into a new Xdr. Return the new Xdr.
Because this header must go first in the Xdr, this encoder unilaterally sets the xdr buffer pointer to the beginning of the buffer and writes its data there.
The format of the Xdr is:
MethodID (16 bytes) src address ( 4 bytes) dst address ( 4 bytes) previous address ( 4 bytes) TTL ( 4 bytes)
- Returns:
- the new Xdr representing this capsule.
See Also: xdr
· encodeCapsuleForSend | Summary | Top |
public Xdr encodeCapsuleForSend(Node node)
Encode an outgoing capsule.
This writes the ANEP and ANTSR header for an outgoing capsule in its associated Xdr. A new Xdr is created if the Capsule doesn't already have one. Then, the per-capsule encoding is called.
This function should be invoked immediately before pushing the capsule out the door.
XXX: rename to 'encodeForSend()'
Parameter Description node the node interface
- Returns:
- Xdr returns Xdr in which the remainder of the capsule should be encoded.
- Throws: SecurityException
- if the source is not defined in the capsule or the capsule has not been primed
- Throws: ResourceLimitException
- if the capsule has insufficent resources
· decodeWith | Summary | Top |
void decodeWith(Xdr xdr)
· decode | Summary | Top |
public Xdr decode()
Decode a capsule header from this Capsule's xdr field.
- Returns:
- the new Xdr based on the current xdr.
· peekPrevious | Summary | Top |
static final int peekPrevious(BufferHandle buf)
Peek at the 'previous' field of buf. For bootstrapping capsule code loading.
Parameter Description buf the Buffer to peek into.
- Returns:
- in the value of the 'previous' field in buf.
· prime | Summary | Top |
public final void prime(Capsule parent)
Prime this capsule for transmission. Use the given parent Capsule to prime the src and ttl of this capsule.
Does not maintain zero-sum ttl. This capsule gets parent's ttl minus 1. Parent loses one hop.
Parameter Description parent the capsule to take src and ttl (minus 1) from.
· prime | Summary | Top |
final void prime(int src, int ttl)
Priveleged prime operation. Fill in this capsule's src and ttl fields directly. The given ttl is capped at MAX_TTL
This is package-access only, otherwise it would be a security hole.
Parameter Description src the source address for the new packet. ttl the tll for the new packet.
See Also: MAX_TTL
· enqueueCapsule | Summary | Top |
final void enqueueCapsule(CommQueue queue)
Package up this capsule and dump it onto the queue for another application
· dequeueCapsule | Summary | Top |
static final Capsule dequeueCapsule(Node node, CommQueue queue)
Produce a capsule from data pushed through a CommQueue by enqueueCapsule
· toString | Summary | Top |
public String toString()
String representation of a Capsule. Includes the class name, source and destination.
- Overrides:
- toString in class Object
· create | Summary | Top |
public static Capsule create(Class cl, Xdr xdr) throws Exception
Create a new Capsule from the given Xdr. The xdr will be decoded into an instance of the given class which must be a subclass of Capsule.
Parameter Description cl the subtype of capsule to create xdr the encoding of the actual capsule
- Returns:
- the new Capsule instance.
All Packages This Package Class Hierarchy Class Search IndexFreshly brewed Java API Documentation automatically generated with polardoc Version 1.0.7