Deprecating NMDC schema elements
By deprecating, rather than deleting, schema elements in the NMDC model, we ensure backward compatibility, extend user trust, and provide a valuable historical record, aiding in the understanding of the model's evolution. Therefore, 'deleting' a schema element in NMDC is instead, a two-step (and two-release) deprecation process.
First release cycle:
- Add deprecation annotations to the element's definition
| Annotation | Value | 
|---|---|
| One of: deprecated_element_has_exact_replacement OR deprecated_element_has_possible_replacement * | uriorcurie value required | 
| deprecated | A string explaining the reason for deprecation along with a link to the corresponding issue. | 
| last_updated_on | |
| modified_by | With an ORCID value | 
| Deprecation Date | Conforms to iso8601/international dates (e.g., # doi_awards deprecated on 2023-11-12in a class's usage). | 
* note: If a replacement is not warranted, then using only the deprecated metadata tag with an explanation 
string and issue link is fine.
Second release cycle:
- Move the deprecated element to the "deprecated.yaml" schema file. We do this so that the deprecated elements can still be found in the documentation and via reference from stable unique identifiers (w3ids), but do not appear in the main schema file nor participate in the validation of data.
- Remove the element itself from the original schema YAML file (e.g. core.yaml, annotation.yaml, etc.).
- Remove any references to the deprecated element from the original schema YAML file. **
** note: For a deprecated class, references could be in the is_a or mixin elements of another class, 
or in the domain or range elements of an existing slot. For deprecated slots, check all classes that reference that slot, etc.