Let's first describe the list of possible states:
- Service is non-existent; -> No service has been registered with a specified Id yet
- Service is pre-registration; -> Agent instance registration is not active yet
- Service is active-registration; -> Agent instance registration is ongoing
- Service is finished-registration; -> All the agent instances slots are registered
- Service is deployed; -> Service is deployed and operates via created multisig contract
- Service is terminated-bonded; -> Some agents are bonded with stake
In v1 the service has a static set of agent instances following activation of the registration.
Now let's see the evolution of states when calling each of the service functions that modify states between function entrance and exit. We assume that all the input that is passed to the contract is correct. Here we track only the states of the asynchronous on-chain behavior. By design, any attempts to bring service states to those that are not specified would throw an error.
- Current state: non-existent
- Next state: pre-registration
- Current state: pre-registration
- Next state: pre-registration
- Current state: pre-registration
- Next state: active-registration
- Current state: active-registration or finished-registration or deployed
- Next state: terminated-bonded or pre-registration
- Current state: expired-registration or terminated-bonded
- Next state: expired-registration or pre-registration
- Current state: Service is active-registration
- Next state: Service is active-registration or finished-registration
- Current state: finished-registration
- Next state: Service is deployed
Let's consider the change of states via the means of function calls from each specific state. Note that if the function being called from the current state is not included in the list of next possible states, its execution must not change the current state.
Functions to call from this state:
- createService()
List of next possible states:
- Service is pre-registration.
- Function call for this state: createService()
- Output: Unique incremented
service Id
Functions to call from this state:
- activateRegistration()
- update()
List of next possible states:
- Service is active-registration
- Function call for this state: activateRegistration()
Functions to call from this state:
- registerAgents()
- terminate()
-
Service is finished-registration
- Function call for this state: registerAgents()
- Condition: Number of agent instances reached its maximum value
-
Service is terminated-bonded
- Function call for this state: terminate()
- Condition: At least one agent instance is registered
-
Service is pre-registration
- Function call for this state: terminate()
- Condition: No single agent instance is registered
Functions to call from this state:
- deploy()
- terminate()
List of next possible states:
-
Service is deployed
- Function call for this state: deploy()
-
Service is terminated-bonded
- Function call for this state: terminate()
Functions to call from this state:
- terminate()
List of next possible states:
- Service is terminated-bonded
- Function call for this state: terminate()
Condition for this state: Service is terminated and some agents are bonded with agent instances.
Functions to call from this state:
- unbond()
List of next possible states:
- Service is pre-registration
- Function call for this state: unbond()
- Condition: No single agent instance is registered after the function call