-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Enforce line-lenght at 80 characters
- Loading branch information
1 parent
eba9585
commit a9c8d85
Showing
1 changed file
with
136 additions
and
65 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
--- | ||
openapi: 3.0.3 | ||
info: | ||
title: Simple Edge Discovery API | ||
|
@@ -7,62 +8,92 @@ info: | |
--- | ||
# Summary | ||
The Simple Edge Discovery API returns the name of the closest operator MEC platform to a particular user device. | ||
The Simple Edge Discovery API returns the name of the closest operator MEC | ||
platform to a particular user device. | ||
# Purpose | ||
Network operators may host multiple Multi-access Edge Computing (MEC, or 'Edge') platforms in a given territory. Connecting your application to a server on the closest MEC platform means packets travel the shortest distance between endpoints, typically resulting in the lowest round-trip latency. Note, the physical (GPS) location of a user device is not a reliable way to determine the closest MEC platform, due to the way operator networks are routed - so the operator will calculate the MEC platform with the _shortest network path_ to the network-attached device identified in the API request. | ||
Once you have the name of the closest MEC platform to the user device, you may: | ||
* connect the application client on the user device to your application server instance on that MEC platform. Note: the address of that server instance is not part of the API response, but should be known in advance. | ||
* or, if you have no instance on that MEC platform, you may wish to deploy one there. | ||
# Usage | ||
The API may be called either by an application client hosted on a device attached to the operator network (i.e. phone, tablet), or by a server. | ||
There is a single API endpoint: `/mecplatforms?filter=closest`. To call this endpoint, the API consumer must first obtain a valid OAuth2 token from the token endpoint, and pass it as an `Authorization` header in the API request. | ||
The API returns the closest MEC platform to a given device, so that device needs to be identifiable by the network: | ||
* if you call the API from a server, you must explicitly pass one or more device identifiers in the HTTP request header: | ||
* `IP-Address`. This is the public IP address of the user device: this can be obtained by an application hosted on that device calling a public IP address API (e.g. GET https://api.ipify.org?format=json) | ||
* `Phone-Number` . The international E.164 format (starting with country code), e.g. +4407123123456 | ||
Network operators may host multiple Multi-access Edge Computing (MEC, or | ||
'Edge') platforms in a given territory. Connecting your application to a | ||
server on the closest MEC platform means packets travel the shortest | ||
distance between endpoints, typically resulting in the lowest round-trip | ||
latency. Note, the physical (GPS) location of a user device is not a | ||
reliable way to determine the closest MEC platform, due to the way operator | ||
networks are routed - so the operator will calculate the MEC platform with | ||
the _shortest network path_ to the network-attached device identified in | ||
the API request. | ||
Once you have the name of the closest MEC platform to the user device, you | ||
may: | ||
* connect the application client on the user device to your application | ||
server instance on that MEC platform. Note: the address of that server | ||
instance is not part of the API response, but should be known in advance. | ||
* or, if you have no instance on that MEC platform, you may wish to deploy | ||
one there. | ||
# Usage | ||
The API may be called either by an application client hosted on a device | ||
attached to the operator network (i.e. phone, tablet), or by a server. | ||
There is a single API endpoint: `/mecplatforms?filter=closest`. To call | ||
this endpoint, the API consumer must first obtain a valid OAuth2 token from | ||
the token endpoint, and pass it as an `Authorization` header in the API | ||
request. | ||
The API returns the closest MEC platform to a given device, so that device | ||
needs to be identifiable by the network: | ||
* If you call the API from a server, you must explicitly pass one or | ||
more device identifiers in the HTTP request header: | ||
* `IP-Address`. This is the public IP address of the user device: this can | ||
be obtained by an application hosted on that device calling a public IP | ||
address API (e.g. GET https://api.ipify.org?format=json) | ||
* `Phone-Number` . The international E.164 format (starting with country | ||
code), e.g. +4407123123456 | ||
* `Network-Access-Identifier` (where available from the API host operator) | ||
* if you call the API from a device attached to the operator network, you _may_ omit the explicit device identifier(s)from the request header. If such a request fails with a `404 Not Found` error then retry the request but this time include a device identifier. | ||
* if you call the API from a device attached to the operator network, you | ||
_may_ omit the explicit device identifier(s)from the request header. If such | ||
a request fails with a `404 Not Found` error then retry the request but this | ||
time include a device identifier. | ||
The provider of the MEC Platform may be an operator, or a cloud provider. The | ||
The provider of the MEC Platform may be an operator, or a cloud provider. | ||
# Example requests: | ||
Examples for all API clients: | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
Network-Access-Identifier: [email protected] | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
Network-Access-Identifier: [email protected] | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
IP-Address: 84.125.93.10 | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
IP-Address: 84.125.93.10 | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
Phone-Number: 441234567890 | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
Phone-Number: 441234567890 | ||
Example where API client is on a network-attached device: | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
GET /mec-platforms?filter=closest HTTP/1.1 | ||
Host: example.com | ||
Accept: application/json | ||
# Responses | ||
## Success | ||
A JSON object is returned containing a `MECPlatforms` array with a single member, along with the HTTP `200 OK` status code. The value of the `edgeCloudProvider` object is the name of the operator or cloud provider of the MEC Platform. `edgeResourceName` object is the name of the closest MEC platform to the user device. An example of this JSON object is as follows: | ||
A JSON object is returned containing a `MECPlatforms` array with a single | ||
member, along with the HTTP `200 OK` status code. The value of the | ||
`edgeCloudProvider` object is the name of the operator or cloud provider of | ||
the MEC Platform. `edgeResourceName` object is the name of the closest MEC | ||
platform to the user device. An example of this JSON object is as follows: | ||
``` | ||
{ | ||
"MecPlatforms": [ | ||
|
@@ -75,16 +106,22 @@ info: | |
``` | ||
## Errors | ||
If the authentication token is not valid, a `401 UNAUTHENTICATED` error is returned. | ||
If the authentication token is not valid, a `401 UNAUTHENTICATED` error is | ||
returned. | ||
If the mobile subscription parameters contain a formatting error, a `400 INVALID_ARGUMENT` error is returned. | ||
If the mobile subscription parameters contain a formatting error, a `400 | ||
INVALID_ARGUMENT` error is returned. | ||
If the mobile subscription cannot be identified from the provided parameters, a `404 NOT_FOUND` error is returned. | ||
If the mobile subscription cannot be identified from the provided | ||
parameters, a `404 NOT_FOUND` error is returned. | ||
Any more general service failures will result in an error in the `5xx`range with an explanation. | ||
Any more general service failures will result in an error in the `5xx`range | ||
with an explanation. | ||
# Note for Simple Edge API publishers | ||
The API publisher (i.e. the operator implementation) must ensure that the tuple of edgeCloudProvider+edgeResourceName in the success response is unique. | ||
The API publisher (i.e. the operator implementation) must ensure that the | ||
tuple of edgeCloudProvider+edgeResourceName in the success response is | ||
unique. | ||
# Further info and support | ||
|
@@ -123,7 +160,8 @@ paths: | |
- name: filter | ||
in: query | ||
required: true | ||
description: Filter the MEC Platforms according to the parameter value. For this API the only supported value is `closest`. | ||
description: Filter the MEC Platforms according to the parameter | ||
value. For this API the only supported value is `closest`. | ||
schema: | ||
type: string | ||
enum: ["closest"] | ||
|
@@ -146,7 +184,8 @@ paths: | |
|
||
- name: Network-Access-Identifier | ||
in: header | ||
description: 3GPP network access identifier for the subscription being used by the device. | ||
description: 3GPP network access identifier for the subscription being | ||
used by the device. | ||
example: "[email protected]" | ||
required: false | ||
schema: | ||
|
@@ -156,14 +195,17 @@ paths: | |
in: header | ||
example: "441234567890" | ||
required: false | ||
description: MSISDN in E.164 format (starting with country code) of the mobile subscription being used by the device. Optionally prefixed with '+'. | ||
description: MSISDN in E.164 format (starting with country code) of | ||
the mobile subscription being used by the device. Optionally | ||
prefixed with '+'. | ||
schema: | ||
type: string | ||
pattern: '^\+?[0-9]{5,15}$' | ||
|
||
responses: | ||
"200": | ||
description: Successful response, returning the closest MEC platform to the user device identified in the request header. | ||
description: Successful response, returning the closest MEC platform | ||
to the user device identified in the request header. | ||
content: | ||
application/json: | ||
schema: | ||
|
@@ -192,14 +234,22 @@ paths: | |
$ref: "#/components/responses/504GatewayTimeout" | ||
tags: | ||
- Discovery | ||
summary: Returns the name of the MEC platform closest to user device identified in the request. | ||
description: On receiving this request, the network will return the name of the MEC platform with the shortest network path to the end user device identified in the request. | ||
summary: Returns the name of the MEC platform closest to user device | ||
identified in the request. | ||
description: On receiving this request, the network will return the name | ||
of the MEC platform with the shortest network path to the end user | ||
device identified in the request. | ||
|
||
components: | ||
securitySchemes: | ||
oAuth2ClientCredentials: | ||
type: oauth2 | ||
description: The Simple Edge Discovery API makes use of the OAUTH 2.0 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 API invoker client is registered as a confidential client with an authorization grant type of client_credentials. | ||
description: The Simple Edge Discovery API makes use of the OAUTH 2.0 | ||
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 API invoker client is registered as a | ||
confidential client with an authorization grant type of | ||
client_credentials. | ||
flows: | ||
clientCredentials: | ||
tokenUrl: "{tokenUrl}" | ||
|
@@ -209,12 +259,17 @@ components: | |
type: array | ||
items: | ||
$ref: "#/components/schemas/MecPlatform" | ||
description: A collection of MEC Platforms. For this Simple Edge Discovery API the collection will have at most one member (the closest MEC Platform to the user device indicated in the request). | ||
description: A collection of MEC Platforms. For this Simple Edge Discovery | ||
API the collection will have at most one member (the closest MEC | ||
Platform to the user device indicated in the request). | ||
additionalProperties: false | ||
|
||
MecPlatform: | ||
type: object | ||
description: A MEC Platform, uniquely identified by a combination of the value of the Edge Resource Name object and the value of the Provider object (the name of the cloud provider or operator hosting that platform). | ||
description: A MEC Platform, uniquely identified by a combination of the | ||
value of the Edge Resource Name object and the value of the Provider | ||
object (the name of the cloud provider or operator hosting that | ||
platform). | ||
properties: | ||
edgeCloudProvider: | ||
$ref: "#/components/schemas/EdgeCloudProvider" | ||
|
@@ -228,7 +283,8 @@ components: | |
|
||
EdgeResource: | ||
description: | | ||
Edge Resource Name - an identifier for an edge resource in the operator domain. | ||
Edge Resource Name - an identifier for an edge resource in the operator | ||
domain. | ||
type: string | ||
additionalProperties: false | ||
|
||
|
@@ -243,7 +299,9 @@ components: | |
description: The HTTP status code. | ||
message: | ||
type: string | ||
description: This parameter appears when there was an error. Human readable explanation specific to this occurrence of the problem. | ||
description: This parameter appears when there was an error. | ||
Human readable explanation specific to this occurrence of the | ||
problem. | ||
|
||
################################### | ||
# RESPONSES | ||
|
@@ -257,12 +315,17 @@ components: | |
$ref: "#/components/schemas/errorResponse" | ||
examples: | ||
InsufficientParameters: | ||
description: Sufficient parameters must be specified to allow the target UE to be identified. | ||
description: Sufficient parameters must be specified to allow the | ||
target UE to be identified. | ||
value: | ||
{ | ||
"code": "INVALID_ARGUMENT", | ||
"status": 400, | ||
"message": "Insufficient parameters: At least one of Network-Access-Identifier, Phone-Number or IP-Address must be specified, or, the API must be called by a client on a network-attached device (hence passing the source IP in the request header) ", | ||
"message": "Insufficient parameters: At least one of | ||
Network-Access-Identifier, Phone-Number or IP-Address must be | ||
specified, or, the API must be called by a client on a | ||
network-attached device (hence passing the source IP in the | ||
request header) ", | ||
} | ||
InvalidExternalId: | ||
value: | ||
|
@@ -279,7 +342,9 @@ components: | |
"message": "Invalid Header Format: Phone-Number", | ||
} | ||
InvalidIP: | ||
description: This error will be returned if the IP address does not have a valid format, or if the IP address is a private IPv4 address. | ||
description: This error will be returned if the IP address does | ||
not have a valid format, or if the IP address is a private IPv4 | ||
address. | ||
value: | ||
{ | ||
"code": "INVALID_ARGUMENT", | ||
|
@@ -298,7 +363,8 @@ components: | |
{ | ||
"code": "UNAUTHENTICATED", | ||
"status": 401, | ||
"message": "Request not authenticated due to missing, invalid, or expired credentials", | ||
"message": "Request not authenticated due to missing, invalid, | ||
or expired credentials", | ||
} | ||
|
||
403Forbidden: | ||
|
@@ -313,7 +379,8 @@ components: | |
{ | ||
"code": "PERMISSION_DENIED", | ||
"status": 403, | ||
"message": "Client does not have sufficient permissions to perform this action", | ||
"message": "Client does not have sufficient permissions to | ||
perform this action", | ||
} | ||
|
||
404NotFound: | ||
|
@@ -324,7 +391,8 @@ components: | |
$ref: "#/components/schemas/errorResponse" | ||
examples: | ||
SubscriberNotFound: | ||
description: No device found for the specified parameters, meaning the closest MEC platform cannot be determined. | ||
description: No device found for the specified parameters, meaning | ||
the closest MEC platform cannot be determined. | ||
value: | ||
{ | ||
"code": "NOT_FOUND", | ||
|
@@ -340,12 +408,14 @@ components: | |
$ref: "#/components/schemas/errorResponse" | ||
examples: | ||
MethodNotAllowed: | ||
description: An HTTP verb other than GET has been used to try and access the resource. | ||
description: An HTTP verb other than GET has been used to try and | ||
access the resource. | ||
value: | ||
{ | ||
"code": "METHOD_NOT_ALLOWED", | ||
"status": 405, | ||
"message": "The request method is not supported by this resource", | ||
"message": "The request method is not supported by this | ||
resource", | ||
} | ||
|
||
406Unacceptable: | ||
|
@@ -361,7 +431,8 @@ components: | |
{ | ||
"code": "NOT_ACCEPTABLE", | ||
"status": 406, | ||
"message": "The server cannot produce a response matching the content requested by the client through Accept-* headers", | ||
"message": "The server cannot produce a response matching the | ||
content requested by the client through Accept-* headers", | ||
} | ||
|
||
429TooManyRequests: | ||
|
@@ -372,12 +443,12 @@ components: | |
$ref: "#/components/schemas/errorResponse" | ||
examples: | ||
TooManyRequests: | ||
description: Access to the API has been temporarily blocked due to quota or spike arrest limits being reached. | ||
description: Access to the API has been temporarily blocked due to | ||
quota or spike arrest limits being reached. | ||
value: | ||
{ | ||
"code": "TOO_MANY_REQUESTS", | ||
"status": 429, | ||
"message": "Either out of resource quota or reaching rate limiting", | ||
"code": "TOO_MANY_REQUESTS", "status": 429, "message": "Either | ||
out of resource quota or reaching rate limiting", | ||
} | ||
|
||
500InternalServerError: | ||
|