Skip to content

Commit

Permalink
Initial RFC for API versioning
Browse files Browse the repository at this point in the history
Signed-off-by: Andrew Meyer <ameyer@pivotal.io>
  • Loading branch information
ameyer-pivotal committed Aug 5, 2019
1 parent ea08bb5 commit bffdaf4
Showing 1 changed file with 33 additions and 0 deletions.
33 changes: 33 additions & 0 deletions 0000-api-versions.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# Meta
[meta]: #meta
- Name: API Versions
- Start Date: 2019-08-05
- CNB Pull Request: (leave blank)
- CNB Issue: (leave blank)
- Supersedes: N/A

# Summary
[summary]: #summary

Begin versioning the various APIs that the spec describes. Then require these versions be specified in related TOML files, under an `api` field.

# Motivation
[motivation]: #motivation

To enable logic and/or validation based on `api`. For instance, we could keep users from attempting to use a combination of incompatible buildpacks and lifecycle.

# What it is
[what-it-is]: #what-it-is

There would be two pieces to this:

1. A reference to the current versions of all APIs placed somewhere in the spec (location within spec TBA). For instance, a Buildpack API and a Platform API.
2. An `api` field in TOML files for entities that are dependent on a specific version of an API. For instance, `buildpack.toml` would have an `api` to represent the version of the buildpack API to which the buildpack conforms.

# Unresolved Questions
[unresolved-questions]: #unresolved-questions

- Given the current state of the project, what would we deem to be the first "APIs?" Potentially there are two to begin with: a Buildpack API and a Platform API, but more may be warranted in the future.
- What format should the version take? Integer? Semver?
- Given the answer to the above, what version should we begin with for each API?
- What about files that are not spec'd, but rather are related to the `pack` implementation (e.g. `builder.toml`)?

0 comments on commit bffdaf4

Please sign in to comment.