This is a mechanism for the APIs to re-use, extend their functionalities and data models and engage with third-party API frameworks.
Mechanism for the APIs to re-use, extend their functionalities and data models and engage with third-party API frameworks (e.g. ETSI MEC)
Is defined on 3GPP TS 29.122 and 29.500 and is tightly connected with “supported-features” and feature negotiation
Vendor specific extensions are defined on 3GPP TS 29.122 (section 5.2.13) and 29.500 (section 6.6.3) and is tightly connected with "supported-features” and "feature negotiation" procedures.
Vendor Extensibility is a feature focused on the APIs that are published and exposed via CAPIF.
As a result, the feature is supported by the ServiceAPIDescription object (and any other objects embeded on it e.g. AefProfile). In the figure below, depicting all supported features of ServiceAPIDescription,
VendExt feature is noted, which enables vendor-specific extension in the body of the specific object.
* Extend the information element with vendor specific fields
### Fields have specific naming schemes:
* Using the 6-digit IANA-assigned enterprise code:
Vendor extensibility feature can be enabled and leveraged in 2 CAPIF APIs, Publish and Discover.
## Vendor Extensibility in CAPIF APIs
### Publish API:
A vendor can extend the ServiceAPIDescription object by adding additional member elements. However, in order to avoid duplication of member names inside a same object
it is necessary to comply with a naming scheme for vendor-specific data elements, to avoid clashing names between vendors.
Vendor-specific member names in JSON objects shall be named in the following manner:
```
"vendorSpecific-nnnnnnnnn": {
...
}
```
where the value "nnnnnn" can be:
1. 6-digit IANA-assigned enterprise code:
```
"vendorSpecific-010415": {
@@ -20,7 +34,7 @@ Is defined on 3GPP TS 29.122 and 29.500 and is tightly connected with “support
}
```
* Using domain name:
2. domain name:
```
@@ -29,7 +43,7 @@ Is defined on 3GPP TS 29.122 and 29.500 and is tightly connected with “support
}
```
* Using URN:
3. URN:
```
@@ -38,32 +52,62 @@ Is defined on 3GPP TS 29.122 and 29.500 and is tightly connected with “support
}
```
**Service API Description and AEF Profile Data**

A concrete example of vendor-specific extensibility exists on section 9 of ETSI GS MEC 011 V3.2.1, where ETSI MEC extends the ServiceAPIDescription as depicted on the following two figures.