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

update type and license #133

Merged
merged 2 commits into from
Aug 9, 2021
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
14 changes: 10 additions & 4 deletions core/openapi/schemas/recordGeoJSON.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,11 @@ properties:
type:
type: string
description: |-
The nature or genre of the resource.
format: uri
The nature or genre of the resource. The value should be a code,
convenient for filtering the records. Where available, a link to
the canonical URI of the record type resource will be added to
the 'links' property.
maxLength: 64
title:
type: string
description: |-
Expand Down Expand Up @@ -123,8 +126,11 @@ properties:
license:
type: string
description: |-
A legal document under which the resource is made available.
format: uri
A legal document under which the resource is made available.
The value should be a code, convenient for filtering the records.
Where applicable, the use of the identifiers from the SPDX License List is recommended. If multiple licenses apply, it is recommended to use "various".
Where available, links to a URI of each applicable license should be added to the 'links' property.
maxLength: 64
rights:
type: string
description: |-
Expand Down
1 change: 1 addition & 0 deletions core/standard/annex_bibliography.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,4 @@
* [[DWBP]] W3C: Data on the Web Best Practices, W3C Recommendation 31 January 2017, https://www.w3.org/TR/dwbp/
* [[DCAT]] W3C: Data Catalog Vocabulary, W3C Recommendation 16 January 2014, https://www.w3.org/TR/vocab-dcat/
* [[link-relations]] IANA: Link Relation Types, https://www.iana.org/assignments/link-relations/link-relations.xml
* [[SPDX]] Linux Foundation: SPDX License List, https://spdx.org/licenses/
2 changes: 2 additions & 0 deletions core/standard/clause_7_record_api.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,8 @@ include::requirements/core/REQ_query-param-q-response.adoc[]

include::requirements/core/REQ_query-param-type-definition.adoc[]

include::recommendations/core/REC_query-param-type-definition.adoc[]

include::requirements/core/REQ_query-param-type-response.adoc[]

[[core-query-parameters-externalid]]
Expand Down
11 changes: 11 additions & 0 deletions core/standard/clause_7_record_core.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,17 @@ these properties in a record.

include::recommendations/core/REC_record-keywords-themes.adoc[]

[[sc_type_and_licenses]]
==== Type and Licenses

A record has one `properties.type` and one `properties.license` properties. The value of each property should be a code, convenient for filtering records.

include::recommendations/core/REC_record-type.adoc[]

include::recommendations/core/REC_record-license.adoc[]

In addition, links to external resources representing the record type and the licenses are recommended, as described in the next section.

[[sc_associations_and_links]]
==== Associations and Links

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[[rec_core_param-type-definition]]
[width="90%",cols="2,6a"]
|===
^|*Recommendation {counter:rec-id}* |*/rec/core/param-type-definition*
^|A |The definition of the `type` parameter SHOULD be extended to enumerate the list of known record types.
|===
8 changes: 8 additions & 0 deletions core/standard/recommendations/core/REC_record-license.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
[[rec_record-license]]
[width="90%",cols="2,6a"]
|===
^|*Recommendation {counter:rec-id}* |*/rec/core/record-license*
^|A |The list of codes that can occur in records of a catalog for the property `properties.license` SHOULD be listed as enum values in the API definition of the record schema.
^|B |The use of the https://spdx.dev/ids[identifiers] from the <<SPDX,SPDX License List>> is recommended, where applicable.
^|C |If multiple licenses apply, it is recommended to use "various" as a special value.
|===
2 changes: 2 additions & 0 deletions core/standard/recommendations/core/REC_record-links.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,6 @@
|===
^|*Recommendation {counter:rec-id}* |*/rec/core/record-links*
^|A |Implementations SHOULD use the record `links` property to provide hypermedia for navigation in the API (e.g. next record in a query response ) and alternate representations of the current record.
^|B |If a canonical URI is available for the record type that is the value of the core queryable _type_, a link with link relation type `type` to that canonical URI SHOULD be added to the `links` property.
^|C |If a canonical URI is available for a license that is a value of the core queryable _license_, a link with link relation type `license` to that canonical URI SHOULD be added to the `links` property.
|===
6 changes: 6 additions & 0 deletions core/standard/recommendations/core/REC_record-type.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[[rec_record-type]]
[width="90%",cols="2,6a"]
|===
^|*Recommendation {counter:rec-id}* |*/rec/core/record-type*
^|A |The list of codes that can occur in records of a catalog for the property `properties.type` SHOULD be listed as enum values in the API definition of the record schema.
|===
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
|===
^|*Requirement {counter:req-id}* |*/req/core/param-type-definition*
^|A |A Records API SHALL support the search by Type (type) parameter for the operation.
^|A |The `type` parameter SHALL have the following characteristics (using an OpenAPI Specification 3.0 fragment):
^|B |The `type` parameter SHALL have the following characteristics (using an OpenAPI Specification 3.0 fragment):

[source,YAML]
----
Expand All @@ -14,6 +14,7 @@ schema:
type: array
items:
type: string
maxLength: 64
explode: false
----
|===