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

Processing Parameters Extension #276 #545 #471

Open
wants to merge 8 commits into
base: draft
Choose a base branch
from

Conversation

m-mohr
Copy link
Member

@m-mohr m-mohr commented Nov 15, 2022

Adds the Processing Parameters Extension.

This extension adds a new endpoint (GET /processing_options)
to discover the additional processing options that a back-end offers.

Additionally, this extension allows to provide specific default values for user-defined processes (UDPs, see below).

Implements #276 and #545

… define the parameters that can be submitted suring creation #276
@m-mohr m-mohr added job management incl. /result service management minor requires a minor-version (x.1.0 for example) labels Nov 15, 2022
@m-mohr m-mohr added this to the 1.2.0 milestone Nov 15, 2022
@m-mohr m-mohr linked an issue Nov 15, 2022 that may be closed by this pull request
@soxofaan
Copy link
Member

soxofaan commented Nov 15, 2022

I'm not 100% sure whether adding these parameters to GET /jobs and GET /services is ideal as they would always be served whenever a job/service list will be served or paginated. We could also add the data to two new endpoints.

Indeed, I also find it strange to add this to the endpoints were we currently list actual jobs/services.
Can't we just add this to the general capabilities doc / ?
We already list some request aspects there anyway, like

  "endpoints": [
...
    {
      "methods": [ "GET", "POST"],
      "path": "/jobs"
    },
    {
      "methods": ["GET", "DELETE"],
      "path": "/jobs/{job_id}"
    },
...

@m-mohr
Copy link
Member Author

m-mohr commented Nov 15, 2022

I'm hesistant to add it there to keep it simple/small and not delay the request too much, because it's the first one and should not block additional requests because it needs to wait for some options to be retrieved. We also have /service_types externally for this reason.

@soxofaan
Copy link
Member

to keep it simple/small and not delay the request too much,

maybe I'm misunderstanding, but I don't think a reasonable implementation of the API will be delayed by adding a couple of fields the the capabilities document.

@soxofaan
Copy link
Member

I get that it feels normal from the web editor point of view, because you probably list a user's jobs before they are able to create a new one.

But in case of less interactive or lazy client environments like python client usage: it's a bit weird that the client first has to request GET /jobs in order to create a new job.

@m-mohr
Copy link
Member Author

m-mohr commented Nov 15, 2022

No, I think you understood correctly, but I also assumed that with other endpoints and it did turnout that this was a false assumption. So maybe we just add a new endpoint that returns these options (then likely called job_create_parameters and service_create_parameters or so).

@m-mohr
Copy link
Member Author

m-mohr commented Nov 16, 2022

I've updated the PR to have a dedicated (optional) endpoint.

openapi.yaml Outdated Show resolved Hide resolved
@m-mohr m-mohr marked this pull request as ready for review November 28, 2022 14:43
@m-mohr m-mohr modified the milestones: 1.2.0, 1.3.0 Dec 21, 2022
@m-mohr m-mohr removed this from the 1.3.0 milestone Feb 10, 2023
@m-mohr m-mohr modified the milestones: 1.2.0, 1.3.0 May 2, 2023
@m-mohr
Copy link
Member Author

m-mohr commented May 3, 2023

Moved this from 1.2.0 to 1.3.0. Implementors are free to implement this proposal and give feedback, but it didn't feel fully fleshed out yet for a release in 1.2.0.

@m-mohr
Copy link
Member Author

m-mohr commented Dec 4, 2024

As per #545 (comment), this PR should be reworked to be an extension.

@m-mohr m-mohr force-pushed the processing-parameters branch from e948c5f to 514b35b Compare December 18, 2024 15:17
@m-mohr m-mohr force-pushed the processing-parameters branch from 9bbaff5 to 830f9c2 Compare December 18, 2024 15:54
@m-mohr
Copy link
Member Author

m-mohr commented Dec 18, 2024

This PR has been updated to include the functionality requested in #545 and has been migrated from an addition to the core API to an experimental extension to the API. @jdries @soxofaan

@m-mohr m-mohr linked an issue Dec 18, 2024 that may be closed by this pull request
@m-mohr m-mohr requested review from soxofaan and dthiex December 18, 2024 17:20
@m-mohr m-mohr added data processing and removed minor requires a minor-version (x.1.0 for example) job management incl. /result service management labels Dec 18, 2024
@m-mohr m-mohr changed the title Jobs and services: Define creation parameters #276 Processing Parameters Extension #276 #545 Dec 18, 2024
Copy link

@jdries jdries left a comment

Choose a reason for hiding this comment

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

LGTM, we'll want to follow up with an implementation in our backend.

extensions/processing-parameters/README.md Outdated Show resolved Hide resolved
extensions/processing-parameters/README.md Outdated Show resolved Hide resolved

- `default_synchronous_parameters` for synchronous processing
- `default_job_parameters` for batch jobs
- `default_service_parameters` for secondary web services
Copy link
Member

Choose a reason for hiding this comment

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

(feel free to ignore if this is too much bike-shedding)

I'm not sure if it is intentional and there is a reasoning behind it, but the current description mixes "parameter" and "option": "processing parameter extension", GET /processing_options, default_job_parameters, ...

To me, "parameter" sounds more like a non-concrete placeholder, while "option" sounds a bit more concrete (e.g. a value provided by the user to make a parameter concrete). So in that sense, I'd think that the naming should be switched to:

  • GET /processing_parameters
  • default_synchronous_options, default_job_options, ....

I would also be fine with just collapsing everything to a single name, e.g. "option"

Copy link
Member Author

Choose a reason for hiding this comment

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

Indeed, it should just be a single name for it. Not sure yet which is better, but something to consider. Will have another look tomorrow.

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.

UDP: define minimally required additional job options Batch job options/configuration settings
4 participants