Versioning: Generic

Uit COINS2
Versie door Renzo van Rijswijk (Overleg | bijdragen) op 29 jun 2016 om 21:20

(wijz) ← Oudere versie | Huidige versie (wijz) | Nieuwere versie → (wijz)
Ga naar: navigatie, zoeken

This page describes data versioning according to COINS

Version levels

Version levels
Versionmanagement can be definend on two different levels:
  • Application level,
  • Information level.

At application level each software system (like CAD, GIS, Planning, etc.) has its own way of managing changes in the data. This makes it very difficult to exchange this information to other systems. In Coins we need an open and transparant way of versioning that is not dependent of such a software system. Therefore the versioning in Coins is managed on Information level.

Coins distinguishes 2 version types, external and internal versions.

  • External versions are used when the information is exchanged between client and contractor. These versions are mandatory within Coins.
  • Internal versions are used within the internal processes of a party. These versions are optional within Coins

Changes within the application are not a part of Coins.

Versioning

Versioning

Versioning can be schematised by the following image. A number of things can be distinguished:

  • All squares are versions of an information item.
  • the green squares are the external versions. They specify the Trunk of this version principle. Therefore they are called TrunkVersions.
  • the yellow squares are the internal versions. They are called BranchVersions. They make it possible to follow the changes within the internal processes of a party.
  • a purple squares means this VersionObject is expired but this object has no successor.
  • the current version is number 9.

Within the Coins core model the TrunkVersioning principle is defined. A reference framework is developed for adding the BranchVersioning functionalities (internal versions).

Between these TrunkVersionObjects there is a relation defined called the nextTrunkVersion (the green arrow from object 1 to 4 and from 4 to 9). When an object gets a nextTrunkVersion it must be classified as an ExpiredEntity, also. In this way, Coins is able to capture all the changes and makes it possible to return to a certain situation. In this way you can follow the changes back to its origin.

See also

Reference Framework for BranchVersioning