dcae design doc updates

Change-Id: I7145f840d9a7de34bb6a615fe992ba22e1ff0380
Signed-off-by: VENKATESH KUMAR <vv770d@att.com>
Issue-ID: DCAEGEN2-2024
Issue-ID: DCAEGEN2-1865
Signed-off-by: VENKATESH KUMAR <vv770d@att.com>
diff --git a/docs/sections/design-components/DCAE-MOD/DCAE-MOD-User-Guide.rst b/docs/sections/design-components/DCAE-MOD/DCAE-MOD-User-Guide.rst
new file mode 100644
index 0000000..25bf095
--- /dev/null
+++ b/docs/sections/design-components/DCAE-MOD/DCAE-MOD-User-Guide.rst
@@ -0,0 +1,443 @@
+===================
+DCAE MOD User Guide
+===================
+
+
+
+-  `Types of Users and Usage
+   Instructions: <#DCAEMODUserGuide(draft)-TypesofUsersand>`__
+
+-  `1.    Deployment of DCAE MOD components via Helm
+   charts <#DCAEMODUserGuide(draft)-1.DeploymentofD>`__
+
+   -  `Using DCAE MOD without an Ingress
+      Controller <#DCAEMODUserGuide(draft)-UsingDCAEMODwit>`__
+
+-  `2.    Configuring DCAE
+   mod <#DCAEMODUserGuide(draft)-2.ConfiguringDC>`__
+
+-  `3.    Design & Distribution
+   Flow <#DCAEMODUserGuide(draft)-3.Design&Distri>`__
+
+
+Types of Users and Usage Instructions:
+======================================
+
++-------+-----------------------------+-----------------------------+
+| Sr.No | User                        | Usage Instructions          |
++=======+=============================+=============================+
+| 1.    | Developers who are looking  | -        Access the Nifi    |
+|       | to onboard their mS         | Web UI url provided to you  |
+|       |                             |                             |
+|       |                             | -        Follow steps  2.c  |
+|       |                             | to 2.f                      |
+|       |                             |                             |
+|       |                             | -        You should be able |
+|       |                             | to see your microservices   |
+|       |                             | in the Nifi Web UI by       |
+|       |                             | clicking and dragging       |
+|       |                             | ‘Processor’ on the canvas,  |
+|       |                             | and searching for the name  |
+|       |                             | of the                      |
+|       |                             | micros                      |
+|       |                             | ervice/component/processor. |
++-------+-----------------------------+-----------------------------+
+| 2.    | Designers who are building  | -        Access the Nifi    |
+|       | the flows through UI and    | Web UI url provided to you  |
+|       | triggering distribution     |                             |
+|       |                             | -        Follow steps 3 to  |
+|       |                             | the end of the document     |
++-------+-----------------------------+-----------------------------+
+| 3.    | Infrastructure/ Admins who  | -        Follow start to    |
+|       | want to stand up DCAE Mod   | the end                     |
+|       | and validate it             |                             |
++-------+-----------------------------+-----------------------------+
+
+
+1.    Deployment of DCAE MOD components via Helm charts
+=======================================================
+
+The DCAE MOD components are deployed using the standard ONAP OOM
+deployment process.   When deploying ONAP using the helm deploy command,
+DCAE MOD components are deployed when the dcaemod.enabled flag is set to
+true, either via a --set option on the command line or by an entry in an
+overrides file.  In this respect, DCAE MOD is no different from any
+other ONAP subsystem.
+
+The default DCAE MOD deployment relies on an nginx ingress controller
+being available in the Kubernetes cluster where DCAE MOD is being
+deployed.   The Rancher RKE installation process sets up a suitable
+ingress controller.   In order to enable the use of the ingress
+controller, it is necessary to override the OOM default global settings
+for ingress configuration.   Specifically, the installation needs to set
+the following configuration in an override file::
+ 
+  global:
+   ingress:
+    enabled: true
+    virtualhost:
+     enabled: false
+
+When DCAE MOD is deployed with an ingress controller, several endpoints
+are exposed outside the cluster at the ingress controller's external IP
+address and port.   (In the case of a Rancher RKE installation, there is
+an ingress controller on every worker node, listening at the the
+standard HTTP port (80).)  These exposed endpoints are needed by users
+using machines outside the Kubernetes cluster.
+
++--------------+--------------------------------------------------+--------------------------+
+| **Endpoint** | ** Routes to (cluster                            | **Description**          |
+|              | internal address)**                              |                          |
++==============+==================================================+==========================+
+| /nifi        | http://dcaemod-designtool:8080/nifi              | Design tool Web UI       |
+|              |                                                  |                          |
++--------------+--------------------------------------------------+--------------------------+
+| /nifi-api    | http://dcaemod-designtool:8080/nifi-api          | Design tool API          |
+|              |                                                  |                          |
++--------------+--------------------------------------------------+--------------------------+
+| /nifi-jars   | http://dcaemod-nifi-registry:18080/nifi-jars     | Flow registry listing of |
+|              |                                                  | JAR files built from     |
+|              |                                                  | component specs          |
++--------------+--------------------------------------------------+--------------------------+
+| /onboarding  | http://dcaemod-onboarding-api:8080/onboarding    | Onboarding API           |
+|              |                                                  |                          |
++--------------+--------------------------------------------------+--------------------------+
+| /distributor | http://dcaemod-distributor-api:8080/distributor  | Distributor API          |
+|              |                                                  |                          |
++--------------+--------------------------------------------------+--------------------------+
+
+| To access the design Web UI, for example, a user would use the URL :
+  http://*ingress_controller_address:ingress_controller_port*/nifi.
+| *ingress_controller_address* is the the IP address or DNS FQDN of the
+  ingress controller and
+| *ingress_controller_port* is the port on which the ingress controller
+  is listening for HTTP requests.  (If the port is 80, the HTTP default,
+  then there is no need to specify a port.)
+
+There are two additional *internal* endpoints that users need to know,
+in order to configure a registry client and a distribution target in the
+design tool's controller settings.
+
++------------------------+--------------------------------------------+
+| **Configuration Item** | **Endpoint URL**                           |
++========================+============================================+
+| Registry client        | http://dcaemod-nifi-registry:18080         |
++------------------------+--------------------------------------------+
+| Distribution target    | http://dcaemod-runtime-api:9090            |
++------------------------+--------------------------------------------+
+
+Using DCAE MOD without an Ingress Controller
+
+
+Not currently supported
+
+2.    Configuring DCAE mod
+==========================
+
+**a. Configure Nifi Registry url**
+
+Next check Nifi settings by selecting the Hamburger button in the Nifi
+UI. It should lead you to the Nifi Settings screen
+
+|image16|
+
+|image3|
+
+Add a registry client. The Registry client url will be
+http://dcaemod-nifi-registry:18080
+
+|image4|
+
+
+**b. Add distribution target which will be the runtime api url**
+
+Set the distribution target in the controller settings
+
+|image17|
+
+Distribution target URL will be
+`http://dcaemod-runtime-api:9090 <http://dcaemod-runtime-api:9090/>`__
+
+
+
+Now let’s access the Nifi (DCAE designer) UI - http://<IPAddress>/nifi
+
+IPAddress is the host address or the DNS FQDN, if there is one, for one of the Kubernetes nodes.
+
+|image0|
+
+
+**c. Get the artifacts to test and onboard.**
+
+Let's fetch the artifacts/ spec files 
+
+**Sample Component DCAE-VES-Collector :** https://git.onap.org/dcaegen2/collectors/ves/tree/dpo/spec/vescollector-componentspec.json
+
+**Sample Data Format :** https://git.onap.org/dcaegen2/collectors/ves/tree/dpo/data-formats/VES-5.28.4-dataformat.json
+
+For the purpose of onboarding, a Sample Request body should be of the type -::
+
+  { "owner": "<some value>", "spec": <some json object> }
+
+where the json object inside the spec field can be a component spec json.
+
+Request bodies of this type will be used in the onboarding requests you make using curl or the onboarding swagger interface.
+
+**The prepared Sample Request body for a component dcae-ves-collector looks like
+so –**
+
+See :download:`VES Collector Spec <./Sample-Input-Files/Request-body-of-Sample-Component.json>`
+
+**The prepared Sample request body for a sample data format  looks like so -**
+
+See :download:`VES data Format <./Sample-Input-Files/Request-body-of-Sample-Data-Format.json>`
+
+
+
+**d. To onboard a data format and a component**
+
+Each component has a description that tells what it does.
+
+These requests would be of the type
+
+curl -X POST http://<onboardingapi host>/onboarding/dataformats     -H "Content-Type: application/json" -d
+@<filepath to request>
+
+curl -X POST http://<onboardingapi host>/onboarding/components     -H "Content-Type: application/json" -d
+@<filepath to request>
+
+In our case,
+
+curl -X POST http://<IPAddress>/onboarding/dataformats     -H "Content-Type: application/json" -d @<filepath to request>
+
+curl -X POST http://<IPAddress>/onboarding/components    -H "Content-Type: application/json" -d @<filepath to request>
+
+
+
+
+**e. Verify the resources were created using**
+
+curl -X GET http://<IPAddress>/onboarding/dataformats
+
+curl -X GET http://<IPAddress>/onboarding/components
+
+**f. Verify the genprocessor (which polls onboarding periodically to convert component specs to nifi processor), converted the component**
+
+Open http://<IPAddress>/nifi-jars in a browser.
+
+These jars should now be available for you to use in the nifi UI as
+processors
+
+|image1|
+
+3.    Design & Distribution Flow
+================================
+
+
+**a**. To start creating flows, we need to create a process group first. The
+name of the process group will be the name of the flow. Drag and Drop on
+the canvas, the ‘Processor Group’ icon from the DCAE Designer bar on the
+top.
+
+|image2|
+
+
+Now enter the process group by double clicking it,
+
+You can now drag and drop on the canvas ‘Processor’ icon from the top
+DCAE Designer tab. You can search for a particular component in the
+search box that appears when you attempt to drag the ‘Processor’ icon to
+the canvas.
+
+|image5|
+
+If the Nifi registry linking worked, you should see the “Import” button
+when you try to add a Processor or Process group to the Nifi canvas,
+like so-
+
+|image6|
+
+By clicking on the import button, we can import already created saved
+and version controlled flows from the Nifi registry, if they are
+present.
+
+|image7|
+
+We can save created flows by version controlling them like so starting
+with a 'right click' anywhere on the canvas-
+
+|image8|
+
+Ideally you would name the flow and process group the same, because
+functionally they are similar.
+
+|image9|
+
+When the flow is checked in, the bar at the bottom shows a green
+checkmark
+
+|image10|
+
+Note: Even if you move a component around on the canvas, and its
+position on the canvas changes, it is recognized as a change, and it
+will have to recommitted.
+
+You can add additional components in your flow and connect them.
+
+DcaeVesCollector connects to DockerTcagen2.
+
+|image11|
+
+|image12|
+
+|image13|
+
+Along the way you need to also provide topic names in the settings
+section. These can be arbitrary names.
+
+|image14|
+
+To recap, see how DcaeVesCollector connects to DockerTcagen2. Look at
+the connection relationships. Currently there is no way to validate
+these relationships. Notice how it is required to name the topics by
+going to Settings.
+
+The complete flow after joining our components looks like so
+
+|image15|
+
+
+**b. Submit/ Distribute the flow:**
+
+Once your flow is complete and saved in the Nifi registry, you can
+choose to submit it for distribution.
+
+|image18|
+
+If the flow was submitted successfully to the runtime api, you should
+get a pop up a success message like so -
+
+|image19|
+
+At this step, the design was packaged and sent to Runtime api.
+
+The runtime is supposed to generate the blueprint out of the packaged
+design/flow and push it to the DCAE inventory and the DCAE Dasboard.
+
+**c. Checking the components in the DCAE Dashboard**
+
+You should see the generated artifact/ blueprint in the DCAE Dashboard
+dashboard at https://<IPAddress>:30418/ccsdk-app/login_external.htm in
+our deployment. The name for each component will be appended by the flow
+name followed by underscore followed by the component’s name.
+
+The credentials to access the DCAE Dashboard are-
+
+::
+
+Login: su1234
+
+Password: fusion
+
+
+|image20|
+
+|image21|
+
+|image22|
+
+The generated Blueprint can be viewed.
+
+|image23|
+
+Finally, the generated Blueprint can be deployed.
+
+|image24|
+
+You can use/import the attached input configurations files to deploy. Drag and Drop these sample JSON files to fill in the configuration values.
+See :download:`VES Collector Input Configuration <./Sample-Input-Files/ves-deploy.input.json>`
+See :download:`Tcagen2 Input Configuration <./Sample-Input-Files/tca-deploy.input.json>`
+
+|image25|
+
+|image26|
+
+.. |image0| image:: ../images/1.png
+   :width: 6.5in
+   :height: 1.08333in
+.. |image1| image:: ../images/2.png
+   :width: 6.5in
+   :height: 1.58333in
+.. |image2| image:: ../images/3.png
+   :width: 5.83333in
+   :height: 3.58333in
+.. |image3| image:: ../images/4.png
+   :width: 4.91667in
+   :height: 2.16667in
+.. |image4| image:: ../images/5.png
+   :width: 6.5in
+   :height: 2.66667in
+.. |image5| image:: ../images/6.png
+   :width: 6.5in
+   :height: 3.33333in
+.. |image6| image:: ../images/7.png
+   :width: 4.91667in
+   :height: 2.25in
+.. |image7| image:: ../images/8.png
+   :width: 4.91667in
+   :height: 2.58333in
+.. |image8| image:: ../images/9.png
+   :width: 6.5in
+   :height: 4.58333in
+.. |image9| image:: ../images/10.png
+   :width: 6.5in
+   :height: 4in
+.. |image10| image:: ../images/11.png
+   :width: 4.91667in
+   :height: 0.41667in
+.. |image11| image:: ../images/12.png
+   :width: 6.33333in
+   :height: 3.16667in
+.. |image12| image:: ../images/13.png
+   :width: 6in
+   :height: 2.66667in
+.. |image13| image:: ../images/14.png
+   :width: 6.5in
+   :height: 3.41667in
+.. |image14| image:: ../images/15.png
+   :width: 6.5in
+   :height: 3.58333in
+.. |image15| image:: ../images/16.png
+   :width: 6.5in
+   :height: 2.25in
+.. |image16| image:: ../images/17.png
+   :width: 6.5in
+   :height: 2.83333in
+.. |image17| image:: ../images/18.png
+   :width: 6.5in
+   :height: 3.08333in
+.. |image18| image:: ../images/19.png
+   :width: 4.91667in
+   :height: 1.91667in
+.. |image19| image:: ../images/20.png
+   :width: 4.91667in
+   :height: 2.41667in
+.. |image20| image:: ../images/21.png
+   :width: 6.5in
+   :height: 2.41667in
+.. |image21| image:: ../images/22.png
+   :width: 6.5in
+   :height: 3in
+.. |image22| image:: ../images/23.png
+   :width: 6.5in
+   :height: 2.16667in
+.. |image23| image:: ../images/24.png
+   :width: 6.5in
+   :height: 2.83333in
+.. |image24| image:: ../images/25.png
+   :width: 6.5in
+   :height: 3in
+.. |image25| image:: ../images/26.png
+.. |image26| image:: ../images/27.png
+
+