summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--docs/conf.py3
-rw-r--r--docs/guides/active-projects/index.rst77
-rw-r--r--docs/guides/onap-developer/apiref/index.rst1
-rw-r--r--docs/guides/onap-developer/architecture/media/ONAP-architecture.pngbin131977 -> 131064 bytes
-rw-r--r--docs/guides/onap-developer/developing/index.rst554
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/CLA_types.pngbin0 -> 25736 bytes
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/converting-to-rst.rst (renamed from docs/guides/onap-developer/how-to-use-docs/converting-formats.rst)8
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/index.rst7
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/introduction.rst (renamed from docs/guides/onap-developer/how-to-use-docs/documentation-guide.rst)104
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/setting-up-environment.rst150
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/setting-up.rst (renamed from docs/guides/onap-developer/how-to-use-docs/include-documentation.rst)76
-rw-r--r--docs/guides/onap-developer/how-to-use-docs/style-guide.rst25
-rw-r--r--docs/guides/onap-developer/index.rst1
-rw-r--r--docs/guides/onap-developer/tutorials/index.rst13
-rw-r--r--docs/guides/onap-developer/use-cases/index.rst15
-rw-r--r--docs/guides/onap-developer/use-cases/vfw.rst74
-rw-r--r--docs/guides/onap-user/design/index.rst39
-rw-r--r--docs/guides/onap-user/design/media/Design-Overview.pngbin119287 -> 242669 bytes
-rw-r--r--docs/guides/onap-user/design/media/Design-Overview.pptxbin93558 -> 96935 bytes
-rw-r--r--docs/guides/onap-user/design/pre-onboarding/index.rst2
-rw-r--r--docs/guides/onap-user/design/resource-onboarding/index.rst14
-rw-r--r--docs/guides/onap-user/design/resource-onboarding/media/sdro-entitlement-pool.pngbin29394 -> 21458 bytes
-rw-r--r--docs/guides/onap-user/design/resource-onboarding/media/sdro-license-keygroup.pngbin31652 -> 21753 bytes
-rw-r--r--docs/guides/onap-user/design/service-design/index.rst41
-rw-r--r--docs/guides/onap-user/design/service-design/media/sdc-home.pngbin78421 -> 22145 bytes
-rw-r--r--docs/guides/onap-user/design/service-design/media/sdc-service-general-import.pngbin0 -> 52728 bytes
-rw-r--r--docs/guides/onap-user/design/service-design/media/sdc-service-import.pngbin0 -> 45652 bytes
-rw-r--r--docs/guides/onap-user/design/service-design/media/sdc-service-workflow-design.pngbin29508 -> 46350 bytes
-rw-r--r--docs/guides/onap-user/design/service-distribution/index.rst12
-rw-r--r--docs/guides/onap-user/design/service-distribution/media/sdc-service-distribution-workflow.pngbin27345 -> 12882 bytes
-rw-r--r--docs/guides/onap-user/design/vfcreation/index.rst13
-rw-r--r--docs/guides/onap-user/design/vfcreation/media/sdc-home.pngbin78421 -> 22145 bytes
-rw-r--r--docs/guides/onap-user/index.rst3
-rw-r--r--docs/guides/onap-user/instantiate/instantiation/service_instance/index.rst6
-rw-r--r--docs/guides/onap-user/instantiate/instantiation/vnf_instance/index.rst4
-rw-r--r--docs/guides/onap-user/instantiate/pre_instantiation/index.rst12
-rw-r--r--docs/index.rst3
-rw-r--r--docs/release-notes.rst54
-rw-r--r--docs/release/index.rst94
-rw-r--r--docs/release/releaserepos.rst59
-rw-r--r--docs/templates/sections/release-notes.rst4
-rw-r--r--docs/use-cases/index.rst14
-rw-r--r--docs/use-cases/vfw.rst74
-rwxr-xr-xtools/checkdocs.sh723
-rwxr-xr-xtools/checkrtd.sh86
45 files changed, 1620 insertions, 745 deletions
diff --git a/docs/conf.py b/docs/conf.py
index e026b527f..0c79cc989 100644
--- a/docs/conf.py
+++ b/docs/conf.py
@@ -45,9 +45,10 @@ intersphinx_mapping['onap-vfc-nfvo-driver-vnfm-svnfm'] = ('{}/onap-vfc-nfvo-driv
intersphinx_mapping['onap-holmes-rule-management'] = ('{}/onap-holmes-rule-management/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-portal'] = ('{}/onap-portal/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-cli'] = ('{}/onap-cli/en/%s'.format(doc_url) % branch, None)
-intersphinx_mapping['onap-oom-certservice'] = ('{}/onap-oom-platform-cert-service/en/%s'.format(doc_url) % branch, None)
+intersphinx_mapping['onap-oom-platform-cert-service'] = ('{}/onap-oom-platform-cert-service/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-ccsdk-cds'] = ('{}/onap-ccsdk-cds/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-ccsdk-apps'] = ('{}/onap-ccsdk-apps/en/%s'.format(doc_url) % branch, None)
+intersphinx_mapping['onap-ccsdk-oran'] = ('{}/onap-ccsdk-oran/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-sdnc-oam'] = ('{}/onap-sdnc-oam/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-ccsdk-platform-plugins'] = ('{}/onap-ccsdk-platform-plugins/en/%s'.format(doc_url) % branch, None)
intersphinx_mapping['onap-ccsdk-dashboard'] = ('{}/onap-ccsdk-dashboard/en/%s'.format(doc_url) % branch, None)
diff --git a/docs/guides/active-projects/index.rst b/docs/guides/active-projects/index.rst
deleted file mode 100644
index 6b72b3aeb..000000000
--- a/docs/guides/active-projects/index.rst
+++ /dev/null
@@ -1,77 +0,0 @@
-.. This work is licensed under a Creative Commons Attribution 4.0
-.. International License. http://creativecommons.org/licenses/by/4.0
-.. Copyright 2020
-
-.. _active_projects:
-
-All Active Projects
-===================
-
-| :ref:`onap-oom-offline-installer <onap-oom-offline-installer:master_index>`
-| :ref:`onap-oom <onap-oom:master_index>`
-| :ref:`onap-oparent-cia <onap-oparent-cia:master_index>`
-| :ref:`onap-music-distributed-kv-store <onap-music-distributed-kv-store:master_index>`
-| :ref:`onap-dmaap-dbcapi <onap-dmaap-dbcapi:master_index>`
-| :ref:`onap-msb-swagger-sdk <onap-msb-swagger-sdk:master_index>`
-| :ref:`onap-msb-java-sdk <onap-msb-java-sdk:master_index>`
-| :ref:`onap-holmes-engine-management <onap-holmes-engine-management:master_index>`
-| :ref:`onap-multicloud-azure <onap-multicloud-azure:master_index>`
-| :ref:`onap-modeling-etsicatalog <onap-modeling-etsicatalog:master_index>`
-| :ref:`onap-modeling-toscaparsers <onap-modeling-toscaparsers:master_index>`
-| :ref:`onap-modeling-modelspec <onap-modeling-modelspec:master_index>`
-| :ref:`onap-vnfrqts-requirements <onap-vnfrqts-requirements:master_index>`
-| :ref:`onap-vnfrqts-guidelines <onap-vnfrqts-guidelines:master_index>`
-| :ref:`onap-dmaap-messagerouter-messageservice <onap-dmaap-messagerouter-messageservice:master_index>`
-| :ref:`onap-externalapi-nbi <onap-externalapi-nbi:master_index>`
-| :ref:`onap-logging-analytics <onap-logging-analytics:master_index>`
-| :ref:`onap-dmaap-buscontroller <onap-dmaap-buscontroller:master_index>`
-| :ref:`onap-dmaap-datarouter <onap-dmaap-datarouter:master_index>`
-| :ref:`onap-music <onap-music:master_index>`
-| :ref:`onap-sdc-sdc-workflow-designer <onap-sdc-sdc-workflow-designer:master_index>`
-| :ref:`onap-sdc-sdc-tosca <onap-sdc-sdc-tosca:master_index>`
-| :ref:`onap-vvp-documentation <onap-vvp-documentation:master_index>`
-| :ref:`onap-logging-analytics-pomba-pomba-audit-common <onap-logging-analytics-pomba-pomba-audit-common:master_index>`
-| :ref:`onap-msb-apigateway <onap-msb-apigateway:master_index>`
-| :ref:`onap-msb-discovery <onap-msb-discovery:master_index>`
-| :ref:`onap-vnfrqts-testcases <onap-vnfrqts-testcases:master_index>`
-| :ref:`onap-vnfrqts-usecases <onap-vnfrqts-usecases:master_index>`
-| :ref:`onap-policy-parent <onap-policy-parent:master_index>`
-| :ref:`onap-vfc-nfvo-lcm <onap-vfc-nfvo-lcm:master_index>`
-| :ref:`onap-vfc-nfvo-driver-vnfm-svnfm <onap-vfc-nfvo-driver-vnfm-svnfm:master_index>`
-| :ref:`onap-holmes-rule-management <onap-holmes-rule-management:master_index>`
-| :ref:`onap-portal <onap-portal:master_index>`
-| :ref:`onap-cli <onap-cli:master_index>`
-| :ref:`onap-aaf-certservice <onap-aaf-certservice:master_index>`
-| :ref:`onap-ccsdk-cds <onap-ccsdk-cds:master_index>`
-| :ref:`onap-ccsdk-apps <onap-ccsdk-apps:master_index>`
-| :ref:`onap-sdnc-oam <onap-sdnc-oam:master_index>`
-| :ref:`onap-ccsdk-platform-plugins <onap-ccsdk-platform-plugins:master_index>`
-| :ref:`onap-ccsdk-dashboard <onap-ccsdk-dashboard:master_index>`
-| :ref:`onap-ccsdk-features <onap-ccsdk-features:master_index>`
-| :ref:`onap-ccsdk-distribution <onap-ccsdk-distribution:master_index>`
-| :ref:`onap-so-libs <onap-so-libs:master_index>`
-| :ref:`onap-so <onap-so:master_index>`
-| :ref:`onap-integration <onap-integration:master_index>`
-| :ref:`onap-aai-aai-common <onap-aai-aai-common:master_index>`
-| :ref:`onap-aaf-sms <onap-aaf-sms:master_index>`
-| :ref:`onap-appc <onap-appc:master_index>`
-| :ref:`onap-appc-deployment <onap-appc-deployment:master_index>`
-| :ref:`onap-optf-cmso <onap-optf-cmso:master_index>`
-| :ref:`onap-optf-osdf <onap-optf-osdf:master_index>`
-| :ref:`onap-optf-has <onap-optf-has:master_index>`
-| :ref:`onap-sdc-sdc-distribution-client <onap-sdc-sdc-distribution-client:master_index>`
-| :ref:`onap-sdc-sdc-docker-base <onap-sdc-sdc-docker-base:master_index>`
-| :ref:`onap-sdc <onap-sdc:master_index>`
-| :ref:`onap-clamp <onap-clamp:master_index>`
-| :ref:`onap-aai-event-client <onap-aai-event-client:master_index>`
-| :ref:`onap-aai-sparky-be <onap-aai-sparky-be:master_index>`
-| :ref:`onap-aai-esr-gui <onap-aai-esr-gui:master_index>`
-| :ref:`onap-aai-esr-server <onap-aai-esr-server:master_index>`
-| :ref:`onap-multicloud-k8s <onap-multicloud-k8s:master_index>`
-| :ref:`onap-multicloud-framework <onap-multicloud-framework:master_index>`
-| :ref:`onap-dcaegen2 <onap-dcaegen2:master_index>`
-| :ref:`onap-vnfsdk-model <onap-vnfsdk-model:master_index>`
-| :ref:`onap-usecase-ui <onap-usecase-ui:master_index>`
-| :ref:`onap-vid <onap-vid:master_index>`
-| :ref:`onap-aaf-authz <onap-aaf-authz:master_index>`
-
diff --git a/docs/guides/onap-developer/apiref/index.rst b/docs/guides/onap-developer/apiref/index.rst
index 7cf6be7d1..9a8970eca 100644
--- a/docs/guides/onap-developer/apiref/index.rst
+++ b/docs/guides/onap-developer/apiref/index.rst
@@ -39,6 +39,7 @@ Platform Components
* :ref:`SDNC - SDN Controller<onap-sdnc-oam:offeredapis>`
* :ref:`SO - Service Orchestration<onap-so:offeredapis>`
* :ref:`VFC - Virtual Function Controller<onap-vfc-nfvo-lcm:master_index>`
+* :ref:`CDS - Controller Design Studio<onap-ccsdk-cds:offeredapis>`
Common Services
---------------
diff --git a/docs/guides/onap-developer/architecture/media/ONAP-architecture.png b/docs/guides/onap-developer/architecture/media/ONAP-architecture.png
index 5f12d955a..0e7c69548 100644
--- a/docs/guides/onap-developer/architecture/media/ONAP-architecture.png
+++ b/docs/guides/onap-developer/architecture/media/ONAP-architecture.png
Binary files differ
diff --git a/docs/guides/onap-developer/developing/index.rst b/docs/guides/onap-developer/developing/index.rst
index e4bb6b149..9500ec227 100644
--- a/docs/guides/onap-developer/developing/index.rst
+++ b/docs/guides/onap-developer/developing/index.rst
@@ -9,302 +9,406 @@
ONAP components and functionalities
===================================
-Additional developer level detail is provided for each project below.
-
-Active and Available Inventory
-------------------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-| :ref:`aai aai-common<onap-aai-aai-common:master_index>`
-| :ref:`AAI-esr-gui<onap-aai-esr-gui:master_index>`
-| :ref:`aai esr-server<onap-aai-esr-server:master_index>`
-| :ref:`aai sparky-be<onap-aai-sparky-be:master_index>`
-| :ref:`aai event-clientrst<onap-aai-event-client:master_index>`
-
-
-Application Controller
-----------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-| :ref:`appc deployment<onap-appc-deployment:master_index>`
-| :ref:`appc<onap-appc:master_index>`
-
-Application Authorization Framework
------------------------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-| :ref:`aaf authz<onap-aaf-authz:master_index>`
-| :ref:`Secret Management Service<onap-aaf-sms:master_index>`
-
-Command Line Interface
-----------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-:ref:`cli<onap-cli:master_index>`
-
-
-Control Loop Automation Management Platform
--------------------------------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-:ref:`clamp<onap-clamp:master_index>`
-
-Common Controller Software Development Kit
-------------------------------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+Here you will find the detailed documentation of projects,
+ONAP components and functionalities
-| :ref:`ccsdk distribution<onap-ccsdk-distribution:master_index>`
-| :ref:`ccsdk dashboard<onap-ccsdk-dashboard:master_index>`
-| :ref:`ccsdk platform plugins<onap-ccsdk-platform-plugins:master_index>`
-| :ref:`ccsdk apps<onap-ccsdk-apps:master_index>`
-| :ref:`ccsdk cds<onap-ccsdk-cds:master_index>`
+Project - ONAP Integration
+--------------------------
-Data Collection, Analysis, and Events
--------------------------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`Integration<onap-integration:master_index>`
+ - ONAP Integration Project Documentation
-:ref:`dcaegen2<onap-dcaegen2:master_index>`
+Project - ONAP Modeling
+-----------------------
-Data Management as a Platform Data Bus Controller
--------------------------------------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 1
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`Model<onap-modeling-modelspec:master_index>`
+ - ONAP Model Specification
+ * - :ref:`ETSI Catalog<onap-modeling-etsicatalog:master_index>`
+ - ONAP ETSI Runtime Catalog Documentation
-| :ref:`dmaap dbcapi<onap-dmaap-dbcapi:master_index>`
-| :ref:`dmaap buscontroller<onap-dmaap-buscontroller:master_index>`
-Data Management as a Platform Data Router
+AAF - Application Authorization Framework
-----------------------------------------
-.. toctree::
- :maxdepth: 1
- :titlesonly:
-
-:ref:`dmaap datarouter<onap-dmaap-datarouter:master_index>`
-
-Data Management as a Platform Message Router
---------------------------------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-:ref:`dmaap messagerouter messageservice<onap-dmaap-messagerouter-messageservice:master_index>`
-
-External API Framework
-----------------------
-
-.. toctree::
- :maxdepth: 2
- :titlesonly:
-
-:ref:`externalapi nbi<onap-externalapi-nbi:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - (in Maintenance) `AAF (Frankfurt) <https://docs.onap.org/projects/onap-aaf-authz/en/frankfurt/>`_
+ - AAF Architecture, APIs and Guides
+
+AAI - Active and Available Inventory
+------------------------------------
+
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`AAI<onap-aai-aai-common:master_index>`
+ - AAI Architecture, APIs and Guides
+ * - (in Maintenance) `ESR GUI (Latest) <https://docs.onap.org/projects/onap-aai-esr-gui/en/latest/>`_
+ - External System Registry GUI Documentation
+ * - (in Maintenance) `ESR Server (Latest) <https://docs.onap.org/projects/onap-aai-esr-server/en/latest/>`_
+ - External System Registry Server Documentation
+ * - (in Maintenance) :ref:`AAI UI<onap-aai-sparky-be:master_index>`
+ - Sparky - AAI Inventory UI Documentation
+
+APPC - Application Controller
+-----------------------------
+
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - (in Maintenance) `APPC (Frankfurt) <https://docs.onap.org/projects/onap-appc/en/frankfurt/>`_
+ - APPC Architecture, APIs and Guides
+ * - (in Maintenance) `APPC Deployment (Frankfurt) <https://docs.onap.org/projects/onap-appc-deployment/en/frankfurt/>`_
+ - APPC Deployment Documentation
+
+CCSDK - Common Controller Software Development Kit
+--------------------------------------------------
+
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`Distribution<onap-ccsdk-distribution:master_index>`
+ - TOSCA Orchestration Plugin, Directed Graph Support
+
+CDS - Controller Design Studio
+------------------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Holmes
-------
+ * - Document
+ - Description
+ * - :ref:`CDS<onap-ccsdk-cds:master_index>`
+ - Controller Design Studio Architecture and Guides (part of CCSDK)
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+CLAMP - Control Loop Automation Management Platform
+---------------------------------------------------
-| :ref:`Alarm Correlation and Analysis<onap-holmes-engine-management:master_index>`
-| :ref:`Architecture and APIs<onap-holmes-rule-management:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Integration
------------
+ * - Document
+ - Description
+ * - :ref:`CLAMP <onap-clamp:master_index>`
+ - CLAMP Architecture and Guides
-.. toctree::
- :maxdepth: 1
- :titlesonly:
+CLI - Command Line Interface
+----------------------------
-:ref:`integration<onap-integration:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Logging Analytics
------------------
+ * - Document
+ - Description
+ * - :ref:`CLI <onap-cli:master_index>`
+ - CLI Documentation
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+DCAE - Data Collection, Analysis and Events
+-------------------------------------------
-:ref:`logging-analytics<onap-logging-analytics:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Micro Services Bus
-------------------
+ * - Document
+ - Description
+ * - :ref:`DCAE<onap-dcaegen2:master_index>`
+ - DCAE Architecture and Guides
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+DMAAP - Data Management as a Platform
+-------------------------------------
-:ref:`msb apigateway<onap-msb-apigateway:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`Bus Controller<onap-dmaap-buscontroller:master_index>`
+ - Bus Controller Documentation
+ * - :ref:`Bus Controller API<onap-dmaap-dbcapi:master_index>`
+ - Bus Controller API Documentation
+ * - :ref:`Data Router<onap-dmaap-datarouter:master_index>`
+ - Data Router Documentation
+ * - :ref:`Message Router<onap-dmaap-messagerouter-messageservice:master_index>`
+ - Message Router Documentation
+
+EXTAPI - External API Framework/NBI
+-----------------------------------
-:ref:`msb swagger-sdk<onap-msb-swagger-sdk:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+ * - Document
+ - Description
+ * - :ref:`EXTAPI<onap-externalapi-nbi:master_index>`
+ - External API Framework Documentation
-Modeling
---------
+HOLMES - Holmes Alarm Correlation and Analysis
+----------------------------------------------
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-:ref:`modeling modelspec<onap-modeling-modelspec:master_index>`
+ * - Document
+ - Description
+ * - :ref:`HOLMES<onap-holmes-rule-management:master_index>`
+ - HOLMES Architecture and APIs
+ * - :ref:`Engine Management<onap-holmes-engine-management:master_index>`
+ - HOLMES Engine Management Documentation
-:ref:`modeling etsicatalog<onap-modeling-etsicatalog:master_index>`
+LOGGING - Centralized Logging
+-----------------------------
-MultiVIM Cloud
---------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - (in Maintenance) `LOGGING (Latest) <https://docs.onap.org/projects/onap-logging-analytics/en/latest/>`_
+ - ONAP Centralized Logging Documentation
-:ref:`multicloud framework<onap-multicloud-framework:master_index>`
+MSB - Microservices Bus
+-----------------------
-Music
------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`MSB<onap-msb-apigateway:master_index>`
+ - Microservices Bus Documentation
-:ref:`music<onap-music:master_index>`
+MULTICLOUD - MultiCloud Framework
+---------------------------------
-:ref:`music distributed-kv-store<onap-music-distributed-kv-store:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-ONAP Operations Manager
------------------------
+ * - Document
+ - Description
+ * - :ref:`MULTICLOUD<onap-multicloud-framework:master_index>`
+ - MultiCloud Framework Architecture and Guides
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+MUSIC - ONAP Multi-Site Integration
+-----------------------------------
-| :ref:`oom<onap-oom:master_index>`
-| :ref:`CMPv2 CertService<onap-oom-certservice:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Optimization Framework
-----------------------
+ * - Document
+ - Description
+ * - (in Maintenance) `MUSIC (Frankfurt) <https://docs.onap.org/projects/onap-music/en/frankfurt/>`_
+ - MUSIC Architecture and Guides
+ * - (in Maintenance) `MUSIC KV (Latest) <https://docs.onap.org/projects/onap-music-distributed-kv-store/en/latest/>`_
+ - MUSIC Distribute KV Store Documents
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+OOF - Optimization Framework
+----------------------------
-| :ref:`optf has<onap-optf-has:master_index>`
-| :ref:`optf osdf<onap-optf-osdf:master_index>`
-| :ref:`optf cmso<onap-optf-cmso:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`Homing and Allocation<onap-optf-has:master_index>`
+ - ONAP policy-driven placement optimizing service documentation
+ * - :ref:`Optimization Service Design Framework<onap-optf-osdf:master_index>`
+ - Optimization Service Design Framework documentation
+ * - :ref:`Change Management Schedule Optimization<onap-optf-cmso:master_index>`
+ - Change Management Schedule Optimization documentation
+
+OOM - ONAP Operations Manager
+-----------------------------
+
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`OOM<onap-oom:master_index>`
+ - ONAP Operations Manager Documentation
+ * - :ref:`OOM Certification Service<onap-oom-platform-cert-service:master_index>`
+ - ONAP CMPv2 certification support
+
+ORAN - Open-RAN Support in ONAP
+-------------------------------
+
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
+
+ * - Document
+ - Description
+ * - :ref:`ORAN<onap-ccsdk-oran:master_index>`
+ - O-RAN Support in ONAP (part of CCSDK)
+
+POLICY - Policy Framework
+-------------------------
-Policy Framework
-----------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`Policy<onap-policy-parent:master_index>`
+ - Policy Framework Documentation
-:ref:`policy parent<onap-policy-parent:master_index>`
+PORTAL - Portal Platform
+------------------------
-Portal Platform
----------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`Portal<onap-portal:master_index>`
+ - ONAP Portal Platform Documentation
-:ref:`portal<onap-portal:master_index>`
+SDC - Service Design & Creation
+-------------------------------
-Service Design & Creation
--------------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`SDC<onap-sdc:master_index>`
+ - Service Design & Creation Documentation
-:ref:`sdc<onap-sdc:master_index>`
+SDNC - Software Defined Network Controller
+------------------------------------------
-Service Orchestration
----------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+ * - Document
+ - Description
+ * - :ref:`SDNC<onap-sdnc-oam:master_index>`
+ - SDNC Architecture, APIs and Guides
-:ref:`so<onap-so:master_index>`
+SDNR - Software Defined Network Controller for Radio
+----------------------------------------------------
-:ref:`so libs<onap-so-libs:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Software Defined Network Controller
------------------------------------
+ * - Document
+ - Description
+ * - :ref:`SDN-R<onap-ccsdk-features:master_index>`
+ - SDN-R Documentation (part of CCSDK)
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+SO - Service Orchestration
+--------------------------
-:ref:`sdnc oam<onap-sdnc-oam:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Software Defined Network Controller for Radio (SDN-R)
------------------------------------------------------
+ * - Document
+ - Description
+ * - :ref:`SO<onap-so:master_index>`
+ - Service Orchestration Architecture, APIs and Guides
+ * - :ref:`SO Libraries<onap-so-libs:master_index>`
+ - ONAP SO/libs Documentation
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+UUI - Use Case User Interface
+-----------------------------
-:ref:`ccsdk features<onap-ccsdk-features:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Use Case User Interface
------------------------
+ * - Document
+ - Description
+ * - :ref:`UUI<onap-usecase-ui:master_index>`
+ - Usecase-UI Architecture, APIs and Guides
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+VFC - Virtual Function Controller
+---------------------------------
-:ref:`usecase-ui<onap-usecase-ui:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Virtual Function Controller
----------------------------
+ * - Document
+ - Description
+ * - :ref:`VF-C<onap-vfc-nfvo-lcm:master_index>`
+ - Virtual Function Controller Architecture, APIs and Guides
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+VID - Virtual Infrastructure Deployment
+---------------------------------------
-:ref:`vfc nfvo lcm<onap-vfc-nfvo-lcm:master_index>`
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-Virtual Infrastructure Deployment
----------------------------------
+ * - Document
+ - Description
+ * - :ref:`VID<onap-vid:master_index>`
+ - Virtual Infrastructure Deployment Architecture, APIs and Guides
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+VNFSDK - VNF Software Development Kit
+-------------------------------------
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-:ref:`vid<onap-vid:master_index>`
+ * - Document
+ - Description
+ * - :ref:`VnfSDK<onap-vnfsdk-model:master_index>`
+ - VNF SDK Documentation and User Guides
-VNF Software Development Kit
-----------------------------
+VVP - VNF Validation Platform
+-----------------------------
-.. toctree::
- :maxdepth: 2
- :titlesonly:
+.. list-table::
+ :widths: 20 80
+ :header-rows: 1
-:ref:`vnfsdk model<onap-vnfsdk-model:master_index>`
+ * - Document
+ - Description
+ * - :ref:`VVP<onap-vvp-documentation:master_index>`
+ - VNF Validation Platform Documentation
diff --git a/docs/guides/onap-developer/how-to-use-docs/CLA_types.png b/docs/guides/onap-developer/how-to-use-docs/CLA_types.png
new file mode 100644
index 000000000..d687135af
--- /dev/null
+++ b/docs/guides/onap-developer/how-to-use-docs/CLA_types.png
Binary files differ
diff --git a/docs/guides/onap-developer/how-to-use-docs/converting-formats.rst b/docs/guides/onap-developer/how-to-use-docs/converting-to-rst.rst
index 835a9c5a2..56449beb2 100644
--- a/docs/guides/onap-developer/how-to-use-docs/converting-formats.rst
+++ b/docs/guides/onap-developer/how-to-use-docs/converting-to-rst.rst
@@ -7,6 +7,14 @@
Converting to RST
=================
+RST format is used for documentation. Other file formats can be converted to RST
+with pandoc.
+
+.. caution::
+
+ Always check the output text after conversion. For the most common errors,
+ see section Fixing the converted document.
+
Installing pandoc
-----------------
diff --git a/docs/guides/onap-developer/how-to-use-docs/index.rst b/docs/guides/onap-developer/how-to-use-docs/index.rst
index 90c657501..787b8c17c 100644
--- a/docs/guides/onap-developer/how-to-use-docs/index.rst
+++ b/docs/guides/onap-developer/how-to-use-docs/index.rst
@@ -7,11 +7,12 @@ Creating Documentation
.. toctree::
:maxdepth: 2
- documentation-guide
+ introduction
+ setting-up-environment
+ setting-up
style-guide
- include-documentation
api-swagger-guide
- converting-formats
+ converting-to-rst
addendum
.. toctree::
diff --git a/docs/guides/onap-developer/how-to-use-docs/documentation-guide.rst b/docs/guides/onap-developer/how-to-use-docs/introduction.rst
index 70e98ad93..ceb2eb0e6 100644
--- a/docs/guides/onap-developer/how-to-use-docs/documentation-guide.rst
+++ b/docs/guides/onap-developer/how-to-use-docs/introduction.rst
@@ -17,6 +17,20 @@ Much of the content in this document is derived from similar
documentation processes used in other Linux Foundation
Projects including OPNFV and Open Daylight.
+When is documentation required?
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+All ONAP project contributions should have corresponding documentation.
+This includes all new features and changes to features that impact users.
+
+How do I create ONAP documentation?
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ONAP documentation is written in ReStructuredText_ (an easy-to-read,
+what-you-see-is-what-you-get, plain text markup syntax). The process for
+creating ONAP documentation and what documents are required are
+described in later sections of this Developer Documentation Guide.
+
+.. _ReStructuredText: http://docutils.sourceforge.net/rst.html
+
Why reStructuredText/Sphinx?
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@@ -96,22 +110,80 @@ is referenced from this structure.
::
- docs
- ├── guides
- │   ├── onap-developer
- │   │   ├── apiref
- │   │   ├── architecture
- │   │   ├── developing
- │   │   ├── how-to-use-docs
- │   │   ├── settingup
- │   │   ├── tutorials
- │   │   └── use-cases
- │   ├── onap-provider
- │   └── onap-user
- ├── release
- └── templates
-    ├── collections
-    └── sections
+docs
+├── guides
+│   ├── active-projects
+│   ├── onap-developer
+│   │   ├── apiref
+│   │   ├── architecture
+│   │   │   └── media
+│   │   ├── developing
+│   │   ├── how-to-use-docs
+│   │   ├── tutorials
+│   │   └── use-cases
+│   ├── onap-operator
+│   │   ├── cloud_site
+│   │   │   ├── aws
+│   │   │   ├── azure
+│   │   │   ├── k8s
+│   │   │   ├── openstack
+│   │   │   └── vmware
+│   │   ├── onap-portal-admin
+│   │   │   └── attachments
+│   │   └── settingup
+│   ├── onap-provider
+│   ├── onap-user
+│   │   ├── configure
+│   │   │   ├── change_config
+│   │   │   ├── pnf_connect
+│   │   │   └── vnf_connect
+│   │   ├── design
+│   │   │   ├── control-loop
+│   │   │   │   └── media
+│   │   │   ├── media
+│   │   │   ├── parameter_resolution
+│   │   │   │   └── ubuntu_example
+│   │   │   │   ├── cba-after-enrichment
+│   │   │   │   │   ├── Definitions
+│   │   │   │   │   ├── Templates
+│   │   │   │   │   └── TOSCA-Metadata
+│   │   │   │   ├── cba-before-enrichment
+│   │   │   │   │   ├── Definitions
+│   │   │   │   │   ├── Templates
+│   │   │   │   │   └── TOSCA-Metadata
+│   │   │   │   └── ubuntuCDS_heat
+│   │   │   ├── pre-onboarding
+│   │   │   │   └── media
+│   │   │   ├── resource-onboarding
+│   │   │   │   └── media
+│   │   │   ├── service-design
+│   │   │   │   └── media
+│   │   │   ├── service-distribution
+│   │   │   │   └── media
+│   │   │   └── vfcreation
+│   │   │   └── media
+│   │   ├── instantiate
+│   │   │   ├── instantiation
+│   │   │   │   ├── nbi
+│   │   │   │   ├── pnf_instance
+│   │   │   │   ├── service_instance
+│   │   │   │   ├── so1
+│   │   │   │   ├── so2
+│   │   │   │   ├── uui
+│   │   │   │   ├── vid
+│   │   │   │   ├── virtual_link_instance
+│   │   │   │   └── vnf_instance
+│   │   │   └── pre_instantiation
+│   │   └── onap-portal-user
+│   │   └── attachments
+│   └── overview
+│   └── media
+├── release
+├── templates
+│   ├── collections
+│   └── sections
+└── use-cases
+
Source Files
------------
diff --git a/docs/guides/onap-developer/how-to-use-docs/setting-up-environment.rst b/docs/guides/onap-developer/how-to-use-docs/setting-up-environment.rst
new file mode 100644
index 000000000..821ee8c68
--- /dev/null
+++ b/docs/guides/onap-developer/how-to-use-docs/setting-up-environment.rst
@@ -0,0 +1,150 @@
+.. This work is licensed under a Creative Commons Attribution 4.0
+.. International License. http://creativecommons.org/licenses/by/4.0
+.. Copyright 2020 Nokia.
+
+Setting up environment
+======================
+
+This chapter is based on the `Git Guide <https://docs.releng.linuxfoundation.org/en/latest/git.html>`_
+and the `Gerrit Guide <https://docs.releng.linuxfoundation.org/en/latest/gerrit.html>`_
+in the Linux Foundation Releng Documentation.
+
+Prerequisites
+~~~~~~~~~~~~~
+
+Before you start, you should have an LFID account (sign up
+`here <https://identity.linuxfoundation.org/>`_).
+
+Installing git
+~~~~~~~~~~~~~~
+
+1. Install Git.
+
+ For Debian based systems:
+
+ .. code-block:: bash
+
+ sudo apt-get install git -y
+
+
+ For rpm based systems:
+
+ .. code-block:: bash
+
+ sudo dnf install git -y
+
+
+ For MacOS systems, install `homebrew <http://brew.sh>`_ and install Git
+
+ .. code-block:: bash
+
+ brew install git
+
+.. note:: For more information on git, see the `Git Guide <https://docs.releng.linuxfoundation.org/en/latest/git.html>`_ in the Linux Foundation Releng Documentation.
+
+Configure Git
+~~~~~~~~~~~~~
+
+1. Set the author name or email used to sign off a commit with the following commands.
+
+.. code-block:: bash
+
+ git config --local user.name "Your Name"
+ git config --local user.email yourname@example.com
+
+.. note:: Your name and e-mail address (including capitalization) must match the one you entered when creating your LFID account.
+
+2. Optionally, change the Git commit editor to your preferred editor, for example, vim.
+
+.. code-block:: bash
+
+ git config --global core.editor "vim"
+
+Installing git-review
+~~~~~~~~~~~~~~~~~~~~~
+
+1. Install git-review.
+
+.. code-block:: bash
+
+ pip install git-review
+
+.. note:: If you don’t have pip installed already, follow the `installation documentation <https://pip.pypa.io/en/stable/installing/#installing-with-get-pip-py>`_ for pip.
+
+Setting up gerrit
+~~~~~~~~~~~~~~~~~
+
+Setting SSH keys
+----------------
+
+1. Generate SSH keys.
+
+.. code-block:: bash
+
+ ssh-keygen -t rsa
+
+Your public key is now available as .ssh/id_rsa.pub in your home folder.
+
+2. Print the generated key to the terminal and copy it.
+
+.. code-block:: bash
+
+ cat .ssh/id_rsa.pub
+
+3. On the project gerrit page, go to Settings.
+
+.. figure:: https://docs.releng.linuxfoundation.org/en/latest/_images/gerrit-settings.png
+ :alt: Settings page for your Gerrit account
+ :width: 50 %
+
+4. Click **SSH Public Keys** under **Settings**.
+
+5. Click **Add Key**.
+
+6. In the **Add SSH Public Key** text box, paste the contents of your **id\_rsa.pub** file and then click **Add**.
+
+.. figure:: https://docs.releng.linuxfoundation.org/en/latest/_images/gerrit-ssh-keys.png
+ :alt: Adding your SSH key
+ :width: 50 %
+
+Setting up CLA as an individual contributor
+-------------------------------------------
+
+1. Navigate to **Settings** — the gear icon on the upper right corner, and click **Agreements** from the menu on the left:
+
+.. figure:: https://raw.githubusercontent.com/communitybridge/docs/master/.gitbook/assets/settings-icon.png
+
+.. figure:: https://raw.githubusercontent.com/communitybridge/docs/master/.gitbook/assets/agreements.png
+
+2. Click **New Contributor Agreement**.
+
+.. figure:: https://raw.githubusercontent.com/communitybridge/docs/master/.gitbook/assets/agreement-link.png
+
+3. New Contributor Agreement types appear:
+
+.. figure:: https://raw.githubusercontent.com/communitybridge/docs/master/.gitbook/assets/new-contributor-agreement.png
+
+4. Choose the Individual CLA option.
+
+.. figure:: CLA_types.png
+
+5. Click the **Please review the agreement link** and then click the message link that appears:
+
+.. figure:: https://raw.githubusercontent.com/communitybridge/docs/master/.gitbook/assets/cla-gerrit-icla-proceed-to-sign-cla.png
+
+6. Sign in to EasyCLA if you are prompted.
+
+7. Select **Company**.
+
+.. note:: To contribute to this project, you must be authorized under a signed Contributor License Agreement. You are contributing on behalf of your work for a company.
+
+If any further prompts appear, follow the steps described at the below links:
+
+- `If a Confirmation of Association with statement appears <https://docs.linuxfoundation.org/docs/communitybridge/easycla/contributors/contribute-to-a-gerrit-project#if-a-confirmation-of-association-with-statement-appears>`_
+- `If your company has not signed CCLA <https://docs.linuxfoundation.org/docs/communitybridge/easycla/contributors/contribute-to-a-gerrit-project#if-your-company-has-not-signed-ccla>`_
+- `If you are not added to the approved list <https://docs.linuxfoundation.org/docs/communitybridge/easycla/contributors/contribute-to-a-gerrit-project#if-you-are-not-added-to-the-approved-list>`_
+- `If Company is not in the list <https://docs.linuxfoundation.org/docs/communitybridge/easycla/contributors/contribute-to-a-gerrit-project#if-company-is-not-in-the-list>`_
+
+8. Complete the form and click **SEND**.
+
+The CCLA manager signs a Corporate CLA and adds you to the approved list.
diff --git a/docs/guides/onap-developer/how-to-use-docs/include-documentation.rst b/docs/guides/onap-developer/how-to-use-docs/setting-up.rst
index 91f530983..cafa4790a 100644
--- a/docs/guides/onap-developer/how-to-use-docs/include-documentation.rst
+++ b/docs/guides/onap-developer/how-to-use-docs/setting-up.rst
@@ -295,6 +295,15 @@ release. In this context:
Creating Restructured Text
==========================
+ReStructuredText markup conventions
+-----------------------------------
+For detailed information on ReStructuredText and how to best use the format,
+see:
+
+- `ReStructured Text Primer <http://docutils.sourceforge.net/docs/user/rst/quickstart.html>`_
+- `ReStructured Text Quick Reference <http://docutils.sourceforge.net/docs/user/rst/quickref.html>`_
+
+
Templates and Examples
----------------------
Templates are available that capture the kinds of information
@@ -333,24 +342,53 @@ then add them to your repository docs folder and index.rst.
Sections
++++++++
-.. toctree::
- :maxdepth: 1
- :glob:
-
- ../../../templates/sections/*
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|Sections |Description |
++======================================================================================================================+======================================================================================================================================================================================================+
+|`Administration <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/administration.rst>`_ | This section is used to describe a software component from the perspective of on-going operation including regular processes and actions that are taken to configure and manage the component. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Architecture <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/architecture.rst>`_ | This section is used to describe a software component from a high level view of capability, common usage scenarios, and interactions with other components required in the usage scenarios. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Build <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/build.rst>`_ | This section is used to describe how a software component is built from source into something ready for use either in a run-time environment or to build other components. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Configuration <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/configuration.rst>`_ | This section is used to describe the options a software component offers for configuration. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Consumed APIs <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/consumedapis.rst>`_ | This section is used to reference APIs that a software component depends on and uses from other sources. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Delivery <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/delivery.rst>`_ | This section is used to describe a software component packaging. For a run-time component this might be executable images, containers, etc. For an SDK this might be libraries. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Design <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/design.rst>`_ | This section is used to describe the internal design structure of a software component. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Human interfaces <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/humaninterfaces.rst>`_ |This section is used to describe a software component's command line and graphical user interfaces. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Installation <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/installation.rst>`_ | This section is used to describe how a software component is acquired and installed. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Logging <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/logging.rst>`_ | This section is used to describe the informational or diagnostic messages emitted from a software component and the methods or collecting them. |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Offered APIs <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/offeredapis.rst>`_ | This section is used to describe the external interfaces offered by a software component |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`Release notes <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/release-notes.rst>`_ | The release note needs to be updated for each ONAP release |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
+|`VNF reference <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/sections/vnf-reference.rst>`_ | This section is used to describe Virtual Network Function software |
+| | |
++----------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
Collections
+++++++++++
-.. toctree::
- :maxdepth: 1
- :glob:
-
- ../../../templates/collections/*
-
-
-
In addition to these simple templates and examples
there are many open source projects (e.g. Open Daylight, Open Stack)
that are using Sphinx and Readthedocs where you may find examples
@@ -372,6 +410,14 @@ content that can be used as is or easily converted, and use of Sphinx
directives/extensions to automatically generate restructured text
from other source you already have.
++------------------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------+
+|Collections |Description |
++==============================================================================================================================+============================================================+
+|`Platform component <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/collections/platform-component.rst>`_ | This collection is used to describe a platform component. |
++------------------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------+
+|`SDK <https://gerrit.onap.org/r/gitweb?p=doc.git;a=blob;f=docs/templates/collections/sdk.rst>`_ | This collection is used to describe an SDK. |
++------------------------------------------------------------------------------------------------------------------------------+------------------------------------------------------------+
+
Links and References
--------------------
It's pretty common to want to reference another location in the
@@ -477,8 +523,8 @@ Change directory to doc & install requirements.
.. warning::
- Just follow the next step (copying conf.py from Doc project to your project)
- if that is your intention, otherwise skip it. Currently all projects should already have a conf.py file.
+ Just follow the next step (copying conf.py from Doc project to your project)
+ if that is your intention, otherwise skip it. Currently all projects should already have a conf.py file.
Through the next step, this file and potential extensions in your project get overriden.
Copy the conf.py file to your project folder where RST files have been kept:
diff --git a/docs/guides/onap-developer/how-to-use-docs/style-guide.rst b/docs/guides/onap-developer/how-to-use-docs/style-guide.rst
index 324688551..dcd1552bf 100644
--- a/docs/guides/onap-developer/how-to-use-docs/style-guide.rst
+++ b/docs/guides/onap-developer/how-to-use-docs/style-guide.rst
@@ -8,30 +8,6 @@ Style guide
This style guide is for ONAP documentation contributors, reviewers and
committers.
-Getting started
----------------
-
-When is documentation required?
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-All ONAP project contributions should have corresponding documentation.
-This includes all new features and changes to features that impact users.
-
-How do I create ONAP documentation?
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-ONAP documentation is written in ReStructuredText_ (an easy-to-read,
-what-you-see-is-what-you-get, plain text markup syntax). The process for
-creating ONAP documentation and what documents are required are
-described in later sections of this Developer Documentation Guide.
-
-.. _ReStructuredText: http://docutils.sourceforge.net/rst.html
-
-ReStructuredText markup conventions
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-For detailed information ReStructuredText and how to best use the format, see:
-
-- `ReStructured Text Primer <http://docutils.sourceforge.net/docs/user/rst/quickstart.html>`_
-- `ReStructured Text Quick Reference <http://docutils.sourceforge.net/docs/user/rst/quickref.html>`_
-
Writing guidelines
------------------
Following these writing guidelines will keep ONAP documentation
@@ -141,4 +117,3 @@ Needs Directive
* - R
- Represents a requirement that must be met by a VNF provider
- Defined only in the vnfrqts project repositories, may be referenced in any project repository source
-
diff --git a/docs/guides/onap-developer/index.rst b/docs/guides/onap-developer/index.rst
index 221f7ca0d..0d2418ba5 100644
--- a/docs/guides/onap-developer/index.rst
+++ b/docs/guides/onap-developer/index.rst
@@ -12,7 +12,6 @@ understand or contribute to the ONAP open source.
.. toctree::
:maxdepth: 1
- tutorials/index
how-to-use-docs/index
apiref/index
diff --git a/docs/guides/onap-developer/tutorials/index.rst b/docs/guides/onap-developer/tutorials/index.rst
index 1d090fabe..a181644bc 100644
--- a/docs/guides/onap-developer/tutorials/index.rst
+++ b/docs/guides/onap-developer/tutorials/index.rst
@@ -5,17 +5,6 @@ Tutorials
=========
.. note::
- Until this section is migrated to gerrit/readthedocs, use the links below.
+ This is an empty document as placeholder for future tutorials.
-.. caution::
- The tutorials may refer to earlier versions of software
- and have not been certified on the latest Casablanca Release.
-
-* `Automatically Creating a Netconf Mount in APPC from SDNC <https://wiki.onap.org/x/JYUx>`_
-
-* `Clearwater vIMS Onboarding and Instantiation <https://wiki.onap.org/x/RJp9>`_
-
-* `How to use SLI-API for SDNC Model, Directed Graph and Adapter prototyping <https://wiki.onap.org/x/0wCW>`_
-
-* `Setting up a Nexus Proxy <https://wiki.onap.org/x/_y70>`_
diff --git a/docs/guides/onap-developer/use-cases/index.rst b/docs/guides/onap-developer/use-cases/index.rst
deleted file mode 100644
index d9dc0d202..000000000
--- a/docs/guides/onap-developer/use-cases/index.rst
+++ /dev/null
@@ -1,15 +0,0 @@
-.. This work is licensed under a Creative Commons Attribution 4.0 International License.
-.. http://creativecommons.org/licenses/by/4.0
-.. Copyright 2017 AT&T Intellectual Property. All rights reserved.
-
-Use Cases
-=========
-
-Example uses case descriptions and sequence diagrams illustrating
-interactions between platform components.
-
-.. toctree::
- :maxdepth: 1
-
- vfw.rst
- volte.rst
diff --git a/docs/guides/onap-developer/use-cases/vfw.rst b/docs/guides/onap-developer/use-cases/vfw.rst
deleted file mode 100644
index 2f83102a9..000000000
--- a/docs/guides/onap-developer/use-cases/vfw.rst
+++ /dev/null
@@ -1,74 +0,0 @@
-.. This work is licensed under a Creative Commons Attribution 4.0 International License.
-.. http://creativecommons.org/licenses/by/4.0
-.. Copyright 2017 AT&T Intellectual Property. All rights reserved.
-
-vFirewall Use Case
-==================
-
-Description
------------
-
-Onboarding
-----------
-
-
-.. uml::
-
- @startuml
- title vFW/vFWCL and vDNS VNF Onboarding (R1)\nVFW/vFWCL and vDNS use the same flows but they are separate VNFs/Services
- ONAP_User -> SDC : vFW_vDNS resource onboarding (HEAT)
- note right : vFWCL (vpg & vfw,vsn)\nvFW (vpg, vfw, vsn)\nvDNS (vpg, vlb,vdns) + DNSScaling (vdns)\
- ONAP_User -> SDC : vFW_vDNS service onboarding
- ONAP_User -> SDC : vFW_vDNS distribution
- |||
- SDC -> SO : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- SDC -> AAI : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- SDC -> SDNC : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- @enduml
-
-Instantiation
--------------
-
-.. uml::
-
- @startuml
- title vFW vDNS Instantiation (R1)\nvFW and vDNS use the same flows but they are separate VNFs/Services
- participant ONAP_User
- participant Robot
- Participant SDC
- Participant VID
- Participant SO
- ONAP_User -> AAI : populate cloud inventory
- note left of AAI: manual via curl or POSTMAN
- |||
- ONAP_User -> VID : vFW_vDNS deployment
- VID -> SDC : Lookup VNF artifacts
- VID -> AAI : Lookup cloud locations, subscriber
- VID -> SO : vFW_vDNS Service \nInstantiation\n(base modules)
- SO -> AAI : inventory update
- VID -> SO : vFW_vDNS VNF Instantiation\n(base modules)
- note left of AAI : VFWCL is two VNFs in one service\nso VNF instantiate occurs twice
- SO -> AAI : inventory update
- ONAP_User -> SDNC : VNF API Preload VNF/VF data
- VID -> SO : vFW_vDNS VF Instantiation\n(base modules)
- SO -> AAI : inventory update
- SO -> SDNC : Generic VNF API\n(assign)
- SO -> Multi_VIM : vFW_vDNS Heat template, \nENV file, preload parameters
- Multi_VIM -> CloudAPI : vFW_vDNS Heat template,\nENV file, preload parameters or
- CloudAPI -> Hypervisor : vFW_vDNS Infrastructure instantiation
- Hypervisor -> vFW_vDNS : Nova/Neutron Instantiation
- Hypervisor -> CloudAPI : complete
- CloudAPI -> Multi_VIM : complete
- Multi_VIM -> SO : complete
- note right : SO may poll for completion
- SO -> SDNC: Generic VNF API\n(activated)
- note left : on failure from Openstack SO issues rollback to SDNC
- SDNC -> AAI : L3 Network resource update
- SO -> VID : complete
- note right : VID will poll for completion
- ONAP_User -> Robot : run Heat Bridge
- Robot -> CloudAPI : retrieve cloud data
- Robot -> AAI : Update with cloud data
- |||
- @enduml
-
diff --git a/docs/guides/onap-user/design/index.rst b/docs/guides/onap-user/design/index.rst
index 0d89bd0df..aa38a79c8 100644
--- a/docs/guides/onap-user/design/index.rst
+++ b/docs/guides/onap-user/design/index.rst
@@ -9,16 +9,15 @@ Design Service
The goal of the design process is to create all artifacts (models)
that are required to instantiate and manage resources, services,
-and products on the ONAP platform. The design process requires
-input from users with multiple roles.
+and products on the ONAP platform.
Design progresses logically through a series of phases. Each phase:
* is organized into steps that are completed in sequence
-* is accessed using a different role with specific responsibilities
- generates artifacts that are used in other phases of design or when
- instantiating or monitoring virtual functions.
+* generates artifacts that are used in other phases of design
+
+* is performed by multiple Design components
The following figure show the different phases and tools involved in
Onboarding, Design and Distribution process.
@@ -41,13 +40,12 @@ Onboarding, Design and Distribution process.
(b) manual creation and import of artefacts created via external
tools like the Controller Design Studio (CDS), responsible for the
Controller Blueprint Design
- The created VF will pass a testing workflow to be used
- in a Service Model
+ The created VF Model will be used in a Service Model
**Service Design**
A Service Model is created as a composition of resources
(e.g. V(N)Fs, PNFs,...), Policies, Workflows,...
- The created Service Model will ber certified and handed over to
+ The created Service Model will be certified and handed over to
the Service Distribution process
**Service Distribution**
@@ -60,8 +58,8 @@ Onboarding, Design and Distribution process.
The objective is to automate the resolution of resources for instantiation
and any config provisioning operation, such as day0, day1 or day2
configuration.
- The Controller Blueprint archive (CBA) is the overall service design,
- fully model-driven, intent based package needed to design self service
+ The Controller Blueprint archive (CBA) is a fully model-driven,
+ intent based package needed to design self service
provisioning and configuration management automation.
ONAP CDS (Controller Design Studio) is the controller that will process
the Controller Blueprint archive (CBA) at run-time.
@@ -76,7 +74,7 @@ Onboarding, Design and Distribution process.
**VNF LifeCycle Command templating**
APPC Controller Design Tool (CDT) is used for self-service onboarding of
- VNF’s. VNF owners can create templates and other artifacts for APPC
+ VNFs. VNF owners can create templates and other artifacts for APPC
Configure command (used to apply a post-instantiation configuration)
as well as other life cycle commands.
@@ -85,16 +83,13 @@ Onboarding, Design and Distribution process.
modify workflows to support Service/Resource change management scenarios
executed by the Service Orchestrator.
-**Control Loop Design**
- This phase includes the Design of a closed loop template and associate it
- to a Service. The template represents the theoretical flow of the CL.
- It generates a deployment artifact that can be ingested by the DCAE in
- order to create the needed DCAE microservices in runtime.
- The design is done in the SDC DCAE-DS (Design Studio).
- The DCAE Design Studio enables to define and configure
- the monitoring flows of DCAE.
- The configuration and deployment of a Control Loop will be done with
- Control Loop Automation Management (CLAMP) tool.
+**DCAE Onboard/Design**
+ This phase includes the Onboarding of DCAE Microservices and their
+ Policy Models, the Service Assurance Design and Distribution to Policy
+ and CLAMP for Closed Loop Automation Management.
+ The DCAE Onboard/Design component contains an own Design Catalog, which is
+ not yet integrated with the SDC Design Catalog to exchange models and
+ artefacts.
The follwing sections will focus on the different Design steps:
@@ -120,7 +115,7 @@ The follwing sections will focus on the different Design steps:
:ref:`Workflow Design<onap-sdc:workflow>`
-:ref:`Control Loop Design<onap-sdc:dcaedesigner>`
+:ref:`DCAE Onboard/Design<onap-dcaegen2:master_index>`
:ref:`Control Loop Automation Management<onap-clamp:master_index>`
diff --git a/docs/guides/onap-user/design/media/Design-Overview.png b/docs/guides/onap-user/design/media/Design-Overview.png
index 276e53fc0..3c1eea772 100644
--- a/docs/guides/onap-user/design/media/Design-Overview.png
+++ b/docs/guides/onap-user/design/media/Design-Overview.png
Binary files differ
diff --git a/docs/guides/onap-user/design/media/Design-Overview.pptx b/docs/guides/onap-user/design/media/Design-Overview.pptx
index 64416a801..ecef26131 100644
--- a/docs/guides/onap-user/design/media/Design-Overview.pptx
+++ b/docs/guides/onap-user/design/media/Design-Overview.pptx
Binary files differ
diff --git a/docs/guides/onap-user/design/pre-onboarding/index.rst b/docs/guides/onap-user/design/pre-onboarding/index.rst
index 063ba3c4e..b712958aa 100644
--- a/docs/guides/onap-user/design/pre-onboarding/index.rst
+++ b/docs/guides/onap-user/design/pre-onboarding/index.rst
@@ -114,4 +114,4 @@ No VF functionality testing is performed at this stage.
.. _generate-manifest.py: https://git.onap.org/sdc/tree/openecomp-be/tools/scripts/generate-manifest.py
-.. _example-packages: https://git.onap.org/sdc/tree/test-apis-ci/sdc-api-tests/chef-repo/cookbooks/sdc-api-tests/files/default/Files
+.. _example-packages: https://git.onap.org/sdc/tree/integration-tests/src/test/resources/Files/VNFs
diff --git a/docs/guides/onap-user/design/resource-onboarding/index.rst b/docs/guides/onap-user/design/resource-onboarding/index.rst
index 7154bb833..2c7020d7d 100644
--- a/docs/guides/onap-user/design/resource-onboarding/index.rst
+++ b/docs/guides/onap-user/design/resource-onboarding/index.rst
@@ -16,11 +16,11 @@ Resource Onboarding
|image0|
**Steps**
- * `Create a License Model`_
- * `Create a License Key Group [Optional]`_
- * `Create an Entitlement Pool`_
- * `Create a Feature Group`_
- * `Create a License Agreement`_
+ * `Create a License Model [Optional]`_
+ * `Create a License Key Group [Optional]`_
+ * `Create an Entitlement Pool`_
+ * `Create a Feature Group`_
+ * `Create a License Agreement`_
* `Create a Vendor Software Product`_
* `Update VFCs in a VSP [optional]`_
* `Update a VSP [optional]`_
@@ -33,8 +33,8 @@ After updating the artifacts in a VSP, also update:
.. _doc_guide_user_des_res-onb_cre-lic:
-Create a License Model
-----------------------
+Create a License Model [Optional]
+---------------------------------
VSPs optionally require a license and entitlements to enable the service
provider to track the usage.
diff --git a/docs/guides/onap-user/design/resource-onboarding/media/sdro-entitlement-pool.png b/docs/guides/onap-user/design/resource-onboarding/media/sdro-entitlement-pool.png
index db56087f7..6633693d1 100644
--- a/docs/guides/onap-user/design/resource-onboarding/media/sdro-entitlement-pool.png
+++ b/docs/guides/onap-user/design/resource-onboarding/media/sdro-entitlement-pool.png
Binary files differ
diff --git a/docs/guides/onap-user/design/resource-onboarding/media/sdro-license-keygroup.png b/docs/guides/onap-user/design/resource-onboarding/media/sdro-license-keygroup.png
index ed1e7ac35..557e403b5 100644
--- a/docs/guides/onap-user/design/resource-onboarding/media/sdro-license-keygroup.png
+++ b/docs/guides/onap-user/design/resource-onboarding/media/sdro-license-keygroup.png
Binary files differ
diff --git a/docs/guides/onap-user/design/service-design/index.rst b/docs/guides/onap-user/design/service-design/index.rst
index fc290cb27..ce7fb9a3c 100644
--- a/docs/guides/onap-user/design/service-design/index.rst
+++ b/docs/guides/onap-user/design/service-design/index.rst
@@ -9,6 +9,8 @@ Service Design
**Goal:** Add models and other artifacts required to create, configure,
instantiate, and manage services. Validate and certify the services.
+Besides the manual creation of a Service Model, an existing model can
+be imported via a CSAR file
**Tool:** SDC
@@ -23,9 +25,10 @@ instantiate, and manage services. Validate and certify the services.
#. `Create Service`_
#. `Create a Management Workflow [optional]`_
#. `Create a Network Callflow [optional]`_
- #. `Add Service Inputs [optional]`_
+ #. `Manage Service Properties [optional]`_
#. `Update Service [optional]`_
#. `Certify Service`_
+ #. `Import Service CSAR [optional]`_
.. _doc_guide_user_des_ser-cre_serv:
@@ -206,10 +209,11 @@ the service model.
.. _doc_guide_user_des_ser-para_in:
-Add Service Inputs [optional]
------------------------------
+Manage Service Properties [optional]
+------------------------------------
-Select parameters as input fields during Service instantiation.
+Add new Service parameters and define as input fields
+during Service instantiation.
**Prerequisites:** `Create service`_
@@ -307,6 +311,31 @@ architecture contains uncertified resources.
#. A Message appears, that the Service is certified.
+Import Service CSAR [optional]
+------------------------------
+
+Note: This step can be used, when a Service Model already exists
+
+**Steps**
+
+#. From the SDC HOME page, hover over IMPORT and select *IMPORT SERVICE CSAR*.
+
+ |image0|
+
+#. In the File Upload Dialog, select the csar file and press *Open*.
+
+ |image10|
+
+#. In the General section, complete all fields.
+
+ |image11|
+
+#. Click Create.
+
+ A message displays when Service creation is complete.
+
+#. Continue with Service Design steps mentioned above
+
.. |image0| image:: media/sdc-home.png
.. |image1| image:: media/sdc-service-workflow.png
.. |image2| image:: media/design_asdccanvas_connect_elements.png
@@ -316,4 +345,6 @@ architecture contains uncertified resources.
.. |image6| image:: media/sdc-service-composition.png
.. |image7| image:: media/sdc-service-workflow.png
.. |image8| image:: media/sdc-service-properties.png
-.. |image9| image:: media/sdc-service-properties-input.png \ No newline at end of file
+.. |image9| image:: media/sdc-service-properties-input.png
+.. |image10| image:: media/sdc-service-import.png
+.. |image11| image:: media/sdc-service-general-import.png
diff --git a/docs/guides/onap-user/design/service-design/media/sdc-home.png b/docs/guides/onap-user/design/service-design/media/sdc-home.png
index 3b14c99e0..201383e98 100644
--- a/docs/guides/onap-user/design/service-design/media/sdc-home.png
+++ b/docs/guides/onap-user/design/service-design/media/sdc-home.png
Binary files differ
diff --git a/docs/guides/onap-user/design/service-design/media/sdc-service-general-import.png b/docs/guides/onap-user/design/service-design/media/sdc-service-general-import.png
new file mode 100644
index 000000000..f050ff596
--- /dev/null
+++ b/docs/guides/onap-user/design/service-design/media/sdc-service-general-import.png
Binary files differ
diff --git a/docs/guides/onap-user/design/service-design/media/sdc-service-import.png b/docs/guides/onap-user/design/service-design/media/sdc-service-import.png
new file mode 100644
index 000000000..bf0c8c196
--- /dev/null
+++ b/docs/guides/onap-user/design/service-design/media/sdc-service-import.png
Binary files differ
diff --git a/docs/guides/onap-user/design/service-design/media/sdc-service-workflow-design.png b/docs/guides/onap-user/design/service-design/media/sdc-service-workflow-design.png
index 03867f954..35ba6615b 100644
--- a/docs/guides/onap-user/design/service-design/media/sdc-service-workflow-design.png
+++ b/docs/guides/onap-user/design/service-design/media/sdc-service-workflow-design.png
Binary files differ
diff --git a/docs/guides/onap-user/design/service-distribution/index.rst b/docs/guides/onap-user/design/service-distribution/index.rst
index fbd0d1b29..72730d901 100644
--- a/docs/guides/onap-user/design/service-distribution/index.rst
+++ b/docs/guides/onap-user/design/service-distribution/index.rst
@@ -29,8 +29,6 @@ Steps
- `Distribute Service`_
- `Monitor Distribution`_
-- `Verify that the DCAE Blueprint is Deployed`_
-
.. _doc_guide_user_des_ser-dis-start:
@@ -79,16 +77,6 @@ Monitor Distribution
#. If deploy errors are shown, the reason has to be investigated and the
Service can be *Redistributed*
-.. _doc_guide_user_des_ser-dis-dcae:
-
-Verify that the DCAE Blueprint is Deployed
-------------------------------------------
-
-The DCAE controller requires a blueprint (or guideline) to be available
-at the site on which the first VNF is deployed. This blueprint is a
-management workflow and configuration description for a given VNF, and
-it must be available after completing the service distribution process
-and before beginning the instantiation process.
.. |image1| image:: media/sdc-service-distribution-workflow.png
.. |image2| image:: media/sdc-service-distribute.png
diff --git a/docs/guides/onap-user/design/service-distribution/media/sdc-service-distribution-workflow.png b/docs/guides/onap-user/design/service-distribution/media/sdc-service-distribution-workflow.png
index 16578cbc2..4222f8548 100644
--- a/docs/guides/onap-user/design/service-distribution/media/sdc-service-distribution-workflow.png
+++ b/docs/guides/onap-user/design/service-distribution/media/sdc-service-distribution-workflow.png
Binary files differ
diff --git a/docs/guides/onap-user/design/vfcreation/index.rst b/docs/guides/onap-user/design/vfcreation/index.rst
index 14928bbe7..0eacd40dd 100644
--- a/docs/guides/onap-user/design/vfcreation/index.rst
+++ b/docs/guides/onap-user/design/vfcreation/index.rst
@@ -35,7 +35,7 @@ Create a VF/PNF by VSP import
**Steps**
-#. From the SDC HOME page, click the *Import VSP*
+#. From the SDC HOME page, hover over *Import*, then click on *IMPORT VSP*
|image2|
@@ -94,7 +94,7 @@ Create a VF/PNF manually
**Steps**
-#. From the SDC HOME page, click the *ADD VF* or *ADD PNF*
+#. From the SDC HOME page, hover over *Add*, then click on *ADD VF* or *ADD PNF*.
|image2|
@@ -160,7 +160,7 @@ Update a VF/PNF [optional]
**Steps**
-#. From the SDC HOME page, click *CATALOG* and search for the VF/PNF.
+#. From the SDC HOME page, click *CATALOG* and search for the VF/PNF, click on selected VF/PNF to update.
#. In the General section, click *Check Out*.
The *VSP* field is displays.
@@ -173,7 +173,8 @@ Update a VF/PNF [optional]
|image4|
#. Click *Update VSP*
- A progress bar displays.|image5|
+ A progress bar displays.
+ |image5|
#. Click *Deployment Artifact* to edit, upload, or delete associated [Optional]
deployment artifacts.
@@ -206,7 +207,9 @@ Certify VF/PNF
**Steps**
#. When a VF/PNF is ready for certification,
- click *CATALOG* and search for the checked-in VF/PNF.
+ On the SDC HOME page, click *CATALOG* and search for the checked-in VF/PNF.
+ Bottom half of the VN/PNF will say “In Design Check In”.
+
#. Click the VF/PNF and click *Certify*.
|image7|
diff --git a/docs/guides/onap-user/design/vfcreation/media/sdc-home.png b/docs/guides/onap-user/design/vfcreation/media/sdc-home.png
index 3b14c99e0..201383e98 100644
--- a/docs/guides/onap-user/design/vfcreation/media/sdc-home.png
+++ b/docs/guides/onap-user/design/vfcreation/media/sdc-home.png
Binary files differ
diff --git a/docs/guides/onap-user/index.rst b/docs/guides/onap-user/index.rst
index 79698fcf3..d8432fb0a 100644
--- a/docs/guides/onap-user/index.rst
+++ b/docs/guides/onap-user/index.rst
@@ -26,4 +26,5 @@ Verified Use Cases
In the following page you find all use cases and functional requirements
which have been officially verified in the actual release by the ONAP community.
-* :ref:`Verified Use Cases<onap-integration:docs_usecases>`
+* :ref:`Guilin Use Cases<onap-integration:docs_usecases_release>`
+* :ref:`Deprecated Use Cases<onap-integration:docs_usecases>`
diff --git a/docs/guides/onap-user/instantiate/instantiation/service_instance/index.rst b/docs/guides/onap-user/instantiate/instantiation/service_instance/index.rst
index b23a90f33..9e06c4318 100644
--- a/docs/guides/onap-user/instantiate/instantiation/service_instance/index.rst
+++ b/docs/guides/onap-user/instantiate/instantiation/service_instance/index.rst
@@ -8,9 +8,9 @@ Service Instantiation
**Pre-requisites**
-- the Service has been designed and distributed (see: Service Design)
+- The Service has been designed and distributed (see: :ref:`Service Design <doc_guide_user_des_ser-des>`)
- pre-instantiation operations have been performed
- (see: pre instantiation section)
+ (see: :ref:`pre instantiation section <doc_guide_user_pre_ser-inst>`)
**Possible Tools to perform Service Instantiation**
@@ -41,7 +41,7 @@ Service Instantiation
ONAP will collect and assign all required parameters/values by itself.
- Note: **Macro** method is not (yet) available via ONAP VID
+ .. Note:: **Macro** method is not (yet) available via ONAP VID
nor via extAPI/NBI
With "A La Carte" method
diff --git a/docs/guides/onap-user/instantiate/instantiation/vnf_instance/index.rst b/docs/guides/onap-user/instantiate/instantiation/vnf_instance/index.rst
index 822118f00..a020f9aeb 100644
--- a/docs/guides/onap-user/instantiate/instantiation/vnf_instance/index.rst
+++ b/docs/guides/onap-user/instantiate/instantiation/vnf_instance/index.rst
@@ -8,9 +8,9 @@ VNF Instantiation
**Pre-requisites**
-- the VNF is part of a Service Model (see: Service Design)
+- The VNF is part of a Service Model (see: :ref:`Service Design <doc_guide_user_des_ser-des>`)
- Note: in ONAP SDC tool, VNF is named "VF"
+ .. Note:: In ONAP SDC tool, VNF is named "VF"
**Possible methods with ONAP to instantiate a VNF**
diff --git a/docs/guides/onap-user/instantiate/pre_instantiation/index.rst b/docs/guides/onap-user/instantiate/pre_instantiation/index.rst
index 1ab726d6a..ea3f90852 100644
--- a/docs/guides/onap-user/instantiate/pre_instantiation/index.rst
+++ b/docs/guides/onap-user/instantiate/pre_instantiation/index.rst
@@ -46,7 +46,7 @@ to instantiate a service with SO using GR_API.
::
- curl -X PUT \
+ curl -k -X PUT \
https://aai.api.sparky.simpledemo.onap.org:30233/aai/v13/business/owning-entities/owning-entity/8874891f-5120-4b98-b452-46284513958d \
-H 'Accept: application/json' \
-H 'Authorization: Basic QUFJOkFBSQ==' \
@@ -61,7 +61,7 @@ to instantiate a service with SO using GR_API.
::
- curl -X GET \
+ curl -k -X GET \
https://aai.api.sparky.simpledemo.onap.org:30233/aai/v16/business/owning-entities \
-H 'Accept: application/json' \
-H 'Authorization: Basic QUFJOkFBSQ==' \
@@ -75,7 +75,7 @@ To declare the Owning Entity in VID:
::
- curl -X POST \
+ curl -k -X POST \
https://vid.api.simpledemo.onap.org:30200/vid/maintenance/category_parameter/owningEntity \
-H 'Accept-Encoding: gzip, deflate' \
-H 'Content-Type: application/json' \
@@ -89,7 +89,7 @@ Example for "platform" named "Test_Platform"
::
- curl -X POST \
+ curl -k -X POST \
https://vid.api.simpledemo.onap.org:30200/vid/maintenance/category_parameter/platform \
-H 'Content-Type: application/json' \
-H 'cache-control: no-cache' \
@@ -101,7 +101,7 @@ Example for "line of business" named "Test_LOB"
::
- curl -X POST \
+ curl -k -X POST \
https://vid.api.simpledemo.onap.org:30200/vid/maintenance/category_parameter/lineOfBusiness \
-H 'Content-Type: application/json' \
-H 'cache-control: no-cache' \
@@ -113,7 +113,7 @@ Example for "project" named "Test_project"
::
- curl -X POST \
+ curl -k -X POST \
https://vid.api.simpledemo.onap.org:30200/vid/maintenance/category_parameter/project \
-H 'Content-Type: application/json' \
-H 'cache-control: no-cache' \
diff --git a/docs/index.rst b/docs/index.rst
index 6ee7a5d1c..060522713 100644
--- a/docs/index.rst
+++ b/docs/index.rst
@@ -54,8 +54,6 @@ Please find some guidance here on the content of ONAP documentation:
| | and PNFs can accelerate the optimal usage of this ONAP environment. The guidelines |
| | on VNF/PNF requirements facilitates synchronized and aligned activities for all participants. |
+---------------------------------------------------------------------------------+-----------------------------------------------------------------------------------------------+
- | :ref:`Active Projects <active_projects>` | Simple listing of all Active projects |
- +---------------------------------------------------------------------------------+-----------------------------------------------------------------------------------------------+
.. toctree::
@@ -71,4 +69,3 @@ Please find some guidance here on the content of ONAP documentation:
guides/onap-user/index
guides/onap-developer/index
guides/onap-provider/index
- guides/active-projects/index
diff --git a/docs/release-notes.rst b/docs/release-notes.rst
index 84a7da754..67141c5a7 100644
--- a/docs/release-notes.rst
+++ b/docs/release-notes.rst
@@ -10,67 +10,35 @@ Release Notes
This document provides the release notes for the documentation project.
-Frankfurt Maintenance Release 6.0.1
-===================================
+Guilin Release
+==============
Release data
============
+--------------------------------------+--------------------------------------+
-| **Project** | Open Network Automation Platform |
-| | (ONAP) |
-+--------------------------------------+--------------------------------------+
-| **Release name** | Frankfurt |
+| **Project** | Documentation Project |
| | |
+--------------------------------------+--------------------------------------+
-| **Release version** | 6.0.1 |
+| **Release name** | Guilin |
| | |
+--------------------------------------+--------------------------------------+
-| **Release date** | August 17th 2020 |
+| **Release version** | 7.0.0 |
| | |
+--------------------------------------+--------------------------------------+
-New features
-------------
-
-- no updates
-
-Frankfurt Release 6.0.0
-=======================
-
-Release Data
-------------
-
-+--------------------------------------+--------------------------------------+
-| **Project** | Documentation |
-| | |
-+--------------------------------------+--------------------------------------+
-| **Release name** | Frankfurt |
-| | |
-+--------------------------------------+--------------------------------------+
-| **Release version** | Frankfurt 6.0.0 |
-| | |
-+--------------------------------------+--------------------------------------+
-| **Release date** | June 11th 2020 |
-| | |
-+--------------------------------------+--------------------------------------+
New features
------------
-- Improved end to end user guides.
-- A refined release note template to be used by all projects in ONAP. To ensure
- a common way of how to provide the release notes from a content such a look
- and feel perspective.
+- Refined and improved parts of the documentation guide.
+- Continue with improving the user and admin documentation.
+- Minor corrections after the migration.
- In addition the documentation project is continuously working with improving
processes and tools for documentation. Enabling the community to as easy as
- possible document all the aspects of the ONAP platform. During the Frankfurt
- release cycle we have started the work to clean up available content, both on
- the wiki and readthedocs (docs.onap.org) as well as moving the
- documentation away from submodules according to the LFN documentation
- strategy.
+ possible document all the aspects of the ONAP platform.
-All JIRA tickets for the Frankfurt release can be found
+All JIRA tickets for the Guilin release can be found
`ONAP Documentation Jira`_
-.. _`ONAP Documentation Jira`: https://jira.onap.org/browse/DOC-617?jql=project%20%3D%20DOC%20AND%20fixVersion%20%3D%20%22Frankfurt%20Release%22%20
+.. _`ONAP Documentation Jira`: https://jira.onap.org/browse/DOC-674?jql=project%20%3D%20DOC%20AND%20fixVersion%20%3D%20%22Guilin%20Release%22
diff --git a/docs/release/index.rst b/docs/release/index.rst
index 8c2035b80..0a342d39c 100644
--- a/docs/release/index.rst
+++ b/docs/release/index.rst
@@ -4,10 +4,10 @@
.. _release-notes:
-Frankfurt Release Notes
-^^^^^^^^^^^^^^^^^^^^^^^
+Guilin Release Notes
+^^^^^^^^^^^^^^^^^^^^
-This page provides the release notes for the ONAP Frankfurt release. This
+This page provides the release notes for the ONAP Guilin release. This
includes details of software versions, known limitations, and outstanding
trouble reports.
@@ -19,15 +19,14 @@ release notes and links to those release notes are provided below.
Details on the specific items delivered in each release by each component is
maintained in the component specific release notes.
-Frankfurt Releases
-==================
+Guilin Releases
+===============
-The following releases are available for Frankfurt:
- - `Frankfurt Major Release 6.0.0`_
- - `Frankfurt Maintenance Release 6.0.1`_
+The following releases are available for Guilin:
+ - `Guilin Major Release 7.0.0`_
-Frankfurt Maintenance Release 6.0.1
-===================================
+Guilin Major Release 7.0.0
+==========================
Release data
============
@@ -36,53 +35,40 @@ Release data
| **Project** | Open Network Automation Platform |
| | (ONAP) |
+--------------------------------------+--------------------------------------+
-| **Release name** | Frankfurt |
+| **Release name** | Guilin |
| | |
+--------------------------------------+--------------------------------------+
-| **Release version** | 6.0.1 |
+| **Release version** | 7.0.0 |
| | |
+--------------------------------------+--------------------------------------+
-| **Release date** | August 17th 2020 |
+| **Release date** | December 3rd 2020 |
| | |
+--------------------------------------+--------------------------------------+
-Frankfurt Maintenance Release 6.0.1 delivered a number of fixes and updates
-across the following projects:
+Guilin Features
+===============
+ONAP Gulin focusses on:
-- AAF
-- OOM
-- CCSDK
-- CLAMP
-- DCAEGEN2
-- Integration
-- POLICY
-- SDC
-- SO
-- TEST
+* 5G network automation and services such as network slicing through RAN, core and transport
+* deepening O-RAN Software Community integration along with other leading SDOs
+* seamless orchestration of CNFs, VNFs and PNFs
+* and bringing several new ONAP Blueprint and docs updates.
-Details on the specific Jira tickets addressed by each project can be found in
-the component specific Release Notes. Link can be found below in section
-`Project Specific Release Notes`_.
+5G Network Slicing
+------------------
+In the industry evolution toward 5G networks, Guilin expands upon the end-to-end network slicing introduced with Frankfurt with the addition of RAN, core, and transport through Network Slice Subnet Management Function (NSSMF) which completes functionality with the Communication Service Management Function (CSMF) and Network Slice Management Function (NSMF) components. In addition to the NSSMF included in Guilin, ONAP supports an external RAN NSSMF. Next, the RAN domain also has initial support for a simple closed control loop and machine learning (ML) for intelligent slicing.
-Frankfurt Major Release 6.0.0
-=============================
+ONAP/O-RAN Alignment
+--------------------
+The release also marks greater ONAP + O-RAN Software Community harmonization by adding support for the A1 interface (O-RAN A1-AP v1.1), adding to the existing O1 support. ONAP can now manage multiple A1 targets with different versions and includes a A1 Policy Management Service that interacts with the Near Real-Time RICs policy instances and provides a transient cache for these policies.
-Release data
-============
+CNF, VNF and PNF integration
+----------------------------
+Guilin contains a large number of new features classified into design time, run time, and ONAP operations to optimize the self-serve control loop and dashboard, make it easier to reuse existing models, make xNF pre-onboarding and onboarding easier, speed up UI development, and more. For Documentation (Usability), ONAP documentation made improvements such as setting up ONAP, Platform Operations, Service Design and Deployment, and User Guides. Specific to cloud native, The Service Design & Creation (SDC) project, the unified design time tool, now supports Helm types to natively support Cloud Native Network Functions (CNF).
-+--------------------------------------+--------------------------------------+
-| **Project** | Open Network Automation Platform |
-| | (ONAP) |
-+--------------------------------------+--------------------------------------+
-| **Release name** | Frankfurt |
-| | |
-+--------------------------------------+--------------------------------------+
-| **Release version** | 6.0.0 |
-| | |
-+--------------------------------------+--------------------------------------+
-| **Release date** | June 11th 2020 |
-| | |
-+--------------------------------------+--------------------------------------+
+Enhancements in ONAP Blueprints
+-------------------------------
+Other enhancements to the ONAP Blueprints includes a new Standard Defined VNF Event Stream (VES) event for Fault Management (FM) / Performance Management (PM) Data Collection, the first use of Machine Learning in Self-Organizing Networks (SON), and greater support for 5G RAN Wireless Network Resource Model (NRM) with Service Modeling and Definition and Intent Based Network supporting intent-drive 5G slice creation.
Project Specific Release Notes
==============================
@@ -96,8 +82,8 @@ are compatible with a major release are made available.
Documentation
=============
-ONAP Frankfurt Release provides a set selection of documents,
-see `ONAP Documentation <https://docs.onap.org/en/frankfurt/index.html>`_.
+ONAP Guilin Release provides a set selection of documents,
+see `ONAP Documentation <https://docs.onap.org/en/guilin/index.html>`_.
The `developer wiki <http://wiki.onap.org>`_ remains a good source of
information on meeting plans and notes from committees, project teams and
@@ -113,6 +99,8 @@ ONAP has adopted the `CII Best Practice Badge Program <https://bestpractices.cor
- `Badging Requirements <https://github.com/coreinfrastructure/best-practices-badge>`_
- `Badging Status for all ONAP projects <https://bestpractices.coreinfrastructure.org/en/projects?q=onap>`_
+In the Guilin release, 24% projects pass the CII badge, 52% projects pass 75% of the CII silver badge tests (next badge up from the vanilla CII badge), 5% projects pass 84% of the CII silver badge tests, and 20% pass the entirety of the silver CII badge.
+
Project specific details are in the :ref:`release notes<doc-releaserepos>` for
each project.
@@ -120,12 +108,16 @@ each project.
ONAP Maturity Testing Notes
===========================
-For the Frankfurt release, ONAP continues to improve in multiple areas of
+For the Guilin release, ONAP continues to improve in multiple areas of
Scalability, Security, Stability and Performance (S3P) metrics.
-The Integration team ran the 72 hours stability testing (100% passing rate)
-and full resilience testing (99.4% passing rate) at ONAP OpenLabs. More details
-in :ref:`ONAP Maturity Testing Notes <integration-s3p>`
+In Guilin the Integration team focussed in
+
+- Automating ONAP Testing to improve the overall quality
+- Adding security and E2E tests
+- Integrated new ONAP Python SDK in E2E testing
+
+More details in :ref:`ONAP Integration Project<onap-integration:master_index>`
Known Issues and Limitations
============================
diff --git a/docs/release/releaserepos.rst b/docs/release/releaserepos.rst
index 5ff18d27e..b573b1a7a 100644
--- a/docs/release/releaserepos.rst
+++ b/docs/release/releaserepos.rst
@@ -11,32 +11,33 @@ Project Specific Release Notes
.. toctree::
:maxdepth: 1
-| :ref:`Active and Available Inventory<onap-aai-aai-common:release_notes>`
-| :ref:`Application Authorization Framework<onap-aaf-authz:release_notes>`
-| :ref:`Application Controller<onap-appc:release_notes>`
-| :ref:`Common Controller Software Development Kit<onap-ccsdk-distribution:release_notes>`
-| :ref:`Closed Loop Automation Platform<onap-clamp:release_notes>`
-| :ref:`Data Collection Analysis and Events<onap-dcaegen2:release_notes>`
-| :ref:`DMAAP Message Router (MR)<onap-dmaap-messagerouter-messageservice:release_notes>`
-| :ref:`DMAAP Dmaap Data Router (DR)<onap-dmaap-datarouter:release_notes>`
-| :ref:`DMAAP Dmaap Bus Controller (BC)<onap-dmaap-buscontroller:release_notes>`
-| :ref:`Documentation<doc_release_notes>`
-| :ref:`External API NorthBound Interface<onap-externalapi-nbi:release_notes>`
-| :ref:`Integration<onap-integration:release_notes>`
-| :ref:`Modeling etsicatalog<onap-modeling-etsicatalog:release_notes>`
-| :ref:`Micro Services Bus<onap-msb-apigateway:release_notes>`
-| :ref:`Music<onap-music:release_notes>`
-| :ref:`MultiVIM Cloud <onap-multicloud-framework:master_index>`
-| :ref:`ONAP Operations Manager<onap-oom:release_notes>`
-| :ref:`Optimization Framework<onap-optf-osdf:release_notes>`
-| :ref:`Policy Framework<onap-policy-parent:release_notes>`
-| :ref:`Portal Platform<onap-portal:release_notes>`
-| :ref:`Service Design & Creation<onap-sdc:release_notes>`
-| :ref:`Service Orchestration<onap-so:release_notes>`
-| :ref:`Software Defined Network Controller<onap-sdnc-oam:release_notes>`
-| :ref:`Use Case User Interface<onap-usecase-ui:release_notes>`
-| :ref:`Virtual Function Controller<onap-vfc-nfvo-lcm:release_notes>`
-| :ref:`Virtual Infrastructure Deployment<onap-vid:release_notes>`
-| :ref:`VNF Requirements<onap-vnfrqts-requirements:release_notes>`
-| :ref:`VNF Software Development Kit<onap-vnfsdk-model:release_notes>`
-| :ref:`VNF Validation Project<onap-vvp-documentation:release_notes>`
+| :ref:`Project: Integration<onap-integration:release_notes>`
+| :ref:`Project: Model Specification<onap-modeling-modelspec:release_notes>`
+| :ref:`Project: VNF Requirements<onap-vnfrqts-requirements:release_notes>`
+| :ref:`AAI - Active and Available Inventory<onap-aai-aai-common:release_notes>`
+| :ref:`CCSDK - Common Controller Software Development Kit<onap-ccsdk-distribution:release_notes>`
+| :ref:`CLAMP - Control Loop Automation Platform<onap-clamp:release_notes>`
+| :ref:`CLI - Command Line Interface<onap-cli:release_notes>`
+| :ref:`DCAE - Data Collection Analysis and Events<onap-dcaegen2:release_notes>`
+| :ref:`DMAAP - Message Router (MR)<onap-dmaap-messagerouter-messageservice:release_notes>`
+| :ref:`DMAAP - Data Router (DR)<onap-dmaap-datarouter:release_notes>`
+| :ref:`DMAAP - Bus Controller (BC)<onap-dmaap-buscontroller:release_notes>`
+| :ref:`DOC - Documentation<doc_release_notes>`
+| :ref:`EXTAPI - External API NorthBound Interface<onap-externalapi-nbi:release_notes>`
+| :ref:`HOLMES - Rule Management<onap-holmes-rule-management:release_notes>`
+| :ref:`MODELING - Modeling ETSI catalog<onap-modeling-etsicatalog:release_notes>`
+| :ref:`MSB - Micro Services Bus<onap-msb-apigateway:release_notes>`
+| :ref:`MULTICLOUD - MultiCloud Framework<onap-multicloud-framework:release_notes>`
+| :ref:`OOF - Optimization Framework<onap-optf-osdf:release_notes>`
+| :ref:`OOM - ONAP Operations Manager<onap-oom:release_notes>`
+| :ref:`OOM - Certification Service<onap-oom-platform-cert-service:release_notes>`
+| :ref:`POLICY- Policy Framework<onap-policy-parent:release_notes>`
+| :ref:`PORTAL - Portal Platform<onap-portal:release_notes>`
+| :ref:`SDC - Service Design & Creation<onap-sdc:release_notes>`
+| :ref:`SDNC - Software Defined Network Controller<onap-sdnc-oam:release_notes>`
+| :ref:`SO - Service Orchestration<onap-so:release_notes>`
+| :ref:`UUI - Use Case User Interface<onap-usecase-ui:release_notes>`
+| :ref:`VFC - Virtual Function Controller<onap-vfc-nfvo-lcm:release_notes>`
+| :ref:`VID - Virtual Infrastructure Deployment<onap-vid:release_notes>`
+| :ref:`VNFSDK - VNF Software Development Kit<onap-vnfsdk-model:release_notes>`
+| :ref:`VVP - VNF Validation Project<onap-vvp-documentation:release_notes>`
diff --git a/docs/templates/sections/release-notes.rst b/docs/templates/sections/release-notes.rst
index 99eb015f2..11f38fed9 100644
--- a/docs/templates/sections/release-notes.rst
+++ b/docs/templates/sections/release-notes.rst
@@ -42,9 +42,7 @@ Release Data
| **Release designation** | <release name followed by version> |
| | |
+--------------------------------------+--------------------------------------+
-| **Release date** | <DD/MM/YYYY> |
-| | |
-+--------------------------------------+--------------------------------------+
+
New features
------------
diff --git a/docs/use-cases/index.rst b/docs/use-cases/index.rst
deleted file mode 100644
index cc076b1c5..000000000
--- a/docs/use-cases/index.rst
+++ /dev/null
@@ -1,14 +0,0 @@
-.. This work is licensed under a Creative Commons Attribution 4.0 International License.
-.. http://creativecommons.org/licenses/by/4.0
-.. Copyright 2017 AT&T Intellectual Property. All rights reserved.
-
-ONAP Use Cases
-==============
-
-Example uses case descriptions and sequence diagrams illustrating
-interactions between platform components.
-
-.. toctree::
- :maxdepth: 1
-
- vfw.rst
diff --git a/docs/use-cases/vfw.rst b/docs/use-cases/vfw.rst
deleted file mode 100644
index beef17caa..000000000
--- a/docs/use-cases/vfw.rst
+++ /dev/null
@@ -1,74 +0,0 @@
-.. This work is licensed under a Creative Commons Attribution 4.0 International License.
-.. http://creativecommons.org/licenses/by/4.0
-.. Copyright 2017 AT&T Intellectual Property. All rights reserved.
-
-.. _vfirewall_usecase:
-
-vFirewall
-=========
-
-Description
------------
-
-Onboarding
-----------
-
-.. uml::
-
- @startuml
- title vFW/vFWCL and vDNS VNF Onboarding (R1)\nVFW/vFWCL and vDNS use the same flows but they are separate VNFs/Services
- ONAP_User -> SDC : vFW_vDNS resource onboarding (HEAT)
- note right : vFWCL (vpg & vfw,vsn)\nvFW (vpg, vfw, vsn)\nvDNS (vpg, vlb,vdns) + DNSScaling (vdns)\
- ONAP_User -> SDC : vFW_vDNS service onboarding
- ONAP_User -> SDC : vFW_vDNS distribution
- |||
- SDC -> SO : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- SDC -> AAI : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- SDC -> SDNC : artifact distribution\nNOTIFY,DOWNLOAD,DEPLOY_OK
- @enduml
-
-Instantiation
--------------
-
-.. uml::
-
- @startuml
- title vFW vDNS Instantiation (R1)\nvFW and vDNS use the same flows but they are separate VNFs/Services
- participant ONAP_User
- participant Robot
- Participant SDC
- Participant VID
- Participant SO
- ONAP_User -> AAI : populate cloud inventory
- note left of AAI: manual via curl or POSTMAN
- |||
- ONAP_User -> VID : vFW_vDNS deployment
- VID -> SDC : Lookup VNF artifacts
- VID -> AAI : Lookup cloud locations, subscriber
- VID -> SO : vFW_vDNS Service \nInstantiation\n(base modules)
- SO -> AAI : inventory update
- VID -> SO : vFW_vDNS VNF Instantiation\n(base modules)
- note left of AAI : VFWCL is two VNFs in one service\nso VNF instantiate occurs twice
- SO -> AAI : inventory update
- ONAP_User -> SDNC : VNF API Preload VNF/VF data
- VID -> SO : vFW_vDNS VF Instantiation\n(base modules)
- SO -> AAI : inventory update
- SO -> SDNC : Generic VNF API\n(assign)
- SO -> Multi_VIM : vFW_vDNS Heat template, \nENV file, preload parameters
- Multi_VIM -> CloudAPI : vFW_vDNS Heat template,\nENV file, preload parameters or
- CloudAPI -> Hypervisor : vFW_vDNS Infrastructure instantiation
- Hypervisor -> vFW_vDNS : Nova/Neutron Instantiation
- Hypervisor -> CloudAPI : complete
- CloudAPI -> Multi_VIM : complete
- Multi_VIM -> SO : complete
- note right : SO may poll for completion
- SO -> SDNC: Generic VNF API\n(activated)
- note left : on failure from Openstack SO issues rollback to SDNC
- SDNC -> AAI : L3 Network resource update
- SO -> VID : complete
- note right : VID will poll for completion
- ONAP_User -> Robot : run Heat Bridge
- Robot -> CloudAPI : retrieve cloud data
- Robot -> AAI : Update with cloud data
- |||
- @enduml
diff --git a/tools/checkdocs.sh b/tools/checkdocs.sh
new file mode 100755
index 000000000..1f7f10be5
--- /dev/null
+++ b/tools/checkdocs.sh
@@ -0,0 +1,723 @@
+#!/bin/bash
+#set -x # uncomment for bash script debugging
+
+### ============================================================================
+### Licensed 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
+###
+### http://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.
+### ============LICENSE_END=====================================================
+
+###
+### checkdocs.sh
+###
+### AUTHOR(S):
+### Thomas Kulik, Deutsche Telekom AG, 2020
+###
+### DESCRIPTION:
+### Retrieves a full list of ONAP repos from gerrit inluding their state.
+### Clones all active repos of the ONAP master branch plus other requested ONAP
+### branches. Then the script does some docs related analyses depending on the
+### clone results. It creates logfiles containing filtered results. In addition
+### a table.csv is created which can be used to import it in a spreadsheed.
+### Also a zip-file is created which contains all the results.
+###
+### IMPORTANT:
+### - in the output, repo names are shown in square brackets for readability
+### e.g [aai/aai-common]/docs/release-notes.rst
+### - in the table.csv file you see data for the requested branch if available.
+### if not available, data is retrieved from the master branch. it will be
+### denoted in round brackets, e.g. (3) (tox.ini)
+###
+### REQUIREMENTS:
+### curl
+### jq
+###
+
+###
+### SOME HELPING COMMANDS TO PROCESS LOG FILES:
+### create repo list
+### curl -s https://git.onap.org/ | grep "^<tr><td class='toplevel-repo'><a title='" | sed -r "s:^<tr><td class='toplevel-repo'><a title='::" | sed -r "s:'.*::"
+###
+### remove branchname from the line
+### cat frankfurt_gerritclone.log | sed 's:frankfurt|::'
+###
+### list only image names
+### cat master_dockerimagesfull.log | grep image | sed -r 's:image\:::' | sed -r 's:^ +::' | sed '/^[[:space:]]*$/d'
+###
+### more interesting stuff ...
+### curl https://gerrit.onap.org/r/projects/?d
+### LONG: curl -s 'https://gerrit.onap.org/r/projects/?d' | awk '{if(NR>1)print}' | jq -c '.[] | {id, state}' | sed -r 's:%2F:/:g' | sed -r 's:["{}]::g' | sed -r 's:id\:::' | sed -r 's:,state\::|:' | sed '/All-Projects/d' | sed '/All-Users/d'
+### SHORT: curl -s 'https://gerrit.onap.org/r/projects/?d' | awk '{if(NR>1)print}' | jq -c '.[] | {id, state}' | sed -r 's:%2F:/:g; s:["{}]::g; s:id\:::; s:,state\::|:; /All-Projects/d; /All-Users/d'
+###
+
+script_version="1.2 (2020-11-18)"
+
+# save command for the restart with logging enabled
+command=$0
+arguments=$@
+fullcommand="${command} ${arguments}"
+
+###
+### functions
+###
+
+# print usage
+function usage() {
+ echo " "
+ echo " checkdocs.sh Version ${script_version}"
+ echo " "
+ echo " USAGE: "
+ echo " ./checkdocs.sh <arguments> "
+ echo " "
+ echo " ARGUMENTS: "
+ echo " -u|--user username "
+ echo " linux foundation username used to clone ONAP Gerrit repos"
+ echo " "
+ echo " -b|--branches branch1,branch2,branch3 "
+ echo " list of branches to be cloned. master is automatically "
+ echo " added to the list. do not add manually! "
+ echo " "
+ echo " -d|--dev "
+ echo " development-mode - limits number of repos to be cloned "
+ echo " "
+}
+
+# draw a simple line
+function drawline {
+ echo "*******************************************************************************"
+}
+
+# remove lockfile in case script is interrupted
+trap InterruptedScript SIGINT SIGTERM SIGHUP SIGKILL SIGSTOP
+function InterruptedScript {
+ echo " "
+ echo "Script was interrupted."
+ if [ -f $lockfile ] ; then
+ rm $lockfile
+ fi
+ exit 0
+}
+
+###
+### arguments handling
+###
+
+PARAMS=""
+
+while (( "$#" )); do
+ case "$1" in
+ -d|--dev)
+ devmode="TRUE"
+ shift
+ ;;
+ -b|--branches)
+ if [ -n "$2" ] && [ ${2:0:1} != "-" ]; then
+ branches_csv=$2
+ shift 2
+ else
+ echo "Error: Argument for $1 is missing" >&2
+ usage
+ exit 1
+ fi
+ ;;
+ -u|--user)
+ if [ -n "$2" ] && [ ${2:0:1} != "-" ]; then
+ lfusername=$2
+ shift 2
+ else
+ echo "Error: Argument for $1 is missing" >&2
+ usage
+ exit 1
+ fi
+ ;;
+ -*|--*=) # unsupported flags
+ echo "Error: Unsupported argument $1" >&2
+ usage
+ exit 1
+ ;;
+ *) # preserve positional arguments
+ PARAMS="$PARAMS $1"
+ shift
+ ;;
+ esac
+done
+
+# set positional arguments in their proper place
+eval set -- "$PARAMS"
+
+# old: declare -a branches=("master" "frankfurt" "guilin")
+if [[ $branches_csv == "" || $lfusername == "" ]]; then
+ usage
+ exit -1
+fi
+
+# master branch is automatically added and must not part of the user arguments
+if [[ $branches_csv == *"master"* ]]; then
+ usage
+ exit -1
+fi
+# clone master first, the the other branches
+branches_csv="master,${branches_csv}"
+
+# create the branches array by readinging in the values from the variable
+IFS=',' read -r -a branches <<< "${branches_csv}"
+
+#echo "DBUG: devmode = \"${devmode}\""
+#echo "DBUG: branches_csv = \"${branches_csv}\""
+#echo "DBUG: lfusername = \"${lfusername}\""
+#echo "DBUG: branches = \"${branches[@]}\""
+
+# restart script with logging enabled
+lockfile="checkdocs-runtime-lockfile"
+if [ ! -f $lockfile ] ; then
+ touch $lockfile
+ echo "Restarting script with logging enabled."
+ ${fullcommand} 2>&1 | tee checkdocs.log
+ rm $lockfile
+ exit
+fi
+
+echo " "
+echo "checkdocs.sh Version ${script_version}"
+echo " "
+
+# curl must be installed
+if ! command -v curl &> /dev/null
+then
+ echo "ERROR: curl command could not be found"
+ exit -1
+fi
+
+today=$(date '+%Y-%m-%d');
+repolist="gerrit-repos-master-"$today".txt";
+unique=$(date +%s)
+
+echo "Retrieving a full list of ONAP repositories (master) from gerrit.onap.org."
+
+# retrieve the full repolist from gerrit
+# workaround because of the (wrong?) response of gerrit.onap.org which makes jq command fail
+# "| awk '{if(NR>1)print}'" filters the first line of the response so that jq will work again (thx marek)
+curl -s 'https://gerrit.onap.org/r/projects/?d' | awk '{if(NR>1)print}' | jq -c '.[] | {id, state}' | sed -r 's:%2F:/:g; s:["{}]::g; s:id\:::; s:,state\::|:; /All-Projects/d; /All-Users/d' >./$repolist
+
+# process the created repolist
+# only active projects will be cloned in case the requested branch of the project exists
+echo "Accessing gerrit.onap.org with username \"${lfusername}\"."
+echo "Start cloning of repositories."
+
+for branch in "${branches[@]}"
+do
+
+ echo " "
+ echo "###"
+ echo "### ${branch}"
+ echo "###"
+ echo " "
+
+ branch_upper=$(echo "${branch}" | tr '[:lower:]' '[:upper:]')
+
+ mkdir $branch
+ cp $repolist $branch
+ cd $branch
+
+ devcounter=0
+
+ # process repolist
+ while read line
+ do
+
+ if [[ $devmode == "TRUE" ]]; then
+ devcounter=$((devcounter+1))
+ fi
+
+ if [[ $devcounter -lt "11" ]]; then
+
+ if [[ $devmode == "TRUE" ]]; then
+ echo "INFO: devmode! counter=${devcounter}"
+ fi
+
+ drawline
+ reponame=$(echo $line | awk -F "|" '{print $1}');
+ repostate=$(echo $line | awk -F "|" '{print $2}');
+ echo $reponame
+ echo $repostate
+
+ if [[ $repostate == "ACTIVE" ]]; then
+ echo "Cloning \"${branch}\" branch of ACTIVE project ${reponame}..."
+
+ git clone --branch ${branch} --recurse-submodules ssh://${lfusername}@gerrit.onap.org:29418/$reponame ./$reponame
+ gitexitcode=$?
+
+ if [[ ! ${gitexitcode} == "0" ]]; then
+ errormsg=$(tail -1 ../checkdocs.log)
+ else
+ errormsg="cloned"
+ fi
+
+ # gerritclone.log format: $1=gitexitcode|$2=reponame|$3=repostate|$4=errormsg
+ echo "${gitexitcode}|${reponame}|${repostate}|${errormsg}" | tee -a ${branch}_gerritclone.log
+
+ elif [[ $repostate == "READ_ONLY" ]]; then
+ echo "-|${reponame}|${repostate}|ignored" | tee -a ${branch}_gerritclone.log
+ else
+ echo "-|${reponame}|unknown repo state \"${repostate}\"|-" | tee -a ${branch}_gerritclone.log
+ fi
+
+ # examine repo
+ if [[ ${gitexitcode} == "0" ]]; then
+
+ printf "\ndocs directories:\n"
+ find ./$reponame -type d -name docs | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_docs.log
+
+ printf "\nrst files:\n"
+ find ./$reponame -type f -name *.rst | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_rstfiles.log
+
+ printf "\nrelease notes rst:\n"
+ find ./$reponame -type f | grep 'release.*note.*.rst' | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_releasenotes.log
+
+ printf "\ntox.ini files:\n"
+ find ./$reponame -type f -name tox.ini | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_toxini.log
+
+ printf "\nconf.py files:\n"
+ find ./$reponame -type f -name conf.py | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_confpy.log
+
+ printf "\nindex.rst files:\n"
+ find ./$reponame -type f -name index.rst | sed -r 's:./::' | sed -r s:${reponame}:[${reponame}]: | tee -a ${branch}_indexrst.log
+
+ fi
+
+ # end defcounter loop
+ fi
+
+ gitexitcode=""
+
+ done <${repolist}
+
+ # examine repos
+ drawline
+ find . -type f -name values.yaml -print -exec grep "image:" {} \; | sed -r 's:^ +::' | tee ${branch}_dockerimagesfull.log
+ drawline
+ ls --format single-column -d */ | sed 's:/$::' | tee ${branch}_directories.log
+ drawline
+ cat ${branch}_dockerimagesfull.log | grep image | sed -r 's:image\:::' | sed -r 's:^ +::' | sed '/^[[:space:]]*$/d' >${branch}_dockerimages.log
+ drawline
+ ls --format single-column -d oom/kubernetes/*/ | tee ${branch}_oomkubernetes.log
+ drawline
+
+ # examine docs
+ readarray -t docs_array < ./${branch}_docs.log;
+
+ for line in "${docs_array[@]}"
+ do
+
+ echo $line | tee -a ${branch}_docsconfig.log
+
+ # remove [ and ] which are distinguish the project name in the output
+ line=$(echo $line | sed -r 's:\[:: ; s:\]::')
+
+ if [ -f ./${line}/conf.py ] ; then
+ echo " conf.py ..... found" | tee -a ${branch}_docsconfig.log
+ else
+ echo " conf.py ..... NOT FOUND" | tee -a ${branch}_docsconfig.log
+ fi
+
+ if [ -f ./${line}/index.rst ] ; then
+ echo " index.rst ... found" | tee -a ${branch}_docsconfig.log
+ else
+ echo " index.rst ... NOT FOUND" | tee -a ${branch}_docsconfig.log
+ fi
+
+ if [ -f ./${line}/tox.ini ] ; then
+ echo " tox.ini ..... found" | tee -a ${branch}_docsconfig.log
+ else
+ echo " tox.ini ..... NOT FOUND" | tee -a ${branch}_docsconfig.log
+ fi
+
+ echo " " | tee -a ${branch}_docsconfig.log
+
+ done
+ unset docs_array
+
+ drawline
+
+ ###
+ ### build a csv table that combines results
+ ###
+
+ #
+ # csv column #1: project name
+ #
+
+ readarray -t array < ./${repolist};
+ i=0
+ csv[i]="project"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ reponame=$(echo $line | awk -F "|" '{print $1}');
+ project=$(echo $reponame | sed 's:/.*$::')
+ #echo "DBUG: reponame=${reponame}"
+ #echo "DBUG: project=${project}"
+ #echo "DBUG: i=${i}"
+ csv[i]=${project}
+ ((i++))
+ done
+ unset array
+ unset i
+ unset reponame
+ unset project
+
+ #
+ # csv column #2: repo name
+ #
+
+ readarray -t array < ./${repolist};
+ i=0
+ csv[i]="${csv[i]},MASTER repo name"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ reponame=$(echo $line | awk -F "|" '{print $1}');
+ csv[i]="${csv[i]},${reponame}"
+ ((i++))
+ done
+ unset array
+ unset i
+ unset reponame
+
+ #
+ # csv column #3: repo state
+ #
+
+ readarray -t array < ./${repolist};
+ i=0
+ csv[i]="${csv[i]},MASTER repo state"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ repostate=$(echo $line | awk -F "|" '{print $2}');
+ csv[i]="${csv[i]},${repostate}"
+ ((i++))
+ done
+ unset array
+ unset i
+ unset repostate
+
+ #
+ # csv column #4: clone message
+ #
+
+ readarray -t array < ./${branch}_gerritclone.log;
+ i=0
+ csv[i]="${csv[i]},${branch_upper} clone message"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ # gerritclone.log format: $1=gitexitcode|$2=reponame|$3=repostate|$4=errormsg
+ errormsg=$(echo $line | awk -F "|" '{print $4}');
+ csv[i]="${csv[i]},${errormsg}"
+ ((i++))
+ done
+ unset array
+ unset i
+ unset errormsg
+
+ #
+ # csv column #5: RELEASE component (yes|no|maybe)
+ # to be filled with values of the planned release config file maintained by
+ # the onap release manager
+ #
+
+ # gerritclone.log format: $1=gitexitcode|$2=reponame|$3=repostate|$4=errormsg
+ readarray -t array < ./${branch}_gerritclone.log;
+ i=0
+ csv[i]="${csv[i]},${branch_upper} component"
+ ((i++))
+ for line in "${array[@]}"
+ do
+
+ # gerritclone.log format: $1=gitexitcode|$2=reponame|$3=repostate|$4=errormsg
+ gitexitcode=$(echo $line | awk -F "|" '{print $1}');
+ reponame=$(echo $line | awk -F "|" '{print $2}');
+ repostate=$(echo $line | awk -F "|" '{print $3}');
+ errormsg=$(echo $line | awk -F "|" '{print $4}');
+
+ if [[ ${repostate} == "ACTIVE" && ${gitexitcode} == "0" ]]; then
+ releasecomponent="yes"
+ elif [[ ${repostate} == "ACTIVE" && ${gitexitcode} == "128" ]]; then
+ releasecomponent="maybe"
+ elif [ ${repostate} == "READ_ONLY" ]; then
+ releasecomponent="no"
+ else
+ releasecomponent="unknown"
+ fi
+
+ csv[i]="${csv[i]},${releasecomponent}"
+ ((i++))
+ done
+ unset array
+ unset i
+ unset gitexitcode
+ unset reponame
+ unset repostate
+ unset errormsg
+ unset releasecomponent
+
+ #
+ # csv column #6: docs (at repo root directory only; no recursive search!)
+ # csv column #7: conf.py
+ # csv column #8: tox.ini
+ # csv column #9: index.rst
+ #
+ # columns are filled with values from requested branch.
+ # if data is not available values from master branch are used.
+ # to identify master branch values, data is put into brackets "(...)"
+ #
+
+ readarray -t array < ./${repolist};
+ i=0
+ csv[$i]="${csv[i]},docs,conf.py,tox.ini,index.rst"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ line=$(echo $line | sed 's:|.*$::')
+ #echo "DBUG: line=${line}"
+ #echo "DBUG: i=${i}"
+
+ # docs
+ if [ -d ./${line}/docs ] ; then
+ docs="docs"
+ elif [ -d ../master/${line}/docs ] ; then
+ docs="(docs)"
+ else
+ docs="-"
+ fi
+
+ # conf.py
+ if [ -f ./${line}/docs/conf.py ] ; then
+ docs="${docs},conf.py"
+ elif [ -f ../master/${line}/docs/conf.py ] ; then
+ docs="${docs},(conf.py)"
+ else
+ docs="${docs},-"
+ fi
+
+ # tox.ini
+ if [ -f ./${line}/docs/tox.ini ] ; then
+ docs="${docs},tox.ini"
+ elif [ -f ../master/${line}/docs/tox.ini ] ; then
+ docs="${docs},(tox.ini)"
+ else
+ docs="${docs},-"
+ fi
+
+ # index.rst
+ if [ -f ./${line}/docs/index.rst ] ; then
+ docs="${docs},index.rst"
+ elif [ -f ../master/${line}/docs/index.rst ] ; then
+ docs="${docs},(index.rst)"
+ else
+ docs="${docs},-"
+ fi
+
+ #echo "DBUG: docs=${docs}"
+ line="${csv[i]},${docs}"
+ csv[$i]=${line}
+ ((i++))
+ done
+ unset array
+ unset i
+ unset docs
+
+ #
+ # csv column #10: index.html@RTD accessibility check
+ # csv column #11: index.html url
+ #
+
+ readarray -t array < ./${branch}_gerritclone.log;
+ i=0
+ csv[i]="${csv[i]},index.html@RTD,index.html url"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ # gerritclone.log format: $1=gitexitcode|$2=reponame|$3=repostate|$4=errormsg
+ gitexitcode=$(echo $line | awk -F "|" '{print $1}');
+ reponame=$(echo $line | awk -F "|" '{print $2}');
+ repostate=$(echo $line | awk -F "|" '{print $3}');
+ errormsg=$(echo $line | awk -F "|" '{print $4}');
+
+ url=""
+ curl_result=""
+
+ # this routine works only with release "frankfurt" and later because
+ # earlier releases are using submodule structure for documentation files
+ if echo "$branch" | grep -q '^[abcde]'; then
+ curl_result="unsupported release"
+ url="-"
+ else
+
+ # we are working on "frankfurt" branch or later ...
+ # only if repostate IS ACTIVE a curl test is required
+ if [[ ${repostate} == "ACTIVE" ]]; then
+
+ # OPTIONAL: USE ALSO GITEXITCODE AS A FILTER CRITERIA ???
+
+ # url base
+ # important! only doc project needs a different url base
+ if [[ ${reponame} == "doc" ]]; then
+ url_start="https://docs.onap.org"
+ else
+ url_start="https://docs.onap.org/projects/onap"
+ fi
+ url_lang="en"
+ url_branch=${branch}
+
+ # "master" branch documentation is available as "latest" in RTD
+ if [[ ${url_branch} == "master" ]]; then
+ url_branch="latest"
+ fi
+
+ # replace all / characters in repo name with - charachter
+ url_repo=$(echo ${reponame} | sed -r 's/\//-/g')
+ url_file="index.html"
+
+ # build the full url
+ if [[ ${reponame} == "doc" ]]; then
+ # build the full url for the doc project
+ url="${url_start}/${url_lang}/${url_branch}/${url_file}"
+ else
+ # build the full url for the other projects
+ url="${url_start}-${url_repo}/${url_lang}/${url_branch}/${url_file}"
+ fi
+ #echo "DBUG: url=$url"
+
+ # test accessibility of url
+ curl --head --silent --fail "${url}?${unique}" >/dev/null
+ curl_result=$?
+
+ # convert numeric results to text
+ if [ "${curl_result}" = "0" ]; then
+ curl_result="accessible"
+ elif [ "${curl_result}" = "22" ]; then
+ curl_result="does not exist"
+ else
+ curl_result="ERROR:${curl_result}"
+ fi
+
+ # url does not exist for this branch.
+ # in case the requested url is not already for "master" branch,
+ # we try to access the url of the master branch and denote the
+ # result by using round brackets (result)
+ if [[ ${curl_result} == "does not exist" && ! $branch == "master" ]]; then
+
+ # build the full (master/latest) url
+ url="${url_start}-${url_repo}/${url_lang}/latest/${url_file}"
+ #echo "DBUG: url=$url"
+
+ # test accessibility of url in "master branch" (latest)
+ curl --head --silent --fail "${url}?${unique}" >/dev/null
+ curl_result=$?
+ # denote result as a value from "master" branch (latest)
+ url="(${url})"
+
+ # convert numeric results to text
+ if [ "${curl_result}" = "0" ]; then
+ curl_result="(accessible)"
+ elif [ "${curl_result}" = "22" ]; then
+ curl_result="(does not exist)"
+ else
+ curl_result="(ERROR:${curl_result})"
+ fi
+
+ fi
+ else
+ # repostate IS NOT ACTIVE - no curl test required
+ curl_result="-"
+ url="-"
+ fi
+ fi
+
+ echo "$url ... $curl_result"
+ csv[i]="${csv[i]},${curl_result},${url}"
+ #echo "DBUG: csv line=${csv[i]}"
+
+ ((i++))
+ done
+
+ #
+ # csv column #12: release notes
+ #
+
+ readarray -t array < ../${repolist};
+ i=0
+ csv[i]="${csv[i]},release notes"
+ ((i++))
+ for line in "${array[@]}"
+ do
+ line=$(echo $line | sed 's:|.*$::')
+ #echo "DBUG: line=\"${line}\""
+ #echo "DBUG: i=${i}"
+ relnote=""
+
+ # put repo name in square brackets for increased grep hit rate
+ # escape minus and bracket characters to avoid problems with the grep command
+ #repo_grepable=$(echo ${line} | sed -r s:${line}:[${line}]: | sed -r 's/-/\\-/g' | sed -r 's/\[/\\[/g' | sed -r 's/\]/\\]/g')
+ #echo "DBUG: repo_grepable=\"${repo_grepable}\""
+
+ # check if repo dir exists in this branch
+ if [ -d ./${line} ] ; then
+ # if yes, check if repo name appears in the branch releasenotes.log
+ relnote=$(find "./${line}" -type f | grep 'release.*note.*.rst' | wc -l);
+ # repo dir DOES NOT exist in this branch - so check if repo dir exists in MASTER branch
+ elif [ -d ../master/${line} ] ; then
+ # if yes, check if repo name appears in the MASTER releasenotes.log
+ # count release notes files in MASTER branch (in repo root and its subdirectories)
+ relnote=$(find "../master/${line}" -type f | grep 'release.*note.*.rst' | wc -l);
+ # put results in round brackets to show that this is MASTER data
+ relnote=$(echo ${relnote} | sed -r s:${relnote}:\(${relnote}\):)
+ else
+ relnote="-"
+ fi
+
+ line="${csv[i]},${relnote}"
+ csv[i]=${line}
+ ((i++))
+
+ done
+ unset array
+ unset i
+ unset relnote
+ unset repo_grepable
+
+ #
+ # build the table.csv file
+ #
+
+ for i in "${csv[@]}"
+ do
+ echo "$i" | tee -a ./${branch}_table.csv
+ done
+
+ #
+ # create data package for this branch and zip it
+ #
+
+ datadir=${branch}_data
+ mkdir $datadir
+ cp $repolist $datadir
+ cp ${branch}_table.csv $datadir
+ cp ${branch}_*.log $datadir
+ zip -r ${datadir}.zip $datadir
+
+ # return from the branch directory
+ cd ..
+
+# return and work on the next requested branch ... or exit
+done
diff --git a/tools/checkrtd.sh b/tools/checkrtd.sh
new file mode 100755
index 000000000..e626dd9c1
--- /dev/null
+++ b/tools/checkrtd.sh
@@ -0,0 +1,86 @@
+#!/bin/bash
+#set -x # uncomment for bash script debugging
+
+# branch, e.g. "master" or "guilin"
+branch=$1
+# logfile produced by checkdocs that contains the list of links
+file_to_process=$2
+
+#
+# NOTE: works NOT with elalto release and below because of the submodule structure used for documentation
+#
+
+# url
+# important! only doc project needs a different url base
+url_lang="en"
+url_branch=${branch}
+unique=$(date +%s)
+
+# "master" branch documentation is available as "latest" in RTD
+if [[ ${url_branch} == "master" ]]; then
+ url_branch="latest"
+fi
+
+#readarray -t array < ./${branch}_releasenotes.log;
+readarray -t array < ${file_to_process};
+for line in "${array[@]}"
+do
+
+ reponame=$(echo ${line} | cut -d "[" -f2 | cut -d "]" -f1)
+ #reponame="[${reponame}]"
+ #echo "DBUG: reponame=${reponame}"
+
+ # example line: [dmaap/messagerouter/messageservice]/docs/release-notes/release-notes.rst
+ # example url: https://docs.onap.org/projects/onap-dmaap-messagerouter-messageservice/en/frankfurt/release-notes/release-notes.html
+
+ # extract repo name which comes in square bracktes ([...]) and convert slash (/) to minus (-)
+ # line: [dmaap/messagerouter/messageservice]/docs/release-notes/release-notes.rst
+ # output: dmaap-messagerouter-messageservice
+ url_repo=$(echo ${line} | sed -r 's/].+$//' | sed -r 's/\[//' | sed -r 's/\//-/g')
+
+ # extract rst filename and its path; replace .rst ending with .html
+ # warning: path does not always contain "docs"!
+ # line: [dmaap/messagerouter/messageservice]/docs/release-notes/release-notes.rst
+ # output: release-notes/release-notes.html
+ url_file=$(echo ${line} | sed -r 's/^.+\]//' | sed -r 's/^.*\/docs\///' | sed -r 's/\.rst$/\.html/' )
+
+ #echo "DBUG: line = ${line}"
+ #echo "DBUG: url_file = ${url_file}"
+ #echo "DBUG: url_repo = ${url_repo}"
+ #echo "DBUG: reponame = ${reponame}"
+
+ # build the full url
+ if [[ ${reponame} == "doc" ]]; then
+ # build the full url for the doc project
+ url_start="https://docs.onap.org"
+ url="${url_start}/${url_lang}/${url_branch}/${url_file}"
+ else
+ # build the full url for the other projects
+ url_start="https://docs.onap.org/projects/onap"
+ url="${url_start}-${url_repo}/${url_lang}/${url_branch}/${url_file}"
+ fi
+
+ #echo "DBUG: url = $url"
+
+ # check with curl if html page is accessible (no content check!)
+ # to prevent (server side) cached results a unique element is added to the request
+ curl --head --silent --fail "${url}?${unique}" >/dev/null
+ curl_result=$?
+
+ # "0" and "22" are expected as a curl result
+ if [ "${curl_result}" = "0" ]; then
+ curl_result="accessible"
+ elif [ "${curl_result}" = "22" ]; then
+ curl_result="does not exist"
+ fi
+
+ #echo -e "DBUG: ${line}"
+ #echo -e "DBUG: ${curl_result} ${url}"
+ #echo " "
+
+ echo "${line},${url},${curl_result}"
+
+ ((i++))
+done
+unset array
+unset i