|
Rice Pastry API | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.mpisws.p2p.transport.table.TableTransprotLayerImpl<Identifier,Key,Value>
public class TableTransprotLayerImpl<Identifier,Key,Value>
| Field Summary | |
|---|---|
protected TransportLayerCallback<Identifier,java.nio.ByteBuffer> |
callback
|
protected ErrorHandler<Identifier> |
errorHandler
|
protected Serializer<Key> |
keySerializer
|
protected TableStore<Key,Value> |
knownValues
Could just be a hashTable |
protected Logger |
logger
|
static byte |
PASSTHROUGH
|
static byte |
REQUEST
|
static byte |
RESPONSE_FAILED
|
static byte |
RESPONSE_SUCCESS
|
protected TransportLayer<Identifier,java.nio.ByteBuffer> |
tl
|
protected Serializer<Value> |
valueSerializer
|
| Constructor Summary | |
|---|---|
TableTransprotLayerImpl(Serializer<Key> iSerializer,
Serializer<Value> cSerializer,
TableStore<Key,Value> tableStore,
TransportLayer<Identifier,java.nio.ByteBuffer> tl,
Environment env)
|
|
| Method Summary | |
|---|---|
void |
acceptMessages(boolean b)
Toggle accepting incoming messages. |
void |
acceptSockets(boolean b)
Toggle accepting new sockets. |
void |
destroy()
|
Identifier |
getLocalIdentifier()
The local node. |
void |
handleValueRequest(P2PSocket<Identifier> sock)
|
boolean |
hasKey(Key i)
|
void |
incomingSocket(P2PSocket<Identifier> sock)
Notification of a new socket. |
void |
messageReceived(Identifier i,
java.nio.ByteBuffer m,
java.util.Map<java.lang.String,java.lang.Object> options)
Called when a new message is received. |
SocketRequestHandle<Identifier> |
openSocket(Identifier i,
SocketCallback<Identifier> deliverSocketToMe,
java.util.Map<java.lang.String,java.lang.Object> options)
Open a socket to the Identifier |
Cancellable |
requestValue(Identifier source,
Key principal,
Continuation<Value,java.lang.Exception> c,
java.util.Map<java.lang.String,java.lang.Object> options)
REQUEST, int requestId, Key |
MessageRequestHandle<Identifier,java.nio.ByteBuffer> |
sendMessage(Identifier i,
java.nio.ByteBuffer m,
MessageCallback<Identifier,java.nio.ByteBuffer> deliverAckToMe,
java.util.Map<java.lang.String,java.lang.Object> options)
Send the message to the identifier |
void |
setCallback(TransportLayerCallback<Identifier,java.nio.ByteBuffer> callback)
Set the callback for incoming sockets/messages |
void |
setErrorHandler(ErrorHandler<Identifier> handler)
To be notified of problems not related to an outgoing messaage/socket. |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
|---|
public static final byte PASSTHROUGH
public static final byte REQUEST
public static final byte RESPONSE_SUCCESS
public static final byte RESPONSE_FAILED
protected TableStore<Key,Value> knownValues
protected TransportLayerCallback<Identifier,java.nio.ByteBuffer> callback
protected TransportLayer<Identifier,java.nio.ByteBuffer> tl
protected Serializer<Key> keySerializer
protected Serializer<Value> valueSerializer
protected ErrorHandler<Identifier> errorHandler
protected Logger logger
| Constructor Detail |
|---|
public TableTransprotLayerImpl(Serializer<Key> iSerializer,
Serializer<Value> cSerializer,
TableStore<Key,Value> tableStore,
TransportLayer<Identifier,java.nio.ByteBuffer> tl,
Environment env)
iSerializer - cSerializer - tableStore - should be pre-populated with any persistent or initial valuestl - env - | Method Detail |
|---|
public Cancellable requestValue(Identifier source,
Key principal,
Continuation<Value,java.lang.Exception> c,
java.util.Map<java.lang.String,java.lang.Object> options)
requestValue in interface TableTransportLayer<Identifier,Key,Value>
public SocketRequestHandle<Identifier> openSocket(Identifier i,
SocketCallback<Identifier> deliverSocketToMe,
java.util.Map<java.lang.String,java.lang.Object> options)
TransportLayer
openSocket in interface TransportLayer<Identifier,java.nio.ByteBuffer>i - who to open the socket todeliverSocketToMe - the callback when the socket is openedoptions - options on how to open the socket (don't source route, encrypt etc) (may not be respected if layer cannot provide service)
public void incomingSocket(P2PSocket<Identifier> sock)
throws java.io.IOException
TransportLayerCallback
incomingSocket in interface TransportLayerCallback<Identifier,java.nio.ByteBuffer>sock - the incoming socket
java.io.IOExceptionpublic void handleValueRequest(P2PSocket<Identifier> sock)
public boolean hasKey(Key i)
hasKey in interface TableTransportLayer<Identifier,Key,Value>public void acceptMessages(boolean b)
TransportLayer
acceptMessages in interface TransportLayer<Identifier,java.nio.ByteBuffer>public void acceptSockets(boolean b)
TransportLayer
acceptSockets in interface TransportLayer<Identifier,java.nio.ByteBuffer>public Identifier getLocalIdentifier()
TransportLayer
getLocalIdentifier in interface TransportLayer<Identifier,java.nio.ByteBuffer>
public MessageRequestHandle<Identifier,java.nio.ByteBuffer> sendMessage(Identifier i,
java.nio.ByteBuffer m,
MessageCallback<Identifier,java.nio.ByteBuffer> deliverAckToMe,
java.util.Map<java.lang.String,java.lang.Object> options)
TransportLayer
sendMessage in interface TransportLayer<Identifier,java.nio.ByteBuffer>i - the destinationm - the messagedeliverAckToMe - layer dependent notification when the message is sent (can indicate placed on the wire, point-to-point acknowledgment, or end-to-end acknowledgement)options - delivery options (don't source route, encrypt etc) (may not be respected if layer cannot provide service)
public void setCallback(TransportLayerCallback<Identifier,java.nio.ByteBuffer> callback)
TransportLayer
setCallback in interface TransportLayer<Identifier,java.nio.ByteBuffer>callback - the callback for incoming sockets/messagespublic void setErrorHandler(ErrorHandler<Identifier> handler)
TransportLayer
setErrorHandler in interface TransportLayer<Identifier,java.nio.ByteBuffer>handler - to be notified of problems not related to a specific messaage/socket.public void destroy()
destroy in interface Destructable
public void messageReceived(Identifier i,
java.nio.ByteBuffer m,
java.util.Map<java.lang.String,java.lang.Object> options)
throws java.io.IOException
TransportLayerCallback
messageReceived in interface TransportLayerCallback<Identifier,java.nio.ByteBuffer>i - The node it is coming fromm - the messageoptions - describe how the message arrived (udp/tcp, encrypted etc)
java.io.IOException - if there is a problem decoding the message
|
Rice Pastry API | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||