blob: e566c86e2c7b5cf352d65825b53fd84c03117af9 [file] [log] [blame]
.. This work is licensed under a
Creative Commons Attribution 4.0 International License.
.. _prh_api:
==============================
PRH (PNF Registration Handler)
==============================
:Date: 2018-09-13
.. contents::
:depth: 3
Overview
========
Physical Network Function Registration Handler is responsible for registration
of PNF (Physical Network Function) to ONAP (Open Network Automation Platform)
in plug and play manner.
.. csv-table::
:header: "API name", "Swagger JSON", "Swagger YAML"
:widths: 10,5,5
"PNF Registration Handler", ":download:`link <PRH.json>`", ":download:`link <PRH.yaml>`"
.. swaggerv2doc:: PRH.json
Introduction
============
PRH is delivered as one **Docker container** which hosts application server and
can be started by `docker-compose`.
Functionality
=============
.. image:: ../images/prhAlgo.png
Paths
=====
GET /events/unauthenticated.VES_PNFREG_OUTPUT
---------------------------------------------
Description
~~~~~~~~~~~
Reads PNF registration fromD DMaaP (Data Movement as a Platform)
Responses
~~~~~~~~~
+-----------+-------------------------------------------+
| HTTP Code | Description |
+===========+===========================================+
| **200** | successful response |
+-----------+-------------------------------------------+
PATCH /aai/v12/network/pnfs/{pnf-name}
--------------------------------------
Description
~~~~~~~~~~~
Update AAI (Active and Available Inventory) PNF's specific entries:
- ipv4 to ipaddress-v4-oam
- ipv6 to ipaddress-v6-oam
Parameters
~~~~~~~~~~
+----------+---------------+---------------------------------+------------------+
| Type | Name | Description | Schema |
+==========+===============+=================================+==================+
| **Path** | | **pnf-name**| Name of the PNF. | string (text) |
| | | *required* | | |
+----------+---------------+---------------------------------+------------------+
| **Body** | **patchbody** | Required patch body. | |
+----------+---------------+---------------------------------+------------------+
Responses
~~~~~~~~~
+-----------+-------------------------------------------+
| HTTP Code | Description |
+===========+===========================================+
| **200** | successful response |
+-----------+-------------------------------------------+
POST /events/unauthenticated.PNF_READY
--------------------------------------
Description
~~~~~~~~~~~
Publish PNF_READY to DMaaP and set:
- pnf-id to correlationID
- ipv4 to ipaddress-v4-oam
- ipv6 to ipaddress-v6-oam
Parameters
~~~~~~~~~~
+----------+----------------+---------------------------------+------------------+
| Type | Name | Description | Schema |
+==========+================+=================================+==================+
| **Body** | | **postbody** | Required patch body. | `hydratorappput |
| | | *required* | | <#_hydratorapppu |
| | | | t>`__ |
+----------+----------------+---------------------------------+------------------+
Responses
~~~~~~~~~
+-----------+-------------------------------------------+
| HTTP Code | Description |
+===========+===========================================+
| **200** | successful response |
+-----------+-------------------------------------------+
Compiling PRH
=============
Whole project (top level of PRH directory) and each module (sub module
directory) can be compiled using `mvn clean install` command.
Main API Endpoints
==================
Running with dev-mode of PRH
- Heartbeat: **http://<container_address>:8100/heartbeat** or **https://<container_address>:8443/heartbeat**
- Start PRH: **http://<container_address>:8100/start** or **https://<container_address>:8433/start**
- Stop PRH: **http://<container_address>:8100/stopPrh** or **https://<container_address>:8433/stopPrh**
Maven GroupId:
==============
org.onap.dcaegen2.services
Maven Parent ArtifactId:
========================
dcae-services
Maven Children Artifacts:
=========================
1. prh-app-server: Pnf Registration Handler (PRH) server
2. prh-aai-client: Contains implementation of AAI client
3. prh-dmaap-client: Contains implementation of DmaaP client
4. prh-commons: Common code for whole prh modules