-
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.
This contribution intends to provide an overview about how to use Application Endpoint Discovery API
- Loading branch information
1 parent
4f2a148
commit 00a8b35
Showing
1 changed file
with
52 additions
and
0 deletions.
There are no files selected for viewing
52 changes: 52 additions & 0 deletions
52
documentation/SupportingDocuments/API_Documentation/User Stories/User_Story.md
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 |
---|---|---|
@@ -0,0 +1,52 @@ | ||
|
||
|
||
# Application Endpoint Discovery API User Story | ||
_This document is based on the [CAMARA Commonalities template for User Stories](https://github.com/camaraproject/Commonalities/blob/main/documentation/Userstory-template.md)_ | ||
_Roles are referenced from the ITU-T Cloud Refence Architecture._ | ||
|
||
## Summary | ||
"As an User, I want to connect my application to the optimal application instance running in an Edge Cloud Zone. The Application Endpoint Discovery API allows me to achieve this by providing direct access to the closest application endpoints within these zones. By using device-specific identifiers such as IP-Address, Phone-Number, or Network-Access-Identifier, I can ensure precise localization and connection to the best available endpoint. To maintain security and integrity, the API requires robust authentication and authorization processes using OpenID Connect and OAuth 2.0, with secure transmission over HTTPS and comprehensive error handling mechanisms to manage permissions and secure data transmission.". | ||
|
||
|
||
## Actors, Roles, and Scope | ||
| Actor | Role | Scope | | ||
|-------|------|-------| | ||
|Application Provider (AP) |API Consumer | API Requester | | ||
|Edge Platform (EP)|Edge Cloud Provider | API Publisher | | ||
|Edge Service Provider (ESP)|Edge Cloud Provider|API Publisher | ||
|Operator|Communications Service Provider|API Publisher | ||
|User Client(UC)|API Consumer|API Requester | ||
|
||
Note: the role of Edge Service Provider may be played by either the MNO or Cloud Service Providers (Hyperscalers). | ||
|
||
| Item | Description | Support Qualifier | | ||
|----|----|----| | ||
|Summary|The Application Endpoint Discovery API extends the capabilities of the Simple Edge Discovery API by locating the nearest Edge Cloud Zone and directly linking to application endpoints within those zones. This API enables immediate connection to the most optimal service endpoint, optimizing the application's interaction with edge computing resources. By providing the actual endpoints, developers can instantly integrate these into their applications, improving user experience by minimizing latency and enhancing service responsiveness.| M | | ||
|Pre-conditions|The AP has a resource usage agreement with the Operator| M | | ||
|Begins when|The user client request access to the application| M | | ||
|Step 1|The User invokes the Application Endpoint Discovery API to request an endpoint of the closest Edge Cloud Zone for this user (using MSISDN, IP-Address, or Network-Access-Identifier)| M | | ||
|Step 2|The Application Endpoint Discovery API returns an endpoint of the closest application instance for this user.| M| | ||
|Step 3|The User stablish the connectivity with the application instance| M| | ||
|Ends when|The user successfully connects to the instance| M | | ||
|
||
|
||
|
||
|
||
## Flow | ||
```mermaid | ||
sequenceDiagram | ||
participant UC | ||
participant Auth Server | ||
participant ESP | ||
participant Operator | ||
UC->>Auth Server: Token Request | ||
Auth Server-->>UC: <OAuth2 TOKEN> | ||
Note over Auth Server,UC: OpenID Connect Authenticationn | ||
UC->>ESP: GET request `/apps-endpoints?filter=closest` | ||
Note right of UC: - <TOKEN><br/>- Phone-Number<br/>- AppId | ||
ESP-->>Operator: | ||
Operator-->>ESP : User Location | ||
ESP-->>UC: 200 OK: <Endpoint JSON> | ||
``` |