Skip to content

0385 Controlled Glossary Development

Many organization that use glossary terms to drive the operation of the data landscape, need to use a controlled process to introduce and amend glossary terms, because the consequences of any change need to be carefully considered.

This model covers the extensions needed to support a controlled development process for glossary terms. Typically, the organization has its (approved) live glossary locked read-only to normal users. When updates need to be made, copies of the affected glossary terms and related elements are made and linked to their original element via the SourcedFrom relationship.

In addition, the following associations are made:

  • If the copied element is a glossary term it is also linked to the editing glossary via the TermAnchor relationship.
  • If the copied element is a glossary category it is also linked to the editing glossary via the CategoryAnchor relationship.
  • All copies of elements made to support an editing glossary will have their Anchors classification set to the editing glossary's unique identifier so if the editing glossary is deleted, all the copies are deleted too.

editing glossary

An example of an editing glossary with its glossary terms linked to the appropriate terms in the live glossary.

Once the updates are complete, they go through a review and approval process.

Once approved, the changes identified in the editing glossary are made to the terms in the live glossary. The Glossary Manager OMVS supports a simple model that updates a glossary term based on the values from another glossary term and this can be used to perform a simple merging process. Alternatively, a Governance Action Process can perform the merging process. This would run asynchronously to the end user request, which is useful if the editing glossary is large, and it can manage conflicts and organize the subsequent correction and resubmission of the changes through its stewardship support.

UML

EditingGlossary classification

The EditingGlossary classification identifies that a glossary contains copies of live glossary terms that are being updated as part of a controlled glossary development process.

The contents of the editing glossary may represent a single change, changes associated with a particular project/community or may represent a new release of the whole glossary.

StagingGlossary classification

The StagingGlossary classification identifies that a glossary contains copies of live glossary terms that are being published from a source glossary into a new glossary as part of a controlled glossary development process.

ControlledGlossaryTerm entity

The ControlledGlossaryTerm extends the standard GlossaryTerm with additional valid instance statuses for supporting a complex development lifecycle. The statuses are:

  • Draft - The term is incomplete.
  • Prepared - The term is ready for review.
  • Proposed - The term is in review.
  • Approved - The term is approved and awaiting activation.
  • Rejected - The term is rejected and should not be used.
  • Active - The term is approved and in use.
  • Deprecated - The term is out of date and should not be used.
  • Other - The term is in a locally defined state.
  • Deleted - The term has been soft-deleted and can no longer be used.

These status values can be thought of as the system-defined statuses. It is possible to replace, or extend these statuses using the userDefinedStatus attribute that can be controlled through the use of valid metadata values.

Deprecated types

The GlossaryTermEvolution relationship was introduced in release 4.0 to support editing glossaries. It has been replaced with the use of the SourcedFrom relationship.


Raise an issue or comment below