Skip to content

Commit

Permalink
Add files via upload
Browse files Browse the repository at this point in the history
This contribution intends to provide an overview about how to use Application Endpoint Discovery API
  • Loading branch information
crissancas authored Jun 13, 2024
1 parent 4f2a148 commit 00a8b35
Showing 1 changed file with 52 additions and 0 deletions.
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>
```

0 comments on commit 00a8b35

Please sign in to comment.