From 9eb79ad7a278f4c04125643849bf2781fe284bad Mon Sep 17 00:00:00 2001
From: Isabel Heise <isabel.heise@informatik.hu-berlin.de>
Date: Mon, 9 Dec 2024 10:50:14 +0100
Subject: [PATCH] Update 12 files

- /JavaCloudWorker/mvnw.cmd
- /JavaCloudWorker/pom.xml
- /JavaCloudWorker/readme.md
- /JavaCloudWorker/mvnw
- /JavaCloudWorker/target/classes/application.yaml
- /JavaCloudWorker/target/classes/zeebe/camunda/worker/WorkerApplication.class
- /JavaCloudWorker/src/main/resources/application.yaml
- /JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java
- /check_system_integrety_form.form
- /classify_data_breach_form.form
- /Cybersecurity-Incident.bpmn
- /README.md
---
 Cybersecurity-Incident.bpmn                   | 321 ++++++++++++++++++
 JavaCloudWorker/mvnw                          | 310 +++++++++++++++++
 JavaCloudWorker/mvnw.cmd                      | 182 ++++++++++
 JavaCloudWorker/pom.xml                       |  52 +++
 JavaCloudWorker/readme.md                     |  22 ++
 .../camunda/worker/WorkerApplication.java     |  40 +++
 .../src/main/resources/application.yaml       |   8 +
 .../target/classes/application.yaml           |   8 +
 .../camunda/worker/WorkerApplication.class    | Bin 0 -> 2713 bytes
 README.md                                     |  92 +----
 check_system_integrety_form.form              |   1 +
 classify_data_breach_form.form                |   1 +
 12 files changed, 948 insertions(+), 89 deletions(-)
 create mode 100644 Cybersecurity-Incident.bpmn
 create mode 100644 JavaCloudWorker/mvnw
 create mode 100644 JavaCloudWorker/mvnw.cmd
 create mode 100644 JavaCloudWorker/pom.xml
 create mode 100644 JavaCloudWorker/readme.md
 create mode 100644 JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java
 create mode 100644 JavaCloudWorker/src/main/resources/application.yaml
 create mode 100644 JavaCloudWorker/target/classes/application.yaml
 create mode 100644 JavaCloudWorker/target/classes/zeebe/camunda/worker/WorkerApplication.class
 create mode 100644 check_system_integrety_form.form
 create mode 100644 classify_data_breach_form.form

diff --git a/Cybersecurity-Incident.bpmn b/Cybersecurity-Incident.bpmn
new file mode 100644
index 0000000..b065e4b
--- /dev/null
+++ b/Cybersecurity-Incident.bpmn
@@ -0,0 +1,321 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<bpmn:definitions xmlns:bpmn="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:dc="http://www.omg.org/spec/DD/20100524/DC" xmlns:modeler="http://camunda.org/schema/modeler/1.0" xmlns:di="http://www.omg.org/spec/DD/20100524/DI" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:zeebe="http://camunda.org/schema/zeebe/1.0" id="Definitions_1" targetNamespace="http://bpmn.io/schema/bpmn" exporter="Camunda Web Modeler" exporterVersion="0d4ab51" modeler:executionPlatform="Camunda Cloud" modeler:executionPlatformVersion="8.6.0">
+  <bpmn:process id="Process_14ywtdk" name="Cybersecurity-Incident" isExecutable="true">
+    <bpmn:startEvent id="StartEvent_1" name="Data breach identified">
+      <bpmn:outgoing>Flow_1xwt94g</bpmn:outgoing>
+    </bpmn:startEvent>
+    <bpmn:sequenceFlow id="Flow_1xwt94g" sourceRef="StartEvent_1" targetRef="Activity_0tfdjsk" />
+    <bpmn:exclusiveGateway id="Gateway_1xbod6o" name="Severity">
+      <bpmn:incoming>Flow_1md3fu2</bpmn:incoming>
+      <bpmn:outgoing>Flow_0hs0fky</bpmn:outgoing>
+      <bpmn:outgoing>Flow_13iai4n</bpmn:outgoing>
+    </bpmn:exclusiveGateway>
+    <bpmn:sequenceFlow id="Flow_1md3fu2" sourceRef="Activity_0tfdjsk" targetRef="Gateway_1xbod6o" />
+    <bpmn:sequenceFlow id="Flow_0hs0fky" name="Low Severity" sourceRef="Gateway_1xbod6o" targetRef="Activity_0jda4m0">
+      <bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">=matches(breach_class, "low")</bpmn:conditionExpression>
+    </bpmn:sequenceFlow>
+    <bpmn:endEvent id="Event_0p4uqww" name="Breach addressed">
+      <bpmn:incoming>Flow_1pxnl8f</bpmn:incoming>
+    </bpmn:endEvent>
+    <bpmn:sequenceFlow id="Flow_1pxnl8f" sourceRef="Activity_020uyya" targetRef="Event_0p4uqww" />
+    <bpmn:userTask id="Activity_0tfdjsk" name="Classify Data Breach">
+      <bpmn:extensionElements>
+        <zeebe:formDefinition formId="classify_data_breach_form" />
+      </bpmn:extensionElements>
+      <bpmn:incoming>Flow_1xwt94g</bpmn:incoming>
+      <bpmn:outgoing>Flow_1md3fu2</bpmn:outgoing>
+    </bpmn:userTask>
+    <bpmn:sequenceFlow id="Flow_13iai4n" name="High Severity" sourceRef="Gateway_1xbod6o" targetRef="Gateway_0nn8hf8">
+      <bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">=matches(breach_class, "high")</bpmn:conditionExpression>
+    </bpmn:sequenceFlow>
+    <bpmn:parallelGateway id="Gateway_0nn8hf8">
+      <bpmn:incoming>Flow_13iai4n</bpmn:incoming>
+      <bpmn:outgoing>Flow_0vlkwsn</bpmn:outgoing>
+      <bpmn:outgoing>Flow_14rz0nf</bpmn:outgoing>
+    </bpmn:parallelGateway>
+    <bpmn:task id="Activity_1hj6eiu" name="Develope Strategy">
+      <bpmn:incoming>Flow_0w3y6qd</bpmn:incoming>
+      <bpmn:outgoing>Flow_0eyuqk6</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:task id="Activity_1t8xv9j" name="Restore Operational Workflows">
+      <bpmn:incoming>Flow_0eyuqk6</bpmn:incoming>
+      <bpmn:outgoing>Flow_0fqpefi</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:sequenceFlow id="Flow_0eyuqk6" sourceRef="Activity_1hj6eiu" targetRef="Activity_1t8xv9j" />
+    <bpmn:sequenceFlow id="Flow_0fqpefi" sourceRef="Activity_1t8xv9j" targetRef="Activity_02e01ku" />
+    <bpmn:exclusiveGateway id="Gateway_0edep4g" name="System Integrity">
+      <bpmn:incoming>Flow_1eykyf1</bpmn:incoming>
+      <bpmn:outgoing>Flow_1w65oai</bpmn:outgoing>
+      <bpmn:outgoing>Flow_1odsz99</bpmn:outgoing>
+      <bpmn:outgoing>Flow_0pe6dua</bpmn:outgoing>
+    </bpmn:exclusiveGateway>
+    <bpmn:sequenceFlow id="Flow_1eykyf1" sourceRef="Activity_02e01ku" targetRef="Gateway_0edep4g" />
+    <bpmn:task id="Activity_1j50msg" name="Approve normal Operations">
+      <bpmn:incoming>Flow_1w65oai</bpmn:incoming>
+      <bpmn:outgoing>Flow_0tgcrwa</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:sequenceFlow id="Flow_1w65oai" name="System restored" sourceRef="Gateway_0edep4g" targetRef="Activity_1j50msg">
+      <bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">=matches(system_interety, "restored")</bpmn:conditionExpression>
+    </bpmn:sequenceFlow>
+    <bpmn:task id="Activity_0taabav" name="Declare Data Loss">
+      <bpmn:incoming>Flow_1odsz99</bpmn:incoming>
+      <bpmn:outgoing>Flow_08ux6w3</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:sequenceFlow id="Flow_1odsz99" name="Data loss" sourceRef="Gateway_0edep4g" targetRef="Activity_0taabav">
+      <bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">=matches(system_interety, "data_loss")</bpmn:conditionExpression>
+    </bpmn:sequenceFlow>
+    <bpmn:exclusiveGateway id="Gateway_0gl5f58">
+      <bpmn:incoming>Flow_0tgcrwa</bpmn:incoming>
+      <bpmn:incoming>Flow_08ux6w3</bpmn:incoming>
+      <bpmn:outgoing>Flow_1g4eezq</bpmn:outgoing>
+    </bpmn:exclusiveGateway>
+    <bpmn:sequenceFlow id="Flow_0tgcrwa" sourceRef="Activity_1j50msg" targetRef="Gateway_0gl5f58" />
+    <bpmn:sequenceFlow id="Flow_08ux6w3" sourceRef="Activity_0taabav" targetRef="Gateway_0gl5f58" />
+    <bpmn:sequenceFlow id="Flow_1g4eezq" sourceRef="Gateway_0gl5f58" targetRef="Gateway_11v9dm5" />
+    <bpmn:sequenceFlow id="Flow_1lld3vc" sourceRef="Activity_0mmeygm" targetRef="Gateway_11v9dm5" />
+    <bpmn:parallelGateway id="Gateway_11v9dm5">
+      <bpmn:incoming>Flow_1lld3vc</bpmn:incoming>
+      <bpmn:incoming>Flow_1g4eezq</bpmn:incoming>
+      <bpmn:outgoing>Flow_124idhi</bpmn:outgoing>
+    </bpmn:parallelGateway>
+    <bpmn:exclusiveGateway id="Gateway_018xxjb">
+      <bpmn:incoming>Flow_124idhi</bpmn:incoming>
+      <bpmn:incoming>Flow_04e72pz</bpmn:incoming>
+      <bpmn:outgoing>Flow_1cy3sri</bpmn:outgoing>
+    </bpmn:exclusiveGateway>
+    <bpmn:sequenceFlow id="Flow_124idhi" sourceRef="Gateway_11v9dm5" targetRef="Gateway_018xxjb" />
+    <bpmn:sequenceFlow id="Flow_04e72pz" sourceRef="Activity_0jda4m0" targetRef="Gateway_018xxjb" />
+    <bpmn:sequenceFlow id="Flow_1cy3sri" sourceRef="Gateway_018xxjb" targetRef="Activity_020uyya" />
+    <bpmn:exclusiveGateway id="Gateway_0d4c7h8">
+      <bpmn:incoming>Flow_0vlkwsn</bpmn:incoming>
+      <bpmn:incoming>Flow_0pe6dua</bpmn:incoming>
+      <bpmn:outgoing>Flow_0w3y6qd</bpmn:outgoing>
+    </bpmn:exclusiveGateway>
+    <bpmn:sequenceFlow id="Flow_0vlkwsn" sourceRef="Gateway_0nn8hf8" targetRef="Gateway_0d4c7h8" />
+    <bpmn:sequenceFlow id="Flow_0w3y6qd" sourceRef="Gateway_0d4c7h8" targetRef="Activity_1hj6eiu" />
+    <bpmn:sequenceFlow id="Flow_0pe6dua" name="System needs improvement" sourceRef="Gateway_0edep4g" targetRef="Gateway_0d4c7h8">
+      <bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">=matches(system_interety, "needs_improvement")</bpmn:conditionExpression>
+    </bpmn:sequenceFlow>
+    <bpmn:userTask id="Activity_02e01ku" name="Check System Integrity">
+      <bpmn:extensionElements>
+        <zeebe:formDefinition formId="check_system_integrety_form" />
+      </bpmn:extensionElements>
+      <bpmn:incoming>Flow_0fqpefi</bpmn:incoming>
+      <bpmn:outgoing>Flow_1eykyf1</bpmn:outgoing>
+    </bpmn:userTask>
+    <bpmn:serviceTask id="Activity_0mmeygm" name="Contact Stakeholders and Authorities">
+      <bpmn:extensionElements>
+        <zeebe:taskDefinition type="contact_stakeholders_and_authorities" />
+      </bpmn:extensionElements>
+      <bpmn:incoming>Flow_1oe0n4m</bpmn:incoming>
+      <bpmn:outgoing>Flow_1lld3vc</bpmn:outgoing>
+    </bpmn:serviceTask>
+    <bpmn:serviceTask id="Activity_020uyya" name="Document Incident">
+      <bpmn:extensionElements>
+        <zeebe:taskDefinition type="document_incident" />
+      </bpmn:extensionElements>
+      <bpmn:incoming>Flow_1cy3sri</bpmn:incoming>
+      <bpmn:outgoing>Flow_1pxnl8f</bpmn:outgoing>
+    </bpmn:serviceTask>
+    <bpmn:task id="Activity_0jda4m0" name="Secure Systems">
+      <bpmn:incoming>Flow_0hs0fky</bpmn:incoming>
+      <bpmn:outgoing>Flow_04e72pz</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:task id="Activity_162wji2" name="Prepare statement">
+      <bpmn:incoming>Flow_14rz0nf</bpmn:incoming>
+      <bpmn:outgoing>Flow_1oe0n4m</bpmn:outgoing>
+    </bpmn:task>
+    <bpmn:sequenceFlow id="Flow_14rz0nf" sourceRef="Gateway_0nn8hf8" targetRef="Activity_162wji2" />
+    <bpmn:sequenceFlow id="Flow_1oe0n4m" sourceRef="Activity_162wji2" targetRef="Activity_0mmeygm" />
+  </bpmn:process>
+  <bpmndi:BPMNDiagram id="BPMNDiagram_1">
+    <bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="Process_14ywtdk">
+      <bpmndi:BPMNShape id="_BPMNShape_StartEvent_2" bpmnElement="StartEvent_1">
+        <dc:Bounds x="172" y="152" width="36" height="36" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="160" y="195" width="60" height="27" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_1xbod6o_di" bpmnElement="Gateway_1xbod6o" isMarkerVisible="true">
+        <dc:Bounds x="475" y="145" width="50" height="50" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="479" y="123" width="42" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Event_0p4uqww_di" bpmnElement="Event_0p4uqww">
+        <dc:Bounds x="2352" y="546" width="36" height="36" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="2325" y="589" width="90" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_0l8tk9d_di" bpmnElement="Activity_0tfdjsk">
+        <dc:Bounds x="290" y="130" width="100" height="80" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_1ynf3e6_di" bpmnElement="Gateway_0nn8hf8">
+        <dc:Bounds x="615" y="325" width="50" height="50" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_1hj6eiu_di" bpmnElement="Activity_1hj6eiu">
+        <dc:Bounds x="760" y="524" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_1t8xv9j_di" bpmnElement="Activity_1t8xv9j">
+        <dc:Bounds x="960" y="524" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_0edep4g_di" bpmnElement="Gateway_0edep4g" isMarkerVisible="true">
+        <dc:Bounds x="1365" y="539" width="50" height="50" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="1300" y="533" width="79" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_1j50msg_di" bpmnElement="Activity_1j50msg">
+        <dc:Bounds x="1520" y="414" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_0taabav_di" bpmnElement="Activity_0taabav">
+        <dc:Bounds x="1520" y="524" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_0gl5f58_di" bpmnElement="Gateway_0gl5f58" isMarkerVisible="true">
+        <dc:Bounds x="1725" y="539" width="50" height="50" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_1as1ccm_di" bpmnElement="Gateway_11v9dm5">
+        <dc:Bounds x="1885" y="539" width="50" height="50" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_018xxjb_di" bpmnElement="Gateway_018xxjb" isMarkerVisible="true">
+        <dc:Bounds x="2045" y="539" width="50" height="50" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Gateway_0d4c7h8_di" bpmnElement="Gateway_0d4c7h8" isMarkerVisible="true">
+        <dc:Bounds x="615" y="539" width="50" height="50" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_02902av_di" bpmnElement="Activity_02e01ku">
+        <dc:Bounds x="1160" y="524" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_0x5x3m1_di" bpmnElement="Activity_020uyya">
+        <dc:Bounds x="2180" y="524" width="100" height="80" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_072atxm_di" bpmnElement="Activity_0jda4m0">
+        <dc:Bounds x="760" y="130" width="100" height="80" />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_162wji2_di" bpmnElement="Activity_162wji2">
+        <dc:Bounds x="760" y="310" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNShape id="Activity_1pxpbtz_di" bpmnElement="Activity_0mmeygm">
+        <dc:Bounds x="960" y="310" width="100" height="80" />
+        <bpmndi:BPMNLabel />
+      </bpmndi:BPMNShape>
+      <bpmndi:BPMNEdge id="Flow_1xwt94g_di" bpmnElement="Flow_1xwt94g">
+        <di:waypoint x="208" y="170" />
+        <di:waypoint x="290" y="170" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1md3fu2_di" bpmnElement="Flow_1md3fu2">
+        <di:waypoint x="390" y="170" />
+        <di:waypoint x="475" y="170" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0hs0fky_di" bpmnElement="Flow_0hs0fky">
+        <di:waypoint x="525" y="170" />
+        <di:waypoint x="760" y="170" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="609" y="152" width="67" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1pxnl8f_di" bpmnElement="Flow_1pxnl8f">
+        <di:waypoint x="2280" y="564" />
+        <di:waypoint x="2352" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_13iai4n_di" bpmnElement="Flow_13iai4n">
+        <di:waypoint x="500" y="195" />
+        <di:waypoint x="500" y="350" />
+        <di:waypoint x="615" y="350" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="507" y="202" width="66" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0eyuqk6_di" bpmnElement="Flow_0eyuqk6">
+        <di:waypoint x="860" y="564" />
+        <di:waypoint x="960" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0fqpefi_di" bpmnElement="Flow_0fqpefi">
+        <di:waypoint x="1060" y="564" />
+        <di:waypoint x="1160" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1eykyf1_di" bpmnElement="Flow_1eykyf1">
+        <di:waypoint x="1260" y="564" />
+        <di:waypoint x="1365" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1w65oai_di" bpmnElement="Flow_1w65oai">
+        <di:waypoint x="1390" y="539" />
+        <di:waypoint x="1390" y="454" />
+        <di:waypoint x="1520" y="454" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="1399" y="494" width="81" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1odsz99_di" bpmnElement="Flow_1odsz99">
+        <di:waypoint x="1415" y="564" />
+        <di:waypoint x="1520" y="564" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="1445" y="546" width="46" height="14" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0tgcrwa_di" bpmnElement="Flow_0tgcrwa">
+        <di:waypoint x="1620" y="454" />
+        <di:waypoint x="1750" y="454" />
+        <di:waypoint x="1750" y="539" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_08ux6w3_di" bpmnElement="Flow_08ux6w3">
+        <di:waypoint x="1620" y="564" />
+        <di:waypoint x="1725" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1g4eezq_di" bpmnElement="Flow_1g4eezq">
+        <di:waypoint x="1775" y="564" />
+        <di:waypoint x="1885" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1lld3vc_di" bpmnElement="Flow_1lld3vc">
+        <di:waypoint x="1060" y="350" />
+        <di:waypoint x="1910" y="350" />
+        <di:waypoint x="1910" y="539" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_124idhi_di" bpmnElement="Flow_124idhi">
+        <di:waypoint x="1935" y="564" />
+        <di:waypoint x="2045" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_04e72pz_di" bpmnElement="Flow_04e72pz">
+        <di:waypoint x="860" y="170" />
+        <di:waypoint x="2070" y="170" />
+        <di:waypoint x="2070" y="539" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1cy3sri_di" bpmnElement="Flow_1cy3sri">
+        <di:waypoint x="2095" y="564" />
+        <di:waypoint x="2180" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0vlkwsn_di" bpmnElement="Flow_0vlkwsn">
+        <di:waypoint x="640" y="375" />
+        <di:waypoint x="640" y="539" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0w3y6qd_di" bpmnElement="Flow_0w3y6qd">
+        <di:waypoint x="665" y="564" />
+        <di:waypoint x="760" y="564" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_0pe6dua_di" bpmnElement="Flow_0pe6dua">
+        <di:waypoint x="1390" y="589" />
+        <di:waypoint x="1390" y="700" />
+        <di:waypoint x="640" y="700" />
+        <di:waypoint x="640" y="589" />
+        <bpmndi:BPMNLabel>
+          <dc:Bounds x="1313" y="666" width="73" height="27" />
+        </bpmndi:BPMNLabel>
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_14rz0nf_di" bpmnElement="Flow_14rz0nf">
+        <di:waypoint x="665" y="350" />
+        <di:waypoint x="760" y="350" />
+      </bpmndi:BPMNEdge>
+      <bpmndi:BPMNEdge id="Flow_1oe0n4m_di" bpmnElement="Flow_1oe0n4m">
+        <di:waypoint x="860" y="350" />
+        <di:waypoint x="960" y="350" />
+      </bpmndi:BPMNEdge>
+    </bpmndi:BPMNPlane>
+  </bpmndi:BPMNDiagram>
+</bpmn:definitions>
diff --git a/JavaCloudWorker/mvnw b/JavaCloudWorker/mvnw
new file mode 100644
index 0000000..a16b543
--- /dev/null
+++ b/JavaCloudWorker/mvnw
@@ -0,0 +1,310 @@
+#!/bin/sh
+# ----------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#    https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+# ----------------------------------------------------------------------------
+
+# ----------------------------------------------------------------------------
+# Maven Start Up Batch script
+#
+# Required ENV vars:
+# ------------------
+#   JAVA_HOME - location of a JDK home dir
+#
+# Optional ENV vars
+# -----------------
+#   M2_HOME - location of maven2's installed home dir
+#   MAVEN_OPTS - parameters passed to the Java VM when running Maven
+#     e.g. to debug Maven itself, use
+#       set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
+#   MAVEN_SKIP_RC - flag to disable loading of mavenrc files
+# ----------------------------------------------------------------------------
+
+if [ -z "$MAVEN_SKIP_RC" ] ; then
+
+  if [ -f /etc/mavenrc ] ; then
+    . /etc/mavenrc
+  fi
+
+  if [ -f "$HOME/.mavenrc" ] ; then
+    . "$HOME/.mavenrc"
+  fi
+
+fi
+
+# OS specific support.  $var _must_ be set to either true or false.
+cygwin=false;
+darwin=false;
+mingw=false
+case "`uname`" in
+  CYGWIN*) cygwin=true ;;
+  MINGW*) mingw=true;;
+  Darwin*) darwin=true
+    # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
+    # See https://developer.apple.com/library/mac/qa/qa1170/_index.html
+    if [ -z "$JAVA_HOME" ]; then
+      if [ -x "/usr/libexec/java_home" ]; then
+        export JAVA_HOME="`/usr/libexec/java_home`"
+      else
+        export JAVA_HOME="/Library/Java/Home"
+      fi
+    fi
+    ;;
+esac
+
+if [ -z "$JAVA_HOME" ] ; then
+  if [ -r /etc/gentoo-release ] ; then
+    JAVA_HOME=`java-config --jre-home`
+  fi
+fi
+
+if [ -z "$M2_HOME" ] ; then
+  ## resolve links - $0 may be a link to maven's home
+  PRG="$0"
+
+  # need this for relative symlinks
+  while [ -h "$PRG" ] ; do
+    ls=`ls -ld "$PRG"`
+    link=`expr "$ls" : '.*-> \(.*\)$'`
+    if expr "$link" : '/.*' > /dev/null; then
+      PRG="$link"
+    else
+      PRG="`dirname "$PRG"`/$link"
+    fi
+  done
+
+  saveddir=`pwd`
+
+  M2_HOME=`dirname "$PRG"`/..
+
+  # make it fully qualified
+  M2_HOME=`cd "$M2_HOME" && pwd`
+
+  cd "$saveddir"
+  # echo Using m2 at $M2_HOME
+fi
+
+# For Cygwin, ensure paths are in UNIX format before anything is touched
+if $cygwin ; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME=`cygpath --unix "$M2_HOME"`
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
+fi
+
+# For Mingw, ensure paths are in UNIX format before anything is touched
+if $mingw ; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME="`(cd "$M2_HOME"; pwd)`"
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
+fi
+
+if [ -z "$JAVA_HOME" ]; then
+  javaExecutable="`which javac`"
+  if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
+    # readlink(1) is not available as standard on Solaris 10.
+    readLink=`which readlink`
+    if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
+      if $darwin ; then
+        javaHome="`dirname \"$javaExecutable\"`"
+        javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
+      else
+        javaExecutable="`readlink -f \"$javaExecutable\"`"
+      fi
+      javaHome="`dirname \"$javaExecutable\"`"
+      javaHome=`expr "$javaHome" : '\(.*\)/bin'`
+      JAVA_HOME="$javaHome"
+      export JAVA_HOME
+    fi
+  fi
+fi
+
+if [ -z "$JAVACMD" ] ; then
+  if [ -n "$JAVA_HOME"  ] ; then
+    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+      # IBM's JDK on AIX uses strange locations for the executables
+      JAVACMD="$JAVA_HOME/jre/sh/java"
+    else
+      JAVACMD="$JAVA_HOME/bin/java"
+    fi
+  else
+    JAVACMD="`which java`"
+  fi
+fi
+
+if [ ! -x "$JAVACMD" ] ; then
+  echo "Error: JAVA_HOME is not defined correctly." >&2
+  echo "  We cannot execute $JAVACMD" >&2
+  exit 1
+fi
+
+if [ -z "$JAVA_HOME" ] ; then
+  echo "Warning: JAVA_HOME environment variable is not set."
+fi
+
+CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
+
+# traverses directory structure from process work directory to filesystem root
+# first directory with .mvn subdirectory is considered project base directory
+find_maven_basedir() {
+
+  if [ -z "$1" ]
+  then
+    echo "Path not specified to find_maven_basedir"
+    return 1
+  fi
+
+  basedir="$1"
+  wdir="$1"
+  while [ "$wdir" != '/' ] ; do
+    if [ -d "$wdir"/.mvn ] ; then
+      basedir=$wdir
+      break
+    fi
+    # workaround for JBEAP-8937 (on Solaris 10/Sparc)
+    if [ -d "${wdir}" ]; then
+      wdir=`cd "$wdir/.."; pwd`
+    fi
+    # end of workaround
+  done
+  echo "${basedir}"
+}
+
+# concatenates all lines of a file
+concat_lines() {
+  if [ -f "$1" ]; then
+    echo "$(tr -s '\n' ' ' < "$1")"
+  fi
+}
+
+BASE_DIR=`find_maven_basedir "$(pwd)"`
+if [ -z "$BASE_DIR" ]; then
+  exit 1;
+fi
+
+##########################################################################################
+# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
+# This allows using the maven wrapper in projects that prohibit checking in binary data.
+##########################################################################################
+if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Found .mvn/wrapper/maven-wrapper.jar"
+    fi
+else
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
+    fi
+    if [ -n "$MVNW_REPOURL" ]; then
+      jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+    else
+      jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+    fi
+    while IFS="=" read key value; do
+      case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
+      esac
+    done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Downloading from: $jarUrl"
+    fi
+    wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
+    if $cygwin; then
+      wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
+    fi
+
+    if command -v wget > /dev/null; then
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Found wget ... using wget"
+        fi
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            wget "$jarUrl" -O "$wrapperJarPath"
+        else
+            wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
+        fi
+    elif command -v curl > /dev/null; then
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Found curl ... using curl"
+        fi
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            curl -o "$wrapperJarPath" "$jarUrl" -f
+        else
+            curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
+        fi
+
+    else
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Falling back to using Java to download"
+        fi
+        javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
+        # For Cygwin, switch paths to Windows format before running javac
+        if $cygwin; then
+          javaClass=`cygpath --path --windows "$javaClass"`
+        fi
+        if [ -e "$javaClass" ]; then
+            if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
+                if [ "$MVNW_VERBOSE" = true ]; then
+                  echo " - Compiling MavenWrapperDownloader.java ..."
+                fi
+                # Compiling the Java class
+                ("$JAVA_HOME/bin/javac" "$javaClass")
+            fi
+            if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
+                # Running the downloader
+                if [ "$MVNW_VERBOSE" = true ]; then
+                  echo " - Running MavenWrapperDownloader.java ..."
+                fi
+                ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
+            fi
+        fi
+    fi
+fi
+##########################################################################################
+# End of extension
+##########################################################################################
+
+export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
+if [ "$MVNW_VERBOSE" = true ]; then
+  echo $MAVEN_PROJECTBASEDIR
+fi
+MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME=`cygpath --path --windows "$M2_HOME"`
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
+  [ -n "$MAVEN_PROJECTBASEDIR" ] &&
+    MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
+fi
+
+# Provide a "standardized" way to retrieve the CLI args that will
+# work with both Windows and non-Windows executions.
+MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
+export MAVEN_CMD_LINE_ARGS
+
+WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
+
+exec "$JAVACMD" \
+  $MAVEN_OPTS \
+  -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
+  "-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
+  ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"
diff --git a/JavaCloudWorker/mvnw.cmd b/JavaCloudWorker/mvnw.cmd
new file mode 100644
index 0000000..c8d4337
--- /dev/null
+++ b/JavaCloudWorker/mvnw.cmd
@@ -0,0 +1,182 @@
+@REM ----------------------------------------------------------------------------
+@REM Licensed to the Apache Software Foundation (ASF) under one
+@REM or more contributor license agreements.  See the NOTICE file
+@REM distributed with this work for additional information
+@REM regarding copyright ownership.  The ASF licenses this file
+@REM to you under the Apache License, Version 2.0 (the
+@REM "License"); you may not use this file except in compliance
+@REM with the License.  You may obtain a copy of the License at
+@REM
+@REM    https://www.apache.org/licenses/LICENSE-2.0
+@REM
+@REM Unless required by applicable law or agreed to in writing,
+@REM software distributed under the License is distributed on an
+@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+@REM KIND, either express or implied.  See the License for the
+@REM specific language governing permissions and limitations
+@REM under the License.
+@REM ----------------------------------------------------------------------------
+
+@REM ----------------------------------------------------------------------------
+@REM Maven Start Up Batch script
+@REM
+@REM Required ENV vars:
+@REM JAVA_HOME - location of a JDK home dir
+@REM
+@REM Optional ENV vars
+@REM M2_HOME - location of maven2's installed home dir
+@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
+@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
+@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
+@REM     e.g. to debug Maven itself, use
+@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
+@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
+@REM ----------------------------------------------------------------------------
+
+@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
+@echo off
+@REM set title of command window
+title %0
+@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
+@if "%MAVEN_BATCH_ECHO%" == "on"  echo %MAVEN_BATCH_ECHO%
+
+@REM set %HOME% to equivalent of $HOME
+if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
+
+@REM Execute a user defined script before this one
+if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
+@REM check for pre script, once with legacy .bat ending and once with .cmd ending
+if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
+if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
+:skipRcPre
+
+@setlocal
+
+set ERROR_CODE=0
+
+@REM To isolate internal variables from possible post scripts, we use another setlocal
+@setlocal
+
+@REM ==== START VALIDATION ====
+if not "%JAVA_HOME%" == "" goto OkJHome
+
+echo.
+echo Error: JAVA_HOME not found in your environment. >&2
+echo Please set the JAVA_HOME variable in your environment to match the >&2
+echo location of your Java installation. >&2
+echo.
+goto error
+
+:OkJHome
+if exist "%JAVA_HOME%\bin\java.exe" goto init
+
+echo.
+echo Error: JAVA_HOME is set to an invalid directory. >&2
+echo JAVA_HOME = "%JAVA_HOME%" >&2
+echo Please set the JAVA_HOME variable in your environment to match the >&2
+echo location of your Java installation. >&2
+echo.
+goto error
+
+@REM ==== END VALIDATION ====
+
+:init
+
+@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
+@REM Fallback to current working directory if not found.
+
+set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
+IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
+
+set EXEC_DIR=%CD%
+set WDIR=%EXEC_DIR%
+:findBaseDir
+IF EXIST "%WDIR%"\.mvn goto baseDirFound
+cd ..
+IF "%WDIR%"=="%CD%" goto baseDirNotFound
+set WDIR=%CD%
+goto findBaseDir
+
+:baseDirFound
+set MAVEN_PROJECTBASEDIR=%WDIR%
+cd "%EXEC_DIR%"
+goto endDetectBaseDir
+
+:baseDirNotFound
+set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
+cd "%EXEC_DIR%"
+
+:endDetectBaseDir
+
+IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
+
+@setlocal EnableExtensions EnableDelayedExpansion
+for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
+@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
+
+:endReadAdditionalConfig
+
+SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
+set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
+set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
+
+set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+
+FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
+    IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
+)
+
+@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
+@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
+if exist %WRAPPER_JAR% (
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Found %WRAPPER_JAR%
+    )
+) else (
+    if not "%MVNW_REPOURL%" == "" (
+        SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+    )
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Couldn't find %WRAPPER_JAR%, downloading it ...
+        echo Downloading from: %DOWNLOAD_URL%
+    )
+
+    powershell -Command "&{"^
+		"$webclient = new-object System.Net.WebClient;"^
+		"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
+		"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
+		"}"^
+		"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
+		"}"
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Finished downloading %WRAPPER_JAR%
+    )
+)
+@REM End of extension
+
+@REM Provide a "standardized" way to retrieve the CLI args that will
+@REM work with both Windows and non-Windows executions.
+set MAVEN_CMD_LINE_ARGS=%*
+
+%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
+if ERRORLEVEL 1 goto error
+goto end
+
+:error
+set ERROR_CODE=1
+
+:end
+@endlocal & set ERROR_CODE=%ERROR_CODE%
+
+if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
+@REM check for post script, once with legacy .bat ending and once with .cmd ending
+if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
+if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
+:skipRcPost
+
+@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
+if "%MAVEN_BATCH_PAUSE%" == "on" pause
+
+if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
+
+exit /B %ERROR_CODE%
diff --git a/JavaCloudWorker/pom.xml b/JavaCloudWorker/pom.xml
new file mode 100644
index 0000000..0122835
--- /dev/null
+++ b/JavaCloudWorker/pom.xml
@@ -0,0 +1,52 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springframework.boot</groupId>
+		<artifactId>spring-boot-starter-parent</artifactId>
+		<version>3.1.5</version>
+		<relativePath/> <!-- lookup parent from repository -->
+	</parent>
+	<groupId>org.camunda</groupId>
+	<artifactId>worker</artifactId>
+	<version>0.0.1-SNAPSHOT</version>
+	<name>worker</name>
+	<description>Camunda Platform 8 Order to Cash Worker</description>
+	<properties>
+		<java.version>17</java.version>
+	</properties>
+	<dependencies>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter</artifactId>
+		</dependency>
+
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-test</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>io.camunda.spring</groupId>
+			<artifactId>spring-boot-starter-camunda</artifactId>
+			<version>8.2.4</version>
+		</dependency>
+
+		<dependency>
+			<groupId>io.camunda</groupId>
+			<artifactId>zeebe-client-java</artifactId>
+			<version>8.1.9</version>
+		</dependency>
+	</dependencies>
+
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.springframework.boot</groupId>
+				<artifactId>spring-boot-maven-plugin</artifactId>
+			</plugin>
+		</plugins>
+	</build>
+
+</project>
diff --git a/JavaCloudWorker/readme.md b/JavaCloudWorker/readme.md
new file mode 100644
index 0000000..5d29991
--- /dev/null
+++ b/JavaCloudWorker/readme.md
@@ -0,0 +1,22 @@
+## Java Camunda Platform 8 Worker 
+This folder holds all the code for the Java Spring Boot version of the Camunda 8 Worker. As client implementation we have used the spring-zeebe dependency. You can find the GitHub repository right [here](https://github.com/camunda-community-hub/spring-zeebe).
+
+In case you want to add this into your project as well just use this dependency in your pom file:
+```xml
+<dependency>
+  <groupId>io.camunda</groupId>
+  <artifactId>spring-zeebe-starter</artifactId>
+  <version>${CURRENT_VERSION}</version>
+</dependency>
+```
+
+You need to configure properties for Camunda Platform 8 in your resources folder under "application.properties". All necessary information can be retrieved from the Camunda 8 console (Cluster API view) right away. Remember to first of all create a client credential in order to make this possible. 
+
+### JSON Payload to start the process
+```json
+  {
+    "person_uuid": "Carl",
+    "employment_category": "critical infrastructure",
+    "age": 25
+  }
+```
diff --git a/JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java b/JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java
new file mode 100644
index 0000000..16e1f69
--- /dev/null
+++ b/JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java
@@ -0,0 +1,40 @@
+package zeebe.camunda.worker;
+
+import io.camunda.zeebe.client.ZeebeClient;
+import io.camunda.zeebe.client.api.response.ActivatedJob;
+import io.camunda.zeebe.spring.client.annotation.JobWorker;
+import io.camunda.zeebe.spring.client.annotation.Variable;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+import java.util.UUID;
+import java.util.logging.ConsoleHandler;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+
+@SpringBootApplication
+public class WorkerApplication {
+	static Logger logger = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME);
+	static ConsoleHandler handler = new ConsoleHandler();
+	@Autowired
+	private ZeebeClient client;
+
+	public static void main(String[] args) {
+		SpringApplication.run(WorkerApplication.class, args);
+		logger.setLevel(Level.ALL);
+		handler.setLevel(Level.ALL);
+		logger.addHandler(handler);
+	}
+
+	@JobWorker(type = "contact_stakeholders_and_authorities")
+	public void contact(@Variable String message) {
+		logger.info("\nContact stakeholders and authorities: " + message);
+	}
+
+	@JobWorker(type = "document_incident")
+	public void documenting(@Variable String message, @Variable String system_interety) {
+		logger.info("\nDocument incident:\nMessage: " + message + "\nSystem integrety: " +system_interety);
+	}
+}
diff --git a/JavaCloudWorker/src/main/resources/application.yaml b/JavaCloudWorker/src/main/resources/application.yaml
new file mode 100644
index 0000000..5674b9b
--- /dev/null
+++ b/JavaCloudWorker/src/main/resources/application.yaml
@@ -0,0 +1,8 @@
+# https://github.com/camunda-community-hub/spring-zeebe#configuring-camunda-platform-8-saas-connection
+# https://github.com/camunda-community-hub/spring-zeebe#additional-configuration-options
+zeebe.client:
+    cloud:
+        region: bru-2
+        clusterId: 66e8db1c-d166-4774-bed4-59b359cd7f6f
+        clientId: LGQTpQ~1Vmp9L4~zqhWWi28-RWaEg81f
+        clientSecret: TtaChX22nTZh9WFnZv6SThsG1TIFBClBvWHV.QzE~NDvDHAs0hFi5PVe~ZVAaXbD
\ No newline at end of file
diff --git a/JavaCloudWorker/target/classes/application.yaml b/JavaCloudWorker/target/classes/application.yaml
new file mode 100644
index 0000000..5674b9b
--- /dev/null
+++ b/JavaCloudWorker/target/classes/application.yaml
@@ -0,0 +1,8 @@
+# https://github.com/camunda-community-hub/spring-zeebe#configuring-camunda-platform-8-saas-connection
+# https://github.com/camunda-community-hub/spring-zeebe#additional-configuration-options
+zeebe.client:
+    cloud:
+        region: bru-2
+        clusterId: 66e8db1c-d166-4774-bed4-59b359cd7f6f
+        clientId: LGQTpQ~1Vmp9L4~zqhWWi28-RWaEg81f
+        clientSecret: TtaChX22nTZh9WFnZv6SThsG1TIFBClBvWHV.QzE~NDvDHAs0hFi5PVe~ZVAaXbD
\ No newline at end of file
diff --git a/JavaCloudWorker/target/classes/zeebe/camunda/worker/WorkerApplication.class b/JavaCloudWorker/target/classes/zeebe/camunda/worker/WorkerApplication.class
new file mode 100644
index 0000000000000000000000000000000000000000..21701f22ba72188d0594e846d4b97fecf02f9045
GIT binary patch
literal 2713
zcmb7Gi*nOO6g``l93uia5ForvfRF@=S_*|?N*e+csCksoq(Eu9wl|K5tj$O=H2sqP
zM(GSNbfzEBkLvX7N=cNl+M$_|cXjvfz2`p8RsQ<>{ht87z^a2jfyrN#YACNMJKeA)
zy;nL~Rgt%7m)W(oz;DXL*P(*}f!#0UOX&qNY<mwHFH|!T7z%W|ts;T(x;^YBe&89I
zPo=s&s|h$OGHeA#ZK6PJPKU7$)a_J<>O;-IS0SyRs{48qS_ae}c~1@MIlJeDgO9pl
z;&;@7AN!3!&4!^)EbLg|a$QGlFJ6m?XgQJ{WkU2CN`|qwESrgr);+m-!JF+S`jsE4
z7R{Ef5=iJL*97{frWXVT=5$Lr*duV@-=ZyHlmWB@-H<^UyRpy381@Scw^fqnL*U$0
zngyH5`NSZrO&264%ik~<p^HHbIXEOx?RC99gJq24h>N2bA(E>$0Ar%+!a+%3SKSZQ
z{cfkBqQ{ci5~$R5Qw9q%^3A&ymeG$R3^-ZwnZv32hjj^aHqeoNC@?nltRTjPGNy6H
z!HmF6VO6wFym?!yT<^I!i;q}>s7u3*eD3A~8OOCEPlZKq>M&71Cmz$a?6<p-i8kkl
zVsl&@hKElad@QiPH`R6ZQUxx~<5MD<t=CzaqRJVqnyLRq7oXu0dnso9ja1-p7Q%L}
z*c;Q#&^Rudi&tFKa8;lzTdj;50!NFkZV<<IsEpby*l0mc$lrS^S<$VB($FAL5fvSi
z6S6>HUp}!LP060W*vr9`OkT>;JbCWwMmjl6BP8o<?5&fTgQYl;t7=6DE&5#|)t6+K
zU?M;96>&^#XYeM(ZB)MSKcH-MbFIQ*ciY7s++{sG#K1ChrY-u(3U@>mCiFj96n$?8
zo5Ivx+`}vb^uuM%40co;%eJMFZI?W&1$MM_v)kb`Bgq9$7r5#5VhXuu<KB`VHvJY2
zRLJ4SCXnwq)IQ8kuW8ahUXK&ip;>l-O4iw7^ST=~)h*x5g0Y^_f6hcDaIKJ14Z~Pg
zQnSpKQ!3-{bsprn#fI2zL~#<ywX_Z6GJe314xY0~wi4%uFZC*o*r}M7>Q*|XP3TJk
zzve^Fv{QpA58{(`tyjBiwcg-!l5H0svr`My^BhXQcN<gMmN+vpCxc+#PgHH!5T2FL
z;Iu3gw;@$E-}6=Wd^OkeSE{0fmcaS)jjThe8<oCNzL)kCb;|R$Ts%uu+tiCP0ryTA
zs>qH%6+2*Oo$5(pQBoZE93ua%%8y2xK^$kt^^-pRD4DMhcO~-);o65`lzF;?`ys9_
z*Fm1_#0cMZ@$C|I%-?9G@(z1{$ALdE{^TtV|Bhq7QQSx4pb4Wi%8Pq3VWr@8ez-Ct
z9#=v6;LKZ`*t%vs0u_73O%-qwrzji7Bu>+)LGYZb(K}HQGw(39_!<XZ<J=ouc#UIr
zbJ<Fcy}{>OrpFitaFAh+lj?`KJ4`o6a;{GBU#Dx-`I66|;ERF$6=pGDv$2D3*ZIuF
zxPhBIbW8}hxG|V+5|aseCtaU;kFS9@_-4y{nvdg5=Y;h*mMUk#@fz;q0nKH;@6(dN
zLwwuo`;qm%(`3N--a_z@)igC7F$m7S$9y4#NxC|1AyiZCO$Z|y1X{oX!Sq=$!+jKk
m0uag~fBW$LW^+8@`%^w6l>S60(*8D~C^Jp8j1|1V!G8clhtg00

literal 0
HcmV?d00001

diff --git a/README.md b/README.md
index 27beda1..892de03 100644
--- a/README.md
+++ b/README.md
@@ -1,93 +1,7 @@
 # Camunda-excercise-group08
 
+1.  Upload ~/check_system_integrety_form.form, ~/classify_data_breach_form.form, ~/Cybersecurity-Incident.bpmn into own Camunda 8 cloud instance
 
+2.  configure ~/JavaCloudWorker/src/main/resources/application.yaml to connect to own cluster
 
-## Getting started
-
-To make it easy for you to get started with GitLab, here's a list of recommended next steps.
-
-Already a pro? Just edit this README.md and make it your own. Want to make it easy? [Use the template at the bottom](#editing-this-readme)!
-
-## Add your files
-
-- [ ] [Create](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#create-a-file) or [upload](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#upload-a-file) files
-- [ ] [Add files using the command line](https://docs.gitlab.com/ee/gitlab-basics/add-file.html#add-a-file-using-the-command-line) or push an existing Git repository with the following command:
-
-```
-cd existing_repo
-git remote add origin https://gitlab.informatik.hu-berlin.de/heiseisa/camunda-excercise-group08.git
-git branch -M main
-git push -uf origin main
-```
-
-## Integrate with your tools
-
-- [ ] [Set up project integrations](https://gitlab.informatik.hu-berlin.de/heiseisa/camunda-excercise-group08/-/settings/integrations)
-
-## Collaborate with your team
-
-- [ ] [Invite team members and collaborators](https://docs.gitlab.com/ee/user/project/members/)
-- [ ] [Create a new merge request](https://docs.gitlab.com/ee/user/project/merge_requests/creating_merge_requests.html)
-- [ ] [Automatically close issues from merge requests](https://docs.gitlab.com/ee/user/project/issues/managing_issues.html#closing-issues-automatically)
-- [ ] [Enable merge request approvals](https://docs.gitlab.com/ee/user/project/merge_requests/approvals/)
-- [ ] [Set auto-merge](https://docs.gitlab.com/ee/user/project/merge_requests/merge_when_pipeline_succeeds.html)
-
-## Test and Deploy
-
-Use the built-in continuous integration in GitLab.
-
-- [ ] [Get started with GitLab CI/CD](https://docs.gitlab.com/ee/ci/quick_start/index.html)
-- [ ] [Analyze your code for known vulnerabilities with Static Application Security Testing (SAST)](https://docs.gitlab.com/ee/user/application_security/sast/)
-- [ ] [Deploy to Kubernetes, Amazon EC2, or Amazon ECS using Auto Deploy](https://docs.gitlab.com/ee/topics/autodevops/requirements.html)
-- [ ] [Use pull-based deployments for improved Kubernetes management](https://docs.gitlab.com/ee/user/clusters/agent/)
-- [ ] [Set up protected environments](https://docs.gitlab.com/ee/ci/environments/protected_environments.html)
-
-***
-
-# Editing this README
-
-When you're ready to make this README your own, just edit this file and use the handy template below (or feel free to structure it however you want - this is just a starting point!). Thanks to [makeareadme.com](https://www.makeareadme.com/) for this template.
-
-## Suggestions for a good README
-
-Every project is different, so consider which of these sections apply to yours. The sections used in the template are suggestions for most open source projects. Also keep in mind that while a README can be too long and detailed, too long is better than too short. If you think your README is too long, consider utilizing another form of documentation rather than cutting out information.
-
-## Name
-Choose a self-explaining name for your project.
-
-## Description
-Let people know what your project can do specifically. Provide context and add a link to any reference visitors might be unfamiliar with. A list of Features or a Background subsection can also be added here. If there are alternatives to your project, this is a good place to list differentiating factors.
-
-## Badges
-On some READMEs, you may see small images that convey metadata, such as whether or not all the tests are passing for the project. You can use Shields to add some to your README. Many services also have instructions for adding a badge.
-
-## Visuals
-Depending on what you are making, it can be a good idea to include screenshots or even a video (you'll frequently see GIFs rather than actual videos). Tools like ttygif can help, but check out Asciinema for a more sophisticated method.
-
-## Installation
-Within a particular ecosystem, there may be a common way of installing things, such as using Yarn, NuGet, or Homebrew. However, consider the possibility that whoever is reading your README is a novice and would like more guidance. Listing specific steps helps remove ambiguity and gets people to using your project as quickly as possible. If it only runs in a specific context like a particular programming language version or operating system or has dependencies that have to be installed manually, also add a Requirements subsection.
-
-## Usage
-Use examples liberally, and show the expected output if you can. It's helpful to have inline the smallest example of usage that you can demonstrate, while providing links to more sophisticated examples if they are too long to reasonably include in the README.
-
-## Support
-Tell people where they can go to for help. It can be any combination of an issue tracker, a chat room, an email address, etc.
-
-## Roadmap
-If you have ideas for releases in the future, it is a good idea to list them in the README.
-
-## Contributing
-State if you are open to contributions and what your requirements are for accepting them.
-
-For people who want to make changes to your project, it's helpful to have some documentation on how to get started. Perhaps there is a script that they should run or some environment variables that they need to set. Make these steps explicit. These instructions could also be useful to your future self.
-
-You can also document commands to lint the code or run tests. These steps help to ensure high code quality and reduce the likelihood that the changes inadvertently break something. Having instructions for running tests is especially helpful if it requires external setup, such as starting a Selenium server for testing in a browser.
-
-## Authors and acknowledgment
-Show your appreciation to those who have contributed to the project.
-
-## License
-For open source projects, say how it is licensed.
-
-## Project status
-If you have run out of energy or time for your project, put a note at the top of the README saying that development has slowed down or stopped completely. Someone may choose to fork your project or volunteer to step in as a maintainer or owner, allowing your project to keep going. You can also make an explicit request for maintainers.
+3.  run ~/JavaCloudWorker/src/main/java/zeebe/camunda/worker/WorkerApplication.java
\ No newline at end of file
diff --git a/check_system_integrety_form.form b/check_system_integrety_form.form
new file mode 100644
index 0000000..37c778f
--- /dev/null
+++ b/check_system_integrety_form.form
@@ -0,0 +1 @@
+{"executionPlatform":"Camunda Cloud","executionPlatformVersion":"8.6.0","exporter":{"name":"Camunda Web Modeler","version":"0d4ab51"},"schemaVersion":17,"id":"check_system_integrety_form","components":[{"label":"System Integrety","values":[{"label":"restored","value":"restored"},{"label":"data loss","value":"data_loss"},{"label":"needs improvement","value":"needs_improvement"}],"type":"radio","layout":{"row":"Row_1qurww7","columns":null},"id":"Field_1svql9y","key":"system_interety"}],"type":"default"}
\ No newline at end of file
diff --git a/classify_data_breach_form.form b/classify_data_breach_form.form
new file mode 100644
index 0000000..e1517b8
--- /dev/null
+++ b/classify_data_breach_form.form
@@ -0,0 +1 @@
+{"executionPlatform":"Camunda Cloud","executionPlatformVersion":"8.6.0","exporter":{"name":"Camunda Web Modeler","version":"0d4ab51"},"schemaVersion":17,"id":"classify_data_breach_form","components":[{"label":"Select severity of the data breach","values":[{"label":"Low Severity","value":"low"},{"label":"High Severity","value":"high"}],"type":"select","layout":{"row":"Row_1613bgv","columns":null},"id":"Field_03bb6q3","key":"breach_class","defaultValue":"low"},{"label":"Message","type":"textarea","layout":{"row":"Row_1aqysen","columns":null},"id":"Field_07bhuv1","key":"message","description":"Will be send to stakeholders and authorities"}],"type":"default"}
\ No newline at end of file
-- 
GitLab