Skip to content
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

Simple EDS API Aligned with commonalities #127

Merged
merged 5 commits into from
Sep 5, 2023
Merged

Conversation

Kevsy
Copy link
Collaborator

@Kevsy Kevsy commented Aug 11, 2023

  • Unused parameters removed
  • Unused resource types removed
  • filter parameter added (to future-proof GET /mecplatforms with no filter as a request to read the collection resource)
  • URI changed to kebab-case
  • OperationId updated to Camel Case
  • Identifiers moved to header for security reasons and aligned withe identifier names in Device Identifier API and QoD API
  • Basepath updated including major version
  • Standard error codes added
  • Documentation simplified and examples added
  • following review: success response made inline

* Unused parameters removed
* Unused resource types removed
* `filter` parameter added (to future-proof  `GET /mecplatforms` with no filter as a request to read the collection resource
* URI changed to kebab-case
* OperationId updated to Camel Case
*  Identifiers moved to header for security reasons (per Device Identifier API)
* Basepath updated including major version
* Standard error codes added
* Documentation simplified and examples added
"closest"
]

- name: IP-Address

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should this be a OneOf for IP-Address, Network-Access-Identifier, or Phone-Number.

Also I don't think capital kebab-case is a supporting naming convention. I believe that these parameters would be classified as objects and would be CabelCase. So IpAddress

Objects are defined in CamelCase inside properties field. For example: Greetings, ExampleObject Per section https://github.com/camaraproject/Commonalities/blob/main/documentation/API-design-guidelines.md#41-url-definition

Perhaps kebab-case would also be acceptable. for ip-address

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for reviewing @RandyLevensalor -

Should this be a OneOf for IP-Address, Network-Access-Identifier, or Phone-Number.

At least one is required, but two or all of them can be passed. This may help the operator in case they have trouble resolving the device. The CAMARA Device Identifier API takes the same approach.

Also I don't think capital kebab-case is a supporting naming convention. I believe that these parameters would be classified as objects and would be CabelCase. So IpAddress

Good point and I just checked this with a colleague on the CAMARA Technical Steering Committee. The exception here is that these are HTTP Request headers, which, whilst not prescribed by RFC 7230, are de facto written in Captal-Kebab case (ref: IANA message headers). The CAMARA Commonalities API Design Guidelines go on to say that:

Business data sent as part of the HTTP protocol will be exempt from these rules. In these cases, compliance with the standard protocol will apply.

...hence, use of Capital-Kebab as that is the expected convention for headers. I'll make a PR on the Design Guidelines to make that clearer.

ResourcesMecPlatform:

EdgeResource:
description: |

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you considered providing a URI and / or a unique ID for the EdgeResource?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Business data sent as part of the HTTP protocol will be exempt from these rules. In these cases, compliance with the standard protocol will apply.

Not a URI - since the platform itself (unlike a resource running on it) is not linkable.

But that's a great point about unique ID, because the various edge cloud providers do not have an agreed naming convention (such as a URN) which would ensure a globally unique value. E.g. in the South of England you could get the following names returned depending on the platform provider:

eu-west-2-wl1-lon-wlz-1
Europe-west2
UK South

So I propose to add the platform provider name, e..g AWS, Azure, GCP, {operator name} to help clarify. This can be particularyly useful should an operator partner with more than one platform provider. WDYT? @kevin8xu I think we may have discussed this at one point...?

Copy link
Collaborator

@kevin8xu kevin8xu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me.

1. made `MecPlatforms` an array of `MecPlatform`. Only one `MecPlatform` is returned for this Simple EDS API but this allows extensibility
2. Added the Provider as context to the Ern (name of closest MEC Platform) as there is no agreed globally unique identifier for a MEC Platform
3. Simplified the introduction.
@Kevsy
Copy link
Collaborator Author

Kevsy commented Aug 15, 2023

Following inital reviews (thanks!) I've made thgree changes to the commit (same Pull Request):

  1. made MecPlatforms an array of MecPlatform. Only one MecPlatform is returned for this Simple EDS API but this allows extensibility
  2. Added the Provider as context to the Ern (name of closest MEC Platform) as there is no agreed globally unique identifier for a MEC Platform.
  3. Simplified the introduction.

Kevsy added a commit that referenced this pull request Aug 17, 2023
Align with #127 and fix comment from initial review (404 instead of 500 for 'invalid device identifier')
@gunjald
Copy link
Collaborator

gunjald commented Aug 18, 2023

Can we assume that there is an implicit assumption that the MEC platform names are to be unique within an telco environment? As the API client responsibility is assumed to manage the mapping a MEC platform name as returned in the API response to the application endpoints or IP address details so in my opinion it implicitly imposes a uniqueness constraints for the operator to manage the uniqueness of MEC platform names.

If this is the case then it should be mentioned in the API description as the constraint then needs to be considered for SED API implementation.

Kevsy added 2 commits August 21, 2023 14:07
added missing quote mark in example success response
@Kevsy
Copy link
Collaborator Author

Kevsy commented Aug 21, 2023

@gunjald

Can we assume that there is an implicit assumption that the MEC platform names are to be unique within an telco environment? As the API client responsibility is assumed to manage the mapping a MEC platform name as returned in the API response to the application endpoints or IP address details so in my opinion it implicitly imposes a uniqueness constraints for the operator to manage the uniqueness of MEC platform names.

If this is the case then it should be mentioned in the API description as the constraint then needs to be considered for SED API implementation.

Added to latest document a 'note for API publishers' that the provider : ern tuple must be unique. The cloud provider zone names are already unique within the cloud provider domain, so it's really a comment to operators with self-build MEC. I would already strongly suspect those to be unique within a given operator, but best to make it explicit :)

Comment on lines 207 to 211
successResponse:
type: object
properties:
MecPlatforms:
$ref: '#/components/schemas/MecPlatforms'
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just a small comment: if you think that additional APIs may be added to this spec in the future, I would suggest that we remove this successResponse and encode the return type into the actual path+method definition. That is because another API will likely have a different successResponse object type. Unlike the errorReponse definition which is generic and can be referenced across all APIs, this successResponse is specific to a single API, so would be better defined just within path+method definition (i.e. mec-platforms/get), i.e. around line 167 would become:

responses:
  "200":
    description: A list of MEC Platforms, sorted by closest first
    content:
      application/json:
        schema:
          $ref: '#/components/schemas/MecPlatforms'

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @gainsley, that's a good suggestion: updated accordingly in latest commit

@Kevsy
Copy link
Collaborator Author

Kevsy commented Sep 1, 2023

@crissancas @sergiofranciscoortiz please can you approve and merge? Thanks!

Copy link
Collaborator

@sergiofranciscoortiz sergiofranciscoortiz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Approved after last changes taking into account previous comments.

Copy link
Collaborator

@gunjald gunjald left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed

@sergiofranciscoortiz sergiofranciscoortiz merged commit 69ed7a6 into main Sep 5, 2023
@Kevsy Kevsy deleted the Kevsy-patch-5 branch January 15, 2024 16:21
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants