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

release-schema: update tag and publisher description for compiled releases #1712

Open
wants to merge 3 commits into
base: 1.2-dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
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
15 changes: 10 additions & 5 deletions docs/schema/merging.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@

An OCDS [record](../schema/records_reference) aggregates all the releases available for a contracting (or planning) process at a given time, and can include:

* a compiled release, which expresses the current state of the contracting (or planning) process, by showing only the most recent field values
* a versioned release, which expresses all historical states of the contracting (or planning) process, by showing all the field values over time
* a compiled release, which expresses the current state of the contracting (or planning) process, by showing only the most recent field values.
* a versioned release, which expresses all historical states of the contracting (or planning) process, by showing all the field values over time.

**Merging** is the process of combining individual releases with the same OCDS version into a compiled or versioned release, described in more detail below. At a high level:

Expand All @@ -18,7 +18,7 @@ Guidance: [Updates and deletions](../guidance/build/merging)

### Discarded fields

In the release schema, `"omitWhenMerged": true` is declared on fields that must be discarded during merging. These are presently: `id`, `date` and `tag`.
In the release schema, `"omitWhenMerged": true` is declared on fields that must be discarded during merging. These are presently: `id`, `date` `publisher` and `tag`.
odscjen marked this conversation as resolved.
Show resolved Hide resolved

* For a compiled release:
* Both the fields and their values are discarded, because they are metadata about the individual releases; the compiled release replaces these with its own metadata.
odscjen marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -28,9 +28,12 @@ In the release schema, `"omitWhenMerged": true` is declared on fields that must
If `omitWhenMerged` is set to `false`, ignore it.

```{note}
odscjen marked this conversation as resolved.
Show resolved Hide resolved
The compiled release presently uses the same schema as the release schema, which means that the `id`, `date` and `tag` fields are required in a compiled release. We invite discussion on whether to change these requirements in a separate compiled release schema in issue [#330](https://github.com/open-contracting/standard/issues/330).
The compiled release uses the same schema as the release schema, which means that the `id`, `date` and `tag` fields are required in a compiled release.

In the meantime, an intermediate solution is to set `tag` to `["compiled"]`, `date` to the maximum `date` among the individual releases used to create the compiled release, and `id` to `{ocid}-{date}`, like in the [reference implementation](#reference-implementation) of the merge routine.
These fields must be set with values that reflect the compiled release, like in the [reference implementation](#reference-implementation) of the merge routine:
* `id` should be set to `{ocid}-{date}`
* `date` should be set to the maximum `date` among the individual releases used to create the compiled release.
* `tag` should accumulate all `tag` values from the individual releases together with the tag "compiled".
```

### Versioned values
Expand Down Expand Up @@ -87,6 +90,8 @@ To create a compiled or versioned release, you must:
1. For a compiled release:
1. Set `date` to the maximum `date` among the releases.
1. Set `id` to `{ocid}-{date}`.
1. Set `tag` to include all tag values from the individual releases together with "compiled".
odscjen marked this conversation as resolved.
Show resolved Hide resolved
1. If using set `publisher` to the publisher of the compiled release.
odscjen marked this conversation as resolved.
Show resolved Hide resolved
1. Merge each release (**input**), in order, into the JSON object (**output**), as follows:

#### Object values
Expand Down
4 changes: 2 additions & 2 deletions schema/dereferenced-release-schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
},
"publisher": {
"title": "Publisher",
"description": "The original publisher of this release.",
"description": "The original publisher of the release. For a compiled release this may differ from the publisher(s) of the individual releases about the contracting process.",
"type": "object",
"properties": {
"scheme": {
Expand Down Expand Up @@ -69,7 +69,7 @@
},
"tag": {
"title": "Release Tag",
"description": "A tag labeling the release, using the the open [releaseTag](https://standard.open-contracting.org/{{version}}/{{lang}}/schema/codelists/#release-tag) codelist. Tags distinguish, for example, planning and contracting processes and the stages of contracting processes. Codes outside the releaseTag codelist might indicate, for example, the notice or form to which the release corresponds, or the event that triggered the publication of the release. Planning processes must not use the 'tender' code, even if they use `tender` fields.",
"description": "A tag labeling the release, using the the open [releaseTag](https://standard.open-contracting.org/{{version}}/{{lang}}/schema/codelists/#release-tag) codelist. Tags distinguish, for example, planning and contracting processes and the stages of contracting processes. Codes outside the releaseTag codelist might indicate, for example, the notice or form to which the release corresponds, or the event that triggered the publication of the release. Planning processes must not use the 'tender' code, even if they use `tender` fields. For a compiled release all the tags used in the individual releases for the contracting process should be included together with the 'compiled' tag.",
"type": "array",
"items": {
"type": "string"
Expand Down
4 changes: 2 additions & 2 deletions schema/release-schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,13 +27,13 @@
},
"publisher": {
"title": "Publisher",
"description": "The original publisher of this release.",
"description": "The original publisher of the release. For a compiled release this may differ from the publisher(s) of the individual releases about the contracting process.",
Copy link
Contributor

Choose a reason for hiding this comment

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

Use non-normative synonym. Add "or planning process".

Suggested change
"description": "The original publisher of the release. For a compiled release this may differ from the publisher(s) of the individual releases about the contracting process.",
"description": "The original publisher of the release. The publisher of a compiled release for a contracting or planning process might differ from the publishers of its releases.",

Copy link
Contributor Author

@odscjen odscjen Nov 7, 2024

Choose a reason for hiding this comment

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

But the schema is supposed to be normative?

Agree with the rest of the re-wording and have applied

Copy link
Contributor

Choose a reason for hiding this comment

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

I think the first sentence sets the normative semantics, and the second sentence provides some additional guidance to aid interpretation. I might be wrong, though!

"omitWhenMerged": true,
"$ref": "#/definitions/Identifier"
},
"tag": {
"title": "Release Tag",
"description": "A tag labeling the release, using the the open [releaseTag](https://standard.open-contracting.org/{{version}}/{{lang}}/schema/codelists/#release-tag) codelist. Tags distinguish, for example, planning and contracting processes and the stages of contracting processes. Codes outside the releaseTag codelist might indicate, for example, the notice or form to which the release corresponds, or the event that triggered the publication of the release. Planning processes must not use the 'tender' code, even if they use `tender` fields.",
"description": "A tag labeling the release, using the the open [releaseTag](https://standard.open-contracting.org/{{version}}/{{lang}}/schema/codelists/#release-tag) codelist. Tags distinguish, for example, planning and contracting processes and the stages of contracting processes. Codes outside the releaseTag codelist might indicate, for example, the notice or form to which the release corresponds, or the event that triggered the publication of the release. Planning processes must not use the 'tender' code, even if they use `tender` fields. For a compiled release all the tags used in the individual releases for the contracting process should be included together with the 'compiled' tag.",
odscjen marked this conversation as resolved.
Show resolved Hide resolved
"type": "array",
"items": {
"type": "string"
Expand Down