Repository with source code, artifacts and documentation about YANG [1] to NGSI-LD translation. This translation process is the baseline for modeling a Descriptive Network Digital Twin (Descriptive NDT) solution by means of the NGSI-LD standard specified by ETSI ISG CIM [2].
The proposed Descriptive NDT architecture covers the core elements of NDT described by an IETF draft [3] and the descriptive twin vision provided by ETSI ISG CIM and its NGSI-LD standard specification [4]. The solution is targeted to real networks supporting Model-Driven Telemetry (MDT) and management mechanisms based on YANG data modeling language [5]. The architecture proposes an automated methodology for mapping YANG data from network management domain to an NDT representation, following a data integration approach supported by the NGSI-LD standard. The solution proposes the use of generic rules, based on [6], for translating between YANG and the NGSI-LD meta-model.
There is a prototype implementation for completing the Descriptive NDT architecture for data collection purposes which is built on a Docker microservices-based solution. The prototype covers the process of collecting telemetry and configuration data from the network for its integration in a Descriptive NDT adopting the data materialization approach. The implementation of this Descriptive NDT prototype is mainly based on the use of the OpenAPI Specification (OAS) compatible with the NGSI-LD API [7]. The OAS allows modeling the NDT data schemas (i.e., NDT Data Models in the Descriptive NDT architecture), as well as generating a client library with programmable code that makes use of the NGSI-LD API and the generated schemas for instantiating the resulting NDT data. The client is implemented in Python, a programming language that also provides additional libraries (e.g., pyang [8] or pydantic [9]) for parsing the YANG modeled data and completing the mapping process to NGSI-LD modeled data, as well as for instantiating the NDT data.
The prototype separates its functionality into two main planes: Descriptive NDT Generator Plane and Data Materialization Pipeline Plane. The Descriptive NDT Generator Plane general functionality consists in processing the native data models of the MDT Network Assets (i.e., YANG Schemas) in order to generate different programmed artifacts that allow performing the YANG to NGSI-LD translation in an autonomous way. Then, the Data Materialization Pipeline Plane makes use of the programmed artifacts to be able to parse the raw configuration and operational data coming from network assets and generate NGSI-LD modeled data to be instantiated within a compliant NGSI-LD Context Broker. The network configuration and telemetry data is collected by using MDT network management protocol such as NETCONF or gNMI. For a NETCONF client working as a data collector, a Python library called ncclient [10] has been selected that supports all operations and capabilities defined by the NETCONF management protocol. Meanwhile, for gNMIc a CLI client called gNMIc [11] has been selected that provides full support for Capabilities, Get, Set and Subscribe RPCs with collector capabilities and is also the gNMI client reference implementation provided by the OpenConfig consortium.
- candil-ngsi-ld-context-generator.py: given one or several YANG schemas, it generates the corresponding NGSI-LD context files in
.jsonld
format. - candil-xml-parser-generator.py: given one or several YANG schemas, it generates the Python code of an XML parser that reads data modeled by these schemas and generates the corresponding NGSI-LD Entity data structures (dictionary buffers). XML Parser Generator for operational status and configuration information received from NETCONF Query RPCs, and also for telemetry notifications received from NETCONF YANG-Push Subscriptions.
- candil-yang-identities-generator.py: given one or several YANG schemas, it generates the corresponding NGSI-LD Entity data structures (dictionary buffers) for YANG identities.
- candil-json-parser-generator-queries.py: given one or several YANG schemas, it generates the Python code of an JSON parser that reads data modeled by these schemas and generates the corresponding NGSI-LD Entity data structures (dictionary buffers). JSON Parser Generator for operational status and configuration information received from gNMI Query RPCs.
- candil-json-parser-generator-notifications.py: given one or several YANG schemas, it generates the Python code of an JSON parser that reads data modeled by these schemas and generates the corresponding NGSI-LD Entity data structures (dictionary buffers). JSON Parser Generator for telemetry notifications received from gNMI Subscription RPCs.
- candil-openapi-schemas-generator.py: given one or several YANG schemas, it dynamically generates the relative OpenAPI Schemas according to the OpenAPI specification for NGSI-LD API.
- candil-json-parser-generator.py: given one or several YANG schemas, it generates the Python code of an JSON parser that reads data modeled by these schemas and generates the corresponding NGSI-LD Entity data structures (dictionary buffers). JSON Parser Generator for non-gNMI data modeled according to YANG schemas. This means it is valid for data in JSON format that does not come from the gNMI protocol but is supported by IETF YANG models, OpenConfig YANG models, or vendor proprietary YANG models.
Supported extra data sources: NetFlow v9 and Network Topologies.
- TopologyDriver.java: Java application based on the YANG Tools [12], library for parsing data from network topology descriptor based on the ContainerLab [13] simulation testbed and mapping it to YANG-compliant data according to the ietf-network and ietf-network-topology YANG data models (RFC 8345).
The repository includes experimental results about the performance of the Descriptive NDT prototype solution. The experimental results allows determining the performance of the YANG to NGSI-LD translation and data intantiation processes in terms of latency (i.e., experiments 1 and 2) and throughput (i.e., experiment 3). The experiments have been performed for telemetry statistics from network interfaces encoded in both XML and JSON formats according to notifications received by the NETCONF and gNMI management protocols.
- M. Björklund, “The YANG 1.1 Data Modeling Language,” RFC 7950, Internet Engineering Task Force, Aug. 2016.
- ETSI, “Context Information Management (CIM); NGSI-LD API,” GS CIM 009 V1.8.1, ETSI, Mar. 2024.
- ETSI, “Context Information Management (CIM); Feasibility of NGSI-LD for Digital Twins,” GR CIM 017 v1.1.1, ETSI, Dec. 2022.
- C. Zhou et al., “Network Digital Twin: Concepts and Reference Architecture,” Internet-Draft draft-irtf-nmrg-network-digital-twin-arch-08, Internet Engineering Task Force, Oct. 2024. Work in Progress.
- B. Claise, J. Clarke, and J. Lindblad, Network Programmability with YANG: The Structure of Network Automation with YANG, NETCONF, RESTCONF, and gNMI. Addison-Wesley Professional, 2019, isbn:9780135180617
- ETSI, “Context Information Management (CIM); YANG and NGSI-LD interoperability,” GR CIM 038 v1.1.1, ETSI, Nov. 2024.
- ETSI, “OpenAPI Specification for NGSI-LD API,” GS CIM 047 v1.1.1, ETSI, Nov. 2024.
- pyang: https://github.com/mbj4668/pyang
- pydantic: https://docs.pydantic.dev/latest/
- ncclient: https://github.com/ncclient/ncclient
- gNMIc: https://github.com/openconfig/gnmic
- YANG Tools: https://github.com/opendaylight/yangtools
- ContainerLab: https://containerlab.dev/
This project is licensed under Apache-2.0.