-
Notifications
You must be signed in to change notification settings - Fork 45
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
application end point registration API yaml #321
base: main
Are you sure you want to change the base?
application end point registration API yaml #321
Conversation
🦙 MegaLinter status: ✅ SUCCESS
See detailed report in MegaLinter reports |
url: https://www.apache.org/licenses/LICENSE-2.0.html | ||
description: | | ||
Application endpoint registration allows application developers to | ||
register one or more Application Endpoints, and retrieve, update,and |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we have a definition for "Application Endpoints" to make it more explicit?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also think that these Application Endpoints are not generic and they corresponds to the application instances running on edge cloud zones in probably distributed manner. So should we qualify the Application Endpoints in some way to indicate developers about the expectations from these endpoints i.e. edge instances?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we have a definition for "Application Endpoints" to make it more explicit?
Added the "Application Endpoints" definition in "Relevant terms and Definitions" section
description: | | ||
Application endpoint registration allows application developers to | ||
register one or more Application Endpoints, and retrieve, update,and | ||
delete those egistrations. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suppose egistrations is should be "registrations"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
modified
|
||
This information can we used for various usecases like optimal end | ||
point discovery to help end users connect to the most most optimal | ||
instance of the application. Addtionally the information can be used |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I feel that if can refer or qualify applications as "edge applications" then it will make it more related to edge deployments while using generically may imply any deployment including clouds. Just a thought.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, modified "applications" to "edge applications"
delete those egistrations. | ||
|
||
This information can we used for various usecases like optimal end | ||
point discovery to help end users connect to the most most optimal |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"most most optimal" should be changed to "most optimal"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Modified
items: | ||
$ref: "#/components/schemas/ApplicationInstance" | ||
responses: | ||
"200": |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should also consider the additional status codes which could be valid for the POST requests in alignment with other APIs and consistency.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added relevant status codes for all the APIs
paths: | ||
/application-endpoints: | ||
post: | ||
operationId: register-application-endpoints |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For the POST method should we also include "x-correlator" header as done with other APIs.?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Included "x-correlator" for all the APIs
edgeCloudRegionId: | ||
$ref: "#/components/schemas/EdgeCloudRegionName" | ||
ResourcesapplicationEndpoint: | ||
type: object |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we assume that an application can expose only one endpoint or there could be more than one for different purposes? If there can be more than one which only application provider knows then this parameter should allow the multiplicity by having it as an array of objects. Also in that case with each endpoint there should be a discriminator field to allow client applications to know the purpose of a specific endpoint.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Although the top level object is an array but then if application has multiple endpoints some of the information will be repeated that many times as they will be common to an application.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also had the same question about repetitive data in the array. For example, is it expected that applicationId is the same for each ApplicationInstance in the array? If any field must be the same for each item in the array, it should be factored out into a single field in a parent object that encapsulates the endpoints array. If every field in the array can be different, then what is the intent of assigning a single applicationEndpointsId to the entire array?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In this initial version, the API handles where an application has a single purpose but distributed across various edge locations so each application instance at a given edge location has an endpoint to register.
The scenario mentioned application endpoints with different purpose is also a valid one. This can be considered in the later release.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The title "title: Application Endpoints Registration" has plural "Endpoints" as the keyword and based on the current form with single endpoint we may change it to singular form as endpoint or if we want to handle endpoints with different purposes in this release only then we need to provide option for multiple endpoint i.e. array in my view.
…ts-functionality-to-be-a-new-api EAR: Fixing Typo
@urvika-v tagging Urvika for review and updates |
edgeCloudZoneId: | ||
$ref: "#/components/schemas/EdgeCloudZoneId" | ||
edgeCloudZoneName: | ||
$ref: "#/components/schemas/EdgeCloudZoneName" | ||
edgeCloudProvider: | ||
$ref: "#/components/schemas/EdgeCloudProvider" | ||
edgeCloudRegionId: | ||
$ref: "#/components/schemas/EdgeCloudRegionName" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have a question on the intent here. First, are these edgeCloudZone-related fields specified during the POST /application-endpoints API? If they are specified, is it expected that the Operator Platform handling the API call will verify that it has the specified Zone in it's list of zones (i.e., if I specify a random string for the Zone ID, it will reject it)? Or does it treat them as just a reference to some external Zone that it doesn't know about, so I could just put in anything there and I will just get it back out during the "find" API call?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, the edgeCloudZone-related fields are to be specified during the POST call. And it is expected that the Operator platform should verify whether its a valid cloud zone or not before the "ApplicationEndpointsId" gets created
ApplicationInstance: | ||
description: Application instance represented | ||
by application Endpoint definition | ||
type: object |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest adding a required
section to note which fields are required.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added "Required" section to the schema.
applicationId: | ||
type: string | ||
description: Unique ID representing the Edge Application |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this really the applicationId or is it the appInstanceId? In the EAM API, the appId refers to definition of an App, like a helm chart, while the appInstanceId refers to an actually deployed instance of the helm chart. I ask because this object is called ApplicationInstance
but I don't see any appInstanceId
field. I think it would confusing if applicationId
in Discovery means something different from appId
in EAM.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed. "applicationId" is not referenced. Removed the parameter
description: | | ||
region of the Edge Cloud Zone. | ||
type: string | ||
TypesApplicationEndpointsId: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest renaming TypesApplicationEndpointsId
to just ApplicationEndpointsId
, as the Types prefix seems redundant.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
format: uuid | ||
readOnly: true | ||
additionalProperties: false | ||
TypesApplicationProfileId: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest renaming TypesApplicationProfileId
to just ApplicationProfileId
, as the Types prefix seems redundant.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Modified "TypesApplicationProfileId" to "ApplicationProfileId"
paths: | ||
/application-endpoints: | ||
post: | ||
operationId: register-application-endpoints |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest to specify operationIds in camelCase, rather than dash-separated, i.e. this should be registerApplicationEndpoints
. Both the EAM API and the official doc examples specify operationIds in camelCase, and it's better to be consistent across the APIs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed.
- name: applicationEndpointsId | ||
in: path | ||
required: true | ||
description: applicationEndpointsId param //added desc |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This description looks like it needs to be fixed, and the //added desc
removed.
There's 6 instances //added desc
in this file that need to be fixed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
application. | ||
|
||
paths: | ||
/application-endpoints: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would have expected there to also be a get
method for /application-endpoints
, to be able to list all of the registered applicationEndpointsId
. Otherwise the client needs to maintain a database of the registered applicationEndpointsId
to be able to update/delete them later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed. Added GetAll API which lists all the registered applications.
tags: | ||
- Application Endpoint Registration | ||
summary: Update a application Endpoint | ||
description: Update registered application Endpoint information. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please clarify if the update completely replaces the existing array or does something else like appending to it.
Also, a minor complaint, typically the summary
and description
would come at the top, right after the method type (i.e. the put
or get
). Having it all the way at the bottom after the responses means I'm trying to understand all the details of the method before I know the general intent of the method, which is hard. I would suggest moving them up.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moved the summary and the description to the top of the Schema.
tags: | ||
- name: Application Endpoint Registration | ||
description: | | ||
Operations to register, read and manage an deployed instances of the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
read and manage an deployed instances
-> either read and manage a deployed instance
or read and manage deployed instances
. Not sure if the intent is singular or plural but right now it's a mix.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Modified to "read and manage deployed instances"
Updated Error codes,Description,Security Schema, required parameter and added GetAllApplicationEndpoints API
…ts-functionality-to-be-a-new-api AER: Updated Error Codes, Description and added GetAllRegisteredApplicationEndpoints API
…ts-functionality-to-be-a-new-api AER: Fixed Linting issues
|
||
* **Application Endpoint**: | ||
|
||
The Endpoint on which the application is running. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we slightly update the statement "application is running" to such as "application is accessible"?
* **Application Endpoint**: | ||
|
||
The Endpoint on which the application is running. | ||
It can be a URI, FQDN, IPv4, or IPv6 address with a port number. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should the protocol i.e. TCP/UDP also be part of the endpoint spec?
Application Endpoint Information | ||
type: array | ||
items: | ||
$ref: "#/components/schemas/ApplicationEndpointRequest" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The term ApplicationEndpointRequest does not aligned to the top-level object name ApplicationEndpoins. May it could be ApplicationEndpointInfo or something like that?
Returns endpoint information for all | ||
Application Endpoints registered. | ||
operationId: getAllRegisteredApplicationEndpoints | ||
parameters: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was thinking from the usage perspective of GET method on how the apps suppose to use it. To me it it look like there will be a case where applications would need to retrieve the endpoint information of given application in a given location. As of, in current structure it seems the application will need to iterate through the whole array and find out which is the right endpoint of an app.
So if this seems to be a valid use case then should we have query parameters for say appId and/or edge cloud zone as an example? Though with the two GET method the same goal may still be achieved but i was just thinking if we should provide additional options for such endpoint retrieval scenarios?
What type of PR is this?
This PR is to review and update application endpoint registration API yaml.
Add one of the following kinds:
What this PR does / why we need it:
Initial commit of the yaml to provide ability to register application endpoints.
Which issue(s) this PR fixes:
issue #286
Fixes #
Special notes for reviewers:
This is only the initial commit and additional updates are required related to documentation, error codes etc to ensure it meets the CAMARA guidelines.
Changelog input
Additional documentation
This section can be blank.