Introduction
The OSDU (Open Subsurface Data Universe) Data platform, contains a set of standardized data definitions and Object types with properties and relationsips, that is used when ingesting data into or extracting data from the platform. The core functionality of this module, consists of the ability to import and export Json files according to these definitions. JSON is a lightweight data interchange format, and has become a popular standard format for exchanging data between applications. Even if JSON is human readable, it is not easy to see and identify the relationships between the data (Json-files). This AKM module provides a way to import and export OSDU Json files from/to AKM models.
The AKM model presents the complex Json-file structure and relatioships between the ObjectTypes in a user firendly graphical and a more understandable and concise way.
This makes it easy to edit and expand the Metamodels to embrace new product categories. The Object types are enhanced and expanded by adding new properties and relationships. The new enhanced models can then be exported as Json-files for import into the OSDU Data platform.
Table of contents:
- Extensions of the IRTV-Metamodel
- Importing the OSDU Metamodel types
- Importing a OSDU Json-file to an AKM Model type
- Importing the OSDU Json-file as a Json structure model
Extensions of the IRTV Metamodel
The AKM extensions of the Osdu-Metamodel are built on the AKM IRTV-Metamodel (see separate description in th Help documentation). These extensions will enable the capabilities of the IRTV-Metamodel to include specific Json objects and attributes, that represent the structure of Json-file object structure.
The EntityType Objecttype is extended to include some osdu and json-file specific properties.
-name
-osduId
-jsonType
-osduType
-jsonKey
The EntityType Property is extended to include OSDU and Json-file specific properties.
-title
-pattern
-example
This model is a Type Definition Model that defines the types, structure and content of the OSDU Json-file.
As shown in the figure above, the -name, -osduId, -title, -pattern and example properties can be of a long text, and therefore defined as Datatype textarea
The -jsonType and -osduType are defined as enum Datatypes, and connected to Value objects with hasAllowed and isDefault relationships.
Two new EntityTypes are added:
JsonObject and JsonArray are used to represent objects and arrays in a Json-file. The relationships hasMember is used to represent members of Json-file arrays. The relationships hasPart is used to represent the structure of the Json-file object tree.
To generate a metamodel from this model, right-click on the background and choose Generate Metamodel command. A dialog-box will appear asking "Do you want to include system types". Click Ok to include system types. A new dialog-box will appear where you can select which metamodel you want to generate.
(Note: A metamodel has to exist before you can generate a metamodel from a concept model. On the background menu choose New Metamodel to create a new metamodel.)
Importing the OSDU Metamodel types
Now the OSDU Metamodel is ready to be used to create a new OSDU Type Definition Model (_TDM).: On the background menu select the Create New Model to create a new _TDM model. You will then be asked which Metamodel to use so select the appropriate Metamodel.
Open the new model, and on the left side you see the palette with the generated metamodel types.
Select the MM tab on the left side and you will see the OSDU metmodel with both the IRTV and OSDU metamodel object and relationship types. This is the available types that can be used to model new consept models.
Import (Open) an OSDU Start-up Model (Json-file)
Click on the Model file button (blue button) to open the Import dialog and then Click on the Choose file button to select a file to import.
Then click Done button
Importing an OSDU Json-file to an AKM Model type
Then click the OSDU Json file (1) button to open the Import dialog and then click on the Choose file (2) button in the blue area to select an OSDU JSON file to import. Then click the Done (3) button.
Click on the modelview tab Main (1) or refresh (2) (upper right) to refresh the model. Then click on the Objects (3) tab to see the imported objects. Find and drag the top level object (i.e. Wellbore) (4) to the modelview (5).
Then right-click the object and choose Add Connected Objects to add the child objects. Type in the number of levels to add in the dialog-box.
The imported EntityType with properties is added to the modelview.
If you want to add more objects, you can now add them to the modelview.
Importing the OSDU Json-file as a Json structure model
Then click the Choose file button in the green OSDU Json file structure to open the Import dialog and then Click on the Choos file button to select an OSDU JSON file to import. Then click the Done button.
Find and drag the top level object (i.e. Wellbore.1.0.0.json) into the Modelling area.
Then right-click the object and choose Add Connected Objects to add the child objects. Type in the number of levels to add in the dialog-box.
The imported EntityType with properties is added to the modelview.