blob: b10277355a54886ede8a733fc950eef0e8716cde [file] [log] [blame]
.. This work is licensed under a Creative Commons Attribution 4.0 International License.
.. SPDX-License-Identifier: CC-BY-4.0
.. Copyright (C) 2024 Nordix Foundation. All rights Reserved
.. Copyright (C) 2024 OpenInfra Foundation Europe. All Rights Reserved
Discover and Reconciliation Interface
#####################################
Discover and Reconciliation Interface to enrich topology with data.
Operations
==========
.. _Ingestion Create:
PUB ``ingestionCreate`` Operation
---------------------------------
*Topology & Inventory entities and relationships can be created.*
- Operation ID: ``Ingestion``
Operation on Topology Inventory and Exposure input topic.
Message Topology CREATE ``ingestionCreate``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*Creates components in topology.*
- Message ID: ``create``
- Content type: application/json
CREATE Headers
^^^^^^^^^^^^^^
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| Name | Type | Description | Value | Constraints | Notes |
+================+========+===========================================+==========================+=================+===================+
| (root) | object | - | - | - | | **additional** |
| | | | | | | **properties** |
| | | | | | | **are allowed** |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_id | string | Unique identifier for the event. | - | - | - |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_source | string | Source of the CloudEvent. | - | | format | - |
| | | | | | (`uri`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_type | string | | Event type. It can be one of | - | - | - |
| | | | topology-inventory-ingestion-merge, | | | |
| | | | topology-inventory-ingestion-delete, or | | | |
| | | | topology-inventory-ingestion-create. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| content-type | string | | Content-type of the data contained | | const | - | - |
| | | | within the cloud event. It is | | (`"application/json"`) | | |
| | | | application/json. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_dataschema | string | | URI representing the schema of the data | - | | format | - |
| | | | This references the event-specific yang | | | (`uri`) | |
| | | | schema. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_time | string | Event timestamp. | - | | format | - |
| | | | | | (`date-time`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_specversion | string | | The version of the CloudEvents | const (`"1.0"`) | - | - |
| | | | specification which the event uses. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
..
Examples of headers *(generated)*
.. code:: json
{
"ce_specversion": "1.0",
"ce_id": "a30e63c9-d29e-46ff-b99a-b63ed83fd233",
"ce_source": "dmi-plugin:nm-1",
"ce_type": "topology-inventory-ingestion-create",
"ce_time": "2023-06-12T09:05:00Z",
"content-type": "application/json",
"ce_dataschema": "topology-inventory-ingestion:events:create:1.0.0"
}
CREATE Payload
^^^^^^^^^^^^^^
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| Name | Type | Description |
+======================================================+===============+================================================================+
| (root) | Object | - |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data | - | | The data part consists of the actual topology data. It |
| | | | contains all the entities and their associated |
| | | | relationships. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.entities | Array<Object> | | Entities are topology objects comprising of an id, consumer |
| | | | data, attributes and metadata for each. It contains the id |
| | | | only in case of delete cloud event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.entities | Object | | Entities schema is adherent to the entity types and |
| | .<module_name> | | | attributes mentioned in the yang modules. For yang modules, |
| | :<mo_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.relationships | Array<Object> | | Relationships comprising of an A-side and a B-side for each. |
| | | | The A-side is considered the originating side of the |
| | | | relationship; the B-side is considered the terminating side |
| | | | of the relationship. The order of A-side and B-side is of |
| | | | importance and MUST NOT be changed once defined. It |
| | | | contains the id only in case of delete event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.relationships | Object | | Relationship schema is adherent to the relationship types |
| | .<module_name> | | | mentioned in the yang modules. For yang modules, |
| | :<relationship_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
Examples of payload *(generated)*
.. code:: json
{
"data": {
"entities": [
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=1",
"attributes": {
"antennaModelNumber": "1",
"mechanicalAntennaBearing": 50,
"mechanicalAntennaTilt": 10,
"positionWithinSector": "Unknown",
"totalTilt": 14,
"electricalAntennaTilt": 2,
"antennaBeamWidth": [
35,
23,
21
],
"geo-location": {
"latitude": 41.73297,
"longitude": -73.007696,
"height": 3000
}
},
"sourceIds": [
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=1,AntennaSubunit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaNearUnit=1,RetSubUnit=1"
],
"metadata": {
"trustLevel": "RELIABLE"
}
}
]
},
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=2",
"attributes": {
"antennaModelNumber": "2",
"mechanicalAntennaBearing": 61,
"mechanicalAntennaTilt": 21,
"positionWithinSector": "Unknown",
"totalTilt": 25,
"electricalAntennaTilt": 3,
"antennaBeamWidth": [
46,
34,
32
],
"geo-location": {
"latitude": 52.84308,
"longitude": -84.118707,
"height": 41111
}
},
"sourceIds": [
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=2",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=2,AntennaSubunit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaNearUnit=2,RetSubUnit=1"
],
"metadata": {
"trustLevel": "RELIABLE"
}
}
]
}
],
"relationships": [
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVs=",
"aSide": "urn:oran:smo:teiv:AntennaModule=1",
"bSide": "urn:oran:smo:teiv:Site=1"
}
]
},
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVsYW5kLE1lQ2=",
"aSide": "urn:oran:smo:teiv:AntennaModule=2",
"bSide": "urn:oran:smo:teiv:Site=2"
}
]
}
]
}
}
.. _Ingestion Merge:
PUB ``ingestionMerge`` Operation
--------------------------------
*Topology & Inventory entities and relationships can be updated.*
- Operation ID: ``Ingestion``
Operation on Topology Inventory and Exposure input topic.
Message Topology MERGE ``ingestionMerge``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*Updates components in topology.*
- Message ID: ``merge``
- Content type: application/json
MERGE Headers
^^^^^^^^^^^^^
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| Name | Type | Description | Value | Constraints | Notes |
+================+========+===========================================+==========================+=================+===================+
| (root) | object | - | - | - | | **additional** |
| | | | | | | **properties** |
| | | | | | | **are allowed** |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_id | string | Unique identifier for the event. | - | - | - |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_source | string | Source of the CloudEvent. | - | | format | - |
| | | | | | (`uri`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_type | string | | Event type. It can be one of | - | - | - |
| | | | topology-inventory-ingestion-merge, | | | |
| | | | topology-inventory-ingestion-delete, or | | | |
| | | | topology-inventory-ingestion-create. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| content-type | string | | Content-type of the data contained | | const | - | - |
| | | | within the cloud event. It is | | (`"application/json"`) | | |
| | | | application/json. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_dataschema | string | | URI representing the schema of the data | - | | format | - |
| | | | This references the event-specific yang | | | (`uri`) | |
| | | | schema. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_time | string | Event timestamp. | - | | format | - |
| | | | | | (`date-time`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_specversion | string | | The version of the CloudEvents | const (`"1.0"`) | - | - |
| | | | specification which the event uses. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
..
Examples of headers *(generated)*
.. code:: json
{
"ce_specversion": "1.0",
"ce_id": "a30e63c9-d29e-46ff-b99a-b63ed83fd234",
"ce_source": "dmi-plugin:nm-1",
"ce_type": "topology-inventory-ingestion-merge",
"ce_time": "2023-06-12T09:05:00Z",
"content-type": "application/json",
"ce_dataschema": "topology-inventory-ingestion:events:merge:1.0.0"
}
MERGE Payload
^^^^^^^^^^^^^
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| Name | Type | Description |
+======================================================+===============+================================================================+
| (root) | Object | - |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data | - | | The data part consists of the actual topology data. It |
| | | | contains all the entities and their associated |
| | | | relationships. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.entities | Array<Object> | | Entities are topology objects comprising of an id, consumer |
| | | | data, attributes and metadata for each. It contains the id |
| | | | only in case of delete cloud event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.entities | Object | | Entities schema is adherent to the entity types and |
| | .<module_name> | | | attributes mentioned in the yang modules. For yang modules, |
| | :<mo_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.relationships | Array<Object> | | Relationships comprising of an A-side and a B-side for each. |
| | | | The A-side is considered the originating side of the |
| | | | relationship; the B-side is considered the terminating side |
| | | | of the relationship. The order of A-side and B-side is of |
| | | | importance and MUST NOT be changed once defined. It |
| | | | contains the id only in case of delete event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.relationships | Object | | Relationship schema is adherent to the relationship types |
| | .<module_name> | | | mentioned in the yang modules. For yang modules, |
| | :<relationship_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
..
Examples of payload *(generated)*
.. code:: json
{
"data": {
"entities": [
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=1",
"attributes": {
"antennaModelNumber": "1",
"mechanicalAntennaBearing": 50,
"mechanicalAntennaTilt": 10,
"positionWithinSector": "Unknown",
"totalTilt": 14,
"electricalAntennaTilt": 2,
"antennaBeamWidth": [
35,
23,
21
],
"geo-location": {
"latitude": 41.73297,
"longitude": -73.007696,
"height": 3000
}
},
"sourceIds": [
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=1,AntennaSubunit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaNearUnit=1,RetSubUnit=1"
],
"metadata": {
"trustLevel": "RELIABLE"
}
}
]
},
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=2",
"attributes": {
"antennaModelNumber": "2",
"mechanicalAntennaBearing": 61,
"mechanicalAntennaTilt": 21,
"positionWithinSector": "Unknown",
"totalTilt": 25,
"electricalAntennaTilt": 3,
"antennaBeamWidth": [
46,
34,
32
],
"geo-location": {
"latitude": 52.84308,
"longitude": -84.118707,
"height": 41111
}
},
"sourceIds": [
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=2",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaUnit=2,AntennaSubunit=1",
"urn:3gpp:dn:ManagedElement=NR01,Equipment=1,AntennaUnitGroup=1,AntennaNearUnit=2,RetSubUnit=1"
],
"metadata": {
"trustLevel": "RELIABLE"
}
}
]
}
],
"relationships": [
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVs=",
"aSide": "urn:oran:smo:teiv:AntennaModule=1",
"bSide": "urn:oran:smo:teiv:Site=1"
}
]
},
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVsYW5kLE1lQ2=",
"aSide": "urn:oran:smo:teiv:AntennaModule=2",
"bSide": "urn:oran:smo:teiv:Site=2"
}
]
}
]
}
}
.. _Ingestion Delete:
PUB ``ingestionDelete`` Operation
---------------------------------
*Topology & Inventory entities and relationships can be deleted.*
- Operation ID: ``Ingestion``
Operation on Topology Inventory and Exposure input topic.
Message Topology DELETE ``ingestionDelete``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*Deletes components in topology.*
- Message ID: ``delete``
- Content type: application/json
DELETE Headers
^^^^^^^^^^^^^^
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| Name | Type | Description | Value | Constraints | Notes |
+================+========+===========================================+==========================+=================+===================+
| (root) | object | - | - | - | | **additional** |
| | | | | | | **properties** |
| | | | | | | **are allowed** |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_id | string | Unique identifier for the event. | - | - | - |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_source | string | Source of the CloudEvent. | - | | format | - |
| | | | | | (`uri`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_type | string | | Event type. It can be one of | - | - | - |
| | | | topology-inventory-ingestion-merge, | | | |
| | | | topology-inventory-ingestion-delete, or | | | |
| | | | topology-inventory-ingestion-create. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| content-type | string | | Content-type of the data contained | | const | - | - |
| | | | within the cloud event. It is | | (`"application/json"`) | | |
| | | | application/json. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_dataschema | string | | URI representing the schema of the data | - | | format | - |
| | | | This references the event-specific yang | | | (`uri`) | |
| | | | schema. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_time | string | Event timestamp. | - | | format | - |
| | | | | | (`date-time`) | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
| ce_specversion | string | | The version of the CloudEvents | const (`"1.0"`) | - | - |
| | | | specification which the event uses. | | | |
+----------------+--------+-------------------------------------------+--------------------------+-----------------+-------------------+
..
Examples of headers *(generated)*
.. code:: json
{
"ce_specversion": "1.0",
"ce_id": "a30e63c9-d29e-46ff-b99a-b63ed83fd235",
"ce_source": "dmi-plugin:nm-1",
"ce_type": "topology-inventory-ingestion-delete",
"ce_time": "2023-06-12T09:05:00Z",
"content-type": "application/json",
"ce_dataschema": "topology-inventory-ingestion:events:delete:1.0.0"
}
DELETE Payload
^^^^^^^^^^^^^^
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| Name | Type | Description |
+======================================================+===============+================================================================+
| (root) | Object | - |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data | - | | The data part consists of the actual topology data. It |
| | | | contains all the entities and their associated |
| | | | relationships. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.entities | Array<Object> | | Entities are topology objects comprising of an id, consumer |
| | | | data, attributes and metadata for each. It contains the id |
| | | | only in case of delete cloud event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.entities | Object | | Entities schema is adherent to the entity types and |
| | .<module_name> | | | attributes mentioned in the yang modules. For yang modules, |
| | :<mo_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| data.relationships | Array<Object> | | Relationships comprising of an A-side and a B-side for each. |
| | | | The A-side is considered the originating side of the |
| | | | relationship; the B-side is considered the terminating side |
| | | | of the relationship. The order of A-side and B-side is of |
| | | | importance and MUST NOT be changed once defined. It |
| | | | contains the id only in case of delete event. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
| | data.relationships | Object | | Relationship schema is adherent to the relationship types |
| | .<module_name> | | | mentioned in the yang modules. For yang modules, |
| | :<relationship_type> | | | see [Data Models][Data Models]. |
+------------------------------------------------------+---------------+----------------------------------------------------------------+
..
Examples of payload *(generated)*
.. code:: json
{
"data": {
"entities": [
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=1"
}
]
},
{
"o-ran-smo-teiv-equipment:AntennaModule": [
{
"id": "urn:oran:smo:teiv:AntennaModule=2"
}
]
}
],
"relationships": [
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVs="
}
]
},
{
"o-ran-smo-teiv-equipment:ANTENNAMODULE_INSTALLED_AT_SITE": [
{
"id": "urn:sha512:TlJDZWxsRFU6U3ViTmV0d29yaz1FdXJvcGUsU3ViTmV0d29yaz1JcmVsYW5kLE1lQ2="
}
]
}
]
}
}