Package jade.proto
Class TwoPh0Initiator
-
- All Implemented Interfaces:
Serializable,Serializable
public class TwoPh0Initiator extends FSMBehaviour
Class description- Author:
- Elena Quarantotto - TILAB, Giovanni Caire - TILAB
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class jade.core.behaviours.Behaviour
Behaviour.RunnableChangedEvent
-
-
Field Summary
Fields Modifier and Type Field Description StringALL_CFPS_KEYkey to retrieve from the DataStore of the behaviour the vector of CFP messages that have to be sent.protected StringALL_INITIATIONS_KStringALL_PENDINGS_KEYkey to retrieve from the DataStore of the behaviour the vector of CFP messages for which a response has not been received yet.StringALL_PROPOSES_KEYkey to retrieve from the DataStore of the behaviour the vector of PROPOSE messages that have been received as response.StringALL_RESPONSES_KEYkey to retrieve from the DataStore of the behaviour the vector of all messages that have been received as response.StringCFP_KEYkey to retrieve from the DataStore of the behaviour the ACLMessage object passed in the constructor of the class.protected static StringCHECK_IN_SEQprotected static StringCHECK_SESSIONSprotected static StringDUMMY_FINALprotected static StringHANDLE_FAILUREprotected static StringHANDLE_NOT_UNDERSTOODprotected static StringHANDLE_OUT_OF_SEQprotected StringINITIATION_Kprotected static StringPREPARE_INITIATIONSprotected static StringRECEIVE_REPLYprotected StringREPLY_KStringREPLY_KEYkey to retrieve from the DataStore of the behaviour the last ACLMessage object that has been received (null if the timeout expired).protected MsgReceiverreplyReceiverprotected MessageTemplatereplyTemplateprotected static StringSEND_INITIATIONSprotected Mapsessions-
Fields inherited from class jade.core.behaviours.FSMBehaviour
currentName, lastStates
-
Fields inherited from class jade.core.behaviours.CompositeBehaviour
currentExecuted
-
Fields inherited from class jade.core.behaviours.Behaviour
myAgent, myEvent, NOTIFY_DOWN, NOTIFY_UP, parent, STATE_BLOCKED, STATE_READY, STATE_RUNNING
-
-
Constructor Summary
Constructors Constructor Description TwoPh0Initiator(Agent a, ACLMessage cfp, String outputKey)Constructs aTwoPh0Initiatorbehaviour.TwoPh0Initiator(Agent a, ACLMessage cfp, String outputKey, DataStore store)Constructs aTwoPh0Initiatorbehaviour.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidadjustReplyTemplate(ACLMessage msg)protected booleancheckInSequence(ACLMessage reply)Check whether a reply is in-sequence and than update the appropriate Session and removes corresponding cfp from vector of pendings.protected intcheckSessions(ACLMessage reply)Check if there are still active sessions or if timeout is expired.protected StringcreateConvId(Vector msgs)Create a new conversation identifier to begin a new interaction.protected jade.proto.Initiator.ProtocolSessiongetSession(ACLMessage msg, int sessionIndex)Return a ProtocolSession object to manage replies to a given initiation messageprotected String[]getToBeReset()Return the states that must be reset before they are visited again.protected voidhandleAllResponses(Vector responses, Vector proposes, Vector pendings, Vector nextPhMsgs)This method is called when all the responses have been collected or when the timeout is expired.protected voidhandleFailure(ACLMessage failure)This method is called every time afailuremessage is received, which is not out-of-sequence according to the protocol rules.protected voidhandleNotUnderstood(ACLMessage notUnderstood)This method is called every time anot-understoodmessage is received, which is not out-of-sequence according to the protocol rules.protected voidhandleOutOfSequence(ACLMessage msg)This method is called every time a message is received, which is out-of-sequence according to the protocol rules.protected voidhandlePropose(ACLMessage propose)This method is called every time aproposemessage is received, which is not out-of-sequence according to the protocol rules.protected voidinitializeDataStore(ACLMessage msg)Initialize the data store.intonEnd()Override the onEnd() method to return the exit value of the last executed state.voidonStart()Override the onStart() method to initialize the vectors that will keep all the replies in the data store.protected VectorprepareCfps(ACLMessage cfp)This method must return the vector of ACLMessage objects to be sent.protected VectorprepareInitiations(ACLMessage initiation)Prepare vector containing cfps.voidregisterHandleAllResponses(Behaviour b)This method allows to register a user definedBehaviourin the HANDLE_ALL_RESPONSES state.voidregisterHandleFailure(Behaviour b)This method allows to register a user definedBehaviourin the HANDLE_FAILURE state.voidregisterHandleNotUnderstood(Behaviour b)This method allows to register a user definedBehaviourin the HANDLE_NOT_UNDERSTOOD state.voidregisterHandleOutOfSequence(Behaviour b)This method allows to register a user definedBehaviourin the HANDLE_OUT_OF_SEQ state.voidregisterHandlePropose(Behaviour b)This method allows to register a user definedBehaviourin the HANDLE_PROPOSE state.voidregisterPrepareCfps(Behaviour b)This method allows to register a user-definedBehaviourin the PREPARE_CFPS state.protected voidregisterPrepareInitiations(Behaviour b)Attach a behaviour to thePrepare-initiationsprotocol state.protected voidreinit()Re-initialize the internal state without performing a complete reset.voidreset()reset this behaviour by putting a null ACLMessage as message to be sentvoidreset(ACLMessage msg)reset this behaviourprotected voidsendInitiations(Vector initiations)This method sets for all prepared cfpsconversation-idslot (with value passed in the constructor),protocolslot andreply-withslot with a unique value constructed by concatenating receiver's agent name and phase number (i.e.voidsetDataStore(DataStore ds)Override the setDataStore() method to propagate this setting to all children.-
Methods inherited from class jade.core.behaviours.FSMBehaviour
checkTermination, deregisterDefaultTransition, deregisterState, deregisterTransition, forceTransitionTo, getChildren, getCurrent, getLastExitValue, getName, getPrevious, getState, handleInconsistentFSM, handleStateEntered, hasDefaultTransition, registerDefaultTransition, registerDefaultTransition, registerFirstState, registerLastState, registerState, registerTransition, registerTransition, resetStates, scheduleFirst, scheduleNext, stringifyTransitionTable
-
Methods inherited from class jade.core.behaviours.SerialBehaviour
handle
-
Methods inherited from class jade.core.behaviours.CompositeBehaviour
action, done, handleBlockEvent, handleRestartEvent, registerAsChild, resetChildren, setAgent
-
Methods inherited from class jade.core.behaviours.Behaviour
actionWrapper, block, block, getAgent, getBehaviourName, getDataStore, getExecutionState, getParent, getRestartCounter, isRunnable, restart, root, setBehaviourName, setExecutionState
-
-
-
-
Field Detail
-
CFP_KEY
public final String CFP_KEY
key to retrieve from the DataStore of the behaviour the ACLMessage object passed in the constructor of the class.
-
ALL_CFPS_KEY
public final String ALL_CFPS_KEY
key to retrieve from the DataStore of the behaviour the vector of CFP messages that have to be sent.
-
REPLY_KEY
public final String REPLY_KEY
key to retrieve from the DataStore of the behaviour the last ACLMessage object that has been received (null if the timeout expired).
-
ALL_RESPONSES_KEY
public final String ALL_RESPONSES_KEY
key to retrieve from the DataStore of the behaviour the vector of all messages that have been received as response.
-
ALL_PROPOSES_KEY
public final String ALL_PROPOSES_KEY
key to retrieve from the DataStore of the behaviour the vector of PROPOSE messages that have been received as response.
-
ALL_PENDINGS_KEY
public final String ALL_PENDINGS_KEY
key to retrieve from the DataStore of the behaviour the vector of CFP messages for which a response has not been received yet.
-
INITIATION_K
protected final String INITIATION_K
-
ALL_INITIATIONS_K
protected final String ALL_INITIATIONS_K
-
REPLY_K
protected final String REPLY_K
-
PREPARE_INITIATIONS
protected static final String PREPARE_INITIATIONS
- See Also:
- Constant Field Values
-
SEND_INITIATIONS
protected static final String SEND_INITIATIONS
- See Also:
- Constant Field Values
-
RECEIVE_REPLY
protected static final String RECEIVE_REPLY
- See Also:
- Constant Field Values
-
CHECK_IN_SEQ
protected static final String CHECK_IN_SEQ
- See Also:
- Constant Field Values
-
HANDLE_NOT_UNDERSTOOD
protected static final String HANDLE_NOT_UNDERSTOOD
- See Also:
- Constant Field Values
-
HANDLE_FAILURE
protected static final String HANDLE_FAILURE
- See Also:
- Constant Field Values
-
HANDLE_OUT_OF_SEQ
protected static final String HANDLE_OUT_OF_SEQ
- See Also:
- Constant Field Values
-
CHECK_SESSIONS
protected static final String CHECK_SESSIONS
- See Also:
- Constant Field Values
-
DUMMY_FINAL
protected static final String DUMMY_FINAL
- See Also:
- Constant Field Values
-
sessions
protected Map sessions
-
replyReceiver
protected MsgReceiver replyReceiver
-
replyTemplate
protected MessageTemplate replyTemplate
-
-
Constructor Detail
-
TwoPh0Initiator
public TwoPh0Initiator(Agent a, ACLMessage cfp, String outputKey)
Constructs aTwoPh0Initiatorbehaviour.- Parameters:
a- The agent performing the protocol.cfp- The message that must be used to initiate the protocol. Notice that the default implementation of theprepareCfpsmethod returns an array composed of that message only.outputKey- Data store key where the behaviour will store the Vector of messages to be sent to initiate the successive phase.
-
TwoPh0Initiator
public TwoPh0Initiator(Agent a, ACLMessage cfp, String outputKey, DataStore store)
Constructs aTwoPh0Initiatorbehaviour.- Parameters:
a- The agent performing the protocol.cfp- The message that must be used to initiate the protocol. Notice that the default implementation of theprepareCfpsmethod returns an array composed of that message only.outputKey- Data store key where the behaviour will store the Vector of messages to be sent to initiate the successive phase.store-DataStorethat will be used by thisTwoPh0Initiator.
-
-
Method Detail
-
onEnd
public int onEnd()
Description copied from class:FSMBehaviourOverride the onEnd() method to return the exit value of the last executed state.- Overrides:
onEndin classFSMBehaviour- Returns:
- an integer code representing the termination value of the behaviour.
-
prepareCfps
protected Vector prepareCfps(ACLMessage cfp)
This method must return the vector of ACLMessage objects to be sent. It is called in the first state of this protocol. This default implementation just returns the ACLMessage object (a CFP) passed in the constructor. Programmers might prefer to override this method in order to return a vector of CFP objects for 1:N conversations.- Parameters:
cfp- the ACLMessage object passed in the constructor- Returns:
- a vector of ACLMessage objects. The value of the
reply-withslot is ignored and regenerated automatically by this class. Instead user can specifyreply-byslot representing phase0 timeout.
-
handlePropose
protected void handlePropose(ACLMessage propose)
This method is called every time aproposemessage is received, which is not out-of-sequence according to the protocol rules. This default implementation does nothing; programmers might wish to override the method in case they need to react to this event.- Parameters:
propose- the received propose message
-
handleAllResponses
protected void handleAllResponses(Vector responses, Vector proposes, Vector pendings, Vector nextPhMsgs)
This method is called when all the responses have been collected or when the timeout is expired. The used timeout is the minimum value of the slotreply-Byof all the sent messages. By response message we intend here all thepropose, failure, not-understoodreceived messages, which are not out-of-sequence according to the protocol rules. This default implementation does nothing; programmers might wish to override this method to modify the Vector of initiation messages (nextPhMsgs) for next phase. More in details this Vector already includes messages with the performative set according to the default protocol rules i.e. QUERY_IF (if all responders replied with PROPOSE) or REJECT_PROPOSAL (if at least one responder failed or didn't reply). In particular, by setting thereply-byslot, users can specify a timeout for next phase.- Parameters:
responses- The Vector of all messages received as responseproposes- The Vector of PROPOSE messages received as responsependings- The Vector of CFP messages for which a response has not been received yetnextPhMsgs- The Vector of initiation messages for next phase already filled withQUERY_IFmessages (if all responders replied withPROPOSE) orREJECT_PROPOSAL(if at least one responder failed or didn't reply).
-
registerPrepareCfps
public void registerPrepareCfps(Behaviour b)
This method allows to register a user-definedBehaviourin the PREPARE_CFPS state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. It is responsibility of the registered behaviour to put theVectorof ACLMessage objects to be sent into the datastore at theALL_CFPS_KEYkey.- Parameters:
b- the Behaviour that will handle this state
-
registerHandlePropose
public void registerHandlePropose(Behaviour b)
This method allows to register a user definedBehaviourin the HANDLE_PROPOSE state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. The registered behaviour can retrieve theproposeACLMessage object received from the datastore at theREPLY_KEYkey.- Parameters:
b- the Behaviour that will handle this state
-
registerHandleAllResponses
public void registerHandleAllResponses(Behaviour b)
This method allows to register a user definedBehaviourin the HANDLE_ALL_RESPONSES state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. The registered behaviour can retrieve the vector of ACLMessage proposes, failures, pending and responses from the datastore atALL_PROPOSES_KEY,ALL_FAILURES_KEY,ALL_PH0_PENDINGS_KEYandoutputfield.- Parameters:
b- the Behaviour that will handle this state
-
getToBeReset
protected String[] getToBeReset()
Return the states that must be reset before they are visited again. Note that resetting a state before visiting it again is required only if - The onStart() method is redefined - The state has an "internal memory"
-
prepareInitiations
protected final Vector prepareInitiations(ACLMessage initiation)
Prepare vector containing cfps.- Parameters:
initiation- cfp passed in the constructor- Returns:
- Vector of cfps
-
sendInitiations
protected final void sendInitiations(Vector initiations)
This method sets for all prepared cfpsconversation-idslot (with value passed in the constructor),protocolslot andreply-withslot with a unique value constructed by concatenating receiver's agent name and phase number (i.e. 0). After that it sends all cfps.- Parameters:
initiations- vector prepared in PREPARE_CFPS state
-
checkInSequence
protected final boolean checkInSequence(ACLMessage reply)
Check whether a reply is in-sequence and than update the appropriate Session and removes corresponding cfp from vector of pendings.- Parameters:
reply- message received- Returns:
- true if reply is compliant with flow of protocol, false otherwise
-
checkSessions
protected final int checkSessions(ACLMessage reply)
Check if there are still active sessions or if timeout is expired.- Parameters:
reply- last message received- Returns:
- ALL_RESPONSES_RECEIVED or -1 (still active sessions)
-
initializeDataStore
protected void initializeDataStore(ACLMessage msg)
Initialize the data store.- Parameters:
msg- Message passed in the constructor
-
getSession
protected jade.proto.Initiator.ProtocolSession getSession(ACLMessage msg, int sessionIndex)
Return a ProtocolSession object to manage replies to a given initiation message
-
handleNotUnderstood
protected void handleNotUnderstood(ACLMessage notUnderstood)
This method is called every time anot-understoodmessage is received, which is not out-of-sequence according to the protocol rules. This default implementation does nothing; programmers might wish to override the method in case they need to react to this event.- Parameters:
notUnderstood- the received not-understood message
-
handleFailure
protected void handleFailure(ACLMessage failure)
This method is called every time afailuremessage is received, which is not out-of-sequence according to the protocol rules. This default implementation does nothing; programmers might wish to override the method in case they need to react to this event.- Parameters:
failure- the received failure message
-
handleOutOfSequence
protected void handleOutOfSequence(ACLMessage msg)
This method is called every time a message is received, which is out-of-sequence according to the protocol rules. This default implementation does nothing; programmers might wish to override the method in case they need to react to this event.- Parameters:
msg- the received message
-
registerPrepareInitiations
protected void registerPrepareInitiations(Behaviour b)
Attach a behaviour to thePrepare-initiationsprotocol state.- Parameters:
b- The behaviour object to be executed in thePrepare-initiationsstate.
-
registerHandleNotUnderstood
public void registerHandleNotUnderstood(Behaviour b)
This method allows to register a user definedBehaviourin the HANDLE_NOT_UNDERSTOOD state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. The registered behaviour can retrieve thenot-understoodACLMessage object received from the datastore at theREPLY_KEYkey.- Parameters:
b- the Behaviour that will handle this state
-
registerHandleFailure
public void registerHandleFailure(Behaviour b)
This method allows to register a user definedBehaviourin the HANDLE_FAILURE state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. The registered behaviour can retrieve thefailureACLMessage object received from the datastore at theREPLY_KEYkey.- Parameters:
b- the Behaviour that will handle this state
-
registerHandleOutOfSequence
public void registerHandleOutOfSequence(Behaviour b)
This method allows to register a user definedBehaviourin the HANDLE_OUT_OF_SEQ state. This behaviour would override the homonymous method. This method also set the data store of the registeredBehaviourto the DataStore of this current behaviour. The registered behaviour can retrieve theout of sequenceACLMessage object received from the datastore at theREPLY_KEYkey.- Parameters:
b- the Behaviour that will handle this state
-
reset
public void reset()
reset this behaviour by putting a null ACLMessage as message to be sent- Overrides:
resetin classFSMBehaviour
-
reset
public void reset(ACLMessage msg)
reset this behaviour- Parameters:
msg- is the ACLMessage to be sent
-
reinit
protected void reinit()
Re-initialize the internal state without performing a complete reset.
-
onStart
public void onStart()
Override the onStart() method to initialize the vectors that will keep all the replies in the data store.
-
setDataStore
public void setDataStore(DataStore ds)
Override the setDataStore() method to propagate this setting to all children.- Overrides:
setDataStorein classBehaviour- Parameters:
ds- theDataStorethat thisBehaviourwill use as its private data store
-
createConvId
protected String createConvId(Vector msgs)
Create a new conversation identifier to begin a new interaction.- Parameters:
msgs- A vector of ACL messages. If the first one has a non-empty:conversation-idslot, its value is used, else a new conversation identifier is generated.
-
adjustReplyTemplate
protected void adjustReplyTemplate(ACLMessage msg)
-
-