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

docs: decision record about API versioning #3595

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions DEPENDENCIES
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
maven/mavencentral/com.apicatalog/carbon-did/0.0.2, Apache-2.0, approved, #9239

Check warning on line 1 in DEPENDENCIES

View workflow job for this annotation

GitHub Actions / check / Dash-Verify-Licenses

Restricted Dependencies found

Some dependencies are marked 'restricted' - please review them
maven/mavencentral/com.apicatalog/iron-ed25519-cryptosuite-2020/0.8.1, Apache-2.0, approved, #11157
maven/mavencentral/com.apicatalog/iron-verifiable-credentials/0.8.1, Apache-2.0, approved, #9234
maven/mavencentral/com.apicatalog/titanium-json-ld/1.0.0, Apache-2.0, approved, clearlydefined
Expand Down Expand Up @@ -146,21 +146,21 @@
maven/mavencentral/io.swagger.core.v3/swagger-core-jakarta/2.2.15, Apache-2.0, approved, #5929
maven/mavencentral/io.swagger.core.v3/swagger-core/2.2.15, Apache-2.0, approved, #9265
maven/mavencentral/io.swagger.core.v3/swagger-core/2.2.8, Apache-2.0, approved, #9265
maven/mavencentral/io.swagger.core.v3/swagger-integration-jakarta/2.2.15, Apache-2.0, approved, clearlydefined
maven/mavencentral/io.swagger.core.v3/swagger-integration-jakarta/2.2.15, Apache-2.0, approved, #11475
maven/mavencentral/io.swagger.core.v3/swagger-integration/2.2.15, Apache-2.0, approved, #10352
maven/mavencentral/io.swagger.core.v3/swagger-jaxrs2-jakarta/2.2.15, Apache-2.0, approved, clearlydefined
maven/mavencentral/io.swagger.core.v3/swagger-jaxrs2-jakarta/2.2.15, Apache-2.0, approved, #11477
maven/mavencentral/io.swagger.core.v3/swagger-jaxrs2/2.2.15, Apache-2.0, approved, #9814
maven/mavencentral/io.swagger.core.v3/swagger-models-jakarta/2.2.15, Apache-2.0, approved, #5919
maven/mavencentral/io.swagger.core.v3/swagger-models/2.2.15, Apache-2.0, approved, #10353
maven/mavencentral/io.swagger.core.v3/swagger-models/2.2.8, Apache-2.0, approved, #10353
maven/mavencentral/io.swagger.parser.v3/swagger-parser-core/2.1.10, None, restricted, #11314
maven/mavencentral/io.swagger.parser.v3/swagger-parser-core/2.1.10, None, restricted, #11478
maven/mavencentral/io.swagger.parser.v3/swagger-parser-v2-converter/2.1.10, Apache-2.0, approved, #9330
maven/mavencentral/io.swagger.parser.v3/swagger-parser-v3/2.1.10, Apache-2.0, approved, #9323
maven/mavencentral/io.swagger.parser.v3/swagger-parser/2.1.10, None, restricted, #11316
maven/mavencentral/io.swagger/swagger-annotations/1.6.9, Apache-2.0, approved, #3792
maven/mavencentral/io.swagger/swagger-compat-spec-parser/1.0.64, None, restricted, #11282
maven/mavencentral/io.swagger/swagger-compat-spec-parser/1.0.64, None, restricted, #11479
maven/mavencentral/io.swagger/swagger-core/1.6.9, Apache-2.0, approved, #4358
maven/mavencentral/io.swagger/swagger-models/1.6.9, LicenseRef-scancode-proprietary-license, restricted, #11330
maven/mavencentral/io.swagger/swagger-models/1.6.9, LicenseRef-scancode-proprietary-license, restricted, #11476
maven/mavencentral/io.swagger/swagger-parser/1.0.64, Apache-2.0, approved, #4359
maven/mavencentral/jakarta.activation/jakarta.activation-api/1.2.1, EPL-2.0 OR BSD-3-Clause OR GPL-2.0-only with Classpath-exception-2.0, approved, ee4j.jaf
maven/mavencentral/jakarta.activation/jakarta.activation-api/2.1.0, EPL-2.0 OR BSD-3-Clause OR GPL-2.0-only with Classpath-exception-2.0, approved, ee4j.jaf
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
# Consistent Versioning of external APIs

## Decision

Going forward, all our external APIs will be versioned consistently across all endpoints and controllers. This means,
that the
Management API (to name a prominent example) will encode the same version number consistently across all its existing service endpoint URLs, within a major version.

## Rationale

Currently, every module that contributes an API can have its own versioning model. For example, at the time of writing
some APIs are available under `/v2/...`, some are available under `/v3/...` and some without a version specifier.

This can be confusing to developers who want to consume the API, because they not only need different base paths for
every API, they also need to re-check every endpoint when a new version of EDC is released, because every API can change
individually.

Therefore, we will use consistent versioning across _all_ client-facing APIs. At the time of writing, this includes just
the Management API.

## Approach

### Versioning scheme

Following the general semantics of SemVer, we will distinguish between a breaking change (major version bump) and
non-breaking and patch changes (minor/patch version bump). The major version will be represented in the URL:

```
https://some.host.com/api/management/v4/...
```

This means, client code only needs to be updated on major version changes of an API.

> Only major versions are represented in the URL

> Minor or patch updates will **not** be represented in the URL, and we will **not** host multiple minor/patch versions
> of an API at any given time.

Consequently, when multiple major versions of an API are available, every versioned URL (e.g. `/v3/assets`) effectively
contains the _latest_ version, so for instance `/v3/assets` would effectively point to version `3.1.4` of the Management
API.

> The same exact version is used for the entire Management API, we do **not** version independent modules or controllers

> The version of an API is independent of the version of EDC.

### Delegation mechanism for controllers

Not every endpoint changes from version to version. We will have to make the _same_ controller available
under _multiple_ URL paths as we do not want to duplicate controllers. There are several potential ways we could make
this work:

- Declare the `@Path` as [wildcard](https://docs.oracle.com/javaee/7/api/javax/ws/rs/Path.html)
- implement a custom interceptor, that parses the path and delegates to the correct controller

These are as yet untested and need further investigation with regard to the following aspects:

- do controllers appear as individual endpoints in the OpenAPI documentation?
- is there a significant impact w.r.t. resource consumption and response time?

### Storing and publishing version information

A new endpoint will be available that provides exact information about the version of the API. The path and the response
schema is TBD.

The version of an API must be stored in a file that is available at runtime. Every change to an API must increase that
version property. The `gradle.properties` file would be the obvious choice, however we would have to craft a way to
access that information at runtime.

### Publishing APIs to SwaggerHub

Ultimately, we will move away from publishing our APIs under the EDC version, and will publish them only under their
own version. Every update (major, minor, patch,...) will be published to SwaggerHub.
For this, we will have to update our Swagger-publish workflow quite significantly and read the
API [version information](#storing-and-publishing-version-information).

### Maintenance/deprecation model

As a standard M/O EDC will expose at most two versions of an API at any given time. The older one must be marked
as `deprecated` both in code and in Swagger.

All maintenance (bugfixes, patches, improvements) will **only** be made to the most recent API. Deprecated APIs will
**not** receive any maintenance.
2 changes: 2 additions & 0 deletions docs/developer/decision-records/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,3 +48,5 @@
- [2023-08-01 Default datasource](2023-08-01-default-datasource)
- [2023-08-07 Generic properties](./2023-08-07-generic-properties)
- [2023-09-07 Policy Monitor](./2023-09-07-policy-monitor)
- [2023-10-04 JSON-LD Scopes](./2023-10-04-json-ld-scopes)
- [2023-11-09 API Versioning](./2023-11-09-api-versioning)
Loading