Skip to content

Domain Entities and Relations

In the context of DEV-1415: Domain Model we attempted to gain a clear overview over the DSP's domain, as implicitly modelled by the ontologies, code, validations and documentation of the DSP-API.

The following document aims to give a higher level overview of said domain.

Note

  • As a high level overview, this document does not aim for exhaustivity.
  • Naming is tried to be kept as simple as possible, while trying to consolidate different naming schemes (ontologies, code, API), which in result means that no naming scheme is strictly followed.
  • The split between V2 and Admin is arbitrary as those are intertwined within the system. It merely serves the purpose of organizing the presented entities.

Domain Entities

The following Diagrams visualize the top level entities present in the DSP. The attributes of these entities should be exhaustive. Cardinalities or validation constraints are normally not depicted. The indicated relationships are of conceptual nature and are more complicated in the actual system.

Admin

erDiagram
    %% entities
    User {
        IRI id
        string userName "unique"
        string email "unique"
        string givenName
        string familyName
        string password
        string language "2 character ISO language code"
        boolean status
        boolean systemAdmin
    }
    Project {
        IRI id
        string shortcode "4 character hex"
        string shortname "xsd:NCNAME"
        string longname "optional"
        langstring description
        string keywords
        boolean status
        boolean selfjoin
        string logo "optional"
        string restrictedViewSize
        string restrictedViewWatermark
    }
    Group {
        IRI id
        string name
        langstring description
        boolean status
        boolean selfjoin
    }
    ListNode {
        IRI id
        IRI projectIri "only for root node"
        langstring labels
        langstring comments
        string name
        boolean isRootNode
        integer listNodePosition
    }
    DefaultObjectAccessPermission {
        IRI id
        string hasPermission "the 'RV, V, M, D, CR' string"
    }
    AdministrativePermission {
        IRI id
        string hasPermission "a different string representation"
    }
    Property {}
    ResourceClass {}

    %% relations
    User }|--|{ Project: "is member/admin of"
    User }o--|{ Group: "is member of"
    Group }o--|| Project: "belongs to"
    ListNode }o--|| Project: "belongs to"
    ListNode }o--o{ ListNode: "hasSubListNode"
    ListNode |o--o| ListNode: "hasRootNode"
    AdministrativePermission |{--o| Project: "points to"
    AdministrativePermission |{--|{ Group: "points to"

    DefaultObjectAccessPermission |{--o{ Group: "points to"
    DefaultObjectAccessPermission |{--|| Project: "points to"
    DefaultObjectAccessPermission |{--o{ Property: "points to"
    DefaultObjectAccessPermission |{--o{ ResourceClass: "points to"

Unclear/Unexpected Stuff

  • User.phone?
  • Institution? (name, description, website, phone, address, email)
  • Project.belongsToInstitution?

Overview V2

erDiagram
    Ontology ||--o{ ResourceClass: "consists of"
    Ontology ||--o{ Property: "consists of"
    ResourceClass o{--o{ Cardinality: defines
    Cardinality ||--|| Property: on
    ResourceClass ||--o{ Resource: "can be instantiated as"
    Property ||--o{ Value: "can be instantiated as"
    Resource ||--o{ Value: has
    Value }o--|| ObjectAccessPermission: grants
    Resource }o--|| ObjectAccessPermission: grants
    Resource }o--|| User: "attached to"
    Resource }o--|| Project: "attached to"

Ontology

erDiagram
    Project {}
    Ontology {
        IRI id
        string ontologyName
        string label
        string comment "optional"
        boolean isShared
        date lastModificationDate
    }
    ResourceClass {
        IRI id
        langstring label
        langstring comment
    }
    Property {
        IRI id
        langstring label
        langstring comment
        string guiAttribute
    }
    GuiElement {}
    Cardinality {
        owl_cardinality cardinality "1, 0-1, 0-n, 1-n"
        integer guiOrder
    }
    Ontology o{--|| Project: "attached to"
    Ontology ||--o{ ResourceClass: "consists of"
    Ontology ||--o{ Property: "consists of"
    ResourceClass }o--o{ ResourceClass: subClassOf
    ResourceClass ||--o{ Cardinality: defines
    Cardinality ||--|| Property: specifies
    Property }o--o{ Property: subPropertyOf
    Property }o--o| ResourceClass: subjectType
    Property }o--o| ResourceClass: objectType
    Property }o--|| GuiElement: has
    Cardinality ||--|| Property: specifies

Data

erDiagram
    User {}
    Project {}
    Resource {
        IRI id
        string label
        boolean isDeleted
        string hasPermission
        date creationDate
        date lastModificationDate
        date deleteDate
        string deleteComment
    }
    Value {
        IRI id
        date valueCreationDate
        string hasPermission
        integer valueHasOrder
        langstring valueHasComment
        boolean isDeleted
        date deleteDate
        langstring deleteComment
        string valueHasString
        UUID valueHasUUID
    }
    Resource ||--o{ Value: contains
    Resource o{--o{ Value: hasStandoffLinkTo
    Resource o{--|| User: attachedToUser
    Resource o{--o| User: deletedBy
    Resource o{--|| Project: attachedToProject
    Value ||--|| ValueLiteral: "is represented by"
    Value }o--o{ Resource: "links to"
    Value }o--o{ ListNode: "links to"
    Value o{--|| User: attachedToUser
    Value o{--o| User: deletedBy
    Value o|--o| Value: previousValue

Last update: 2023-04-28