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

[api] extend Display Provider observation API #832

Closed
Shastick opened this issue Oct 31, 2024 · 1 comment
Closed

[api] extend Display Provider observation API #832

Shastick opened this issue Oct 31, 2024 · 1 comment
Assignees
Labels
enhancement New feature or request P2 Normal priority

Comments

@Shastick
Copy link
Contributor

Shastick commented Oct 31, 2024

(Note: this issue is opened in the context of #754 regarding modifications to the observation API of a Display Provider)

The display provider's observation API is missing some optional fields that are defined in the standard, mainly:

(legend: d - added to draft pr, v - nothing to do)

  • timestamp accuracy (missing entirely) d
  • geodetic altitude (present in openAPI) v
  • geodetic vertical accuracy (missing entirely) d
  • horizontal accuracy (missing entirely) d
  • speed accuracy (missing entirely) d
  • vertical speed (missing entirely) d
  • UA Type (missing entirely) d
  • UA Classification Type (missing entirely: this field does not actually exist. See observations)
    • eu_classification (the actual field we need to optionally inject and provide) d
  • height (included but not expressed in the Python classes, should be checked) v
  • height type (included but not expressed in the Python classes) v

As-is, the qualifier is not able to fully verify compliance with NET0470 due to this. The solution we discussed at the community meeting is to expand the existing Observation API for it to include these optional fields.

The API definition for the display provider is here.

We probably want to add data types or modify the existing ones in commons.yaml and injection.yaml where required, given that any field we wish to observe must also be injected – though the injection API seems to cover all of them, except for the UA Type

observations

Where possible, we will want to mimic the existing USS uss/flights endpoint (in terms of the data structure) to avoid possible confusion and making the update of the mock_uss easier.

UA Classification Type

According to the OpenAPI spec for RID v2, the classification type is inferred implicitly depending on the presence of the eu_classification field:

When this field is specified, the Classification Type is "European
Union". If no other classification field is specified, the Classification Type
is "Undeclared"

It is assumed that this should be taken over for the RID testing interfaces as-is (injection and observation APIs)

misc

  • We will also need (in a second step) to update our mock_uss to ensure it populates new fields
  • Things to check:
    • height is available at injection and observation, and is validated by the qualifier. Need to confirm the validation occurs. If it does, nothing else to do.
    • height_type: same as height, should be covered in theory. Confirm that the check actually happens.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request P2 Normal priority
Projects
None yet
Development

No branches or pull requests

1 participant