Priming The CLAMP Automation Composition Runtime Lifecycle Management uses the following system-level dialogues. These dialogues enable the CLAMP runtime capabilities described in Section 2 of TOSCA Defined Automation Compositions: Architecture and Design . Design Time dialogues will be described in future releases of the system.
1 Dialogues on Participants 1.1 Participant Registration Participant Registration is performed by a Participant when it starts up. It registers its ID and the ACM Element Types it supports with the ACM runtime. Participant Participant ACM_Runtime ACM_Runtime ACM_Database ACM_Database [ASYNC] Register [ASYNC] Create or Update Participant Registration and store supported ACM element types Registration Accepted
1.2 Participant Deregistration Participant Deregistration is performed by a Participant when it shuts down. It deregisters its ID and type with the ACM runtime.
The participant should already have cleared down all its ACM Element instances and set their states to UNINITIALIZED. Participant Participant ACM_Runtime ACM_Runtime ACM_Database ACM_Database Uninitialize all ACM Element Instances running on Participant (See Instantiation Dialogues) Delete Participant Registration [ASYNC] Deregistration Accepted
1.3 Participant Supervision Participant Supervision is performed periodically between participants and the ACM runtime server to ensure that registered participants are available over time. Participants send a heartbeat message to the ACM runtime at a configured interval.
Participant Participant ACM_Runtime ACM_Runtime ACM_Database ACM_Database loop [Every Participant Supervision Interval] Heartbeat message Update Participant Heartbeat data
The ACM runtime regularly checks the heartbeat reports from participants and takes action of participants time out. If a heartbeat message is not received for a participant in the Timeout Interval, the participant is marked as timed out and its ACM element instances are informed.
ACM_Runtime ACM_Runtime ACM_Database ACM_Database Database Database loop [Every ACM_Runtime Supervision Interval] loop [Over all Participants] Read Participant Heartbeat Information alt [Participant Heartbeat not received in Timeout Interval] Inform all ACM Element Instances running on Participant of Timeout (See Instantiation Dialogues)
The information on participants is available over a REST endpoint.
REST REST ACM_Runtime ACM_Runtime ACM_Database ACM_Database Get Participant Information Read Participant Data Return Participant Information including supported ACM Element Types and Heartbeat Information
2 Dialogues on Automation Composition Types
2.1
REST REST ACM_Runtime ACM_Runtime ACM_Database ACM_Database Commission Automation Composition Type alt [Automation Composition Type exists and has Instances] Automation Composition Type Commissioning Failed Create and Store Automation Composition Type Automation Composition Type Commissioned
2.2 SDC SDC Policy_Distribution Policy_Distribution ACM_Runtime ACM_Runtime [ASYNC] CSAR containing Automation Composition Type Definition Commission Automation Composition Type (See Commissioning Sequence Diagram) Result of Commissioning [ASYNC] Return result of Deployment
2.3 Decommissioning an Automation Composition Type Definition REST REST ACM_Runtime ACM_Runtime ACM_Database ACM_Database Decommission Automation Composition Type alt [Automation Composition Type has Instances] Automation Composition Type Decommissioning Failed Delete Automation Composition Type Automation Composition Type Decommissioned
2.4
REST REST ACM_Runtime ACM_Runtime Participant Participant ACM_Database ACM_Database Priming REST Request Prime Automation Composition Type Read Automation Composition Type [ASYNC] Send Priming Request to all Participants with Automation Composition Type Definition Priming of Automation Composition Type Ordered Each Participant [ASYNC] Receive Priming Request with Automation Composition Type Definition loop [Over all Automation Composition Element Type Definitions in Automation Composition Type Definition] alt [Automation Composition Element Type supported by Participant] Save Automation Composition Element Type details on this Participant [ASYNC] Send Priming Response claiming Automation Composition Element Type alt [Automation Composition Element Type already Primed] Ignore Priming Response Record Participant for Automation Composition Element Type and set Element Type as Primed Ignore Priming Request
2.5 This dialogue allows an Automation Composition Type to be read.
REST REST ACM_Runtime ACM_Runtime ACM_Database ACM_Database Get Automation Composition Type Information Read Automation Composition Type Information Respond with Automation Composition information including ACM Element Type information and Priming Status
3. Instantiation Dialogues
3.1 REST REST ACM_Runtime ACM_Runtime ACM_Database ACM_Database [REST] Read Automation Composition Type Definitions Read Automation Composition Type Definitions ACM_Runtime -> REST: [REST] Type Definitions returned Select Automation Composition Type Definition to use to create Automation Composition Instance [REST] Fetch GUI fields for Instance Specific Parameter Definitions ACM_Runtime -> ACM_Database: Read Automation Composition Type Definition ACM_Runtime -> ACM_Runtime: Generate fields for Instance Specific Parameters for GUI ACM_Runtime -> REST: [REST] Return GUI fields Instance Specific Parameter Definitions Render UI for Instance Specific Parameters REST -> REST: Get values for Instance Specific Parameters from user REST -> ACM_Runtime: [REST] Request Creation of Automation Composition Instance ACM_Runtime -> ACM_Runtime: Create Automation Composition Instance ACM_Runtime -> ACM_Database: Store First Version of Automation Composition Instance ACM_Runtime -> REST: [REST] Automation Composition Instance Updated
Note that this dialogue creates the Automation Composition Instance in the Instantiated Automation Composition Inventory. The instance is sent to the participants using the process described in the dialogue in Section 2.3.
3.2 Updating Instance Specific Parameters on an Automation Composition Instance Welcome to PlantUML! You can start with a simple UML Diagram like: Bob->Alice: Hello Or class Example You will find more information about PlantUML syntax on https://plantuml.com (Details by typing license keyword) PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.3 Updating an on Participants PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
Changing the state of an Automation Composition Instance on Participants PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.5 De-instantiating an Automation Composition Instance from Participants PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.6 Deleting an Automation Composition Instance PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.7 Reading Automation Composition Instances Welcome to PlantUML! You can start with a simple UML Diagram like: Bob->Alice: Hello Or class Example You will find more information about PlantUML syntax on https://plantuml.com (Details by typing license keyword) PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3. Monitoring Dialogues Monitoring dialogues are used to monitor and read statistics on Automation Composition Instances.
ACM_Runtime ACM_Runtime Participant Participant ACM_Database ACM_Database [DMaaP] Participant and Automation Composition Element Monitoring and Statistics report ACM_Runtime -> ACM_Database: Store Participant and Automation Composition Element Monitoring and Statistics report alt [Fault reported on Participant ACM_Runtime -> ACM_Runtime: log fault on Participant ACM_Runtime -> ACM_Database: Record fault on Participant] alt [Fault reported on Automation Composition Element ACM_Runtime -> ACM_Runtime: log fault on Automation Composition Element and Automation Composition ACM_Runtime -> ACM_Database: Record fault on Automation Composition Element and Automation Composition end]
PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.2 Viewing of Statistics PlantUML 1.2023.12 <b>This version of PlantUML is 342 days old, so you should <b>consider upgrading from https://plantuml.com/download [From string (line 3) ] @startuml participant REST participant ACM_Runtime Syntax Error?
3.3 Statistics Housekeeping ACM_Runtime ACM_Runtime ACM_Database ACM_Database Automation Composition Instance Statistics loop [forever ACM_Runtime -> ACM_Database: Read Automation Composition Instance Statistics ACM_Runtime -> ACM_Runtime: Summarise Automation Composition Instance Statistics ACM_Runtime -> ACM_Database: Store summarised Automation Composition Instance Statistics ACM_Runtime -> ACM_Database: Delete Automation Composition Instance Statistics on which retention period has expired] Participant Statistics loop [forever ACM_Runtime -> ACM_Database: Read Participant Statistics ACM_Runtime -> ACM_Runtime: Summarise Participant Statistics ACM_Runtime -> ACM_Database: Store summarised Participant Statistics ACM_Runtime -> ACM_Database: Delete Participant Statistics on which retention period has expired]
4. Supervision Dialogues Supervision dialogues are used to check the state of Automation Composition Instances and Participants.
4.1 Supervise Participants ACM_Runtime ACM_Runtime ACM_Database ACM_Database loop [forever ACM_Runtime -> ACM_Database: Read Participants] loop [Over each Participant] alt [Participant has not reported in last reporting window ACM_Runtime -> ACM_Runtime: Log Participant as having missed a report ACM_Runtime -> ACM_Database: Increment missed report counter on Participant] alt [Participant has exceeded alarm threshold on missed report counter ACM_Runtime -> ACM_Runtime: Raise a Participant Offline alarm on participant ACM_Runtime -> ACM_Database: Mark participant as being offline] [Participant has reported in last reporting window ACM_Runtime -> ACM_Database: Clear missed report counter on Participant] alt [Participant marked as being offline ACM_Runtime -> ACM_Runtime: Clear Participant Offline alarm on participant ACM_Runtime -> ACM_Database: Mark participant as being online]
4.2 Supervise Automation Compositions ACM_Runtime ACM_Runtime ACM_Database ACM_Database loop [forever ACM_Runtime -> ACM_Database: Read Automation Composition Instances] loop [Over each Automation Composition Instance] loop [Over each Automation Composition Element] alt [Automation Composition Element has not reported in last reporting window ACM_Runtime -> ACM_Runtime: Log Automation Composition Element as having missed a report ACM_Runtime -> ACM_Database: Increment missed report counter on Automation Composition Element] [Automation Composition Element has reported in last reporting window ACM_Runtime -> ACM_Database: Clear missed report counter on Automation Composition Element] alt [Automation Composition Element in incorrect state in last reporting window ACM_Runtime -> ACM_Runtime: Log Automation Composition Element as being in incorrect state ACM_Runtime -> ACM_Database: Record Automation Composition Element as being in incorrect state] [Automation Composition Element not in incorrect state in last reporting window] alt [Automation Composition Element was in incorrect state on previous report ACM_Runtime -> ACM_Runtime: Log Automation Composition Element as being in correct state ACM_Runtime -> ACM_Database: Record Automation Composition Element as being in correct state] alt [Automation Composition Element reported fault in last reporting window ACM_Runtime -> ACM_Runtime: Log Automation Composition Element as being faulty ACM_Runtime -> ACM_Database: Record Automation Composition Element as being faulty] [Automation Composition Element did not report fault in last reporting window] alt [Automation Composition Element reported fault on previous report ACM_Runtime -> ACM_Runtime: Log Automation Composition Element fault as cleared ACM_Runtime -> ACM_Database: Mark fault Automation Composition Element as being cleared] alt [Automation Composition Element in Automation Composition Instance has exceeded alarm threshold on missed report counter ACM_Runtime -> ACM_Runtime: Raise a Automation Composition Offline alarm on Automation Composition Instance ACM_Runtime -> ACM_Database: Mark Automation Composition Instance as being offline] [No Automation Composition Element in Automation Composition Instance has exceeded alarm threshold on missed report counter] alt [Automation Composition Instance marked as being offline ACM_Runtime -> ACM_Runtime: Clear Automation Composition Instance Offline alarm on Automation Composition ACM_Runtime -> ACM_Database: Mark Automation Composition Instance as being online] alt [Automation Composition Element in Automation Composition Instance in incorrect state in last reporting window ACM_Runtime -> ACM_Runtime: Log Automation Composition Instance as being in incorrect state ACM_Runtime -> ACM_Database: Record Automation Composition Instance as being in incorrect state] alt [Automation Composition Element in Automation Composition Instance has exceeded alarm threshold on incorrect state reports ACM_Runtime -> ACM_Runtime: Raise a Automation Composition Instance in Incorrect State alarm on Automation Composition Instance ACM_Runtime -> ACM_Database: Mark Automation Composition Instance as being in an incorrect state] [No Automation Composition Element in incorrect state in last reporting window] alt [Automation Composition Element in Automation Composition Instance was in incorrect state on previous report ACM_Runtime -> ACM_Runtime: Log Automation Composition Instance as being in correct state ACM_Runtime -> ACM_Database: Record Automation Composition Instance as being in correct state] alt [Automation Composition Instance in Incorrect State alarm raised on Automation Composition Instance ACM_Runtime -> ACM_Runtime: Clear Automation Composition Instance in Incorrect State alarm on Automation Composition Instance] alt [Automation Composition Element in Automation Composition Instance reported a fault in last reporting window ACM_Runtime -> ACM_Runtime: Log Automation Composition Instance as being faulty ACM_Runtime -> ACM_Database: Record Automation Composition Instance as being faulty] alt [Automation Composition Element in Automation Composition Instance has exceeded alarm threshold on faulty reports ACM_Runtime -> ACM_Runtime: Raise a Automation Composition Instance Faulty alarm on Automation Composition Instance] [No Automation Composition Element faulty in last reporting window] alt [Automation Composition Element in Automation Composition Instance was faulty on previous report ACM_Runtime -> ACM_Runtime: Log Automation Composition Instance as being fault free ACM_Runtime -> ACM_Database: Record Automation Composition Instance as being fault free] alt [Automation Composition Instance Faulty alarm raised on Automation Composition Instance ACM_Runtime -> ACM_Runtime: Clear Automation Composition Instance Faulty alarm on Automation Composition Instance]