Contributions to the TDF specification are welcome! Please be sure to follow these guidelines when proposing changes or submitting feedback.
- Pull Requests(PRs) proposing changes should be made in branches prefixed with
draft-<change>
- If the changes proposed to the spec would result in a Major or Minor semver version bump (see versioning guidelines) to the spec, the spec change MUST LINK TO A REFERENCE IMPLEMENTATION OF THE CHANGES in a publicly-visible Git repository.
- It is suggested that the PR include a link to one or more reference implementation PRs in the OpenTDF project's reference implementation
Proposed changes must specify what kind of semver change they would cause - (see guidelines).
- Major version changes must include a detailed writeup motivating the change and its impact. These PRs must be left open for review for at least 7 days.
- Minor version changes must include a brief writeup motivating the change and its impact. These PRs must be left open for review for at least 3 days.
- Patch version changes must include a brief writeup motivating the change and its impact. These PRs must be left open for review for at least 3 days.
We follow the semver guidelines on version changes, although reviewers may exercise their discretion on individual PRs.
- Major version revs when a backwards-incompatible change is made that would break clients. (Example: new required manifest fields or new required API call, or client code changes required)
- Minor version revs when backwards-compatible functionality is added that would not break clients. (Example: new optional API parameter.)
- Patch version revs when a change does not affect functionality but could affect how readers interpret the spec. (Example: Substantive new diagram illustrating a previously poorly-documented protocol interaction.)
- Cosmetic changes should not affect the version number. (Example: Fixing typos, reformatting docs.)
The spec version is this repo's most recent semver Git tag - this means that if the spec version is 4.1.0, then the protocol version and all associated schema versions are also 4.1.0
Any changes that affect project version must update both git tag
and the VERSION file.
Rather than use a CHANGELOG file, we ask that you use annotated git tags
when bumping the spec Semver, and use the annotation message to describe the change.
Example:
git tag -s 4.1.0 -m "Spec version 4.1.0 - twiddled a doohickey"
)
Please use the raw semver when tagging - no v4.1.0
, just 4.1.0
A list of git tag
versions and their annotations can be generated at will via git tag -n
To create a CHANGELOG file, run the following command
git tag -n --sort=-v:refname > CHANGELOG
Please use GitHub issues to ask questions, submit suggestions, or otherwise provide feedback. Thank you!