From 86dd468b9fd4bd1ee6c5c9bd6067fa5a2570a952 Mon Sep 17 00:00:00 2001
From: FabrizioMoggio <87469955+FabrizioMoggio@users.noreply.github.com>
Date: Thu, 16 May 2024 14:22:29 +0200
Subject: [PATCH 1/3] TI Rel 0.9.4 Documentation
- new Release Notes section added in Documentation, to replace the .md documentation file
- Minor changes:
- modified camara URL to refer to the Edge Cloud WG
- OAS version now includes "-wip" extension
- simplified "Servers" section and included "vwip" as version
---
code/API_definitions/Traffic_Influence.yaml | 81 ++++++++++++++++++---
1 file changed, 69 insertions(+), 12 deletions(-)
diff --git a/code/API_definitions/Traffic_Influence.yaml b/code/API_definitions/Traffic_Influence.yaml
index 9dec615..a4c2adf 100644
--- a/code/API_definitions/Traffic_Influence.yaml
+++ b/code/API_definitions/Traffic_Influence.yaml
@@ -5,7 +5,7 @@ openapi: 3.0.3
############################################################################
info:
title: OPAG-CAMARA Traffic Influence API
- version: 0.9.3
+ version: 0.9.4-wip
description: |
## Overview
The reference scenario foresees a Service, composed by one or more Service
@@ -33,7 +33,7 @@ info:
geographical location and the Device moves to another geographical location,
the TI API can be invoked to get the optimal routing in the new geographical
location for that Device.
- ## 1. Introduction
+ ## Introduction
The TI API provides the capability to establish the best routing, in terms
of latency, in a specific geographical area, between the user Device, e.g.
the user’s smartphone, and the optimal EAS instance nearby. If the Device
@@ -74,7 +74,7 @@ info:
instance. In the case the Application detects a location change, it can
invoke the TI API again to request a new routing optimization toward
the new EAS instance.
- ## 2. Quick Start
+ ## Quick Start
The usage of the TI API is based on the management of a "TrafficInfluence"
resource, an object containing the intent requested invoking the TI API and
that is implemented by the platform configuring the Mobile Network for the
@@ -164,7 +164,7 @@ info:
Developers have a chance to specify call back URL on which notifications
(e.g. session termination) regarding the session can be received from the
service provider. This is also an optional parameter.
- ## 3. Authentication and Authorization
+ ## Authentication and Authorization
CAMARA guidelines defines a set of authorization flows which can grant API
clients access to the API functionality, as outlined in the document
[CAMARA-API-access-and-user-consent.md](https://github.com/camaraproject\
@@ -181,8 +181,7 @@ info:
mandatory. This measure ensures that the API remains in strict compliance
with user privacy preferences and regulatory obligations, upholding the
principles of transparency and user-centric data control.
- ## 4. API Documentation
- ## 4.1 Details
+ ## API Documentation
The TI API is consumed by an Application Function (AF) requesting for the
optimal routing, in term of latency, for the traffic flow from a Device
toward EAS instances in Edge Cloud Zones.\
@@ -210,6 +209,67 @@ info:
3) activate the optimal routing for a user devices: the TI API can be
invoked with a user Device identifier (“Device”). For each user Device,
a TI API invocation is required.
+ ## Release Notes
+ The Traffic Influence API reduces the complexity of the 3GPP Traffic
+ Influence API exposed by the 3GPP Network Exposure Function (NEF) [1]. While
+ the 3GPP TI API offers fastest routing activation and user mobility among
+ different edge sites, this version of the CAMARA Traffic Influence API
+ covers only the fastest routing activation, also for selected users.
+ User mobility will be introduced in a future version.\
+ \
+ **Enhancements with respect to the previous release V0.8.1:**
+ - These release also effects existing data sessions
+ - These release can be also used to optimize existing data sessions when a
+ Device moves among geographical areas.
+ - The ueId parameter is renamed into Device
+ - The parameter Device, that identifies the User, is now simplified to
+ guarantee the identification of an existing data session
+ - InstanceId added
+ - TrafficFilters description updated
+ - CAMEL type adopted
+ - FlowInfo deleted
+ - OpenAPI version updated to 3.0.3
+ - To let the Developer to just work on parameters actually editable, the PUT
+ method is changed into a PATCH method with a limitation on the
+ parameters usable and modifiable. A new resource is created,
+ PatchTrafficInfluence that contains only the editable parameters
+ The same approach is also adopted for the PUT method and a new resource
+ PostTrafficInfluence was created with just the editable parameters
+ - DELETE response code modified as 202. The Deletion request is accepted
+ (not yet completed, it must be carried on by the system)
+ - Added response code 400 (bad request) to POST
+ - General improvement in documentation
+ - applicationId changed into appId and instanceId changed into appInstanceId
+ - Alignement of parameters with EdgeCloud_LCM: applicationId changed into
+ appId and instanceId changed into appInstanceId
+ - Modified reference to CAMARA Authorization guidelines link
+ - Telco Edge Site changed in Edge Cloud Zone
+ - Added: info-contact
+ - Device: IPV4 and IPV6 changed to represent just one IP. Netmask is no more
+ valid
+ - Global tags definition
+ - Adopted lowerCamelCase for OperationId
+ - Added descriptions for Delete and Get (for specific resource) methods
+ - Added missing operationid
+ - Improvement of callback definition
+ - Added "description" to the TrafficInfluence resource
+ - Added "description" to the PatchTrafficInfluence resource
+ - Added "description" to TrafficInfluenceNotification
+ - Added "description" to NetworkAccessIdentifier
+ - Added "description" to ErrResponse
+ - Added "description" to message
+ - Added "description" to status
+ - Added "description" to ErrorInfo
+ - Removed unused error code SessionNotFound404
+ - Alignement of parameters with EdgeCloud_LCM: applicationId changed into
+ appId and instanceId changed into appInstanceId
+ - Adoption of OpenId authentication for Consent Management. Client
+ Credential is removed
+ - Intruduced xcorrelator
+ - General alignment with CAMARA on returned Errors
+ - Modified CAMARA URL to refer to the Edge Cloud Repository
+ - OAS version now includes "-wip" extension
+ - simplified "Servers" section and included "vwip" as version
license:
name: Apache 2.0
url: https://www.apache.org/licenses/LICENSE-2.0.html
@@ -218,19 +278,16 @@ info:
externalDocs:
description: Product documentation at Camara
- url: https://github.com/camaraproject/
+ url: https://github.com/camaraproject/EdgeCloud
############################################################################
# Servers #
############################################################################
servers:
- - url: "{apiRoot}/{basePath}"
+ - url: "{apiRoot}/traffic-influence/vwip"
variables:
apiRoot:
default: http://localhost:9091
- description: API root
- basePath:
- default: traffic-influence/v0
- description: Base path for the Traffic Influence API
+ description: API root for the Traffic Influence API
############################################################################
# Tags #
############################################################################
From d80f8250772494e4e52a22a50f5b5ede349165ae Mon Sep 17 00:00:00 2001
From: FabrizioMoggio <87469955+FabrizioMoggio@users.noreply.github.com>
Date: Thu, 16 May 2024 14:25:20 +0200
Subject: [PATCH 2/3] Delete Traffic_Influence_API_Documentation.md
According to: https://github.com/camaraproject/EdgeCloud/discussions/229
---
.../Traffic_Influence_API_Documentation.md | 392 ------------------
1 file changed, 392 deletions(-)
delete mode 100644 documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation.md
diff --git a/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation.md b/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation.md
deleted file mode 100644
index 291361c..0000000
--- a/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation.md
+++ /dev/null
@@ -1,392 +0,0 @@
-
-# OPAG-CAMARA Traffic Influence API
-## Overview
-
-The reference scenario foresees a Service, composed by one or more Service Producers deployed in different geographical locations on Telco Edge sites (Edge datacentres of Telco Operator) or in Cloud. The Service Producer, deployed at the Edge, is referred as Edge Application Server (EAS).
-The Traffic Influence API (TI API) provides the fastest routing from the user Device (e.g. a Smartphone) to the optimal EAS instance in a specific geographical location, installed in a Telco Edge site.
-If a Service is offered by Cloud Instances and by Edge Instances, the TI API can be used get the optimal routing of the traffic to the Edge Instances, maybe for a set of users. Getting the optimal routing can be used to improve latency maybe in combination with other CAMARA APIs such as QoD (Quality On Demand). Providing the optimal routing is indeed an important step to get the optimal latency.
-If the TI API is used to get the best routing at the Edge for a Device in a geographical location and the Device moves to another geographical location, the TI API can be invoked to get the optimal routing in the new geographical location for that Device.
-
-## 1. Introduction
-The TI API provides the capability to establish the best routing, in terms of latency, in a specific geographical area, between the user Device, e.g. the user’s smartphone, and the optimal EAS instance nearby. If the Device moves in a different geographical location where a more suitable EAS instance is available, the TI API can be invoked to influence the Device connectivity to get the optimal routing to the that local instance. It is important to notice that it is a task of the Application invoking the TI API to detect the changes in the Device location.
-The generic architecture for the Service can foresee some Cloud instances of the Application, one or more Edge Instances of the Application. A component of the Service is the TI API Consumer. This logical component can be integrated in other components of the Service to invoke the TI API, creating a "TrafficInfluence" resource specifying the desired intent.
-The TI API Producer implements the intent specified in the "TrafficInfluence" resource.
-While the TI API can be invoked to activate the fastest routing for any user, it can also be used to request the best routing for a specific user. Invoking the TI API for each user, many "TrafficInfluence" resources are created for each user to provide the requested routing for a set of users.
-The same approach is used for the geographical locations where the influence of the traffic must be applied. Invoking the TI API without specifying a geographical area activates the optimal routing toward any EAS instance, while invoking the TI API specifying a geographical area activates the optimal routing only toward the EAS instance located closest to that geographical area. To activate the optimal routing in selected geographical areas, the TI API must be invoked for each geographical area.
-The TI API can be used to:
- - optimise the routing when Devices need to consume the service provided by a local EAS Instances.
- - effect an already established Device routing when the Device moves among different geographical locations. When the TI API consumer detects a Device has entered a geographical location where an EAS instance is available, it can invoke the TI API to get the optimal routing toward that EAS instance. If the Device moves to another geographical location, served by another EAS instance, the routing might not be optimal anymore for the new EAS instance. In the case the Application detects a location change, it can invoke the TI API again to request a new routing optimization toward the new EAS instance.
-
-## 2. Quick Start
-The usage of the TI API is based on the management of a "TrafficInfluence" resource, an object containing the intent requested invoking the TI API and that is implemented by the platform configuring the Mobile Network for the optimal routing toward the EAS instance.
-The "TrafficInfluence" resource can be created (providing the related parameters that specify the desired intent), queried, modified and deleted.
-The TI API is asynchronous, a notification is available providing information about the status of the requested resource.
-For an Application (identified by "applicationId") many "TrafficInfluence" resources can be created, e.g. to add multiple users, regions or zones.
-
-Before starting to use the TI API, the developer needs to know about the below specified details:
-
-**Base-Url**
-The RESTful TI API endpoint, for example [**https://tim-api.developer.tim.it/trafficinfluence**](https://tim-api.developer.tim.it/trafficinfluence)
-
-**Authentication**
-Configure security access keys such as OAuth 2.0 client credentials to be used by Client applications which will invoke the TI API.
-
-**TrafficInfluence**
-This object represents the resource that carries the requirements from the user to be implemented. The TI API is invoked for the life cycle management of this resource (CRUD). The resource contains the intents from the TI API Consumer. Managing this resource, the developer can specify in which geographical location the routing must be applied, toward which application, maybe for a specific set of users or for a limited period of time.
-
-**trafficInfluenceID**
-Identifier for the Traffic Influence resource. This parameter is returned by the TI API and must be used to update it (e.g., adding a Device or deleting it). A different Traffic Influence resource must be created for any Device or Zone or Region. All these resources are related to an Application identified by the applicationId.
-
-**apiConsumerId**
-Unique identifier for the TI API Consumer.
-
-**region**
-The developer can specify in which geographical area he requires the fastest routing toward the nearest application instance. A Region is a wide geographical area and it contains one or more Zones. A Zone is where the Telco Edge sites are located. Zones and Regions identifiers are defined and provided by the Telco Operator and can also be used or retrieved with other CAMARA APIs (“MEC Exposure & Experience Management API” and “Simple Edge Discovery”). To add more regions the TI API must be invoked (POST) for each region. New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "applicationId").
-
-**zone**
-The developer can specify in which geographical area he requires the fastest routing toward the nearest Application instance. A Zone is a smaller geographical area inside a Region. A Zone is where the Telco Edge sites are located. To add more zones the TI API must be invoked (POST) for each zone. New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "applicationId").
-
-**applicationId**
-Unique Application identifier inside the Telco Operator Platform. This identifier is provided during the application onboarding process. To influence the traffic toward a specific Application. It is the Operator Platform that detects the appropriate Application instance in the selected Region or Zone.
-
-**instanceId**
-Unique identifier generated by the Operator Platform to identify a specific instance of the Application on a specific zone. To influence a traffic toward a specific Application instance.
-
-**trafficFilters**
-The Application can expose different service on different interfaces, with this parameter it is possible to enable just some of those services maybe for different sets of users.
-
-**Device**
-A user Device can be provided as an input. To add more users the TI API must be invoked (POST) of each user Device. New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "applicationId"). The routing toward the selected Application instance is only applied for provided user Devices.
-
-**Notification URL and token**
-Developers have a chance to specify call back URL on which notifications (e.g. session termination) regarding the session can be received from the service provider. This is also an optional parameter.
-
-## 3. Authentication and Authorization
-The TI API makes use of the client credentials grant which is applicable for server to server use cases involving trusted partners or clients without any protected user data involved.
-In this method the TI API invoker client is registered as a confidential client with an authorization grant type of client\\_credentials [2].
-
-## 4. API Documentation
-## 4.1 Details
-
-The TI API is consumed by an Application Function (AF) requesting for the optimal routing, in term of latency, for the traffic flow from a Device toward EAS instances in Telco Edge sites.
-When the Application (the EAS) is onboarded and deployed in the Telco Edge site, the Application is identified with a unique identifier (applicationId).
-Using the application identifier ("applicationId") and specifying a Zone or a Region, the Telco Operator Platform, autonomously identifies the best instance of the EAS toward which routing the traffic flow and configures the Mobile Network accordingly to get the fastest routing.
-If just the application identifier is used, the Telco Operator Platform identifies all the EAS Instances and activates the optimal routing on the Mobile Network.
-If the optimal routing in term of latency should be available just for a set of users, the TI API must be invoked for each user creating a new TrafficInfluce resource for each one.
-If the Application offers different services on different interfaces a traffic filter based on IP, Port and Protocol can be used. I this way it is also possible to redirect different users to different interfaces.
-Here are some possible intents:
-
-1) activate the optimal routing for any EAS instance: the TI API must be invoked with the applicationId. The Telco Operator Platform identifies all the EAS instances and activates the optimal routing on the Mobile Network.
-2) activate the optimal routing in a specific Region or Zone: the TI API must be invoked with the applicationId and the Zones and Regions identifiers.
-3) activate the optimal routing for a user devices: the TI API can be invoked with a user Device identifier (“Device”). For each user Device, a TI API invocation is required.
-
-## Version: 0.9.2
-
-**License:** [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0.html)
-
-[Product documentation at Camara](https://github.com/camaraproject/)
-### /traffic-influences
-
-#### GET
-##### Summary
-
-Retries existing TrafficInfluence Resources
-
-##### Description
-
-Reads all of the active TrafficInfluence resources owned by the same API Consumer authenticated via oAuth2
-
-##### Parameters
-
-| Name | Located in | Description | Required | Schema |
-| ---- | ---------- | ----------- | -------- | ---- |
-| applicationId | query | Not required. Used to select traffic influence resources filtered by applicationId | No | string |
-
-##### Responses
-
-| Code | Description |
-| ---- | ----------- |
-| 200 | Returns the information about existing TrafficInfluence resources. |
-| 401 | Unauthorized |
-| 403 | Forbidden |
-| 500 | An unknow error has occurred |
-| 503 | Service unavailable |
-| 504 | Connection timeout towards backend service has occurred |
-
-#### POST
-##### Summary
-
-Creates a new TrafficInfluence resource
-
-##### Description
-
-Takes as input an object containing the intents from the API Consumer and creates a TrafficInfluence resource accordingly. The trafficInfluenceID parameter, that is part of the object, must not be valorized when creating a new resource. For this reason the trafficInfluenceID parameter must be avoided in the object, anyway it will be ignored by the API Producer. It is automatically generated by the system and returned in the response.
-
-##### Responses
-
-| Code | Description |
-| ---- | ----------- |
-| 201 | TrafficInfluence resource created, the related object is returned with the resource ID (trafficInfluenceID) and status (state) valorised, |
-| 400 | Invalid input |
-| 401 | Unauthorized |
-| 403 | Forbidden |
-| 500 | An unknow error has occurred |
-| 503 | Service unavailable |
-| 504 | Connection timeout towards backend service has occurred |
-
-### /traffic-influences/{trafficInfluenceID}
-
-#### GET
-##### Summary
-
-read a specific TrafficInfluence resource identified by the trafficInfluenceID value
-
-##### Parameters
-
-| Name | Located in | Description | Required | Schema |
-| ---- | ---------- | ----------- | -------- | ---- |
-| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string |
-
-##### Responses
-
-| Code | Description |
-| ---- | ----------- |
-| 200 | OK. |
-| 401 | Unauthorized |
-| 403 | Forbidden |
-| 404 | The specified resource was not found |
-| 500 | An unknow error has occurred |
-| 503 | Service unavailable |
-| 504 | Connection timeout towards backend service has occurred |
-
-#### PATCH
-##### Summary
-
-updates a specific TrafficInfluence resource, identified by the trafficInfluenceID value
-
-##### Description
-
-The resource identified by the trafficInfluenceID value can be modified
-
-##### Parameters
-
-| Name | Located in | Description | Required | Schema |
-| ---- | ---------- | ----------- | -------- | ---- |
-| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string |
-
-##### Responses
-
-| Code | Description |
-| ---- | ----------- |
-| 200 | TrafficInfluence resource edited, the related object is returned, the status (state) is updated. |
-| 400 | Invalid input |
-| 401 | Unauthorized |
-| 403 | Forbidden |
-| 404 | The specified resource was not found |
-| 500 | An unknow error has occurred |
-| 503 | Service unavailable |
-| 504 | Connection timeout towards backend service has occurred |
-
-#### DELETE
-##### Summary
-
-Delete an existing TrafficInfluence resource
-
-##### Parameters
-
-| Name | Located in | Description | Required | Schema |
-| ---- | ---------- | ----------- | -------- | ---- |
-| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string |
-| callbackUrl | query | the location where updated data will be sent. Must be network accessible by the source server | No | string (uri) |
-
-##### Responses
-
-| Code | Description |
-| ---- | ----------- |
-| 202 | The resource delation request has been accepted |
-| 401 | Unauthorized |
-| 403 | Forbidden |
-| 404 | The specified resource was not found |
-| 503 | Service unavailable |
-| 504 | Connection timeout towards backend service has occurred |
-
-### Models
-
-#### TrafficInfluence
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| trafficInfluenceID | string | Identifier for the Traffic Influence resource. This parameter is returned by the API and must be used to update it (e.g., adding new users or deleting it). | No |
-| apiConsumerId | string | Unique Identifier of the TI API Consumer. | Yes |
-| applicationId | string | Unique ID representing the Edge Application
_Example:_ `"Virtual_Reality_Arena"` | Yes |
-| instanceId | string | Unique identifier generated by the partner OP to identify an instance of the application on a specific zone. | No |
-| region | string | Unique identifier representing a region | No |
-| zone | string | Unique identifier representing a zone | No |
-| device | object | Device identifier | No |
-| state | string | it reports the state of the TrafficInfluence resource. When first invoked, the resource is 'ordered'. When the platforms prepares the resource, it is 'created'. When the new routing is enabled in the network, the state is 'active'. If an error occurs in the resource creation or in its activation, the state is 'error'. When the DELETE method is invoked the state is 'deletion in progress'. After the resource is deleted (as a consequence of the previous invokation of the DELETE method) the state is 'deleted'.
_Enum:_ `"ordered"`, `"created"`, `"active"`, `"error"`, `"deletion in progress"`, `"deleted"` | No |
-| trafficFilters | [ string ] | Identifies IP packet filters. To be used when a the Application needs a traffic flow towards a specific EAS interface | No |
-| notificationUri | string | Defines the callback uri which should be notified in asynchronous way when the state for the requested resources changes (i.e. ordered to activated) | No |
-| notificationAuthToken | string | Authentification token for callback API | No |
-
-#### PatchTrafficInfluence
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| trafficInfluenceID | | | No |
-| apiConsumerId | | | No |
-| applicationId | | | No |
-| state | | | No |
-
-#### PostTrafficInfluence
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| trafficInfluenceID | | | No |
-| state | | | No |
-
-#### TrafficInfluenceNotification
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| trafficInfluenceChanged | object | | Yes |
-
-#### TypesZoneId
-
-Unique identifier representing a zone
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| TypesZoneId | string | Unique identifier representing a zone | |
-
-#### TypesRegionId
-
-Unique identifier representing a region
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| TypesRegionId | string | Unique identifier representing a region | |
-
-#### Device
-
-Device identifier
-
-| Name | Type | Description | Required |
-| ---- | ---- | ----------- | -------- |
-| phoneNumber | string | Subscriber number in E.164 format (starting with country code). Optionally prefixed with '+'.
_Example:_ `"123456789"` | No |
-| networkAccessIdentifier | string | _Example:_ `"123456789@domain.com"` | No |
-| ipv4Address | string (ipv4) | IPv4 address may be specified in form
123456789@domain.com- -#### PhoneNumber - -Subscriber number in E.164 format (starting with country code). Optionally prefixed with '+'. - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| PhoneNumber | string | Subscriber number in E.164 format (starting with country code). Optionally prefixed with '+'. | | - -**Example** -
123456789- -#### Ipv4Address - -IPv4 address may be specified in form as: - -- address - an IPv4 number in dotted-quad form 1.2.3.4. Only this exact IP number will match the flow control rule. -- address/mask - an IP number as above with a mask width of the form 1.2.3.4/24. - In this case, all IP numbers from 1.2.3.0 to 1.2.3.255 will match. The bit width MUST be valid for the IP version. - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| Ipv4Address | string | IPv4 address may be specified in form as: - address - an IPv4 number in dotted-quad form 1.2.3.4. Only this exact IP number will match the flow control rule. - address/mask - an IP number as above with a mask width of the form 1.2.3.4/24. In this case, all IP numbers from 1.2.3.0 to 1.2.3.255 will match. The bit width MUST be valid for the IP version. | | - -**Example** -
192.168.0.1/24- -#### Ipv6Address - -IPv6 address, following IETF 5952 format, may be specified in form as: - -- address - The /128 subnet is optional for single addresses: - - 2001:db8:85a3:8d3:1319:8a2e:370:7344 - - 2001:db8:85a3:8d3:1319:8a2e:370:7344/128 -- address/mask - an IP v6 number with a mask: - - 2001:db8:85a3:8d3::0/64 - - 2001:db8:85a3:8d3::/64 - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| Ipv6Address | string | IPv6 address, following IETF 5952 format, may be specified in form as: - address - The /128 subnet is optional for single addresses: - 2001:db8:85a3:8d3:1319:8a2e:370:7344 - 2001:db8:85a3:8d3:1319:8a2e:370:7344/128 - address/mask - an IP v6 number with a mask: - 2001:db8:85a3:8d3::0/64 - 2001:db8:85a3:8d3::/64 | | - -**Example** -
2001:db8:85a3:8d3:1319:8a2e:370:7344- -#### InstanceIdentifier - -Unique identifier generated by the partner OP to identify an instance of the application on a specific zone. - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| InstanceIdentifier | string | Unique identifier generated by the partner OP to identify an instance of the application on a specific zone. | | - -#### ErrResponse - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| status | string | _Example:_ `"OK"` | No | -| message | string | _Example:_ `"OK"` | No | - -#### ErrorInfo - -| Name | Type | Description | Required | -| ---- | ---- | ----------- | -------- | -| code | string | Code given to this error | Yes | -| message | string | Detailed error description | Yes | -### 4.4 Policies - -N/A - -### 4.5 Code Snippets - -N/A -### 4.6 FAQ's - -(FAQs will be added in a later version of the documentation) - -### 4.7 Terms - -N/A - -### 4.8 Release Notes - -The Traffic Influence API reduces the complexity of the 3GPP Traffic Influence API exposed by the 3GPP Network Exposure Function (NEF) [1]. While the 3GPP TI API offers fastest routing activation and user mobility among different edge sites, this version of the CAMARA Traffic Influence API covers only the fastest routing activation, also for selected users. User mobility will be introduced in a future version. - -Enhancements with respect to the previous release: - - - These release also effects existing data sessions - - These release can be also used to optimize existing data sessions when a Device moves among geographical areas. - - The ueId parameter is renamed into Device - - The parameter Device, that identifies the User, is now simplified to guarantee the identification of an existing data session - - instanceId added -- trafficFilters description updated -- CAMEL type adopted -- FlowInfo deleted -- OpenAPI version updated to 3.0.3 -- To let the Developer to just work on parameters actually editable, the PUT method is changed into a PATCH method with a limitation on the parameters usable and modifiable. A new resource is created, PatchTrafficInfluence that contains only the editable parameters. The same approach is also adopted for the PUT method and a new resource PostTrafficInfluence was created with just the editable parameters. -- DELETE response code modified as 202. The Deletion request is accepted (not yet completed) -- Added response code 400 (bad request) to POST -- General improvement in documentation - -## References - -[1] 3GPP TS 23.501: System architecture for the 5G System (5GS); Stage 2 (Release 17), V17.4.0 (2022-03) -[2] CAMARA Commonalities : Authentication and Authorization Concept for Service APIs https://github.com/camaraproject/WorkingGroups/blob/main/Commonalities/documentation/Working/CAMARA-AuthN-AuthZ-Concept.md \ No newline at end of file From 8c7d237e73b6b7fe926f8908b06253d87e479c5c Mon Sep 17 00:00:00 2001 From: FabrizioMoggio <87469955+FabrizioMoggio@users.noreply.github.com> Date: Wed, 22 May 2024 10:42:19 +0200 Subject: [PATCH 3/3] Documentation file as Obsolete as discussed here: https://github.com/camaraproject/EdgeCloud/pull/241#issuecomment-2122861126 Also adding a note on top of the file --- ...ic_Influence_API_Documentation_Obsolete.md | 439 ++++++++++++++++++ 1 file changed, 439 insertions(+) create mode 100644 documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation_Obsolete.md diff --git a/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation_Obsolete.md b/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation_Obsolete.md new file mode 100644 index 0000000..39294cf --- /dev/null +++ b/documentation/SupportingDocuments/API_Documentation/Traffic_Influence_API_Documentation_Obsolete.md @@ -0,0 +1,439 @@ + +# OPAG-CAMARA Traffic Influence API +## Overview + +NOTE: this documentation file is obsolete. The API documentation is now fully included in the API YAML file. + +The reference scenario foresees a Service, composed by one or more Service Producers deployed in different geographical locations on Edge Cloud Zones (Edge datacentres of Telco Operator) or in Cloud. The Service Producer, deployed at the Edge, is referred as Edge Application Server (EAS). +An Edge Cloud Zone is a platform in the Telco Operator network, offering network, compute and storage resources to developers. A developer can deploy and run applications on an Edge Cloud Zone, meaning reduced latency to end users that are nearby, as the network path is shorter. A network operator's EdgeCloud may comprise multiple Edge Cloud Zones, each in a discrete location to bring latency benefits to end users across a country . The operator can help developers know which of the Edge Cloud Zones will bring the best performance benefit for a given end user and application +The Traffic Influence API (TI API) provides the fastest routing from the user Device (e.g. a Smartphone) to the optimal EAS instance in a specific geographical location, installed in an Edge Cloud Zone. +If a Service is offered by Cloud Instances and by Edge Instances, the TI API can be used get the optimal routing of the traffic to the Edge Instances, maybe for a set of users. Getting the optimal routing can be used to improve latency maybe in combination with other CAMARA APIs such as QoD (Quality On Demand). Providing the optimal routing is indeed an important step to get the optimal latency. +If the TI API is used to get the best routing at the Edge for a Device in a geographical location and the Device moves to another geographical location, the TI API can be invoked to get the optimal routing in the new geographical location for that Device. + +## 1. Introduction +The TI API provides the capability to establish the best routing, in terms of latency, in a specific geographical area, between the user Device, e.g. the user’s smartphone, and the optimal EAS instance nearby. If the Device moves in a different geographical location where a more suitable EAS instance is available, the TI API can be invoked to influence the Device connectivity to get the optimal routing to the that local instance. It is important to notice that it is a task of the Application invoking the TI API to detect the changes in the Device location. +The generic architecture for the Service can foresee some Cloud instances of the Application, one or more Edge Instances of the Application. A component of the Service is the TI API Consumer. This logical component can be integrated in other components of the Service to invoke the TI API, creating a "TrafficInfluence" resource specifying the desired intent. +The TI API Producer implements the intent specified in the "TrafficInfluence" resource. +While the TI API can be invoked to activate the fastest routing for any user, it can also be used to request the best routing for a specific user. Invoking the TI API for each user, many "TrafficInfluence" resources are created for each user to provide the requested routing for a set of users. +The same approach is used for the geographical locations where the influence of the traffic must be applied. Invoking the TI API without specifying a geographical area activates the optimal routing toward any EAS instance, while invoking the TI API specifying a geographical area activates the optimal routing only toward the EAS instance located closest to that geographical area. To activate the optimal routing in selected geographical areas, the TI API must be invoked for each geographical area. +The TI API can be used to: + - optimise the routing when Devices need to consume the service provided by a local EAS Instances. + - effect an already established Device routing when the Device moves among different geographical locations. When the TI API consumer detects a Device has entered a geographical location where an EAS instance is available, it can invoke the TI API to get the optimal routing toward that EAS instance. If the Device moves to another geographical location, served by another EAS instance, the routing might not be optimal anymore for the new EAS instance. In the case the Application detects a location change, it can invoke the TI API again to request a new routing optimization toward the new EAS instance. + +## 2. Quick Start +The usage of the TI API is based on the management of a "TrafficInfluence" resource, an object containing the intent requested invoking the TI API and that is implemented by the platform configuring the Mobile Network for the optimal routing toward the EAS instance. +The "TrafficInfluence" resource can be created (providing the related parameters that specify the desired intent), queried, modified and deleted. +The TI API is asynchronous, a notification is available providing information about the status of the requested resource. +For an Application (identified by "appId") many "TrafficInfluence" resources can be created, e.g. to add multiple users, regions or zones. + +Before starting to use the TI API, the developer needs to know about the below specified details: + +**Base-Url** +The RESTful TI API endpoint, for example [**https://tim-api.developer.tim.it/trafficinfluence**](https://tim-api.developer.tim.it/trafficinfluence) + +**Authentication** +Configure security access keys such as OAuth 2.0 client credentials to be used by Client applications which will invoke the TI API. + +**TrafficInfluence** +This object represents the resource that carries the requirements from the user to be implemented. The TI API is invoked for the life cycle management of this resource (CRUD). The resource contains the intents from the TI API Consumer. Managing this resource, the developer can specify in which geographical location the routing must be applied, toward which application, maybe for a specific set of users or for a limited period of time. + +**trafficInfluenceID** +Identifier for the Traffic Influence resource. This parameter is returned by the TI API and must be used to update it (e.g., adding a Device or deleting it). A different Traffic Influence resource must be created for any Device or Zone or Region. All these resources are related to an Application identified by "appId". + +**apiConsumerId** +Unique identifier for the TI API Consumer. + +**region** +The developer can specify in which geographical area he requires the fastest routing toward the nearest application instance. A "region" is a wide geographical area and it contains one or more "zones". A "zone" is where the Edge Cloud Zone is located. Zones and Regions identifiers are defined and provided by the Telco Operator and can also be used or retrieved with other CAMARA APIs (“MEC Exposure & Experience Management API” and “Simple Edge Discovery”). To add more regions the TI API must be invoked (POST) for each region. New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "appId"). + +**zone** +The developer can specify in which geographical area he requires the fastest routing toward the nearest Application instance. A "zone" is a smaller geographical area inside a "region". A "zone" is where the Edge Cloud Zone is located. To add more zones the TI API must be invoked (POST) for each "zone". New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "appId"). + +**appId** +A globally unique identifier associated with the application. This identifier is provided during the application onboarding process. To influence the traffic toward a specific Application. It is the Operator Platform that detects the appropriate Application instance in the selected "region" or "zone". + +**appInstanceId** +A globally unique identifier generated by the Operator Platform to identify a specific instance of the Application on a specific zone. To influence a traffic toward a specific Application instance. + +**trafficFilters** +The Application can expose different service on different interfaces, with this parameter it is possible to enable just some of those services maybe for different sets of users. + +**Device** +A user Device can be provided as an input. To add more users the TI API must be invoked (POST) of each user Device. New "TrafficInfluence" resources are created (with different "trafficInfluenceID"). All the created resources are aggregated by the Application (identified by "appId"). The routing toward the selected Application instance is only applied for provided user Devices. + +**Notification URL and token** +Developers have a chance to specify call back URL on which notifications (e.g. session termination) regarding the session can be received from the service provider. This is also an optional parameter. + +## 3. Authentication and Authorization +The TI API makes use of the client credentials grant which is applicable for server to server use cases involving trusted partners or clients without any protected user data involved. +In this method the TI API invoker client is registered as a confidential client with an authorization grant type of client\\_credentials [2]. + +## 4. API Documentation +## 4.1 Details + +The TI API is consumed by an Application Function (AF) requesting for the optimal routing, in term of latency, for the traffic flow from a Device toward EAS instances in Edge Cloud Zones. +When the Application (the EAS) is onboarded and deployed in the Edge Cloud Zones, the Application is identified with a unique identifier ("appId"). +Using the application identifier ("appId") and specifying a Zone or a Region, the Telco Operator Platform, autonomously identifies the best instance of the EAS toward which routing the traffic flow and configures the Mobile Network accordingly to get the fastest routing. +If just the application identifier is used, the Telco Operator Platform identifies all the EAS Instances and activates the optimal routing on the Mobile Network. +If the optimal routing in term of latency should be available just for a set of users, the TI API must be invoked for each user creating a new TrafficInfluce resource for each one. +If the Application offers different services on different interfaces a traffic filter based on IP, Port and Protocol can be used. I this way it is also possible to redirect different users to different interfaces. +Here are some possible intents: + +1) activate the optimal routing for any EAS instance: the TI API must be invoked with the "appId". The Telco Operator Platform identifies all the EAS instances and activates the optimal routing on the Mobile Network. +2) activate the optimal routing in a specific Region or Zone: the TI API must be invoked with the "appId" and the Zones and Regions identifiers. +3) activate the optimal routing for a user devices: the TI API can be invoked with a user Device identifier (“Device”). For each user Device, a TI API invocation is required. + +## Version: 0.9.3 + +**Contact information:** +project-email@sample.com + +**License:** [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0.html) + +[Product documentation at Camara](https://github.com/camaraproject/) +### /traffic-influences + +#### GET +##### Summary + +Retries existing TrafficInfluence Resources + +##### Description + +Reads all of the active TrafficInfluence resources owned by the same API Consumer authenticated via oAuth2 + +##### Parameters + +| Name | Located in | Description | Required | Schema | +| ---- | ---------- | ----------- | -------- | ---- | +| appId | query | Used to select traffic influence resources filtered by appId | No | string (uuid) | + +##### Responses + +| Code | Description | +| ---- | ----------- | +| 200 | Returns the information about existing TrafficInfluence resources. | +| 401 | Unauthorized | +| 403 | Forbidden | +| 500 | An unknow error has occurred | +| 503 | Service unavailable | +| 504 | Connection timeout towards backend service has occurred | + +#### POST +##### Summary + +Creates a new TrafficInfluence resource + +##### Description + +Takes as input an object containing the intents from the API Consumer and creates a TrafficInfluence resourse accordingly. The trafficInfluenceID parameter, that is part of the object, must not be valorized when creating a new resource. For this reason the trafficInfluenceID parameter must be avoided in the object, anyway it will be ignored by the API Producer. It is automatically generated by the system and returned in the response. + +##### Responses + +| Code | Description | +| ---- | ----------- | +| 201 | TrafficInfluence resource created, the related object is returned with the resource ID (trafficInfluenceID) and status (state) valorised, | +| 400 | Invalid input | +| 401 | Unauthorized | +| 403 | Forbidden | +| 500 | An unknow error has occurred | +| 503 | Service unavailable | +| 504 | Connection timeout towards backend service has occurred | + +### /traffic-influences/{trafficInfluenceID} + +#### GET +##### Summary + +Reads a specific TrafficInfluence resource identified by the trafficInfluenceID value + +##### Description + +Returns a specific TrafficInfluence resources owned by the same API Consumer authenticated via oAuth2 + +##### Parameters + +| Name | Located in | Description | Required | Schema | +| ---- | ---------- | ----------- | -------- | ---- | +| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string | + +##### Responses + +| Code | Description | +| ---- | ----------- | +| 200 | OK. | +| 401 | Unauthorized | +| 403 | Forbidden | +| 404 | The specified resource was not found | +| 500 | An unknow error has occurred | +| 503 | Service unavailable | +| 504 | Connection timeout towards backend service has occurred | + +#### PATCH +##### Summary + +updates a specific TrafficInfluence resource, identified by the trafficInfluenceID value + +##### Description + +The resource identified by the trafficInfluenceID value can be modified + +##### Parameters + +| Name | Located in | Description | Required | Schema | +| ---- | ---------- | ----------- | -------- | ---- | +| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string | + +##### Responses + +| Code | Description | +| ---- | ----------- | +| 200 | TrafficInfluence resource edited, the related object is returned, the status (state) is updated. | +| 400 | Invalid input | +| 401 | Unauthorized | +| 403 | Forbidden | +| 404 | The specified resource was not found | +| 500 | An unknow error has occurred | +| 503 | Service unavailable | +| 504 | Connection timeout towards backend service has occurred | + +#### DELETE +##### Summary + +Delete an existing TrafficInfluence resource + +##### Description + +invoked by the API Consumer to stop influencing the traffic, deleting a TrafficInfluence resource previously created + +##### Parameters + +| Name | Located in | Description | Required | Schema | +| ---- | ---------- | ----------- | -------- | ---- | +| trafficInfluenceID | path | Identifier of the specific TrafficInfluence resource to be retrieved, modified or deleted. It is the value used to fill trafficInfluenceID parameter | Yes | string | +| callbackUrl | query | the location where updated data will be sent. Must be network accessible by the source server | No | string (uri) | + +##### Responses + +| Code | Description | +| ---- | ----------- | +| 202 | The resource delation request has been accepted | +| 401 | Unauthorized | +| 403 | Forbidden | +| 404 | The specified resource was not found | +| 503 | Service unavailable | +| 504 | Connection timeout towards backend service has occurred | + +### Models + +#### TrafficInfluence + +Resource conteining the informations to influence the traffic from the device to the EAS + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| trafficInfluenceID | string | Identifier for the Traffic Influence resource. This parameter is returned by the API and must be used to update it (e.g., adding new users or deleting it). | No | +| apiConsumerId | string | Unique Identifier of the TI API Consumer. | Yes | +| appId | string (uuid) | A globally unique identifier associated with the application. OP generates this identifier when the application is submitted over NBI.
123456789@domain.com+ +#### PhoneNumber + +Subscriber number in E.164 format (starting with country code). Optionally prefixed with '+'. + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| PhoneNumber | string | Subscriber number in E.164 format (starting with country code). Optionally prefixed with '+'. | | + +**Example** +
123456789+ +#### Ipv4Address + +IP of the device. A single IPv4 address may be specified in dotted-quad form 1.2.3.4. Only this exact IP number will match the flow control rule. + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| Ipv4Address | string | IP of the device. A single IPv4 address may be specified in dotted-quad form 1.2.3.4. Only this exact IP number will match the flow control rule. | | + +**Example** +
192.168.0.1+ +#### Ipv6Address + +IP of the device. A single IPv6 address, following IETF 5952 format, may be specified like 2001:db8:85a3:8d3:1319:8a2e:370:7344 + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| Ipv6Address | string | IP of the device. A single IPv6 address, following IETF 5952 format, may be specified like 2001:db8:85a3:8d3:1319:8a2e:370:7344 | | + +**Example** +
2001:db8:85a3:8d3:1319:8a2e:370:7344+ +#### AppInstanceId + +A globally unique identifier associated with a running instance of an application. OP generates this identifier. + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| AppInstanceId | string | A globally unique identifier associated with a running instance of an application. OP generates this identifier. | | + +#### AppId + +A globally unique identifier associated with the application. OP generates this identifier when the application is submitted over NBI. + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| AppId | string | A globally unique identifier associated with the application. OP generates this identifier when the application is submitted over NBI. | | + +**Example** +
6B29FC40-CA47-1067-B31D-00DD010662DA+ +#### ErrResponse + +Responce feedback in case of errors + +| Name | Type | Description | Required | +| ---- | ---- | ----------- | -------- | +| status | string | status for the error