TEIV: Fix ordering of items in responses 14/14314/1
authorJvD_Ericsson <jeff.van.dam@est.tech>
Thu, 10 Apr 2025 09:14:10 +0000 (10:14 +0100)
committerJeff van Dam <jeff.van.dam@est.tech>
Thu, 10 Apr 2025 10:49:25 +0000 (10:49 +0000)
- Added specific yang modles for testing,
  and updated tests and sql schemas to show this

Issue-ID: SMO-186
Issue-ID: SMO-185
Change-Id: I651a548e00ab79508de344e73091fcea6a52b8e4
Signed-off-by: JvD_Ericsson <jeff.van.dam@est.tech>
120 files changed:
teiv/src/main/java/org/oran/smo/teiv/CachedBodyHttpServletRequest.java [moved from teiv/src/main/java/org/oran/smo/teiv/groups/utils/CachedBodyHttpServletRequest.java with 52% similarity]
teiv/src/main/java/org/oran/smo/teiv/CachedBodyServletInputStream.java [moved from teiv/src/main/java/org/oran/smo/teiv/groups/utils/CachedBodyServletInputStream.java with 98% similarity]
teiv/src/main/java/org/oran/smo/teiv/RequestFilter.java [new file with mode: 0644]
teiv/src/main/java/org/oran/smo/teiv/exception/YangParsingException.java
teiv/src/main/java/org/oran/smo/teiv/exposure/OranTeivErrorJsonMessage.java [moved from teiv/src/main/java/org/oran/smo/teiv/listener/audit/IngestionAuditInfo.java with 52% similarity]
teiv/src/main/java/org/oran/smo/teiv/exposure/classifiers/rest/controller/ClassifiersRequestFilter.java [new file with mode: 0644]
teiv/src/main/java/org/oran/smo/teiv/exposure/classifiers/rest/controller/ClassifiersRestController.java
teiv/src/main/java/org/oran/smo/teiv/exposure/decorators/rest/controller/DecoratorsRequestFilter.java [new file with mode: 0644]
teiv/src/main/java/org/oran/smo/teiv/exposure/decorators/rest/controller/DecoratorsRestController.java
teiv/src/main/java/org/oran/smo/teiv/exposure/exception/ApplicationExceptionHandler.java
teiv/src/main/java/org/oran/smo/teiv/exposure/spi/DataRepository.java
teiv/src/main/java/org/oran/smo/teiv/exposure/spi/impl/DataRepositoryImpl.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/AndOrLogicalBlock.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/EmptyLogicalBlock.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/InnerFilterCriteria.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/LogicalBlock.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/ScopeLogicalBlock.java
teiv/src/main/java/org/oran/smo/teiv/exposure/teivpath/refiner/PathToJooqRefinement.java
teiv/src/main/java/org/oran/smo/teiv/groups/rest/controller/GroupCreationRequestFilter.java [moved from teiv/src/main/java/org/oran/smo/teiv/groups/utils/GroupCreationRequestFilter.java with 86% similarity]
teiv/src/main/java/org/oran/smo/teiv/groups/rest/controller/GroupsController.java
teiv/src/main/java/org/oran/smo/teiv/groups/spi/impl/GroupsRepositoryImpl.java
teiv/src/main/java/org/oran/smo/teiv/listener/CreateTopologyProcessor.java
teiv/src/main/java/org/oran/smo/teiv/listener/DeleteTopologyProcessor.java
teiv/src/main/java/org/oran/smo/teiv/listener/MergeTopologyProcessor.java
teiv/src/main/java/org/oran/smo/teiv/listener/SourceEntityDeleteTopologyProcessor.java
teiv/src/main/java/org/oran/smo/teiv/listener/audit/IngestionAuditLogger.java
teiv/src/main/java/org/oran/smo/teiv/schema/SchemaRegistry.java
teiv/src/main/java/org/oran/smo/teiv/schema/SchemaRegistryErrorCode.java
teiv/src/main/java/org/oran/smo/teiv/service/TeivDbOperations.java
teiv/src/main/java/org/oran/smo/teiv/service/kafka/KafkaTopicService.java
teiv/src/main/java/org/oran/smo/teiv/service/models/OperationResult.java
teiv/src/main/java/org/oran/smo/teiv/startup/AppInit.java
teiv/src/main/java/org/oran/smo/teiv/utils/OperationResultParser.java [new file with mode: 0644]
teiv/src/main/java/org/oran/smo/teiv/utils/ResponseUtil.java [new file with mode: 0644]
teiv/src/main/java/org/oran/smo/teiv/utils/YangParser.java
teiv/src/main/java/org/oran/smo/teiv/utils/yangparser/ExposureYangParser.java
teiv/src/main/java/org/oran/smo/teiv/utils/yangparser/IngestionYangParser.java
teiv/src/main/java/org/oran/smo/teiv/utils/yangparser/YangModelLoader.java
teiv/src/main/resources/v1/topology-exposure-inventory-kafka-asyncapi.yaml
teiv/src/test/java/org/oran/smo/teiv/db/TestPostgresqlContainer.java
teiv/src/test/java/org/oran/smo/teiv/exposure/api/contract/TopologyExposureApiBase.java
teiv/src/test/java/org/oran/smo/teiv/exposure/spi/impl/DataRepositoryImplGETRequestsContainerizedTest.java
teiv/src/test/java/org/oran/smo/teiv/exposure/teivpath/innerlanguage/DtoToJooqTest.java
teiv/src/test/java/org/oran/smo/teiv/exposure/teivpath/refiner/BasePathRefinementTest.java
teiv/src/test/java/org/oran/smo/teiv/groups/TopologyGroupsApiBase.java
teiv/src/test/java/org/oran/smo/teiv/ingestion/validation/IngestionOperationValidatorTest.java
teiv/src/test/java/org/oran/smo/teiv/listener/CreateTopologyProcessorTest.java
teiv/src/test/java/org/oran/smo/teiv/listener/DeleteTopologyProcessorTest.java
teiv/src/test/java/org/oran/smo/teiv/listener/MergeTopologyProcessorTest.java
teiv/src/test/java/org/oran/smo/teiv/listener/SourceEntityDeleteTopologyProcessorTest.java
teiv/src/test/java/org/oran/smo/teiv/schema/SchemaRegistryTest.java
teiv/src/test/java/org/oran/smo/teiv/service/EndToEndDbTest.java
teiv/src/test/java/org/oran/smo/teiv/service/TeivDbOperationResultsTest.java
teiv/src/test/java/org/oran/smo/teiv/utils/CloudEventTestUtil.java
teiv/src/test/java/org/oran/smo/teiv/utils/EndToEndTestUtil.java
teiv/src/test/java/org/oran/smo/teiv/utils/ExposureYangParserTest.java
teiv/src/test/java/org/oran/smo/teiv/utils/IngestionYangParserTest.java
teiv/src/test/java/org/oran/smo/teiv/utils/YangModelValidationTestUtil.java [new file with mode: 0644]
teiv/src/test/resources/cloudeventdata/common/ce-invalid-entity-attribute.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-inferred.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-many-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-one-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-one-to-many3.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-one-to-one.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-relationship-connecting-same-entity.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-create-second-case.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-delete-one-to-one.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-delete-relationship-connecting-same-entity.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-merge-long-names.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-merge-many-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-merge-one-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/ce-merge-one-to-many2.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-create-inferred.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-create-many-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-create-one-to-one.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-create-second-case.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-delete-one-to-one.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-merge-many-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/exp-merge-one-to-many.json
teiv/src/test/resources/cloudeventdata/end-to-end/expected-results/not-exp-delete-one-to-one.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one2.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one3.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one4.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one5.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one6.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one7.json
teiv/src/test/resources/cloudeventdata/validation/one-to-one/ce-create-one-to-one8.json
teiv/src/test/resources/contracts/exposure/classifiers/01_getClassifiers_getRelationshipsByType.groovy
teiv/src/test/resources/contracts/exposure/classifiers/04_postClassifiers_delete.groovy
teiv/src/test/resources/contracts/exposure/data/00_getAllDomains.groovy
teiv/src/test/resources/contracts/exposure/data/01_getTopologyEntityTypes.groovy
teiv/src/test/resources/contracts/exposure/data/02_getTopologyByEntityTypeName.groovy
teiv/src/test/resources/contracts/exposure/data/03_getTopologyById.groovy
teiv/src/test/resources/contracts/exposure/data/04_getAllRelationshipsForEntityId.groovy
teiv/src/test/resources/contracts/exposure/data/05_getRelationshipTypes.groovy
teiv/src/test/resources/contracts/exposure/data/06_getRelationshipsByType.groovy
teiv/src/test/resources/contracts/exposure/data/07_getRelationshipById.groovy
teiv/src/test/resources/contracts/exposure/data/08_getEntitiesByDomain.groovy
teiv/src/test/resources/contracts/exposure/decorators/04_postDecoratorsDelete.groovy
teiv/src/test/resources/contracts/exposure/schemas/00_getAllSchemas.groovy
teiv/src/test/resources/contracts/exposure/schemas/01_getSchemaContent.groovy
teiv/src/test/resources/contracts/exposure/schemas/02_postSchemas.groovy
teiv/src/test/resources/contracts/exposure/schemas/03_deleteSchemas.groovy
teiv/src/test/resources/contracts/groups/00_createGroup.groovy
teiv/src/test/resources/contracts/groups/01_getGroups.groovy
teiv/src/test/resources/contracts/groups/02_getGroupById.groovy
teiv/src/test/resources/contracts/groups/03_deleteGroup.groovy
teiv/src/test/resources/contracts/groups/04_putGroup.groovy
teiv/src/test/resources/contracts/groups/05_getMembers.groovy
teiv/src/test/resources/contracts/groups/06_getProvidedMembers.groovy
teiv/src/test/resources/contracts/groups/07_updateProvidedMembers.groovy
teiv/src/test/resources/pgsqlschema/end-to-end-test-data.sql [new file with mode: 0644]
teiv/src/test/resources/pgsqlschema/end-to-end-test-model.sql [new file with mode: 0644]
teiv/src/test/resources/pgsqlschema/ingestion-test-data.sql
teiv/src/test/resources/yang/models/o-ran-smo-teiv-equipment-test.yang [new file with mode: 0644]
teiv/src/test/resources/yang/models/o-ran-smo-teiv-oam-test.yang [new file with mode: 0644]
teiv/src/test/resources/yang/models/o-ran-smo-teiv-ran-test.yang [new file with mode: 0644]
teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-equipment-ran-test.yang [new file with mode: 0644]
teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-oam-ran-test.yang [new file with mode: 0644]

@@ -1,7 +1,6 @@
 /*
  *  ============LICENSE_START=======================================================
- *  Copyright (C) 2024 Ericsson
- *  Modifications Copyright (C) 2024-2025 OpenInfra Foundation Europe
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
  *  ================================================================================
  *  Licensed under the Apache License, Version 2.0 (the "License");
  *  you may not use this file except in compliance with the License.
  *  SPDX-License-Identifier: Apache-2.0
  *  ============LICENSE_END=========================================================
  */
-package org.oran.smo.teiv.groups.utils;
+
+package org.oran.smo.teiv;
+
+import jakarta.servlet.ServletInputStream;
+import jakarta.servlet.http.HttpServletRequest;
+import jakarta.servlet.http.HttpServletRequestWrapper;
 
 import java.io.BufferedReader;
 import java.io.ByteArrayInputStream;
 import java.io.IOException;
-import java.io.InputStream;
 import java.io.InputStreamReader;
 import java.nio.charset.StandardCharsets;
 
-import org.springframework.util.StreamUtils;
-
-import jakarta.servlet.ServletInputStream;
-import jakarta.servlet.http.HttpServletRequest;
-import jakarta.servlet.http.HttpServletRequestWrapper;
-
 public class CachedBodyHttpServletRequest extends HttpServletRequestWrapper {
+    private final byte[] requestBody;
 
-    private final byte[] cachedBody;
-
-    public CachedBodyHttpServletRequest(HttpServletRequest request) throws IOException {
+    public CachedBodyHttpServletRequest(final HttpServletRequest request) throws IOException {
         super(request);
-        InputStream requestInputStream = request.getInputStream();
-        this.cachedBody = StreamUtils.copyToByteArray(requestInputStream);
+        this.requestBody = readRequestBody(request);
     }
 
     @Override
-    public ServletInputStream getInputStream() throws IOException {
-        return new CachedBodyServletInputStream(this.cachedBody);
+    public ServletInputStream getInputStream() {
+        return new CachedBodyServletInputStream(this.requestBody);
     }
 
     @Override
-    public BufferedReader getReader() throws IOException {
-        ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(this.cachedBody);
-        return new BufferedReader(new InputStreamReader(byteArrayInputStream, StandardCharsets.UTF_8));
+    public BufferedReader getReader() {
+        return new BufferedReader(new InputStreamReader(new ByteArrayInputStream(requestBody), StandardCharsets.UTF_8));
+    }
+
+    public String getRequestBody() {
+        return new String(requestBody, StandardCharsets.UTF_8);
+    }
+
+    private byte[] readRequestBody(final HttpServletRequest request) throws IOException {
+        StringBuilder body = new StringBuilder();
+        char[] buffer = new char[1024];
+        try (BufferedReader reader = new BufferedReader(new InputStreamReader(request.getInputStream(),
+                StandardCharsets.UTF_8))) {
+            int bytesRead;
+            while ((bytesRead = reader.read(buffer)) != -1) {
+                body.append(buffer, 0, bytesRead);
+            }
+        }
+        return body.toString().getBytes(StandardCharsets.UTF_8);
     }
 }
@@ -18,7 +18,7 @@
  *  SPDX-License-Identifier: Apache-2.0
  *  ============LICENSE_END=========================================================
  */
-package org.oran.smo.teiv.groups.utils;
+package org.oran.smo.teiv;
 
 import java.io.ByteArrayInputStream;
 import java.io.IOException;
diff --git a/teiv/src/main/java/org/oran/smo/teiv/RequestFilter.java b/teiv/src/main/java/org/oran/smo/teiv/RequestFilter.java
new file mode 100644 (file)
index 0000000..01f51ea
--- /dev/null
@@ -0,0 +1,58 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv;
+
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.exc.ValueInstantiationException;
+import jakarta.servlet.Filter;
+import jakarta.servlet.ServletResponse;
+import jakarta.servlet.http.HttpServletResponse;
+import org.oran.smo.teiv.exposure.OranTeivErrorJsonMessage;
+import org.springframework.http.HttpStatus;
+
+import java.io.IOException;
+import java.util.List;
+
+public abstract class RequestFilter implements Filter {
+    protected void writeError(final ServletResponse servletResponse, final JsonProcessingException exception,
+            final String message) throws IOException {
+        HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
+        httpResponse.setStatus(HttpServletResponse.SC_BAD_REQUEST);
+        httpResponse.setContentType("application/problem+json");
+        final OranTeivErrorJsonMessage errorMessage = OranTeivErrorJsonMessage.extendedBuilder().status(
+                HttpStatus.BAD_REQUEST.name()).message(message).details(getErrorDetails(exception)).build();
+        httpResponse.getWriter().write(errorMessage.toJson());
+        httpResponse.getWriter().flush();
+    }
+
+    private String getErrorDetails(JsonProcessingException exception) {
+        String details;
+        if (exception instanceof ValueInstantiationException e && exception
+                .getCause()instanceof IllegalArgumentException cause) {
+            final Class<?> targetType = e.getType().getRawClass();
+            details = cause.getMessage() + ". Invalid value for " + targetType.getSimpleName() + ", allowed values: " + List
+                    .of(targetType.getEnumConstants());
+        } else {
+            details = exception.getOriginalMessage();
+        }
+        return details;
+    }
+}
index 9ea5529..1f63c95 100644 (file)
@@ -21,6 +21,9 @@
 package org.oran.smo.teiv.exception;
 
 public class YangParsingException extends YangException {
+    private YangParsingException(final String message) {
+        super(message);
+    }
 
     public YangParsingException(final String message, final Throwable cause) {
         super(message, cause);
@@ -29,4 +32,8 @@ public class YangParsingException extends YangException {
     public static YangParsingException failedIOExecution(Exception e) {
         return new YangParsingException("Failed to execute IO operation", e);
     }
+
+    public static YangParsingException modelDirectoryDoesNotExists() {
+        return new YangParsingException("Model directory does not exist");
+    }
 }
@@ -1,7 +1,6 @@
 /*
  *  ============LICENSE_START=======================================================
- *  Copyright (C) 2024 Ericsson
- *  Modifications Copyright (C) 2024 OpenInfra Foundation Europe
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
  *  ================================================================================
  *  Licensed under the Apache License, Version 2.0 (the "License");
  *  you may not use this file except in compliance with the License.
  *  SPDX-License-Identifier: Apache-2.0
  *  ============LICENSE_END=========================================================
  */
-package org.oran.smo.teiv.listener.audit;
 
-import static org.oran.smo.teiv.listener.audit.ExecutionStatus.SUCCESS;
-
-import org.apache.commons.lang3.StringUtils;
+package org.oran.smo.teiv.exposure;
 
 import lombok.Builder;
+import org.oran.smo.teiv.api.model.OranTeivErrorMessage;
 
-@Builder
-public class IngestionAuditInfo {
-    private final ExecutionStatus status;
-    private final String operation;
-    private final String messageKey;
-    private final String cloudEvent;
-    private final String exceptionMessage;
-
-    @Override
-    public String toString() {
-        String baseMessage = String.format("%s - %s topology. Message key: %s, CloudEvent: %s", status, StringUtils
-                .capitalize(operation), messageKey, cloudEvent);
+public class OranTeivErrorJsonMessage extends OranTeivErrorMessage {
+    @Builder(builderMethodName = "extendedBuilder")
+    public OranTeivErrorJsonMessage(String status, final String message, final String details) {
+        super(status, message, details);
+    }
 
-        return status.equals(SUCCESS) ? baseMessage : (baseMessage + ", " + exceptionMessage);
+    public String toJson() {
+        return "{" + "\"status\": \"" + this.getStatus() + "\"," + "\"message\": \"" + this
+                .getMessage() + "\"," + "\"details\": \"" + this.getDetails() + "\"}";
     }
 }
diff --git a/teiv/src/main/java/org/oran/smo/teiv/exposure/classifiers/rest/controller/ClassifiersRequestFilter.java b/teiv/src/main/java/org/oran/smo/teiv/exposure/classifiers/rest/controller/ClassifiersRequestFilter.java
new file mode 100644 (file)
index 0000000..9137abc
--- /dev/null
@@ -0,0 +1,72 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv.exposure.classifiers.rest.controller;
+
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import jakarta.servlet.FilterChain;
+import jakarta.servlet.ServletException;
+import jakarta.servlet.ServletRequest;
+import jakarta.servlet.ServletResponse;
+import jakarta.servlet.http.HttpServletRequest;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.oran.smo.teiv.CustomMetrics;
+import org.oran.smo.teiv.RequestFilter;
+import org.oran.smo.teiv.api.model.OranTeivClassifier;
+import org.oran.smo.teiv.exposure.audit.LoggerHandler;
+import org.oran.smo.teiv.CachedBodyHttpServletRequest;
+import org.springframework.context.annotation.Profile;
+
+import java.io.IOException;
+
+@Slf4j
+@Profile("exposure")
+@RequiredArgsConstructor
+public class ClassifiersRequestFilter extends RequestFilter {
+    private final LoggerHandler loggerHandler;
+    private final ObjectMapper objectMapper;
+    private final CustomMetrics customMetrics;
+
+    @Override
+    public void doFilter(final ServletRequest servletRequest, final ServletResponse servletResponse,
+            final FilterChain filterChain) throws IOException, ServletException {
+        if (servletRequest instanceof HttpServletRequest request) {
+            CachedBodyHttpServletRequest cachedBodyHttpServletRequest = new CachedBodyHttpServletRequest(request);
+            if (cachedBodyHttpServletRequest.getMethod().equalsIgnoreCase("POST")) {
+                final String payload = cachedBodyHttpServletRequest.getRequestBody();
+                try {
+                    objectMapper.readValue(payload, OranTeivClassifier.class);
+                    filterChain.doFilter(cachedBodyHttpServletRequest, servletResponse);
+                } catch (final JsonProcessingException exception) {
+                    customMetrics.incrementNumUnsuccessfullyUpdatedClassifiers();
+                    final String logMsg = String.format(
+                            "Failed to process the request to merge/remove classifiers. Exception= %s , Payload= %s",
+                            exception.getMessage(), payload);
+                    loggerHandler.logAudit(log, logMsg, cachedBodyHttpServletRequest);
+                    writeError(servletResponse, exception, "Failed to process the request to merge/remove classifiers");
+                }
+            }
+        } else {
+            filterChain.doFilter(servletRequest, servletResponse);
+        }
+    }
+}
index edc7484..a4a7d59 100644 (file)
@@ -25,6 +25,7 @@ import java.util.Optional;
 import java.util.function.Consumer;
 import java.util.function.Supplier;
 
+import com.fasterxml.jackson.databind.ObjectMapper;
 import io.micrometer.core.annotation.Timed;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -39,12 +40,17 @@ import org.oran.smo.teiv.exposure.audit.LoggerHandler;
 import org.oran.smo.teiv.exposure.classifiers.api.ClassifiersService;
 import org.oran.smo.teiv.utils.TeivConstants;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.boot.web.servlet.FilterRegistrationBean;
+import org.springframework.context.annotation.Bean;
 import org.springframework.context.annotation.Profile;
+import org.springframework.core.Ordered;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
+import static org.oran.smo.teiv.utils.TeivConstants.REQUEST_MAPPING;
+
 @Slf4j
 @RestController
 @RequestMapping(TeivConstants.REQUEST_MAPPING)
@@ -97,4 +103,13 @@ public class ClassifiersRestController implements ClassifiersApi {
             throw ex;
         }
     }
+
+    @Bean
+    public FilterRegistrationBean<ClassifiersRequestFilter> classifiersRequestFilter(final ObjectMapper objectMapper) {
+        FilterRegistrationBean<ClassifiersRequestFilter> registrationBean = new FilterRegistrationBean<>();
+        registrationBean.setFilter(new ClassifiersRequestFilter(loggerHandler, objectMapper, customMetrics));
+        registrationBean.addUrlPatterns(REQUEST_MAPPING + "/classifiers");
+        registrationBean.setOrder(Ordered.HIGHEST_PRECEDENCE);
+        return registrationBean;
+    }
 }
diff --git a/teiv/src/main/java/org/oran/smo/teiv/exposure/decorators/rest/controller/DecoratorsRequestFilter.java b/teiv/src/main/java/org/oran/smo/teiv/exposure/decorators/rest/controller/DecoratorsRequestFilter.java
new file mode 100644 (file)
index 0000000..a75aa7f
--- /dev/null
@@ -0,0 +1,73 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv.exposure.decorators.rest.controller;
+
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import jakarta.servlet.FilterChain;
+import jakarta.servlet.ServletException;
+import jakarta.servlet.ServletRequest;
+import jakarta.servlet.ServletResponse;
+import jakarta.servlet.http.HttpServletRequest;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.oran.smo.teiv.CachedBodyHttpServletRequest;
+import org.oran.smo.teiv.CustomMetrics;
+import org.oran.smo.teiv.RequestFilter;
+import org.oran.smo.teiv.api.model.OranTeivDecorator;
+import org.oran.smo.teiv.exposure.audit.LoggerHandler;
+import org.springframework.context.annotation.Profile;
+
+import java.io.IOException;
+
+@Slf4j
+@Profile("exposure")
+@RequiredArgsConstructor
+public class DecoratorsRequestFilter extends RequestFilter {
+    private final LoggerHandler loggerHandler;
+    private final ObjectMapper objectMapper;
+    private final CustomMetrics customMetrics;
+
+    @Override
+    public void doFilter(final ServletRequest servletRequest, final ServletResponse servletResponse,
+            final FilterChain filterChain) throws IOException, ServletException {
+        if (servletRequest instanceof HttpServletRequest request) {
+            CachedBodyHttpServletRequest cachedBodyHttpServletRequest = new CachedBodyHttpServletRequest(request);
+            if (cachedBodyHttpServletRequest.getMethod().equalsIgnoreCase("POST")) {
+                final String payload = cachedBodyHttpServletRequest.getRequestBody();
+                try {
+                    objectMapper.readValue(payload, OranTeivDecorator.class);
+                    filterChain.doFilter(cachedBodyHttpServletRequest, servletResponse);
+                } catch (final JsonProcessingException exception) {
+                    customMetrics.incrementNumUnsuccessfullyUpdatedDecorators();
+                    final String logMsg = String.format(
+                            "Failed to process the request to merge/remove decorators. Exception= %s , Payload= %s",
+                            exception.getMessage(), payload);
+                    loggerHandler.logAudit(log, logMsg, cachedBodyHttpServletRequest);
+                    writeError(servletResponse, exception, "Failed to process the request to merge/remove decorators");
+                }
+            }
+        } else {
+            filterChain.doFilter(servletRequest, servletResponse);
+        }
+    }
+
+}
index 9a460f4..53b3575 100644 (file)
@@ -24,6 +24,8 @@ import java.util.Collections;
 import java.util.Optional;
 import java.util.function.Consumer;
 import java.util.function.Supplier;
+
+import com.fasterxml.jackson.databind.ObjectMapper;
 import jakarta.servlet.http.HttpServletRequest;
 
 import io.micrometer.core.annotation.Timed;
@@ -37,17 +39,21 @@ import org.oran.smo.teiv.exception.TeivException;
 import org.oran.smo.teiv.exposure.audit.AuditMapper;
 import org.oran.smo.teiv.exposure.audit.LoggerHandler;
 import org.oran.smo.teiv.exposure.decorators.api.DecoratorsService;
-import org.oran.smo.teiv.utils.TeivConstants;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.boot.web.servlet.FilterRegistrationBean;
+import org.springframework.context.annotation.Bean;
 import org.springframework.context.annotation.Profile;
+import org.springframework.core.Ordered;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
+import static org.oran.smo.teiv.utils.TeivConstants.REQUEST_MAPPING;
+
 @Slf4j
 @RestController
-@RequestMapping(TeivConstants.REQUEST_MAPPING)
+@RequestMapping(REQUEST_MAPPING)
 @RequiredArgsConstructor
 @Profile("exposure")
 public class DecoratorsRestController implements DecoratorsApi {
@@ -97,4 +103,13 @@ public class DecoratorsRestController implements DecoratorsApi {
             throw ex;
         }
     }
+
+    @Bean
+    public FilterRegistrationBean<DecoratorsRequestFilter> decoratorsRequestFilter(final ObjectMapper objectMapper) {
+        FilterRegistrationBean<DecoratorsRequestFilter> registrationBean = new FilterRegistrationBean<>();
+        registrationBean.setFilter(new DecoratorsRequestFilter(loggerHandler, objectMapper, customMetrics));
+        registrationBean.addUrlPatterns(REQUEST_MAPPING + "/decorators");
+        registrationBean.setOrder(Ordered.HIGHEST_PRECEDENCE);
+        return registrationBean;
+    }
 }
index 113a0f5..90bb607 100644 (file)
@@ -38,6 +38,8 @@ import org.springframework.web.context.request.WebRequest;
 import org.springframework.web.servlet.mvc.method.annotation.ResponseEntityExceptionHandler;
 import org.springframework.web.servlet.resource.NoResourceFoundException;
 
+import static org.oran.smo.teiv.utils.ResponseUtil.getHeadersContentTypeAppProblemJson;
+
 @Slf4j
 @ControllerAdvice
 public class ApplicationExceptionHandler extends ResponseEntityExceptionHandler {
@@ -48,8 +50,9 @@ public class ApplicationExceptionHandler extends ResponseEntityExceptionHandler
         if (exception.getException() != null) {
             log.error(exception.getMessage(), exception.getException());
         }
-        return new ResponseEntity<>(new OranTeivErrorMessage().message(exception.getMessage()).details(exception
-                .getDetails()).status(exception.getStatus().name()), exception.getStatus());
+        return ResponseEntity.status(exception.getStatus()).headers(getHeadersContentTypeAppProblemJson()).body(
+                OranTeivErrorMessage.builder().status(exception.getStatus().name()).message(exception.getMessage()).details(
+                        exception.getDetails()).build());
     }
 
     @ResponseBody
@@ -58,8 +61,9 @@ public class ApplicationExceptionHandler extends ResponseEntityExceptionHandler
         if (exception.getResponse() != null) {
             return new ResponseEntity<>(exception.getResponse(), HttpStatus.OK);
         } else {
-            return new ResponseEntity<>(new OranTeivErrorMessage().message(exception.getMessage()).details(exception
-                    .getDetails()).status(exception.getHttpStatus().name()), exception.getHttpStatus());
+            return ResponseEntity.status(exception.getHttpStatus()).headers(getHeadersContentTypeAppProblemJson()).body(
+                    OranTeivErrorMessage.builder().status(exception.getHttpStatus().name()).message(exception.getMessage())
+                            .details(exception.getDetails()).build());
         }
     }
 
@@ -67,28 +71,32 @@ public class ApplicationExceptionHandler extends ResponseEntityExceptionHandler
     @ExceptionHandler(Exception.class)
     protected ResponseEntity<OranTeivErrorMessage> handleGeneralException(final Exception ex) {
         log.error("Handling general exception", ex);
-        return new ResponseEntity<>(new OranTeivErrorMessage().status(HttpStatus.INTERNAL_SERVER_ERROR.name()),
-                HttpStatus.INTERNAL_SERVER_ERROR);
+        return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).headers(getHeadersContentTypeAppProblemJson()).body(
+                new OranTeivErrorMessage().status(HttpStatus.INTERNAL_SERVER_ERROR.name()));
     }
 
     @ResponseBody
     @ExceptionHandler(ConstraintViolationException.class)
     public ResponseEntity<OranTeivErrorMessage> handleConstraintViolationException(ConstraintViolationException exception) {
-        return new ResponseEntity<>(new OranTeivErrorMessage().message(exception.getMessage()).status(HttpStatus.BAD_REQUEST
-                .name()), HttpStatus.BAD_REQUEST);
+        return ResponseEntity.status(HttpStatus.BAD_REQUEST).headers(getHeadersContentTypeAppProblemJson()).body(
+                getBadRequestErrorMessage(exception));
     }
 
     @Override
     protected ResponseEntity<Object> handleNoResourceFoundException(NoResourceFoundException exception, HttpHeaders headers,
             HttpStatusCode status, WebRequest request) {
-        return new ResponseEntity<>(new OranTeivErrorMessage().message(exception.getMessage()).status(HttpStatus.BAD_REQUEST
-                .name()), HttpStatus.BAD_REQUEST);
+        return ResponseEntity.status(HttpStatus.BAD_REQUEST).headers(getHeadersContentTypeAppProblemJson()).body(
+                getBadRequestErrorMessage(exception));
     }
 
     @Override
     protected ResponseEntity<Object> handleHttpRequestMethodNotSupported(HttpRequestMethodNotSupportedException exception,
             HttpHeaders headers, HttpStatusCode status, WebRequest request) {
-        return new ResponseEntity<>(new OranTeivErrorMessage().message(exception.getMessage()).status(HttpStatus.BAD_REQUEST
-                .name()), HttpStatus.BAD_REQUEST);
+        return ResponseEntity.status(HttpStatus.BAD_REQUEST).headers(getHeadersContentTypeAppProblemJson()).body(
+                getBadRequestErrorMessage(exception));
+    }
+
+    public static OranTeivErrorMessage getBadRequestErrorMessage(final Exception e) {
+        return OranTeivErrorMessage.builder().status(HttpStatus.BAD_REQUEST.name()).message(e.getMessage()).build();
     }
 }
index 64b7df1..cfc1eb7 100644 (file)
@@ -138,5 +138,5 @@ public interface DataRepository {
      *     The id
      * @return true if exists, false if it does not
      */
-    boolean isTopologyExist(final Persistable type, final String id);
+    boolean doesTopologyExist(final Persistable type, final String id);
 }
index 21799c9..934ab10 100644 (file)
@@ -175,7 +175,7 @@ public class DataRepositoryImpl implements DataRepository {
     }
 
     @Override
-    public boolean isTopologyExist(final Persistable type, final String id) {
+    public boolean doesTopologyExist(final Persistable type, final String id) {
         return runMethodSafe(() -> readDataDslContext.fetchExists(readDataDslContext.selectFrom(table(type.getTableName()))
                 .where(field(name(type.getIdColumnName())).eq(id))));
     }
index 5cb0c3d..dc180ae 100644 (file)
@@ -45,10 +45,10 @@ public abstract class AndOrLogicalBlock extends LogicalBlock {
     }
 
     @Override
-    public Set<Pair<String, Field>> getJoinCondition() {
+    public Set<Pair<String, Field>> getWhereExistsConditions() {
         Set<Pair<String, Field>> tables = new LinkedHashSet<>();
-        tables.addAll(children.get(0).getJoinCondition());
-        tables.addAll(children.get(1).getJoinCondition());
+        tables.addAll(children.get(0).getWhereExistsConditions());
+        tables.addAll(children.get(1).getWhereExistsConditions());
         return tables;
     }
 
index 4358fb6..f2ee75e 100644 (file)
@@ -53,7 +53,7 @@ public class EmptyLogicalBlock extends LogicalBlock {
         return Collections.emptySet();
     }
 
-    public Set<Pair<String, Field>> getJoinCondition() {
+    public Set<Pair<String, Field>> getWhereExistsConditions() {
         return Collections.emptySet();
     }
 }
index 17c4bbd..4299a6d 100644 (file)
@@ -74,11 +74,10 @@ public class InnerFilterCriteria {
         return tables;
     }
 
-    public Set<Pair<String, Field>> getJoinCondition() {
-        Set<Pair<String, Field>> joins = new LinkedHashSet<>();
-        joins.addAll(scope.getJoinCondition());
-
-        return joins;
+    public Set<Pair<String, Field>> getWhereExistsCondition() {
+        Set<Pair<String, Field>> whereExistsCondition = new LinkedHashSet<>();
+        whereExistsCondition.addAll(scope.getWhereExistsConditions());
+        return whereExistsCondition;
     }
 
     public Map<SelectField, Map<SelectField, DataType>> getSelects() {
index 29465d4..7bf92e1 100644 (file)
@@ -36,5 +36,5 @@ public abstract class LogicalBlock {
 
     public abstract Set<Table> getTables();
 
-    public abstract Set<Pair<String, Field>> getJoinCondition();
+    public abstract Set<Pair<String, Field>> getWhereExistsConditions();
 }
index f0c1330..bcfcdd6 100644 (file)
@@ -35,13 +35,16 @@ import org.oran.smo.teiv.schema.RelationshipDataLocation;
 import org.oran.smo.teiv.schema.SchemaRegistry;
 import org.oran.smo.teiv.utils.query.exception.TeivPathException;
 
+import java.util.ArrayList;
 import java.util.HashSet;
 import java.util.LinkedHashSet;
 import java.util.List;
 import java.util.Optional;
 import java.util.Set;
 
+import static org.jooq.impl.DSL.exists;
 import static org.jooq.impl.DSL.field;
+import static org.jooq.impl.DSL.selectOne;
 import static org.jooq.impl.DSL.table;
 import static org.oran.smo.teiv.exposure.teivpath.innerlanguage.TopologyObjectType.ASSOCIATION;
 import static org.oran.smo.teiv.utils.PersistableUtil.getTableNameWithColumnName;
@@ -56,7 +59,26 @@ public class ScopeLogicalBlock extends LogicalBlock {
 
     @Override
     public Condition getCondition() {
-        return ConditionFactory.create(scopeObject).getCondition(scopeObject);
+        Condition scopeCondition = ConditionFactory.create(scopeObject).getCondition(scopeObject);
+        List<Pair<String, Field>> whereExistsConditions = new ArrayList<>(getWhereExistsConditions());
+        if (!whereExistsConditions.isEmpty()) {
+            if (whereExistsConditions.size() > 2) {
+                //error out as with in a scope block there cannot be more than two joins/where exists conditions(many to many)
+                throw TeivException.serverException("Server unknown exception",
+                        "More than two where exists condition within a logical block is not supported", null);
+            }
+            Condition existsCondition;
+            if (whereExistsConditions.size() == 1) {
+                existsCondition = exists(selectOne().from(whereExistsConditions.get(0).getLeft()).where(scopeCondition).and(
+                        whereExistsConditions.get(0).getRight()));
+            } else {
+                existsCondition = exists(selectOne().from(whereExistsConditions.get(0).getLeft()).where(
+                        whereExistsConditions.get(0).getRight()).andExists(selectOne().from(whereExistsConditions.get(1)
+                                .getLeft()).where(whereExistsConditions.get(1).getRight()).and(scopeCondition)));
+            }
+            return existsCondition;
+        }
+        return scopeCondition;
     }
 
     @Override
@@ -75,8 +97,8 @@ public class ScopeLogicalBlock extends LogicalBlock {
     }
 
     @SuppressWarnings({ "java:S1874" })
-    public Set<Pair<String, Field>> getJoinCondition() {
-        Set<Pair<String, Field>> joinCondition = new LinkedHashSet<>();
+    public Set<Pair<String, Field>> getWhereExistsConditions() {
+        Set<Pair<String, Field>> whereExistsCondition = new LinkedHashSet<>();
         String[] topologyObjectSplit = scopeObject.getTopologyObject().split("/");
         if (scopeObject.getTopologyObjectType().equals(ASSOCIATION) && SchemaRegistry.getEntityTypeByName(
                 topologyObjectSplit[0]) != null) {
@@ -87,26 +109,26 @@ public class ScopeLogicalBlock extends LogicalBlock {
                     entityType) || relation.getBSide().equals(entityType)).findFirst().orElseThrow(() -> TeivPathException
                             .invalidAssociation(entityType.getName(), association));
             if (isManyToMany(relationType)) {
-                String columnName = getColumnNameForManyToManyJoin(entityType, relationType);
-                String col1 = constructColumnNameForJoinCondition(relationType, columnName);
+                String columnName = getColumnNameForManyToManyWhereExists(entityType, relationType);
+                String col1 = constructColumnNameForWhereExistsCondition(relationType, columnName);
                 String col2 = getTableNameWithColumnName(entityType.getTableName(), ID_COLUMN_NAME);
-                joinCondition.add(constructJoinConditionPair(relationType.getTableName(), col1, col2));
+                whereExistsCondition.add(constructWhereExistsConditionPair(relationType.getTableName(), col1, col2));
 
-                if (isSecondJoinNeeded()) {
-                    joinCondition.add(getSecondJoinCondition(entityType, relationType));
+                if (isNestedWhereExistsRequired()) {
+                    whereExistsCondition.add(getNestedWhereExistsCondition(entityType, relationType));
                 }
-            } else if (isJoinNeeded(topologyObjectSplit, relationType)) {
-                String col1 = constructColumnNameForJoinCondition(relationType, relationType
+            } else if (isWhereExistsNeeded(topologyObjectSplit, relationType)) {
+                String col1 = constructColumnNameForWhereExistsCondition(relationType, relationType
                         .getNotStoringSideEntityIdColumnNameInStoringSideTable());
                 String col2 = getTableNameWithColumnName(relationType.getNotStoringSideTableName(), ID_COLUMN_NAME);
-                String tableName = getTableNameForJoin(topologyObjectSplit, relationType);
-                joinCondition.add(constructJoinConditionPair(tableName, col1, col2));
+                String tableName = getTableNameForWhereExists(topologyObjectSplit, relationType);
+                whereExistsCondition.add(constructWhereExistsConditionPair(tableName, col1, col2));
             }
         }
-        return joinCondition;
+        return whereExistsCondition;
     }
 
-    private boolean isSecondJoinNeeded() {
+    private boolean isNestedWhereExistsRequired() {
         return !scopeObject.getContainer().equals(ContainerType.ID) && !scopeObject.getContainer().equals(
                 ContainerType.NOT_NULL);
     }
@@ -115,12 +137,12 @@ public class ScopeLogicalBlock extends LogicalBlock {
         return relationType.getRelationshipStorageLocation().equals(RelationshipDataLocation.RELATION);
     }
 
-    private boolean isJoinNeeded(String[] topologyObjectSplit, RelationType relationType) {
+    private boolean isWhereExistsNeeded(String[] topologyObjectSplit, RelationType relationType) {
         return !relationType.getStoringSideEntityType().getName().equals(topologyObjectSplit[0]) || (!scopeObject
                 .getContainer().equals(ContainerType.ID) && !scopeObject.getContainer().equals(ContainerType.NOT_NULL));
     }
 
-    private static String getTableNameForJoin(String[] topologyObjectSplit, RelationType relationType) {
+    private static String getTableNameForWhereExists(String[] topologyObjectSplit, RelationType relationType) {
         if (relationType.getStoringSideEntityType().getName().equals(topologyObjectSplit[0])) {
             return relationType.getNotStoringSideTableName();
         } else {
@@ -128,22 +150,25 @@ public class ScopeLogicalBlock extends LogicalBlock {
         }
     }
 
-    private static Pair<String, Field> getSecondJoinCondition(EntityType entityType, RelationType relationType) {
-        EntityType entityTypeForSecondJoin;
-        String columnNameForSecondJoin;
+    private static Pair<String, Field> getNestedWhereExistsCondition(EntityType entityType, RelationType relationType) {
+        EntityType entityTypeForNestedWhereExists;
+        String columnNameForNestedWhereExists;
         if (!relationType.getASide().equals(entityType)) {
-            columnNameForSecondJoin = relationType.aSideColumnName();
-            entityTypeForSecondJoin = relationType.getASide();
+            columnNameForNestedWhereExists = relationType.aSideColumnName();
+            entityTypeForNestedWhereExists = relationType.getASide();
         } else {
-            columnNameForSecondJoin = relationType.bSideColumnName();
-            entityTypeForSecondJoin = relationType.getBSide();
+            columnNameForNestedWhereExists = relationType.bSideColumnName();
+            entityTypeForNestedWhereExists = relationType.getBSide();
         }
-        String col1ForSecondJoin = constructColumnNameForJoinCondition(relationType, columnNameForSecondJoin);
-        String col2ForSecondJoin = getTableNameWithColumnName(entityTypeForSecondJoin.getTableName(), ID_COLUMN_NAME);
-        return constructJoinConditionPair(entityTypeForSecondJoin.getTableName(), col1ForSecondJoin, col2ForSecondJoin);
+        String col1ForNestedWhereExists = constructColumnNameForWhereExistsCondition(relationType,
+                columnNameForNestedWhereExists);
+        String col2ForNestedWhereExists = getTableNameWithColumnName(entityTypeForNestedWhereExists.getTableName(),
+                ID_COLUMN_NAME);
+        return constructWhereExistsConditionPair(entityTypeForNestedWhereExists.getTableName(), col1ForNestedWhereExists,
+                col2ForNestedWhereExists);
     }
 
-    private static String getColumnNameForManyToManyJoin(EntityType entityType, RelationType relationType) {
+    private static String getColumnNameForManyToManyWhereExists(EntityType entityType, RelationType relationType) {
         if (relationType.getASide().equals(entityType)) {
             return relationType.aSideColumnName();
         } else {
@@ -151,11 +176,11 @@ public class ScopeLogicalBlock extends LogicalBlock {
         }
     }
 
-    private static String constructColumnNameForJoinCondition(RelationType relationType, String columnName) {
+    private static String constructColumnNameForWhereExistsCondition(RelationType relationType, String columnName) {
         return relationType.getTableName() + "." + String.format(QUOTED_STRING, columnName);
     }
 
-    private static Pair<String, Field> constructJoinConditionPair(String tableName, String col1, String col2) {
+    private static Pair<String, Field> constructWhereExistsConditionPair(String tableName, String col1, String col2) {
         Field equalsField = field(col1 + "=" + col2);
         return new ImmutablePair<>(tableName, equalsField);
     }
index 349cc3f..009dab7 100644 (file)
@@ -20,8 +20,6 @@
  */
 package org.oran.smo.teiv.exposure.teivpath.refiner;
 
-import org.apache.commons.lang3.tuple.Pair;
-import org.jooq.Field;
 import org.jooq.JSONB;
 import org.jooq.OrderField;
 import org.jooq.Record;
@@ -109,10 +107,6 @@ public class PathToJooqRefinement {
         }
         SelectJoinStep<Record> query = select(resolvedFields).from(filterCriteria.getTableFromTarget(filterCriteria
                 .getTargets().get(0)));
-        List<Pair<String, Field>> joinConditions = new ArrayList<>(filterCriteria.getJoinCondition());
-        for (int i = 0; i < joinConditions.size(); i++) {
-            query = query.join(joinConditions.get(i).getLeft()).on(joinConditions.get(i).getRight());
-        }
         SelectConditionStep<Record> conditionStep = query.where(filterCriteria.getCondition());
         if (countMode) {
             return conditionStep;
  *  SPDX-License-Identifier: Apache-2.0
  *  ============LICENSE_END=========================================================
  */
-package org.oran.smo.teiv.groups.utils;
+package org.oran.smo.teiv.groups.rest.controller;
 
 import static org.oran.smo.teiv.groups.audit.ExecutionStatus.FAILED;
 import static org.oran.smo.teiv.groups.audit.GroupOperation.CREATE;
 
-import java.io.BufferedReader;
 import java.io.IOException;
-import java.io.InputStreamReader;
-import java.nio.charset.StandardCharsets;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
+import org.oran.smo.teiv.CachedBodyHttpServletRequest;
 import org.oran.smo.teiv.exposure.audit.LoggerHandler;
 import org.oran.smo.teiv.groups.audit.AuditInfo;
 import org.springframework.context.annotation.Profile;
-import org.springframework.core.Ordered;
-import org.springframework.core.annotation.Order;
 import org.springframework.http.HttpStatus;
-import org.springframework.stereotype.Component;
 import org.springframework.web.util.ContentCachingRequestWrapper;
 import org.springframework.web.util.ContentCachingResponseWrapper;
 
@@ -54,14 +49,12 @@ import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 
 @Slf4j
-@Component
 @RequiredArgsConstructor
-@Order(Ordered.HIGHEST_PRECEDENCE)
 @Profile("groups")
 public class GroupCreationRequestFilter implements jakarta.servlet.Filter {
 
     private final LoggerHandler loggerHandler;
-    private final ObjectMapper objectMapper = new ObjectMapper();
+    private final ObjectMapper objectMapper;
 
     @Override
     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,
@@ -70,7 +63,7 @@ public class GroupCreationRequestFilter implements jakarta.servlet.Filter {
         CachedBodyHttpServletRequest cachedBodyHttpServletRequest = new CachedBodyHttpServletRequest(httpServletRequest);
         ContentCachingResponseWrapper httpServletResponse = new ContentCachingResponseWrapper(
                 (HttpServletResponse) response);
-        String payloadString = readRequestBody(cachedBodyHttpServletRequest);
+        String payloadString = cachedBodyHttpServletRequest.getRequestBody();
         try {
             if (cachedBodyHttpServletRequest.getMethod().equalsIgnoreCase("POST")) {
                 JsonNode createGroupPayload = objectMapper.readValue(payloadString, JsonNode.class);
@@ -80,7 +73,7 @@ public class GroupCreationRequestFilter implements jakarta.servlet.Filter {
                             payloadString).exceptionMessage(message).status(FAILED).build().toString(),
                             cachedBodyHttpServletRequest);
                     httpServletResponse.setStatus(HttpServletResponse.SC_BAD_REQUEST);
-                    httpServletResponse.setContentType("application/json");
+                    httpServletResponse.setContentType("application/problem+json");
                     httpServletResponse.getWriter().write(generateResponse(message));
                     httpServletResponse.getWriter().flush();
                     return;
@@ -125,16 +118,4 @@ public class GroupCreationRequestFilter implements jakarta.servlet.Filter {
         jsonResponse.put("status", HttpStatus.BAD_REQUEST);
         return objectMapper.writeValueAsString(jsonResponse);
     }
-
-    private String readRequestBody(HttpServletRequest request) throws IOException {
-        StringBuilder body = new StringBuilder();
-        try (BufferedReader reader = new BufferedReader(new InputStreamReader(request.getInputStream(),
-                StandardCharsets.UTF_8))) {
-            String line;
-            while ((line = reader.readLine()) != null) {
-                body.append(line);
-            }
-        }
-        return body.toString();
-    }
 }
index 9e488bf..cad025f 100644 (file)
@@ -29,17 +29,19 @@ import static org.oran.smo.teiv.groups.audit.GroupOperation.REMOVE_PROVIDED_MEMB
 import static org.oran.smo.teiv.groups.audit.GroupOperation.UPDATE_NAME;
 import static org.oran.smo.teiv.groups.rest.controller.GroupsConstants.MEMBERS_HREF_TEMPLATE;
 import static org.oran.smo.teiv.groups.rest.controller.GroupsConstants.PROVIDED_MEMBERS_HREF_TEMPLATE;
+import static org.oran.smo.teiv.utils.ResponseUtil.getHeadersContentTypeAppProblemJson;
+import static org.oran.smo.teiv.utils.TeivConstants.REQUEST_MAPPING;
 
 import java.util.function.Consumer;
 import java.util.function.Supplier;
 
+import com.fasterxml.jackson.databind.ObjectMapper;
 import org.apache.commons.lang3.tuple.Pair;
 import org.oran.smo.teiv.api.model.OranTeivDynamicGroupByIdResponse;
 import org.oran.smo.teiv.api.model.OranTeivStaticGroupByIdResponse;
 import org.oran.smo.teiv.exposure.audit.LoggerHandler;
 import org.oran.smo.teiv.groups.audit.AuditInfo;
 import org.oran.smo.teiv.groups.audit.ExecutionStatus;
-import org.oran.smo.teiv.groups.utils.GroupCreationRequestFilter;
 import org.springframework.boot.web.servlet.FilterRegistrationBean;
 import org.springframework.context.annotation.Bean;
 import org.springframework.context.annotation.Profile;
@@ -66,11 +68,10 @@ import org.oran.smo.teiv.api.model.OranTeivUpdateGroupNamePayload;
 import org.oran.smo.teiv.exposure.utils.RequestDetails;
 import org.oran.smo.teiv.groups.GroupsCustomMetrics;
 import org.oran.smo.teiv.groups.api.GroupsService;
-import org.oran.smo.teiv.utils.TeivConstants;
 
 @Slf4j
 @RestController
-@RequestMapping(TeivConstants.REQUEST_MAPPING)
+@RequestMapping(REQUEST_MAPPING)
 @RequiredArgsConstructor
 @Profile("groups")
 public class GroupsController implements GroupsApi {
@@ -195,7 +196,8 @@ public class GroupsController implements GroupsApi {
         final OranTeivErrorMessage errorMessage = OranTeivErrorMessage.builder().status(exception.getStatus().name())
                 .message(exception.getMessage()).details(exception.getDetails()).build();
 
-        return new ResponseEntity<>(errorMessage, exception.getStatus());
+        return ResponseEntity.status(exception.getStatus()).headers(getHeadersContentTypeAppProblemJson()).body(
+                errorMessage);
     }
 
     private <T> T runWithFailCheck(final Supplier<T> supp, final Runnable runnable) {
@@ -224,10 +226,10 @@ public class GroupsController implements GroupsApi {
     }
 
     @Bean
-    public FilterRegistrationBean<GroupCreationRequestFilter> loggingFilter() {
+    public FilterRegistrationBean<GroupCreationRequestFilter> loggingFilter(final ObjectMapper objectMapper) {
         FilterRegistrationBean<GroupCreationRequestFilter> registrationBean = new FilterRegistrationBean<>();
-        registrationBean.setFilter(new GroupCreationRequestFilter(loggerHandler));
-        registrationBean.addUrlPatterns("/groups");
+        registrationBean.setFilter(new GroupCreationRequestFilter(loggerHandler, objectMapper));
+        registrationBean.addUrlPatterns(REQUEST_MAPPING + "/groups");
         registrationBean.setOrder(Ordered.HIGHEST_PRECEDENCE);
         return registrationBean;
     }
index 9351839..877af76 100644 (file)
@@ -215,7 +215,7 @@ public class GroupsRepositoryImpl implements GroupsRepository {
 
     @Override
     public void createStaticGroup(final StaticGroupRecord groupRecord) {
-        log.debug("Create a static group with name {}", groupRecord.getGroupName());
+        log.debug("Create a static group with name: {}", groupRecord.getGroupName());
         writeDataDslContext.transaction((Configuration trx) -> {
             trx.dsl().insertInto(GROUPS_TABLE).set(GROUP_ID, groupRecord.getId()).set(GROUP_NAME, groupRecord
                     .getGroupName()).set(GROUP_TYPE, groupRecord.getGroupType()).execute();
index 671f4bf..b4ce191 100644 (file)
@@ -36,6 +36,7 @@ import org.springframework.context.annotation.Profile;
 import org.springframework.stereotype.Component;
 import org.springframework.util.StopWatch;
 
+import java.util.ArrayList;
 import java.util.List;
 
 import static org.oran.smo.teiv.utils.TeivConstants.CLOUD_EVENT_WITH_TYPE_CREATE;
@@ -59,7 +60,7 @@ public class CreateTopologyProcessor implements TopologyProcessor {
         if (null == parsedCloudEventData) {
             log.error("Failed to parse the following CloudEvent: {}", CloudEventUtil.cloudEventToPrettyString(cloudEvent));
             customMetrics.incrementNumUnsuccessfullyParsedCreateCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey,
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey,
                     "Failed to parse the CloudEvent");
             return;
         }
@@ -70,28 +71,33 @@ public class CreateTopologyProcessor implements TopologyProcessor {
 
         stopWatch.start();
         List<OperationResult> operationResults;
+        List<String> inferredItems = new ArrayList<>();
         final String sourceAdapter = String.valueOf(cloudEvent.getSource());
         try {
             operationResults = teivDbOperations.executeEntityAndRelationshipMergeOperations(parsedCloudEventData,
                     sourceAdapter);
+            operationResults.stream().filter(OperationResult::isInferred).map(result -> String.format(
+                    "{\"%s:%s\":[{\"id\":\"%s\"}]}", result.getModule(), result.getType(), result.getId())).forEach(
+                            inferredItems::add);
         } catch (InvalidFieldInYangDataException e) {
             log.error("Invalid field in yang data. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                     CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedCreateCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey, e
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey, e
                     .getMessage());
             return;
         } catch (RuntimeException e) {
             log.error("Failed to process a CloudEvent. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                     CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedCreateCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey, e
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey, e
                     .getMessage());
             return;
         }
         stopWatch.stop();
         customMetrics.incrementNumSuccessfullyPersistedCreateCloudEvents();
         customMetrics.recordCloudEventCreatePersistTime(stopWatch.lastTaskInfo().getTimeNanos());
-        auditLogger.auditLog(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey, "");
+        auditLogger.logSuccess(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_CREATE, cloudEvent, messageKey,
+                inferredItems);
     }
 }
index b8ea59c..c150f4c 100644 (file)
@@ -29,7 +29,6 @@ import lombok.AllArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.jooq.DSLContext;
 import org.oran.smo.teiv.CustomMetrics;
-import org.oran.smo.teiv.listener.audit.ExecutionStatus;
 import org.oran.smo.teiv.listener.audit.IngestionAuditLogger;
 import org.oran.smo.teiv.schema.EntityType;
 import org.oran.smo.teiv.schema.RelationType;
@@ -45,6 +44,9 @@ import org.springframework.context.annotation.Profile;
 import org.springframework.stereotype.Component;
 import org.springframework.util.StopWatch;
 
+import static org.oran.smo.teiv.listener.audit.ExecutionStatus.FAILED;
+import static org.oran.smo.teiv.listener.audit.ExecutionStatus.SUCCESS;
+import static org.oran.smo.teiv.utils.OperationResultParser.fromOperationResults;
 import static org.oran.smo.teiv.utils.TeivConstants.CLOUD_EVENT_WITH_TYPE_DELETE;
 
 @Component
@@ -68,7 +70,7 @@ public class DeleteTopologyProcessor implements TopologyProcessor {
         if (parsedCloudEventData == null) {
             log.error("Failed to parse the following CloudEvent: {}", CloudEventUtil.cloudEventToPrettyString(cloudEvent));
             customMetrics.incrementNumUnsuccessfullyParsedDeleteCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, "Failed to parse the CloudEvent");
+            auditLogger.logError(FAILED, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, "Failed to parse the CloudEvent");
             return;
         }
         parsedCloudEventData.sort();
@@ -106,13 +108,13 @@ public class DeleteTopologyProcessor implements TopologyProcessor {
             log.error("Failed to process a CloudEvent. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                 CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedDeleteCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, e.getMessage());
+            auditLogger.logError(FAILED, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, e.getMessage());
             return;
         }
         stopWatch.stop();
         customMetrics.recordCloudEventDeletePersistTime(stopWatch.lastTaskInfo().getTimeNanos());
         customMetrics.incrementNumSuccessfullyPersistedDeleteCloudEvents();
-        auditLogger.auditLog(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, "");
+        auditLogger.logSuccess(SUCCESS, CLOUD_EVENT_WITH_TYPE_DELETE, cloudEvent, messageKey, fromOperationResults(operationResults));
     }
     //spotless:on
 }
index 920b915..44349ff 100644 (file)
@@ -65,7 +65,7 @@ public class MergeTopologyProcessor implements TopologyProcessor {
         if (null == parsedCloudEventData) {
             log.error("Failed to parse the following CloudEvent: {}", CloudEventUtil.cloudEventToPrettyString(cloudEvent));
             customMetrics.incrementNumUnsuccessfullyParsedMergeCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, "Failed to parse the CloudEvent");
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, "Failed to parse the CloudEvent");
             return;
         }
         parsedCloudEventData.sort();
@@ -75,27 +75,32 @@ public class MergeTopologyProcessor implements TopologyProcessor {
 
         stopWatch.start();
         List<OperationResult> operationResults = new ArrayList<>();
+        List<String> inferredItems = new ArrayList<>();
         final String sourceAdapter = String.valueOf(cloudEvent.getSource());
         try {
             operationResults = teivDbOperations.executeEntityAndRelationshipMergeOperations(parsedCloudEventData, sourceAdapter);
+            operationResults.stream()
+                .filter(OperationResult::isInferred)
+                .map(result -> String.format("{\"%s:%s\":[{\"id\":\"%s\"}]}", result.getModule(), result.getType(), result.getId()))
+                .forEach(inferredItems::add);
         } catch (InvalidFieldInYangDataException e) {
             log.error("Invalid field in yang data. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                 CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedMergeCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, e.getMessage());
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, e.getMessage());
             return;
         } catch (RuntimeException e) {
             log.error("Failed to process a CloudEvent. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                 CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedMergeCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, e.getMessage());
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, e.getMessage());
             return;
         }
         stopWatch.stop();
 
         customMetrics.incrementNumSuccessfullyPersistedMergeCloudEvents();
         customMetrics.recordCloudEventMergePersistTime(stopWatch.lastTaskInfo().getTimeNanos());
-        auditLogger.auditLog(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, "");
+        auditLogger.logSuccess(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_MERGE, cloudEvent, messageKey, inferredItems);
     }
     //spotless:on
 }
index e8f5dba..b8d6258 100644 (file)
@@ -70,7 +70,7 @@ public class SourceEntityDeleteTopologyProcessor implements TopologyProcessor {
         } catch (IOException e) {
             log.error("Error while parsing the {} event.", e.getMessage());
             customMetrics.incrementNumUnsuccessfullyParsedSourceEntityDeleteCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
                     "Failed to parse the CloudEvent");
             return;
         }
@@ -80,7 +80,7 @@ public class SourceEntityDeleteTopologyProcessor implements TopologyProcessor {
             log.error("Unsupported type: {} for source-entity-delete event. Event: {}", sourceEntityDelete.type,
                     cloudEvent);
             customMetrics.incrementNumReceivedCloudEventNotSupported();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
                     String.format("Unsupported type: %s for source-entity-delete event.", sourceEntityDelete.type));
             return;
         }
@@ -107,7 +107,7 @@ public class SourceEntityDeleteTopologyProcessor implements TopologyProcessor {
             log.error("Failed to process a CloudEvent. Discarded CloudEvent: {}. Used kafka message key: {}. Reason: {}",
                     CloudEventUtil.cloudEventToPrettyString(cloudEvent), messageKey, e.getMessage());
             customMetrics.incrementNumUnsuccessfullyPersistedSourceEntityDeleteCloudEvents();
-            auditLogger.auditLog(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
+            auditLogger.logError(ExecutionStatus.FAILED, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
                     e.getMessage());
             return;
         }
@@ -115,8 +115,8 @@ public class SourceEntityDeleteTopologyProcessor implements TopologyProcessor {
         stopWatch.stop();
         customMetrics.recordCloudEventSourceEntityDeletePersistTime(stopWatch.lastTaskInfo().getTimeNanos());
         customMetrics.incrementNumSuccessfullyPersistedSourceEntityDeleteCloudEvents();
-        auditLogger.auditLog(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
-                "");
+        auditLogger.logSuccess(ExecutionStatus.SUCCESS, CLOUD_EVENT_WITH_TYPE_SOURCE_ENTITY_DELETE, cloudEvent, messageKey,
+                List.of());
     }
 
     @JsonIgnoreProperties(ignoreUnknown = true)
index e1068a4..c710f77 100644 (file)
@@ -20,6 +20,7 @@
  */
 package org.oran.smo.teiv.listener.audit;
 
+import org.apache.commons.lang3.StringUtils;
 import org.oran.smo.teiv.exposure.audit.LoggerHandler;
 import org.springframework.stereotype.Component;
 
@@ -28,6 +29,11 @@ import io.cloudevents.CloudEvent;
 import lombok.AllArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 
+import java.util.List;
+
+import static org.oran.smo.teiv.utils.TeivConstants.CLOUD_EVENT_WITH_TYPE_CREATE;
+import static org.oran.smo.teiv.utils.TeivConstants.CLOUD_EVENT_WITH_TYPE_MERGE;
+
 @Slf4j
 @AllArgsConstructor
 @Component
@@ -35,10 +41,25 @@ public class IngestionAuditLogger {
 
     private final LoggerHandler loggerHandler;
 
-    public void auditLog(ExecutionStatus status, String operationType, CloudEvent cloudEvent, String messageKey,
+    public void logError(ExecutionStatus status, String operationType, CloudEvent cloudEvent, String messageKey,
             String errorMsg) {
-        loggerHandler.logAuditBase(log, IngestionAuditInfo.builder().status(status).operation(operationType).messageKey(
-                messageKey).cloudEvent(CloudEventUtil.cloudEventToPrettyString(cloudEvent)).exceptionMessage(errorMsg)
-                .build().toString(), String.valueOf(cloudEvent.getSource()));
+        final String message = String.format("%s. Exception = %s", getMessage(status, operationType, cloudEvent,
+                messageKey), errorMsg);
+        loggerHandler.logAuditBase(log, message, cloudEvent.getSource().toString());
+    }
+
+    public void logSuccess(ExecutionStatus status, String operationType, CloudEvent cloudEvent, String messageKey,
+            List<String> inferred) {
+        final String message = String.format("%s. Implicitly %sd items = %s", getMessage(status, operationType, cloudEvent,
+                messageKey), operationType.equals(CLOUD_EVENT_WITH_TYPE_MERGE) ?
+                        CLOUD_EVENT_WITH_TYPE_CREATE :
+                        operationType, inferred);
+        loggerHandler.logAuditBase(log, message, cloudEvent.getSource().toString());
+    }
+
+    private String getMessage(final ExecutionStatus status, final String operation, final CloudEvent cloudEvent,
+            final String messageKey) {
+        return String.format("%s - %s topology. Message key: %s, CloudEvent: %s", status, StringUtils.capitalize(operation),
+                messageKey, CloudEventUtil.cloudEventToPrettyString(cloudEvent));
     }
 }
index 840bbde..6569ca6 100644 (file)
  */
 package org.oran.smo.teiv.schema;
 
+import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.DUPLICATE_ENTITY_NAME_IN_DOMAIN;
+import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.DUPLICATE_ENTITY_NAME_IN_TEIV_DOMAIN;
+import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.DUPLICATE_RELATION_NAME_IN_DOMAIN;
+import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.DUPLICATE_RELATION_NAME_IN_TEIV_DOMAIN;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.ENTITY_NOT_FOUND_IN_DOMAIN;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.ENTITY_NOT_FOUND_IN_MODULE;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.RELATIONSHIP_NOT_FOUND_IN_DOMAIN;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.RELATIONSHIP_NOT_FOUND_IN_MODULE;
+import static org.oran.smo.teiv.utils.TeivConstants.TEIV_DOMAIN;
 
 import java.util.ArrayList;
 import java.util.Collections;
@@ -156,29 +161,44 @@ public class SchemaRegistry {
     }
 
     /**
-     * Gets the {@link EntityType} by the given module name and the entity type name.
+     * Gets the {@link EntityType} by the given domain name and the entity type name.
      * Since TEIV supports TEIV as top level domain on the exposure side, there is possibility to return more than one
-     * EntityType for a given name
-     * with domain as TIEV.
+     * EntityType for a given name with domain as TEIV. In this instance, an error will be thrown because this is not yet
+     * implemented in TEIV.
      *
      * @param domain
      *     - name of the domain
      * @param entityTypeName
      *     - name of the entityType
-     * @return the list of {@link EntityType}
+     * @return the {@link EntityType}
      * @throws SchemaRegistryException
      *     if entity type is not found in the domain
      */
-    public static List<EntityType> getEntityTypeByDomainAndName(final String domain, final String entityTypeName)
+    @Cacheable("entityTypeByDomainAndName")
+    public static EntityType getEntityTypeByDomainAndName(final String domain, final String entityTypeName)
             throws SchemaRegistryException {
-        final List<EntityType> matchedEntityTypes = entityTypes.stream().filter(entityType -> entityType.getModule()
-                .getDomain().equals(domain) && entityType.getName().equals(entityTypeName)).toList();
-        if (matchedEntityTypes.isEmpty()) {
+        final List<EntityType> matchedEntityTypes = getEntityTypesByDomain(domain).stream().filter(entityType -> entityType
+                .getName().equals(entityTypeName)).toList();
+        if (matchedEntityTypes.size() == 1) {
+            return matchedEntityTypes.get(0);
+        } else if (matchedEntityTypes.isEmpty()) {
             log.warn("Domain: {} does not contain the entity type: {}", domain, entityTypeName);
             throw new SchemaRegistryException(ENTITY_NOT_FOUND_IN_DOMAIN, String.format(
                     "Entity type: %s not found in domain: %s", entityTypeName, domain));
+        } else {
+            if (domain.equals(TEIV_DOMAIN)) {
+                log.warn("Domain: {} contains duplicate entity type: {}. This is yet to be implemented in TEIV.", domain,
+                        entityTypeName);
+                throw new SchemaRegistryException(DUPLICATE_ENTITY_NAME_IN_TEIV_DOMAIN, String.format(
+                        "Duplicate entity type: %s found in domain: %s. This is yet to be implemented in TEIV.",
+                        entityTypeName, domain));
+            }
+            log.warn("Domain: {} contains duplicate entity type: {}. This is not supported in TEIV.", domain,
+                    entityTypeName);
+            throw new SchemaRegistryException(DUPLICATE_ENTITY_NAME_IN_DOMAIN, String.format(
+                    "Duplicate entity type: %s found in domain: %s. This is not supported in TEIV.", entityTypeName,
+                    domain));
         }
-        return matchedEntityTypes;
     }
 
     /**
@@ -290,28 +310,44 @@ public class SchemaRegistry {
     }
 
     /**
-     * Gets the {@link RelationType} (could be more than one when domain is TEIV) by the given module name and the relation
-     * type
-     * name.
+     * Gets the {@link RelationType} by the given domain name and the relation type name.
+     * Since TEIV supports TEIV as top level domain on the exposure side, there is possibility to return more than one
+     * RelationType for a given name with domain as TEIV. In this instance, an error will be thrown because this is not yet
+     * implemented in TEIV.
      *
      * @param domain
      *     - name of the domain
      * @param relationTypeName
      *     - name of the relation type
-     * @return the list of {@link RelationType}
+     * @return the {@link RelationType}
      * @throws SchemaRegistryException
      *     if relation type is not found in the domain
      */
-    public static List<RelationType> getRelationTypeByDomainAndName(final String domain, final String relationTypeName)
+    @Cacheable("relationTypeByDomainAndName")
+    public static RelationType getRelationTypeByDomainAndName(final String domain, final String relationTypeName)
             throws SchemaRegistryException {
-        final List<RelationType> matchedRelationTypes = relationTypes.stream().filter(relationType -> relationType
-                .getModule().getDomain().equals(domain) && relationType.getName().equals(relationTypeName)).toList();
-        if (matchedRelationTypes.isEmpty()) {
+        final List<RelationType> matchedRelationTypes = getRelationTypesByDomain(domain).stream().filter(
+                relationType -> relationType.getName().equals(relationTypeName)).toList();
+        if (matchedRelationTypes.size() == 1) {
+            return matchedRelationTypes.get(0);
+        } else if (matchedRelationTypes.isEmpty()) {
             log.warn("Domain: {} does not contain the relation type: {}", domain, relationTypeName);
             throw new SchemaRegistryException(RELATIONSHIP_NOT_FOUND_IN_DOMAIN, String.format(
                     "Relation type: %s not found in domain: %s", relationTypeName, domain));
+        } else {
+            if (domain.equals(TEIV_DOMAIN)) {
+                log.warn("Domain: {} contains duplicate relation type: {}. This is yet to be implemented in TEIV.", domain,
+                        relationTypeName);
+                throw new SchemaRegistryException(DUPLICATE_RELATION_NAME_IN_TEIV_DOMAIN, String.format(
+                        "Duplicate relation type: %s found in domain: %s. This is yet to be implemented in TEIV.",
+                        relationTypeName, domain));
+            }
+            log.warn("Domain: {} contains duplicate relation type: {}. This is not supported in TEIV.", domain,
+                    relationTypeName);
+            throw new SchemaRegistryException(DUPLICATE_RELATION_NAME_IN_DOMAIN, String.format(
+                    "Duplicate relation type: %s found in domain: %s. This is not supported in TEIV.", relationTypeName,
+                    domain));
         }
-        return matchedRelationTypes;
     }
 
     /**
index 7b48051..a3e3d4f 100644 (file)
@@ -26,6 +26,10 @@ package org.oran.smo.teiv.schema;
 public enum SchemaRegistryErrorCode {
     ENTITY_NOT_FOUND_IN_DOMAIN,
     ENTITY_NOT_FOUND_IN_MODULE,
+    DUPLICATE_ENTITY_NAME_IN_TEIV_DOMAIN,
+    DUPLICATE_ENTITY_NAME_IN_DOMAIN,
     RELATIONSHIP_NOT_FOUND_IN_DOMAIN,
-    RELATIONSHIP_NOT_FOUND_IN_MODULE
+    RELATIONSHIP_NOT_FOUND_IN_MODULE,
+    DUPLICATE_RELATION_NAME_IN_TEIV_DOMAIN,
+    DUPLICATE_RELATION_NAME_IN_DOMAIN
 }
index 3acb2bd..89ed799 100644 (file)
@@ -153,7 +153,8 @@ public class TeivDbOperations {
         int affectedRows = context.delete(table(entityType.getTableName())).where(field(ID_COLUMN_NAME).eq(entityId))
                 .execute();
         if (affectedRows > 0) {
-            result.add(OperationResult.builder().id(entityId).type(entityType.getName()).category(ENTITY_CATEGORY).build());
+            result.add(OperationResult.builder().id(entityId).type(entityType.getName()).category(ENTITY_CATEGORY).module(
+                    entityType.getModule().getName()).build());
         }
         return result;
     }
@@ -168,15 +169,14 @@ public class TeivDbOperations {
                 .getIdColumnName()), String.class)).from(table(relationType.getTableName())).where(field(String.format(
                         QUOTED_STRING, manySideEntityIdColumn)).eq(manySideEntityId)).forUpdate().fetchInto(String.class)
                 .stream().filter(Objects::nonNull).map(id -> OperationResult.builder().id(id).type(relationType.getName())
-                        .category(RELATIONSHIP_CATEGORY).build()).collect(Collectors.toList());
+                        .category(RELATIONSHIP_CATEGORY).module(relationType.getModule().getName()).build()).collect(
+                                Collectors.toList());
+        int updateResult;
         if (relationshipList.isEmpty()) {
             return relationshipList;
         } else {
-            int updateResult = context.update(table(relationType.getTableName())).setNull(field(String.format(QUOTED_STRING,
-                    relationType.getIdColumnName()))).setNull(field(String.format(QUOTED_STRING, oneSideEntityIdColumn)))
-                    .set(field(String.format(QUOTED_STRING, relationType.getSourceIdsColumnName())), toJsonb(List.of()))
-                    .setNull(field(String.format(QUOTED_STRING, relationType.getMetadataColumnName()))).where(field(String
-                            .format(QUOTED_STRING, manySideEntityIdColumn)).eq(manySideEntityId)).execute();
+            updateResult = executeRelationshipDelete(context, manySideEntityIdColumn, manySideEntityId, relationType,
+                    oneSideEntityIdColumn);
             return updateResult > 0 ? relationshipList : List.of();
         }
 
@@ -187,17 +187,28 @@ public class TeivDbOperations {
         String oneSideEntityIdColumn = relationType.getRelationshipStorageLocation().equals(B_SIDE) ?
                 relationType.aSideColumnName() :
                 relationType.bSideColumnName();
-        int affectedRows = context.update(table(relationType.getTableName())).setNull(field(String.format(QUOTED_STRING,
-                relationType.getIdColumnName()))).setNull(field(String.format(QUOTED_STRING, oneSideEntityIdColumn))).set(
-                        field(String.format(QUOTED_STRING, relationType.getSourceIdsColumnName())), toJsonb(List.of()))
-                .setNull(field(String.format(QUOTED_STRING, relationType.getMetadataColumnName()))).where(field(String
-                        .format(QUOTED_STRING, relationType.getIdColumnName())).eq(relationshipId)).execute();
+
+        int affectedRows;
+        affectedRows = executeRelationshipDelete(context, relationType.getIdColumnName(), relationshipId, relationType,
+                oneSideEntityIdColumn);
         return affectedRows > 0 ?
                 Optional.of(OperationResult.builder().id(relationshipId).type(relationType.getName()).category(
-                        RELATIONSHIP_CATEGORY).build()) :
+                        RELATIONSHIP_CATEGORY).module(relationType.getModule().getName()).build()) :
                 Optional.empty();
     }
 
+    private static int executeRelationshipDelete(DSLContext context, String whereClauseColumnName,
+            String whereClauseColumnId, RelationType relationType, String oneSideEntityIdColumn) {
+        return context.update(table(relationType.getTableName())).setNull(field(String.format(QUOTED_STRING, relationType
+                .getIdColumnName()))).setNull(field(String.format(QUOTED_STRING, oneSideEntityIdColumn))).set(field(String
+                        .format(QUOTED_STRING, relationType.getSourceIdsColumnName())), toJsonb(List.of())).set(field(String
+                                .format(QUOTED_STRING, relationType.getClassifiersColumnName())), toJsonb(List.of())).set(
+                                        field(String.format(QUOTED_STRING, relationType.getDecoratorsColumnName())),
+                                        toJsonb("{}")).setNull(field(String.format(QUOTED_STRING, relationType
+                                                .getMetadataColumnName()))).where(field(String.format(QUOTED_STRING,
+                                                        whereClauseColumnName)).eq(whereClauseColumnId)).execute();
+    }
+
     public List<OperationResult> deleteManyToManyRelationByEntityId(DSLContext context, RelationType relationType,
             String entityId, String aSideColumnName, String bSideColumnName) {
         List<String> deletedIds = context.delete(table((relationType.getTableName()))).where(field(String.format(
@@ -206,7 +217,7 @@ public class TeivDbOperations {
                                 TeivConstants.ID_COLUMN_NAME), String.class);
 
         return deletedIds.stream().map(id -> OperationResult.builder().id(id).type(relationType.getName()).category(
-                RELATIONSHIP_CATEGORY).build()).collect(Collectors.toList());
+                RELATIONSHIP_CATEGORY).module(relationType.getModule().getName()).build()).collect(Collectors.toList());
     }
 
     public Optional<OperationResult> deleteManyToManyRelationByRelationId(DSLContext context, RelationType relationType,
@@ -215,7 +226,7 @@ public class TeivDbOperations {
                 relationshipId)).execute();
         return affectedRows > 0 ?
                 Optional.of(OperationResult.builder().id(relationshipId).type(relationType.getName()).category(
-                        RELATIONSHIP_CATEGORY).build()) :
+                        RELATIONSHIP_CATEGORY).module(relationType.getModule().getName()).build()) :
                 Optional.empty();
     }
 
@@ -348,7 +359,8 @@ public class TeivDbOperations {
                             createMissingStoringSideEntity(dslContext, relationship, relationType, respAdapterByteArray,
                                     metadataMissingEntity);
                             addEntityToOperationResults(results, relationship.getStoringSideEntityId(),
-                                    metadataMissingEntity, relationType.getStoringSideEntityType().getName());
+                                    metadataMissingEntity, relationType.getStoringSideEntityType().getName(), relationType
+                                            .getStoringSideEntityType().getModule().getName());
                             updateRelationshipInEntityTable(dslContext, relationship, relationType, dbMap).ifPresentOrElse(
                                     results::add, () -> {
                                         throw new IllegalOneToManyRelationshipUpdateException(relationship, true);
@@ -365,12 +377,14 @@ public class TeivDbOperations {
                     createMissingStoringSideEntity(dslContext, relationship, relationType, respAdapterByteArray,
                             metadataMissingEntity);
                     addEntityToOperationResults(results, relationship.getStoringSideEntityId(), metadataMissingEntity,
-                            relationType.getStoringSideEntityType().getName());
+                            relationType.getStoringSideEntityType().getName(), relationType.getStoringSideEntityType()
+                                    .getModule().getName());
                 }
                 createMissingNotStoringSideEntity(dslContext, relationship, relationType, respAdapterByteArray,
                         metadataMissingEntity);
                 addEntityToOperationResults(results, relationship.getNotStoringSideEntityId(), metadataMissingEntity,
-                        relationType.getNotStoringSideEntityType().getName());
+                        relationType.getNotStoringSideEntityType().getName(), relationType.getNotStoringSideEntityType()
+                                .getModule().getName());
                 updateRelationshipInEntityTable(dslContext, relationship, relationType, dbMap).ifPresentOrElse(results::add,
                         () -> {
                             throw new IllegalOneToManyRelationshipUpdateException(relationship, false);
@@ -446,20 +460,24 @@ public class TeivDbOperations {
             List<OperationResult> results, byte[] respAdapterByteArray) {
         String aSideTableName = relationType.getASide().getTableName();
         String aSideId = relationship.getASide();
+        String aSideModuleName = relationType.getASide().getModule().getName();
         String bSideTableName = relationType.getBSide().getTableName();
         String bSideId = relationship.getBSide();
+        String bSideModuleName = relationType.getASide().getModule().getName();
         String relationshipId = relationship.getId();
         final Map<String, Object> metadata = TeivMetadataResolver.getMetadataForInferredEntity();
 
         if (createMissingEntity(aSideTableName, aSideId, relationshipId, dslContext, relationType.getASide(),
                 respAdapterByteArray, metadata) == 1) {
             results.add(OperationResult.builder().id(aSideId).type(relationType.getASide().getName()).category(
-                    ENTITY_CATEGORY).sourceIds(List.of(relationshipId)).metadata(metadata).build());
+                    ENTITY_CATEGORY).sourceIds(List.of(relationshipId)).metadata(metadata).module(aSideModuleName)
+                    .isInferred(true).build());
         }
         if (createMissingEntity(bSideTableName, bSideId, relationshipId, dslContext, relationType.getBSide(),
                 respAdapterByteArray, metadata) == 1) {
             results.add(OperationResult.builder().id(bSideId).type(relationType.getBSide().getName()).category(
-                    ENTITY_CATEGORY).sourceIds(List.of(relationshipId)).metadata(metadata).build());
+                    ENTITY_CATEGORY).sourceIds(List.of(relationshipId)).metadata(metadata).module(bSideModuleName)
+                    .isInferred(true).build());
         }
     }
 
@@ -513,9 +531,9 @@ public class TeivDbOperations {
     }
 
     private void addEntityToOperationResults(List<OperationResult> results, String entityId, Map<String, Object> metadata,
-            String entityType) {
+            String entityType, String entityModule) {
         OperationResult result = OperationResult.builder().id(entityId).type(entityType).category(ENTITY_CATEGORY).metadata(
-                metadata).build();
+                metadata).module(entityModule).isInferred(true).build();
         if (!results.contains(result)) {
             results.add(result);
         }
index ae7d7c4..846a464 100644 (file)
@@ -25,7 +25,6 @@ import java.util.Map;
 import java.util.Set;
 import java.util.concurrent.ExecutionException;
 
-import io.cloudevents.CloudEvent;
 import lombok.AllArgsConstructor;
 import lombok.Getter;
 import lombok.extern.slf4j.Slf4j;
@@ -36,11 +35,9 @@ import org.apache.kafka.common.config.TopicConfig;
 import org.oran.smo.teiv.config.KafkaAdminConfig;
 import org.oran.smo.teiv.config.KafkaConfig;
 import org.oran.smo.teiv.utils.RetryOperationUtils;
-import org.springframework.beans.factory.annotation.Qualifier;
 import org.springframework.context.annotation.Profile;
 import org.springframework.kafka.config.TopicBuilder;
 import org.springframework.kafka.core.KafkaAdmin;
-import org.springframework.kafka.core.KafkaTemplate;
 import org.springframework.retry.support.RetryTemplate;
 import org.springframework.stereotype.Component;
 
@@ -58,9 +55,6 @@ public class KafkaTopicService {
     @Getter
     private final KafkaConfig kafkaConfig;
 
-    @Qualifier("topologyAuditKafkaTemplate")
-    private final KafkaTemplate<String, CloudEvent> topologyAuditkafkaTemplate;
-
     public boolean checkTopologyIngestionTopic() {
         return checkTopicCreated(kafkaConfig.getTopologyIngestion().getTopicName());
     }
index 8d7e516..9340ff8 100644 (file)
@@ -26,6 +26,7 @@ import java.util.Map;
 
 import com.fasterxml.jackson.annotation.JsonIgnore;
 import com.fasterxml.jackson.annotation.JsonInclude;
+import com.fasterxml.jackson.annotation.JsonInclude.Include;
 import lombok.Builder;
 import lombok.AllArgsConstructor;
 import lombok.Data;
@@ -34,13 +35,16 @@ import lombok.NoArgsConstructor;
 @Data
 @AllArgsConstructor
 @NoArgsConstructor
-@JsonInclude(JsonInclude.Include.NON_NULL)
+// Include.NON_NULL was chosen over NON_EMPTY, since empty classifiers/decorators means those field in DB are empty,
+// while null classifiers/decorators means they were irrelevant in terms of the executed operation.
+@JsonInclude(Include.NON_NULL)
 @Builder
 public class OperationResult {
     private String id;
     private String type; // e.g.: NRCellDU, Site, CloudNativeApplication
     private String category; // "entity" or "relationship"
     private Map<String, Object> attributes;
+    private String module;
     private String aSide;
     private String bSide;
     private List<String> classifiers;
@@ -48,6 +52,7 @@ public class OperationResult {
     private Map<String, Object> metadata;
     private List<String> sourceIds;
     private boolean isUpdatedInDb;
+    private boolean isInferred;
     public static final String ENTITY_CATEGORY = "entity";
     public static final String RELATIONSHIP_CATEGORY = "relationship";
 
index 22f249c..4b32016 100644 (file)
@@ -52,7 +52,7 @@ public class AppInit {
      * unaffected by retries.
      */
     @Async
-    @Order(value = 20)
+    @Order(value = 25)
     @EventListener(value = ApplicationReadyEvent.class)
     public void startUpHandler() {
         if (dependentServiceAvailabilityKafka.checkService()) {
diff --git a/teiv/src/main/java/org/oran/smo/teiv/utils/OperationResultParser.java b/teiv/src/main/java/org/oran/smo/teiv/utils/OperationResultParser.java
new file mode 100644 (file)
index 0000000..eb88364
--- /dev/null
@@ -0,0 +1,35 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv.utils;
+
+import lombok.experimental.UtilityClass;
+import org.oran.smo.teiv.service.models.OperationResult;
+
+import java.util.List;
+
+@UtilityClass
+public class OperationResultParser {
+
+    public static List<String> fromOperationResults(List<OperationResult> operationResults) {
+        return operationResults.stream().filter(op -> !op.isInferred()).map(op -> String.format(
+                "{\"%s:%s\":[{\"id\":\"%s\"}]}", op.getModule(), op.getType(), op.getId())).toList();
+    }
+}
diff --git a/teiv/src/main/java/org/oran/smo/teiv/utils/ResponseUtil.java b/teiv/src/main/java/org/oran/smo/teiv/utils/ResponseUtil.java
new file mode 100644 (file)
index 0000000..dca9fe0
--- /dev/null
@@ -0,0 +1,34 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv.utils;
+
+import lombok.experimental.UtilityClass;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.MediaType;
+
+@UtilityClass
+public class ResponseUtil {
+    public static HttpHeaders getHeadersContentTypeAppProblemJson() {
+        final HttpHeaders httpHeaders = new HttpHeaders();
+        httpHeaders.setContentType(MediaType.valueOf(MediaType.APPLICATION_PROBLEM_JSON_VALUE));
+        return httpHeaders;
+    }
+}
index ec121f5..f0f6c32 100644 (file)
@@ -266,6 +266,7 @@ public class YangParser {
                     case "string" -> "TEXT";
                     case "boolean" -> "BOOLEAN";
                     case "int8", "int16", "int32", "int64", "uint8", "uint16", "uint32", "uint64" -> "INT";
+                    case "decimal64" -> "DEC";
                     default -> throw TeivException.invalidFileInput("Invalid data type");
                 }));
             }
index dea6d90..a46ff9f 100644 (file)
@@ -31,6 +31,7 @@ import java.util.Set;
 import java.util.concurrent.ConcurrentHashMap;
 import java.util.concurrent.CopyOnWriteArrayList;
 
+import org.oran.smo.teiv.exception.YangException;
 import org.springframework.web.multipart.MultipartFile;
 
 import org.oran.smo.yangtools.parser.ParserExecutionContext;
@@ -43,7 +44,6 @@ import org.oran.smo.yangtools.parser.model.YangModel;
 import org.oran.smo.yangtools.parser.model.yangdom.YangDomElement;
 import org.oran.smo.teiv.exception.TeivException;
 import org.oran.smo.teiv.exception.YangParsingException;
-import org.oran.smo.teiv.exception.YangSchemaException;
 
 public class ExposureYangParser extends YangModelLoader {
     private static final List<YangModel> yangModelInputs = new CopyOnWriteArrayList<>();
@@ -52,7 +52,7 @@ public class ExposureYangParser extends YangModelLoader {
             ModuleAndFindingTypeAndSchemaNodePathFilterPredicate.fromString("ietf-*;*;*"),
             ModuleAndFindingTypeAndSchemaNodePathFilterPredicate.fromString("_3gpp*;*;*"));
 
-    public static void loadAndValidateModels() throws YangSchemaException {
+    public static void loadAndValidateModels() throws YangException {
         ParserExecutionContext context = createParserExecutionContext(List.of(), List.of(), FILTER_PREDICATES);
         context.setFailFast(false);
         final List<YangModel> yangModels = YangModelLoader.loadModulesFromSchemaRegistry();
@@ -127,6 +127,7 @@ public class ExposureYangParser extends YangModelLoader {
                         case "string" -> "TEXT";
                         case "boolean" -> "BOOLEAN";
                         case "int8", "int16", "int32", "int64", "uint8", "uint16", "uint32", "uint64" -> "INT";
+                        case "decimal64" -> "DEC";
                         default -> throw TeivException.invalidFileInput("Invalid data type");
                     };
                     if (resultMap.putIfAbsent(key, value) != null) {
index 76ba229..71ec05e 100644 (file)
@@ -27,6 +27,7 @@ import java.util.List;
 import java.util.Set;
 import java.util.concurrent.CopyOnWriteArrayList;
 
+import org.oran.smo.teiv.exception.YangException;
 import org.oran.smo.yangtools.parser.ParserExecutionContext;
 import org.oran.smo.yangtools.parser.YangDeviceModel;
 import org.oran.smo.yangtools.parser.data.YangData;
@@ -45,7 +46,6 @@ import org.oran.smo.yangtools.parser.model.statements.ietf.IetfExtensionsClassSu
 import org.oran.smo.yangtools.parser.model.statements.threegpp.ThreeGppExtensionsClassSupplier;
 import org.oran.smo.teiv.CustomMetrics;
 import org.oran.smo.teiv.exception.YangParsingException;
-import org.oran.smo.teiv.exception.YangSchemaException;
 import org.oran.smo.teiv.exception.YangValidationException;
 
 public class IngestionYangParser extends YangModelLoader {
@@ -58,7 +58,7 @@ public class IngestionYangParser extends YangModelLoader {
     private static final List<StatementClassSupplier> EXTENSION_CREATORS = List.of(new IetfExtensionsClassSupplier(),
             new ThreeGppExtensionsClassSupplier());
 
-    public static void loadModels() throws YangSchemaException, YangValidationException {
+    public static void loadModels() throws YangException {
         ParserExecutionContext context = createParserExecutionContext(EXTENSION_CREATORS, List.of(), FILTER_PREDICATES);
         final List<YangModel> yangModels = YangModelLoader.loadModulesFromSchemaRegistry();
         List<YangModel> models = YangModelLoader.parseModelsIntoContext(context, yangModels);
index e8ee177..37d6303 100644 (file)
@@ -23,8 +23,10 @@ package org.oran.smo.teiv.utils.yangparser;
 import java.io.IOException;
 import java.nio.charset.StandardCharsets;
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.Base64;
 import java.util.List;
+import java.util.Locale;
 import java.util.Map;
 import java.util.Objects;
 import java.util.Set;
@@ -43,15 +45,14 @@ import org.oran.smo.teiv.exception.YangParsingException;
 import org.oran.smo.teiv.exception.YangSchemaException;
 import org.oran.smo.teiv.exposure.spi.Module;
 import org.oran.smo.teiv.schema.SchemaRegistry;
+import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
+import org.springframework.core.io.support.ResourcePatternResolver;
+import org.springframework.util.StringUtils;
 
 public abstract class YangModelLoader {
-    private static final Set<String> MODULES_TO_IMPORT = Set.of("_3gpp-common-yang-extensions", "_3gpp-common-yang-types",
-            "ietf-geo-location", "ietf-inet-types", "ietf-yang-types");
 
-    private static final Set<String> MODULES_TO_IMPLEMENT = Set.of("o-ran-smo-teiv-common-yang-extensions",
-            "o-ran-smo-teiv-common-yang-types", "o-ran-smo-teiv-equipment", "o-ran-smo-teiv-oam", "o-ran-smo-teiv-ran",
-            "o-ran-smo-teiv-rel-equipment-ran", "o-ran-smo-teiv-rel-oam-ran", "o-ran-smo-teiv-cloud",
-            "o-ran-smo-teiv-rel-cloud-ran");
+    private static final String IMPORT_MODELS_PATH = "classpath:models/import/*.yang";
+    private static final String IMPLEMENT_MODELS_PATH = "classpath:models/*.yang";
 
     public static ParserExecutionContext createParserExecutionContext(List<StatementClassSupplier> extensions,
             List<CustomProcessor> customProcessors, Set<FindingFilterPredicate> filterPredicates) {
@@ -62,24 +63,37 @@ public abstract class YangModelLoader {
         return context;
     }
 
-    public static List<YangModel> loadModulesFromSchemaRegistry() throws YangSchemaException {
+    public static List<YangModel> loadModulesFromSchemaRegistry() throws YangSchemaException, YangParsingException {
         Map<String, Module> modules = SchemaRegistry.getModuleRegistry();
         if (modules == null) {
             throw YangSchemaException.failedToLoadSchema();
         }
+        List<String> importModels = readYangModelsFromPath(IMPORT_MODELS_PATH);
+        List<String> implementModels = readYangModelsFromPath(IMPLEMENT_MODELS_PATH);
         List<String> implementList = new ArrayList<>();
         List<String> importList = new ArrayList<>();
         modules.values().stream().filter(module -> module.getContent() != null).forEach(module -> {
             String content = new String(Base64.getDecoder().decode(module.getContent()), StandardCharsets.UTF_8);
-            if (MODULES_TO_IMPORT.contains(module.getName())) {
+            if (importModels.contains(module.getName())) {
                 importList.add(content);
-            } else if (MODULES_TO_IMPLEMENT.contains(module.getName())) {
+            } else if (implementModels.contains(module.getName())) {
                 implementList.add(content);
             }
         });
         return createYangModels(importList, implementList);
     }
 
+    public static List<String> readYangModelsFromPath(String modelsPath) throws YangParsingException {
+        try {
+            ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(YangModelLoader.class
+                    .getClassLoader());
+            return Arrays.stream(resolver.getResources(modelsPath)).map(f -> StringUtils.stripFilenameExtension(Objects
+                    .requireNonNull(f.getFilename()).toLowerCase(Locale.ROOT))).toList();
+        } catch (IOException e) {
+            throw YangParsingException.modelDirectoryDoesNotExists();
+        }
+    }
+
     public static List<YangModel> parseModelsIntoContext(ParserExecutionContext context, List<YangModel> yangModelInputs)
             throws YangSchemaException {
         if (yangModelInputs.isEmpty()) {
index 9fe392e..7295227 100644 (file)
@@ -82,32 +82,32 @@ components:
           payload:
             entities:
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
                     attributes:
                       cellLocalId: 4589
                       nRPCI: 12
                       nRTAC: 310
                       sourceIds:
-                        - "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
+                        - "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
                         - "urn:cmHandle:395221E080CCF0FD1924103B15873814"
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
                     attributes:
                       cellLocalId: 4590
                       nRPCI: 32
                       nRTAC: 510
                       sourceIds:
-                        - "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
+                        - "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
                         - "urn:cmHandle:395221E080CCF0FD1924103B15873814"
             relationships:
               - o-ran-smo-teiv-ran:NRCELLDU_USES_NRSECTORCARRIER:
                   - id: "urn:o-ran:smo:teiv:sha512:NRCELLDU_USES_NRSECTORCARRIER=CA576F4716C36A1BD1C506DCB58418FC731858D3D3F856F536813A8C4D3F1CC21292E506815410E04496D709D96066EBC0E4890DEFC3789EDC4BD9C28DA1D52B"
-                    aSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
-                    bSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRSectorCarrier=1"
+                    aSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
+                    bSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRSectorCarrier=1"
               - o-ran-smo-teiv-ran:NRCELLDU_USES_NRSECTORCARRIER:
                   - id: "urn:o-ran:smo:teiv:sha512:NRCELLDU_USES_NRSECTORCARRIER=11AB21444F9D7C6DAC7453879AB5586D294B495E43AC6F94750767DD624014DB7317E9A5EE73239876649D801037D6347355B19C5D97222B3C25000CF8A97C78"
-                    aSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
-                    bSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRSectorCarrier=2"
+                    aSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
+                    bSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRSectorCarrier=2"
           headers:
             ce_specversion: '1.0'
             ce_id: a30e63c9-d29e-46ff-b99a-b63ed83fd233
@@ -132,32 +132,32 @@ components:
           payload:
             entities:
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
                     attributes:
                       cellLocalId: 4579
                       nRPCI: 12
                       nRTAC: 310
                       sourceIds:
-                        - "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
+                        - "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
                         - "urn:cmHandle:395221E080CCF0FD1924103B15873814"
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
                     attributes:
                       cellLocalId: 4580
                       nRPCI: 32
                       nRTAC: 510
                       sourceIds:
-                        - "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
+                        - "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
                         - "urn:cmHandle:395221E080CCF0FD1924103B15873814"
             relationships:
               - o-ran-smo-teiv-ran:NRCELLDU_USES_NRSECTORCARRIER:
                   - id: "urn:o-ran:smo:teiv:sha512:NRCELLDU_USES_NRSECTORCARRIER=CA576F4716C36A1BD1C506DCB58418FC731858D3D3F856F536813A8C4D3F1CC21292E506815410E04496D709D96066EBC0E4890DEFC3789EDC4BD9C28DA1D52B"
-                    aSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
-                    bSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRSectorCarrier=1"
+                    aSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
+                    bSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRSectorCarrier=1"
               - o-ran-smo-teiv-ran:NRCELLDU_USES_NRSECTORCARRIER:
                   - id: "urn:o-ran:smo:teiv:sha512:NRCELLDU_USES_NRSECTORCARRIER=11AB21444F9D7C6DAC7453879AB5586D294B495E43AC6F94750767DD624014DB7317E9A5EE73239876649D801037D6347355B19C5D97222B3C25000CF8A97C78"
-                    aSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
-                    bSide: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRSectorCarrier=2"
+                    aSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
+                    bSide: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRSectorCarrier=2"
           headers:
             ce_specversion: '1.0'
             ce_id: a30e63c9-d29e-46ff-b99a-b63ed83fd234
@@ -182,9 +182,9 @@ components:
           payload:
             entities:
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=1"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=1"
               - o-ran-smo-teiv-ran:NRCellDU:
-                  - id: "urn:3gpp:dn:ManagedElement=1,GNBDUFunction=1,NRCellDU=2"
+                  - id: "urn:3gpp:dn:ManagedElement=1,ODUFunction=1,NRCellDU=2"
             relationships:
               - o-ran-smo-teiv-ran:NRCELLDU_USES_NRSECTORCARRIER:
                   - id: "urn:o-ran:smo:teiv:sha512:NRCELLDU_USES_NRSECTORCARRIER=CA576F4716C36A1BD1C506DCB58418FC731858D3D3F856F536813A8C4D3F1CC21292E506815410E04496D709D96066EBC0E4890DEFC3789EDC4BD9C28DA1D52B"
@@ -212,15 +212,13 @@ components:
       items:
         type: object
         description: Entities schema will adhere to the entity types and
-          attributes mentioned in the yang modules. Refer to EIC Developer
-          Portal for Yang Modules.
+          attributes mentioned in the yang modules.
     relationships:
       type: array
       items:
         type: object
         description: Relationship schema will adhere to the relationship
-          types mentioned in the yang modules. Refer to EIC Developer Portal
-          for Yang Modules.
+          types mentioned in the yang modules.
   messageTraits:
     commonHeaders:
       headers:
index 7e1be03..a827293 100644 (file)
@@ -57,6 +57,10 @@ public class TestPostgresqlContainer extends PostgreSQLContainer<TestPostgresqlC
                     "/pgsqlschema/ingestion-test-model.sql");
             container.withCopyFileToContainer(MountableFile.forClasspathResource("pgsqlschema/ingestion-test-data.sql"),
                     "/pgsqlschema/ingestion-test-data.sql");
+            container.withCopyFileToContainer(MountableFile.forClasspathResource("pgsqlschema/end-to-end-test-model.sql"),
+                    "/pgsqlschema/end-to-end-test-model.sql");
+            container.withCopyFileToContainer(MountableFile.forClasspathResource("pgsqlschema/end-to-end-test-data.sql"),
+                    "/pgsqlschema/end-to-end-test-data.sql");
             container.withCopyFileToContainer(MountableFile.forClasspathResource("pgsqlschema/consumer-data.sql"),
                     "/pgsqlschema/consumer-data.sql");
             container.withCopyFileToContainer(MountableFile.forClasspathResource("pgsqlschema/groups.sql"),
@@ -104,6 +108,17 @@ public class TestPostgresqlContainer extends PostgreSQLContainer<TestPostgresqlC
         }
     }
 
+    public static void loadEndToEndTestData() {
+        try {
+            container.execInContainer("psql", "-U", "test", "-w", "-f", "/pgsqlschema/end-to-end-test-data.sql",
+                    "--set=pguser=test");
+            container.execInContainer("psql", "-U", "test", "-w", "-f", "/pgsqlschema/end-to-end-test-model.sql",
+                    "--set=pguser=test");
+        } catch (UnsupportedOperationException | IOException | InterruptedException e) {
+            throw new RuntimeException(e.getMessage());
+        }
+    }
+
     public static void loadIngestionTestData() {
         try {
             container.execInContainer("psql", "-U", "test", "-w", "-f", "/pgsqlschema/ingestion-test-data.sql",
index e708f2e..faf789a 100644 (file)
@@ -22,28 +22,41 @@ package org.oran.smo.teiv.exposure.api.contract;
 
 import javax.sql.DataSource;
 
+import io.restassured.module.mockmvc.RestAssuredMockMvc;
 import org.jooq.DSLContext;
 import org.jooq.SQLDialect;
 import org.jooq.impl.DSL;
 import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.BeforeEach;
+import org.oran.smo.teiv.CustomMetrics;
 import org.oran.smo.teiv.TopologyApiBase;
 import org.oran.smo.teiv.db.TestPostgresqlContainer;
 import org.oran.smo.teiv.exception.YangException;
+import org.oran.smo.teiv.exposure.audit.LoggerHandler;
+import org.oran.smo.teiv.exposure.classifiers.rest.controller.ClassifiersRequestFilter;
+import org.oran.smo.teiv.exposure.decorators.rest.controller.DecoratorsRequestFilter;
+import org.oran.smo.teiv.service.kafka.KafkaTopicService;
 import org.oran.smo.teiv.startup.SchemaCleanUpHandler;
 import org.oran.smo.teiv.utils.yangparser.ExposureYangParser;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.jdbc.DataSourceBuilder;
 import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
 import org.springframework.boot.test.context.SpringBootTest;
-import org.springframework.boot.test.mock.mockito.MockBean;
+import org.springframework.context.ApplicationContext;
 import org.springframework.test.context.ActiveProfiles;
 
 import com.fasterxml.jackson.databind.ObjectMapper;
 
 import org.oran.smo.teiv.schema.PostgresSchemaLoader;
 import org.oran.smo.teiv.schema.SchemaLoaderException;
+import org.springframework.test.context.bean.override.mockito.MockitoBean;
+import org.springframework.test.web.servlet.MockMvc;
+import org.springframework.test.web.servlet.setup.MockMvcBuilders;
+import org.springframework.web.context.WebApplicationContext;
 
 import java.util.List;
 
+import static org.oran.smo.teiv.utils.TeivConstants.REQUEST_MAPPING;
 import static org.oran.smo.teiv.utils.TeivConstants.TEIV_CONSUMER_DATA_SCHEMA;
 import static org.oran.smo.teiv.utils.TeivConstants.TEIV_DATA_SCHEMA;
 import static org.oran.smo.teiv.utils.TeivConstants.TEIV_MODEL_SCHEMA;
@@ -52,10 +65,22 @@ import static org.oran.smo.teiv.utils.TeivConstants.TEIV_MODEL_SCHEMA;
 @SpringBootTest
 @ActiveProfiles({ "test", "exposure" })
 public abstract class TopologyExposureApiBase extends TopologyApiBase {
+    @Autowired
+    private MockMvc mockMvc;
+    @Autowired
+    private ApplicationContext context;
+    @Autowired
+    private CustomMetrics customMetrics;
+    @Autowired
+    private LoggerHandler loggerHandler;
+    @Autowired
+    private ObjectMapper objectMapper;
 
     // This is required so that "Schema in deleting state" contract test works from 03_postSchemas.groovy
-    @MockBean
+    @MockitoBean
     private SchemaCleanUpHandler schemaCleanUpHandler;
+    @MockitoBean
+    KafkaTopicService kafkaTopicService;
 
     @BeforeAll
     public static void beforeAll() throws SchemaLoaderException, YangException {
@@ -70,4 +95,18 @@ public abstract class TopologyExposureApiBase extends TopologyApiBase {
         postgresSchemaLoader.loadSchemaRegistry();
         ExposureYangParser.loadAndValidateModels();
     }
+
+    @BeforeEach
+    public void setup() {
+        ClassifiersRequestFilter classifiersRequestFilter = new ClassifiersRequestFilter(loggerHandler, objectMapper,
+                customMetrics);
+        DecoratorsRequestFilter decoratorsRequestFilter = new DecoratorsRequestFilter(loggerHandler, objectMapper,
+                customMetrics);
+        mockMvc = MockMvcBuilders.webAppContextSetup((WebApplicationContext) context).addFilter(classifiersRequestFilter,
+                REQUEST_MAPPING + "/classifiers").addFilter(decoratorsRequestFilter, REQUEST_MAPPING + "/decorators")
+                .build();
+
+        RestAssuredMockMvc.mockMvc(mockMvc);
+
+    }
 }
index bd65066..c9b3674 100644 (file)
@@ -179,38 +179,37 @@ class DataRepositoryImplGETRequestsContainerizedTest {
     }
 
     @Test
-    void isTopologyExist_entityTest() throws SchemaRegistryException {
-        EntityType entityType = SchemaRegistry.getEntityTypeByDomainAndName("RAN", "NRCellDU").get(0);
+    void doesTopologyExist_entityTest() throws SchemaRegistryException {
+        EntityType entityType = SchemaRegistry.getEntityTypeByDomainAndName("RAN", "NRCellDU");
         String entityId = "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=19,ODUFunction=19,NRCellDU=91";
-        Assertions.assertTrue(underTest.isTopologyExist(entityType, entityId),
+        Assertions.assertTrue(underTest.doesTopologyExist(entityType, entityId),
                 "That's strange, the result should have been true as this id in DB dataset: " + entityId);
         String nonExistentEntityId = "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=19,ODUFunction=19,NRCellDU=911";
-        Assertions.assertFalse(underTest.isTopologyExist(entityType, nonExistentEntityId),
+        Assertions.assertFalse(underTest.doesTopologyExist(entityType, nonExistentEntityId),
                 "Result should have been false as the entity id is not in DB data set: " + nonExistentEntityId);
     }
 
     @Test
-    void isTopologyExist_relationshipTest() throws SchemaRegistryException {
+    void doesTopologyExist_relationshipTest() throws SchemaRegistryException {
         RelationType relationType = SchemaRegistry.getRelationTypeByDomainAndName("RAN",
-                "NRSECTORCARRIER_USES_ANTENNACAPABILITY").get(0);
+                "NRSECTORCARRIER_USES_ANTENNACAPABILITY");
         String aSideRelationshipId = "urn:o-ran:smo:teiv:sha512:NRSECTORCARRIER_USES_ANTENNACAPABILITY=11EDFC31E2BE240D3CB15DB1A3FA3B78C828524BC8FCA3365A615129A61A627C21DA8EBF6DD788CDBDEC668344D1F79A371749083D6AE04DDDD57CB4FA8C3ECB";
-        Assertions.assertTrue(underTest.isTopologyExist(relationType, aSideRelationshipId),
+        Assertions.assertTrue(underTest.doesTopologyExist(relationType, aSideRelationshipId),
                 "That's strange, the result should have been true as this id in DB dataset: " + aSideRelationshipId);
 
-        relationType = SchemaRegistry.getRelationTypeByDomainAndName("REL_OAM_RAN", "MANAGEDELEMENT_MANAGES_OCUUPFUNCTION")
-                .get(0);
+        relationType = SchemaRegistry.getRelationTypeByDomainAndName("REL_OAM_RAN", "MANAGEDELEMENT_MANAGES_OCUUPFUNCTION");
         String bSideRelationshipId = "urn:o-ran:smo:teiv:sha512:MANAGEDELEMENT_MANAGES_OCUUPFUNCTION=5255F37093F8EB3763CE5F017DFC1E162B44FC9DF6E13744C04DC1832C5E754AB7BE440DBE1187EE8EEE42FD04E652BB8148655C6F977B1FFDDA54FE87C6411A";
-        Assertions.assertTrue(underTest.isTopologyExist(relationType, bSideRelationshipId),
+        Assertions.assertTrue(underTest.doesTopologyExist(relationType, bSideRelationshipId),
                 "That's strange, the result should have been true as this id in DB dataset: " + bSideRelationshipId);
 
         relationType = SchemaRegistry.getRelationTypeByDomainAndName("REL_EQUIPMENT_RAN",
-                "ANTENNAMODULE_SERVES_ANTENNACAPABILITY").get(0);
+                "ANTENNAMODULE_SERVES_ANTENNACAPABILITY");
         String manyToManyRelationshipId = "urn:o-ran:smo:teiv:sha512:ANTENNAMODULE_SERVES_ANTENNACAPABILITY=ABD52B030DF1169F9F41C898913EF30F7BB5741F53352F482310B280C90AC569B7D31D52A2BB41F1F0099AE1EDD56CACF0B285D145A5584D376DD45DED1E2D65";
-        Assertions.assertTrue(underTest.isTopologyExist(relationType, manyToManyRelationshipId),
+        Assertions.assertTrue(underTest.doesTopologyExist(relationType, manyToManyRelationshipId),
                 "That's strange, the result should have been true as this id in DB dataset: " + manyToManyRelationshipId);
 
         String nonExistentRelationshipId = "urn:o-ran:smo:teiv:sha512:MANAGEDELEMENT_MANAGES_OCUUPFUNCTION=5255F37093F8EB3763CE5F017DFC1E162B44FC9DF6E13744C04DC1832C5E754AB7BE440DBE1187EE8EEE42FD04E652BB8148655C6F977B1FFDDA54FE87C6411A";
-        Assertions.assertFalse(underTest.isTopologyExist(relationType, nonExistentRelationshipId),
+        Assertions.assertFalse(underTest.doesTopologyExist(relationType, nonExistentRelationshipId),
                 "Result should have been false as the relationship id is not in DB data set: " + nonExistentRelationshipId);
     }
 
index 66f397e..4d6c458 100644 (file)
@@ -733,12 +733,31 @@ class DtoToJooqTest {
         alb.setChildren(List.of(scopeObject1, scopeObject2));
         Condition actualCondition = alb.getCondition();
         // spotless:off
-        assertEquals(condition(
-            "\n" +
-                "  teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"REL_FK_managed-by-managedElement\" is not null\n" +
-                "  and teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"id\" = 'odu1'\n" +
-                "  and teiv_data.\"o-ran-smo-teiv-ran_OCUCPFunction\".\"REL_FK_managed-by-managedElement\" is not null\n")
-            .toString(), actualCondition.toString());
+        assertEquals(
+            condition(
+                "\n" +
+                    "  exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"REL_FK_managed-by-managedElement\" is not null\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"id\" = 'odu1'\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"REL_FK_managed-by-managedElement\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-oam_ManagedElement\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n" +
+                    "  and exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"o-ran-smo-teiv-ran_OCUCPFunction\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"o-ran-smo-teiv-ran_OCUCPFunction\".\"REL_FK_managed-by-managedElement\" is not null\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-ran_OCUCPFunction\".\"REL_FK_managed-by-managedElement\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-oam_ManagedElement\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n"
+            ).toString(),
+            actualCondition.toString()
+        );
         // spotless:on
     }
 
@@ -775,14 +794,31 @@ class DtoToJooqTest {
         alb.setChildren(List.of(scopeObject1, scopeObject2));
         Condition actualCondition = alb.getCondition();
         // spotless:off
-        assertEquals(condition(
-            "\n" +
-                "  (\n" +
-                "    teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n" +
-                "    and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\" = 'am1'\n" +
-                "  )\n" +
-                "  or teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n")
-            .toString(), actualCondition.toString());
+        assertEquals(
+            condition(
+                "\n" +
+                    "  exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\" = 'am1'\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-equipment_Site\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n" +
+                    "  or exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n" +
+                    "      and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-equipment_Site\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n"
+            ).toString(),
+            actualCondition.toString()
+        );
         // spotless:on
     }
 
@@ -793,20 +829,33 @@ class DtoToJooqTest {
                 .innerContainer(List.of()).leaf("id").queryFunction(QueryFunction.CONTAINS).parameter("am1").build());
         Condition actualCondition = scopeObject1.getCondition();
         // spotless:off
-        assertEquals(condition(
-            "\n" +
-                "teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n" +
-                "and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\" like (" +
-                "('%' || replace(" + "\n"+
-                "replace(" + "\n"+
-                "replace('am1', '!', '!!')," + "\n"+
-                "'%'," + "\n"+
-                "'!%'" + "\n"+
-                ")," + "\n"+
-                "'_'," + "\n"+
-                "'!_'" + "\n"+
-                ")) || '%') escape '!'" + "\n")
-            .toString().replace(" ", ""), actualCondition.toString().replace(" ", ""));
+        String expectedCondition = condition(
+            "exists (\n" +
+                "  select 1 \"one\"\n" +
+                "  from teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\"\n" +
+                "  where (\n" +
+                "    teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\" is not null\n" +
+                "    and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\" like (('%' || replace(\n" +
+                "      replace(\n" +
+                "        replace('am1', '!', '!!'),\n" +
+                "        '%',\n" +
+                "        '!%'\n" +
+                "      ),\n" +
+                "      '_',\n" +
+                "      '!_'\n" +
+                "    )) || '%') escape '!'\n" +
+                "    and teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"REL_FK_installed-at-site\"=" +
+                "teiv_data.\"o-ran-smo-teiv-equipment_Site\".\"id\"\n" +
+                "  )\n" +
+                ")"
+        ).toString();
+
+        // Remove outer parentheses if they exist
+        if (expectedCondition.startsWith("(") && expectedCondition.endsWith(")")) {
+            expectedCondition = expectedCondition.substring(1, expectedCondition.length() - 1);
+        }
+
+        assertEquals(expectedCondition, actualCondition.toString());
         // spotless:on
     }
 
@@ -818,17 +867,32 @@ class DtoToJooqTest {
                 .parameter("ac1").build());
         Condition actualCondition = scopeObject1.getCondition();
         // spotless:off
-        assertEquals(("teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"" +
-            ".\"bSide_AntennaCapability\"like(('%'||replace(" + "\n"+
-            "replace(" + "\n"+
-            "replace('ac1','!','!!')," + "\n"+
-            "'%'," + "\n"+
-            "'!%'" + "\n"+
-            ")," + "\n"+
-            "'_'," + "\n"+
-            "'!_'" + "\n"+
-            "))||'%')escape'!'")
-            .replace(" ", ""), actualCondition.toString().replace(" ", ""));
+        String expectedCondition = condition(
+            "exists (\n" +
+                "  select 1 \"one\"\n" +
+                "  from teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"\n" +
+                "  where (\n" +
+                "    teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\" like (('%' || replace(\n" +
+                "      replace(\n" +
+                "        replace('ac1', '!', '!!'),\n" +
+                "        '%',\n" +
+                "        '!%'\n" +
+                "      ),\n" +
+                "      '_',\n" +
+                "      '!_'\n" +
+                "    )) || '%') escape '!'\n" +
+                "    and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"aSide_AntennaModule\"=" +
+                "teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\"\n" +
+                "  )\n" +
+                ")"
+        ).toString();
+
+        // Remove outer parentheses if they exist
+        if (expectedCondition.startsWith("(") && expectedCondition.endsWith(")")) {
+            expectedCondition = expectedCondition.substring(1, expectedCondition.length() - 1);
+        }
+
+        assertEquals(expectedCondition, actualCondition.toString());
         // spotless:on
     }
 
@@ -867,11 +931,30 @@ class DtoToJooqTest {
         alb.setChildren(List.of(scopeObject1, scopeObject2));
         Condition actualCondition = alb.getCondition();
         // spotless:off
-        assertEquals(condition(
-            "\n" +
-                "  teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\" = 'ac1'\n" +
-                "  and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".id is not null\n")
-            .toString(), actualCondition.toString());
+        assertEquals(
+            condition(
+                "\n" +
+                    "  exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\" = 'ac1'\n" +
+                    "      and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"aSide_AntennaModule\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n" +
+                    "  and exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".id is not null\n" +
+                    "      and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"aSide_AntennaModule\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-equipment_AntennaModule\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n"
+            ).toString(),
+            actualCondition.toString()
+        );
         // spotless:on
     }
 
@@ -889,11 +972,30 @@ class DtoToJooqTest {
         alb.setChildren(List.of(scopeObject1, scopeObject2));
         Condition actualCondition = alb.getCondition();
         // spotless:off
-        assertEquals(condition(
-            "\n" +
-                "  teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"aSide_AntennaModule\" = 'am1'\n" +
-                "  and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".id is not null\n")
-            .toString(), actualCondition.toString());
+        assertEquals(
+            condition(
+                "\n" + // Keeping the initial newline for consistency
+                    "  exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"aSide_AntennaModule\" = 'am1'\n" +
+                    "      and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-ran_AntennaCapability\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n" +
+                    "  and exists (\n" +
+                    "    select 1 \"one\"\n" +
+                    "    from teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"\n" +
+                    "    where (\n" +
+                    "      teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".id is not null\n" +
+                    "      and teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\"=" +
+                    "teiv_data.\"o-ran-smo-teiv-ran_AntennaCapability\".\"id\"\n" +
+                    "    )\n" +
+                    "  )\n"
+            ).toString(),
+            actualCondition.toString()
+        );
         // spotless:on
     }
 
@@ -1238,14 +1340,14 @@ class DtoToJooqTest {
     }
 
     @Test
-    void testGetJoinCondition() {
+    void testWhereExistsCondition() {
         LogicalBlock slb1 = new ScopeLogicalBlock(ScopeObject.builder("ODUFunction/provided-nrCellDu").topologyObjectType(
                 TopologyObjectType.ASSOCIATION).innerContainer(List.of()).build());
         InnerFilterCriteria innerFilterCriteria1 = InnerFilterCriteria.builder().scope(slb1).build();
         Pair<String, Field> pair1 = new ImmutablePair<>("teiv_data.\"o-ran-smo-teiv-ran_NRCellDU\"", field(
                 "teiv_data.\"o-ran-smo-teiv-ran_NRCellDU\".\"REL_FK_provided-by-oduFunction\"" + "=" + "teiv_data.\"o-ran-smo-teiv-ran_ODUFunction\".\"id\""));
         Assertions.assertEquals(new HashSet(Arrays.asList(pair1)), innerFilterCriteria1.builder().scope(slb1).build()
-                .getJoinCondition());
+                .getWhereExistsCondition());
         LogicalBlock slb2 = new ScopeLogicalBlock(ScopeObject.builder("AntennaCapability/serving-antennaModule")
                 .topologyObjectType(TopologyObjectType.ASSOCIATION).container(ContainerType.ID).innerContainer(List.of())
                 .build());
@@ -1253,6 +1355,6 @@ class DtoToJooqTest {
         Pair<String, Field> pair2 = new ImmutablePair<>("teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\"", field(
                 "teiv_data.\"CFC235E0404703D1E4454647DF8AAE2C193DB402\".\"bSide_AntennaCapability\"" + "=" + "teiv_data.\"o-ran-smo-teiv-ran_AntennaCapability\".\"id\""));
         Assertions.assertEquals(new HashSet(Arrays.asList(pair2)), innerFilterCriteria2.builder().scope(slb2).build()
-                .getJoinCondition());
+                .getWhereExistsCondition());
     }
 }
index fd6731d..06cd680 100644 (file)
@@ -20,6 +20,7 @@
  */
 package org.oran.smo.teiv.exposure.teivpath.refiner;
 
+import static org.junit.jupiter.api.Assertions.assertEquals;
 import static org.oran.smo.teiv.utils.TeivConstants.ID_COLUMN_NAME;
 import static org.oran.smo.teiv.utils.TeivConstants.ITEM;
 import static org.oran.smo.teiv.utils.TeivConstants.WILDCARD;
@@ -100,7 +101,7 @@ class BasePathRefinementTest {
         expectedScopeObject.setDataType(DataType.PRIMITIVE);
         expectedTargets.get(0).setTopologyObjectType(TopologyObjectType.ENTITY);
         expectedTargets.get(0).setAllParamQueried(true);
-        Assertions.assertEquals(expectedFilterCriteria, filterCriteria);
+        assertEquals(expectedFilterCriteria, filterCriteria);
     }
 
     @Test
@@ -126,7 +127,7 @@ class BasePathRefinementTest {
         expectedScopeObject.setDataType(DataType.PRIMITIVE);
         expectedTargets.get(0).setTopologyObjectType(TopologyObjectType.ENTITY);
         expectedTargets.get(0).setAllParamQueried(false);
-        Assertions.assertEquals(expectedFilterCriteria, filterCriteria);
+        assertEquals(expectedFilterCriteria, filterCriteria);
     }
 
     @Test
@@ -138,7 +139,7 @@ class BasePathRefinementTest {
         ScopeObject scopeObjectResult1 = ScopeObject.builder(WILDCARD + "/managed-by-managedElement").container(
                 ContainerType.ID).innerContainer(List.of()).resolverDataType(ResolverDataType.STRING).queryFunction(
                         QueryFunction.EQ).leaf(null).parameter("me1").build();
-        Assertions.assertEquals(scopeObjectResult1, ((ScopeLogicalBlock) logicalBlock1).getScopeObject());
+        assertEquals(scopeObjectResult1, ((ScopeLogicalBlock) logicalBlock1).getScopeObject());
         LogicalBlock logicalBlock2 = scopeResolver.process(ODU_FUNCTION, "/managed-by-managedElement");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock2).build()));
         basePathRefinement.handleAssociationsInScope((ScopeLogicalBlock) logicalBlock2, "RAN");
@@ -146,7 +147,7 @@ class BasePathRefinementTest {
         ScopeObject scopeObjectResult2 = ScopeObject.builder(ODU_FUNCTION + "/managed-by-managedElement")
                 .topologyObjectType(TopologyObjectType.ASSOCIATION).container(ContainerType.NOT_NULL).resolverDataType(
                         ResolverDataType.NOT_NULL).queryFunction(QueryFunction.NOT_NULL).build();
-        Assertions.assertEquals(scopeObjectResult2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
+        assertEquals(scopeObjectResult2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
         LogicalBlock logicalBlock3 = scopeResolver.process(null, "/ODUFUNCTION_PROVIDES_NRCELLDU");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock3).build()));
         Assertions.assertThrows(TeivPathException.class, () -> basePathRefinement
@@ -156,7 +157,7 @@ class BasePathRefinementTest {
         basePathRefinement.processTopologyObjectsWithContainerTypeNull(filterCriteria);
         ScopeObject scopeObjectResult4 = ScopeObject.builder(WILDCARD + "/" + ODU_FUNCTION).container(ContainerType.ID)
                 .resolverDataType(ResolverDataType.STRING).queryFunction(QueryFunction.EQ).parameter("odu1").build();
-        Assertions.assertEquals(scopeObjectResult4, ((ScopeLogicalBlock) logicalBlock4).getScopeObject());
+        assertEquals(scopeObjectResult4, ((ScopeLogicalBlock) logicalBlock4).getScopeObject());
         try (MockedStatic<SchemaRegistry> utilities = Mockito.mockStatic(SchemaRegistry.class)) {
             utilities.when(() -> SchemaRegistry.getEntityNamesByDomain("RAN")).thenReturn(Arrays.asList(
                     "RelationAndEntity"));
@@ -181,7 +182,7 @@ class BasePathRefinementTest {
         ScopeObject scopeObjectResult9 = ScopeObject.builder("*/NRCellDU").container(ContainerType.ATTRIBUTES)
                 .resolverDataType(ResolverDataType.INTEGER).queryFunction(QueryFunction.EQ).leaf("nCI").parameter("12")
                 .build();
-        Assertions.assertEquals(scopeObjectResult9, ((ScopeLogicalBlock) logicalBlock9).getScopeObject());
+        assertEquals(scopeObjectResult9, ((ScopeLogicalBlock) logicalBlock9).getScopeObject());
         LogicalBlock logicalBlock10 = scopeResolver.process(null, "/NRCellDU[@nCI=12]");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock10).build()));
         Assertions.assertThrows(TeivPathException.class, () -> basePathRefinement
@@ -215,8 +216,8 @@ class BasePathRefinementTest {
         resultTargetObjects.add(targetObjectResult);
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects, filterCriteria.getTargets());
-        Assertions.assertEquals(scopeResult1, filterCriteria.getScope());
+        assertEquals(resultTargetObjects, filterCriteria.getTargets());
+        assertEquals(scopeResult1, filterCriteria.getScope());
     }
 
     @Test
@@ -234,7 +235,7 @@ class BasePathRefinementTest {
         basePathRefinement.handleAssociationsInScope((ScopeLogicalBlock) filterCriteria.getScope(), "RAN");
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects3_1, filterCriteria.getTargets());
+        assertEquals(resultTargetObjects3_1, filterCriteria.getTargets());
     }
 
     @Test
@@ -254,7 +255,7 @@ class BasePathRefinementTest {
         resultTargetObjects4_1.add(targetObjectResult4_2);
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects4_1, filterCriteria.getTargets());
+        assertEquals(resultTargetObjects4_1, filterCriteria.getTargets());
     }
 
     @Test
@@ -307,8 +308,8 @@ class BasePathRefinementTest {
         resultTargetObjects5_1.add(targetObjectResult5_2);
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects5_1, filterCriteria.getTargets());
-        Assertions.assertEquals(or1, filterCriteria.getScope());
+        assertEquals(resultTargetObjects5_1, filterCriteria.getTargets());
+        assertEquals(or1, filterCriteria.getScope());
     }
 
     @Test
@@ -328,8 +329,8 @@ class BasePathRefinementTest {
                 "cellLocalId").queryFunction(QueryFunction.EQ).parameter("156").resolverDataType(ResolverDataType.INTEGER)
                 .build();
         LogicalBlock logicalBlockResult6_1 = new ScopeLogicalBlock(scopeObjectResult6_1);
-        Assertions.assertEquals(resultTargetObjects6_1, filterCriteria.getTargets());
-        Assertions.assertEquals(logicalBlockResult6_1, filterCriteria.getScope());
+        assertEquals(resultTargetObjects6_1, filterCriteria.getTargets());
+        assertEquals(logicalBlockResult6_1, filterCriteria.getScope());
     }
 
     @Test
@@ -396,8 +397,8 @@ class BasePathRefinementTest {
         resultTargetObjects9_1.add(targetObjectResult9_2);
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects9_1, filterCriteria.getTargets());
-        Assertions.assertEquals(or, filterCriteria.getScope());
+        assertEquals(resultTargetObjects9_1, filterCriteria.getTargets());
+        assertEquals(or, filterCriteria.getScope());
     }
 
     @Test
@@ -472,8 +473,8 @@ class BasePathRefinementTest {
         resultTargetObjects11_1.add(targetObjectResult11_2);
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects11_1, filterCriteria.getTargets());
-        Assertions.assertEquals(or1, filterCriteria.getScope());
+        assertEquals(resultTargetObjects11_1, filterCriteria.getTargets());
+        assertEquals(or1, filterCriteria.getScope());
     }
 
     @Test
@@ -557,8 +558,8 @@ class BasePathRefinementTest {
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria2, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
 
-        Assertions.assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
-        Assertions.assertEquals(or1, filterCriteria2.getScope());
+        assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
+        assertEquals(or1, filterCriteria2.getScope());
     }
 
     @Test
@@ -575,7 +576,7 @@ class BasePathRefinementTest {
                 .of(filterCriteria)).build());
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.ENTITY);
-        Assertions.assertEquals(resultTargetObjects9_1, filterCriteria.getTargets());
+        assertEquals(resultTargetObjects9_1, filterCriteria.getTargets());
     }
 
     @Test
@@ -589,7 +590,7 @@ class BasePathRefinementTest {
                 .of(filterCriteria)).build());
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.RELATIONSHIP);
-        Assertions.assertEquals(new ScopeLogicalBlock(scopeObject), filterCriteria.getScope());
+        assertEquals(new ScopeLogicalBlock(scopeObject), filterCriteria.getScope());
     }
 
     @Test
@@ -630,8 +631,8 @@ class BasePathRefinementTest {
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria2, "RAN",
                 FilterCriteria.ResolvingTopologyObjectType.RELATIONSHIP);
 
-        Assertions.assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
-        Assertions.assertEquals(or1, filterCriteria2.getScope());
+        assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
+        assertEquals(or1, filterCriteria2.getScope());
     }
 
     @Test
@@ -701,8 +702,8 @@ class BasePathRefinementTest {
         basePathRefinement.resolveWildCardObjectsInScopeAndTarget(filterCriteria2, "REL_OAM_RAN",
                 FilterCriteria.ResolvingTopologyObjectType.RELATIONSHIP);
 
-        Assertions.assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
-        Assertions.assertEquals(or1, filterCriteria2.getScope());
+        assertEquals(resultTargetObjectsResult13_1, filterCriteria2.getTargets());
+        assertEquals(or1, filterCriteria2.getScope());
     }
 
     @Test
@@ -720,15 +721,15 @@ class BasePathRefinementTest {
             utilities.when(() -> SchemaRegistry.getRelationNamesByDomain("RAN")).thenReturn(Arrays.asList(
                     "ODUFUNCTION_PROVIDES_NRCELLDU"));
             basePathRefinement.resolveUndefinedTopologyObjectTypes(filterCriteria);
-            Assertions.assertEquals(TopologyObjectType.ENTITY, filterCriteria.getFilterCriteriaList().get(0).getTargets()
-                    .get(0).getTopologyObjectType());
-            Assertions.assertEquals(TopologyObjectType.ENTITY, ((ScopeLogicalBlock) filterCriteria.getFilterCriteriaList()
-                    .get(0).getScope()).getScopeObject().getTopologyObjectType());
+            assertEquals(TopologyObjectType.ENTITY, filterCriteria.getFilterCriteriaList().get(0).getTargets().get(0)
+                    .getTopologyObjectType());
+            assertEquals(TopologyObjectType.ENTITY, ((ScopeLogicalBlock) filterCriteria.getFilterCriteriaList().get(0)
+                    .getScope()).getScopeObject().getTopologyObjectType());
             filterCriteria.getFilterCriteriaList().get(0).setScope(EmptyLogicalBlock.getInstance());
             targetObject.setTopologyObjectType(TopologyObjectType.UNDEFINED);
             basePathRefinement.resolveUndefinedTopologyObjectTypes(filterCriteria);
-            Assertions.assertEquals(TopologyObjectType.ENTITY, filterCriteria.getFilterCriteriaList().get(0).getTargets()
-                    .get(0).getTopologyObjectType());
+            assertEquals(TopologyObjectType.ENTITY, filterCriteria.getFilterCriteriaList().get(0).getTargets().get(0)
+                    .getTopologyObjectType());
         }
     }
 
@@ -747,10 +748,10 @@ class BasePathRefinementTest {
             utilities.when(() -> SchemaRegistry.getRelationNamesByDomain("RAN")).thenReturn(Arrays.asList(
                     "ODUFUNCTION_PROVIDES_NRCELLDU"));
             basePathRefinement.resolveUndefinedTopologyObjectTypes(filterCriteria);
-            Assertions.assertEquals(TopologyObjectType.RELATION, filterCriteria.getFilterCriteriaList().get(0).getTargets()
-                    .get(0).getTopologyObjectType());
-            Assertions.assertEquals(TopologyObjectType.RELATION, ((ScopeLogicalBlock) filterCriteria.getFilterCriteriaList()
-                    .get(0).getScope()).getScopeObject().getTopologyObjectType());
+            assertEquals(TopologyObjectType.RELATION, filterCriteria.getFilterCriteriaList().get(0).getTargets().get(0)
+                    .getTopologyObjectType());
+            assertEquals(TopologyObjectType.RELATION, ((ScopeLogicalBlock) filterCriteria.getFilterCriteriaList().get(0)
+                    .getScope()).getScopeObject().getTopologyObjectType());
         }
     }
 
@@ -891,7 +892,7 @@ class BasePathRefinementTest {
         LogicalBlock logicalBlock1 = scopeResolver.process(ODU_FUNCTION, "/attributes[@gNBId=21]");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock1).build()));
         basePathRefinement.validateScopeParametersDataType(filterCriteria);
-        Assertions.assertEquals(DataType.BIGINT, ((ScopeLogicalBlock) logicalBlock1).getScopeObject().getDataType());
+        assertEquals(DataType.BIGINT, ((ScopeLogicalBlock) logicalBlock1).getScopeObject().getDataType());
         // error reason: for gNBId attribute string value is not accepted
         LogicalBlock logicalBlock2 = scopeResolver.process(ODU_FUNCTION, "/attributes[@gNBId='abc']");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock2).build()));
@@ -909,7 +910,7 @@ class BasePathRefinementTest {
                 .resolverDataType(ResolverDataType.STRING).build());
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(scopeLogicalBlock1).build()));
         basePathRefinement.validateScopeParametersDataType(filterCriteria);
-        Assertions.assertEquals(DataType.PRIMITIVE, scopeLogicalBlock1.getScopeObject().getDataType());
+        assertEquals(DataType.PRIMITIVE, scopeLogicalBlock1.getScopeObject().getDataType());
         // error reason: scopeFilter: /managed-by-managedElement[@id=1] -> ResolverDataType is INTEGER, but in case of id it should be STRING
         ScopeLogicalBlock scopeLogicalBlock2 = new ScopeLogicalBlock(ScopeObject.builder(ODU_FUNCTION).innerContainer(
                 new ArrayList<>(Arrays.asList("managed-by-managedElement"))).container(ContainerType.ID).topologyObjectType(
@@ -930,7 +931,7 @@ class BasePathRefinementTest {
         LogicalBlock logicalBlock4 = scopeResolver.process(ODU_FUNCTION, "/ODUFunction[@id='odu1']");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock4).build()));
         basePathRefinement.validateScopeParametersDataType(filterCriteria);
-        Assertions.assertEquals(DataType.PRIMITIVE, ((ScopeLogicalBlock) logicalBlock4).getScopeObject().getDataType());
+        assertEquals(DataType.PRIMITIVE, ((ScopeLogicalBlock) logicalBlock4).getScopeObject().getDataType());
         // error reason: for id INTEGER ResolverDataType is not accepted
         LogicalBlock logicalBlock5 = scopeResolver.process(ODU_FUNCTION, "/ODUFunction[@id=1]");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock5).build()));
@@ -945,7 +946,7 @@ class BasePathRefinementTest {
         LogicalBlock logicalBlock7 = scopeResolver.process(ODU_FUNCTION, "/sourceIds[@items = 'someSourceId']");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock7).build()));
         basePathRefinement.validateScopeParametersDataType(filterCriteria);
-        Assertions.assertEquals(DataType.PRIMITIVE, scopeLogicalBlock1.getScopeObject().getDataType());
+        assertEquals(DataType.PRIMITIVE, scopeLogicalBlock1.getScopeObject().getDataType());
         // error reason: for sourceIds container INTEGER dataType is not accepted
         LogicalBlock logicalBlock8 = scopeResolver.process(ODU_FUNCTION, "/sourceIds[@items = 1]");
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(logicalBlock8).build()));
@@ -1079,8 +1080,8 @@ class BasePathRefinementTest {
                 targetObject3)).scope(fc2or1).build();
         InnerFilterCriteria innerFilterCriteria3 = InnerFilterCriteria.builder().targets(List.of(targetObject4)).scope(
                 fc3and1).build();
-        Assertions.assertEquals(Set.of(innerFilterCriteria1, innerFilterCriteria2, innerFilterCriteria3), new HashSet<>(
-                filterCriteria.getFilterCriteriaList()));
+        assertEquals(Set.of(innerFilterCriteria1, innerFilterCriteria2, innerFilterCriteria3), new HashSet<>(filterCriteria
+                .getFilterCriteriaList()));
     }
 
     @Test
@@ -1107,7 +1108,7 @@ class BasePathRefinementTest {
         scopeLogicalBlock6.setValid(false);
         filterCriteria.setFilterCriteriaList(List.of(InnerFilterCriteria.builder().scope(orLogicalBlock1).build()));
         basePathRefinement.validateQuery(filterCriteria);
-        Assertions.assertEquals(andLogicalBlock2, filterCriteria.getFilterCriteriaList().get(0).getScope());
+        assertEquals(andLogicalBlock2, filterCriteria.getFilterCriteriaList().get(0).getScope());
         ScopeLogicalBlock scopeLogicalBlock2_1 = new ScopeLogicalBlock(null);
         ScopeLogicalBlock scopeLogicalBlock2_2 = new ScopeLogicalBlock(null);
         AndOrLogicalBlock andLogicalBlock2_1 = new AndLogicalBlock();
@@ -1149,10 +1150,10 @@ class BasePathRefinementTest {
         orLogicalBlock.setChildren(Arrays.asList(orLogicalBlockChild1, orLogicalBlockChild2));
         basePathRefinement.runOnTree(orLogicalBlock, filterCriteria.getDomain(), (ScopeLogicalBlock lb, String domain) -> lb
                 .getScopeObject().setParameter("0"));
-        Assertions.assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock1).getScopeObject().getParameter());
-        Assertions.assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock2).getScopeObject().getParameter());
-        Assertions.assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock3).getScopeObject().getParameter());
-        Assertions.assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock4).getScopeObject().getParameter());
+        assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock1).getScopeObject().getParameter());
+        assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock2).getScopeObject().getParameter());
+        assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock3).getScopeObject().getParameter());
+        assertEquals("0", ((ScopeLogicalBlock) scopeLogicalBlock4).getScopeObject().getParameter());
     }
 
     @Test
@@ -1165,8 +1166,8 @@ class BasePathRefinementTest {
 
         TeivPathException thrown = Assertions.assertThrows(TeivPathException.class, () -> basePathRefinement.refine(
                 filterCriteria));
-        Assertions.assertEquals("Querying any thing other than id is not supported in case of association of relation",
-                thrown.getDetails());
+        assertEquals("Querying any thing other than id is not supported in case of association of relation", thrown
+                .getDetails());
 
     }
 
@@ -1199,7 +1200,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria);
 
-        Assertions.assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
+        assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
 
         LogicalBlock logicalBlock2 = scopeResolver.resolve("NRCellDU",
                 "/serving-antennaModule/attributes[coveredBy(@geo-location, 'POLYGON((48 68, 50 68, 50 69, 48 69, 48 68))')]");
@@ -1221,7 +1222,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria2);
 
-        Assertions.assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
+        assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
 
         LogicalBlock logicalBlock3 = scopeResolver.resolve("NRCellDU",
                 "/serving-antennaModule/attributes[withinMeters(@geo-location, 'POINT(49.40199 68.94199)', 500)]");
@@ -1243,7 +1244,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria3);
 
-        Assertions.assertEquals(expectedScopeObject3, ((ScopeLogicalBlock) logicalBlock3).getScopeObject());
+        assertEquals(expectedScopeObject3, ((ScopeLogicalBlock) logicalBlock3).getScopeObject());
 
         LogicalBlock logicalBlock4 = scopeResolver.resolve("NRCellDU",
                 "/serving-antennaModule/attributes[@antennaModelNumber='5']");
@@ -1265,7 +1266,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria4);
 
-        Assertions.assertEquals(expectedScopeObject4, ((ScopeLogicalBlock) logicalBlock4).getScopeObject());
+        assertEquals(expectedScopeObject4, ((ScopeLogicalBlock) logicalBlock4).getScopeObject());
 
         LogicalBlock logicalBlock5 = scopeResolver.resolve(null,
                 "/serving-antennaModule/attributes[@antennaModelNumber='5']");
@@ -1286,7 +1287,7 @@ class BasePathRefinementTest {
         expectedScopeObject5.setDataType(DataType.PRIMITIVE);
 
         basePathRefinement.refine(filterCriteria5);
-        Assertions.assertEquals(new ScopeLogicalBlock(expectedScopeObject5), filterCriteria5.getFilterCriteriaList().get(0)
+        assertEquals(new ScopeLogicalBlock(expectedScopeObject5), filterCriteria5.getFilterCriteriaList().get(0)
                 .getScope());
 
     }
@@ -1314,7 +1315,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria);
 
-        Assertions.assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
+        assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
 
         LogicalBlock logicalBlock2 = scopeResolver.resolve("NRCellDU",
                 "/serving-antennaModule/sourceIds[contains(@item,'urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,Equipment=1,AntennaUnitGroup=1,AntennaUnit=1,AntennaSubunit=1')]");
@@ -1337,7 +1338,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria2);
 
-        Assertions.assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
+        assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
 
     }
 
@@ -1371,7 +1372,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria);
 
-        Assertions.assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
+        assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
 
         LogicalBlock logicalBlock2 = scopeResolver.resolve("NRCellDU",
                 "/serving-antennaModule/classifiers[contains(@item,'app-module:Rural')]");
@@ -1393,7 +1394,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria2);
 
-        Assertions.assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
+        assertEquals(expectedScopeObject2, ((ScopeLogicalBlock) logicalBlock2).getScopeObject());
     }
 
     @Test
@@ -1418,7 +1419,7 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria);
 
-        Assertions.assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
+        assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
 
     }
 
@@ -1444,6 +1445,6 @@ class BasePathRefinementTest {
 
         basePathRefinement.refine(filterCriteria);
 
-        Assertions.assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
+        assertEquals(expectedScopeObject, ((ScopeLogicalBlock) logicalBlock).getScopeObject());
     }
 }
index d29dd26..46838e9 100644 (file)
@@ -36,12 +36,11 @@ import org.jooq.impl.DSL;
 import org.junit.jupiter.api.BeforeAll;
 import org.junit.jupiter.api.BeforeEach;
 import org.oran.smo.teiv.exposure.audit.LoggerHandler;
-import org.oran.smo.teiv.groups.utils.GroupCreationRequestFilter;
+import org.oran.smo.teiv.groups.rest.controller.GroupCreationRequestFilter;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.jdbc.DataSourceBuilder;
 import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
 import org.springframework.boot.test.context.SpringBootTest;
-import org.springframework.boot.test.mock.mockito.MockBean;
 import org.springframework.test.context.ActiveProfiles;
 
 import com.fasterxml.jackson.databind.ObjectMapper;
@@ -64,7 +63,9 @@ public abstract class TopologyGroupsApiBase extends TopologyApiBase {
     private ApplicationContext context;
     @Autowired
     private MockMvc mockMvc;
-    @MockBean
+    @Autowired
+    private ObjectMapper objectMapper;
+    @Autowired
     private LoggerHandler loggerHandler;
 
     @BeforeAll
@@ -82,7 +83,7 @@ public abstract class TopologyGroupsApiBase extends TopologyApiBase {
 
     @BeforeEach
     public void setup() {
-        GroupCreationRequestFilter groupCreationRequestFilter = new GroupCreationRequestFilter(loggerHandler);
+        GroupCreationRequestFilter groupCreationRequestFilter = new GroupCreationRequestFilter(loggerHandler, objectMapper);
         mockMvc = MockMvcBuilders.webAppContextSetup((WebApplicationContext) context).addFilter(groupCreationRequestFilter,
                 "/topology-inventory/v1alpha11/groups").build();
 
index 5c4c40e..d265c55 100644 (file)
@@ -43,6 +43,7 @@ import org.jooq.Result;
 import org.junit.jupiter.api.BeforeAll;
 import org.junit.jupiter.api.BeforeEach;
 import org.junit.jupiter.api.Test;
+import org.junit.jupiter.api.TestInstance;
 import org.junit.jupiter.params.ParameterizedTest;
 import org.junit.jupiter.params.provider.CsvSource;
 import org.mockito.MockedStatic;
@@ -75,6 +76,7 @@ import com.fasterxml.jackson.databind.ObjectMapper;
 import jakarta.annotation.PostConstruct;
 
 @Configuration
+@TestInstance(TestInstance.Lifecycle.PER_METHOD)
 @SpringBootTest
 @ActiveProfiles({ "test", "ingestion" })
 class IngestionOperationValidatorTest {
index cf39d3e..74ff01a 100644 (file)
@@ -111,7 +111,7 @@ class CreateTopologyProcessorTest {
 
         verify(teivDbService, times(1)).execute(anyList());
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -134,7 +134,7 @@ class CreateTopologyProcessorTest {
 
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -157,7 +157,7 @@ class CreateTopologyProcessorTest {
 
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -172,7 +172,7 @@ class CreateTopologyProcessorTest {
 
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("create"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 }
index ce781a4..6001302 100644 (file)
@@ -111,7 +111,7 @@ class DeleteTopologyProcessorTest {
 
         verify(teivDbService, times(1)).execute(anyList());
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("delete"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("delete"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -126,7 +126,7 @@ class DeleteTopologyProcessorTest {
         verify(metrics, times(1)).incrementNumUnsuccessfullyParsedDeleteCloudEvents();
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("delete"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("delete"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
index 3b7e322..5340ec6 100644 (file)
@@ -111,7 +111,7 @@ class MergeTopologyProcessorTest {
 
         verify(teivDbService, times(1)).execute(anyList());
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -134,7 +134,7 @@ class MergeTopologyProcessorTest {
 
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -157,7 +157,7 @@ class MergeTopologyProcessorTest {
 
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 
@@ -171,7 +171,7 @@ class MergeTopologyProcessorTest {
         verify(metrics, times(1)).incrementNumUnsuccessfullyParsedMergeCloudEvents();
         verifyNoMoreInteractions(metrics);
 
-        verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
+        verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("merge"), any(CloudEvent.class), anyString(),
                 anyString());
     }
 }
index 92ea516..aede674 100644 (file)
@@ -109,7 +109,7 @@ class SourceEntityDeleteTopologyProcessorTest {
             verify(metrics, times(1)).incrementNumUnsuccessfullyParsedSourceEntityDeleteCloudEvents();
             verifyNoMoreInteractions(metrics);
 
-            verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
+            verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
                     anyString(), anyString());
         }
     }
@@ -128,7 +128,7 @@ class SourceEntityDeleteTopologyProcessorTest {
             verify(metrics, times(1)).incrementNumReceivedCloudEventNotSupported();
             verifyNoMoreInteractions(metrics);
 
-            verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
+            verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
                     anyString(), anyString());
         }
     }
@@ -153,7 +153,7 @@ class SourceEntityDeleteTopologyProcessorTest {
             verify(metrics, times(1)).recordCloudEventSourceEntityDeleteParseTime(anyLong());
             verifyNoMoreInteractions(metrics);
 
-            verify(auditLogger).auditLog(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
+            verify(auditLogger).logError(eq(ExecutionStatus.FAILED), eq("source-entity-delete"), any(CloudEvent.class),
                     anyString(), any());
         }
     }
@@ -203,7 +203,7 @@ class SourceEntityDeleteTopologyProcessorTest {
 
             verifyNoMoreInteractions(metrics);
 
-            verify(auditLogger).auditLog(eq(ExecutionStatus.SUCCESS), eq("source-entity-delete"), any(CloudEvent.class),
+            verify(auditLogger).logSuccess(eq(ExecutionStatus.SUCCESS), eq("source-entity-delete"), any(CloudEvent.class),
                     anyString(), any());
             verifyNoMoreInteractions(metrics);
         } catch (IllegalAccessException e) {
index 8f7e30f..4cad968 100644 (file)
@@ -25,6 +25,7 @@ import static org.oran.smo.teiv.schema.RelationshipDataLocation.A_SIDE;
 import static org.oran.smo.teiv.schema.RelationshipDataLocation.B_SIDE;
 import static org.oran.smo.teiv.schema.RelationshipDataLocation.RELATION;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.ENTITY_NOT_FOUND_IN_DOMAIN;
+import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.ENTITY_NOT_FOUND_IN_MODULE;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.RELATIONSHIP_NOT_FOUND_IN_DOMAIN;
 import static org.oran.smo.teiv.schema.SchemaRegistryErrorCode.RELATIONSHIP_NOT_FOUND_IN_MODULE;
 import static org.oran.smo.teiv.utils.TeivConstants.QUOTED_STRING;
@@ -124,10 +125,20 @@ class SchemaRegistryTest {
     @Test
     void testGetEntityTypeByDomainAndName() throws SchemaRegistryException {
         //when
-        List<EntityType> entityTypes = SchemaRegistry.getEntityTypeByDomainAndName("RAN", "ODUFunction");
+        EntityType entityType = SchemaRegistry.getEntityTypeByDomainAndName("RAN", "ODUFunction");
+        //then
+        assertEquals("ODUFunction", entityType.getName());
+        assertEquals("RAN", entityType.getModule().getDomain());
+
+        //when
+        entityType = SchemaRegistry.getEntityTypeByDomainAndName("TEIV", "ODUFunction");
+        //then
+        assertEquals("ODUFunction", entityType.getName());
+        assertEquals("RAN", entityType.getModule().getDomain());
+
+        //when
+        entityType = SchemaRegistry.getEntityTypeByDomainAndName("REL_OAM_RAN", "ODUFunction");
         //then
-        assertEquals(1, entityTypes.size());
-        EntityType entityType = entityTypes.get(0);
         assertEquals("ODUFunction", entityType.getName());
         assertEquals("RAN", entityType.getModule().getDomain());
 
@@ -145,8 +156,8 @@ class SchemaRegistryTest {
         assertEquals("RAN", entityType.getModule().getDomain());
 
         final SchemaRegistryException exception = assertThrows(SchemaRegistryException.class, () -> SchemaRegistry
-                .getEntityTypeByDomainAndName("o-ran-smo-teiv-oam", "ODUFunction"));
-        assertEquals(ENTITY_NOT_FOUND_IN_DOMAIN, exception.getErrorCode());
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-oam", "ODUFunction"));
+        assertEquals(ENTITY_NOT_FOUND_IN_MODULE, exception.getErrorCode());
     }
 
     @Test
@@ -280,15 +291,38 @@ class SchemaRegistryTest {
         Association expectedASideAssociation = new Association("managed-ocucpFunction", 1, 1);
         Association expectedBSideAssociation = new Association("managed-by-managedElement", 0, 9223372036854775807L);
         //when
-        List<RelationType> relationTypes = SchemaRegistry.getRelationTypeByDomainAndName("REL_OAM_RAN",
+        RelationType relationType = SchemaRegistry.getRelationTypeByDomainAndName("REL_OAM_RAN",
                 "MANAGEDELEMENT_MANAGES_OCUCPFUNCTION");
         //then
-        assertEquals(1, relationTypes.size());
-        RelationType managedElementManagesOcucpfunction = relationTypes.get(0);
-        assertEquals(expectedASideAssociation.toString(), managedElementManagesOcucpfunction.getASideAssociation()
-                .toString());
-        assertEquals(expectedBSideAssociation.toString(), managedElementManagesOcucpfunction.getBSideAssociation()
-                .toString());
+        assertEquals(expectedASideAssociation.toString(), relationType.getASideAssociation().toString());
+        assertEquals(expectedBSideAssociation.toString(), relationType.getBSideAssociation().toString());
+
+        //when
+        relationType = SchemaRegistry.getRelationTypeByDomainAndName("TEIV", "MANAGEDELEMENT_MANAGES_OCUCPFUNCTION");
+        //then
+        assertEquals(expectedASideAssociation.toString(), relationType.getASideAssociation().toString());
+        assertEquals(expectedBSideAssociation.toString(), relationType.getBSideAssociation().toString());
+
+        //given
+        Association expectedASideAssociation1 = new Association("provided-nrCellDu", 1, 1);
+        Association expectedBSideAssociation1 = new Association("provided-by-oduFunction", 0, 9223372036854775807L);
+        //when
+        RelationType relationType1 = SchemaRegistry.getRelationTypeByDomainAndName("RAN", "ODUFUNCTION_PROVIDES_NRCELLDU");
+        //then
+        assertEquals(expectedASideAssociation1.toString(), relationType1.getASideAssociation().toString());
+        assertEquals(expectedBSideAssociation1.toString(), relationType1.getBSideAssociation().toString());
+
+        //when
+        relationType1 = SchemaRegistry.getRelationTypeByDomainAndName("TEIV", "ODUFUNCTION_PROVIDES_NRCELLDU");
+        //then
+        assertEquals(expectedASideAssociation1.toString(), relationType1.getASideAssociation().toString());
+        assertEquals(expectedBSideAssociation1.toString(), relationType1.getBSideAssociation().toString());
+
+        //when
+        relationType1 = SchemaRegistry.getRelationTypeByDomainAndName("REL_OAM_RAN", "ODUFUNCTION_PROVIDES_NRCELLDU");
+        //then
+        assertEquals(expectedASideAssociation1.toString(), relationType1.getASideAssociation().toString());
+        assertEquals(expectedBSideAssociation1.toString(), relationType1.getBSideAssociation().toString());
 
         final SchemaRegistryException exception = assertThrows(SchemaRegistryException.class, () -> SchemaRegistry
                 .getRelationTypeByDomainAndName("OAM", "MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"));
index 7431b90..efcb35a 100644 (file)
@@ -24,13 +24,18 @@ import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
 import static org.junit.jupiter.api.Assertions.assertEquals;
 import static org.junit.jupiter.api.Assertions.assertFalse;
 import static org.junit.jupiter.api.Assertions.assertTrue;
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.ArgumentMatchers.eq;
+import static org.mockito.ArgumentMatchers.nullable;
 import static org.oran.smo.teiv.utils.JooqTypeConverter.jsonbToMap;
+import static org.oran.smo.teiv.utils.OperationResultParser.fromOperationResults;
 import static org.oran.smo.teiv.utils.TeivConstants.TEIV_DATA_SCHEMA;
 import static org.oran.smo.teiv.utils.TeivTestConstants.KAFKA_RETRY_INTERVAL_10_MS;
 import static org.oran.smo.teiv.utils.TeivTestConstants.SPRING_BOOT_SERVER_HOST;
 import static org.oran.smo.teiv.utils.TeivTestConstants.SPRING_BOOT_SERVER_PORT;
 
 import java.io.File;
+import java.io.IOException;
 import java.time.Duration;
 import java.time.OffsetDateTime;
 import java.time.ZoneOffset;
@@ -64,16 +69,26 @@ import org.junit.jupiter.api.BeforeAll;
 import org.junit.jupiter.api.BeforeEach;
 import org.junit.jupiter.api.Test;
 import org.junit.jupiter.api.TestInstance;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mockito;
 import org.oran.smo.teiv.CustomMetrics;
 import org.oran.smo.teiv.availability.DependentServiceAvailabilityKafka;
 import org.oran.smo.teiv.config.KafkaConfig;
 import org.oran.smo.teiv.db.TestPostgresqlContainer;
+import org.oran.smo.teiv.exception.YangException;
 import org.oran.smo.teiv.listener.ListenerStarter;
+import org.oran.smo.teiv.listener.audit.ExecutionStatus;
+import org.oran.smo.teiv.listener.audit.IngestionAuditLogger;
+import org.oran.smo.teiv.schema.MockSchemaLoader;
+import org.oran.smo.teiv.schema.SchemaLoader;
+import org.oran.smo.teiv.schema.SchemaLoaderException;
 import org.oran.smo.teiv.service.kafka.KafkaTopicService;
+import org.oran.smo.teiv.service.models.OperationResult;
 import org.oran.smo.teiv.startup.AppInit;
 import org.oran.smo.teiv.utils.CloudEventTestUtil;
 import org.oran.smo.teiv.utils.EndToEndExpectedResults;
 import org.oran.smo.teiv.utils.KafkaTestExecutionListener;
+import org.oran.smo.teiv.utils.YangModelValidationTestUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.test.context.SpringBootTest;
 import org.springframework.kafka.config.KafkaListenerEndpointRegistry;
@@ -87,6 +102,7 @@ import org.springframework.test.context.ActiveProfiles;
 import org.springframework.test.context.DynamicPropertyRegistry;
 import org.springframework.test.context.DynamicPropertySource;
 import org.springframework.test.context.TestExecutionListeners;
+import org.springframework.test.context.bean.override.mockito.MockitoSpyBean;
 import org.testcontainers.shaded.org.checkerframework.checker.nullness.qual.Nullable;
 
 @EmbeddedKafka
@@ -134,6 +150,9 @@ public class EndToEndDbTest {
     @Autowired
     private DSLContext writeDataDslContext;
 
+    @MockitoSpyBean
+    IngestionAuditLogger auditLogger;
+
     @DynamicPropertySource
     static void setProperties(DynamicPropertyRegistry registry) {
         registry.add("spring.datasource.read.jdbc-url", () -> postgresqlContainer.getJdbcUrl());
@@ -151,13 +170,16 @@ public class EndToEndDbTest {
     private OffsetDateTime testStartTime;
 
     @BeforeAll
-    static void beforeAll() {
+    static void beforeAll() throws SchemaLoaderException {
         TestPostgresqlContainer.loadData();
         TestPostgresqlContainer.loadIngestionTestData();
+        TestPostgresqlContainer.loadEndToEndTestData();
+        SchemaLoader mockSchemaLoader = new MockSchemaLoader();
+        mockSchemaLoader.loadSchemaRegistry();
     }
 
     @BeforeEach
-    void setupEach() {
+    void setupEach() throws IOException, YangException {
         TestPostgresqlContainer.truncateSchemas(List.of(TEIV_DATA_SCHEMA), writeDataDslContext);
         appInit = new AppInit(dependentServiceAvailabilityKafka, kafkaTopicService, listenerStarter);
         appInit.startUpHandler();
@@ -165,6 +187,7 @@ public class EndToEndDbTest {
                 new StringSerializer(), new CloudEventSerializer());
         producer = factory.createProducer();
         testStartTime = OffsetDateTime.now(ZoneOffset.UTC);
+        YangModelValidationTestUtil.mockLoadAndValidateModels();
     }
 
     @AfterEach
@@ -268,8 +291,7 @@ public class EndToEndDbTest {
 
         testStartTime = OffsetDateTime.now(ZoneOffset.UTC);
         sendEventFromFile(CREATE_INFERRED_ENTITIES);
-
-        validateWithTimeout(25, () -> {
+        validateWithTimeout(30, () -> {
             EndToEndExpectedResults expected = getExpectedResults(EXP_CREATE_INFERRED_ENTITIES);
             assertDbContainsExpectedValues(expected);
             validateReceivedCloudEventMetrics(5, 3, 0, 0);
@@ -299,6 +321,23 @@ public class EndToEndDbTest {
             EndToEndExpectedResults notExpected = getExpectedResults(NOT_EXP_DELETE_ONE_TO_ONE_PATH);
             assertDbNotContainsExpectedValues(notExpected);
             validateReceivedCloudEventMetrics(6, 3, 2, 0);
+            List<Map<String, List<String>>> expectedItems = List.of(Map.of(
+                    "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU", List.of(
+                            "relation_11", "relation_12")), Map.of(
+                                    "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt",
+                                    List.of("ManagedElement_21")));
+            List<OperationResult> operationResults = List.of(OperationResult.builder().id("relation_11").type(
+                    "ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU").module("o-ran-smo-teiv-rel-oam-ran-test")
+                    .build(), OperationResult.builder().id("ManagedElement_21").type(
+                            "ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt").module(
+                                    "o-ran-smo-teiv-oam-test").build(), OperationResult.builder().id("relation_12").type(
+                                            "ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU").module(
+                                                    "o-ran-smo-teiv-rel-oam-ran-test").build());
+            ArgumentCaptor<List<String>> auditLogCaptor = ArgumentCaptor.forClass(List.class);
+            Mockito.verify(auditLogger, Mockito.atLeastOnce()).logSuccess(eq(ExecutionStatus.SUCCESS), eq("delete"), any(
+                    CloudEvent.class), nullable(String.class), auditLogCaptor.capture());
+            List<String> actualResponse = auditLogCaptor.getValue();
+            assertEquals(fromOperationResults(operationResults), actualResponse);
         });
 
         testStartTime = OffsetDateTime.now(ZoneOffset.UTC);
@@ -557,7 +596,7 @@ public class EndToEndDbTest {
     }
 
     private void validateWithTimeout(int timeout, Runnable runnable) {
-        Awaitility.await().atMost(timeout, TimeUnit.SECONDS).pollDelay(Duration.ofSeconds(5)).untilAsserted(() -> {
+        Awaitility.await().atMost(timeout, TimeUnit.SECONDS).pollDelay(Duration.ofSeconds(10)).untilAsserted(() -> {
             try {
                 runnable.run();
             } catch (AssertionError e) {
index a5f7cbb..6307714 100644 (file)
@@ -38,6 +38,7 @@ import java.util.List;
 import java.util.Map;
 import java.util.Objects;
 import java.util.Optional;
+import java.util.stream.Collectors;
 
 import javax.sql.DataSource;
 
@@ -57,7 +58,6 @@ import org.oran.smo.teiv.service.models.OperationResult;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.jdbc.DataSourceBuilder;
 import org.springframework.boot.test.context.SpringBootTest;
-import org.springframework.boot.test.mock.mockito.MockBean;
 import org.springframework.context.annotation.Configuration;
 import org.springframework.test.context.ActiveProfiles;
 
@@ -83,6 +83,7 @@ import org.oran.smo.teiv.service.cloudevent.data.Relationship;
 import org.oran.smo.teiv.startup.SchemaHandler;
 import org.oran.smo.teiv.utils.CloudEventTestUtil;
 import org.oran.smo.teiv.utils.JooqTypeConverter;
+import org.springframework.test.context.bean.override.mockito.MockitoBean;
 
 @Configuration
 @SpringBootTest
@@ -106,7 +107,7 @@ class TeivDbOperationResultsTest {
 
     @Autowired
     CloudEventParser cloudEventParser;
-    @MockBean
+    @MockitoBean
     private SchemaHandler schemaHandler;
 
     @BeforeAll
@@ -119,6 +120,7 @@ class TeivDbOperationResultsTest {
         teivDbOperations = new TeivDbOperations(teivDbService, new IngestionOperationValidatorFactory(),
                 new RelationshipMergeValidator(), new TeivMetadataResolver());
         TestPostgresqlContainer.loadIngestionTestData();
+        TestPostgresqlContainer.loadEndToEndTestData();
         PostgresSchemaLoader postgresSchemaLoader = new PostgresSchemaLoader(dslContext, new ObjectMapper());
         postgresSchemaLoader.loadSchemaRegistry();
     }
@@ -130,7 +132,7 @@ class TeivDbOperationResultsTest {
             entityTypeMe = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-oam", "ManagedElement");
             entityTypeORU = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-ran", "ORUFunction");
             entityTypeAntennMod = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment", "AntennaModule");
-            entityTypeAntennModLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+            entityTypeAntennModLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                     "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee");
             entityTypeAntennCap = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-ran", "AntennaCapability");
             relTypeMeManagesORU = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-oam-ran",
@@ -138,7 +140,7 @@ class TeivDbOperationResultsTest {
             relTypeantennServesAntennCap = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-equipment-ran",
                     "ANTENNAMODULE_SERVES_ANTENNACAPABILITY");
             relTypeAntennModRealisedByAntennaModLongName = SchemaRegistry.getRelationTypeByModuleAndName(
-                    "o-ran-smo-teiv-equipment", "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE");
+                    "o-ran-smo-teiv-equipment-test", "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE");
         } catch (SchemaRegistryException e) {
             throw new RuntimeException(e);
         }
@@ -179,8 +181,8 @@ class TeivDbOperationResultsTest {
                 .getEntityTypeByModuleAndName("o-ran-smo-teiv-oam", "ManagedElement"), "managed_element_entity_id1");
 
         assertFalse(deleteResultMatch.isEmpty(), "Delete operation should return a non-empty list");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("managed_element_entity_id1").type(
-                "ManagedElement").category(ENTITY_CATEGORY).build()),
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("managed_element_entity_id1")
+                .type("ManagedElement").category(ENTITY_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'managed_element_entity_id1'");
 
         // Delete operation with the same EIID - expected to fail
@@ -194,14 +196,14 @@ class TeivDbOperationResultsTest {
     void testDeleteOneToOneByRelationId() throws SchemaRegistryException {
         Map<String, Object> managedElementEntity = new HashMap<>();
         managedElementEntity.put("id", "me-id1");
-        EntityType entityTypeMeLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-oam",
+        EntityType entityTypeMeLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-oam-test",
                 "ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt");
         teivDbOperations.merge(dslContext, entityTypeMeLongName, managedElementEntity);
 
         Map<String, Object> nrCellDuEntity = new HashMap<>();
         nrCellDuEntity.put("id", "nrcelldu-id1");
         nrCellDuEntity.put("020335B0F627C169E24167748C38FE756FB34AE2", 1);
-        EntityType entityTypeNrCellDuLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+        EntityType entityTypeNrCellDuLongName = SchemaRegistry.getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                 "NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU");
         teivDbOperations.merge(dslContext, entityTypeNrCellDuLongName, nrCellDuEntity);
 
@@ -215,25 +217,25 @@ class TeivDbOperationResultsTest {
 
         // Delete operation for aSide - expected to succeed
         Optional<OperationResult> deleteASideResultMatch = teivDbOperations.deleteRelationFromEntityTableByRelationId(
-                dslContext, "eiid1", SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-oam-ran",
+                dslContext, "eiid1", SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-oam-ran-test",
                         "ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU"));
 
         assertTrue(deleteASideResultMatch.isPresent(), "Delete operation should return a present Optional");
-        assertEquals(OperationResult.builder().id("eiid1").type("ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU")
-                .category(RELATIONSHIP_CATEGORY).build(), deleteASideResultMatch.get(),
-                "The delete operation result should be present for: 'eiid1'");
+        assertTrue(containsWithPartialMatch(deleteASideResultMatch.stream().collect(Collectors.toList()), OperationResult
+                .builder().id("eiid1").type("ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU").category(
+                        RELATIONSHIP_CATEGORY).build()), "The delete operation result should be present for: 'eiid1'");
 
         // Delete operation with the same EIID - expected to fail
         Optional<OperationResult> deleteResultNoMatch = teivDbOperations.deleteRelationFromEntityTableByRelationId(
-                dslContext, "eiid1", SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-oam-ran",
+                dslContext, "eiid1", SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-rel-oam-ran-test",
                         "ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU"));
         assertTrue(deleteResultNoMatch.isEmpty(),
                 "Delete operation should return an empty list for already deleted/non existing ID");
 
         Result<Record> nrcellduRows = TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"84E676149362F50C55FE1E004B98D4891916BBF3\"");
+                "teiv_data.\"F93C2CA075353668A76B4718E07B741ACCD83641\"");
         Result<Record> managedElementRows = TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"28C9A375E800E82308EBE7DA2932EF2C0AF13C38\"");
+                "teiv_data.\"C9475FE40C02BEB41F720B4284A856F2CF49E1F3\"");
         assertEquals("me-id1", managedElementRows.get(0).get("id"));
         assertEquals("nrcelldu-id1", nrcellduRows.get(0).get("id"));
         assertNull(managedElementRows.get(0).get("REL_FK_used-nrCellDu"));
@@ -267,9 +269,9 @@ class TeivDbOperationResultsTest {
                         "MANAGEDELEMENT_MANAGES_ORUFUNCTION"));
 
         assertFalse(deleteResultMatch.isEmpty(), "Delete operation should return a non-empty list");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("eiid1").type(
-                "MANAGEDELEMENT_MANAGES_ORUFUNCTION").category(RELATIONSHIP_CATEGORY).build()),
-                "The list should contain the delete operation result with id: 'eiid1'");
+        assertTrue(containsWithPartialMatch(deleteResultMatch, (OperationResult.builder().id("eiid1").type(
+                "MANAGEDELEMENT_MANAGES_ORUFUNCTION").category(RELATIONSHIP_CATEGORY).module("o-ran-smo-teiv-rel-oam-ran")
+                .build())), "The list should contain the delete operation result with id: 'eiid1'");
 
         // Delete operation with the same entity ID - expected to return an empty list
         List<OperationResult> deleteResultNoMatch = teivDbOperations.deleteRelationshipByManySideEntityId(dslContext,
@@ -315,16 +317,17 @@ class TeivDbOperationResultsTest {
 
         // Check if all expected IDs are present in the deletion result
         assertEquals(4, deleteResultMatch.size(), "Delete operation should match expected size");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("me-id1").type("ManagedElement").category(
-                ENTITY_CATEGORY).build()), "The list should contain the delete operation result with id: 'me-id1'");
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("me-id1").type("ManagedElement")
+                .category(ENTITY_CATEGORY).build()),
+                "The list should contain the delete operation result with id: 'me-id1'");
 
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("eiid1").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("eiid1").type(
                 "MANAGEDELEMENT_MANAGES_ORUFUNCTION").category(RELATIONSHIP_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'eiid1'");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("eiid2").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("eiid2").type(
                 "MANAGEDELEMENT_MANAGES_ORUFUNCTION").category(RELATIONSHIP_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'eiid2'");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("eiid3").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("eiid3").type(
                 "MANAGEDELEMENT_MANAGES_ORUFUNCTION").category(RELATIONSHIP_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'eiid3'");
 
@@ -387,8 +390,9 @@ class TeivDbOperationResultsTest {
         Optional<OperationResult> deleteResultMatch = teivDbOperations.deleteManyToManyRelationByRelationId(dslContext,
                 relType, "rel_id1");
         assertTrue(deleteResultMatch.isPresent(), "Delete operation should return a present Optional");
-        assertEquals(OperationResult.builder().id("rel_id1").type("ANTENNAMODULE_SERVES_ANTENNACAPABILITY").category(
-                RELATIONSHIP_CATEGORY).build(), deleteResultMatch.get(), "Deleted relationship ID should match 'rel_id1'");
+        assertTrue(containsWithPartialMatch(deleteResultMatch.stream().collect(Collectors.toList()), OperationResult
+                .builder().id("rel_id1").type("ANTENNAMODULE_SERVES_ANTENNACAPABILITY").category(RELATIONSHIP_CATEGORY)
+                .build()), "Deleted relationship ID should match 'rel_id1'");
 
         // Test deletion of the same relationship ID again (expected failure)
         Optional<OperationResult> deleteResultNoMatch = teivDbOperations.deleteManyToManyRelationByRelationId(dslContext,
@@ -441,11 +445,11 @@ class TeivDbOperationResultsTest {
         List<OperationResult> deleteResultMatch = teivDbOperations.deleteManyToManyRelationByEntityId(dslContext, relType,
                 "antennamodule_id1", "aSide_AntennaModule", "bSide_AntennaCapability");
         assertEquals(2, deleteResultMatch.size(), "Expected two relations to be deleted");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("rel_id1").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("rel_id1").type(
                 "ANTENNAMODULE_SERVES_ANTENNACAPABILITY").category(RELATIONSHIP_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'rel_id1'");
 
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("rel_id2").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("rel_id2").type(
                 "ANTENNAMODULE_SERVES_ANTENNACAPABILITY").category(RELATIONSHIP_CATEGORY).build()),
                 "The list should contain the delete operation result with id: 'rel_id2'");
 
@@ -493,13 +497,13 @@ class TeivDbOperationResultsTest {
         teivDbOperations.merge(dslContext, relTypeAntennModRealisedByAntennaModLongName, rel2);
 
         Result<Record> row1 = TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"53017288F3FE983848689A3DD21D48D298CCD23E\"");
+                "teiv_data.\"98D95275440120DC7A5FEF7E870FB6649F275AEC\"");
         assertEquals(2, row1.size());
         Result<Record> row2 = TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"53089669D370B15C78B7E8376D434921D1C94240\"");
+                "teiv_data.\"98D95275440120DC7A5FEF7E870FB6649F275AEC\"");
         assertEquals(2, row2.size());
 
-        RelationType antennaRelType1 = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-equipment",
+        RelationType antennaRelType1 = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                 "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE");
 
         // Test deletion of a relationship by ID (expected success)
@@ -507,9 +511,9 @@ class TeivDbOperationResultsTest {
                 antennaRelType1, "rel_id1");
 
         assertTrue(deleteResultMatch.isPresent(), "Delete operation should return a present Optional");
-        assertEquals(OperationResult.builder().id("rel_id1").type(
-                "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE").category(RELATIONSHIP_CATEGORY).build(),
-                deleteResultMatch.get(), "Deleted relationship ID should match 'rel_id1'");
+        assertTrue(containsWithPartialMatch(deleteResultMatch.stream().collect(Collectors.toList()), OperationResult
+                .builder().id("rel_id1").type("ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE").category(
+                        RELATIONSHIP_CATEGORY).build()), "Deleted relationship ID should match 'rel_id1'");
 
         // Test deletion of the same relationship ID again (expected failure)
         Optional<OperationResult> deleteResultNoMatch = teivDbOperations.deleteManyToManyRelationByRelationId(dslContext,
@@ -554,12 +558,12 @@ class TeivDbOperationResultsTest {
         teivDbOperations.merge(dslContext, relTypeAntennModRealisedByAntennaModLongName, rel2);
 
         assertEquals(2, TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"53017288F3FE983848689A3DD21D48D298CCD23E\"").size(), "Expected two AntennaModule records");
+                "teiv_data.\"98D95275440120DC7A5FEF7E870FB6649F275AEC\"").size(), "Expected two AntennaModule records");
         assertEquals(2, TeivDbServiceContainerizedTest.selectAllRowsFromTable(dslContext,
-                "teiv_data.\"53089669D370B15C78B7E8376D434921D1C94240\"").size(),
+                "teiv_data.\"98D95275440120DC7A5FEF7E870FB6649F275AEC\"").size(),
                 "Expected two ANTENNAMODULE_REALISED_BY_ANTENNAMODULE relations");
 
-        RelationType relType = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-equipment",
+        RelationType relType = SchemaRegistry.getRelationTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                 "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE");
 
         // Test deletion of relations by entity ID (expected to delete two relations)
@@ -567,11 +571,11 @@ class TeivDbOperationResultsTest {
                 "module_id1", "aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C",
                 "bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E");
         assertEquals(2, deleteResultMatch.size(), "Expected two relations to be deleted");
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("rel_id1").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("rel_id1").type(
                 "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE").category(RELATIONSHIP_CATEGORY)
                 .build()), "The list should contain the delete operation result with id: 'rel_id1'");
 
-        assertTrue(deleteResultMatch.contains(OperationResult.builder().id("rel_id2").type(
+        assertTrue(containsWithPartialMatch(deleteResultMatch, OperationResult.builder().id("rel_id2").type(
                 "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE").category(RELATIONSHIP_CATEGORY)
                 .build()), "The list should contain the delete operation result with id: 'rel_id2'");
 
@@ -610,37 +614,37 @@ class TeivDbOperationResultsTest {
 
         // Entity with One_To_One relationship
         List<OperationResult> deleteEntityResult1 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-oam",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-oam-test",
                         "ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt"), "ManagedElement_3");
         assertEquals(2, deleteEntityResult1.size());
 
         // Entity with One_To_Many relationship
         List<OperationResult> deleteEntityResult2 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn"), "ODUFunction_1");
         assertEquals(2, deleteEntityResult2.size());
 
         // Entity and Many_To_One relationship
         List<OperationResult> deleteEntityResult3 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr"), "LTESectorCarrier_id1");
         assertEquals(2, deleteEntityResult3.size());
 
         // Entity with Many_To_Many relationship
         List<OperationResult> deleteEntityResult4 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                         "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"), "AntennaModule_7");
         assertEquals(2, deleteEntityResult4.size());
 
         // Entity with One_To_Many relationship ConnectingSameEntity
         List<OperationResult> deleteEntityResult5 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                         "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"), "AntennaModule_5");
         assertEquals(2, deleteEntityResult5.size());
 
         // Entity with One_To_One relationship ConnectingSameEntity
         List<OperationResult> deleteEntityResult6 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                         "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"), "AntennaModule_1");
         assertEquals(2, deleteEntityResult6.size());
     }
@@ -658,44 +662,44 @@ class TeivDbOperationResultsTest {
 
         // Entity with One_To_One relationship
         List<OperationResult> deleteEntityResult1 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"), "NRCellDU_2");
         assertEquals(2, deleteEntityResult1.size());
 
         // Entity with One_To_Many relationship
         List<OperationResult> deleteEntityResult2 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"), "NRCellDU_1");
         assertEquals(2, deleteEntityResult2.size());
 
         // Entity with Many_To_One relationship
         List<OperationResult> deleteEntityResult3 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"), "AntennaCapability_id2");
         assertEquals(2, deleteEntityResult3.size());
 
         // Entity with Many_To_Many relationship
         List<OperationResult> deleteEntityResult4 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"), "AntennaCapability_id1");
         assertEquals(2, deleteEntityResult4.size());
 
         // Entity with One_To_Many relationship ConnectingSameEntity
         List<OperationResult> deleteEntityResult5 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                         "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"), "AntennaModule_6");
         assertEquals(2, deleteEntityResult5.size());
 
         // Entity with One_To_One relationship ConnectingSameEntity
         List<OperationResult> deleteEntityResult6 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-equipment-test",
                         "AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"), "AntennaModule_2");
         assertEquals(2, deleteEntityResult6.size());
 
         // Again delete AntennaCapability(id=AntennaCapability_id1) should
         // return empty result list
         List<OperationResult> deleteEntityResult7 = teivDbOperations.deleteEntity(dslContext, SchemaRegistry
-                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran",
+                .getEntityTypeByModuleAndName("o-ran-smo-teiv-ran-test",
                         "AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"), "AntennaCapability_id1");
         assertTrue(deleteEntityResult7.isEmpty(),
                 "Delete operation should return an empty list for already deleted/non existing ID");
@@ -713,7 +717,7 @@ class TeivDbOperationResultsTest {
         assertEquals(25, mergeResult.size());
 
         // One_To_One Relationship
-        Relationship oneToOneRelationship = new Relationship("o-ran-smo-teiv-rel-oam-ran",
+        Relationship oneToOneRelationship = new Relationship("o-ran-smo-teiv-rel-oam-ran-test",
                 "ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU", "ManagedElement_USES_NRCELLDU_relation_1",
                 "ManagedElement_3", "NRCellDU_2", List.of());
         RelationType oneToOneRelationType = SchemaRegistry.getRelationTypeByModuleAndName(oneToOneRelationship.getModule(),
@@ -723,7 +727,7 @@ class TeivDbOperationResultsTest {
         assertTrue(deleteOneToOneRelationshipResult.isPresent(), "Delete operation should return a present Optional");
 
         // One_To_Many Relationship
-        Relationship oneToManyRelationship = new Relationship("o-ran-smo-teiv-rel-oam-ran",
+        Relationship oneToManyRelationship = new Relationship("o-ran-smo-teiv-rel-oam-ran-test",
                 "MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN",
                 "MANAGEDELEMENT_MANAGES_ODUFUNCTION_relation_1", "ManagedElement_1", "ODUFunction_1", List.of());
         RelationType oneToManyRelationType = SchemaRegistry.getRelationTypeByModuleAndName(oneToManyRelationship
@@ -734,7 +738,7 @@ class TeivDbOperationResultsTest {
         assertTrue(deleteOneToManyRelationshipResult.isPresent(), "Delete operation should return a present Optional");
 
         // Many_To_One Relationship
-        Relationship manyToOneRelationship = new Relationship("o-ran-smo-teiv-ran",
+        Relationship manyToOneRelationship = new Relationship("o-ran-smo-teiv-ran-test",
                 "LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY",
                 "LTESECTORCARRIER_USES_ANTENNACAPABILITY_relation_1", "LTESectorCarrier_id1", "AntennaCapability_id2", List
                         .of());
@@ -746,7 +750,7 @@ class TeivDbOperationResultsTest {
         assertTrue(deleteManyToOneRelationshipResult.isPresent(), "Delete operation should return a present Optional");
 
         // Many_To_Many Relationship
-        Relationship manyToManyRelationship = new Relationship("o-ran-smo-teiv-rel-equipment-ran",
+        Relationship manyToManyRelationship = new Relationship("o-ran-smo-teiv-rel-equipment-ran-test",
                 "ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY",
                 "ANTENNAMODULE_SERVES_ANTENNACAPABILITY_relation_1", "AntennaModule_7", "AntennaCapability_id1", List.of());
         RelationType manyToManyRelationType = SchemaRegistry.getRelationTypeByModuleAndName(manyToManyRelationship
@@ -756,7 +760,7 @@ class TeivDbOperationResultsTest {
         assertTrue(deleteManyToManyRelationshipResult.isPresent(), "Delete operation should return a present Optional");
 
         // One_To_One Relationship ConnectingSameEntity
-        Relationship connectingSameEntityOneToOneRelationship = new Relationship("o-ran-smo-teiv-equipment",
+        Relationship connectingSameEntityOneToOneRelationship = new Relationship("o-ran-smo-teiv-equipment-test",
                 "ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE",
                 "ANTENNAMODULE_REALISED_BY_ANTENNAMODULE_relation_1", "AntennaModule_1", "AntennaModule_2", List.of());
         RelationType connectingSameEntityType = SchemaRegistry.getRelationTypeByModuleAndName(
@@ -768,7 +772,7 @@ class TeivDbOperationResultsTest {
                 "Delete operation should return a present Optional");
 
         // One_To_Many Relationship ConnectingSameEntity
-        Relationship connectingSameEntityOneToManyRelationship = new Relationship("o-ran-smo-teiv-equipment",
+        Relationship connectingSameEntityOneToManyRelationship = new Relationship("o-ran-smo-teiv-equipment-test",
                 "ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE",
                 "ANTENNAMODULE_DEPLOYED_ON_ANTENNAMODULE_relation_1", "AntennaModule_5", "AntennaModule_6", List.of());
         connectingSameEntityType = SchemaRegistry.getRelationTypeByModuleAndName(connectingSameEntityOneToManyRelationship
@@ -1193,4 +1197,10 @@ class TeivDbOperationResultsTest {
                 Object::toString).anyMatch(result.getId()::equals);
         assertTrue(contains);
     }
+
+    private boolean containsWithPartialMatch(List<OperationResult> list, OperationResult op) {
+        return list.stream().anyMatch(obj -> Objects.equals(obj.getId(), op.getId()) && Objects.equals(obj.getType(), op
+                .getType()) && Objects.equals(obj.getCategory(), op.getCategory()) && (op.getModule() == null || Objects
+                        .equals(obj.getModule(), op.getModule())));
+    }
 }
index 69749e7..f9e9730 100644 (file)
@@ -31,7 +31,9 @@ import com.fasterxml.jackson.databind.ObjectMapper;
 import io.cloudevents.CloudEvent;
 import io.cloudevents.SpecVersion;
 import io.cloudevents.core.builder.CloudEventBuilder;
+import lombok.extern.slf4j.Slf4j;
 
+@Slf4j
 public class CloudEventTestUtil {
 
     private CloudEventTestUtil() {
@@ -62,6 +64,7 @@ public class CloudEventTestUtil {
             cloudEventBuilder.withDataSchema(URI.create(rootNode.get("dataschema").asText()));
             cloudEventBuilder.withData(rootNode.get("data").toString().getBytes());
             CloudEvent event = cloudEventBuilder.build();
+            log.info("CloudEvent data: {}", rootNode.get("data").toString());
             return event;
         } catch (Exception e) {
             throw new RuntimeException(e);
index c1b6203..c47b699 100644 (file)
@@ -1,76 +1,77 @@
-/*
- *  ============LICENSE_START=======================================================
- *  Copyright (C) 2024 Ericsson
- *  Modifications Copyright (C) 2024 OpenInfra Foundation Europe
- *  ================================================================================
- *  Licensed under the Apache License, Version 2.0 (the "License");
- *  you may not use this file except in compliance with the License.
- *  You may obtain a copy of the License at
- *
- *        http://www.apache.org/licenses/LICENSE-2.0
- *
- *  Unless required by applicable law or agreed to in writing, software
- *  distributed under the License is distributed on an "AS IS" BASIS,
- *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- *  See the License for the specific language governing permissions and
- *  limitations under the License.
- *
- *  SPDX-License-Identifier: Apache-2.0
- *  ============LICENSE_END=========================================================
- */
+///*
+// *  ============LICENSE_START=======================================================
+// *  Copyright (C) 2024 Ericsson
+// *  Modifications Copyright (C) 2024 OpenInfra Foundation Europe
+// *  ================================================================================
+// *  Licensed under the Apache License, Version 2.0 (the "License");
+// *  you may not use this file except in compliance with the License.
+// *  You may obtain a copy of the License at
+// *
+// *        http://www.apache.org/licenses/LICENSE-2.0
+// *
+// *  Unless required by applicable law or agreed to in writing, software
+// *  distributed under the License is distributed on an "AS IS" BASIS,
+// *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// *  See the License for the specific language governing permissions and
+// *  limitations under the License.
+// *
+// *  SPDX-License-Identifier: Apache-2.0
+// *  ============LICENSE_END=========================================================
+// */
 package org.oran.smo.teiv.utils;
 
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import org.apache.kafka.clients.producer.Producer;
-import org.apache.kafka.clients.producer.ProducerRecord;
-import org.apache.kafka.common.serialization.StringSerializer;
-import org.springframework.kafka.core.DefaultKafkaProducerFactory;
-import org.springframework.kafka.test.EmbeddedKafkaBroker;
-import org.springframework.kafka.test.utils.KafkaTestUtils;
-import org.springframework.web.client.RestTemplate;
-
-import org.oran.smo.teiv.config.KafkaConfig;
-import com.fasterxml.jackson.core.type.TypeReference;
-import com.fasterxml.jackson.databind.JsonNode;
-import com.fasterxml.jackson.databind.ObjectMapper;
-
-import io.cloudevents.CloudEvent;
-import io.cloudevents.kafka.CloudEventSerializer;
-import lombok.extern.slf4j.Slf4j;
-
-@Slf4j
-public class EndToEndTestUtil {
-    public static void sendEventList(final List<CloudEvent> events, EmbeddedKafkaBroker embeddedKafkaBroker,
-            KafkaConfig kafkaConfig) {
-        Map<String, Object> configs = new HashMap<>(KafkaTestUtils.producerProps(embeddedKafkaBroker));
-        Producer<String, CloudEvent> producer = new DefaultKafkaProducerFactory<>(configs, new StringSerializer(),
-                new CloudEventSerializer()).createProducer();
-        for (CloudEvent event : events) {
-            ProducerRecord<String, CloudEvent> producerRecord = new ProducerRecord<String, CloudEvent>(kafkaConfig
-                    .getTopologyIngestion().getTopicName(), null, event);
-            producer.send(producerRecord);
-        }
-    }
-
-    public static String getResponseFromApi(final String uri) {
-        RestTemplate restTemplate = new RestTemplate();
-        return restTemplate.getForObject(uri, String.class);
-    }
-
-    public static String processApiCall(final String uri) {
-        log.info("(processApiCall) Sending request for: {}", uri);
-        String responseBody = getResponseFromApi(uri);
-        log.info("(processApiCall) Response: {}", responseBody);
-        return responseBody;
-    }
-
-    public static Map<String, Object> processNode(JsonNode node) {
-        ObjectMapper mapper = new ObjectMapper();
-        return mapper.convertValue(node, new TypeReference<>() {
-        });
-    }
-
-}
+//
+//import java.util.HashMap;
+//import java.util.List;
+//import java.util.Map;
+//
+//import org.apache.kafka.clients.producer.Producer;
+//import org.apache.kafka.clients.producer.ProducerRecord;
+//import org.apache.kafka.common.serialization.StringSerializer;
+//import org.springframework.kafka.core.DefaultKafkaProducerFactory;
+//import org.springframework.kafka.test.EmbeddedKafkaBroker;
+//import org.springframework.kafka.test.utils.KafkaTestUtils;
+//import org.springframework.web.client.RestTemplate;
+//
+//import org.oran.smo.teiv.config.KafkaConfig;
+//import com.fasterxml.jackson.core.type.TypeReference;
+//import com.fasterxml.jackson.databind.JsonNode;
+//import com.fasterxml.jackson.databind.ObjectMapper;
+//
+//import io.cloudevents.CloudEvent;
+//import io.cloudevents.kafka.CloudEventSerializer;
+//import lombok.extern.slf4j.Slf4j;
+//
+//@Slf4j
+//public class EndToEndTestUtil {
+//    public static void sendEventList(final List<CloudEvent> events, EmbeddedKafkaBroker embeddedKafkaBroker,
+//            KafkaConfig kafkaConfig) {
+//        Map<String, Object> configs = new HashMap<>(KafkaTestUtils.producerProps(embeddedKafkaBroker));
+//        Producer<String, CloudEvent> producer = new DefaultKafkaProducerFactory<>(configs, new StringSerializer(),
+//                new CloudEventSerializer()).createProducer();
+//        for (CloudEvent event : events) {
+//            ProducerRecord<String, CloudEvent> producerRecord = new ProducerRecord<String, CloudEvent>(kafkaConfig
+//                    .getTopologyIngestion().getTopicName(), null, event);
+//            producer.send(producerRecord);
+//        }
+//    }
+//
+//    public static String getResponseFromApi(final String uri) {
+//        RestTemplate restTemplate = new RestTemplate();
+//        return restTemplate.getForObject(uri, String.class);
+//    }
+//
+//    public static String processApiCall(final String uri) {
+//        log.info("(processApiCall) Sending request for: {}", uri);
+//        String responseBody = getResponseFromApi(uri);
+//        log.info("(processApiCall) Response: {}", responseBody);
+//        return responseBody;
+//    }
+//
+//    public static Map<String, Object> processNode(JsonNode node) {
+//        ObjectMapper mapper = new ObjectMapper();
+//        return mapper.convertValue(node, new TypeReference<>() {
+//        });
+//    }
+//
+//}
index 5ca0097..f485008 100644 (file)
@@ -64,13 +64,13 @@ class ExposureYangParserTest {
     @Test
     void testValidateCorrectSchema() throws YangException {
         MultipartFile correctFile = new MockMultipartFile("file", "file.yang", MediaType.MULTIPART_FORM_DATA_VALUE,
-                ("module module-rapp-module1 {\n" + " \n" + "\tyang-version 1.1;\n" + "\tnamespace \"urn:module-rapp-model\";\n" + "\tprefix testModule;\n" + "\t\n" + "    import o-ran-smo-teiv-common-yang-types { prefix model; }\n" + "\timport o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }\n" + "\t\n" + "\trevision \"2024-05-08\" {\n" + "\t\tdescription\n" + "\t\t\"Initial revision.\";\n" + "\t\tor-teiv-yext:label 0.3.0;\n" + "\t}\n" + "\t\n" + "\taugment /model:decorators {\n" + "        leaf test1 {\n" + "            type string;\n" + "        }\n" + "\t\tleaf test2 {\n" + "            type boolean;\n" + "        }\n" + "\t\tleaf test3 {\n" + "            type uint32;\n" + "        }\n" + "    }\n" + "\t\n" + "\tidentity geo-classifier {\n" + "\t\tbase model:classifiers;\n" + "\t}\n" + " \n" + "    identity urban {\n" + "        base geo-classifier;\n" + "    }\n" + "\t\n" + "\tidentity rural {\n" + "        base geo-classifier;\n" + "    }\n" + "\n" + "}")
+                ("module module-rapp-module1 {\n" + " \n" + "\tyang-version 1.1;\n" + "\tnamespace \"urn:module-rapp-model\";\n" + "\tprefix testModule;\n" + "\t\n" + "    import o-ran-smo-teiv-common-yang-types { prefix model; }\n" + "\timport o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }\n" + "\t\n" + "\trevision \"2024-05-08\" {\n" + "\t\tdescription\n" + "\t\t\"Initial revision.\";\n" + "\t\tor-teiv-yext:label 0.3.0;\n" + "\t}\n" + "\t\n" + "\taugment /model:decorators {\n" + "        leaf test1 {\n" + "            type string;\n" + "        }\n" + "\t\tleaf test2 {\n" + "            type boolean;\n" + "        }\n" + "\t\tleaf test3 {\n" + "            type uint32;\n" + "        }\n" + "\t\tleaf test4 {\n" + "            type decimal64;\n" + "        }\n" + "        }\n" + "\t\n" + "\tidentity geo-classifier {\n" + "\t\tbase model:classifiers;\n" + "\t}\n" + " \n" + "    identity urban {\n" + "        base geo-classifier;\n" + "    }\n" + "\t\n" + "\tidentity rural {\n" + "        base geo-classifier;\n" + "    }\n" + "\n" + "}")
                         .getBytes());
         Map<String, Object> expected = new HashMap<>();
         expected.put("moduleName", "module-rapp-module1");
         expected.put("revision", "2024-05-08");
         expected.put(CLASSIFIERS, List.of("geo-classifier", "urban", "rural"));
-        expected.put(DECORATORS, Map.of("test1", "TEXT", "test2", "BOOLEAN", "test3", "INT"));
+        expected.put(DECORATORS, Map.of("test1", "TEXT", "test2", "BOOLEAN", "test3", "INT", "test4", "DEC"));
 
         Map<String, Object> actual = ExposureYangParser.validateSchemasYang(correctFile);
         assertEquals(expected, actual);
index 5b8e951..5fc1af7 100644 (file)
@@ -30,7 +30,9 @@ import java.io.IOException;
 import java.nio.charset.StandardCharsets;
 import java.nio.file.Files;
 import java.nio.file.Paths;
+import java.util.HashSet;
 import java.util.List;
+import java.util.Set;
 
 import org.junit.jupiter.api.BeforeAll;
 import org.junit.jupiter.api.Test;
@@ -73,6 +75,27 @@ class IngestionYangParserTest {
         IngestionYangParser.loadModels();
     }
 
+    @Test
+    void testLoadAndValuateModels_Successful() {
+        final Set<String> modulesToImport = Set.of("_3gpp-common-yang-extensions", "_3gpp-common-yang-types",
+                "ietf-geo-location", "ietf-inet-types", "ietf-yang-types");
+
+        final Set<String> modulesToImplement = Set.of("o-ran-smo-teiv-common-yang-extensions",
+                "o-ran-smo-teiv-common-yang-types", "o-ran-smo-teiv-equipment", "o-ran-smo-teiv-oam", "o-ran-smo-teiv-ran",
+                "o-ran-smo-teiv-rel-equipment-ran", "o-ran-smo-teiv-rel-oam-ran");
+
+        List<String> importModelList = assertDoesNotThrow(() -> YangModelLoader.readYangModelsFromPath(
+                "classpath:models/import/*.yang"));
+        List<String> implementModelList = assertDoesNotThrow(() -> YangModelLoader.readYangModelsFromPath(
+                "classpath:models/*.yang"));
+
+        Set<String> importModulesSet = new HashSet<>(importModelList);
+        Set<String> implementModulesSet = new HashSet<>(implementModelList);
+
+        assertTrue(importModulesSet.containsAll(modulesToImport));
+        assertTrue(implementModulesSet.containsAll(modulesToImplement));
+    }
+
     @Test
     void parseMultipleTypesOfEntities() throws YangException {
         RootInstance rootInstance = parseAndValidateFromFile("src/test/resources/yang/parser/multiple-entity.json",
diff --git a/teiv/src/test/java/org/oran/smo/teiv/utils/YangModelValidationTestUtil.java b/teiv/src/test/java/org/oran/smo/teiv/utils/YangModelValidationTestUtil.java
new file mode 100644 (file)
index 0000000..3bdfe27
--- /dev/null
@@ -0,0 +1,108 @@
+/*
+ *  ============LICENSE_START=======================================================
+ *  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+ *  ================================================================================
+ *  Licensed under the Apache License, Version 2.0 (the "License");
+ *  you may not use this file except in compliance with the License.
+ *  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing, software
+ *  distributed under the License is distributed on an "AS IS" BASIS,
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *  See the License for the specific language governing permissions and
+ *  limitations under the License.
+ *
+ *  SPDX-License-Identifier: Apache-2.0
+ *  ============LICENSE_END=========================================================
+ */
+
+package org.oran.smo.teiv.utils;
+
+import org.mockito.MockedStatic;
+import org.mockito.Mockito;
+import org.oran.smo.teiv.exception.YangException;
+import org.oran.smo.teiv.exception.YangSchemaException;
+import org.oran.smo.teiv.exposure.spi.Module;
+import org.oran.smo.teiv.schema.SchemaRegistry;
+import org.oran.smo.teiv.utils.yangparser.IngestionYangParser;
+import org.oran.smo.teiv.utils.yangparser.YangModelLoader;
+import org.oran.smo.yangtools.parser.input.StringYangInput;
+import org.oran.smo.yangtools.parser.model.ConformanceType;
+import org.oran.smo.yangtools.parser.model.YangModel;
+import org.springframework.util.StringUtils;
+
+import java.io.File;
+import java.io.IOException;
+import java.nio.charset.StandardCharsets;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Base64;
+import java.util.List;
+import java.util.Locale;
+import java.util.Map;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+import static org.mockito.ArgumentMatchers.any;
+
+public class YangModelValidationTestUtil {
+    public static void mockLoadAndValidateModels() throws YangException, IOException {
+        try (MockedStatic<YangModelLoader> mockedLoader = Mockito.mockStatic(YangModelLoader.class)) {
+            List<String> modulesImport = collectYangFilesNameFromPath("src/main/resources/models/import");
+            List<String> modulesImplement = collectYangFilesNameFromPath("src/main/resources/models");
+            modulesImplement.addAll(collectYangFilesNameFromPath("src/test/resources/yang/models"));
+
+            Map<String, Module> modules = SchemaRegistry.getModuleRegistry();
+            if (modules == null) {
+                throw YangSchemaException.failedToLoadSchema();
+            }
+
+            List<String> implementList = new ArrayList<>();
+            List<String> importList = new ArrayList<>();
+
+            modules.values().stream().filter(module -> module.getContent() != null).forEach(module -> {
+                String content = new String(Base64.getDecoder().decode(module.getContent()), StandardCharsets.UTF_8);
+                if (modulesImport.contains(module.getName())) {
+                    importList.add(content);
+                }
+                if (modulesImplement.contains(module.getName())) {
+                    implementList.add(content);
+                }
+            });
+
+            List<YangModel> models = createYangModels(importList, implementList);
+            mockedLoader.when(() -> YangModelLoader.loadModulesFromSchemaRegistry()).thenReturn(models);
+            mockedLoader.when(() -> YangModelLoader.createParserExecutionContext(any(), any(), any())).thenCallRealMethod();
+            mockedLoader.when(() -> YangModelLoader.parseModelsIntoContext(any(), any())).thenReturn(models);
+            IngestionYangParser.loadModels();
+        }
+    }
+
+    private static List<String> collectYangFilesNameFromPath(String resourcePath) throws IOException {
+        File directory = new File(resourcePath);
+        if (directory.isFile()) {
+            return List.of(StringUtils.stripFilenameExtension(directory.getName().toLowerCase(Locale.ROOT)));
+        }
+        File[] files = directory.listFiles();
+        if (files == null) {
+            throw new IOException();
+        }
+        return Arrays.stream(files).filter(File::isFile).filter(file -> file.getName().endsWith(".yang")).map(
+                file -> StringUtils.stripFilenameExtension(file.getName().toLowerCase(Locale.ROOT))).collect(Collectors
+                        .toList());
+    }
+
+    public static List<YangModel> createYangModels(List<String> importList, List<String> implementList) {
+        List<YangModel> yangModelInputs = new ArrayList<>();
+        yangModelInputs.addAll(createYangModels(importList, ConformanceType.IMPORT));
+        yangModelInputs.addAll(createYangModels(implementList, ConformanceType.IMPLEMENT));
+        return yangModelInputs;
+    }
+
+    private static List<YangModel> createYangModels(List<String> resources, ConformanceType conformanceType) {
+        return resources.stream().map(resource -> new YangModel(new StringYangInput(resource, resource,
+                "application/yang-data+json"), conformanceType)).filter(Objects::nonNull).toList();
+    }
+}
index ef4d22e..dfed6ed 100644 (file)
@@ -13,7 +13,7 @@
                     {
                         "id": "id1",
                         "attributes": {
-                            "gNBId": -1.0
+                            "gNBId": "abba"
                         },
                         "sourceIds": [
                             "source1",
index 8dc4da7..cb0bd55 100644 (file)
                     {
                         "id": "AntennaCapability_3",
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "1",
-                                "attribute_2": "2"
-                            }
+                            "geranFqBands": [
+                                "1",
+                                "2"
+                            ]
                         },
                         "sourceIds": [
                             "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Ireland,MeContext=NR01gNodeBRadio00009,ManagedElement=NR01gNodeBRadio00009,OCUCPFunction=1",
@@ -45,7 +45,7 @@
                         "id": "ODU_2",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": "111",
+                                "mcc": "251",
                                 "mnc": "211"
                             },
                             "gNBDUId": 13,
                 ]
             },
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_61",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "source1",
                             "source2"
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_41",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "source1",
                             "source2"
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "relation_one_to_one_missing_bSide",
                         "aSide": "ManagedElement_61",
                             "source1",
                             "source2"
                         ]
+                    },
+                    {
+                        "id": "relation_one_to_one_both_sides_missing",
+                        "aSide": "ManagedElement_X",
+                        "bSide": "NRCellDU_X",
+                        "sourceIds": [
+                            "source1",
+                            "source2"
+                        ]
                     }
                 ]
             },
                             "source1",
                             "source2"
                         ]
+                    },
+                    {
+                        "id": "relation_one_to_many_both_sides_missing",
+                        "aSide": "ODU_X",
+                        "bSide": "NRCellDU_X",
+                        "sourceIds": [
+                            "source1",
+                            "source2"
+                        ]
                     }
                 ]
             },
index 8610767..dbb6008 100644 (file)
                     {
                         "id": "AntennaCapability_1",
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "1",
-                                "attribute_2": "2"
-                            }
+                            "geranFqBands": [
+                                "1",
+                                "2"
+                            ]
                         },
                         "sourceIds": [
                             "source1",
                     {
                         "id": "AntennaCapability_2",
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "1",
-                                "attribute_2": "2"
-                            }
+                            "geranFqBands": [
+                                "1",
+                                "2"
+                            ]
                         },
                         "sourceIds": [
                             "source1",
index b954484..6e3cef2 100644 (file)
@@ -12,9 +12,6 @@
                 "o-ran-smo-teiv-oam:ManagedElement": [
                     {
                         "id": "ManagedElement_1",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "urn:3gpp:dn:fdn1",
                             "urn:cmHandle:1234"
index 1869e10..8bc8370 100644 (file)
@@ -12,9 +12,6 @@
                 "o-ran-smo-teiv-oam:ManagedElement": [
                     {
                         "id": "ManagedElement_1",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "urn:3gpp:dn:fdn1",
                             "urn:cmHandle:12345"
@@ -22,9 +19,6 @@
                     },
                     {
                         "id": "ManagedElement_2",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "urn:3gpp:dn:fdn1",
                             "urn:cmHandle:12345"
@@ -52,8 +46,8 @@
                         "id": "ODU_1",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": 110,
-                                "mnc": 210
+                                "mcc": "250",
+                                "mnc": "210"
                             },
                             "gNBDUId": 111,
                             "gNBId": 123,
index 40b6d97..1d58268 100644 (file)
@@ -9,12 +9,9 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_21",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "source1",
                             "source2"
@@ -22,9 +19,6 @@
                     },
                     {
                         "id": "ManagedElement_41",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "source1",
                             "source2"
@@ -33,7 +27,7 @@
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_21",
                         "attributes": {
@@ -62,7 +56,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "relation_11",
                         "aSide": "ManagedElement_21",
index 1f61d05..a9e2735 100644 (file)
@@ -33,7 +33,7 @@
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee": [
+                "o-ran-smo-teiv-equipment-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee": [
                     {
                         "id": "AntennaModule_3",
                         "attributes": {
@@ -79,7 +79,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "one_to_many_relation_1",
                         "aSide": "AntennaModule_3",
@@ -92,7 +92,7 @@
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "one_to_one_relation_1",
                         "aSide": "AntennaModule_51",
index a8ff2d0..f27419d 100644 (file)
                             "urn:cmHandle:395221E080CCF0FD1929103B15999999"
                         ],
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "1",
-                                "attribute_2": "2"
-                            }
+                            "geranFqBands": [
+                                "1",
+                                "2"
+                            ]
                         }
                     },
                     {
                             "urn:cmHandle:395221E080CCF0FD1929103B15999999"
                         ],
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "1",
-                                "attribute_2": "2"
-                            }
+                            "geranFqBands": [
+                                "1",
+                                "2"
+                            ]
                         }
                     }
                 ]
index dc1b118..9438902 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_21"
                     }
@@ -18,7 +18,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "relation_12"
                     }
index 74985ee..6b64195 100644 (file)
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "one_to_many_relation_1"
                     }
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "one_to_one_relation_1"
                     }
index c454317..597c3ef 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_1",
                         "attributes": {
@@ -43,7 +43,7 @@
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_1",
                         "attributes": {
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn": [
+                "o-ran-smo-teiv-ran-test:ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn": [
                     {
                         "id": "ODUFunction_1",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": "110",
+                                "mcc": "250",
                                 "mnc": "210"
                             },
                             "gNBDUId": 12,
@@ -94,7 +94,7 @@
                         "id": "ODUFunction_2",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": "110",
+                                "mcc": "250",
                                 "mnc": "210"
                             },
                             "gNBDUId": 12,
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee": [
+                "o-ran-smo-teiv-equipment-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee": [
                     {
                         "id": "AntennaModule_1",
                         "attributes": {
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy": [
+                "o-ran-smo-teiv-ran-test:AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy": [
                     {
                         "id": "AntennaCapability_id1",
                         "attributes": {
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr": [
+                "o-ran-smo-teiv-ran-test:LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr": [
                     {
                         "id": "LTESectorCarrier_id1",
                         "attributes": {
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN": [
+                "o-ran-smo-teiv-rel-oam-ran-test:MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN": [
                     {
                         "id": "MANAGEDELEMENT_MANAGES_ODUFUNCTION_relation_1",
                         "aSide": "ManagedElement_1",
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "ODUFUNCTION_PROVIDES_NRCELLDU_relation_1",
                         "aSide": "ODUFunction_2",
                 ]
             },
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "ManagedElement_USES_NRCELLDU_relation_1",
                         "aSide": "ManagedElement_3",
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "ANTENNAMODULE_REALISED_BY_ANTENNAMODULE_relation_1",
                         "aSide": "AntennaModule_1",
                 ]
             },
             {
-                "o-ran-smo-teiv-equipment:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
+                "o-ran-smo-teiv-equipment-test:ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE": [
                     {
                         "id": "ANTENNAMODULE_DEPLOYED_ON_ANTENNAMODULE_relation_1",
                         "aSide": "AntennaModule_5",
                 ]
             },
             {
-                "o-ran-smo-teiv-rel-equipment-ran:ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY": [
+                "o-ran-smo-teiv-rel-equipment-ran-test:ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY": [
                     {
                         "id": "ANTENNAMODULE_SERVES_ANTENNACAPABILITY_relation_1",
                         "aSide": "AntennaModule_7",
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY": [
+                "o-ran-smo-teiv-ran-test:LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY": [
                     {
                         "id": "LTESECTORCARRIER_USES_ANTENNACAPABILITY_relation_1",
                         "aSide": "LTESectorCarrier_id1",
index 5d3399a..efb1988 100644 (file)
                     {
                         "id": "AntennaCapability_1",
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "2",
-                                "attribute_2": "3"
-                            }
+                            "geranFqBands": [
+                                "2",
+                                "3"
+                            ]
                         },
                         "sourceIds": [
                             "source1",
                     {
                         "id": "AntennaCapability_2",
                         "attributes": {
-                            "geranFqBands": {
-                                "attribute_1": "23",
-                                "attribute_2": "23"
-                            }
+                            "geranFqBands": [
+                                "23",
+                                "34"
+                            ]
                         },
                         "sourceIds": [
                             "source1",
index 71dbe0c..0771248 100644 (file)
@@ -14,7 +14,7 @@
                         "id": "ODU_1",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": "110",
+                                "mcc": "250",
                                 "mnc": "210"
                             },
                             "gNBDUId": 12,
index 54608bf..cf4394d 100644 (file)
@@ -12,9 +12,6 @@
                 "o-ran-smo-teiv-oam:ManagedElement": [
                     {
                         "id": "ManagedElement_1",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "urn:3gpp:dn:fdn1",
                             "urn:cmHandle:1234"
@@ -22,9 +19,6 @@
                     },
                     {
                         "id": "ManagedElement_2",
-                        "attributes": {
-
-                        },
                         "sourceIds": [
                             "urn:3gpp:dn:fdn1",
                             "urn:cmHandle:1234"
@@ -52,8 +46,8 @@
                         "id": "ODU_1",
                         "attributes": {
                             "dUpLMNId": {
-                                "mcc": 110,
-                                "mnc": 210
+                                "mcc": "250",
+                                "mnc": "210"
                             },
                             "gNBDUId": 111,
                             "gNBId": 123,
index 01547b7..04cc9cf 100644 (file)
@@ -1,5 +1,5 @@
 {
-    "84E676149362F50C55FE1E004B98D4891916BBF3": [
+    "F93C2CA075353668A76B4718E07B741ACCD83641": [
         {
             "id": "NRCellDU_41"
         },
                 "firstDiscovered": "<AFTER TEST START TIME>",
                 "lastModified": "<AFTER TEST START TIME>"
             }
+        },
+        {
+            "id": "NRCellDU_X",
+            "CD_sourceIds": [
+                "relation_one_to_one_both_sides_missing"
+            ]
         }
     ],
-    "28C9A375E800E82308EBE7DA2932EF2C0AF13C38": [
+    "C9475FE40C02BEB41F720B4284A856F2CF49E1F3": [
         {
             "id": "ManagedElement_61",
             "REL_FK_used-nrCellDu": "NRCellDU_51",
                 "source1",
                 "source2"
             ]
+        },
+        {
+            "id": "ManagedElement_X",
+            "REL_FK_used-nrCellDu": "NRCellDU_X",
+            "REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": "relation_one_to_one_both_sides_missing",
+            "CD_sourceIds": [
+                "relation_one_to_one_both_sides_missing"
+            ],
+            "REL_CD_1F61FA6DDAECE90540F9880F2A98037B1530A5A4": [
+                "source1",
+                "source2"
+            ]
         }
     ],
     "o-ran-smo-teiv-ran_NRCellDU": [
                 "source1",
                 "source2"
             ]
+        },
+        {
+            "id": "NRCellDU_X",
+            "REL_FK_provided-by-oduFunction": "ODU_X",
+            "REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU": "relation_one_to_many_both_sides_missing",
+            "CD_sourceIds": [
+                "relation_one_to_many_both_sides_missing"
+            ],
+            "metadata": {
+                "reliabilityIndicator": "ADVISED",
+                "firstDiscovered": "<AFTER TEST START TIME>",
+                "lastModified": "<AFTER TEST START TIME>"
+            },
+            "REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU": [
+                "source1",
+                "source2"
+            ]
         }
     ],
     "o-ran-smo-teiv-ran_ODUFunction": [
         {
             "id": "ODU_2",
             "dUpLMNId": {
-                "mcc": "111",
+                "mcc": "251",
                 "mnc": "211"
             },
             "gNBDUId": 13,
                 "firstDiscovered": "<AFTER TEST START TIME>",
                 "lastModified": "<AFTER TEST START TIME>"
             }
+        },
+        {
+            "id": "ODU_X",
+            "CD_sourceIds": [
+                "relation_one_to_many_both_sides_missing"
+            ],
+            "metadata": {
+                "reliabilityIndicator": "ADVISED",
+                "firstDiscovered": "<AFTER TEST START TIME>",
+                "lastModified": "<AFTER TEST START TIME>"
+            }
         }
     ],
     "o-ran-smo-teiv-equipment_AntennaModule": [
     "o-ran-smo-teiv-ran_AntennaCapability": [
         {
             "id": "AntennaCapability_3",
-            "geranFqBands": {
-                "attribute_1": "1",
-                "attribute_2": "2"
-            }
+            "geranFqBands": [
+                1,
+                2
+            ]
         },
         {
             "id": "AntennaCapability_123",
index eabcc96..d27de8d 100644 (file)
     "o-ran-smo-teiv-ran_AntennaCapability": [
         {
             "id": "AntennaCapability_1",
-            "geranFqBands": {
-                "attribute_1": "1",
-                "attribute_2": "2"
-            },
+            "geranFqBands": [
+                1,
+                2
+            ],
             "metadata": {
                 "reliabilityIndicator": "OK",
                 "firstDiscovered": "<AFTER TEST START TIME>",
         },
         {
             "id": "AntennaCapability_2",
-            "geranFqBands": {
-                "attribute_1": "1",
-                "attribute_2": "2"
-            },
+            "geranFqBands": [
+                1,
+                2
+            ],
             "metadata": {
                 "reliabilityIndicator": "OK",
                 "firstDiscovered": "<AFTER TEST START TIME>",
index 0307ab0..7c90d26 100644 (file)
@@ -1,5 +1,5 @@
 {
-    "84E676149362F50C55FE1E004B98D4891916BBF3": [
+    "F93C2CA075353668A76B4718E07B741ACCD83641": [
         {
             "id": "NRCellDU_21"
         },
@@ -7,7 +7,7 @@
             "id": "NRCellDU_31"
         }
     ],
-    "28C9A375E800E82308EBE7DA2932EF2C0AF13C38": [
+    "C9475FE40C02BEB41F720B4284A856F2CF49E1F3": [
         {
             "id": "ManagedElement_21",
             "REL_FK_used-nrCellDu": "NRCellDU_21",
index 62df5f4..c22ff47 100644 (file)
                 "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Ireland,MeContext=NR01gNodeBRadio00009,ManagedElement=NR01gNodeBRadio00009,OCUCPFunction=1",
                 "urn:cmHandle:395221E080CCF0FD1929103B15999999"
             ],
-            "geranFqBands": {
-                "attribute_1": "1",
-                "attribute_2": "2"
-            },
+            "geranFqBands": [
+                1,
+                2
+            ],
             "eUtranFqBands": null,
             "nRFqBands": null,
             "metadata": {
                 "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Ireland,MeContext=NR01gNodeBRadio00009,ManagedElement=NR01gNodeBRadio00009,OCUCPFunction=1",
                 "urn:cmHandle:395221E080CCF0FD1929103B15999999"
             ],
-            "geranFqBands": {
-                "attribute_1": "1",
-                "attribute_2": "2"
-            },
+            "geranFqBands": [
+                1,
+                2
+            ],
             "eUtranFqBands": null,
             "nRFqBands": null,
             "metadata": {
index 67de539..4922325 100644 (file)
@@ -1,5 +1,5 @@
 {
-    "84E676149362F50C55FE1E004B98D4891916BBF3": [
+    "F93C2CA075353668A76B4718E07B741ACCD83641": [
         {
             "id": "NRCellDU_21"
         },
@@ -7,12 +7,16 @@
             "id": "NRCellDU_31"
         }
     ],
-    "28C9A375E800E82308EBE7DA2932EF2C0AF13C38": [
+    "C9475FE40C02BEB41F720B4284A856F2CF49E1F3": [
         {
             "id": "ManagedElement_41",
             "REL_FK_used-nrCellDu": null,
             "REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": null,
-            "REL_metadata_C9E09FBCCBA1F6A3252B71B869B269EF28AACDFB": null
+            "REL_metadata_C9E09FBCCBA1F6A3252B71B869B269EF28AACDFB": null,
+            "REL_CD_E388983F3E6BFAD67CA100F0AFCF8CD3E9B89ADD": [],
+            "REL_CD_EF3979E9DAF31B7949C883654633E633B9D35B92": {
+
+            }
         }
     ]
 }
index eef53b8..e623b99 100644 (file)
     "o-ran-smo-teiv-ran_AntennaCapability": [
         {
             "id": "AntennaCapability_1",
-            "geranFqBands": {
-                "attribute_1": "2",
-                "attribute_2": "3"
-            },
+            "geranFqBands": [
+                2,
+                3
+            ],
             "metadata": {
                 "reliabilityIndicator": "OK",
                 "firstDiscovered": "<BEFORE TEST START TIME>",
         },
         {
             "id": "AntennaCapability_2",
-            "geranFqBands": {
-                "attribute_1": "23",
-                "attribute_2": "23"
-            }
+            "geranFqBands": [
+                23,
+                34
+            ]
         }
     ],
     "CFC235E0404703D1E4454647DF8AAE2C193DB402": [
index b695a6c..25ec29b 100644 (file)
@@ -56,7 +56,7 @@
         {
             "id": "ODU_1",
             "dUpLMNId": {
-                "mcc": "110",
+                "mcc": "250",
                 "mnc": "210"
             },
             "gNBDUId": 12,
index dcfc153..4043b85 100644 (file)
@@ -1,5 +1,5 @@
 {
-    "28C9A375E800E82308EBE7DA2932EF2C0AF13C38": [
+    "C9475FE40C02BEB41F720B4284A856F2CF49E1F3": [
         "ManagedElement_21",
         "relation_11",
         "relation_12"
index 049e2aa..1592270 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_1",
                         "attributes": {
@@ -23,7 +23,7 @@
                 ]
             },
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_1",
                         "attributes": {
@@ -42,7 +42,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_1",
index b4173e8..dc09192 100644 (file)
@@ -42,7 +42,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_2",
index e1d2134..c4048eb 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_2",
                         "attributes": {
@@ -25,7 +25,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_2",
                         "aSide": "ManagedElement_2",
index fc00d41..7e62f34 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_2",
index ea4fe25..d719b33 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_1",
                         "attributes": {
@@ -28,7 +28,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_1",
index 126787f..9601a26 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-oam:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
+                "o-ran-smo-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt": [
                     {
                         "id": "ManagedElement_1",
                         "attributes": {
@@ -25,7 +25,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_1",
index 3bd21b3..9295aec 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_1",
index c71198c..bfa289e 100644 (file)
@@ -9,7 +9,7 @@
     "data": {
         "entities": [
             {
-                "o-ran-smo-teiv-ran:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU": [
                     {
                         "id": "NRCellDU_2",
                         "attributes": {
@@ -28,7 +28,7 @@
         ],
         "relationships": [
             {
-                "o-ran-smo-teiv-rel-oam-ran:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
+                "o-ran-smo-teiv-rel-oam-ran-test:ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU": [
                     {
                         "id": "Relation_OneToOne_1",
                         "aSide": "ManagedElement_2",
index 90d7662..bbe0ecb 100644 (file)
@@ -225,7 +225,7 @@ import org.springframework.cloud.contract.spec.Contract
         }
     },
     Contract.make {
-        description "SUCCESS - 200: Get classifiers using getRelationshipsByType - CONTAINS"
+        description "NOT FOUND - 404: Get classifiers using getRelationshipsByType - CONTAINS"
         request {
             method GET()
             url "/topology-inventory/v1alpha11/domains/REL_OAM_RAN/relationship-types/MANAGEDELEMENT_MANAGES_ODUFUNCTION/relationships?offset=0&limit=500&targetFilter=/classifiers&scopeFilter=/classifiers[contains(@item,'NOT_EXISTING')]"
@@ -233,7 +233,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                     "status": "NOT_FOUND",
index 7fe40aa..449740c 100644 (file)
@@ -233,5 +233,81 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NO_CONTENT()
         }
+    },
+    Contract.make {
+        description "BAD REQUEST - 400: Invalid operation type in the classifiers request."
+        request {
+            method POST()
+            url "/topology-inventory/v1alpha11/classifiers"
+            headers {
+                contentType("application/json")
+                accept('application/problem+json')
+            }
+            body('''{
+                "classifiers": [
+                        "test-app-module-wrong:Rural",
+                        "test-app-module:Weekend"
+                 ],
+                "entityIds": [
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=13,ODUFunction=13",
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=14,ODUFunction=14"
+                ],
+                "operation": "unknown"
+            }''')
+        }
+        response {
+            status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
+            body('''{
+                "status": "BAD_REQUEST",
+                "message": "Failed to process the request to merge/remove classifiers",
+                "details": "Unexpected value 'unknown'. Invalid value for OperationEnum, allowed values: [merge, delete]"
+            }''')
+            bodyMatchers {
+                jsonPath('$.status', byEquality())
+                jsonPath('$.message', byEquality())
+                jsonPath('$.details', byEquality())
+            }
+        }
+    },
+    Contract.make {
+        description "BAD REQUEST - 400: Using object type for the classifiers parameter in the payload."
+        request {
+            method POST()
+            url "/topology-inventory/v1alpha11/classifiers"
+            headers {
+                contentType("application/json")
+                accept('application/problem+json')
+            }
+            body('''{
+                "classifiers": {
+                    "test-app-module:textdata": "Stockholm",
+                    "test-app-module:intdata": 123
+                },
+                "entityIds": [
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=13,ODUFunction=13",
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=14,ODUFunction=14"
+                ],
+                "operation": "delete"
+            }''')
+        }
+        response {
+            status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
+            body('''{
+                "status": "BAD_REQUEST",
+                "message": "Failed to process the request to merge/remove classifiers",
+                "details": "Cannot deserialize value of type `java.util.ArrayList<java.lang.String>` from Object value (token `JsonToken.START_OBJECT`)"
+            }''')
+            bodyMatchers {
+                jsonPath('$.status', byEquality())
+                jsonPath('$.message', byEquality())
+                jsonPath('$.details', byEquality())
+            }
+        }
     }
 ]
index 3ea0fd8..6005524 100644 (file)
@@ -264,7 +264,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index f3cacab..3edbcd8 100644 (file)
@@ -520,7 +520,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -538,7 +538,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index e1dd959..a2daa0b 100644 (file)
@@ -1520,7 +1520,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1538,7 +1538,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1547,6 +1547,24 @@ import org.springframework.cloud.contract.spec.Contract
             }''')
         }
     },
+    Contract.make {
+        description 'ERROR - 400: Get entities of type AntennaModule with scopeFilter inside MULTIPOLYGON - Invalid format: missing parentheses in the second list of points.'
+        request {
+            method GET()
+            url "/topology-inventory/v1alpha11/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),(60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+        }
+        response {
+            status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
+            body('''{
+                "status": "BAD_REQUEST",
+                "message": "Invalid query condition",
+                "details": "Invalid parameter for covered by condition"
+            }''')
+        }
+    },
     Contract.make {
         description 'ERROR - 400: Get entities of type AntennaModule with scopeFilter on geographic attribute with height - 1 coordinate'
         request {
@@ -1556,7 +1574,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1574,7 +1592,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1592,7 +1610,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1610,7 +1628,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1629,7 +1647,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1647,7 +1665,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1835,7 +1853,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                "status": "BAD_REQUEST",
@@ -1858,7 +1876,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                "status": "BAD_REQUEST",
@@ -1881,7 +1899,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                "status": "BAD_REQUEST",
@@ -1904,7 +1922,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                "status": "BAD_REQUEST",
@@ -2009,6 +2027,51 @@ import org.springframework.cloud.contract.spec.Contract
             }
         }
     },
+    Contract.make {
+        description 'SUCCESS - 200: Get entities of type AntennaModule inside MultiPolygon'
+        request {
+            method GET()
+            url "/topology-inventory/v1alpha11/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+        }
+        response {
+            status OK()
+            headers {
+                contentType('application/json')
+            }
+            body('''{
+                "items": [
+                    {
+                        "o-ran-smo-teiv-equipment:AntennaModule": [
+                            {
+                                "id": "urn:o-ran:smo:teiv:sha512:AntennaModule=971FCD28D02B78DDD982611639A0957140339C5522EAAF3FBACA1B8308CF7B0A870CFA80AE04E259805B2A2CB95E263261309883B4D4BF50183FA17AFBA47EA7"
+                            }
+                        ]
+                    }
+                ],
+                "self": {
+                    "href": "/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+                },
+                "first": {
+                    "href": "/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+                },
+                "prev": {
+                    "href": "/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+                },
+                "next": {
+                    "href": "/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+                },
+                "last": {
+                    "href": "/domains/EQUIPMENT/entity-types/AntennaModule/entities?offset=0&limit=500&scopeFilter=/attributes[coveredBy(@geo-location, 'MULTIPOLYGON(((48 68, 50 68, 50 69, 48 69, 48 68)),((60 70, 50 68, 50 69, 48 69, 60 70)))')]"
+                },
+                "totalCount": 1
+            }''')
+            bodyMatchers {
+                jsonPath('$.items', byType {
+                    occurrence(1)
+                })
+            }
+        }
+    },
     Contract.make {
         description "SUCCESS - 200: Get entities of type AntennaCapability by AntennaModule id"
         request {
@@ -2755,7 +2818,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -2773,7 +2836,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -3318,7 +3381,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                     "status": "BAD_REQUEST",
@@ -3341,7 +3404,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                     "status": "BAD_REQUEST",
@@ -3472,7 +3535,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                     "status": "BAD_REQUEST",
@@ -3495,7 +3558,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -3513,7 +3576,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -3625,7 +3688,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -3643,7 +3706,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index 968ca74..5c587c5 100644 (file)
@@ -94,7 +94,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "NOT_FOUND",
@@ -112,7 +112,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index 8a51d32..dcf0617 100644 (file)
@@ -737,7 +737,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
             "status": "BAD_REQUEST",
@@ -755,7 +755,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
             "status": "NOT_FOUND",
index 9bb9c60..6a2ea2a 100644 (file)
@@ -533,7 +533,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index f6a5b76..0214d0c 100644 (file)
@@ -677,7 +677,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -695,7 +695,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index 3a5241b..665ecb9 100644 (file)
@@ -70,7 +70,7 @@ import org.springframework.cloud.contract.spec.Contract
         }
     },
     Contract.make {
-        description "ERROR - 400: Get relationship with non existing id 'urn:non-existing-id'"
+        description "ERROR - 404: Get relationship with non existing id 'urn:non-existing-id'"
         request {
             method GET()
             url "/topology-inventory/v1alpha11/domains/REL_OAM_RAN/relationship-types/MANAGEDELEMENT_MANAGES_ODUFUNCTION/relationships/urn:non-existing-id"
@@ -78,7 +78,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "NOT_FOUND",
index 1789f43..32ad53f 100644 (file)
@@ -1099,7 +1099,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1117,7 +1117,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1433,12 +1433,100 @@ import org.springframework.cloud.contract.spec.Contract
                 jsonPath('$.items', byType {
                     occurrence(2)
                 })
-                jsonPath('$.items[*].o-ran-smo-teiv-ran:NRCellDU[0].id', byType {
-                    minOccurrence(1)
+                jsonPath('$.items[0].o-ran-smo-teiv-ran:NRCellDU[0].id', byEquality())
+                jsonPath('$.items[1].o-ran-smo-teiv-ran:AntennaCapability[0].id', byEquality())
+            }
+        }
+    },
+    Contract.make {
+        description 'SUCCESS - 200: Get entities of domain RAN  with complex filter here many to many relationship(ANTENNAMODULE_SERVES_NRCELLDU) , one to many(NRCELLDU_USES_NRSECTORCARRIER) where relationship information is stored in NRSECTORCARRIER , and NRCELLDU Attribute. So 3 Logical blocks and 3 joins from NRCELLDU connects to NRSectorCarrier,ANTENNAMODULE_SERVES_NRCELLDU and AntennaModule'
+        request {
+            method GET()
+            url "/topology-inventory/v1alpha11/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+        }
+        response {
+            status OK()
+            headers {
+                contentType('application/json')
+            }
+            body('''{
+                "items": [
+                    {
+                        "o-ran-smo-teiv-ran:NRCellDU": [
+                            {
+                                "id": "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRCellDU=1"
+                            }
+                        ]
+                    }
+                ],
+                "self": {
+                    "href": "/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+                },
+                "first": {
+                    "href": "/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+                },
+                "prev": {
+                    "href": "/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+                },
+                "next": {
+                    "href": "/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+                },
+                "last": {
+                    "href": "/domains/RAN/entities?offset=0&limit=500&scopeFilter=/serving-antennaModule/attributes[@antennaModelNumber='5'];/used-nrSectorCarrier[@id='urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9,NRSectorCarrier=1'];/attributes[@nCI=1]"
+                },
+                "totalCount": 1
+            }''')
+            bodyMatchers {
+                jsonPath('$.items', byType {
+                    occurrence(1)
                 })
-                jsonPath('$.items[*].o-ran-smo-teiv-ran:AntennaCapability[0].id', byType {
-                    minOccurrence(1)
+                jsonPath('$.items[0].o-ran-smo-teiv-ran:NRCellDU[0].id', byEquality())
+            }
+        }
+    },
+    Contract.make {
+        description 'SUCCESS - 200: Get entities with filter on attributes and associations. Based on local dataset ODUFunction with gNBId=9 is connected to three instances of NRCellDU but result should contain just one ODUFunction'
+        request {
+            method GET()
+            url "/topology-inventory/v1alpha11/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+        }
+        response {
+            status OK()
+            headers {
+                contentType('application/json')
+            }
+            body('''{
+                "items": [
+                    {
+                        "o-ran-smo-teiv-ran:ODUFunction": [
+                            {
+                                "id": "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=9,ODUFunction=9"
+                            }
+                        ]
+                    }
+                ],
+                "self": {
+                    "href": "/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+                },
+                "first": {
+                    "href": "/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+                },
+                "prev": {
+                    "href": "/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+                },
+                "next": {
+                    "href": "/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+                },
+                "last": {
+                    "href": "/domains/RAN/entities?offset=0&limit=100&scopeFilter=/attributes[@gNBId=9];/provided-nrCellDu[contains(@id,'urn:3gpp:dn:')]"
+                },
+                "totalCount": 1
+            }''')
+            bodyMatchers {
+                jsonPath('$.items', byType {
+                    occurrence(1)
                 })
+                jsonPath('$.items[0].o-ran-smo-teiv-ran:ODUFunction[0].id', byEquality())
             }
         }
     },
@@ -1491,12 +1579,8 @@ import org.springframework.cloud.contract.spec.Contract
                 jsonPath('$.items', byType {
                     occurrence(2)
                 })
-                jsonPath('$.items[*].o-ran-smo-teiv-ran:NRCellDU[0].id', byType {
-                    minOccurrence(1)
-                })
-                jsonPath('$.items[*].o-ran-smo-teiv-ran:AntennaCapability[0].id', byType {
-                    minOccurrence(1)
-                })
+                jsonPath('$.items[0].o-ran-smo-teiv-ran:NRCellDU[0].id', byEquality())
+                jsonPath('$.items[1].o-ran-smo-teiv-ran:AntennaCapability[0].id', byEquality())
             }
         }
     },
index 00dd9d6..50da626 100644 (file)
@@ -297,5 +297,80 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NO_CONTENT()
         }
+    },
+    Contract.make {
+        description "BAD REQUEST - 400: Invalid operation type in the decorators request."
+        request {
+            method POST()
+            url "/topology-inventory/v1alpha11/decorators"
+            headers {
+                contentType("application/json")
+                accept('application/problem+json')
+            }
+            body('''{
+                "decorators": {
+                    "test-app-module:textdata": "Stockholm",
+                    "test-app-module:intdata": 123
+                },
+                "entityIds": [
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=13,ODUFunction=13",
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=14,ODUFunction=14"
+                ],
+                "operation": "unknown"
+            }''')
+        }
+        response {
+            status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
+            body('''{
+                "status": "BAD_REQUEST",
+                "message": "Failed to process the request to merge/remove decorators",
+                "details": "Unexpected value 'unknown'. Invalid value for OperationEnum, allowed values: [merge, delete]"
+            }''')
+            bodyMatchers {
+                jsonPath('$.status', byEquality())
+                jsonPath('$.message', byEquality())
+                jsonPath('$.details', byEquality())
+            }
+        }
+    },
+    Contract.make {
+        description "BAD REQUEST - 400: Using list type for the decorators parameter in the payload."
+        request {
+            method POST()
+            url "/topology-inventory/v1alpha11/decorators"
+            headers {
+                contentType("application/json")
+                accept('application/problem+json')
+            }
+            body('''{
+                "decorators": [
+                    "test-app-module:textdata"
+                ],
+                "entityIds": [
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=13,ODUFunction=13",
+                    "urn:3gpp:dn:SubNetwork=Europe,SubNetwork=Hungary,MeContext=1,ManagedElement=14,ODUFunction=14"
+                ],
+                "operation": "delete"
+            }''')
+        }
+        response {
+            status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
+            body('''{
+                "status": "BAD_REQUEST",
+                "message": "Failed to process the request to merge/remove decorators",
+                "details": "Cannot deserialize value of type `java.util.LinkedHashMap<java.lang.String,java.lang.Object>` from Array value (token `JsonToken.START_ARRAY`)"
+            }''')
+            bodyMatchers {
+                jsonPath('$.status', byEquality())
+                jsonPath('$.message', byEquality())
+                jsonPath('$.details', byEquality())
+            }
+        }
     }
 ]
index 13b1258..50e9f29 100644 (file)
@@ -566,7 +566,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index 62c21d8..949df7f 100644 (file)
@@ -244,7 +244,7 @@ import org.springframework.cloud.contract.spec.Contract
                     "details": "Invalid schema name: invalid"
                 }''')
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
         }
     }
index 42c0abe..60b7225 100644 (file)
@@ -61,6 +61,9 @@ import org.springframework.cloud.contract.spec.Contract
                     '    leaf weekend { ' +
                     '            type uint32; ' +
                     '        } ' +
+                    '    leaf decimal { ' +
+                    '            type decimal64; ' +
+                    '        } ' +
                     '    } ' +
                     '   ' +
                     '  identity geo-classifier { ' +
@@ -225,6 +228,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid schema name",
@@ -288,6 +294,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid schema name",
@@ -363,6 +372,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -429,6 +441,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -496,6 +511,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -552,6 +570,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid schema name",
@@ -619,6 +640,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -686,6 +710,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -711,6 +738,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -734,6 +764,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
             "status": "BAD_REQUEST",
             "message": "Invalid file input",
@@ -794,6 +827,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -854,6 +890,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -902,6 +941,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -942,6 +984,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -1009,6 +1054,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -1076,6 +1124,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -1116,6 +1167,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "Invalid file input",
@@ -1177,6 +1231,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -1240,6 +1297,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
             "status": "BAD_REQUEST",
             "message": "Invalid file input",
@@ -1303,6 +1363,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid file input",
@@ -1361,11 +1424,84 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status CONFLICT()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "CONFLICT",
                 "message": "Schema in deleting state",
                 "details": "Schema test-app-in-deleting-status already exists and is in the process of being deleted. This may take some time, please try again later."
             }''')
         }
+    },
+    Contract.make {
+        description "ERROR - 400: Create a new classifier and decorator schema with not supported decorator type"
+        request {
+            method POST()
+            url("/topology-inventory/v1alpha11/schemas")
+            headers {
+                contentType(multipartFormData())
+            }
+            multipart(
+                    file: named(
+                    name: $(c(regex(nonEmpty())), p('file.yang')),
+                    contentType: p('application/yang'),
+                    content: $(c(regex(nonEmpty())),
+                    p('module module-rapp-model15 { ' +
+                    '  ' +
+                    '  yang-version 1.1; ' +
+                    '  namespace "urn:module-rapp-model15"; ' +
+                    '  prefix model15; ' +
+                    '   ' +
+                    '    import o-ran-smo-teiv-common-yang-types { prefix model; } ' +
+                    '  import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; } ' +
+                    '   ' +
+                    '  revision "2024-05-08" { ' +
+                    '    description ' +
+                    '    "Initial revision."; ' +
+                    '    or-teiv-yext:label 0.3.0; ' +
+                    '  } ' +
+                    '   ' +
+                    '  augment /model:decorators { ' +
+                    '        leaf urban { ' +
+                    '            type string; ' +
+                    '        } ' +
+                    '    leaf rural { ' +
+                    '            type boolean; ' +
+                    '        } ' +
+                    '    leaf weekend { ' +
+                    '            type uint32; ' +
+                    '        } ' +
+                    '    leaf decimal { ' +
+                    '            type decimal32; ' +
+                    '        } ' +
+                    '    } ' +
+                    '   ' +
+                    '  identity geo-classifier { ' +
+                    '    base model:classifiers; ' +
+                    '  } ' +
+                    '  ' +
+                    '    identity classifierTest1 { ' +
+                    '        base geo-classifier; ' +
+                    '    } ' +
+                    '   ' +
+                    '  identity classifierTest2 { ' +
+                    '        base geo-classifier; ' +
+                    '    } ' +
+                    '   ' +
+                    '  identity classifierTest3 { ' +
+                    '        base model:classifiers; ' +
+                    '  } ' +
+                    '   ' +
+                    '}'))))
+        }
+        response {
+            status BAD_REQUEST()
+            body('''{
+                    "status": "BAD_REQUEST",
+                    "message": "Invalid file input",
+                    "details": "Invalid file input: Cannot resolve typedef 'decimal32'."
+                }''')
+        }
     }
 ]
index 28d6615..9300388 100644 (file)
@@ -41,6 +41,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid schema name",
@@ -56,6 +59,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid schema name",
index fd35df1..7c99158 100644 (file)
@@ -333,7 +333,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -364,7 +364,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -395,7 +395,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -458,7 +458,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -493,7 +493,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -525,7 +525,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -612,7 +612,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -646,7 +646,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -684,7 +684,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -722,7 +722,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -760,7 +760,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -789,7 +789,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -823,7 +823,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -858,7 +858,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -893,7 +893,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -928,7 +928,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -964,7 +964,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1004,7 +1004,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1085,7 +1085,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1119,7 +1119,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1153,7 +1153,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1185,7 +1185,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
index 498177c..0bebf61 100644 (file)
@@ -268,6 +268,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                     "status": "BAD_REQUEST",
                     "message": "getAllGroups.limit: must be less than or equal to 500"
index 1bd72e2..83d0297 100644 (file)
@@ -204,6 +204,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status INTERNAL_SERVER_ERROR()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "INTERNAL_SERVER_ERROR",
                 "message": "Criteria deserialization exception",
@@ -225,7 +228,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -242,6 +245,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status NOT_FOUND()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "NOT_FOUND",
                 "message": "Resource Not Found",
index c29bdcf..849adb7 100644 (file)
@@ -66,6 +66,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
         }
     }
 ]
index 3242238..7972c5f 100644 (file)
@@ -70,7 +70,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "NOT_FOUND",
index 7cbec9e..87a4160 100644 (file)
@@ -597,6 +597,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status NOT_FOUND()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "NOT_FOUND",
                 "message": "Resource Not Found",
@@ -613,7 +616,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body ('''{
                 "status": "NOT_FOUND",
@@ -630,6 +633,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Grammar error",
@@ -645,6 +651,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status NOT_FOUND()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "NOT_FOUND",
                 "message": "Resource Not Found",
@@ -660,6 +669,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Filter Error",
@@ -675,6 +687,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid target filter, only relationship conditions can be provided",
index f6fc5e9..bcec9a1 100644 (file)
@@ -410,6 +410,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status BAD_REQUEST()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "BAD_REQUEST",
                 "message": "Invalid status",
@@ -425,6 +428,9 @@ import org.springframework.cloud.contract.spec.Contract
         }
         response {
             status NOT_FOUND()
+            headers {
+                contentType('application/problem+json')
+            }
             body('''{
                 "status": "NOT_FOUND",
                 "message": "Resource Not Found",
index 72463a3..0bf6068 100644 (file)
@@ -263,7 +263,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -343,7 +343,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -399,7 +399,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -454,7 +454,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -496,7 +496,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -532,7 +532,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "NOT_FOUND",
@@ -573,7 +573,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -614,7 +614,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -679,7 +679,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -815,7 +815,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -847,7 +847,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -874,7 +874,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -905,7 +905,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -938,7 +938,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -971,7 +971,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1004,7 +1004,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1038,7 +1038,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1076,7 +1076,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
@@ -1112,7 +1112,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status NOT_FOUND()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "NOT_FOUND",
@@ -1153,7 +1153,7 @@ import org.springframework.cloud.contract.spec.Contract
         response {
             status BAD_REQUEST()
             headers {
-                contentType('application/json')
+                contentType('application/problem+json')
             }
             body('''{
                 "status": "BAD_REQUEST",
diff --git a/teiv/src/test/resources/pgsqlschema/end-to-end-test-data.sql b/teiv/src/test/resources/pgsqlschema/end-to-end-test-data.sql
new file mode 100644 (file)
index 0000000..52447f0
--- /dev/null
@@ -0,0 +1,2898 @@
+--  ============LICENSE_START=======================================================
+--  Modifications Copyright (C) 2025 OpenInfra Foundation Europe
+--  ================================================================================
+--  Licensed under the Apache License, Version 2.0 (the "License");
+--  you may not use this file except in compliance with the License.
+--  You may obtain a copy of the License at
+--
+--        http://www.apache.org/licenses/LICENSE-2.0
+--
+--  Unless required by applicable law or agreed to in writing, software
+--  distributed under the License is distributed on an "AS IS" BASIS,
+--  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+--  See the License for the specific language governing permissions and
+--  limitations under the License.
+--
+--  SPDX-License-Identifier: Apache-2.0
+--  ============LICENSE_END=========================================================
+
+BEGIN;
+
+CREATE EXTENSION IF NOT EXISTS postgis;
+CREATE EXTENSION IF NOT EXISTS postgis_topology;
+CREATE EXTENSION IF NOT EXISTS pg_trgm;
+
+GRANT USAGE ON SCHEMA topology to :pguser;
+GRANT SELECT ON ALL SEQUENCES IN SCHEMA topology TO :pguser;
+GRANT SELECT ON ALL TABLES IN SCHEMA topology TO :pguser;
+
+CREATE SCHEMA IF NOT EXISTS teiv_data;
+ALTER SCHEMA teiv_data OWNER TO :pguser;
+SET default_tablespace = '';
+SET default_table_access_method = heap;
+
+SET ROLE :'pguser';
+
+-- Function to create CONSTRAINT only if it does not exists
+CREATE OR REPLACE FUNCTION teiv_data.create_constraint_if_not_exists (
+       t_name TEXT, c_name TEXT, constraint_sql TEXT
+)
+RETURNS void AS
+$$
+BEGIN
+       IF NOT EXISTS (SELECT constraint_name FROM information_schema.table_constraints WHERE table_name = t_name AND constraint_name = c_name) THEN
+               EXECUTE constraint_sql;
+       END IF;
+END;
+$$ language 'plpgsql';
+
+CREATE TABLE IF NOT EXISTS teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" (
+       "id"                    TEXT,
+       "aSide_AntennaModule"                   TEXT,
+       "bSide_AntennaCapability"                       TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-equipment_AntennaModule" (
+       "id"                    TEXT,
+       "antennaBeamWidth"                      jsonb,
+       "antennaModelNumber"                    TEXT,
+       "electricalAntennaTilt"                 INTEGER,
+       "geo-location"                  geography,
+       "mechanicalAntennaBearing"                      INTEGER,
+       "mechanicalAntennaTilt"                 INTEGER,
+       "positionWithinSector"                  TEXT,
+       "totalTilt"                     INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_installed-at-site"                      TEXT,
+       "REL_ID_ANTENNAMODULE_INSTALLED_AT_SITE"                        TEXT,
+       "REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE"                      jsonb,
+       "REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE"                    jsonb,
+       "REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE"                     jsonb,
+       "REL_FK_grouped-by-sector"                      TEXT,
+       "REL_ID_SECTOR_GROUPS_ANTENNAMODULE"                    TEXT,
+       "REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE"                  jsonb,
+       "REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE"                        jsonb,
+       "REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ALTER COLUMN "REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-equipment_Site" (
+       "id"                    TEXT,
+       "geo-location"                  geography,
+       "name"                  TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_Site" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_Site" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-equipment_Site" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-oam_ManagedElement" (
+       "id"                    TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-oam_ManagedElement" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-oam_ManagedElement" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-oam_ManagedElement" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_AntennaCapability" (
+       "id"                    TEXT,
+       "eUtranFqBands"                 jsonb,
+       "geranFqBands"                  jsonb,
+       "nRFqBands"                     jsonb,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" (
+       "id"                    TEXT,
+       "eNBId"                 INTEGER,
+       "eNodeBPlmnId"                  jsonb,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_managed-by-managedElement"                      TEXT,
+       "REL_ID_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"                  TEXT,
+       "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"                        jsonb,
+       "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"                      jsonb,
+       "REL_CD_decorators_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"                       jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ALTER COLUMN "REL_CD_decorators_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_EUtranCell" (
+       "id"                    TEXT,
+       "cellId"                        INTEGER,
+       "channelBandwidth"                      INTEGER,
+       "dlChannelBandwidth"                    INTEGER,
+       "duplexType"                    TEXT,
+       "earfcn"                        INTEGER,
+       "earfcndl"                      INTEGER,
+       "earfcnul"                      INTEGER,
+       "tac"                   INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_provided-by-enodebFunction"                     TEXT,
+       "REL_ID_ENODEBFUNCTION_PROVIDES_EUTRANCELL"                     TEXT,
+       "REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_EUTRANCELL"                   jsonb,
+       "REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_EUTRANCELL"                 jsonb,
+       "REL_CD_decorators_ENODEBFUNCTION_PROVIDES_EUTRANCELL"                  jsonb,
+       "REL_FK_grouped-by-sector"                      TEXT,
+       "REL_ID_SECTOR_GROUPS_EUTRANCELL"                       TEXT,
+       "REL_CD_sourceIds_SECTOR_GROUPS_EUTRANCELL"                     jsonb,
+       "REL_CD_classifiers_SECTOR_GROUPS_EUTRANCELL"                   jsonb,
+       "REL_CD_decorators_SECTOR_GROUPS_EUTRANCELL"                    jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_EUTRANCELL" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_EUTRANCELL" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_decorators_ENODEBFUNCTION_PROVIDES_EUTRANCELL" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_sourceIds_SECTOR_GROUPS_EUTRANCELL" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_classifiers_SECTOR_GROUPS_EUTRANCELL" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_EUtranCell" ALTER COLUMN "REL_CD_decorators_SECTOR_GROUPS_EUTRANCELL" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" (
+       "id"                    TEXT,
+       "gNBCUName"                     TEXT,
+       "gNBId"                 BIGINT,
+       "gNBIdLength"                   INTEGER,
+       "pLMNId"                        jsonb,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_managed-by-managedElement"                      TEXT,
+       "REL_ID_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"                   TEXT,
+       "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"                 jsonb,
+       "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"                       jsonb,
+       "REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"                        jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ALTER COLUMN "REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" (
+       "id"                    TEXT,
+       "gNBId"                 BIGINT,
+       "gNBIdLength"                   INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_managed-by-managedElement"                      TEXT,
+       "REL_ID_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"                   TEXT,
+       "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"                 jsonb,
+       "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"                       jsonb,
+       "REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"                        jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ALTER COLUMN "REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_ODUFunction" (
+       "id"                    TEXT,
+       "dUpLMNId"                      jsonb,
+       "gNBDUId"                       BIGINT,
+       "gNBId"                 BIGINT,
+       "gNBIdLength"                   INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_managed-by-managedElement"                      TEXT,
+       "REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION"                     TEXT,
+       "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION"                   jsonb,
+       "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION"                 jsonb,
+       "REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION"                  jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ALTER COLUMN "REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" (
+       "id"                    TEXT,
+       "sectorCarrierType"                     TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_provided-by-enodebFunction"                     TEXT,
+       "REL_ID_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"                       TEXT,
+       "REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"                     jsonb,
+       "REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"                   jsonb,
+       "REL_CD_decorators_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"                    jsonb,
+       "REL_FK_used-by-euTranCell"                     TEXT,
+       "REL_ID_EUTRANCELL_USES_LTESECTORCARRIER"                       TEXT,
+       "REL_CD_sourceIds_EUTRANCELL_USES_LTESECTORCARRIER"                     jsonb,
+       "REL_CD_classifiers_EUTRANCELL_USES_LTESECTORCARRIER"                   jsonb,
+       "REL_CD_decorators_EUTRANCELL_USES_LTESECTORCARRIER"                    jsonb,
+       "REL_FK_used-antennaCapability"                 TEXT,
+       "REL_ID_LTESECTORCARRIER_USES_ANTENNACAPABILITY"                        TEXT,
+       "REL_CD_sourceIds_LTESECTORCARRIER_USES_ANTENNACAPABILITY"                      jsonb,
+       "REL_CD_classifiers_LTESECTORCARRIER_USES_ANTENNACAPABILITY"                    jsonb,
+       "REL_CD_decorators_LTESECTORCARRIER_USES_ANTENNACAPABILITY"                     jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_decorators_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_sourceIds_EUTRANCELL_USES_LTESECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_classifiers_EUTRANCELL_USES_LTESECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_decorators_EUTRANCELL_USES_LTESECTORCARRIER" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_sourceIds_LTESECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_classifiers_LTESECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ALTER COLUMN "REL_CD_decorators_LTESECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_NRCellCU" (
+       "id"                    TEXT,
+       "cellLocalId"                   INTEGER,
+       "nCI"                   BIGINT,
+       "nRTAC"                 INTEGER,
+       "plmnId"                        jsonb,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_provided-by-ocucpFunction"                      TEXT,
+       "REL_ID_OCUCPFUNCTION_PROVIDES_NRCELLCU"                        TEXT,
+       "REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU"                      jsonb,
+       "REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU"                    jsonb,
+       "REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU"                     jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellCU" ALTER COLUMN "REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_NRCellDU" (
+       "id"                    TEXT,
+       "cellLocalId"                   INTEGER,
+       "nCI"                   BIGINT,
+       "nRPCI"                 INTEGER,
+       "nRTAC"                 INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_provided-by-oduFunction"                        TEXT,
+       "REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU"                  TEXT,
+       "REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU"                        jsonb,
+       "REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU"                      jsonb,
+       "REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU"                       jsonb,
+       "REL_FK_grouped-by-sector"                      TEXT,
+       "REL_ID_SECTOR_GROUPS_NRCELLDU"                 TEXT,
+       "REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU"                       jsonb,
+       "REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU"                     jsonb,
+       "REL_CD_decorators_SECTOR_GROUPS_NRCELLDU"                      jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ALTER COLUMN "REL_CD_decorators_SECTOR_GROUPS_NRCELLDU" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" (
+       "id"                    TEXT,
+       "arfcnDL"                       INTEGER,
+       "arfcnUL"                       INTEGER,
+       "bSChannelBwDL"                 INTEGER,
+       "frequencyDL"                   INTEGER,
+       "frequencyUL"                   INTEGER,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "REL_FK_provided-by-oduFunction"                        TEXT,
+       "REL_ID_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"                   TEXT,
+       "REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"                 jsonb,
+       "REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"                       jsonb,
+       "REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"                        jsonb,
+       "REL_FK_used-by-nrCellDu"                       TEXT,
+       "REL_ID_NRCELLDU_USES_NRSECTORCARRIER"                  TEXT,
+       "REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER"                        jsonb,
+       "REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER"                      jsonb,
+       "REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER"                       jsonb,
+       "REL_FK_used-antennaCapability"                 TEXT,
+       "REL_ID_NRSECTORCARRIER_USES_ANTENNACAPABILITY"                 TEXT,
+       "REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY"                       jsonb,
+       "REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY"                     jsonb,
+       "REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY"                      jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ALTER COLUMN "REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-ran_Sector" (
+       "id"                    TEXT,
+       "azimuth"                       DECIMAL,
+       "geo-location"                  geography,
+       "sectorId"                      BIGINT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_Sector" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_Sector" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-ran_Sector" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'CFC235E0404703D1E4454647DF8AAE2C193DB402',
+ 'PK_63E61CB6802F21FE7A04A80A095F6AF8ABF067CE',
+ 'ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD CONSTRAINT "PK_63E61CB6802F21FE7A04A80A095F6AF8ABF067CE" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'PK_o-ran-smo-teiv-equipment_AntennaModule_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "PK_o-ran-smo-teiv-equipment_AntennaModule_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_Site',
+ 'PK_o-ran-smo-teiv-equipment_Site_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD CONSTRAINT "PK_o-ran-smo-teiv-equipment_Site_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-oam_ManagedElement',
+ 'PK_o-ran-smo-teiv-oam_ManagedElement_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-oam_ManagedElement" ADD CONSTRAINT "PK_o-ran-smo-teiv-oam_ManagedElement_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_AntennaCapability',
+ 'PK_o-ran-smo-teiv-ran_AntennaCapability_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_AntennaCapability_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'PK_o-ran-smo-teiv-ran_ENodeBFunction_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_ENodeBFunction_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'PK_o-ran-smo-teiv-ran_EUtranCell_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_EUtranCell_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'PK_o-ran-smo-teiv-ran_OCUCPFunction_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_OCUCPFunction_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'PK_o-ran-smo-teiv-ran_OCUUPFunction_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_OCUUPFunction_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'PK_o-ran-smo-teiv-ran_ODUFunction_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_ODUFunction_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'PK_o-ran-smo-teiv-ran_LTESectorCarrier_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_LTESectorCarrier_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'PK_o-ran-smo-teiv-ran_NRCellCU_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_NRCellCU_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'PK_o-ran-smo-teiv-ran_NRCellDU_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_NRCellDU_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'PK_o-ran-smo-teiv-ran_NRSectorCarrier_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_NRSectorCarrier_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_Sector',
+ 'PK_o-ran-smo-teiv-ran_Sector_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD CONSTRAINT "PK_o-ran-smo-teiv-ran_Sector_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'CFC235E0404703D1E4454647DF8AAE2C193DB402',
+ 'FK_D80D1E6B26DF620B4DE659C600A3B7F709A41960',
+ 'ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD CONSTRAINT "FK_D80D1E6B26DF620B4DE659C600A3B7F709A41960" FOREIGN KEY ("aSide_AntennaModule") REFERENCES teiv_data."o-ran-smo-teiv-equipment_AntennaModule" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'CFC235E0404703D1E4454647DF8AAE2C193DB402',
+ 'FK_7148BEED02C0617DE1DEEB6639F34A9FA9251B06',
+ 'ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD CONSTRAINT "FK_7148BEED02C0617DE1DEEB6639F34A9FA9251B06" FOREIGN KEY ("bSide_AntennaCapability") REFERENCES teiv_data."o-ran-smo-teiv-ran_AntennaCapability" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_E3BAEF04443354C0FC1837CF7964E05BEF9FD6CC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_E3BAEF04443354C0FC1837CF7964E05BEF9FD6CC" FOREIGN KEY ("REL_FK_installed-at-site") REFERENCES teiv_data."o-ran-smo-teiv-equipment_Site" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'UNIQUE_9DF414C2F0CD7FA8BFCB3E9BF851784AC4BC49B1',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "UNIQUE_9DF414C2F0CD7FA8BFCB3E9BF851784AC4BC49B1" UNIQUE ("REL_ID_ANTENNAMODULE_INSTALLED_AT_SITE");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_078764B2F3D613D44CC6E3586F564C83164D2481',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_078764B2F3D613D44CC6E3586F564C83164D2481" FOREIGN KEY ("REL_FK_grouped-by-sector") REFERENCES teiv_data."o-ran-smo-teiv-ran_Sector" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'UNIQUE_78B1D3DCD903AFFB1965D440D87B2D194CA028A0',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "UNIQUE_78B1D3DCD903AFFB1965D440D87B2D194CA028A0" UNIQUE ("REL_ID_SECTOR_GROUPS_ANTENNAMODULE");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'FK_6C99B14BF3C9BC6DE2D69AD55DF323ADCB174167',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "FK_6C99B14BF3C9BC6DE2D69AD55DF323ADCB174167" FOREIGN KEY ("REL_FK_managed-by-managedElement") REFERENCES teiv_data."o-ran-smo-teiv-oam_ManagedElement" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'UNIQUE_A30444B7D036FA579730F0D2853E52FD08DEDCF0',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "UNIQUE_A30444B7D036FA579730F0D2853E52FD08DEDCF0" UNIQUE ("REL_ID_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_2D1FA89480BF856AB865D58FAFB6AC0B476015EB',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_2D1FA89480BF856AB865D58FAFB6AC0B476015EB" FOREIGN KEY ("REL_FK_provided-by-enodebFunction") REFERENCES teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'UNIQUE_CA88C7E60C1A332FA7561FC965ED41DD4125CDED',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "UNIQUE_CA88C7E60C1A332FA7561FC965ED41DD4125CDED" UNIQUE ("REL_ID_ENODEBFUNCTION_PROVIDES_EUTRANCELL");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_REL_FK_grouped-by-sector',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_REL_FK_grouped-by-sector" FOREIGN KEY ("REL_FK_grouped-by-sector") REFERENCES teiv_data."o-ran-smo-teiv-ran_Sector" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'UNIQUE_0513FE4A675A02C31E5EDD6BCB3728911FBDA2FA',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "UNIQUE_0513FE4A675A02C31E5EDD6BCB3728911FBDA2FA" UNIQUE ("REL_ID_SECTOR_GROUPS_EUTRANCELL");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_F1FB8F88851067901B66D53EE1420D2ECCEC98A3',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_F1FB8F88851067901B66D53EE1420D2ECCEC98A3" FOREIGN KEY ("REL_FK_managed-by-managedElement") REFERENCES teiv_data."o-ran-smo-teiv-oam_ManagedElement" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'UNIQUE_50E9E4A87D93AC833B1D1AC05E3B58805909E20E',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "UNIQUE_50E9E4A87D93AC833B1D1AC05E3B58805909E20E" UNIQUE ("REL_ID_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'FK_34D6E2537E8EE1D395CAF5BF9B2182A4696A1EAA',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "FK_34D6E2537E8EE1D395CAF5BF9B2182A4696A1EAA" FOREIGN KEY ("REL_FK_managed-by-managedElement") REFERENCES teiv_data."o-ran-smo-teiv-oam_ManagedElement" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'UNIQUE_0CA05800AC7D277BDCB5CF0097DC35978E9311F4',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "UNIQUE_0CA05800AC7D277BDCB5CF0097DC35978E9311F4" UNIQUE ("REL_ID_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_F67FAF9D3E82B97104E2392DA0AC8A86DF2407CC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_F67FAF9D3E82B97104E2392DA0AC8A86DF2407CC" FOREIGN KEY ("REL_FK_managed-by-managedElement") REFERENCES teiv_data."o-ran-smo-teiv-oam_ManagedElement" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'UNIQUE_5BD09ED226520A0BE27904AEAF0557416808E7E2',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "UNIQUE_5BD09ED226520A0BE27904AEAF0557416808E7E2" UNIQUE ("REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_D0868FBC0BBE2754F4B765C4898C1A1700E2BEFD',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_D0868FBC0BBE2754F4B765C4898C1A1700E2BEFD" FOREIGN KEY ("REL_FK_provided-by-enodebFunction") REFERENCES teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'UNIQUE_FD943EE596337B11E0C640E1176CADF9CD69E19A',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "UNIQUE_FD943EE596337B11E0C640E1176CADF9CD69E19A" UNIQUE ("REL_ID_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_96E6D4983CFFDF30FCA20423B5913DEE486E42D0',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_96E6D4983CFFDF30FCA20423B5913DEE486E42D0" FOREIGN KEY ("REL_FK_used-by-euTranCell") REFERENCES teiv_data."o-ran-smo-teiv-ran_EUtranCell" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'UNIQUE_0A76398FBBC8E01A2D3BA602AB47835794E997E5',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "UNIQUE_0A76398FBBC8E01A2D3BA602AB47835794E997E5" UNIQUE ("REL_ID_EUTRANCELL_USES_LTESECTORCARRIER");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_3D8DF3FBD9C042A888CEB382688C1E8F39D85AFE',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_3D8DF3FBD9C042A888CEB382688C1E8F39D85AFE" FOREIGN KEY ("REL_FK_used-antennaCapability") REFERENCES teiv_data."o-ran-smo-teiv-ran_AntennaCapability" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'UNIQUE_EA18F1D278EAFE834B8A80BCF8A7D8355CD013DF',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "UNIQUE_EA18F1D278EAFE834B8A80BCF8A7D8355CD013DF" UNIQUE ("REL_ID_LTESECTORCARRIER_USES_ANTENNACAPABILITY");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_F2CDD1E84C7F07BF8065F99A5F3488E91E3BB7B2',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_F2CDD1E84C7F07BF8065F99A5F3488E91E3BB7B2" FOREIGN KEY ("REL_FK_provided-by-ocucpFunction") REFERENCES teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'UNIQUE_EA2A6F5BA36ABB0DA357542E05AA2D07415E127A',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "UNIQUE_EA2A6F5BA36ABB0DA357542E05AA2D07415E127A" UNIQUE ("REL_ID_OCUCPFUNCTION_PROVIDES_NRCELLCU");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_provided-by-oduFunction',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_provided-by-oduFunction" FOREIGN KEY ("REL_FK_provided-by-oduFunction") REFERENCES teiv_data."o-ran-smo-teiv-ran_ODUFunction" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'UNIQUE_C3D8E5331EC71D46D4B8CED29FE5F6CEB1D8E67A',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "UNIQUE_C3D8E5331EC71D46D4B8CED29FE5F6CEB1D8E67A" UNIQUE ("REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_grouped-by-sector',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_grouped-by-sector" FOREIGN KEY ("REL_FK_grouped-by-sector") REFERENCES teiv_data."o-ran-smo-teiv-ran_Sector" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'UNIQUE_AC1C114ABED77D6DEC3F3AE3F9EBE8231924AEF4',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "UNIQUE_AC1C114ABED77D6DEC3F3AE3F9EBE8231924AEF4" UNIQUE ("REL_ID_SECTOR_GROUPS_NRCELLDU");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_F7978366174C82E41F0A6ABF29005FF01603858F',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_F7978366174C82E41F0A6ABF29005FF01603858F" FOREIGN KEY ("REL_FK_provided-by-oduFunction") REFERENCES teiv_data."o-ran-smo-teiv-ran_ODUFunction" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'UNIQUE_0AC16A840F6ACDC50136E71EC6D4F3D4E04B8198',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "UNIQUE_0AC16A840F6ACDC50136E71EC6D4F3D4E04B8198" UNIQUE ("REL_ID_ODUFUNCTION_PROVIDES_NRSECTORCARRIER");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_used-by-nrCellDu',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_used-by-nrCellDu" FOREIGN KEY ("REL_FK_used-by-nrCellDu") REFERENCES teiv_data."o-ran-smo-teiv-ran_NRCellDU" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'UNIQUE_1AB577E5AC207ED4C99A9A96BA1C9C35544AFD25',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "UNIQUE_1AB577E5AC207ED4C99A9A96BA1C9C35544AFD25" UNIQUE ("REL_ID_NRCELLDU_USES_NRSECTORCARRIER");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_65D538D54EB33081C808540235FEB28823428E64',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_65D538D54EB33081C808540235FEB28823428E64" FOREIGN KEY ("REL_FK_used-antennaCapability") REFERENCES teiv_data."o-ran-smo-teiv-ran_AntennaCapability" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'UNIQUE_A799EC9DA6624651081E1DA21B5F0C2D38F6A192',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "UNIQUE_A799EC9DA6624651081E1DA21B5F0C2D38F6A192" UNIQUE ("REL_ID_NRSECTORCARRIER_USES_ANTENNACAPABILITY");'
+);
+
+CREATE INDEX IF NOT EXISTS "IDX_E896A9EB22A3F9F96CE75A271475316A98B629C8" ON teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_DD0D676834B12CA2F7E8219310998376A08D7F5F" ON teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_7BF09D0227840279556AD27ACECB068705893D28" ON teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_21B0F1FE632B6CB185C49BA6F00224068F443215" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("antennaBeamWidth"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_905011128A2C218B5352C19ED1FE9851F43EB911" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_1C0CAFD80FDD6444044E3F76C7C0A7BDC35F9BC8" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_CD_decorators" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_F497DEC01DA066CB09DA2AA7EDE3F4410078491B" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_17E417F7EF56809674BE1D5F5154DCCE01E00A96" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_2321BFA482AD2700F41E2BA359F6EB00F47601B9" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE");
+
+CREATE INDEX IF NOT EXISTS "IDX_5ABDB19E55A6BDEF33855F14CB1B3B8CF457912C" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_83B6347C0C0A005D5E3D856D973D3322DFEDEA35" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN (("REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_6C6FBD69F47F41970595A8775DC99CA0F5E894A1" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE");
+
+CREATE INDEX IF NOT EXISTS "IDX_102A50584376DE25B6BBD7157594C607A5C957F2" ON teiv_data."o-ran-smo-teiv-equipment_Site" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_EEBF1BC3344E97988232825777AB13FAB6C4F3F0" ON teiv_data."o-ran-smo-teiv-equipment_Site" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-equipment_Site_CD_decorators" ON teiv_data."o-ran-smo-teiv-equipment_Site" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_DDD73D6F4004BF3A96AA118281EE3E565A922B47" ON teiv_data."o-ran-smo-teiv-oam_ManagedElement" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_98AC4232BC02323E03416954215889CEE874A1E9" ON teiv_data."o-ran-smo-teiv-oam_ManagedElement" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-oam_ManagedElement_CD_decorators" ON teiv_data."o-ran-smo-teiv-oam_ManagedElement" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_5FB80647AE3E5C0443A792618D65B9090EE2A3FC" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN (("eUtranFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_A94722FF7B95D8974B494793908B57B4E1A9743B" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN (("geranFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_441B5C05448D63552C6414BD59C13641D8A4408D" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN (("nRFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_CC3E208A4EE51D3B505416A599F36F3C99F466C8" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_E7FFE8F4A166AA9A382A0659762FFEC313A9EB5C" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_AntennaCapability_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ENodeBFunction_eNodeBPlmnId" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN ("eNodeBPlmnId");
+
+CREATE INDEX IF NOT EXISTS "IDX_3F7D14B4CF2CA74F28BA1600606E82C6E8C447C0" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_B598B74193845587BA03553CEDBA058D33956847" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ENodeBFunction_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_252AF4814C67384A7B05EA116316E83AFF9EB6AE" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN (("REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_61CDCD3F69CF67EE740358D2C76FA796CFDA19BF" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN (("REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_35C17C8A9BA3EF3AEADA72C21F8090C38F575BAF" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN ("REL_CD_decorators_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_84E36DC53519D3E334C60B5B02C1AB27130CFA24" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_C9C19F8F83F50C130F2EB6502ABB7B2833F1F783" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_EUtranCell_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_976F6A0F8991F64592B6F9E716EFEECBD5400FDA" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_EUTRANCELL"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4C77E3A51BFAB2FCD30425E4EB21CC7636438299" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_EUTRANCELL"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_FC7D79187227E0BFA69149048CC10E39AE540B8A" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("REL_CD_decorators_ENODEBFUNCTION_PROVIDES_EUTRANCELL");
+
+CREATE INDEX IF NOT EXISTS "IDX_173887418DD4FD6FD592F6404EA784150B1822C0" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("REL_CD_sourceIds_SECTOR_GROUPS_EUTRANCELL"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_8A15E61498725DA9D8C78FC4B99053C06E88DCEC" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN (("REL_CD_classifiers_SECTOR_GROUPS_EUTRANCELL"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_E4EF3C904939ED4C0996EAB7CDFE1895CDF34BFB" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("REL_CD_decorators_SECTOR_GROUPS_EUTRANCELL");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_pLMNId" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN ("pLMNId");
+
+CREATE INDEX IF NOT EXISTS "IDX_BE4B476041D559760931630000D3F4A6DFF42707" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_588840BAE32C7FF8CF0553F631DAAF8BB6E8E7C1" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_E01081465B87F46E1CC7A22FE406C7B41C817E8C" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN (("REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_1324070754C1EBF8EA78EF40743AFC1713733BA8" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN (("REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_13E734DE57346378DA4F21FC4EA030290A7E532F" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN ("REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_C6D2419F8DC299FBC98342AA00BE92308C7566A7" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4C2B68358221A7FF0E68012DEDD3CBA2C4ED669F" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_OCUUPFunction_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_883506CAA3E742D82EEFCEE8C8F29927983B73B1" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN (("REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_EB07ADD66F6CF51B9330403DE4500D05CA067647" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN (("REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_C3141DD7D2695EF74B13981AB378A58390D203D6" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN ("REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_dUpLMNId" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN ("dUpLMNId");
+
+CREATE INDEX IF NOT EXISTS "IDX_2BEF269CED354C2454AC2B2EABB134AC267A0C62" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_601A4514FFACA8985471531013AFC8F760361F09" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_3065F7FB78C5AA9FF17972F825F89AED127A6324" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN (("REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_04C614FDE6A4AE2AA106A1233D1DF95803FC122D" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN (("REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_298FCD184347DEC995B06FED2B1AE61F12BF766A" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN ("REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_6EC539C61EA7078DBA264C9877B87FC263605D42" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_E754EB8AD825DB3111B07B9E5DA3B30C38DB406B" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_LTESectorCarrier_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_1EBC7271CEA658156DE25286404CBC4593340F8E" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_sourceIds_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_846B7740E8AA756B8C1409CD909D2DF73A47ED4C" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_classifiers_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_44075E1D464599B61924196C20F2B88332520CD8" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_CD_decorators_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_F2D46817C2D618D8C33945F282299BF9EB49465E" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_sourceIds_EUTRANCELL_USES_LTESECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_B291D7EFCAD3BF06A2C11F8C0429ABABEEF8308B" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_classifiers_EUTRANCELL_USES_LTESECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_EAE482189F45D63CD1A88B0DD5F76EEE163D9E53" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_CD_decorators_EUTRANCELL_USES_LTESECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_7D01A5D21C990ACCBE65035C062C7D881A05F1EE" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_sourceIds_LTESECTORCARRIER_USES_ANTENNACAPABILITY"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_3D3EFECFB917DAC074F56334224B19F8FD6BF8A5" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN (("REL_CD_classifiers_LTESECTORCARRIER_USES_ANTENNACAPABILITY"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4EE2AA643311DFCC13B6ED832EBE2FAB4CFDF494" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_CD_decorators_LTESECTORCARRIER_USES_ANTENNACAPABILITY");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_plmnId" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN ("plmnId");
+
+CREATE INDEX IF NOT EXISTS "IDX_0C443A16285D233F16966C2F0314CDC9D0F6D0B8" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_E5930226819982DC0CFC1FA64FB3600647222435" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_36A671754CD510FFBDC2713FD142303DCA75DD65" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN (("REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_04BE1EB39848069422B97C28EE3C8ED18BCC6D33" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN (("REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_229957181BBC9D7B4535807BB397E8AA1378ED85" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN ("REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU");
+
+CREATE INDEX IF NOT EXISTS "IDX_FFD60DD99D80C276F402E66546F5DACB2D81EE26" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_C437D39632DC79BAB6AC4F0880826A05425F9C32" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_1F6708B1E34FC908473DD7A7E5641E650B359BEF" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_2F4C43ED084968FDAF9943DB96741885C145FE1D" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_0E63D6B76B229961CD45D998C63175B569DDECD1" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU");
+
+CREATE INDEX IF NOT EXISTS "IDX_6325926B4D2FDD1FBBB34250DABEA5E7229FF9F5" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_7CB4A7724F68D1CB2D12E8DE779BA9103F7DBE0A" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN (("REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_0A03C47C13AD3B5C84D3D8081493D670E9CBDCD1" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("REL_CD_decorators_SECTOR_GROUPS_NRCELLDU");
+
+CREATE INDEX IF NOT EXISTS "IDX_8E34EC0B1DE7DDCE3B32ADD85B11E15F95C5644E" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_050A80BEEF775E4D3CE216F282F23DB99DA2D798" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_CD293AD1111E344D150340A13BD299924D29A9DA" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_273D43FDDD1C4643ECF8BBE51B6B369C657F0861" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_EDE8B88F488F9380DB49CB2C141318FB33C2CCEC" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_7BFD17A71AB1B7765FE6431DA4E66C2EDE88AC3B" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_ED50A5139F1449DBAD8DA10D45F5A5BF819EACBA" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_2ADB5C6DCAEE8811FB1CA8FD9EB53381F35FCB70" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_1F27C515A028616FAC422A02ABBEC402D5DBB2E5" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_B975D24291849007D4AA6686C5D3983885D5C884" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN (("REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_902B73F741160B9D4FBF62406D3D9ABBECAD8BE7" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY");
+
+CREATE INDEX IF NOT EXISTS "IDX_E234B43A7CD7843672F08F2197AB46A2A50BECB0" ON teiv_data."o-ran-smo-teiv-ran_Sector" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_19C19556F9714850389595E0A16218FA229205FE" ON teiv_data."o-ran-smo-teiv-ran_Sector" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_Sector_CD_decorators" ON teiv_data."o-ran-smo-teiv-ran_Sector" USING GIN ("CD_decorators");
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "azimuth" DECIMAL;
+
+CREATE TABLE IF NOT EXISTS teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" (
+       "id"                    TEXT,
+       "aSide_AntennaModule"                   TEXT,
+       "bSide_EUtranCell"                      TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" (
+       "id"                    TEXT,
+       "aSide_AntennaModule"                   TEXT,
+       "bSide_NRCellDU"                        TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb
+);
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '1D71FC3BAE50E72552EAAC17B3B0C959B403E822',
+ 'PK_F3CAF5F2DDEBEEBA48316C708AD6E37BA12A6632',
+ 'ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD CONSTRAINT "PK_F3CAF5F2DDEBEEBA48316C708AD6E37BA12A6632" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU',
+ 'PK_F41873285F3BD831F63C6041B4356A063403406D',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD CONSTRAINT "PK_F41873285F3BD831F63C6041B4356A063403406D" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '1D71FC3BAE50E72552EAAC17B3B0C959B403E822',
+ 'FK_6AF9FA81BF3F1D3374C021E5554012492FA32B72',
+ 'ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD CONSTRAINT "FK_6AF9FA81BF3F1D3374C021E5554012492FA32B72" FOREIGN KEY ("aSide_AntennaModule") REFERENCES teiv_data."o-ran-smo-teiv-equipment_AntennaModule" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '1D71FC3BAE50E72552EAAC17B3B0C959B403E822',
+ 'FK_D71E365C050B4B749155D43A16DCC01C12BFA055',
+ 'ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD CONSTRAINT "FK_D71E365C050B4B749155D43A16DCC01C12BFA055" FOREIGN KEY ("bSide_EUtranCell") REFERENCES teiv_data."o-ran-smo-teiv-ran_EUtranCell" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU',
+ 'FK_1AB1E0CC29DA2E122D43A6616EC60A3F73E68649',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD CONSTRAINT "FK_1AB1E0CC29DA2E122D43A6616EC60A3F73E68649" FOREIGN KEY ("aSide_AntennaModule") REFERENCES teiv_data."o-ran-smo-teiv-equipment_AntennaModule" (id) ON DELETE CASCADE;'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU',
+ 'FK_8605800A4923C52258A8CE3989E18A7C93D22E8C',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD CONSTRAINT "FK_8605800A4923C52258A8CE3989E18A7C93D22E8C" FOREIGN KEY ("bSide_NRCellDU") REFERENCES teiv_data."o-ran-smo-teiv-ran_NRCellDU" (id) ON DELETE CASCADE;'
+);
+
+CREATE INDEX IF NOT EXISTS "IDX_570AAD5BDC2B6A7DCCB840639DE232EE08D72534" ON teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_6657C8783456D4F7FDD411B3B7FD1764E580AB80" ON teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_0B76D3F42FB84D2D1E6B28774B52150174780BE4" ON teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_0E1BE8724BEBB21C5AE3986BE150BEC8F8CD903E" ON teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_F93AD0AE5C6940EE73D0B661A2E2E5BB10B3772C" ON teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_319FDFF6C9E6BC1D922F0A2AFEAAC294E520F753" ON teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" USING GIN ("CD_decorators");
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "horizontalBeamWidth" DECIMAL;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "verticalBeamWidth" DECIMAL;
+
+CREATE OR REPLACE FUNCTION teiv_data.create_enum_type(
+    schema_name TEXT, type_name TEXT, enum_values TEXT[]
+) RETURNS VOID AS $$
+BEGIN
+    IF NOT EXISTS (SELECT 1 FROM pg_type t JOIN pg_namespace n ON n.oid = t.typnamespace WHERE t.typname = type_name AND n.nspname = schema_name) THEN
+        EXECUTE format('CREATE TYPE %I.%I AS ENUM (%s)',schema_name, type_name, array_to_string(ARRAY(SELECT quote_literal(value) FROM unnest(enum_values) AS value), ', '));
+    END IF;
+END;
+$$ language 'plpgsql';
+
+SELECT teiv_data.create_enum_type('teiv_data', 'Reliability', ARRAY['OK', 'RESTORED', 'ADVISED']);
+
+CREATE TABLE IF NOT EXISTS teiv_data."responsible_adapter" (
+       "id"                    TEXT,
+       "hashed_id"                     BYTEA
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'responsible_adapter',
+ 'PK_responsible_adapter_id',
+ 'ALTER TABLE teiv_data."responsible_adapter" ADD CONSTRAINT "PK_responsible_adapter_id" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'responsible_adapter',
+ 'UNIQUE_responsible_adapter_hashed_id',
+ 'ALTER TABLE teiv_data."responsible_adapter" ADD CONSTRAINT "UNIQUE_responsible_adapter_hashed_id" UNIQUE ("hashed_id");'
+);
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "REL_metadata_MANAGEDELEMENT_MANAGES_ODUFUNCTION" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "REL_metadata_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "REL_metadata_ANTENNAMODULE_INSTALLED_AT_SITE" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "REL_metadata_SECTOR_GROUPS_ANTENNAMODULE" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "REL_metadata_ENODEBFUNCTION_PROVIDES_EUTRANCELL" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "REL_metadata_SECTOR_GROUPS_EUTRANCELL" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_EUTRANCELL_USES_LTESECTORCARRIER" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_LTESECTORCARRIER_USES_ANTENNACAPABILITY" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "REL_metadata_OCUCPFUNCTION_PROVIDES_NRCELLCU" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-oam_ManagedElement" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "REL_metadata_ODUFUNCTION_PROVIDES_NRCELLDU" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "REL_metadata_SECTOR_GROUPS_NRCELLDU" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "REL_metadata_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_ODUFUNCTION_PROVIDES_NRSECTORCARRIER" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_NRCELLDU_USES_NRSECTORCARRIER" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_metadata_NRSECTORCARRIER_USES_ANTENNACAPABILITY" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "REL_metadata_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD COLUMN IF NOT EXISTS "metadata" jsonb;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "REL_RESP_id_MANAGEDELEMENT_MANAGES_ODUFUNCTION" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "REL_RESP_id_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "REL_RESP_id_ANTENNAMODULE_INSTALLED_AT_SITE" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "REL_RESP_id_SECTOR_GROUPS_ANTENNAMODULE" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "REL_RESP_id_ENODEBFUNCTION_PROVIDES_EUTRANCELL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "REL_RESP_id_SECTOR_GROUPS_EUTRANCELL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_EUTRANCELL_USES_LTESECTORCARRIER" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_LTESECTORCARRIER_USES_ANTENNACAPABILITY" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "REL_RESP_id_OCUCPFUNCTION_PROVIDES_NRCELLCU" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-oam_ManagedElement" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "REL_RESP_id_ODUFUNCTION_PROVIDES_NRCELLDU" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "REL_RESP_id_SECTOR_GROUPS_NRCELLDU" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "REL_RESP_id_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_ODUFUNCTION_PROVIDES_NRSECTORCARRIER" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_NRCELLDU_USES_NRSECTORCARRIER" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "REL_RESP_id_NRSECTORCARRIER_USES_ANTENNACAPABILITY" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "REL_RESP_id_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD COLUMN IF NOT EXISTS "RESP_id" BYTEA;
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_7B930D529570AED19AABDFA950EED794D4EB53CE',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_7B930D529570AED19AABDFA950EED794D4EB53CE" FOREIGN KEY ("REL_RESP_id_MANAGEDELEMENT_MANAGES_ODUFUNCTION") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_o-ran-smo-teiv-ran_ODUFunction_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ODUFunction_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_2A809BABCCE0A947D420653EF4EBD4707DA73B9F',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_2A809BABCCE0A947D420653EF4EBD4707DA73B9F" FOREIGN KEY ("REL_RESP_id_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_Site',
+ 'FK_o-ran-smo-teiv-equipment_Site_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_Site_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_AntennaCapability',
+ 'FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_F4EE618C98A1EB18212D9607E870E87B59690448',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_F4EE618C98A1EB18212D9607E870E87B59690448" FOREIGN KEY ("REL_RESP_id_ANTENNAMODULE_INSTALLED_AT_SITE") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_E2C830AB84CE31F71BBD0F91BBEFF66069A7E6B8',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_E2C830AB84CE31F71BBD0F91BBEFF66069A7E6B8" FOREIGN KEY ("REL_RESP_id_SECTOR_GROUPS_ANTENNAMODULE") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_A7A12166DB3EC34E10F93FDD942A5DA916CBCFA0',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_A7A12166DB3EC34E10F93FDD942A5DA916CBCFA0" FOREIGN KEY ("REL_RESP_id_ENODEBFUNCTION_PROVIDES_EUTRANCELL") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_6F467D3CDA985248AEB010A0EDB1343A9173593E',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_6F467D3CDA985248AEB010A0EDB1343A9173593E" FOREIGN KEY ("REL_RESP_id_SECTOR_GROUPS_EUTRANCELL") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_2C1B8D1ECA6B4E645EF162522E6A5169CE7D7E9C',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_2C1B8D1ECA6B4E645EF162522E6A5169CE7D7E9C" FOREIGN KEY ("REL_RESP_id_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_B1CBA7F54C85E77DC96CD6531DB073B0EDCFF6BC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_B1CBA7F54C85E77DC96CD6531DB073B0EDCFF6BC" FOREIGN KEY ("REL_RESP_id_EUTRANCELL_USES_LTESECTORCARRIER") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_B8F9FB1ADEBB9B35B6245684DE64775DE98442B4',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_B8F9FB1ADEBB9B35B6245684DE64775DE98442B4" FOREIGN KEY ("REL_RESP_id_LTESECTORCARRIER_USES_ANTENNACAPABILITY") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_LTESectorCarrier_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_LTESectorCarrier_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_323384A3617DC94F73FB225A3562EB93A05E976D',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_323384A3617DC94F73FB225A3562EB93A05E976D" FOREIGN KEY ("REL_RESP_id_OCUCPFUNCTION_PROVIDES_NRCELLCU") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_o-ran-smo-teiv-ran_NRCellCU_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellCU_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-oam_ManagedElement',
+ 'FK_o-ran-smo-teiv-oam_ManagedElement_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-oam_ManagedElement" ADD CONSTRAINT "FK_o-ran-smo-teiv-oam_ManagedElement_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_3F79604542DA97B9338CF6A5610ABC05E17153B4',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_3F79604542DA97B9338CF6A5610ABC05E17153B4" FOREIGN KEY ("REL_RESP_id_ODUFUNCTION_PROVIDES_NRCELLDU") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_01FDDC88AFC28623B49266BFA3FE0D2078988E88',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_01FDDC88AFC28623B49266BFA3FE0D2078988E88" FOREIGN KEY ("REL_RESP_id_SECTOR_GROUPS_NRCELLDU") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'CFC235E0404703D1E4454647DF8AAE2C193DB402',
+ 'FK_1D23F428960B9279D29AC35A946D0C60CAFE638E',
+ 'ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" ADD CONSTRAINT "FK_1D23F428960B9279D29AC35A946D0C60CAFE638E" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'FK_2356BAEED80FD88699DCCD85993162818C9BD0A1',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "FK_2356BAEED80FD88699DCCD85993162818C9BD0A1" FOREIGN KEY ("REL_RESP_id_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU',
+ 'FK_09C96C0397884B6E28EEBE17565CE2DF7535E380',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" ADD CONSTRAINT "FK_09C96C0397884B6E28EEBE17565CE2DF7535E380" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_229725A1E5A342C3E7579273F54AD9B209CE0770',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_229725A1E5A342C3E7579273F54AD9B209CE0770" FOREIGN KEY ("REL_RESP_id_ODUFUNCTION_PROVIDES_NRSECTORCARRIER") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_CD383C61EDAA5A8E84DCB423E1378E3173D585E7',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_CD383C61EDAA5A8E84DCB423E1378E3173D585E7" FOREIGN KEY ("REL_RESP_id_NRCELLDU_USES_NRSECTORCARRIER") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_EEF72E2F5B0421B04A5129F44B6740CE35EB7D7B',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_EEF72E2F5B0421B04A5129F44B6740CE35EB7D7B" FOREIGN KEY ("REL_RESP_id_NRSECTORCARRIER_USES_ANTENNACAPABILITY") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'FK_8B083C6C2AF2BA35E20AE16A4D0702373C5B5D4D',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "FK_8B083C6C2AF2BA35E20AE16A4D0702373C5B5D4D" FOREIGN KEY ("REL_RESP_id_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_Sector',
+ 'FK_o-ran-smo-teiv-ran_Sector_RESP_id',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_Sector_RESP_id" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '1D71FC3BAE50E72552EAAC17B3B0C959B403E822',
+ 'FK_3EB2B0A0A4405454550AED663948D4DD77AD3B77',
+ 'ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" ADD CONSTRAINT "FK_3EB2B0A0A4405454550AED663948D4DD77AD3B77" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" (hashed_id);'
+);
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RESP_dUpLMNId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBDUId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBIdLength" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RI_dUpLMNId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RI_gNBDUId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RI_gNBId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD COLUMN IF NOT EXISTS "RI_gNBIdLength" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBCUName" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBIdLength" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RESP_pLMNId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RI_gNBCUName" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RI_gNBId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RI_gNBIdLength" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD COLUMN IF NOT EXISTS "RI_pLMNId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "RESP_geo-location" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "RESP_name" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "RI_geo-location" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD COLUMN IF NOT EXISTS "RI_name" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RESP_eUtranFqBands" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RESP_geranFqBands" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RESP_nRFqBands" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RI_eUtranFqBands" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RI_geranFqBands" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD COLUMN IF NOT EXISTS "RI_nRFqBands" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_antennaBeamWidth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_antennaModelNumber" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_azimuth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_electricalAntennaTilt" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_geo-location" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_horizontalBeamWidth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_mechanicalAntennaBearing" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_mechanicalAntennaTilt" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_positionWithinSector" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_totalTilt" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RESP_verticalBeamWidth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_antennaBeamWidth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_antennaModelNumber" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_azimuth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_electricalAntennaTilt" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_geo-location" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_horizontalBeamWidth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_mechanicalAntennaBearing" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_mechanicalAntennaTilt" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_positionWithinSector" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_totalTilt" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD COLUMN IF NOT EXISTS "RI_verticalBeamWidth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_cellId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_channelBandwidth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_dlChannelBandwidth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_duplexType" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_earfcn" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_earfcndl" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_earfcnul" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RESP_tac" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_cellId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_channelBandwidth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_dlChannelBandwidth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_duplexType" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_earfcn" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_earfcndl" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_earfcnul" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD COLUMN IF NOT EXISTS "RI_tac" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_sectorCarrierType" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD COLUMN IF NOT EXISTS "RI_sectorCarrierType" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RESP_cellLocalId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RESP_nCI" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RESP_nRTAC" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RESP_plmnId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RI_cellLocalId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RI_nCI" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RI_nRTAC" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD COLUMN IF NOT EXISTS "RI_plmnId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RESP_cellLocalId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RESP_nCI" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RESP_nRPCI" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RESP_nRTAC" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RI_cellLocalId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RI_nCI" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RI_nRPCI" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD COLUMN IF NOT EXISTS "RI_nRTAC" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "RESP_gNBIdLength" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "RI_gNBId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD COLUMN IF NOT EXISTS "RI_gNBIdLength" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_arfcnDL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_arfcnUL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_bSChannelBwDL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_frequencyDL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RESP_frequencyUL" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RI_arfcnDL" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RI_arfcnUL" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RI_bSChannelBwDL" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RI_frequencyDL" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD COLUMN IF NOT EXISTS "RI_frequencyUL" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "RESP_eNBId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "RESP_eNodeBPlmnId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "RI_eNBId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD COLUMN IF NOT EXISTS "RI_eNodeBPlmnId" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RESP_azimuth" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RESP_geo-location" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RESP_sectorId" BYTEA;
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RI_azimuth" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RI_geo-location" teiv_data."Reliability";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD COLUMN IF NOT EXISTS "RI_sectorId" teiv_data."Reliability";
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_o-ran-smo-teiv-ran_ODUFunction_RESP_dUpLMNId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ODUFunction_RESP_dUpLMNId" FOREIGN KEY ("RESP_dUpLMNId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBDUId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBDUId" FOREIGN KEY ("RESP_gNBDUId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBId" FOREIGN KEY ("RESP_gNBId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ODUFunction',
+ 'FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBIdLength',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ODUFunction_RESP_gNBIdLength" FOREIGN KEY ("RESP_gNBIdLength") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBCUName',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBCUName" FOREIGN KEY ("RESP_gNBCUName") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBId" FOREIGN KEY ("RESP_gNBId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBIdLength',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_gNBIdLength" FOREIGN KEY ("RESP_gNBIdLength") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUCPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_pLMNId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUCPFunction_RESP_pLMNId" FOREIGN KEY ("RESP_pLMNId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_Site',
+ 'FK_o-ran-smo-teiv-equipment_Site_RESP_geo-location',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_Site_RESP_geo-location" FOREIGN KEY ("RESP_geo-location") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_Site',
+ 'FK_o-ran-smo-teiv-equipment_Site_RESP_name',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_Site_RESP_name" FOREIGN KEY ("RESP_name") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_AntennaCapability',
+ 'FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_eUtranFqBands',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_eUtranFqBands" FOREIGN KEY ("RESP_eUtranFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_AntennaCapability',
+ 'FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_geranFqBands',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_geranFqBands" FOREIGN KEY ("RESP_geranFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_AntennaCapability',
+ 'FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_nRFqBands',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_AntennaCapability_RESP_nRFqBands" FOREIGN KEY ("RESP_nRFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_antennaBeamWidth',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_antennaBeamWidth" FOREIGN KEY ("RESP_antennaBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_9F8C83A98E46570C846E83D0F220A05357E2007B',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_9F8C83A98E46570C846E83D0F220A05357E2007B" FOREIGN KEY ("RESP_antennaModelNumber") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_azimuth',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_azimuth" FOREIGN KEY ("RESP_azimuth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_4A737D290E8E8B656C1794065E9B16D0E536E1C8',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_4A737D290E8E8B656C1794065E9B16D0E536E1C8" FOREIGN KEY ("RESP_electricalAntennaTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_geo-location',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_geo-location" FOREIGN KEY ("RESP_geo-location") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_C4A0358503DD39D9CB99E3632B2E1E1C337A37CB',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_C4A0358503DD39D9CB99E3632B2E1E1C337A37CB" FOREIGN KEY ("RESP_horizontalBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_1DC2D3CF0DE253BABBF39A6E95711C96AA6EF1DC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_1DC2D3CF0DE253BABBF39A6E95711C96AA6EF1DC" FOREIGN KEY ("RESP_mechanicalAntennaBearing") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_2B6558634445CBA8724FFE8D3E651761E260C91A',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_2B6558634445CBA8724FFE8D3E651761E260C91A" FOREIGN KEY ("RESP_mechanicalAntennaTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_9E7F6B8B5829210351BD81048A305F97BF3E71E6',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_9E7F6B8B5829210351BD81048A305F97BF3E71E6" FOREIGN KEY ("RESP_positionWithinSector") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_totalTilt',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_o-ran-smo-teiv-equipment_AntennaModule_RESP_totalTilt" FOREIGN KEY ("RESP_totalTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-equipment_AntennaModule',
+ 'FK_DF761BBEA829AC0658C2D49D290E500CB71546B7',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" ADD CONSTRAINT "FK_DF761BBEA829AC0658C2D49D290E500CB71546B7" FOREIGN KEY ("RESP_verticalBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_cellId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_cellId" FOREIGN KEY ("RESP_cellId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_channelBandwidth',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_channelBandwidth" FOREIGN KEY ("RESP_channelBandwidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_dlChannelBandwidth',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_dlChannelBandwidth" FOREIGN KEY ("RESP_dlChannelBandwidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_duplexType',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_duplexType" FOREIGN KEY ("RESP_duplexType") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcn',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcn" FOREIGN KEY ("RESP_earfcn") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcndl',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcndl" FOREIGN KEY ("RESP_earfcndl") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcnul',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_earfcnul" FOREIGN KEY ("RESP_earfcnul") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_EUtranCell',
+ 'FK_o-ran-smo-teiv-ran_EUtranCell_RESP_tac',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_EUtranCell_RESP_tac" FOREIGN KEY ("RESP_tac") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_LTESectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_LTESectorCarrier_RESP_sectorCarrierType',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_LTESectorCarrier_RESP_sectorCarrierType" FOREIGN KEY ("RESP_sectorCarrierType") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_o-ran-smo-teiv-ran_NRCellCU_RESP_cellLocalId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellCU_RESP_cellLocalId" FOREIGN KEY ("RESP_cellLocalId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_o-ran-smo-teiv-ran_NRCellCU_RESP_nCI',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellCU_RESP_nCI" FOREIGN KEY ("RESP_nCI") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_o-ran-smo-teiv-ran_NRCellCU_RESP_nRTAC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellCU_RESP_nRTAC" FOREIGN KEY ("RESP_nRTAC") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellCU',
+ 'FK_o-ran-smo-teiv-ran_NRCellCU_RESP_plmnId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellCU_RESP_plmnId" FOREIGN KEY ("RESP_plmnId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_RESP_cellLocalId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_RESP_cellLocalId" FOREIGN KEY ("RESP_cellLocalId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nCI',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nCI" FOREIGN KEY ("RESP_nCI") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nRPCI',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nRPCI" FOREIGN KEY ("RESP_nRPCI") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRCellDU',
+ 'FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nRTAC',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRCellDU_RESP_nRTAC" FOREIGN KEY ("RESP_nRTAC") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_gNBId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_gNBId" FOREIGN KEY ("RESP_gNBId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_OCUUPFunction',
+ 'FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_gNBIdLength',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_OCUUPFunction_RESP_gNBIdLength" FOREIGN KEY ("RESP_gNBIdLength") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_arfcnDL',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_arfcnDL" FOREIGN KEY ("RESP_arfcnDL") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_arfcnUL',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_arfcnUL" FOREIGN KEY ("RESP_arfcnUL") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_bSChannelBwDL',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_bSChannelBwDL" FOREIGN KEY ("RESP_bSChannelBwDL") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_frequencyDL',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_frequencyDL" FOREIGN KEY ("RESP_frequencyDL") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_NRSectorCarrier',
+ 'FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_frequencyUL',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_NRSectorCarrier_RESP_frequencyUL" FOREIGN KEY ("RESP_frequencyUL") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_eNBId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_eNBId" FOREIGN KEY ("RESP_eNBId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_ENodeBFunction',
+ 'FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_eNodeBPlmnId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_ENodeBFunction_RESP_eNodeBPlmnId" FOREIGN KEY ("RESP_eNodeBPlmnId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_Sector',
+ 'FK_o-ran-smo-teiv-ran_Sector_RESP_azimuth',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_Sector_RESP_azimuth" FOREIGN KEY ("RESP_azimuth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_Sector',
+ 'FK_o-ran-smo-teiv-ran_Sector_RESP_geo-location',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_Sector_RESP_geo-location" FOREIGN KEY ("RESP_geo-location") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'o-ran-smo-teiv-ran_Sector',
+ 'FK_o-ran-smo-teiv-ran_Sector_RESP_sectorId',
+ 'ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" ADD CONSTRAINT "FK_o-ran-smo-teiv-ran_Sector_RESP_sectorId" FOREIGN KEY ("RESP_sectorId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+CREATE INDEX IF NOT EXISTS "IDX_A5A6D0F976F10334CBD2DEDBDB6894BF8720157B" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN ("REL_metadata_MANAGEDELEMENT_MANAGES_ODUFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_metadata" ON teiv_data."o-ran-smo-teiv-ran_ODUFunction" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_E4D4598CF15FD8AF9AE91F3647A8D943E1A51E8C" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN ("REL_metadata_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_metadata" ON teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-equipment_Site_metadata" ON teiv_data."o-ran-smo-teiv-equipment_Site" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_AntennaCapability_metadata" ON teiv_data."o-ran-smo-teiv-ran_AntennaCapability" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_B309F56A2389CE1A1CD82B4982F98F7F3B50570E" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("REL_metadata_ANTENNAMODULE_INSTALLED_AT_SITE");
+
+CREATE INDEX IF NOT EXISTS "IDX_0B4648D289B22EAA16B21BE4505F49850AC018C9" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("REL_metadata_SECTOR_GROUPS_ANTENNAMODULE");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_metadata" ON teiv_data."o-ran-smo-teiv-equipment_AntennaModule" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_82B09F9D6370B2F07855F70042BA1B0ED782167D" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("REL_metadata_ENODEBFUNCTION_PROVIDES_EUTRANCELL");
+
+CREATE INDEX IF NOT EXISTS "IDX_C4728AE1A440E5C3670B4B691213C163D805CD84" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("REL_metadata_SECTOR_GROUPS_EUTRANCELL");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_EUtranCell_metadata" ON teiv_data."o-ran-smo-teiv-ran_EUtranCell" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_9966F4C45B258EBA701CE9C1564152885FE3251A" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_metadata_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_19ABF252C4E09016A6FA24AA27724311226C554D" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_metadata_EUTRANCELL_USES_LTESECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_5D51C73E247073756AE9185C219303E004250431" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("REL_metadata_LTESECTORCARRIER_USES_ANTENNACAPABILITY");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_LTESectorCarrier_metadata" ON teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_9F6548916831A3F9771008367D58936D21C30423" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN ("REL_metadata_OCUCPFUNCTION_PROVIDES_NRCELLCU");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_metadata" ON teiv_data."o-ran-smo-teiv-ran_NRCellCU" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-oam_ManagedElement_metadata" ON teiv_data."o-ran-smo-teiv-oam_ManagedElement" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_C731749DB013DA392D5010E566ACA0961D9A6535" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("REL_metadata_ODUFUNCTION_PROVIDES_NRCELLDU");
+
+CREATE INDEX IF NOT EXISTS "IDX_BE5B953B9861DD77A9096198E375074251030653" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("REL_metadata_SECTOR_GROUPS_NRCELLDU");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_metadata" ON teiv_data."o-ran-smo-teiv-ran_NRCellDU" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_FE8D81BC4BD1C54D860A934A4484326AAFF02726" ON teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_4E84A0C18434550C0096F1EE2695DF5952826EA4" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN ("REL_metadata_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_OCUUPFunction_metadata" ON teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_E1F96D2B0519812654B5A3D95B8F0E90C0FBDA55" ON teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_5B3F8D2AA421A4F7084B428387F4BFABE236A936" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_metadata_ODUFUNCTION_PROVIDES_NRSECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_21B2E5B5220DC3FDF12D6E481F0E672B5B034BCA" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_metadata_NRCELLDU_USES_NRSECTORCARRIER");
+
+CREATE INDEX IF NOT EXISTS "IDX_20C83B7E7A4AFBA974AFBF99A0ED1A398F5C11D3" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("REL_metadata_NRSECTORCARRIER_USES_ANTENNACAPABILITY");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_metadata" ON teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_943E4F35504A6F925ADA7C609CE639875C09C949" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN ("REL_metadata_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_ENodeBFunction_metadata" ON teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_GIN_o-ran-smo-teiv-ran_Sector_metadata" ON teiv_data."o-ran-smo-teiv-ran_Sector" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_24F125BEB2D7C718FA6F2634178AA92F7F71D95A" ON teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" USING GIN ("metadata");
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ODUFunction" DROP COLUMN IF EXISTS "REL_updated_time_MANAGEDELEMENT_MANAGES_ODUFUNCTION";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction" DROP COLUMN IF EXISTS "REL_updated_time_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_Site" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_AntennaCapability" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" DROP COLUMN IF EXISTS "REL_updated_time_ANTENNAMODULE_INSTALLED_AT_SITE";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-equipment_AntennaModule" DROP COLUMN IF EXISTS "REL_updated_time_SECTOR_GROUPS_ANTENNAMODULE";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" DROP COLUMN IF EXISTS "REL_updated_time_ENODEBFUNCTION_PROVIDES_EUTRANCELL";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_EUtranCell" DROP COLUMN IF EXISTS "REL_updated_time_SECTOR_GROUPS_EUTRANCELL";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_ENODEBFUNCTION_PROVIDES_LTESECTORCARRIER";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_EUTRANCELL_USES_LTESECTORCARRIER";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_LTESECTORCARRIER_USES_ANTENNACAPABILITY";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellCU" DROP COLUMN IF EXISTS "REL_updated_time_OCUCPFUNCTION_PROVIDES_NRCELLCU";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-oam_ManagedElement" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" DROP COLUMN IF EXISTS "REL_updated_time_ODUFUNCTION_PROVIDES_NRCELLDU";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRCellDU" DROP COLUMN IF EXISTS "REL_updated_time_SECTOR_GROUPS_NRCELLDU";
+
+ALTER TABLE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction" DROP COLUMN IF EXISTS "REL_updated_time_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_ODUFUNCTION_PROVIDES_NRSECTORCARRIER";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_NRCELLDU_USES_NRSECTORCARRIER";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier" DROP COLUMN IF EXISTS "REL_updated_time_NRSECTORCARRIER_USES_ANTENNACAPABILITY";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction" DROP COLUMN IF EXISTS "REL_updated_time_MANAGEDELEMENT_MANAGES_ENODEBFUNCTION";
+
+ALTER TABLE teiv_data."o-ran-smo-teiv-ran_Sector" DROP COLUMN IF EXISTS "updated_time";
+
+ALTER TABLE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822" DROP COLUMN IF EXISTS "updated_time";
+
+CREATE TABLE IF NOT EXISTS teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" (
+       "id"                    TEXT,
+       "aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C"                        TEXT,
+       "bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E"                        TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" (
+       "id"                    TEXT,
+       "sectorCarrierType"                     TEXT,
+       "RI_sectorCarrierType"                  teiv_data."Reliability",
+       "RESP_sectorCarrierType"                        BYTEA,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA,
+       "REL_FK_used-antennaCapability"                 TEXT,
+       "REL_ID_1C61FC18067350DB393AFDB5270E9DE1F5151C64"                       TEXT,
+       "REL_CD_8D8BBB53FB18E8E9A5D241B66DA18CB5DDE9C1A5"                       jsonb,
+       "REL_CD_68C234330FD6388836D0DAF9DFD0A40DE66DD8C5"                       jsonb,
+       "REL_CD_A14923FFF9D13FEB18087CE2A9C0BD264C572CFC"                       jsonb,
+       "REL_metadata_F723867781098568079DD82E5D5E529374F97E98"                 jsonb,
+       "REL_RESP_id_927D105F3F1EA229D51FB9D2C90C6D5727FB3F7B"                  BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "REL_CD_8D8BBB53FB18E8E9A5D241B66DA18CB5DDE9C1A5" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "REL_CD_68C234330FD6388836D0DAF9DFD0A40DE66DD8C5" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ALTER COLUMN "REL_CD_A14923FFF9D13FEB18087CE2A9C0BD264C572CFC" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" (
+       "id"                    TEXT,
+       "aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C"                        TEXT,
+       "bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E"                        TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" (
+       "id"                    TEXT,
+       "antennaBeamWidth"                      jsonb,
+       "antennaModelNumber"                    TEXT,
+       "azimuth"                       DECIMAL,
+       "electricalAntennaTilt"                 INTEGER,
+       "geo-location"                  geography,
+       "horizontalBeamWidth"                   DECIMAL,
+       "mechanicalAntennaBearing"                      INTEGER,
+       "mechanicalAntennaTilt"                 INTEGER,
+       "positionWithinSector"                  TEXT,
+       "totalTilt"                     INTEGER,
+       "verticalBeamWidth"                     DECIMAL,
+       "RI_antennaBeamWidth"                   teiv_data."Reliability",
+       "RESP_antennaBeamWidth"                 BYTEA,
+       "RI_antennaModelNumber"                 teiv_data."Reliability",
+       "RESP_antennaModelNumber"                       BYTEA,
+       "RI_azimuth"                    teiv_data."Reliability",
+       "RESP_azimuth"                  BYTEA,
+       "RI_electricalAntennaTilt"                      teiv_data."Reliability",
+       "RESP_electricalAntennaTilt"                    BYTEA,
+       "RI_geo-location"                       teiv_data."Reliability",
+       "RESP_geo-location"                     BYTEA,
+       "RI_horizontalBeamWidth"                        teiv_data."Reliability",
+       "RESP_horizontalBeamWidth"                      BYTEA,
+       "RI_mechanicalAntennaBearing"                   teiv_data."Reliability",
+       "RESP_mechanicalAntennaBearing"                 BYTEA,
+       "RI_mechanicalAntennaTilt"                      teiv_data."Reliability",
+       "RESP_mechanicalAntennaTilt"                    BYTEA,
+       "RI_positionWithinSector"                       teiv_data."Reliability",
+       "RESP_positionWithinSector"                     BYTEA,
+       "RI_totalTilt"                  teiv_data."Reliability",
+       "RESP_totalTilt"                        BYTEA,
+       "RI_verticalBeamWidth"                  teiv_data."Reliability",
+       "RESP_verticalBeamWidth"                        BYTEA,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" (
+       "id"                    TEXT,
+       "eUtranFqBands"                 jsonb,
+       "geranFqBands"                  jsonb,
+       "nRFqBands"                     jsonb,
+       "RI_eUtranFqBands"                      teiv_data."Reliability",
+       "RESP_eUtranFqBands"                    BYTEA,
+       "RI_geranFqBands"                       teiv_data."Reliability",
+       "RESP_geranFqBands"                     BYTEA,
+       "RI_nRFqBands"                  teiv_data."Reliability",
+       "RESP_nRFqBands"                        BYTEA,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" (
+       "id"                    TEXT,
+       "dUpLMNId"                      jsonb,
+       "gNBDUId"                       BIGINT,
+       "gNBId"                 BIGINT,
+       "gNBIdLength"                   INTEGER,
+       "RI_dUpLMNId"                   teiv_data."Reliability",
+       "RESP_dUpLMNId"                 BYTEA,
+       "RI_gNBDUId"                    teiv_data."Reliability",
+       "RESP_gNBDUId"                  BYTEA,
+       "RI_gNBId"                      teiv_data."Reliability",
+       "RESP_gNBId"                    BYTEA,
+       "RI_gNBIdLength"                        teiv_data."Reliability",
+       "RESP_gNBIdLength"                      BYTEA,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA,
+       "REL_FK_managed-by-managedElement"                      TEXT,
+       "REL_ID_BDE0B6C74D14AC109D29A08D80E92D4D0DCAEB0B"                       TEXT,
+       "REL_CD_45E8E8693B1B8928376EAA8995D08AA7B1E483BD"                       jsonb,
+       "REL_CD_7E9F11EFBF8974D7C7DAB02E181A0BE4148091C6"                       jsonb,
+       "REL_CD_FFF7E036187A7605BFC714483D2E60FD2FF6560B"                       jsonb,
+       "REL_metadata_72494257260B57223C09828D7C3B31D203B050B4"                 jsonb,
+       "REL_RESP_id_B327AD97E459B9904E24439FF4F9A442165DD1C0"                  BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "REL_CD_45E8E8693B1B8928376EAA8995D08AA7B1E483BD" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "REL_CD_7E9F11EFBF8974D7C7DAB02E181A0BE4148091C6" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ALTER COLUMN "REL_CD_FFF7E036187A7605BFC714483D2E60FD2FF6560B" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" (
+       "id"                    TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA,
+       "REL_FK_used-nrCellDu"                  TEXT,
+       "REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU"                       TEXT,
+       "REL_CD_1F61FA6DDAECE90540F9880F2A98037B1530A5A4"                       jsonb,
+       "REL_CD_E388983F3E6BFAD67CA100F0AFCF8CD3E9B89ADD"                       jsonb,
+       "REL_CD_EF3979E9DAF31B7949C883654633E633B9D35B92"                       jsonb,
+       "REL_metadata_C9E09FBCCBA1F6A3252B71B869B269EF28AACDFB"                 jsonb,
+       "REL_RESP_id_16BDFF7861A21C39988A1CE8BF89B1816C8754FC"                  BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "REL_CD_1F61FA6DDAECE90540F9880F2A98037B1530A5A4" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "REL_CD_E388983F3E6BFAD67CA100F0AFCF8CD3E9B89ADD" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ALTER COLUMN "REL_CD_EF3979E9DAF31B7949C883654633E633B9D35B92" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" (
+       "id"                    TEXT,
+       "aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C"                        TEXT,
+       "bSide_E8A97B8133D74D3BE65119E868FAC0BE63C09FFC"                        TEXT,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+CREATE TABLE IF NOT EXISTS teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" (
+       "id"                    TEXT,
+       "020335B0F627C169E24167748C38FE756FB34AE2"                      INTEGER,
+       "nCI"                   BIGINT,
+       "nRPCI"                 INTEGER,
+       "nRTAC"                 INTEGER,
+       "RI_6022A4C8771F6FCB03972F8966C1AD11DB9AD215"                   teiv_data."Reliability",
+       "RESP_958686CF1CBC168C2ED063F6645F06556C76DC3B"                 BYTEA,
+       "RI_nCI"                        teiv_data."Reliability",
+       "RESP_nCI"                      BYTEA,
+       "RI_nRPCI"                      teiv_data."Reliability",
+       "RESP_nRPCI"                    BYTEA,
+       "RI_nRTAC"                      teiv_data."Reliability",
+       "RESP_nRTAC"                    BYTEA,
+       "CD_sourceIds"                  jsonb,
+       "CD_classifiers"                        jsonb,
+       "CD_decorators"                 jsonb,
+       "metadata"                      jsonb,
+       "RESP_id"                       BYTEA,
+       "REL_FK_provided-by-oduFunction"                        TEXT,
+       "REL_ID_7899092EC8FBC674398C53965ADEFF940D17481F"                       TEXT,
+       "REL_CD_32FFD9EF85AB2342E652FA493C3BF34D9BAAF054"                       jsonb,
+       "REL_CD_B614AAA814176BC7128CE9D72C0950C4D6DE8052"                       jsonb,
+       "REL_CD_0AC0D382E4274681870EC7319460192F4F603001"                       jsonb,
+       "REL_metadata_8B4FA813345B7F25ACF2E9635EAF6E6DE0FBBE8A"                 jsonb,
+       "REL_RESP_id_3E560656C6590F0E2C4BAD9653CE371CF29D2D08"                  BYTEA
+);
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "CD_sourceIds" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "CD_classifiers" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "CD_decorators" SET DEFAULT '{}';
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "REL_CD_32FFD9EF85AB2342E652FA493C3BF34D9BAAF054" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "REL_CD_B614AAA814176BC7128CE9D72C0950C4D6DE8052" SET DEFAULT '[]';
+
+ALTER TABLE ONLY teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ALTER COLUMN "REL_CD_0AC0D382E4274681870EC7319460192F4F603001" SET DEFAULT '{}';
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '09D47DF128202AB535BC2056D7C0952F6EE7AF2D',
+ 'PK_8123C74A8D9A873F330C37E370DB951212243844',
+ 'ALTER TABLE teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ADD CONSTRAINT "PK_8123C74A8D9A873F330C37E370DB951212243844" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'PK_61C7969B1B7C806E01CE3D9471CFF52FA37864C3',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "PK_61C7969B1B7C806E01CE3D9471CFF52FA37864C3" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '98D95275440120DC7A5FEF7E870FB6649F275AEC',
+ 'PK_48BAB21388EA2B1BE83EF5D3FC143807776A882D',
+ 'ALTER TABLE teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ADD CONSTRAINT "PK_48BAB21388EA2B1BE83EF5D3FC143807776A882D" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'PK_8EB1724D91D554E7771C8C5AE5AA752A604E025C',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "PK_8EB1724D91D554E7771C8C5AE5AA752A604E025C" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AA68071F5A253FC68706DC4244B2EEEDCFA4F477',
+ 'PK_AE71D2F6E7DABC3C066CEB9E1F30286DE8AF12D0',
+ 'ALTER TABLE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ADD CONSTRAINT "PK_AE71D2F6E7DABC3C066CEB9E1F30286DE8AF12D0" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'PK_BEBBD904815CB84D3D7D326B13A71BC786E8C2B6',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "PK_BEBBD904815CB84D3D7D326B13A71BC786E8C2B6" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'C9475FE40C02BEB41F720B4284A856F2CF49E1F3',
+ 'PK_AD1799D4203C08DE10524497B4997C2DCB4F6A92',
+ 'ALTER TABLE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ADD CONSTRAINT "PK_AD1799D4203C08DE10524497B4997C2DCB4F6A92" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'E2D2B450D65F1FF241A983CBB43B54C040969908',
+ 'PK_E078962EDFAEDBC93784222B0B7BDFC3929D4D79',
+ 'ALTER TABLE teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ADD CONSTRAINT "PK_E078962EDFAEDBC93784222B0B7BDFC3929D4D79" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'PK_94DB80CFD01964A5D56BC22F433BBAF282F5AB0E',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "PK_94DB80CFD01964A5D56BC22F433BBAF282F5AB0E" PRIMARY KEY ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '09D47DF128202AB535BC2056D7C0952F6EE7AF2D',
+ 'FK_1A5303EF43A4407B0A47C80B9EF3DCA81FEA484A',
+ 'ALTER TABLE teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ADD CONSTRAINT "FK_1A5303EF43A4407B0A47C80B9EF3DCA81FEA484A" FOREIGN KEY ("aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C") REFERENCES teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '09D47DF128202AB535BC2056D7C0952F6EE7AF2D',
+ 'FK_AAB4A7CE5DD41A0CAEFA20B7538F2B851529E327',
+ 'ALTER TABLE teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ADD CONSTRAINT "FK_AAB4A7CE5DD41A0CAEFA20B7538F2B851529E327" FOREIGN KEY ("bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E") REFERENCES teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '09D47DF128202AB535BC2056D7C0952F6EE7AF2D',
+ 'FK_A5E880C59CF224776E30855EBDF62B6E98C5D127',
+ 'ALTER TABLE teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" ADD CONSTRAINT "FK_A5E880C59CF224776E30855EBDF62B6E98C5D127" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'FK_53502FA0D6ADEA6C33D6DB99A53D6F3100E9E288',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "FK_53502FA0D6ADEA6C33D6DB99A53D6F3100E9E288" FOREIGN KEY ("RESP_sectorCarrierType") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'FK_100298449AA5ACC1F08DB20BC65868C337E9C333',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "FK_100298449AA5ACC1F08DB20BC65868C337E9C333" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'FK_778741F2AA29B57611EB06A903D58099245BB537',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "FK_778741F2AA29B57611EB06A903D58099245BB537" FOREIGN KEY ("REL_FK_used-antennaCapability") REFERENCES teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'UNIQUE_523F8C2098EA2DE66650F9CCA7713124C14D63DF',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "UNIQUE_523F8C2098EA2DE66650F9CCA7713124C14D63DF" UNIQUE ("REL_ID_1C61FC18067350DB393AFDB5270E9DE1F5151C64");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '8F1E5B0125750A5230DB73DB7816ECCFFC2D918B',
+ 'FK_CD80909E7C7B2A0958E7D96DD4AE1EEA9B85205C',
+ 'ALTER TABLE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" ADD CONSTRAINT "FK_CD80909E7C7B2A0958E7D96DD4AE1EEA9B85205C" FOREIGN KEY ("REL_RESP_id_927D105F3F1EA229D51FB9D2C90C6D5727FB3F7B") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '98D95275440120DC7A5FEF7E870FB6649F275AEC',
+ 'FK_CF5ED6B6F3D98A44BCF9209A20D9C901F5C3C23E',
+ 'ALTER TABLE teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ADD CONSTRAINT "FK_CF5ED6B6F3D98A44BCF9209A20D9C901F5C3C23E" FOREIGN KEY ("aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C") REFERENCES teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '98D95275440120DC7A5FEF7E870FB6649F275AEC',
+ 'FK_FA290CAE2E1C24893F90877F0EDF7304CD6D4563',
+ 'ALTER TABLE teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ADD CONSTRAINT "FK_FA290CAE2E1C24893F90877F0EDF7304CD6D4563" FOREIGN KEY ("bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E") REFERENCES teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '98D95275440120DC7A5FEF7E870FB6649F275AEC',
+ 'FK_58D8B5F4AF4FC229F23B545470E43B8E7C69B75F',
+ 'ALTER TABLE teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" ADD CONSTRAINT "FK_58D8B5F4AF4FC229F23B545470E43B8E7C69B75F" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_01962D77F25A6FD76223BE654784268BF60CD712',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_01962D77F25A6FD76223BE654784268BF60CD712" FOREIGN KEY ("RESP_antennaBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_F7844BAF6629C2103757E04A38C12A2F20500A15',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_F7844BAF6629C2103757E04A38C12A2F20500A15" FOREIGN KEY ("RESP_antennaModelNumber") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_5EB4306AB1BB07F1902717B5C845B689F479B0C8',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_5EB4306AB1BB07F1902717B5C845B689F479B0C8" FOREIGN KEY ("RESP_azimuth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_7D30EF0E91E5821108E28C244D8F200A9F6EF171',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_7D30EF0E91E5821108E28C244D8F200A9F6EF171" FOREIGN KEY ("RESP_electricalAntennaTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_7BB08E9AF9BC6AA4AA3709504D5D9D859446E7EC',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_7BB08E9AF9BC6AA4AA3709504D5D9D859446E7EC" FOREIGN KEY ("RESP_geo-location") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_AA75893038D9D2DFC5276DD64C5B89545B59A85D',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_AA75893038D9D2DFC5276DD64C5B89545B59A85D" FOREIGN KEY ("RESP_horizontalBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_F4A7E5AE0D0197F17A3BF498BFF708E04EA702FE',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_F4A7E5AE0D0197F17A3BF498BFF708E04EA702FE" FOREIGN KEY ("RESP_mechanicalAntennaBearing") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_1BBB2773C56AC17AF4F81E8CE86181C61F4E28D0',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_1BBB2773C56AC17AF4F81E8CE86181C61F4E28D0" FOREIGN KEY ("RESP_mechanicalAntennaTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_166C6D1792E0FCE19E3F6AA5705219094678406F',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_166C6D1792E0FCE19E3F6AA5705219094678406F" FOREIGN KEY ("RESP_positionWithinSector") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_E891C64DBCC7E495419938DBD17B967635EA9921',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_E891C64DBCC7E495419938DBD17B967635EA9921" FOREIGN KEY ("RESP_totalTilt") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_CC36D660526D1C767F26A3544B6B473417B0EE94',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_CC36D660526D1C767F26A3544B6B473417B0EE94" FOREIGN KEY ("RESP_verticalBeamWidth") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       '9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974',
+ 'FK_2B3186DA8B7B260F570B6482C815A75147876AAC',
+ 'ALTER TABLE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ADD CONSTRAINT "FK_2B3186DA8B7B260F570B6482C815A75147876AAC" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AA68071F5A253FC68706DC4244B2EEEDCFA4F477',
+ 'FK_369392B0C4A062C140E858C9400C0E744F0AC68B',
+ 'ALTER TABLE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ADD CONSTRAINT "FK_369392B0C4A062C140E858C9400C0E744F0AC68B" FOREIGN KEY ("RESP_eUtranFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AA68071F5A253FC68706DC4244B2EEEDCFA4F477',
+ 'FK_BDB6F82FFAC7E705C7D5D88643B77E36B2B9C4A7',
+ 'ALTER TABLE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ADD CONSTRAINT "FK_BDB6F82FFAC7E705C7D5D88643B77E36B2B9C4A7" FOREIGN KEY ("RESP_geranFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AA68071F5A253FC68706DC4244B2EEEDCFA4F477',
+ 'FK_5ED96C3949F44E73C1F4EB9E8808FF79627A4E9D',
+ 'ALTER TABLE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ADD CONSTRAINT "FK_5ED96C3949F44E73C1F4EB9E8808FF79627A4E9D" FOREIGN KEY ("RESP_nRFqBands") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AA68071F5A253FC68706DC4244B2EEEDCFA4F477',
+ 'FK_DD48083834253B9A506780AB5EC36078B571553C',
+ 'ALTER TABLE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ADD CONSTRAINT "FK_DD48083834253B9A506780AB5EC36078B571553C" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_7186222B8E58F2BA404053317F6B750832B7AEBB',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_7186222B8E58F2BA404053317F6B750832B7AEBB" FOREIGN KEY ("RESP_dUpLMNId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_F52167D7632035FBC133091B80F9DEE9E37ABD69',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_F52167D7632035FBC133091B80F9DEE9E37ABD69" FOREIGN KEY ("RESP_gNBDUId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_970FEC4332A2D5BBA9EB1398FE0F5FAD455D7EE3',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_970FEC4332A2D5BBA9EB1398FE0F5FAD455D7EE3" FOREIGN KEY ("RESP_gNBId") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_0AB6F974D9D18A47E4FDCEB6C4260AC2A62218BD',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_0AB6F974D9D18A47E4FDCEB6C4260AC2A62218BD" FOREIGN KEY ("RESP_gNBIdLength") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_71C5B9A055FF4C3CB37CB920A7442FC5411F7BCE',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_71C5B9A055FF4C3CB37CB920A7442FC5411F7BCE" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_4ADA30B48EB5107E0F730EB9684B5545524ADB42',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_4ADA30B48EB5107E0F730EB9684B5545524ADB42" FOREIGN KEY ("REL_FK_managed-by-managedElement") REFERENCES teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'UNIQUE_EFB77EDE9661E3C6826E575AB125FD4F8FCD3BE1',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "UNIQUE_EFB77EDE9661E3C6826E575AB125FD4F8FCD3BE1" UNIQUE ("REL_ID_BDE0B6C74D14AC109D29A08D80E92D4D0DCAEB0B");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'AD6AA1B5E225BBC96B792246D095340747056399',
+ 'FK_419715A9297507DFE5165617FB4D8827AEBF3A9A',
+ 'ALTER TABLE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ADD CONSTRAINT "FK_419715A9297507DFE5165617FB4D8827AEBF3A9A" FOREIGN KEY ("REL_RESP_id_B327AD97E459B9904E24439FF4F9A442165DD1C0") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'C9475FE40C02BEB41F720B4284A856F2CF49E1F3',
+ 'FK_743B8A7D8779674BDBA042C099462FFE7BFFBDBB',
+ 'ALTER TABLE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ADD CONSTRAINT "FK_743B8A7D8779674BDBA042C099462FFE7BFFBDBB" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'C9475FE40C02BEB41F720B4284A856F2CF49E1F3',
+ 'FK_15CBD840591824744326C05E2FC38C9ABE9A197E',
+ 'ALTER TABLE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ADD CONSTRAINT "FK_15CBD840591824744326C05E2FC38C9ABE9A197E" FOREIGN KEY ("REL_FK_used-nrCellDu") REFERENCES teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'C9475FE40C02BEB41F720B4284A856F2CF49E1F3',
+ 'UNIQUE_C40364D44BC6DFCB468EEE1A8FB42BDB71D94114',
+ 'ALTER TABLE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ADD CONSTRAINT "UNIQUE_C40364D44BC6DFCB468EEE1A8FB42BDB71D94114" UNIQUE ("REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'C9475FE40C02BEB41F720B4284A856F2CF49E1F3',
+ 'FK_B2748BFFCFCEE7C9AE54A3BACFF9052A7BE3E626',
+ 'ALTER TABLE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" ADD CONSTRAINT "FK_B2748BFFCFCEE7C9AE54A3BACFF9052A7BE3E626" FOREIGN KEY ("REL_RESP_id_16BDFF7861A21C39988A1CE8BF89B1816C8754FC") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'E2D2B450D65F1FF241A983CBB43B54C040969908',
+ 'FK_8ABF058C19072591C1000BDDD52FF17F488DCF24',
+ 'ALTER TABLE teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ADD CONSTRAINT "FK_8ABF058C19072591C1000BDDD52FF17F488DCF24" FOREIGN KEY ("aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C") REFERENCES teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'E2D2B450D65F1FF241A983CBB43B54C040969908',
+ 'FK_37802898775B4197154F9DA54F8B7946A3C735BA',
+ 'ALTER TABLE teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ADD CONSTRAINT "FK_37802898775B4197154F9DA54F8B7946A3C735BA" FOREIGN KEY ("bSide_E8A97B8133D74D3BE65119E868FAC0BE63C09FFC") REFERENCES teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'E2D2B450D65F1FF241A983CBB43B54C040969908',
+ 'FK_A52435BCC8CAF93A5852E912203F3A76ACE9FA35',
+ 'ALTER TABLE teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" ADD CONSTRAINT "FK_A52435BCC8CAF93A5852E912203F3A76ACE9FA35" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_E958432C9E761168561ACE1E78B21A7AF92580C6',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_E958432C9E761168561ACE1E78B21A7AF92580C6" FOREIGN KEY ("RESP_958686CF1CBC168C2ED063F6645F06556C76DC3B") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_8CB88A1C0F652B51FD9845C4F564A272A4F58422',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_8CB88A1C0F652B51FD9845C4F564A272A4F58422" FOREIGN KEY ("RESP_nCI") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_3C034AD8F98A5E741F962CFC406F48EECD096DB8',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_3C034AD8F98A5E741F962CFC406F48EECD096DB8" FOREIGN KEY ("RESP_nRPCI") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_74E499FB900CBFFBCB389A24AC99CD5CE92A5144',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_74E499FB900CBFFBCB389A24AC99CD5CE92A5144" FOREIGN KEY ("RESP_nRTAC") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_FA12E9B91FE138393C518269329D9262104DAD7A',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_FA12E9B91FE138393C518269329D9262104DAD7A" FOREIGN KEY ("RESP_id") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_500A088A217D3F8B505A8F408076BB5AD265AF63',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_500A088A217D3F8B505A8F408076BB5AD265AF63" FOREIGN KEY ("REL_FK_provided-by-oduFunction") REFERENCES teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" ("id");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'UNIQUE_6C7164EC5E639D7E0D833D3C4E0CAB85062EE418',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "UNIQUE_6C7164EC5E639D7E0D833D3C4E0CAB85062EE418" UNIQUE ("REL_ID_7899092EC8FBC674398C53965ADEFF940D17481F");'
+);
+
+SELECT teiv_data.create_constraint_if_not_exists(
+       'F93C2CA075353668A76B4718E07B741ACCD83641',
+ 'FK_0C3F721FF39EBC5118835710D0C088C8E3328FF1',
+ 'ALTER TABLE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" ADD CONSTRAINT "FK_0C3F721FF39EBC5118835710D0C088C8E3328FF1" FOREIGN KEY ("REL_RESP_id_3E560656C6590F0E2C4BAD9653CE371CF29D2D08") REFERENCES teiv_data."responsible_adapter" ("hashed_id");'
+);
+
+CREATE INDEX IF NOT EXISTS "IDX_8A2A0ABA5E6ACAA8EF991E5B983551524A679509" ON teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_07C2D9F67E32FD07A927D1DF5F06734D7F89DBA0" ON teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_58D33C1960633F6CAA5F7E0A9880FF85D5923BF7" ON teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_EA883FE1AB208DC033513D76B1414014FE4D1397" ON teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_53A525F2FE3F291B4F2B234FE4EC799C778A8687" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_8F5A022153912D07D92FCE34FA9E754E0163F818" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_83EEB2F630BDBBF7BE7E8BBFA452D7F2AB69EB69" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_77A2303E82E9B9B4A9D61BE7C4F1B6088C40A04E" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_DBBF1D30DCD311E5D9D17524730BBF38DEB8BBF8" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN (("REL_CD_8D8BBB53FB18E8E9A5D241B66DA18CB5DDE9C1A5"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_D8626C46F2134489869EC9F70A2F3960D37BA656" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN (("REL_CD_68C234330FD6388836D0DAF9DFD0A40DE66DD8C5"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_97C1311E85CBA88A2048A17CC3A91406A13A162A" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN ("REL_CD_A14923FFF9D13FEB18087CE2A9C0BD264C572CFC");
+
+CREATE INDEX IF NOT EXISTS "IDX_52840EAF2D41B89AC3CE825BC9B0D9AC35AEFC5C" ON teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B" USING GIN ("REL_metadata_F723867781098568079DD82E5D5E529374F97E98");
+
+CREATE INDEX IF NOT EXISTS "IDX_13E530F00B0D405F58CDA235146715762EF6DF91" ON teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_B6911D7B07CE9E7CF692209760002ABD15DA8CD9" ON teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4D253E190E8502C2DE0DC0E2A7A758EA8A5E5888" ON teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_A04886514310E5B31E206923891CD213D9A5CEE6" ON teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_452AE5B87383D94C9B188FBA8BBDA09B8A7E73B4" ON teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" USING GIN (("antennaBeamWidth"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_52B1FEA89EC725EA6195DBD272ED9983E98B99CB" ON teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_35E57E345ABB0D6A9CD6D8FBDBC620646C046669" ON teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_8B5018C20A65AC6FFF6E9B4C099B8F18058B3533" ON teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_54DC74991A70957B0CEBAA38200F3059ECCABDEC" ON teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_C9652A1BD1F6441ECBDB38922226AD08D7DDD60D" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN (("eUtranFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_41A2CB8C648BE9B006CB04631C440F71DA6A61C3" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN (("geranFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_49AB1B81ED859FE4A0F148617CB3E11454E05EAA" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN (("nRFqBands"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_CD2038615C829FA3EC5520DEF04DEBAD87DB7B57" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_7470F8E4355FEDE440D3CEB831E05AF350B8144B" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_3D44AB1602F5AA87FAF39E6F596888419F723F47" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_9532CB2D7B71297C7279D2E824DBE655331B5220" ON teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_00624177EC65536001DDF0477A8F698B871C142D" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN ("dUpLMNId");
+
+CREATE INDEX IF NOT EXISTS "IDX_241D90708F29A60824E2A63C86D9AB84E611E505" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_98C227150239A7692514F1FDF5E3F49FC4439357" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_F308FB8D16B912769597B9678466ADB19BAA27B2" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_9EC8D13EBFB1E513FD4F18C284AD66FA6751E2BC" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_0B9A243313790591EFA74660F1863924EE8CCB6C" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN (("REL_CD_45E8E8693B1B8928376EAA8995D08AA7B1E483BD"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_3FF5E0D439B273B25E65C4EC6E4682E5F8AE9D79" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN (("REL_CD_7E9F11EFBF8974D7C7DAB02E181A0BE4148091C6"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_DC5DA06087B85C01A975848202AC386694598D78" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN ("REL_CD_FFF7E036187A7605BFC714483D2E60FD2FF6560B");
+
+CREATE INDEX IF NOT EXISTS "IDX_40D54F003F8A66E82DFC0BE377ADEFF1A8EAE78D" ON teiv_data."AD6AA1B5E225BBC96B792246D095340747056399" USING GIN ("REL_metadata_72494257260B57223C09828D7C3B31D203B050B4");
+
+CREATE INDEX IF NOT EXISTS "IDX_36D40805D5D41247C46C23AF06A399E7CDC46EDD" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_18D66A31B8B88551ADA98E4BC6362B71A504CE1B" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_245803DDE5BD5AB2780BB277649AE40CA8F4E145" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_CDD068E13765C799B6503561CB0FAC5638B22C70" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_3EEEE6049314C502989CA49A6050FC40898889D1" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN (("REL_CD_1F61FA6DDAECE90540F9880F2A98037B1530A5A4"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_40A0F4A77264E4DD55EBA83EB2270B21E79F48FF" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN (("REL_CD_E388983F3E6BFAD67CA100F0AFCF8CD3E9B89ADD"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4520B8DC811185D63D0E415F4E0AED4DC9967219" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN ("REL_CD_EF3979E9DAF31B7949C883654633E633B9D35B92");
+
+CREATE INDEX IF NOT EXISTS "IDX_6E7F02AC7C81800C688BB46D2639CBABFB376239" ON teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3" USING GIN ("REL_metadata_C9E09FBCCBA1F6A3252B71B869B269EF28AACDFB");
+
+CREATE INDEX IF NOT EXISTS "IDX_C4B686BC6CAF76EADC031DCCC15CBA7C3F81427C" ON teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_44B101C83E01F881D34B98CFB68E980DF4AF9A96" ON teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_7C35D9F162CB5D2DA8BF96C1F076C9C55EC7CA96" ON teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_2905D52A1A6E49FD9E984F4AD978144B6309C86F" ON teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_E909484E1251C6944EE877CB737E07475884A1AE" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN (("CD_sourceIds"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_14454BB7AC41220815C5885AD1B3DB72F8089315" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN (("CD_classifiers"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_3C1344FC931EF89522B673948D541FD73E375C4F" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN ("CD_decorators");
+
+CREATE INDEX IF NOT EXISTS "IDX_BBF662FB069D121A65DCE5A46DAC3185B9A6D9A4" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN ("metadata");
+
+CREATE INDEX IF NOT EXISTS "IDX_1161D2AF3E3B8B7503469AFF6E3DA87B4D66F852" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN (("REL_CD_32FFD9EF85AB2342E652FA493C3BF34D9BAAF054"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_4F93EF555F8640ADA220F02F1434AF29A96F85F2" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN (("REL_CD_B614AAA814176BC7128CE9D72C0950C4D6DE8052"::TEXT) gin_trgm_ops);
+
+CREATE INDEX IF NOT EXISTS "IDX_17F56568BFFACD4F9F2E6372407CE7F8FA06AF17" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN ("REL_CD_0AC0D382E4274681870EC7319460192F4F603001");
+
+CREATE INDEX IF NOT EXISTS "IDX_6DDF32177944AAEDACB2123D05680F3B3B9BD4C7" ON teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641" USING GIN ("REL_metadata_8B4FA813345B7F25ACF2E9635EAF6E6DE0FBBE8A");
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_ODUFunction";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_OCUCPFunction";
+
+ANALYZE teiv_data."o-ran-smo-teiv-equipment_Site";
+
+ANALYZE teiv_data."C9475FE40C02BEB41F720B4284A856F2CF49E1F3";
+
+ANALYZE teiv_data."98D95275440120DC7A5FEF7E870FB6649F275AEC";
+
+ANALYZE teiv_data."9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974";
+
+ANALYZE teiv_data."o-ran-smo-teiv-oam_ManagedElement";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_NRCellDU";
+
+ANALYZE teiv_data."AD6AA1B5E225BBC96B792246D095340747056399";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_OCUUPFunction";
+
+ANALYZE teiv_data."o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU";
+
+ANALYZE teiv_data."8F1E5B0125750A5230DB73DB7816ECCFFC2D918B";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_AntennaCapability";
+
+ANALYZE teiv_data."o-ran-smo-teiv-equipment_AntennaModule";
+
+ANALYZE teiv_data."09D47DF128202AB535BC2056D7C0952F6EE7AF2D";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_EUtranCell";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_LTESectorCarrier";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_NRCellCU";
+
+ANALYZE teiv_data."F93C2CA075353668A76B4718E07B741ACCD83641";
+
+ANALYZE teiv_data."CFC235E0404703D1E4454647DF8AAE2C193DB402";
+
+ANALYZE teiv_data."AA68071F5A253FC68706DC4244B2EEEDCFA4F477";
+
+ANALYZE teiv_data."E2D2B450D65F1FF241A983CBB43B54C040969908";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_NRSectorCarrier";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_ENodeBFunction";
+
+ANALYZE teiv_data."o-ran-smo-teiv-ran_Sector";
+
+ANALYZE teiv_data."1D71FC3BAE50E72552EAAC17B3B0C959B403E822";
+
+COMMIT;
diff --git a/teiv/src/test/resources/pgsqlschema/end-to-end-test-model.sql b/teiv/src/test/resources/pgsqlschema/end-to-end-test-model.sql
new file mode 100644 (file)
index 0000000..f633b48
--- /dev/null
@@ -0,0 +1,667 @@
+--
+-- ============LICENSE_START=======================================================
+-- Copyright (C) 2024 Ericsson
+-- Modifications Copyright (C) 2024 OpenInfra Foundation Europe
+-- ================================================================================
+-- Licensed under the Apache License, Version 2.0 (the "License");
+-- you may not use this file except in compliance with the License.
+-- You may obtain a copy of the License at
+--
+--       http://www.apache.org/licenses/LICENSE-2.0
+--
+-- Unless required by applicable law or agreed to in writing, software
+-- distributed under the License is distributed on an "AS IS" BASIS,
+-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+-- See the License for the specific language governing permissions and
+-- limitations under the License.
+--
+-- SPDX-License-Identifier: Apache-2.0
+-- ============LICENSE_END=========================================================
+--
+
+BEGIN;
+
+DROP SCHEMA IF EXISTS teiv_model cascade;
+CREATE SCHEMA IF NOT EXISTS teiv_model;
+ALTER SCHEMA teiv_model OWNER TO :pguser;
+SET default_tablespace = '';
+SET default_table_access_method = heap;
+
+SET ROLE :pguser;
+
+CREATE TABLE IF NOT EXISTS teiv_model.hash_info (
+    "name"        TEXT PRIMARY KEY,
+    "hashedValue" VARCHAR(63) NOT NULL,
+    "type"        VARCHAR(511)
+);
+
+CREATE TABLE IF NOT EXISTS teiv_model.module_reference (
+    "name"            TEXT PRIMARY KEY,
+    "namespace"       TEXT,
+    "domain"          TEXT,
+    "includedModules" jsonb DEFAULT '[]'::jsonb,
+    "revision"        TEXT NOT NULL,
+    "content"         TEXT NOT NULL
+);
+
+CREATE TABLE IF NOT EXISTS teiv_model.entity_info (
+    "storedAt"            TEXT PRIMARY KEY,
+    "name"                TEXT NOT NULL,
+    "moduleReferenceName" TEXT NOT NULL,
+    "attributeNames"      jsonb DEFAULT '[]'::jsonb,
+    FOREIGN KEY ("moduleReferenceName") REFERENCES teiv_model.module_reference ("name") ON DELETE CASCADE
+);
+
+CREATE TABLE IF NOT EXISTS teiv_model.relationship_info (
+    "name"                     TEXT NOT NULL,
+    "aSideAssociationName"     TEXT NOT NULL,
+    "aSideMOType"              TEXT NOT NULL,
+    "aSideModule"              TEXT NOT NULL,
+    "aSideMinCardinality"      BIGINT NOT NULL,
+    "aSideMaxCardinality"      BIGINT NOT NULL,
+    "bSideAssociationName"     TEXT NOT NULL,
+    "bSideMOType"              TEXT NOT NULL,
+    "bSideModule"              TEXT NOT NULL,
+    "bSideMinCardinality"      BIGINT NOT NULL,
+    "bSideMaxCardinality"      BIGINT NOT NULL,
+    "associationKind"          TEXT NOT NULL,
+    "relationshipDataLocation" TEXT NOT NULL,
+    "storedAt"                 TEXT NOT NULL,
+    "connectSameEntity"        BOOLEAN NOT NULL,
+    "moduleReferenceName"      TEXT NOT NULL,
+    PRIMARY KEY ("name", "moduleReferenceName"),
+    FOREIGN KEY ("aSideModule") REFERENCES teiv_model.module_reference ("name") ON DELETE CASCADE,
+    FOREIGN KEY ("bSideModule") REFERENCES teiv_model.module_reference ("name") ON DELETE CASCADE,
+    FOREIGN KEY ("moduleReferenceName") REFERENCES teiv_model.module_reference ("name") ON DELETE CASCADE
+);
+
+COPY teiv_model.hash_info("name", "hashedValue", "type") FROM stdin;
+CD_classifiers CD_classifiers  COLUMN
+CD_decorators  CD_decorators   COLUMN
+CD_sourceIds   CD_sourceIds    COLUMN
+FK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_aSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee       FK_1A5303EF43A4407B0A47C80B9EF3DCA81FEA484A     CONSTRAINT
+FK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_bSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee       FK_AAB4A7CE5DD41A0CAEFA20B7538F2B851529E327     CONSTRAINT
+FK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_aSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee       FK_CF5ED6B6F3D98A44BCF9209A20D9C901F5C3C23E     CONSTRAINT
+FK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_bSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee       FK_FA290CAE2E1C24893F90877F0EDF7304CD6D4563     CONSTRAINT
+FK_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_FK_used-nrCellDu       FK_15CBD840591824744326C05E2FC38C9ABE9A197E     CONSTRAINT
+FK_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_FK_managed-by-managedElement     FK_4ADA30B48EB5107E0F730EB9684B5545524ADB42     CONSTRAINT
+FK_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_FK_used-antennaCapability        FK_778741F2AA29B57611EB06A903D58099245BB537     CONSTRAINT
+FK_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_FK_provided-by-oduFunction     FK_500A088A217D3F8B505A8F408076BB5AD265AF63     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY_aSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee     FK_8ABF058C19072591C1000BDDD52FF17F488DCF24     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY_bSide_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy   FK_37802898775B4197154F9DA54F8B7946A3C735BA     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_aSide_NFDeployment    FK_A08D274894ECB6799E56C2089A494AF0345B9B16     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_bSide_OCloudNamespace FK_D39953B79C8D39296B892FCF2C00B9C99AC7023F     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NFDeployment_REL_FK_comprised-by-cloudifiedNF  FK_127C21CB9B8871C3BCACA05A5400BE6B8E7FCAC0     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NFDeployment_REL_FK_serviced-managedElement    FK_AC1348E208C2E64F2EB1DECE2CCA5DB10B89CBD9     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_aSide_NodeCluster    FK_AE882D77CE8D21B8032B124E1822E0EEE5DAAD92     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_bSide_OCloudSite     FK_888BF6FF782916E61B3FE80643A549A1CFDB6117     CONSTRAINT
+FK_o-ran-smo-teiv-cloud_OCloudNamespace_REL_FK_deployed-on-nodeCluster FK_143EFC1953E68469572446EFB56BDEBBC83B8EBF     CONSTRAINT
+FK_o-ran-smo-teiv-equipment_AntennaModule_REL_FK_grouped-by-sector     FK_078764B2F3D613D44CC6E3586F564C83164D2481     CONSTRAINT
+FK_o-ran-smo-teiv-equipment_AntennaModule_REL_FK_installed-at-site     FK_E3BAEF04443354C0FC1837CF7964E05BEF9FD6CC     CONSTRAINT
+FK_o-ran-smo-teiv-oam_ManagedElement_REL_FK_deployed-as-cloudifiedNF   FK_899B8130A861D1450FC49D3159D8B29C0628A717     CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRCellCU_REL_FK_provided-by-ocucpFunction        FK_o-ran-smo-teiv-ran_NRCellCU_REL_FK_provided-by-ocucpFunction CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_grouped-by-sector        FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_grouped-by-sector CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_provided-by-oduFunction  FK_o-ran-smo-teiv-ran_NRCellDU_REL_FK_provided-by-oduFunction   CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_provided-by-oduFunction   FK_9B73B9E2DBA36736FB76606005C823A6D565A5CD     CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_used-antennaCapability    FK_65D538D54EB33081C808540235FEB28823428E64     CONSTRAINT
+FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_used-by-nrCellDu  FK_o-ran-smo-teiv-ran_NRSectorCarrier_REL_FK_used-by-nrCellDu   CONSTRAINT
+FK_o-ran-smo-teiv-ran_NearRTRICFunction_REL_FK_managed-by-managedElement       FK_32BDE0334EA6AD74ABB3958A2B163F63A3F05203     CONSTRAINT
+FK_o-ran-smo-teiv-ran_OCUCPFunction_REL_FK_managed-by-managedElement   FK_122DD9709032528D161177B3624AD7AAF6589005     CONSTRAINT
+FK_o-ran-smo-teiv-ran_OCUUPFunction_REL_FK_managed-by-managedElement   FK_8062AF50E5EE5543FBCC68D66FDFF673E31E081D     CONSTRAINT
+FK_o-ran-smo-teiv-ran_ODUFunction_REL_FK_managed-by-managedElement     FK_B6F0A4F9024FB47DA39C9A4F1DFFF78330222A80     CONSTRAINT
+FK_o-ran-smo-teiv-ran_ORUFunction_REL_FK_managed-by-managedElement     FK_B497A8C3DC2D647938E6DB4C7E691509DD8C90DE     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_aSide_NFDeployment       FK_BE847E738902EA979AC709D5A3D0CCD3FD8911CA     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_bSide_NearRTRICFunction  FK_CCC0DEA6E4ABAB8614332070E83D953254D5A3A5     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_aSide_NFDeployment   FK_2B4B09AF7CC9C877B1140BB127B4CB4DA438195D     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_bSide_OCUCPFunction  FK_BCF2F9776761ABC19AE0BBD0244D7CD5785E7AC6     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_aSide_NFDeployment   FK_AC1393DCBA845EDA13DADCB5BD87DF4163CD1669     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_bSide_OCUUPFunction  FK_8585D545BC37A473A298E0F5F5942F897A7105B1     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_aSide_NFDeployment     FK_ABA5D0BEEB45E6A5B14DB24E880029CA38DF3F79     CONSTRAINT
+FK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_bSide_ODUFunction      FK_C7C12DB840FBCF4EA729B8C2BBCD8BFDE06F0F08     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_aSide_AntennaModule FK_D80D1E6B26DF620B4DE659C600A3B7F709A41960     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_bSide_AntennaCapability     FK_7148BEED02C0617DE1DEEB6639F34A9FA9251B06     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_aSide_AntennaModule  FK_1AB1E0CC29DA2E122D43A6616EC60A3F73E68649     CONSTRAINT
+FK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_bSide_NRCellDU       FK_8605800A4923C52258A8CE3989E18A7C93D22E8C     CONSTRAINT
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_CD_classifiers        IDX_07C2D9F67E32FD07A927D1DF5F06734D7F89DBA0    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_CD_sourceIds  IDX_8A2A0ABA5E6ACAA8EF991E5B983551524A679509    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_CD_classifiers        IDX_B6911D7B07CE9E7CF692209760002ABD15DA8CD9    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_CD_sourceIds  IDX_13E530F00B0D405F58CDA235146715762EF6DF91    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_CD_classifiers        IDX_35E57E345ABB0D6A9CD6D8FBDBC620646C046669    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_CD_sourceIds  IDX_52B1FEA89EC725EA6195DBD272ED9983E98B99CB    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_antennaBeamWidth      IDX_452AE5B87383D94C9B188FBA8BBDA09B8A7E73B4    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_CD_classifiers      IDX_18D66A31B8B88551ADA98E4BC6362B71A504CE1B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_CD_sourceIds        IDX_36D40805D5D41247C46C23AF06A399E7CDC46EDD    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_CD_classifiers_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU IDX_40A0F4A77264E4DD55EBA83EB2270B21E79F48FF    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_CD_sourceIds_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU   IDX_3EEEE6049314C502989CA49A6050FC40898889D1    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_CD_classifiers    IDX_7470F8E4355FEDE440D3CEB831E05AF350B8144B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_CD_sourceIds      IDX_CD2038615C829FA3EC5520DEF04DEBAD87DB7B57    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_eUtranFqBands     IDX_C9652A1BD1F6441ECBDB38922226AD08D7DDD60D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_geranFqBands      IDX_41A2CB8C648BE9B006CB04631C440F71DA6A61C3    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_nRFqBands IDX_49AB1B81ED859FE4A0F148617CB3E11454E05EAA    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_CD_classifiers        IDX_98C227150239A7692514F1FDF5E3F49FC4439357    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_CD_sourceIds  IDX_241D90708F29A60824E2A63C86D9AB84E611E505    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_CD_classifiers_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN     IDX_3FF5E0D439B273B25E65C4EC6E4682E5F8AE9D79    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_CD_sourceIds_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN       IDX_0B9A243313790591EFA74660F1863924EE8CCB6C    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_CD_classifiers        IDX_8F5A022153912D07D92FCE34FA9E754E0163F818    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_CD_sourceIds  IDX_53A525F2FE3F291B4F2B234FE4EC799C778A8687    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_CD_classifiers_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY  IDX_D8626C46F2134489869EC9F70A2F3960D37BA656    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_CD_sourceIds_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY    IDX_DBBF1D30DCD311E5D9D17524730BBF38DEB8BBF8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_CD_classifiers      IDX_14454BB7AC41220815C5885AD1B3DB72F8089315    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_CD_sourceIds        IDX_E909484E1251C6944EE877CB737E07475884A1AE    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_CD_classifiers_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU   IDX_4F93EF555F8640ADA220F02F1434AF29A96F85F2    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_CD_sourceIds_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU     IDX_1161D2AF3E3B8B7503469AFF6E3DA87B4D66F852    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_CD_decorators   IDX_58D33C1960633F6CAA5F7E0A9880FF85D5923BF7    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_metadata        IDX_EA883FE1AB208DC033513D76B1414014FE4D1397    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_CD_decorators   IDX_4D253E190E8502C2DE0DC0E2A7A758EA8A5E5888    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_metadata        IDX_A04886514310E5B31E206923891CD213D9A5CEE6    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_CD_decorators   IDX_8B5018C20A65AC6FFF6E9B4C099B8F18058B3533    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_metadata        IDX_54DC74991A70957B0CEBAA38200F3059ECCABDEC    INDEX
+IDX_GIN_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_CD_decorators IDX_245803DDE5BD5AB2780BB277649AE40CA8F4E145    INDEX
+IDX_GIN_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_CD_decorators_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU    IDX_4520B8DC811185D63D0E415F4E0AED4DC9967219    INDEX
+IDX_GIN_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_metadata_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU IDX_6E7F02AC7C81800C688BB46D2639CBABFB376239    INDEX
+IDX_GIN_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_metadata      IDX_CDD068E13765C799B6503561CB0FAC5638B22C70    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_CD_decorators       IDX_3D44AB1602F5AA87FAF39E6F596888419F723F47    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_metadata    IDX_9532CB2D7B71297C7279D2E824DBE655331B5220    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_CD_decorators   IDX_F308FB8D16B912769597B9678466ADB19BAA27B2    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_CD_decorators_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN        IDX_DC5DA06087B85C01A975848202AC386694598D78    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_metadata_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN     IDX_40D54F003F8A66E82DFC0BE377ADEFF1A8EAE78D    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_dUpLMNId        IDX_00624177EC65536001DDF0477A8F698B871C142D    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_metadata        IDX_9EC8D13EBFB1E513FD4F18C284AD66FA6751E2BC    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_CD_decorators   IDX_83EEB2F630BDBBF7BE7E8BBFA452D7F2AB69EB69    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_CD_decorators_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY     IDX_97C1311E85CBA88A2048A17CC3A91406A13A162A    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_metadata_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY  IDX_52840EAF2D41B89AC3CE825BC9B0D9AC35AEFC5C    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_metadata        IDX_77A2303E82E9B9B4A9D61BE7C4F1B6088C40A04E    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_CD_decorators IDX_3C1344FC931EF89522B673948D541FD73E375C4F    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_CD_decorators_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU      IDX_17F56568BFFACD4F9F2E6372407CE7F8FA06AF17    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_metadata_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU   IDX_6DDF32177944AAEDACB2123D05680F3B3B9BD4C7    INDEX
+IDX_GIN_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_metadata      IDX_BBF662FB069D121A65DCE5A46DAC3185B9A6D9A4    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY_CD_decorators IDX_7C35D9F162CB5D2DA8BF96C1F076C9C55EC7CA96    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY_metadata      IDX_2905D52A1A6E49FD9E984F4AD978144B6309C86F    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_CloudifiedNF_CD_classifiers     IDX_BD96130868B69147B2F87B0D15F5829690DEF454    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_CloudifiedNF_CD_sourceIds       IDX_9EDB5C47201FC82A4565BFED9EF369D6C6529B19    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_CD_classifiers IDX_1BCFD9635C4FA089EDC2E18FFEF56DBF3C5E7A52    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_CD_sourceIds   IDX_F97E398B17532BCD9923CE0CF98E73227D890037    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_CD_classifiers     IDX_BED5B5FAA75FEE133E27581EAA611B89D20F24E1    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_CD_sourceIds       IDX_6433B9B7D69E51E828BDCFCAF59729EDCD10DA60    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_classifiers_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT     IDX_31F185F0F700C0AE11C5A9B8D28DBF6E37538635    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_classifiers_NFDEPLOYMENT_SERVES_MANAGEDELEMENT      IDX_1EE98ACCAE5537752BD51A3D5F6429585CC543F6    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_sourceIds_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT       IDX_072EB0C094138AB2D90F9CFBDA765B3B464EE86F    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_sourceIds_NFDEPLOYMENT_SERVES_MANAGEDELEMENT        IDX_4DD95BAED8503502101FEB9ECA25DDA8F371816C    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_CD_classifiers        IDX_29702D5C8D0B9B20BFB534FA233B9D9FADC2E3A1    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_CD_sourceIds  IDX_1D7F9BD4B5BBF73CC3D06D949731DC169DDED26D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NodeCluster_CD_classifiers      IDX_CB29E8DDA990051B2A3DF193D8E4912F25D5FA0D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_NodeCluster_CD_sourceIds        IDX_DC1829E4241BA7C9B3E5281AC0DF00A766F9452E    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudNamespace_CD_classifiers  IDX_57EB74DEF745DE4BA9AAD8E735BACB71F2E8C417    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudNamespace_CD_sourceIds    IDX_1B8DF6B061E229E5B6AC796911E6C8C23ECAD585    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudNamespace_REL_CD_classifiers_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER      IDX_6EE081E80342904B676496DA42DFAEC3EDA2CE27    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudNamespace_REL_CD_sourceIds_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER        IDX_A7A50200F582AB86EF483F9BA74F999F17B7F653    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudSite_CD_classifiers       IDX_281A2DE604D25D6CFECB9B26D1FF70429FDB0FD0    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-cloud_OCloudSite_CD_sourceIds IDX_30C83E5F8447D28D8E2A73048DF751C886AF318B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_CD_classifiers        IDX_1C0CAFD80FDD6444044E3F76C7C0A7BDC35F9BC8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_CD_sourceIds  IDX_905011128A2C218B5352C19ED1FE9851F43EB911    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE    IDX_17E417F7EF56809674BE1D5F5154DCCE01E00A96    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE        IDX_83B6347C0C0A005D5E3D856D973D3322DFEDEA35    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE      IDX_F497DEC01DA066CB09DA2AA7EDE3F4410078491B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE  IDX_5ABDB19E55A6BDEF33855F14CB1B3B8CF457912C    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_AntennaModule_antennaBeamWidth      IDX_21B0F1FE632B6CB185C49BA6F00224068F443215    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_Site_CD_classifiers IDX_EEBF1BC3344E97988232825777AB13FAB6C4F3F0    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-equipment_Site_CD_sourceIds   IDX_102A50584376DE25B6BBD7157594C607A5C957F2    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam_ManagedElement_CD_classifiers     IDX_98AC4232BC02323E03416954215889CEE874A1E9    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam_ManagedElement_CD_sourceIds       IDX_DDD73D6F4004BF3A96AA118281EE3E565A922B47    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam_ManagedElement_REL_CD_classifiers_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF IDX_634619CF7333EBC0AFDE990900B79220FC626EBA    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-oam_ManagedElement_REL_CD_sourceIds_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF   IDX_8065626F3F48D4E5A4285654739D3B26499E4C4E    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_AntennaCapability_CD_classifiers  IDX_E7FFE8F4A166AA9A382A0659762FFEC313A9EB5C    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_AntennaCapability_CD_sourceIds    IDX_CC3E208A4EE51D3B505416A599F36F3C99F466C8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_AntennaCapability_eUtranFqBands   IDX_5FB80647AE3E5C0443A792618D65B9090EE2A3FC    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_AntennaCapability_geranFqBands    IDX_A94722FF7B95D8974B494793908B57B4E1A9743B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_AntennaCapability_nRFqBands       IDX_441B5C05448D63552C6414BD59C13641D8A4408D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellCU_CD_classifiers   IDX_E5930226819982DC0CFC1FA64FB3600647222435    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellCU_CD_sourceIds     IDX_0C443A16285D233F16966C2F0314CDC9D0F6D0B8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellCU_REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU       IDX_D366F952FD4A52645C45A19CBFD02B8897FC1F18    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellCU_REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU IDX_6891C1BB8EE214340A362906C08955E8ACC1C597    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_CD_classifiers   IDX_C437D39632DC79BAB6AC4F0880826A05425F9C32    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_CD_sourceIds     IDX_FFD60DD99D80C276F402E66546F5DACB2D81EE26    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU IDX_A950BF337D5D820E5B39AC3F1B1AC09C062F30C9    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU        IDX_7CB4A7724F68D1CB2D12E8DE779BA9103F7DBE0A    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU   IDX_B48D188E92ACBE9A2CAF8CD730A5DDFD7E086705    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRCellDU_REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU  IDX_6325926B4D2FDD1FBBB34250DABEA5E7229FF9F5    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_CD_classifiers    IDX_050A80BEEF775E4D3CE216F282F23DB99DA2D798    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_CD_sourceIds      IDX_8E34EC0B1DE7DDCE3B32ADD85B11E15F95C5644E    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER  IDX_ED50A5139F1449DBAD8DA10D45F5A5BF819EACBA    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY IDX_B975D24291849007D4AA6686C5D3983885D5C884    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER   IDX_FC70CCFDC1359B698BBBE5CA7AA158F0AF693461    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER    IDX_7BFD17A71AB1B7765FE6431DA4E66C2EDE88AC3B    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY   IDX_1F27C515A028616FAC422A02ABBEC402D5DBB2E5    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER     IDX_986B2223E72FF79237337329F4C3BB9DA9025A34    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NearRTRICFunction_CD_classifiers  IDX_8BCCF388DFC8652AD5CD0675C64F49D2D2EDC7A1    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NearRTRICFunction_CD_sourceIds    IDX_E4E40B26C322AF63A662706AF8B0B36E1043B793    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NearRTRICFunction_REL_CD_classifiers_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION     IDX_0ECC814A408874C9F8E73EEE3968984A6345A606    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_NearRTRICFunction_REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION       IDX_B608D8F6B8A79097EA61A1B4777A96CD3D2D1E98    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUCPFunction_CD_classifiers      IDX_8D9862DBF6A721FABAEA4204E04B374692C1C5B8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUCPFunction_CD_sourceIds        IDX_84A29F8571860AC5A7BD1A99923485ECB6A3939D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUCPFunction_REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION     IDX_21F2560C8330A795E8AFB54C6D31CDCF6CCD3070    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUCPFunction_REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION       IDX_4C6B5CB5CF018656DC8191CE6FE3B9DA2CD0C819    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUUPFunction_CD_classifiers      IDX_25E4BCFBF8F5344DFC60BCB159FA873FFC8109E9    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUUPFunction_CD_sourceIds        IDX_6C81B2BBFCFE94C87598869A2099E04571202BA7    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUUPFunction_REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION     IDX_3346DFB8C2B7D6EEA12B7C1DE4A84B058C24A657    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUUPFunction_REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION       IDX_50209F1FF59B49F79FF194887B631994F2B5148A    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_OCUUPFunction_pLMNIdList  IDX_9122DAA7A60DB585BE5ECA68A2EDB9ABF1E7156A    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ODUFunction_CD_classifiers        IDX_5CE9EDE1F25AB2D880A41BC5D297FDBE668182E8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ODUFunction_CD_sourceIds  IDX_73790DA8FF6365B752DC8B399893AC6DE8CF26C4    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ODUFunction_REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION IDX_5DD192861541E0EB2776C6BFE34B327FF27F93C3    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ODUFunction_REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION   IDX_0E5C91A3252FBAFA72DB644D4E949A379F0CB910    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ORUFunction_CD_classifiers        IDX_2A5AAAD13FDCFF7F2958005C22937366F6604A0D    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ORUFunction_CD_sourceIds  IDX_D0D11CFAA917F4FA12748A041A34D2B39A3AD707    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ORUFunction_REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ORUFUNCTION IDX_DA79A3F946C1F4E8D05B4D6ADEF5E4C65E47635E    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_ORUFunction_REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ORUFUNCTION   IDX_AF235FB2C9CCA99D94CC4038669EDD1BB6C7B2DF    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_Sector_CD_classifiers     IDX_19C19556F9714850389595E0A16218FA229205FE    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-ran_Sector_CD_sourceIds       IDX_E234B43A7CD7843672F08F2197AB46A2A50BECB0    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_CD_classifiers    IDX_F52FEEDBAF1B04D2D22EBAE051BB5125DF6A6968    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_CD_sourceIds      IDX_996D2C34C2458A6EFE8599C1A0E6942D3D288B7A    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_CD_classifiers        IDX_03F9C6A2FA82614A788443AC6044BCED2401C465    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_CD_sourceIds  IDX_10BCC6B44663A8D5431668BEE5DF80423420C616    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_CD_classifiers        IDX_69152691D777DDB084C053915D4A4B15F7F8B3EB    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_CD_sourceIds  IDX_64B7C127C01069009A3FB13592DAE249B0029283    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_CD_classifiers  IDX_F4A1999634924C7E4D1CBD05E83996A5B1262A8A    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_CD_sourceIds    IDX_5996D077978D38D0C1A951A262F1F7E1E339F052    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_CD_classifiers       IDX_DD0D676834B12CA2F7E8219310998376A08D7F5F    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_CD_sourceIds IDX_E896A9EB22A3F9F96CE75A271475316A98B629C8    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_CD_classifiers        IDX_F93AD0AE5C6940EE73D0B661A2E2E5BB10B3772C    INDEX
+IDX_GIN_TRGM_OPS_ON_LIST_AS_JSONB_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_CD_sourceIds  IDX_0E1BE8724BEBB21C5AE3986BE150BEC8F8CD903E    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_CloudifiedNF_CD_decorators        IDX_GIN_o-ran-smo-teiv-cloud_CloudifiedNF_CD_decorators INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_CD_decorators    IDX_4055A796F223DD01411AFFB5AD97EEEAB6B2320C    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NFDeployment_CD_decorators        IDX_GIN_o-ran-smo-teiv-cloud_NFDeployment_CD_decorators INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_decorators_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT        IDX_46CDB369134F042EC021F7496DF721B49A9D43C0    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NFDeployment_REL_CD_decorators_NFDEPLOYMENT_SERVES_MANAGEDELEMENT IDX_39A292C3C42B34C2AD7C2A0FD087739C253B06FC    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_CD_decorators   IDX_98A32BE3A8C1FF8CDEC95561DE4A74852FE70322    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_NodeCluster_CD_decorators IDX_GIN_o-ran-smo-teiv-cloud_NodeCluster_CD_decorators  INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_OCloudNamespace_CD_decorators     IDX_GIN_o-ran-smo-teiv-cloud_OCloudNamespace_CD_decorators      INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_OCloudNamespace_REL_CD_decorators_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER IDX_9AB8994DE0826F790D70614D4C52DD270AEF946B    INDEX
+IDX_GIN_o-ran-smo-teiv-cloud_OCloudSite_CD_decorators  IDX_GIN_o-ran-smo-teiv-cloud_OCloudSite_CD_decorators   INDEX
+IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_CD_decorators   IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_CD_decorators    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE       IDX_2321BFA482AD2700F41E2BA359F6EB00F47601B9    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment_AntennaModule_REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE   IDX_6C6FBD69F47F41970595A8775DC99CA0F5E894A1    INDEX
+IDX_GIN_o-ran-smo-teiv-equipment_Site_CD_decorators    IDX_GIN_o-ran-smo-teiv-equipment_Site_CD_decorators     INDEX
+IDX_GIN_o-ran-smo-teiv-oam_ManagedElement_CD_decorators        IDX_GIN_o-ran-smo-teiv-oam_ManagedElement_CD_decorators INDEX
+IDX_GIN_o-ran-smo-teiv-oam_ManagedElement_REL_CD_decorators_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF    IDX_F15A070FC83B2E49223B4232E0BEB8931C2B7A4C    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_AntennaCapability_CD_decorators     IDX_GIN_o-ran-smo-teiv-ran_AntennaCapability_CD_decorators      INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_CD_decorators      IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_CD_decorators       INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU  IDX_5D761303176D3B9338784DFBEE0CEC51046ADC30    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_plmnId     IDX_GIN_o-ran-smo-teiv-ran_NRCellCU_plmnId      INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_CD_decorators      IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_CD_decorators       INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU    IDX_F494CB3BA4C726D4C45D53B1EF62E1E26811CCEF    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRCellDU_REL_CD_decorators_SECTOR_GROUPS_NRCELLDU   IDX_0A03C47C13AD3B5C84D3D8081493D670E9CBDCD1    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_CD_decorators       IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_CD_decorators        INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER     IDX_2ADB5C6DCAEE8811FB1CA8FD9EB53381F35FCB70    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY    IDX_902B73F741160B9D4FBF62406D3D9ABBECAD8BE7    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NRSectorCarrier_REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER      IDX_5AB1D780E57D940C42BAD29772E9E2B6C63498A0    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NearRTRICFunction_CD_decorators     IDX_GIN_o-ran-smo-teiv-ran_NearRTRICFunction_CD_decorators      INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NearRTRICFunction_REL_CD_decorators_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION        IDX_B10FD045A6C3E169953CCC38CC2D801FCE15A75F    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_NearRTRICFunction_pLMNId    IDX_GIN_o-ran-smo-teiv-ran_NearRTRICFunction_pLMNId     INDEX
+IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_CD_decorators IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_CD_decorators  INDEX
+IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION        IDX_D856E84F300B6711E81931AE1CBC8AD905FA384F    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_pLMNId        IDX_GIN_o-ran-smo-teiv-ran_OCUCPFunction_pLMNId INDEX
+IDX_GIN_o-ran-smo-teiv-ran_OCUUPFunction_CD_decorators IDX_GIN_o-ran-smo-teiv-ran_OCUUPFunction_CD_decorators  INDEX
+IDX_GIN_o-ran-smo-teiv-ran_OCUUPFunction_REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION        IDX_ADD3393C27589066C4993A3491436C6FB57A539F    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_CD_decorators   IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_CD_decorators    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION    IDX_0B9AC962B1E07740CE43D912B5FBC54E0B39DD24    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_dUpLMNId        IDX_GIN_o-ran-smo-teiv-ran_ODUFunction_dUpLMNId INDEX
+IDX_GIN_o-ran-smo-teiv-ran_ORUFunction_CD_decorators   IDX_GIN_o-ran-smo-teiv-ran_ORUFunction_CD_decorators    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_ORUFunction_REL_CD_decorators_MANAGEDELEMENT_MANAGES_ORUFUNCTION    IDX_7B916E1753D2860DF434831CF1E9697ED9973C8F    INDEX
+IDX_GIN_o-ran-smo-teiv-ran_Sector_CD_decorators        IDX_GIN_o-ran-smo-teiv-ran_Sector_CD_decorators INDEX
+IDX_GIN_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_CD_decorators       IDX_D333FA5882890B7CD3599712FFFB2641B9E04C80    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_CD_decorators   IDX_0867A1E865A904F4BB513948DAEB60412BE67DF3    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_CD_decorators   IDX_3AB53A0DB6DC4B4C8BB6194D6D487EBDC3D0E88F    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_CD_decorators     IDX_5BAC6D2F05A63FDE27F082E8C8F4D766C145E835    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_CD_decorators  IDX_7BF09D0227840279556AD27ACECB068705893D28    INDEX
+IDX_GIN_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_CD_decorators   IDX_319FDFF6C9E6BC1D922F0A2AFEAAC294E520F753    INDEX
+PK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE_id   PK_8123C74A8D9A873F330C37E370DB951212243844     CONSTRAINT
+PK_o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE_id   PK_48BAB21388EA2B1BE83EF5D3FC143807776A882D     CONSTRAINT
+PK_o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_id   PK_8EB1724D91D554E7771C8C5AE5AA752A604E025C     CONSTRAINT
+PK_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_id PK_AD1799D4203C08DE10524497B4997C2DCB4F6A92     CONSTRAINT
+PK_o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy_id       PK_AE71D2F6E7DABC3C066CEB9E1F30286DE8AF12D0     CONSTRAINT
+PK_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_id   PK_BEBBD904815CB84D3D7D326B13A71BC786E8C2B6     CONSTRAINT
+PK_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_id   PK_61C7969B1B7C806E01CE3D9471CFF52FA37864C3     CONSTRAINT
+PK_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_id PK_94DB80CFD01964A5D56BC22F433BBAF282F5AB0E     CONSTRAINT
+PK_o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY_id PK_E078962EDFAEDBC93784222B0B7BDFC3929D4D79     CONSTRAINT
+PK_o-ran-smo-teiv-cloud_CloudifiedNF_id        PK_o-ran-smo-teiv-cloud_CloudifiedNF_id CONSTRAINT
+PK_o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE_id    PK_E4FDDE2DC433209F933C7F53C9F72C1D2EB04BC6     CONSTRAINT
+PK_o-ran-smo-teiv-cloud_NFDeployment_id        PK_o-ran-smo-teiv-cloud_NFDeployment_id CONSTRAINT
+PK_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_id   PK_o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE_id    CONSTRAINT
+PK_o-ran-smo-teiv-cloud_NodeCluster_id PK_o-ran-smo-teiv-cloud_NodeCluster_id  CONSTRAINT
+PK_o-ran-smo-teiv-cloud_OCloudNamespace_id     PK_o-ran-smo-teiv-cloud_OCloudNamespace_id      CONSTRAINT
+PK_o-ran-smo-teiv-cloud_OCloudSite_id  PK_o-ran-smo-teiv-cloud_OCloudSite_id   CONSTRAINT
+PK_o-ran-smo-teiv-equipment_AntennaModule_id   PK_o-ran-smo-teiv-equipment_AntennaModule_id    CONSTRAINT
+PK_o-ran-smo-teiv-equipment_Site_id    PK_o-ran-smo-teiv-equipment_Site_id     CONSTRAINT
+PK_o-ran-smo-teiv-oam_ManagedElement_id        PK_o-ran-smo-teiv-oam_ManagedElement_id CONSTRAINT
+PK_o-ran-smo-teiv-ran_AntennaCapability_id     PK_o-ran-smo-teiv-ran_AntennaCapability_id      CONSTRAINT
+PK_o-ran-smo-teiv-ran_NRCellCU_id      PK_o-ran-smo-teiv-ran_NRCellCU_id       CONSTRAINT
+PK_o-ran-smo-teiv-ran_NRCellDU_id      PK_o-ran-smo-teiv-ran_NRCellDU_id       CONSTRAINT
+PK_o-ran-smo-teiv-ran_NRSectorCarrier_id       PK_o-ran-smo-teiv-ran_NRSectorCarrier_id        CONSTRAINT
+PK_o-ran-smo-teiv-ran_NearRTRICFunction_id     PK_o-ran-smo-teiv-ran_NearRTRICFunction_id      CONSTRAINT
+PK_o-ran-smo-teiv-ran_OCUCPFunction_id PK_o-ran-smo-teiv-ran_OCUCPFunction_id  CONSTRAINT
+PK_o-ran-smo-teiv-ran_OCUUPFunction_id PK_o-ran-smo-teiv-ran_OCUUPFunction_id  CONSTRAINT
+PK_o-ran-smo-teiv-ran_ODUFunction_id   PK_o-ran-smo-teiv-ran_ODUFunction_id    CONSTRAINT
+PK_o-ran-smo-teiv-ran_ORUFunction_id   PK_o-ran-smo-teiv-ran_ORUFunction_id    CONSTRAINT
+PK_o-ran-smo-teiv-ran_Sector_id        PK_o-ran-smo-teiv-ran_Sector_id CONSTRAINT
+PK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION_id       PK_82A1C5618438FF6DF7CDD48FD71E0A584E6D052A     CONSTRAINT
+PK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION_id   PK_2D854968CB74C42C534D8E7C2A53E93F6B7F001F     CONSTRAINT
+PK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION_id   PK_E551D02D14B3C04A565DC73A386BEB29627D3C08     CONSTRAINT
+PK_o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION_id     PK_A10CB552A0F126991DD325EC84DBFAC6F2BBE1A3     CONSTRAINT
+PK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY_id  PK_63E61CB6802F21FE7A04A80A095F6AF8ABF067CE     CONSTRAINT
+PK_o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU_id   PK_F41873285F3BD831F63C6041B4356A063403406D     CONSTRAINT
+REL_CD_classifiers_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU      REL_CD_B614AAA814176BC7128CE9D72C0950C4D6DE8052 COLUMN
+REL_CD_classifiers_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY   REL_CD_68C234330FD6388836D0DAF9DFD0A40DE66DD8C5 COLUMN
+REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE     REL_CD_classifiers_ANTENNAMODULE_INSTALLED_AT_SITE      COLUMN
+REL_CD_classifiers_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN      REL_CD_7E9F11EFBF8974D7C7DAB02E181A0BE4148091C6 COLUMN
+REL_CD_classifiers_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU    REL_CD_E388983F3E6BFAD67CA100F0AFCF8CD3E9B89ADD COLUMN
+REL_CD_decorators_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU       REL_CD_0AC0D382E4274681870EC7319460192F4F603001 COLUMN
+REL_CD_decorators_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY    REL_CD_A14923FFF9D13FEB18087CE2A9C0BD264C572CFC COLUMN
+REL_CD_decorators_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN       REL_CD_FFF7E036187A7605BFC714483D2E60FD2FF6560B COLUMN
+REL_CD_decorators_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU     REL_CD_EF3979E9DAF31B7949C883654633E633B9D35B92 COLUMN
+REL_CD_sourceIds_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU        REL_CD_32FFD9EF85AB2342E652FA493C3BF34D9BAAF054 COLUMN
+REL_CD_sourceIds_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY     REL_CD_8D8BBB53FB18E8E9A5D241B66DA18CB5DDE9C1A5 COLUMN
+REL_CD_sourceIds_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN        REL_CD_45E8E8693B1B8928376EAA8995D08AA7B1E483BD COLUMN
+REL_CD_sourceIds_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU      REL_CD_1F61FA6DDAECE90540F9880F2A98037B1530A5A4 COLUMN
+REL_CD_classifiers_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT REL_CD_classifiers_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT  COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF     REL_CD_classifiers_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF      COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION    REL_CD_classifiers_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION     COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION        REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION        REL_CD_classifiers_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION  REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION   COLUMN
+REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ORUFUNCTION  REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ORUFUNCTION   COLUMN
+REL_CD_classifiers_NFDEPLOYMENT_SERVES_MANAGEDELEMENT  REL_CD_classifiers_NFDEPLOYMENT_SERVES_MANAGEDELEMENT   COLUMN
+REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER       REL_CD_classifiers_NRCELLDU_USES_NRSECTORCARRIER        COLUMN
+REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY      REL_CD_classifiers_NRSECTORCARRIER_USES_ANTENNACAPABILITY       COLUMN
+REL_CD_classifiers_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER     REL_CD_classifiers_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER      COLUMN
+REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU     REL_CD_classifiers_OCUCPFUNCTION_PROVIDES_NRCELLCU      COLUMN
+REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU       REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRCELLDU        COLUMN
+REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER        REL_CD_classifiers_ODUFUNCTION_PROVIDES_NRSECTORCARRIER COLUMN
+REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE REL_CD_classifiers_SECTOR_GROUPS_ANTENNAMODULE  COLUMN
+REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU      REL_CD_classifiers_SECTOR_GROUPS_NRCELLDU       COLUMN
+REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE      REL_CD_decorators_ANTENNAMODULE_INSTALLED_AT_SITE       COLUMN
+REL_CD_decorators_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT  REL_CD_decorators_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT   COLUMN
+REL_CD_decorators_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF      REL_CD_decorators_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF       COLUMN
+REL_CD_decorators_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION     REL_CD_decorators_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION      COLUMN
+REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION  COLUMN
+REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION REL_CD_decorators_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION  COLUMN
+REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION   REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION    COLUMN
+REL_CD_decorators_MANAGEDELEMENT_MANAGES_ORUFUNCTION   REL_CD_decorators_MANAGEDELEMENT_MANAGES_ORUFUNCTION    COLUMN
+REL_CD_decorators_NFDEPLOYMENT_SERVES_MANAGEDELEMENT   REL_CD_decorators_NFDEPLOYMENT_SERVES_MANAGEDELEMENT    COLUMN
+REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER        REL_CD_decorators_NRCELLDU_USES_NRSECTORCARRIER COLUMN
+REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY       REL_CD_decorators_NRSECTORCARRIER_USES_ANTENNACAPABILITY        COLUMN
+REL_CD_decorators_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER      REL_CD_decorators_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER       COLUMN
+REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU      REL_CD_decorators_OCUCPFUNCTION_PROVIDES_NRCELLCU       COLUMN
+REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU        REL_CD_decorators_ODUFUNCTION_PROVIDES_NRCELLDU COLUMN
+REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER REL_CD_decorators_ODUFUNCTION_PROVIDES_NRSECTORCARRIER  COLUMN
+REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE  REL_CD_decorators_SECTOR_GROUPS_ANTENNAMODULE   COLUMN
+REL_CD_decorators_SECTOR_GROUPS_NRCELLDU       REL_CD_decorators_SECTOR_GROUPS_NRCELLDU        COLUMN
+REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE       REL_CD_sourceIds_ANTENNAMODULE_INSTALLED_AT_SITE        COLUMN
+REL_CD_sourceIds_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT   REL_CD_sourceIds_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT    COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF       REL_CD_sourceIds_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF        COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION      REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION       COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION  REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION   COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION  REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION   COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION    REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION     COLUMN
+REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ORUFUNCTION    REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ORUFUNCTION     COLUMN
+REL_CD_sourceIds_NFDEPLOYMENT_SERVES_MANAGEDELEMENT    REL_CD_sourceIds_NFDEPLOYMENT_SERVES_MANAGEDELEMENT     COLUMN
+REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER REL_CD_sourceIds_NRCELLDU_USES_NRSECTORCARRIER  COLUMN
+REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY        REL_CD_sourceIds_NRSECTORCARRIER_USES_ANTENNACAPABILITY COLUMN
+REL_CD_sourceIds_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER       REL_CD_sourceIds_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER        COLUMN
+REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU       REL_CD_sourceIds_OCUCPFUNCTION_PROVIDES_NRCELLCU        COLUMN
+REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRCELLDU  COLUMN
+REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER  REL_CD_sourceIds_ODUFUNCTION_PROVIDES_NRSECTORCARRIER   COLUMN
+REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE   REL_CD_sourceIds_SECTOR_GROUPS_ANTENNAMODULE    COLUMN
+REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU        REL_CD_sourceIds_SECTOR_GROUPS_NRCELLDU COLUMN
+REL_FK_used-nrCellDu   REL_FK_used-nrCellDu    COLUMN
+REL_FK_comprised-by-cloudifiedNF       REL_FK_comprised-by-cloudifiedNF        COLUMN
+REL_FK_deployed-as-cloudifiedNF        REL_FK_deployed-as-cloudifiedNF COLUMN
+REL_FK_deployed-on-nodeCluster REL_FK_deployed-on-nodeCluster  COLUMN
+REL_FK_grouped-by-sector       REL_FK_grouped-by-sector        COLUMN
+REL_FK_installed-at-site       REL_FK_installed-at-site        COLUMN
+REL_FK_managed-by-managedElement       REL_FK_managed-by-managedElement        COLUMN
+REL_FK_provided-by-ocucpFunction       REL_FK_provided-by-ocucpFunction        COLUMN
+REL_FK_provided-by-oduFunction REL_FK_provided-by-oduFunction  COLUMN
+REL_FK_serviced-managedElement REL_FK_serviced-managedElement  COLUMN
+REL_FK_used-antennaCapability  REL_FK_used-antennaCapability   COLUMN
+REL_FK_used-by-nrCellDu        REL_FK_used-by-nrCellDu COLUMN
+REL_ID_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU  REL_ID_7899092EC8FBC674398C53965ADEFF940D17481F COLUMN
+REL_ID_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY       REL_ID_1C61FC18067350DB393AFDB5270E9DE1F5151C64 COLUMN
+REL_ID_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN  REL_ID_BDE0B6C74D14AC109D29A08D80E92D4D0DCAEB0B COLUMN
+REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU        REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU COLUMN
+REL_ID_ANTENNAMODULE_INSTALLED_AT_SITE REL_ID_ANTENNAMODULE_INSTALLED_AT_SITE  COLUMN
+REL_ID_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT     REL_ID_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT      COLUMN
+REL_ID_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF REL_ID_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF  COLUMN
+REL_ID_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION        REL_ID_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION COLUMN
+REL_ID_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION    REL_ID_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION     COLUMN
+REL_ID_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION    REL_ID_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION     COLUMN
+REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION      REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION       COLUMN
+REL_ID_MANAGEDELEMENT_MANAGES_ORUFUNCTION      REL_ID_MANAGEDELEMENT_MANAGES_ORUFUNCTION       COLUMN
+REL_ID_NFDEPLOYMENT_SERVES_MANAGEDELEMENT      REL_ID_NFDEPLOYMENT_SERVES_MANAGEDELEMENT       COLUMN
+REL_ID_NRCELLDU_USES_NRSECTORCARRIER   REL_ID_NRCELLDU_USES_NRSECTORCARRIER    COLUMN
+REL_ID_NRSECTORCARRIER_USES_ANTENNACAPABILITY  REL_ID_NRSECTORCARRIER_USES_ANTENNACAPABILITY   COLUMN
+REL_ID_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER REL_ID_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER  COLUMN
+REL_ID_OCUCPFUNCTION_PROVIDES_NRCELLCU REL_ID_OCUCPFUNCTION_PROVIDES_NRCELLCU  COLUMN
+REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU   REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU    COLUMN
+REL_ID_ODUFUNCTION_PROVIDES_NRSECTORCARRIER    REL_ID_ODUFUNCTION_PROVIDES_NRSECTORCARRIER     COLUMN
+REL_ID_SECTOR_GROUPS_ANTENNAMODULE     REL_ID_SECTOR_GROUPS_ANTENNAMODULE      COLUMN
+REL_ID_SECTOR_GROUPS_NRCELLDU  REL_ID_SECTOR_GROUPS_NRCELLDU   COLUMN
+REL_metadata_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU    REL_metadata_8B4FA813345B7F25ACF2E9635EAF6E6DE0FBBE8A   COLUMN
+REL_metadata_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY REL_metadata_F723867781098568079DD82E5D5E529374F97E98   COLUMN
+REL_metadata_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN    REL_metadata_72494257260B57223C09828D7C3B31D203B050B4   COLUMN
+REL_metadata_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU  REL_metadata_C9E09FBCCBA1F6A3252B71B869B269EF28AACDFB   COLUMN
+REL_metadata_ANTENNAMODULE_INSTALLED_AT_SITE   REL_metadata_ANTENNAMODULE_INSTALLED_AT_SITE    COLUMN
+REL_metadata_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT       REL_metadata_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT        COLUMN
+REL_metadata_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF   REL_metadata_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF    COLUMN
+REL_metadata_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION  REL_metadata_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION   COLUMN
+REL_metadata_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION      REL_metadata_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION       COLUMN
+REL_metadata_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION      REL_metadata_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION       COLUMN
+REL_metadata_MANAGEDELEMENT_MANAGES_ODUFUNCTION        REL_metadata_MANAGEDELEMENT_MANAGES_ODUFUNCTION COLUMN
+REL_metadata_MANAGEDELEMENT_MANAGES_ORUFUNCTION        REL_metadata_MANAGEDELEMENT_MANAGES_ORUFUNCTION COLUMN
+REL_metadata_NFDEPLOYMENT_SERVES_MANAGEDELEMENT        REL_metadata_NFDEPLOYMENT_SERVES_MANAGEDELEMENT COLUMN
+REL_metadata_NRCELLDU_USES_NRSECTORCARRIER     REL_metadata_NRCELLDU_USES_NRSECTORCARRIER      COLUMN
+REL_metadata_NRSECTORCARRIER_USES_ANTENNACAPABILITY    REL_metadata_NRSECTORCARRIER_USES_ANTENNACAPABILITY     COLUMN
+REL_metadata_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER   REL_metadata_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER    COLUMN
+REL_metadata_OCUCPFUNCTION_PROVIDES_NRCELLCU   REL_metadata_OCUCPFUNCTION_PROVIDES_NRCELLCU    COLUMN
+REL_metadata_ODUFUNCTION_PROVIDES_NRCELLDU     REL_metadata_ODUFUNCTION_PROVIDES_NRCELLDU      COLUMN
+REL_metadata_ODUFUNCTION_PROVIDES_NRSECTORCARRIER      REL_metadata_ODUFUNCTION_PROVIDES_NRSECTORCARRIER       COLUMN
+REL_metadata_SECTOR_GROUPS_ANTENNAMODULE       REL_metadata_SECTOR_GROUPS_ANTENNAMODULE        COLUMN
+REL_metadata_SECTOR_GROUPS_NRCELLDU    REL_metadata_SECTOR_GROUPS_NRCELLDU     COLUMN
+UNIQUE_o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt_REL_ID_ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU        UNIQUE_C40364D44BC6DFCB468EEE1A8FB42BDB71D94114 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn_REL_ID_MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN    UNIQUE_EFB77EDE9661E3C6826E575AB125FD4F8FCD3BE1 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr_REL_ID_LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY UNIQUE_523F8C2098EA2DE66650F9CCA7713124C14D63DF CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU_REL_ID_ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU  UNIQUE_6C7164EC5E639D7E0D833D3C4E0CAB85062EE418 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-cloud_NFDeployment_REL_ID_CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT    UNIQUE_A5A8418B6BE911F281E6E2AA640D7D9F777471DC CONSTRAINT
+UNIQUE_o-ran-smo-teiv-cloud_NFDeployment_REL_ID_NFDEPLOYMENT_SERVES_MANAGEDELEMENT     UNIQUE_8AD46969905BEEB89F63D3F37FD82B14F34FDCBC CONSTRAINT
+UNIQUE_o-ran-smo-teiv-cloud_OCloudNamespace_REL_ID_OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER     UNIQUE_C4DE73BD7AA3DBFA2D32E577D4E0A534A7184AB0 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-equipment_AntennaModule_REL_ID_ANTENNAMODULE_INSTALLED_AT_SITE   UNIQUE_9DF414C2F0CD7FA8BFCB3E9BF851784AC4BC49B1 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-equipment_AntennaModule_REL_ID_SECTOR_GROUPS_ANTENNAMODULE       UNIQUE_78B1D3DCD903AFFB1965D440D87B2D194CA028A0 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-oam_ManagedElement_REL_ID_MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF        UNIQUE_EC9B35192A31C6491E6566602720D1C26E3CB708 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRCellCU_REL_ID_OCUCPFUNCTION_PROVIDES_NRCELLCU      UNIQUE_928074AEE57C9CB151F93FDC81BC59200D5F7497 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRCellDU_REL_ID_ODUFUNCTION_PROVIDES_NRCELLDU        UNIQUE_B70F668E0E45FFFC5B7014489F6FD528EB15F192 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRCellDU_REL_ID_SECTOR_GROUPS_NRCELLDU       UNIQUE_AC1C114ABED77D6DEC3F3AE3F9EBE8231924AEF4 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRSectorCarrier_REL_ID_NRCELLDU_USES_NRSECTORCARRIER UNIQUE_1AB577E5AC207ED4C99A9A96BA1C9C35544AFD25 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRSectorCarrier_REL_ID_NRSECTORCARRIER_USES_ANTENNACAPABILITY        UNIQUE_A799EC9DA6624651081E1DA21B5F0C2D38F6A192 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NRSectorCarrier_REL_ID_ODUFUNCTION_PROVIDES_NRSECTORCARRIER  UNIQUE_D5D35955594A6EB48640425529F7DE44BED00B62 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_NearRTRICFunction_REL_ID_MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION    UNIQUE_E020461673334EB824643649B6B31670FB064EC8 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_OCUCPFunction_REL_ID_MANAGEDELEMENT_MANAGES_OCUCPFUNCTION    UNIQUE_2B7D3D49C1072E660047DE56843413CE628BF94A CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_OCUUPFunction_REL_ID_MANAGEDELEMENT_MANAGES_OCUUPFUNCTION    UNIQUE_DF85FE7809B5527CB4A6028DD1A599DBBD5AF214 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_ODUFunction_REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION        UNIQUE_D570291C9E28A2AF73387B7A8B0F4C70130EEDB4 CONSTRAINT
+UNIQUE_o-ran-smo-teiv-ran_ORUFunction_REL_ID_MANAGEDELEMENT_MANAGES_ORUFUNCTION        UNIQUE_4E6F008B82605A806EED04B2315A1FEE095A9241 CONSTRAINT
+aSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee aSide_2A2D3374BF907674FA1905478E30ACB8882DC03C  COLUMN
+aSide_AntennaModule    aSide_AntennaModule     COLUMN
+bSide_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy       bSide_E8A97B8133D74D3BE65119E868FAC0BE63C09FFC  COLUMN
+bSide_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee bSide_EE6DD4A2CFD743779BBCBFC18FC296EF6D72EB1E  COLUMN
+cellLocalIdddddddddddddddddddddddddddddddddddddddddddddddddddddd       020335B0F627C169E24167748C38FE756FB34AE2        COLUMN
+aSide_NFDeployment     aSide_NFDeployment      COLUMN
+aSide_NodeCluster      aSide_NodeCluster       COLUMN
+antennaBeamWidth       antennaBeamWidth        COLUMN
+antennaModelNumber     antennaModelNumber      COLUMN
+arfcnDL        arfcnDL COLUMN
+arfcnUL        arfcnUL COLUMN
+azimuth        azimuth COLUMN
+bSChannelBwDL  bSChannelBwDL   COLUMN
+bSide_AntennaCapability        bSide_AntennaCapability COLUMN
+bSide_NRCellDU bSide_NRCellDU  COLUMN
+bSide_NearRTRICFunction        bSide_NearRTRICFunction COLUMN
+bSide_OCUCPFunction    bSide_OCUCPFunction     COLUMN
+bSide_OCUUPFunction    bSide_OCUUPFunction     COLUMN
+bSide_OCloudNamespace  bSide_OCloudNamespace   COLUMN
+bSide_OCloudSite       bSide_OCloudSite        COLUMN
+bSide_ODUFunction      bSide_ODUFunction       COLUMN
+cellLocalId    cellLocalId     COLUMN
+dUpLMNId       dUpLMNId        COLUMN
+eUtranFqBands  eUtranFqBands   COLUMN
+electricalAntennaTilt  electricalAntennaTilt   COLUMN
+frequencyDL    frequencyDL     COLUMN
+frequencyUL    frequencyUL     COLUMN
+gNBCUName      gNBCUName       COLUMN
+gNBDUId        gNBDUId COLUMN
+gNBId  gNBId   COLUMN
+gNBIdLength    gNBIdLength     COLUMN
+geo-location   geo-location    COLUMN
+geranFqBands   geranFqBands    COLUMN
+horizontalBeamWidth    horizontalBeamWidth     COLUMN
+id     id      COLUMN
+mechanicalAntennaBearing       mechanicalAntennaBearing        COLUMN
+mechanicalAntennaTilt  mechanicalAntennaTilt   COLUMN
+metadata       metadata        COLUMN
+nCI    nCI     COLUMN
+nRFqBands      nRFqBands       COLUMN
+nRPCI  nRPCI   COLUMN
+nRTAC  nRTAC   COLUMN
+name   name    COLUMN
+nearRtRicId    nearRtRicId     COLUMN
+o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE 09D47DF128202AB535BC2056D7C0952F6EE7AF2D        TABLE
+o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE 98D95275440120DC7A5FEF7E870FB6649F275AEC        TABLE
+o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee 9AB5ED164AE73FC3AB14965C0B1F3E90A04CF974        TABLE
+o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt       C9475FE40C02BEB41F720B4284A856F2CF49E1F3        TABLE
+o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy     AA68071F5A253FC68706DC4244B2EEEDCFA4F477        TABLE
+o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn AD6AA1B5E225BBC96B792246D095340747056399        TABLE
+o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr 8F1E5B0125750A5230DB73DB7816ECCFFC2D918B        TABLE
+o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU       F93C2CA075353668A76B4718E07B741ACCD83641        TABLE
+o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY       E2D2B450D65F1FF241A983CBB43B54C040969908        TABLE
+o-ran-smo-teiv-cloud_CloudifiedNF      o-ran-smo-teiv-cloud_CloudifiedNF       TABLE
+o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE  o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE   TABLE
+o-ran-smo-teiv-cloud_NFDeployment      o-ran-smo-teiv-cloud_NFDeployment       TABLE
+o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE  TABLE
+o-ran-smo-teiv-cloud_NodeCluster       o-ran-smo-teiv-cloud_NodeCluster        TABLE
+o-ran-smo-teiv-cloud_OCloudNamespace   o-ran-smo-teiv-cloud_OCloudNamespace    TABLE
+o-ran-smo-teiv-cloud_OCloudSite        o-ran-smo-teiv-cloud_OCloudSite TABLE
+o-ran-smo-teiv-equipment_AntennaModule o-ran-smo-teiv-equipment_AntennaModule  TABLE
+o-ran-smo-teiv-equipment_Site  o-ran-smo-teiv-equipment_Site   TABLE
+o-ran-smo-teiv-oam_ManagedElement      o-ran-smo-teiv-oam_ManagedElement       TABLE
+o-ran-smo-teiv-ran_AntennaCapability   o-ran-smo-teiv-ran_AntennaCapability    TABLE
+o-ran-smo-teiv-ran_NRCellCU    o-ran-smo-teiv-ran_NRCellCU     TABLE
+o-ran-smo-teiv-ran_NRCellDU    o-ran-smo-teiv-ran_NRCellDU     TABLE
+o-ran-smo-teiv-ran_NRSectorCarrier     o-ran-smo-teiv-ran_NRSectorCarrier      TABLE
+o-ran-smo-teiv-ran_NearRTRICFunction   o-ran-smo-teiv-ran_NearRTRICFunction    TABLE
+o-ran-smo-teiv-ran_OCUCPFunction       o-ran-smo-teiv-ran_OCUCPFunction        TABLE
+o-ran-smo-teiv-ran_OCUUPFunction       o-ran-smo-teiv-ran_OCUUPFunction        TABLE
+o-ran-smo-teiv-ran_ODUFunction o-ran-smo-teiv-ran_ODUFunction  TABLE
+o-ran-smo-teiv-ran_ORUFunction o-ran-smo-teiv-ran_ORUFunction  TABLE
+o-ran-smo-teiv-ran_Sector      o-ran-smo-teiv-ran_Sector       TABLE
+o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION     3C2E2CE7BDF8321BC824B6318B190690F58DBB82        TABLE
+o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION  TABLE
+o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION  TABLE
+o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION   o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION    TABLE
+o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY        CFC235E0404703D1E4454647DF8AAE2C193DB402        TABLE
+o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU  TABLE
+oruId  oruId   COLUMN
+pLMNId pLMNId  COLUMN
+pLMNIdList     pLMNIdList      COLUMN
+plmnId plmnId  COLUMN
+positionWithinSector   positionWithinSector    COLUMN
+sectorId       sectorId        COLUMN
+totalTilt      totalTilt       COLUMN
+verticalBeamWidth      verticalBeamWidth       COLUMN
+\.
+
+COPY teiv_model.module_reference("name", "namespace", "domain", "includedModules", "revision", "content") FROM stdin;
+_3gpp-common-yang-extensions   urn:3gpp:sa5:_3gpp-common-yang-extensions       \N      []      2023-09-18      bW9kdWxlIF8zZ3BwLWNvbW1vbi15YW5nLWV4dGVuc2lvbnMgewogIHlhbmctdmVyc2lvbiAxLjE7CiAgbmFtZXNwYWNlIHVybjozZ3BwOnNhNTpfM2dwcC1jb21tb24teWFuZy1leHRlbnNpb25zIDsKICBwcmVmaXggeWV4dDNncHAgOwoKICBvcmdhbml6YXRpb24gIjNHUFAgU0E1IjsKICBjb250YWN0ICJodHRwczovL3d3dy4zZ3BwLm9yZy9EeW5hUmVwb3J0L1RTRy1XRy0tUzUtLW9mZmljaWFscy5odG0/SXRlbWlkPTQ2NCI7CgogIGRlc2NyaXB0aW9uICJUaGUgbW9kdWxlIGRlZmluZXMgWUFORyBleHRlbnNpb25zIG5lZWRlZCAKICAgIDNHUFAgWUFORyBtb2RlbGluZy4KCiAgICBDb3B5cmlnaHQgKGMpIDIwMTkgM0dQUC4gQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAgICBFeHRlbnNpb25zIE1VU1QgYmUgZGVmaW5lZCB3aXRoIHRoZSBmb2xsb3dpbmcgc3RydWN0dXJlIGluIHRoZQogICAgZGVzY3JpcHRpb24gc3RhdGVtZW50OgogICAgICAgIC0gV2hhdCBpcyB0aGlzIHN0YXRlbWVudC4KICAgICAgICAtIE5ld2xpbmUsCiAgICAgICAgLSBUaGlzIHN0YXRlbWVudCBjYW4gYmUgYSBzdWJzdGF0ZW1lbnQgb2YgdGhlIHh4eCBzdGF0ZW1lbnRzIHdpdGgKICAgICAgICBjYXJkaW5hbGl0eSB4Li55LgogICAgICAgIC0gVGhpcyBzdGF0ZW1lbnQgY2FuIGhhdmUgdGhlIGZvbGxvd2luZyBzdWJzdGF0ZW1lbnRzIHdpdGgKICAgICAgICBjYXJkaW5hbGl0eSB4Li55LgogICAgICAgIC0gTmV3bGluZQogICAgICAgIC0gSXMgY2hhbmdpbmcgdGhpcyBzdGF0ZW1lbnQgYW4gZWRpdG9yaWFsLCBCQyhiYWNrd2FyZHMgY29tcGF0aWJsZSkgCiAgICAgICAgb3IgTkJDKG5vbi1CQykgY2hhbmdlPwogICAgICAgIC0gTmV3bGluZS4KICAgICAgICAtIFRoZSBhcmd1bWVudCBpdHMgbWVhbmluZyBhbmQgdHlwZS4gUHJlZmVyYWJseSB1c2UgWUFORyB0eXBlcyBhbmQKICAgICAgICAgIGNvbnN0cmFpbnRzIHRvIGRlZmluZSB0aGUgYXJndW1lbnQncyB0eXBlLgoKICAgIEFueSBleHRlbnNpb24gc3RhdGVtZW50IGNhbiBiZSBhZGRlZCB3aXRoIGEKICAgIGRldmlhdGlvbi9kZXZpYXRlIGFkZCBzdGF0ZW1lbnQuIEluIHRoaXMgY2FzZSB0aGUgcmVzdHJpY3Rpb24gYWJvdXQKICAgIHRoZSBwYXJlbnQgc3RhdGVtZW50IG9mIHRoZSBleHRlbnNpb24gU0hBTEwgYmUgZXZhbHVhdGVkIGJhc2VkIG9uIHRoZQogICAgdGFyZ2V0IG9mIHRoZSBkZXZpYXRpb24gc3RhdGVtZW50LgoKICAgIFN1cHBvcnQgZm9yIHRoaXMgbW9kdWxlIGRvZXMgbm90IG1lYW4gdGhhdCBhIFlBTkcgc2VydmVyIGltcGxlbWVudHMKICAgIHN1cHBvcnQgZm9yIGVhY2ggb2YgdGhlc2UgZXh0ZW5zaW9ucy4KICAgIEltcGxlbWVudGVycyBvZiBlYWNoIHNwZWNpZmljIG1vZHVsZSB1c2luZyBhbiBleHRlbnNpb25zIE1VU1QgY2hlY2sKICAgIGlmIHRoZSBzZXJ2ZXIgaW1wbGVtZW50cyBzdXBwb3J0IGZvciB0aGUgdXNlZCBleHRlbnNpb24uCiAgICBOb3RlOiBtb2R1bGVzIHVzZSBtYW55IGV4dGVuc2lvbnMgd2hpY2ggaW5kaXZpZHVhbAogICAgaW1wbGVtZW50YXRpb25zIE1BWSBvciBNQVkgTk9UIHN1cHBvcnQuCiAgICBJZiBzdXBwb3J0IGZvciBhbiBleHRlbnNpb24gaXMgbWlzc2luZyB0aGUgZXh0ZW5zaW9uIHN0YXRlbWVudCBuZWVkcwogICAgaW5kaXZpZHVhbCBoYW5kbGluZyBvciBpdCBTSE9VTEQgYmUgcmVtb3ZlZCBmcm9tIHRoZSBtb2R1bGUgdXNpbmcKICAgIHRoZSBleHRlbnNpb24gZS5nLiB3aXRoIGEgZGV2aWF0aW9uLgogICAgQ29weXJpZ2h0IDIwMjMsIDNHUFAgT3JnYW5pemF0aW9uYWwgUGFydG5lcnMgKEFSSUIsIEFUSVMsIENDU0EsIEVUU0ksIFRTRFNJLCAKICAgIFRUQSwgVFRDKS4gQWxsIHJpZ2h0cyByZXNlcnZlZC4iOwogIHJlZmVyZW5jZSAiM0dQUCBUUyAyOC42MjMKICAgICAgR2VuZXJpYyBOZXR3b3JrIFJlc291cmNlIE1vZGVsIChOUk0pCiAgICAgIEludGVncmF0aW9uIFJlZmVyZW5jZSBQb2ludCAoSVJQKTsKICAgICAgU29sdXRpb24gU2V0IChTUykgZGVmaW5pdGlvbnMKICAgICAgM0dQUCBUUyAyOC42MjMiOwoKICByZXZpc2lvbiAyMDIzLTA5LTE4IHsgcmVmZXJlbmNlIENSLTAyNzEgOyB9IAogIHJldmlzaW9uIDIwMjItMTAtMjAgeyByZWZlcmVuY2UgQ1ItMDE5NjsgICB9CiAgcmV2aXNpb24gMjAxOS0wNi0yMyB7IHJlZmVyZW5jZSAiSW5pdGlhbCB2ZXJzaW9uIjsgICB9CgogIGV4dGVuc2lvbiBub3ROb3RpZnlhYmxlIHsKICAgIGRlc2NyaXB0aW9uCiAgICAgICJJbmRpY2F0ZXMgdGhhdCBkYXRhIGNoYW5nZSBub3RpZmljYXRpb25zIHNoYWxsIG5vdCBiZSBzZW50IAogICAgICBmb3IgdGhpcyBhdHRyaWJ1dGUuIElmIHRoZSBleHRlbnNpb24gaXMgbm90IHByZXNlbnQgYW5kIG90aGVyIAogICAgICBjb25kaXRpb25zIGFyZSBmdWxmaWxsZWQgZGF0YSBjaGFuZ2Ugbm90aWZpY2F0aW9uIHNob3VsZCBiZSBzZW50LgogICAgICBJZiBhIGxpc3Qgb3IgY29udGFpbmVyIGFscmVhZHkgaGFzIHRoZSBub3ROb3RpZnlhYmxlIAogICAgICBleHRlbnNpb24sIHRoYXQgaXMgYWxzbyB2YWxpZCBmb3IgYWxsIGNvbnRhaW5lZCBkYXRhIG5vZGVzLgoKICAgICAgVGhlIHN0YXRlbWVudCBNVVNUIG9ubHkgYmUgYSBzdWJzdGF0ZW1lbnQgb2YgYSBsZWFmLCBsZWFmLWxpc3QsIGxpc3QsCiAgICAgIGNvbnRhaW5lciBzdGF0ZW1lbnQgdGhhdCBpcyBjb250YWluZWQgd2l0aGluIHRoZSAnYXR0cmlidXRlcycgCiAgICAgIGNvbnRhaW5lciBvZiBhbiBJT0MgYW5kIHRoYXQgcmVwcmVzZW50cyBhbiBhdHRyaWJ1dGUgb3Igc3ViLXBhcnRzIG9mIAogICAgICBhbiBhdHRyaWJ1dGUgLgogICAgICAKICAgICAgWmVybyBvciBvbmUgbm90Tm90aWZ5YWJsZSBzdGF0ZW1lbnQgaXMgYWxsb3dlZCBwZXIgcGFyZW50IHN0YXRlbWVudC4KICAgICAgTk8gc3Vic3RhdGVtZW50cyBhcmUgYWxsb3dlZC4KICAgICAgICAgICAgCiAgICAgIEFkZGluZyB0aGlzIHN0YXRlbWVudCBpcyBhbiBOQkMgY2hhbmdlLCByZW1vdmluZyBpdCBpcyBCQy4iOwogIH0KCiAgZXh0ZW5zaW9uIGluVmFyaWFudCB7CiAgICBkZXNjcmlwdGlvbgogICAgICAiSW5kaWNhdGVzIHRoYXQgdGhlIHZhbHVlIGZvciB0aGUgZGF0YSBub2RlIGNhbiBvbmx5IGJlIHNldCB3aGVuIHRoZSBsaXN0IAogICAgICBkYXRhIG5vZGUgcmVwcmVzZW50aW5nIHRoZSBjb250YWluaW5nIG9iamVjdChNT0kpIGlzIGNyZWF0ZWQuCiAgICAgIFRoZSBhYm92ZSBzdGF0ZW1lbnQgaW4gWUFORyB0ZXJtcyBtZWFucywgdGhhdCB0aGUgdmFsdWUgZm9yIHRoZSBkYXRhIAogICAgICBub2RlIGNhbiBvbmx5IGJlIHNldCB3aGVuIHRoZSBsaXN0IGVudHJ5IHRoYXQgaXMgdGhlIHBhcmVudCBvZiB0aGUgCiAgICAgIHJlc3RyaWN0ZWQgbm9kZSdzIGFuY2VzdG9yIGNvbnRhaW5lciBuYW1lZCAnYXR0cmlidXRlcycgaXMgYmVpbmcgY3JlYXRlZC4gCiAgICAgIFRvIGNoYW5nZSB0aGUgdmFsdWUgYWZ0ZXIgdGhhdCwgdGhlIG1lbnRpb25lZCAKICAgICAgbGlzdCBkYXRhIG5vZGUgbXVzdCBiZSBkZWxldGVkIGFuZCByZWNyZWF0ZWQgd2l0aCB0aGUgcmVzdHJpY3RlZCBkYXRhIG5vZGUKICAgICAgaGF2aW5nIHRoZSBuZXcgdmFsdWUuCgogICAgICBJZiBhIGxpc3Qgb3IgY29udGFpbmVyIGFscmVhZHkgaGFzIHRoZSBpblZhcmlhbnQgCiAgICAgIGV4dGVuc2lvbiwgdGhhdCBpcyBhbHNvIHZhbGlkIGZvciBhbGwgY29udGFpbmVkIGRhdGEgbm9kZXMuCgogICAgICBJdCBpcyB1bm5lY2Vzc2FyeSB0byB1c2UgYW5kIE1VU1QgTk9UIGJlIHVzZWQgZm9yIGtleSBsZWFmcy4KCiAgICAgIFRoZSBzdGF0ZW1lbnQgTVVTVCBvbmx5IGJlIGEgc3Vic3RhdGVtZW50IG9mIGEgbGVhZiwgbGVhZi1saXN0LCBsaXN0IAogICAgICBzdGF0ZW1lbnQgdGhhdCBpcyBjb25maWc9dHJ1ZS4KICAgICAgWmVybyBvciBvbmUgaW5WYXJpYW50IHN0YXRlbWVudCBpcyBhbGxvd2VkIHBlciBwYXJlbnQgc3RhdGVtZW50LgogICAgICBOTyBzdWJzdGF0ZW1lbnRzIGFyZSBhbGxvd2VkLgogICAgICAgICAgICAKICAgICAgQWRkaW5nIHRoaXMgc3RhdGVtZW50IGlzIGFuIE5CQyBjaGFuZ2UsIHJlbW92aW5nIGl0IGlzIEJDLiI7CiAgfQoKICBleHRlbnNpb24gaW5pdGlhbC12YWx1ZSB7CiAgICBkZXNjcmlwdGlvbiAiU3BlY2lmaWVzIGEgdmFsdWUgdGhhdCB0aGUgc3lzdGVtIHdpbGwgc2V0IGZvciBhIGxlYWYKICAgICAgbGVhZi1saXN0IGlmIGEgdmFsdWUgaXMgbm90IHNwZWNpZmllZCBmb3IgaXQgd2hlbiBpdHMgcGFyZW50IGxpc3QKICAgICAgb3IgY29udGFpbmVyIGlzIGNyZWF0ZWQuIFRoZSB2YWx1ZSBoYXMgbm8gZWZmZWN0IGluIGFueSBvdGhlcgogICAgICBtb2RpZmljYXRpb24gZS5nLiBjaGFuZ2luZyBvciByZW1vdmluZyB0aGUgdmFsdWUuCgogICAgICBUaGUgZGVzY3JpcHRpb24gc3RhdGVtZW50IG9mIHRoZSBwYXJlbnQgc3RhdGVtZW50IFNIT1VMRCBjb250YWluCiAgICAgIHRoZSBsYWJlbCAnSW5pdGlhbC12YWx1ZTogJyBmb2xsb3dlZCBieSB0aGUgdGV4dCBmcm9tIHRoZSBhcmd1bWVudC4KCiAgICAgIFRoZSBzdGF0ZW1lbnQgTVVTVCBvbmx5IGJlIGEgc3Vic3RhdGVtZW50IG9mIGEgbGVhZiBvciBsZWFmLWxpc3QuCiAgICAgIFRoZSBzdGF0ZW1lbnQgTVVTVCBOT1QgYmUgcHJlc2VudCBpZiB0aGUgbGVhZiBvciB0aGUgbGVhZi1saXN0IAogICAgICBoYXMgYSBkZWZhdWx0IHN0YXRlbWVudCBvciB0aGUgdHlwZSB1c2VkIGZvciB0aGUgZGF0YSBub2RlIAogICAgICBoYXMgYSBkZWZhdWx0IHZhbHVlLgogICAgICBUaGUgc3RhdGVtZW50IE1VU1QgTk9UIGJlIHVzZWQgZm9yIGNvbmZpZz1mYWxzZSBkYXRhIG9yIGluIGFuIAogICAgICBhY3Rpb24sIHJwYyBvciBub3RpZmljYXRpb24uCiAgICAgIFplcm8gb3Igb25lIGluaXRpYWwtdmFsdWUgc3RhdGVtZW50cyBhcmUgYWxsb3dlZCBmb3IgYSBsZWFmIHBhcmVudAogICAgICBzdGF0ZW1lbnQuIFplcm8gb3IgbW9yZSBpbml0aWFsLXZhbHVlIHN0YXRlbWVudHMgYXJlIGFsbG93ZWQgZm9yIGEKICAgICAgbGVhZi1saXN0IHBhcmVudCBzdGF0ZW1lbnQuIElmIHRoZSBsZWFmLWxpc3QgaXMgb3JkZXJlZC1ieSB1c2VyLCB0aGUKICAgICAgaW5pdGlhbCB2YWx1ZXMgYXJlIHN0b3JlZCBpbiB0aGUgb3JkZXIgdGhleSBhcHBlYXIgaW4gdGhlIFlBTkcgZGVmaW5pdGlvbi4KICAgICAgTk8gc3Vic3RhdGVtZW50cyBhcmUgYWxsb3dlZC4KCiAgICAgIEFsd2F5cyBjb25zaWRlciB1c2luZyBhIFlBTkctZGVmYXVsdCBzdGF0ZW1lbnQgaW5zdGVhZC4KCiAgICAgIE1vZGlmaWNhdGlvbiBvZiB0aGUgaW5pdGlhbC12YWx1ZSBpcyBhIG5vbi1iYWNrd2FyZHMtY29tcGF0aWJsZSBjaGFuZ2UuCgogICAgICBUaGUgYXJndW1lbnQgc3BlY2lmaWVzIGEgc2luZ2xlIGluaXRpYWwgdmFsdWUgZm9yIGEgbGVhZiBvciBsZWFmLWxpc3QuCiAgICAgIFRoZSB2YWx1ZSBNVVNUIGJlIHBhcnQgb2YgdGhlIHZhbHVlc3BhY2Ugb2YgdGhlIGxlYWYvbGVhZi1saXN0LgogICAgICBJdCBmb2xsb3dzIHRoZSBzYW1lIHJ1bGVzIGFzIHRoZSBhcmd1bWVudCBvZiB0aGUgZGVmYXVsdCBzdGF0ZW1lbnQuIjsKCiAgICBhcmd1bWVudCAiaW5pdGlhbC12YWx1ZSI7CiAgfQp9
+_3gpp-common-yang-types        urn:3gpp:sa5:_3gpp-common-yang-types    \N      []      2023-11-06      module _3gpp-common-yang-types {
  yang-version 1.1;
  namespace "urn:3gpp:sa5:_3gpp-common-yang-types";
  prefix "types3gpp";
  
  import ietf-inet-types { prefix inet; }
  import ietf-yang-types { prefix yang; }
  import _3gpp-common-yang-extensions { prefix yext3gpp; }

  organization "3GPP SA5";
  contact "https://www.3gpp.org/DynaReport/TSG-WG--S5--officials.htm?Itemid=464";
  description "The model defines a YANG mapping of the top level 
    information classes used for management of 5G networks and 
    network slicing.
    Copyright 2023, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TSDSI, 
    TTA, TTC). All rights reserved.";
  reference "3GPP TS 28.623";

  revision 2023-11-06 { reference CR-0305; }
  revision 2023-09-18 { reference CR-0271 ; } 
  revision 2023-08-09 { reference CR-0266; }
  revision 2023-05-10 { reference CR-0250; }
  revision 2023-02-14 { reference CR-0234; }
  revision 2022-11-04 { reference "CR-0194"; }
  revision 2022-10-24 { reference CR-0196;  }
  revision 2022-07-26 { reference "CR-0180" ; }
  revision 2022-02-09 { reference "CR-0144"; }
  revision 2021-11-01 { reference "CR-0141"; }
  
  revision 2021-09-30 {
    description "Added Longitude, Latitude, TenthOfDegrees, OnOff.";
    reference "CR-0138";
  }

  revision 2020-11-06 {
    description "Removed incorrect S-NSSAI definitions.";
    reference "CR-0118";
  }

  revision 2020-03-10 {
    description "Removed faulty when statements.";
    reference "SP-200229";
  }
 
  revision 2019-10-25 {
    description "Added ManagedNFProfile.";
    reference "S5-194457";
  }

  revision 2019-10-16 {
    description "Added SAP and usageState.";
    reference "S5-193518";
  }

  revision 2019-06-23 {
    reference  "Initial version.";
  }

  typedef EnabledDisabled {
    type enumeration {
      enum DISABLED ;
      enum ENABLED ;
    }
  }
  
  grouping nameValuePair {
    leaf name { type string; }
    leaf value { type string; }
  }
  
  grouping ProcessMonitorGrp {
    description "Provides attributes to monitor the progress of processes 
      with specific purpose and limited lifetime running on MnS producers. 
      It may be used as data type for dedicated progress monitor attributes 
      when specifying the management representation of these processes. 
      The attributes in this clause are defined in a generic way. 
      For some attributes specialisations may be provided when specifying a 
      concrete process representation.

      If a management operation on some IOCs triggers an associated 
      asynchronous process (whose progress shall be monitored), this should 
      also result in creating an attribute named 'processMonitor' (of type 
      'ProcessMonitor') in these IOC(s). The processMonitor attribute may be 
      accompanied by use-case specific additional data items.

      The progress of the process is described by the 'status' and 
      'progressPercentage' attributes. Additional textual qualifications for 
      the 'status' attribute may be provided by the 'progressStateInfo' and 
      'resultStateInfo' attributes.

      When the process is instantiated, the 'status' is set to 'NOT_RUNNING' 
      and the 'progressPercentage' to '0'. The MnS producer decides when to 
      start executing the process and to transition into the 'RUNNING' state. 
      This time is captured in the 'startTime' attribute. Alternatively, the 
      process may start to execute directly upon its instantiation. One 
      alternative must be selected when using this data type.

      During the 'RUNNING' state the 'progressPercentage' attribute may be 
      repeatedly updated. The exact semantic of this attribute is subject to 
      further specialisation. The 'progressInfo' attribute may be used to 
      provide additional textual information in the 'NOT_RUNNING', 'CANCELLING' 
      and 'RUNNING' states. Further specialisation of 
      'progressStateInfo' may be provided where this data type is 
      used.

      Upon successful completion of the process, the 'status' attribute is set 
      to 'FINISHED', the 'progressPercentage' to 100%. The time is captured in 
      the 'endTime' attribute. Additional textual information may be provided 
      in the 'resultStateInfo' attribute. The type of 
      'resultStateInfo' in this data type definition is 'String'. 
      Further specialisation of 'resultStateInfo' may be provided 
      where this data type is used.

      In case the process fails to complete successfully, the 'status' 
      attribute is set to 'FAILED' or 'PARTIALLY_FAILED', the current value of 
      'progressPercentage' is frozen, and the time captured in 'endTime'. The 
      'resultStateInfo' specifies the reason for the failure. 
      Specific failure reasons may be specified where the data type defined in 
      this clause is used. The exact semantic of failure may be subject for 
      further specialisation as well.

      In case the process is cancelled, the 'status' attribute is first set to 
      'CANCELLING' and when the process is really cancelled then to 'CANCELLED'. 
      The transition to 'CANCELLED' is captured in the 'endTime' attribute. 
      The value of 'progressPercentage' is frozen. Additional textual 
      information may be provided in the 'resultStateInfo' attribute.

      The 'resultStateInfo' attribute is provided only for additional textual 
      qualification of the states 'FINISHED', 'FAILED', 'PARTIALLY_FAILED' or 
      'CANCELLED'. It shall not be used for making the outcome, that the 
      process may produce in case of success, available.

      The process may have to be completed within a certain time after its 
      creation, for example because required data may not be available any 
      more after a certain time, or the process outcome is needed until a 
      certain time and when not provided by this time is not needed any more. 
      The time until the MnS producer automatically cancels the process is 
      indicated by the 'timer' attribute.";
      
    leaf id {
      type string;
      mandatory true;
      description "Id of the process. It is unique within a single 
        multivalue attribute of type ProcessMonitor.";
    }
    
    leaf status { 
      type enumeration {
        enum NOT_STARTED ;
        enum RUNNING ;
        enum CANCELLING ;
        enum FINISHED ;
        enum FAILED ;
        enum PARTIALLY_FAILED ;
        enum CANCELLED ;
      }
      config false;
      default  RUNNING;
      description "Represents the status of the associated process, 
        whether it fails, succeeds etc. 
        It does not represent the returned values of a successfully finished 
        process. ";
    }

    leaf progressPercentage {
      type uint8 {
        range 0..100;
      }
      config false;
      description "Progress of the associated process as percentage";
    }

    leaf-list progressStateInfo {
      type string;
      config false;
      description "Additional textual qualification of the states 
        'NOT_STARTED', 'CANCELLING' and 'RUNNING'.

        For specific processes, specific well-defined strings (e.g. string 
        patterns or enums) may be defined as a specialisation.";
    }

    leaf resultStateInfo {
      type string;
      config false;
      description "Additional textual qualification of the states 
        'FINISHED', 'FAILED', 'PARTIALLY_FAILED and 'CANCELLED'. 
        For example, in the 'FAILED' or 'PARTIALLY_FAILED' state this 
        attribute may be used to provide error reasons.

        This attribute shall not be used to make the outcome of the process 
        available for retrieval, if any. For this purpose, dedicated 
        attributes shall be specified when specifying the representation of 
        a specific process.

        For specific processes, specific well-defined strings (e.g. string 
        patterns or enums) may be defined as a specialisation.";
    }

    leaf startTime {
      type yang:date-and-time;
      config false;
      description "Start time of the associated process, i.e. the time when the 
        status changed from 'NOT_STARTED' to 'RUNNING'.";
    }

    leaf endTime {
      type yang:date-and-time;
      config false;
      description "Date and time when status changed to 'SUCCESS', 'CANCELLED', 
        'FAILED' or 'PARTIALLY_FAILED'. 

        If the time is in the future, it is the estimated time 
        the process will end.";
    }

    leaf timer {
      type uint32;
      units minutes;
      description "Time until the associated process is automatically cancelled.
        If set, the system decreases the timer with time. When it reaches zero 
        the cancellation of the associated process is initiated by the 
        MnS_Producer. 
        If not set, there is no time limit for the process.
        
        Once the timer is set, the consumer can not change it anymore. 
        If the consumer has not set the timer the MnS Producer may set it.";
      yext3gpp:notNotifyable;
    }
  }
  
  typedef TenthOfDegrees { 
    type uint16 { 
      range 0..3600; 
    }
    units "0.1 degrees";
    description "A single integral value corresponding to an angle in degrees 
      between 0 and 360 with a resolution of 0.1 degrees.";
  }

  typedef Latitude {
    type decimal64 {
      fraction-digits 4;
      range "-90.0000..+90.0000"; 
    }
    description "Latitude values";
  }

  typedef Longitude {
    type decimal64 {
      fraction-digits 4;
      range "-180.0000..+180.0000"; 
    }
    description "Longitude values";
  }

  typedef Altitude  {
    type decimal64 {
      fraction-digits 6;
    }
    units "meters";
    description
      "Height from a reference 0 value.";  
  }

  grouping GeographicalCoordinates {
    description "This datatype represents the geographical coordinates";
    reference "#GPP TS 28.558 clause 6.3.8";
    
    leaf latitude {
      type Latitude;
      mandatory true; 
    }
      
    leaf longitude {
      type Longitude;
      mandatory true; 
    }
    
    leaf altitude {
      type Altitude;
    }
    
  }

  typedef OnOff {
    type enumeration {
      enum ON;
      enum OFF;
    }
  }
  
  // grouping ManagedNFProfile will be removed as it is 
  //  being moved to _3gpp-5gc-nrm-nfprofile
  grouping ManagedNFProfile {
    description "Defines profile for managed NF";
    reference "3GPP TS 23.501";
    
    leaf idx { type uint32 ; }
    
    leaf nfInstanceID {
      config false;
      mandatory true;
      type yang:uuid ;
      description "This parameter defines profile for managed NF. 
        The format of the NF Instance ID shall be a 
        Universally Unique Identifier (UUID) version 4, 
        as described in IETF RFC 4122 " ;
      yext3gpp:inVariant;
    }
    
    leaf-list nfType {
      config false;
      min-elements 1;
      type NfType;
      description "Type of the Network Function" ;
    }
    
    leaf hostAddr {
      mandatory true;
      type inet:host ;
      description "Host address of a NF";
    }
    
    leaf authzInfo {
      type string ;
      description "This parameter defines NF Specific Service authorization 
        information. It shall include the NF type (s) and NF realms/origins 
        allowed to consume NF Service(s) of NF Service Producer.";
      reference "See TS 23.501" ;
    }
    
    leaf location {
      type string ;
      description "Information about the location of the NF instance 
        (e.g. geographic location, data center) defined by operator";
      reference "TS 29.510" ;
    }
    
    leaf capacity {
      mandatory true;
      type uint16 ;
      description "This parameter defines static capacity information 
        in the range of 0-65535, expressed as a weight relative to other 
        NF instances of the same type; if capacity is also present in the 
        nfServiceList parameters, those will have precedence over this value.";
      reference "TS 29.510" ;
    }
      
    leaf nFSrvGroupId {
      type string ;
      description "This parameter defines identity of the group that is 
        served by the NF instance.
        May be config false or true depending on the ManagedFunction. 
        Config=true for Udrinfo. Config=false for UdmInfo and AusfInfo. 
        Shall be present if ../nfType = UDM or AUSF or UDR. ";
      reference "TS 29.510" ;
    }
    
    leaf-list supportedDataSetIds {
      type enumeration {
        enum SUBSCRIPTION;
        enum POLICY;
        enum EXPOSURE;
        enum APPLICATION;
      }
      description "List of supported data sets in the UDR instance. 
        May be present if ../nfType = UDR";
      reference "TS 29.510" ;
    }
    
    leaf-list smfServingAreas {
      type string ;
      description "Defines the SMF service area(s) the UPF can serve. 
        Shall be present if ../nfType = UPF";
      reference "TS 29.510" ;
    }
    
    leaf priority {
      type uint16;
      description "This parameter defines Priority (relative to other NFs 
        of the same type) in the range of 0-65535, to be used for NF selection; 
        lower values indicate a higher priority. If priority is also present 
        in the nfServiceList parameters, those will have precedence over 
        this value. Shall be present if ../nfType = AMF ";
      reference "TS 29.510" ;
    }
  }
  
  typedef usageState {
    type enumeration {
      enum IDLE;
      enum ACTIVE;
      enum BUSY;
    }
    description "It describes whether or not the resource is actively in 
      use at a specific instant, and if so, whether or not it has spare 
      capacity for additional users at that instant. The value is READ-ONLY.";
    reference "ITU T Recommendation X.731";
  }
  
  grouping SAPGrp {
    leaf host {
      type inet:host;
      mandatory true;
    }
    leaf port {
      type inet:port-number;
      mandatory true;
    }
    description "Service access point.";
    reference "TS 28.622";
  }
  
  typedef Mcc {
    description "The mobile country code consists of three decimal digits, 
      The first digit of the mobile country code identifies the geographic 
      region (the digits 1 and 8 are not used):";
    type string {
      pattern '[02-79][0-9][0-9]';
    }
    reference "3GPP TS 23.003 subclause 2.2 and 12.1";
  }

  typedef Mnc {
    description "The mobile network code consists of two or three 
      decimal digits (for example: MNC of 001 is not the same as MNC of 01)";
    type string {
      pattern '[0-9][0-9][0-9]|[0-9][0-9]';
    }
    reference "3GPP TS 23.003 subclause 2.2 and 12.1";
  }

  grouping PLMNId {
    leaf mcc {
      mandatory true;
      type Mcc;
    }
    leaf mnc {
      mandatory true;
      type Mnc;
    }
    reference "TS 38.413 clause 9.3.3.5";
  }
  
  typedef Nci {
    description "NR Cell Identity. The NCI shall be of fixed length of 36 bits 
      and shall be coded using full hexadecimal representation. 
      The exact coding of the NCI is the responsibility of each PLMN operator";
    reference "TS 23.003";
    type union {
      type string {
        length 36;
        pattern '[01]+';
      }
      type string {
        length 9;
        pattern '[a-fA-F0-9]*';
      }
    }
  }
    
  typedef OperationalState {
    reference "3GPP TS 28.625 and ITU-T X.731";
    type enumeration {
      enum DISABLED {
        value 0;
        description "The resource is totally inoperable.";
      }

      enum ENABLED {
        value 1;
        description "The resource is partially or fully operable.";
      }

    }
  }
  
  typedef BasicAdministrativeState {
    reference "3GPP TS 28.625 and ITU-T X.731";
    type enumeration {
      enum LOCKED {
        value 0;
        description "The resource is administratively prohibited from performing
                 services for its users.";
      }

      enum UNLOCKED {
        value 1;
        description "The resource is administratively permitted to perform
          services for its users. This is independent of its inherent
          operability.";
      }
    }
  }
  
  typedef AdministrativeState {
    reference "3GPP TS 28.625 and ITU-T X.731";
    type enumeration {
      enum LOCKED {
        value 0;
        description "The resource is administratively prohibited from performing
                 services for its users.";
      }

      enum UNLOCKED {
        value 1;
        description "The resource is administratively permitted to perform
          services for its users. This is independent of its inherent
          operability.";
      }

      enum SHUTTINGDOWN {
        value 2;
        description "Use of the resource is administratively permitted to
          existing instances of use only. While the system remains in
          the shutting down state the manager or the managed element 
          may at any time cause the resource to transition to the 
          locked state.";
      }
    }
  }
  
  typedef AvailabilityStatus {
      type enumeration {
          enum IN_TEST;
          enum FAILED;                           
          enum POWER_OFF;                           
          enum OFF_LINE;                           
          enum OFF_DUTY;                           
          enum DEPENDENCY;                           
          enum DEGRADED;                           
          enum NOT_INSTALLED;                           
          enum LOG_FULL;                           
       }
  }
  
  typedef CellState {
      type enumeration {
        enum IDLE;
        enum INACTIVE;              
        enum ACTIVE;              
     }
  }

  typedef Nrpci {
    type uint32;
    description "Physical Cell Identity (PCI) of the NR cell.";
    reference "TS 36.211 subclause 6.11";
  }

  typedef Tac {
    type int32 {
      range 0..16777215 ;
    }
    description "Tracking Area Code";
    reference "TS 23.003 clause 19.4.2.3";
  }

  grouping TaiGrp {
    description "This <<dataType>> defines a Tracking Area Identity (TAI) 
      as specified in clause 28.6 of TS 23.003, clause 8.2 of TS 38.300 
      and clause 9.3.3.11 of TS 38.413. It is composed of the PLMN 
      identifier (PLMN-Id, which is composed of the MCC and MNC) and 
      the Tracking Area Code (TAC). ";
    list plmnId {
      description "PLMN Identity.";
      min-elements 1;
      max-elements 1;
      key "mcc mnc";
      uses types3gpp:PLMNId;
    }
    
    leaf tac { type Tac; }
  }
       
  grouping GeoCoordinateGrp {
    description "Geographical location on earth"; 
    leaf latitude {
      type decimal64 {
        fraction-digits 4;
        range -90..90 ;
      }
      mandatory true;
      description "Latitude based on World Geodetic System (1984 version) 
        global reference frame (WGS 84). Positive values correspond to the 
        northern hemisphere.";
      }
        
    leaf longitude {
      type decimal64 {
        fraction-digits 4;
        range -180..180 ;
      }
      mandatory true;
      description "Longitude based on World Geodetic System (1984 version) 
        global reference frame (WGS 84). Positive values correspond to 
        degrees east of 0 degrees longitude.";
    }
  }
   
  grouping GeoAreaGrp {
    description "This data type defines a geographical area. 
      The geo-area is defined using a convex polygon in the attribute 
      'convexGeoPolygon'.";
    
    list convexGeoPolygon {
      description "Specifies the geographical area with a convex polygon. 
        The convex polygon is specified by its corners.";
        key "latitude longitude";
      min-elements 3;
      ordered-by user;
      
      uses GeoCoordinateGrp;
    }
  }
  
  typedef AmfRegionId {
    type union { 
      type uint8 ;
      type string {
        length 8;
        pattern '[01]*';
      }
    }
    reference "clause 2.10.1 of 3GPP TS 23.003";
  }

  typedef AmfSetId {
    type union { 
      type uint16 {
        range '0..1023';
      }
      type string {
        length 8;
        pattern '[01]*';
      }
    }
    reference "clause 2.10.1 of 3GPP TS 23.003";
  }

  typedef AmfPointer {
    type union { 
      type uint8 {
        range '0..63';
      }
      type string {
        length 6;
        pattern '[01]*';
      }
    }
    reference "clause 2.10.1 of 3GPP TS 23.003";
  }
        
  grouping AmfIdentifier {        
    leaf amfRegionId {
      type AmfRegionId;
    }
    leaf amfSetId {
      type AmfSetId;
    }
    leaf amfPointer {
      type AmfPointer;
    } 
    description "The AMFI is constructed from an AMF Region ID, 
      an AMF Set ID and an AMF Pointer. 
      The AMF Region ID identifies the region, 
      the AMF Set ID uniquely identifies the AMF Set within the AMF Region, and 
      the AMF Pointer uniquely identifies the AMF within the AMF Set. "; 
  }    

// type definitions especially for core NFs

  typedef NfType {
    type enumeration {
      enum NRF;
      enum UDM;
      enum AMF;
      enum SMF;
      enum AUSF;
      enum NEF;
      enum PCF;
      enum SMSF;
      enum NSSF;
      enum UDR;
      enum LMF;
      enum GMLC;
      enum 5G_EIR;
      enum SEPP;
      enum UPF;
      enum N3IWF;
      enum AF;
      enum UDSF;
      enum BSF;
      enum CHF;
    }          
  }
  
  typedef NotificationType {
    type enumeration {
      enum N1_MESSAGES;
      enum N2_INFORMATION;
      enum LOCATION_NOTIFICATION;
    }      
  }
  
  typedef Load {
    description "Latest known load information of the NF, percentage ";
    type uint8 {
      range 0..100;
    }
  }

  typedef N1MessageClass {
    type enumeration {
      enum 5GMM;
      enum SM;
      enum LPP;
      enum SMS; 
    }      
  }
  
  typedef N2InformationClass {
    type enumeration {
      enum SM;
      enum NRPPA;
      enum PWS;
      enum PWS_BCAL;
      enum PWS_RF;
    }              
  }
  
  grouping DefaultNotificationSubscription {
    
    leaf notificationType {
      type NotificationType;
    }
    
    leaf callbackUri {
      type inet:uri;
    }
    
    leaf n1MessageClass {
      type N1MessageClass;
    }
    
    leaf n2InformationClass {
      type N2InformationClass;
    }    
  }  
        
  grouping Ipv4AddressRange {
  leaf start {
    type inet:ipv4-address;
    }
  leaf end {
    type inet:ipv4-address;
    }    
  }
    
  grouping Ipv6PrefixRange {
  leaf start {
    type inet:ipv6-prefix;
    }
  leaf end {
    type inet:ipv6-prefix;
    }    
  }
     
  typedef NsiId {
    type string;
  }
    
  typedef UeMobilityLevel {
    type enumeration {
      enum STATIONARY;
      enum NOMADIC;
      enum RESTRICTED_MOBILITY;
      enum FULLY_MOBILITY;
    }
  }
      
  typedef ResourceSharingLevel {
      type enumeration {
        enum SHARED;
        enum NOT_SHARED;
      }
  }
      
  typedef TxDirection {
      type enumeration {
        enum DL;
        enum UL;
        enum DL_AND_UL;
      }
  }
      
  grouping AddressWithVlan {
    leaf ipAddress {
      type inet:ip-address;   
    }
    leaf vlanId {
       type uint16;
    }  
  }

  /* DistinguishedName pattern is built up based on the 
    EBNF in 32.300 clause 7.3  EBNF of DN String Representation
  
    leaf DN { type string {   //  Same pattern as LocalDN
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?(,[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)*';      
    } }
  
    leaf fullLocalDN { type string {   // LocalRDN , { RDNSeparator , LocalRDN }    RDNSeparator is a single , no space or \R allowed   Me.mykey=1 allowed
      //  (fullLocalRDN)(,(fullLocalRDN))*
      pattern '(([A-Z][^,=+<>#;\\"\r\n*.]*|([A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*))=(([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?))(,(([A-Z][^,=+<>#;\\"\r\n*.]*|([A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*))=(([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)))*';      
    } }
  
    leaf LocalDN { type string {   // LocalRDN , { RDNSeparator , LocalRDN }    RDNSeparator is a single , no space or \R allowed
      //  LocalRDN(,LocalRDN)*
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?(,[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)*';      
    } }
  
    leaf fullLocalRDN { type string {   // same as fullLocalDNAttributeTypeAndValue
      pattern '([A-Z][^,=+<>#;\\"\r\n*.]*|([A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*))=(([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)';      
    } }
  
    leaf LocalRDN { type string {   // same as LocalDNAttributeTypeAndValue
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?';      
    } }
  
    leaf fullLocalDNAttributeTypeAndValue { type string { // LocalDNAttributeType , AttributeTypeAndValueSeparator , RegularAttributeValue 
      // pattern LocalDNAttributeType=RegularAttributeValue
      pattern '([A-Z][^,=+<>#;\\"\r\n*.]*|([A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*))=(([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)';      
    } }
    
      // limitation: NamesOfClassAndNamingAttributenot supported Me.mykey=1
    leaf LocalDNAttributeTypeAndValue { type string { 
      // ebnf1          LocalDNAttributeType , AttributeTypeAndValueSeparator , RegularAttributeValue
      // ebnf2-limited  NameOfClassWithIdAttribute , AttributeTypeAndValueSeparator , RegularAttributeValue
      // pattern        NameOfClassWithIdAttribute=RegularAttributeValue
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?';      
    } }

    leaf LocalDNAttributeType { type string {   // NameOfClassWithIdAttribute | NamesOfClassAndNamingAttribute  RDNSeparator is a single , no space or \R allowed
      //  NameOfClassWithIdAttribute|NamesOfClassAndNamingAttribute
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*|([A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*)';      
    } }

    leaf RegularAttributeValue { type string {       // ( AttributeValueChar - SpaceChar ) , [ { AttributeValueChar } , ( AttributeValueChar - SpaceChar ) ]
      pattern '([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?' ; 
    } }
    
    leaf NamesOfClassAndNamingAttribute  { type string {  // ClassName , ClassNamingAttributeSeparator , NamingAttributeName
      // pattern: ClassName\.NamingAttributeName
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*\.[a-z][^,=+<>#;\\"\r\n*.]*' ; 
    } }
  
    leaf restrictiveClassName { type string {     // 
      pattern '[a-zA-Z][a-zA-Z0-9-_]*' ; 
    } }
  
    leaf ClassName { type string {     // CapitalLetterChar , { LocalDNAttributeTypeChar }
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*' ; 
    } }
  
    leaf NamingAttributeName { type string {   // SmallLetterChar , { LocalDNAttributeTypeChar }
      pattern '[a-z][^,=+<>#;\\"\r\n*.]*' ; 
    } }    
    
  */
  typedef DistinguishedName {    
    type string {
      pattern '[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|'
      + '(\\[a-fA-F0-9]{2}))(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*'
      + '([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?'
      + '(,[A-Z][^,=+<>#;\\"\r\n*.]*=([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2}))'
      + '(([^,=+<>#;\\"\r\n*]|(\\[a-fA-F0-9]{2}))*'
      + '([^,=+<>#;\\"\r\n* ]|(\\[a-fA-F0-9]{2})))?)*';      
    }
    description "Represents the 3GPP standard for DistinguishedName. 
      
      Limitations: 
      - RDNSeparator: don't allow SpaceChar or CarriageReturnChar
      - NullDN: Disallow nullDN that is the same as not providing a DN
      - NamesOfClassAndNamingAttribute format not allowed 
        (eg. ManagedElement.mykey=345436)";
    reference  "3GPP TS 32.300";
  } 
 
  typedef QOffsetRange  {
    type int8 { 
      range "-24 | -22 | -20 | -18 | -16 | -14 | -12 | -10 | -8 | -6 | " +
        " -5 | -4 | -3 | -2 | -1 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 10 | " +
        " 12 | 14 | 16 | 18 | 20 | 22 | 24"; 
    }
    units dB;
  }

  grouping ReportingCtrl {
    choice reportingCtrl {
      mandatory true;
      description "
        This choice defines the method for reporting collected performance
        metrics to MnS consumers as well as the parameters for configuring the
        reporting function. It is a choice between the control parameter
        required for the reporting methods, whose presence selects the
        reporting method as follows:

        - When only the fileReportingPeriod attribute is present, the MnS
        producer shall store files on the MnS producer at a location selected
        by the MnS producer and, on condition that an appropriate subscription
        is in place, inform the MnS consumer about the availability of new
        files and the file location using the notifyFileReady notification.
        In case the preparation of a file fails, 'notifyFilePreparationError'
        shall be sent instead.

        - When the 'fileReportingPeriod' and 'notificationRecipientAddress'
        attributes are present, then the MnS producer shall behave like
        described for the case that only the 'fileReportingPeriod' is present.
        In addition, the MnS producer shall create on behalf of the MnS
        consumer a subscription, using 'NtfSubscriptionControl', for the
        notification types 'notifyMOICreation' and 'notifyMOIDeletion' related
        to the 'File' instances that will be produced later. In case an existing
        subscription does already include the 'File' instances to be produced,
        no new subscription shall be created. The
        'notificationRecipientAddress' attribute in the created
        'NtfSubscriptionControl' instance shall be set to the value of the
        'notificationRecipientAddress' in the related 'PerfMetricJob'. This
        feature is called implicit notification subscription, as opposed to the
        case where the MnS consumer creates the subscription (explicit
        notification subscription). When the related 'PerfMetricJob' is
        deleted, the 'NtfSubscriptionControl' instance created due to the
        request for implicit subscription shall be deleted as well.

        - When only the fileReportingPeriod and fileLocation attributes are
        present, the MnS producer shall store the files on a MnS consumer, that
        can be any entity such as a file server, at the location specified by
        fileLocation. No notification is emitted by the MnS producer.

        - When only the streamTarget attribute is present, the MnS producer
        shall stream the data to the location specified by streamTarget.

        For the file-based reporting methods the fileReportingPeriod attribute
        specifies the time window during which collected measurements are
        stored into the same file before the file is closed and a new file is
        opened.";

      case file-based-reporting {
        leaf fileReportingPeriod {
          type uint32 {
            range 1..max;
          }
          units minutes;
          mandatory true;
          description "For the file-based reporting method this is the time
            window during which collected measurements are stored into the same
            file before the file is closed and a new file is opened.
            The time-period must be a multiple of the granularityPeriod.

            Applicable when the file-based reporting method is supported.";
        }
        choice reporting-target {
          case file-target {
            leaf fileLocation {
            type string ;
            description "Applicable and must be present when the file-based
              reporting method is supported, and the files are stored on the MnS
              consumer.";
            }
          }
          case notification-target {
            leaf notificationRecipientAddress {
            type string;
            description "Must be present when the notification-based reporting
              method is supported, and the the files are available as
              notifications for the MnS consumer to subscribe to.";
            }
          }
        description "When netiher fileLocation or notificationRecipientAddress
          are present, the files are stored and available to the MnS consumer
          if the MnS subscribes to the notifyFileReady notification.";
        }
      }

      case stream-based-reporting {
        leaf streamTarget {
          type string;
          mandatory true;
          description "Applicable when stream-based reporting method is
            supported.";
        }
      }
    }
  }
}
+ietf-geo-location      urn:ietf:params:xml:ns:yang:ietf-geo-location   \N      []      2022-02-11      module ietf-geo-location {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-geo-location";
  prefix geo;
  import ietf-yang-types {
    prefix yang;
    reference "RFC 6991: Common YANG Data Types";
  }

  organization
    "IETF NETMOD Working Group (NETMOD)";
  contact
   "WG Web:   <https://datatracker.ietf.org/wg/netmod/>
    WG List:  <mailto:netmod@ietf.org>

    Editor:   Christian Hopps
              <mailto:chopps@chopps.org>";

  description
    "This module defines a grouping of a container object for
     specifying a location on or around an astronomical object (e.g.,
     'earth').

     The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL
     NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED',
     'MAY', and 'OPTIONAL' in this document are to be interpreted as
     described in BCP 14 (RFC 2119) (RFC 8174) when, and only when,
     they appear in all capitals, as shown here.

     Copyright (c) 2022 IETF Trust and the persons identified as
     authors of the code.  All rights reserved.

     Redistribution and use in source and binary forms,
     with or without modification, is permitted pursuant to,
     and subject to the license terms contained in, the
     Revised BSD License set forth in Section 4.c of the
     IETF Trust's Legal Provisions Relating to IETF Documents
     (https://trustee.ietf.org/license-info).

     This version of this YANG module is part of RFC 9179
     (https://www.rfc-editor.org/info/rfc9179); see the RFC itself
     for full legal notices.";

  revision 2022-02-11 {
    description
      "Initial Revision";
    reference
      "RFC 9179: A YANG Grouping for Geographic Locations";
  }

  feature alternate-systems {
    description
      "This feature means the device supports specifying locations
       using alternate systems for reference frames.";
  }

  grouping geo-location {
    description
      "Grouping to identify a location on an astronomical object.";

    container geo-location {
      description
        "A location on an astronomical body (e.g., 'earth')
         somewhere in a universe.";

      container reference-frame {
        description
          "The Frame of Reference for the location values.";

        leaf alternate-system {
          if-feature "alternate-systems";
          type string;
          description
            "The system in which the astronomical body and
             geodetic-datum is defined.  Normally, this value is not
             present and the system is the natural universe; however,
             when present, this value allows for specifying alternate
             systems (e.g., virtual realities).  An alternate-system
             modifies the definition (but not the type) of the other
             values in the reference frame.";
        }
        leaf astronomical-body {
          type string {
            pattern '[ -@\[-\^_-~]*';
          }
          default "earth";
          description
            "An astronomical body as named by the International
             Astronomical Union (IAU) or according to the alternate
             system if specified.  Examples include 'sun' (our star),
             'earth' (our planet), 'moon' (our moon), 'enceladus' (a
             moon of Saturn), 'ceres' (an asteroid), and
             '67p/churyumov-gerasimenko (a comet).  The ASCII value
             SHOULD have uppercase converted to lowercase and not
             include control characters (i.e., values 32..64, and
             91..126).  Any preceding 'the' in the name SHOULD NOT be
             included.";
          reference
            "https://www.iau.org/";
        }
        container geodetic-system {
          description
            "The geodetic system of the location data.";
          leaf geodetic-datum {
            type string {
              pattern '[ -@\[-\^_-~]*';
            }
            description
              "A geodetic-datum defining the meaning of latitude,
               longitude, and height.  The default when the
               astronomical body is 'earth' is 'wgs-84', which is
               used by the Global Positioning System (GPS).  The
               ASCII value SHOULD have uppercase converted to
               lowercase and not include control characters
               (i.e., values 32..64, and 91..126).  The IANA registry
               further restricts the value by converting all spaces
               (' ') to dashes ('-').
               The specification for the geodetic-datum indicates
               how accurately it models the astronomical body in
               question, both for the 'horizontal'
               latitude/longitude coordinates and for height
               coordinates.";
            reference
              "RFC 9179: A YANG Grouping for Geographic Locations,
               Section 6.1";
          }
          leaf coord-accuracy {
            type decimal64 {
              fraction-digits 6;
            }
            description
              "The accuracy of the latitude/longitude pair for
               ellipsoidal coordinates, or the X, Y, and Z components
               for Cartesian coordinates.  When coord-accuracy is
               specified, it indicates how precisely the coordinates
               in the associated list of locations have been
               determined with respect to the coordinate system
               defined by the geodetic-datum.  For example, there
               might be uncertainty due to measurement error if an
               experimental measurement was made to determine each
               location.";
          }
          leaf height-accuracy {
            type decimal64 {
              fraction-digits 6;
            }
            units "meters";
            description
              "The accuracy of the height value for ellipsoidal
               coordinates; this value is not used with Cartesian
               coordinates.  When height-accuracy is specified, it
               indicates how precisely the heights in the
               associated list of locations have been determined
               with respect to the coordinate system defined by the
               geodetic-datum.  For example, there might be
               uncertainty due to measurement error if an
               experimental measurement was made to determine each
               location.";
          }
        }
      }
      choice location {
        description
          "The location data either in latitude/longitude or
           Cartesian values";
        case ellipsoid {
          leaf latitude {
            type decimal64 {
              fraction-digits 16;
            }
            units "decimal degrees";
            description
              "The latitude value on the astronomical body.  The
               definition and precision of this measurement is
               indicated by the reference-frame.";
          }
          leaf longitude {
            type decimal64 {
              fraction-digits 16;
            }
            units "decimal degrees";
            description
              "The longitude value on the astronomical body.  The
               definition and precision of this measurement is
               indicated by the reference-frame.";
          }
          leaf height {
            type decimal64 {
              fraction-digits 6;
            }
            units "meters";
            description
              "Height from a reference 0 value.  The precision and
               '0' value is defined by the reference-frame.";
          }
        }
        case cartesian {
          leaf x {
            type decimal64 {
              fraction-digits 6;
            }
            units "meters";
            description
              "The X value as defined by the reference-frame.";
          }
          leaf y {
            type decimal64 {
              fraction-digits 6;
            }
            units "meters";
            description
              "The Y value as defined by the reference-frame.";
          }
          leaf z {
            type decimal64 {
              fraction-digits 6;
            }
            units "meters";
            description
              "The Z value as defined by the reference-frame.";
          }
        }
      }
      container velocity {
        description
          "If the object is in motion, the velocity vector describes
           this motion at the time given by the timestamp.  For a
           formula to convert these values to speed and heading, see
           RFC 9179.";
        reference
          "RFC 9179: A YANG Grouping for Geographic Locations";

        leaf v-north {
          type decimal64 {
            fraction-digits 12;
          }
          units "meters per second";
          description
            "v-north is the rate of change (i.e., speed) towards
             true north as defined by the geodetic-system.";
        }

        leaf v-east {
          type decimal64 {
            fraction-digits 12;
          }
          units "meters per second";
          description
            "v-east is the rate of change (i.e., speed) perpendicular
             to the right of true north as defined by
             the geodetic-system.";
        }

        leaf v-up {
          type decimal64 {
            fraction-digits 12;
          }
          units "meters per second";
          description
            "v-up is the rate of change (i.e., speed) away from the
             center of mass.";
        }
      }
      leaf timestamp {
        type yang:date-and-time;
        description
          "Reference time when location was recorded.";
      }
      leaf valid-until {
        type yang:date-and-time;
        description
          "The timestamp for which this geo-location is valid until.
           If unspecified, the geo-location has no specific
           expiration time.";
      }
    }
  }
}

+ietf-inet-types        urn:ietf:params:xml:ns:yang:ietf-inet-types     \N      []      2013-07-15      module ietf-inet-types {

  namespace "urn:ietf:params:xml:ns:yang:ietf-inet-types";
  prefix "inet";

  organization
   "IETF NETMOD (NETCONF Data Modeling Language) Working Group";

  contact
   "WG Web:   <http://tools.ietf.org/wg/netmod/>
    WG List:  <mailto:netmod@ietf.org>

    WG Chair: David Kessens
              <mailto:david.kessens@nsn.com>

    WG Chair: Juergen Schoenwaelder
              <mailto:j.schoenwaelder@jacobs-university.de>

    Editor:   Juergen Schoenwaelder
              <mailto:j.schoenwaelder@jacobs-university.de>";

  description
   "This module contains a collection of generally useful derived
    YANG data types for Internet addresses and related things.

    Copyright (c) 2013 IETF Trust and the persons identified as
    authors of the code.  All rights reserved.

    Redistribution and use in source and binary forms, with or
    without modification, is permitted pursuant to, and subject
    to the license terms contained in, the Simplified BSD License
    set forth in Section 4.c of the IETF Trust's Legal Provisions
    Relating to IETF Documents
    (http://trustee.ietf.org/license-info).

    This version of this YANG module is part of RFC 6991; see
    the RFC itself for full legal notices.";

  revision 2013-07-15 {
    description
     "This revision adds the following new data types:
      - ip-address-no-zone
      - ipv4-address-no-zone
      - ipv6-address-no-zone";
    reference
     "RFC 6991: Common YANG Data Types";
  }

  revision 2010-09-24 {
    description
     "Initial revision.";
    reference
     "RFC 6021: Common YANG Data Types";
  }

  /*** collection of types related to protocol fields ***/

  typedef ip-version {
    type enumeration {
      enum unknown {
        value "0";
        description
         "An unknown or unspecified version of the Internet
          protocol.";
      }
      enum ipv4 {
        value "1";
        description
         "The IPv4 protocol as defined in RFC 791.";
      }
      enum ipv6 {
        value "2";
        description
         "The IPv6 protocol as defined in RFC 2460.";
      }
    }
    description
     "This value represents the version of the IP protocol.

      In the value set and its semantics, this type is equivalent
      to the InetVersion textual convention of the SMIv2.";
    reference
     "RFC  791: Internet Protocol
      RFC 2460: Internet Protocol, Version 6 (IPv6) Specification
      RFC 4001: Textual Conventions for Internet Network Addresses";
  }

  typedef dscp {
    type uint8 {
      range "0..63";
    }
    description
     "The dscp type represents a Differentiated Services Code Point
      that may be used for marking packets in a traffic stream.
      In the value set and its semantics, this type is equivalent
      to the Dscp textual convention of the SMIv2.";
    reference
     "RFC 3289: Management Information Base for the Differentiated
                Services Architecture
      RFC 2474: Definition of the Differentiated Services Field
                (DS Field) in the IPv4 and IPv6 Headers
      RFC 2780: IANA Allocation Guidelines For Values In
                the Internet Protocol and Related Headers";
  }

  typedef ipv6-flow-label {
    type uint32 {
      range "0..1048575";
    }
    description
     "The ipv6-flow-label type represents the flow identifier or Flow
      Label in an IPv6 packet header that may be used to
      discriminate traffic flows.

      In the value set and its semantics, this type is equivalent
      to the IPv6FlowLabel textual convention of the SMIv2.";
    reference
     "RFC 3595: Textual Conventions for IPv6 Flow Label
      RFC 2460: Internet Protocol, Version 6 (IPv6) Specification";
  }

  typedef port-number {
    type uint16 {
      range "0..65535";
    }
    description
     "The port-number type represents a 16-bit port number of an
      Internet transport-layer protocol such as UDP, TCP, DCCP, or
      SCTP.  Port numbers are assigned by IANA.  A current list of
      all assignments is available from <http://www.iana.org/>.

      Note that the port number value zero is reserved by IANA.  In
      situations where the value zero does not make sense, it can
      be excluded by subtyping the port-number type.
      In the value set and its semantics, this type is equivalent
      to the InetPortNumber textual convention of the SMIv2.";
    reference
     "RFC  768: User Datagram Protocol
      RFC  793: Transmission Control Protocol
      RFC 4960: Stream Control Transmission Protocol
      RFC 4340: Datagram Congestion Control Protocol (DCCP)
      RFC 4001: Textual Conventions for Internet Network Addresses";
  }

  /*** collection of types related to autonomous systems ***/

  typedef as-number {
    type uint32;
    description
     "The as-number type represents autonomous system numbers
      which identify an Autonomous System (AS).  An AS is a set
      of routers under a single technical administration, using
      an interior gateway protocol and common metrics to route
      packets within the AS, and using an exterior gateway
      protocol to route packets to other ASes.  IANA maintains
      the AS number space and has delegated large parts to the
      regional registries.

      Autonomous system numbers were originally limited to 16
      bits.  BGP extensions have enlarged the autonomous system
      number space to 32 bits.  This type therefore uses an uint32
      base type without a range restriction in order to support
      a larger autonomous system number space.

      In the value set and its semantics, this type is equivalent
      to the InetAutonomousSystemNumber textual convention of
      the SMIv2.";
    reference
     "RFC 1930: Guidelines for creation, selection, and registration
                of an Autonomous System (AS)
      RFC 4271: A Border Gateway Protocol 4 (BGP-4)
      RFC 4001: Textual Conventions for Internet Network Addresses
      RFC 6793: BGP Support for Four-Octet Autonomous System (AS)
                Number Space";
  }

  /*** collection of types related to IP addresses and hostnames ***/

  typedef ip-address {
    type union {
      type inet:ipv4-address;
      type inet:ipv6-address;
    }
    description
     "The ip-address type represents an IP address and is IP
      version neutral.  The format of the textual representation
      implies the IP version.  This type supports scoped addresses
      by allowing zone identifiers in the address format.";
    reference
     "RFC 4007: IPv6 Scoped Address Architecture";
  }

  typedef ipv4-address {
    type string {
      pattern
        '(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
      +  '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
      + '(%[\p{N}\p{L}]+)?';
    }
    description
      "The ipv4-address type represents an IPv4 address in
       dotted-quad notation.  The IPv4 address may include a zone
       index, separated by a % sign.

       The zone index is used to disambiguate identical address
       values.  For link-local addresses, the zone index will
       typically be the interface index number or the name of an
       interface.  If the zone index is not present, the default
       zone of the device will be used.

       The canonical format for the zone index is the numerical
       format";
  }

  typedef ipv6-address {
    type string {
      pattern '((:|[0-9a-fA-F]{0,4}):)([0-9a-fA-F]{0,4}:){0,5}'
            + '((([0-9a-fA-F]{0,4}:)?(:|[0-9a-fA-F]{0,4}))|'
            + '(((25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])\.){3}'
            + '(25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])))'
            + '(%[\p{N}\p{L}]+)?';
      pattern '(([^:]+:){6}(([^:]+:[^:]+)|(.*\..*)))|'
            + '((([^:]+:)*[^:]+)?::(([^:]+:)*[^:]+)?)'
            + '(%.+)?';
    }
    description
     "The ipv6-address type represents an IPv6 address in full,
      mixed, shortened, and shortened-mixed notation.  The IPv6
      address may include a zone index, separated by a % sign.

      The zone index is used to disambiguate identical address
      values.  For link-local addresses, the zone index will
      typically be the interface index number or the name of an
      interface.  If the zone index is not present, the default
      zone of the device will be used.

      The canonical format of IPv6 addresses uses the textual
      representation defined in Section 4 of RFC 5952.  The
      canonical format for the zone index is the numerical
      format as described in Section 11.2 of RFC 4007.";
    reference
     "RFC 4291: IP Version 6 Addressing Architecture
      RFC 4007: IPv6 Scoped Address Architecture
      RFC 5952: A Recommendation for IPv6 Address Text
                Representation";
  }

  typedef ip-address-no-zone {
    type union {
      type inet:ipv4-address-no-zone;
      type inet:ipv6-address-no-zone;
    }
    description
     "The ip-address-no-zone type represents an IP address and is
      IP version neutral.  The format of the textual representation
      implies the IP version.  This type does not support scoped
      addresses since it does not allow zone identifiers in the
      address format.";
    reference
     "RFC 4007: IPv6 Scoped Address Architecture";
  }

  typedef ipv4-address-no-zone {
    type inet:ipv4-address {
      pattern '[0-9\.]*';
    }
    description
      "An IPv4 address without a zone index.  This type, derived from
       ipv4-address, may be used in situations where the zone is
       known from the context and hence no zone index is needed.";
  }

  typedef ipv6-address-no-zone {
    type inet:ipv6-address {
      pattern '[0-9a-fA-F:\.]*';
    }
    description
      "An IPv6 address without a zone index.  This type, derived from
       ipv6-address, may be used in situations where the zone is
       known from the context and hence no zone index is needed.";
    reference
     "RFC 4291: IP Version 6 Addressing Architecture
      RFC 4007: IPv6 Scoped Address Architecture
      RFC 5952: A Recommendation for IPv6 Address Text
                Representation";
  }

  typedef ip-prefix {
    type union {
      type inet:ipv4-prefix;
      type inet:ipv6-prefix;
    }
    description
     "The ip-prefix type represents an IP prefix and is IP
      version neutral.  The format of the textual representations
      implies the IP version.";
  }

  typedef ipv4-prefix {
    type string {
      pattern
         '(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
       +  '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
       + '/(([0-9])|([1-2][0-9])|(3[0-2]))';
    }
    description
     "The ipv4-prefix type represents an IPv4 address prefix.
      The prefix length is given by the number following the
      slash character and must be less than or equal to 32.

      A prefix length value of n corresponds to an IP address
      mask that has n contiguous 1-bits from the most
      significant bit (MSB) and all other bits set to 0.

      The canonical format of an IPv4 prefix has all bits of
      the IPv4 address set to zero that are not part of the
      IPv4 prefix.";
  }

  typedef ipv6-prefix {
    type string {
      pattern '((:|[0-9a-fA-F]{0,4}):)([0-9a-fA-F]{0,4}:){0,5}'
            + '((([0-9a-fA-F]{0,4}:)?(:|[0-9a-fA-F]{0,4}))|'
            + '(((25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])\.){3}'
            + '(25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])))'
            + '(/(([0-9])|([0-9]{2})|(1[0-1][0-9])|(12[0-8])))';
      pattern '(([^:]+:){6}(([^:]+:[^:]+)|(.*\..*)))|'
            + '((([^:]+:)*[^:]+)?::(([^:]+:)*[^:]+)?)'
            + '(/.+)';
    }

    description
     "The ipv6-prefix type represents an IPv6 address prefix.
      The prefix length is given by the number following the
      slash character and must be less than or equal to 128.

      A prefix length value of n corresponds to an IP address
      mask that has n contiguous 1-bits from the most
      significant bit (MSB) and all other bits set to 0.

      The IPv6 address should have all bits that do not belong
      to the prefix set to zero.

      The canonical format of an IPv6 prefix has all bits of
      the IPv6 address set to zero that are not part of the
      IPv6 prefix.  Furthermore, the IPv6 address is represented
      as defined in Section 4 of RFC 5952.";
    reference
     "RFC 5952: A Recommendation for IPv6 Address Text
                Representation";
  }

  /*** collection of domain name and URI types ***/

  typedef domain-name {
    type string {
      pattern
        '((([a-zA-Z0-9_]([a-zA-Z0-9\-_]){0,61})?[a-zA-Z0-9]\.)*'
      + '([a-zA-Z0-9_]([a-zA-Z0-9\-_]){0,61})?[a-zA-Z0-9]\.?)'
      + '|\.';
      length "1..253";
    }
    description
     "The domain-name type represents a DNS domain name.  The
      name SHOULD be fully qualified whenever possible.

      Internet domain names are only loosely specified.  Section
      3.5 of RFC 1034 recommends a syntax (modified in Section
      2.1 of RFC 1123).  The pattern above is intended to allow
      for current practice in domain name use, and some possible
      future expansion.  It is designed to hold various types of
      domain names, including names used for A or AAAA records
      (host names) and other records, such as SRV records.  Note
      that Internet host names have a stricter syntax (described
      in RFC 952) than the DNS recommendations in RFCs 1034 and
      1123, and that systems that want to store host names in
      schema nodes using the domain-name type are recommended to
      adhere to this stricter standard to ensure interoperability.

      The encoding of DNS names in the DNS protocol is limited
      to 255 characters.  Since the encoding consists of labels
      prefixed by a length bytes and there is a trailing NULL
      byte, only 253 characters can appear in the textual dotted
      notation.

      The description clause of schema nodes using the domain-name
      type MUST describe when and how these names are resolved to
      IP addresses.  Note that the resolution of a domain-name value
      may require to query multiple DNS records (e.g., A for IPv4
      and AAAA for IPv6).  The order of the resolution process and
      which DNS record takes precedence can either be defined
      explicitly or may depend on the configuration of the
      resolver.

      Domain-name values use the US-ASCII encoding.  Their canonical
      format uses lowercase US-ASCII characters.  Internationalized
      domain names MUST be A-labels as per RFC 5890.";
    reference
     "RFC  952: DoD Internet Host Table Specification
      RFC 1034: Domain Names - Concepts and Facilities
      RFC 1123: Requirements for Internet Hosts -- Application
                and Support
      RFC 2782: A DNS RR for specifying the location of services
                (DNS SRV)
      RFC 5890: Internationalized Domain Names in Applications
                (IDNA): Definitions and Document Framework";
  }

  typedef host {
    type union {
      type inet:ip-address;
      type inet:domain-name;
    }
    description
     "The host type represents either an IP address or a DNS
      domain name.";
  }

  typedef uri {
    type string;
    description
     "The uri type represents a Uniform Resource Identifier
      (URI) as defined by STD 66.

      Objects using the uri type MUST be in US-ASCII encoding,
      and MUST be normalized as described by RFC 3986 Sections
      6.2.1, 6.2.2.1, and 6.2.2.2.  All unnecessary
      percent-encoding is removed, and all case-insensitive
      characters are set to lowercase except for hexadecimal
      digits, which are normalized to uppercase as described in
      Section 6.2.2.1.

      The purpose of this normalization is to help provide
      unique URIs.  Note that this normalization is not
      sufficient to provide uniqueness.  Two URIs that are
      textually distinct after this normalization may still be
      equivalent.

      Objects using the uri type may restrict the schemes that
      they permit.  For example, 'data:' and 'urn:' schemes
      might not be appropriate.

      A zero-length URI is not a valid URI.  This can be used to
      express 'URI absent' where required.

      In the value set and its semantics, this type is equivalent
      to the Uri SMIv2 textual convention defined in RFC 5017.";
    reference
     "RFC 3986: Uniform Resource Identifier (URI): Generic Syntax
      RFC 3305: Report from the Joint W3C/IETF URI Planning Interest
                Group: Uniform Resource Identifiers (URIs), URLs,
                and Uniform Resource Names (URNs): Clarifications
                and Recommendations
      RFC 5017: MIB Textual Conventions for Uniform Resource
                Identifiers (URIs)";
  }

}

+ietf-yang-types        urn:ietf:params:xml:ns:yang:ietf-yang-types     \N      []      2013-07-15      module ietf-yang-types {

  namespace "urn:ietf:params:xml:ns:yang:ietf-yang-types";
  prefix "yang";

  organization
   "IETF NETMOD (NETCONF Data Modeling Language) Working Group";

  contact
   "WG Web:   <http://tools.ietf.org/wg/netmod/>
    WG List:  <mailto:netmod@ietf.org>

    WG Chair: David Kessens
              <mailto:david.kessens@nsn.com>

    WG Chair: Juergen Schoenwaelder
              <mailto:j.schoenwaelder@jacobs-university.de>

    Editor:   Juergen Schoenwaelder
              <mailto:j.schoenwaelder@jacobs-university.de>";

  description
   "This module contains a collection of generally useful derived
    YANG data types.

    Copyright (c) 2013 IETF Trust and the persons identified as
    authors of the code.  All rights reserved.

    Redistribution and use in source and binary forms, with or
    without modification, is permitted pursuant to, and subject
    to the license terms contained in, the Simplified BSD License
    set forth in Section 4.c of the IETF Trust's Legal Provisions
    Relating to IETF Documents
    (http://trustee.ietf.org/license-info).

    This version of this YANG module is part of RFC 6991; see
    the RFC itself for full legal notices.";

  revision 2013-07-15 {
    description
     "This revision adds the following new data types:
      - yang-identifier
      - hex-string
      - uuid
      - dotted-quad";
    reference
     "RFC 6991: Common YANG Data Types";
  }

  revision 2010-09-24 {
    description
     "Initial revision.";
    reference
     "RFC 6021: Common YANG Data Types";
  }

  /*** collection of counter and gauge types ***/

  typedef counter32 {
    type uint32;
    description
     "The counter32 type represents a non-negative integer
      that monotonically increases until it reaches a
      maximum value of 2^32-1 (4294967295 decimal), when it
      wraps around and starts increasing again from zero.

      Counters have no defined 'initial' value, and thus, a
      single value of a counter has (in general) no information
      content.  Discontinuities in the monotonically increasing
      value normally occur at re-initialization of the
      management system, and at other times as specified in the
      description of a schema node using this type.  If such
      other times can occur, for example, the creation of
      a schema node of type counter32 at times other than
      re-initialization, then a corresponding schema node
      should be defined, with an appropriate type, to indicate
      the last discontinuity.

      The counter32 type should not be used for configuration
      schema nodes.  A default statement SHOULD NOT be used in
      combination with the type counter32.

      In the value set and its semantics, this type is equivalent
      to the Counter32 type of the SMIv2.";
    reference
     "RFC 2578: Structure of Management Information Version 2
                (SMIv2)";
  }

  typedef zero-based-counter32 {
    type yang:counter32;
    default "0";
    description
     "The zero-based-counter32 type represents a counter32
      that has the defined 'initial' value zero.

      A schema node of this type will be set to zero (0) on creation
      and will thereafter increase monotonically until it reaches
      a maximum value of 2^32-1 (4294967295 decimal), when it
      wraps around and starts increasing again from zero.

      Provided that an application discovers a new schema node
      of this type within the minimum time to wrap, it can use the
      'initial' value as a delta.  It is important for a management
      station to be aware of this minimum time and the actual time
      between polls, and to discard data if the actual time is too
      long or there is no defined minimum time.

      In the value set and its semantics, this type is equivalent
      to the ZeroBasedCounter32 textual convention of the SMIv2.";
    reference
      "RFC 4502: Remote Network Monitoring Management Information
                 Base Version 2";
  }

  typedef counter64 {
    type uint64;
    description
     "The counter64 type represents a non-negative integer
      that monotonically increases until it reaches a
      maximum value of 2^64-1 (18446744073709551615 decimal),
      when it wraps around and starts increasing again from zero.

      Counters have no defined 'initial' value, and thus, a
      single value of a counter has (in general) no information
      content.  Discontinuities in the monotonically increasing
      value normally occur at re-initialization of the
      management system, and at other times as specified in the
      description of a schema node using this type.  If such
      other times can occur, for example, the creation of
      a schema node of type counter64 at times other than
      re-initialization, then a corresponding schema node
      should be defined, with an appropriate type, to indicate
      the last discontinuity.

      The counter64 type should not be used for configuration
      schema nodes.  A default statement SHOULD NOT be used in
      combination with the type counter64.

      In the value set and its semantics, this type is equivalent
      to the Counter64 type of the SMIv2.";
    reference
     "RFC 2578: Structure of Management Information Version 2
                (SMIv2)";
  }

  typedef zero-based-counter64 {
    type yang:counter64;
    default "0";
    description
     "The zero-based-counter64 type represents a counter64 that
      has the defined 'initial' value zero.

      A schema node of this type will be set to zero (0) on creation
      and will thereafter increase monotonically until it reaches
      a maximum value of 2^64-1 (18446744073709551615 decimal),
      when it wraps around and starts increasing again from zero.

      Provided that an application discovers a new schema node
      of this type within the minimum time to wrap, it can use the
      'initial' value as a delta.  It is important for a management
      station to be aware of this minimum time and the actual time
      between polls, and to discard data if the actual time is too
      long or there is no defined minimum time.

      In the value set and its semantics, this type is equivalent
      to the ZeroBasedCounter64 textual convention of the SMIv2.";
    reference
     "RFC 2856: Textual Conventions for Additional High Capacity
                Data Types";
  }

  typedef gauge32 {
    type uint32;
    description
     "The gauge32 type represents a non-negative integer, which
      may increase or decrease, but shall never exceed a maximum
      value, nor fall below a minimum value.  The maximum value
      cannot be greater than 2^32-1 (4294967295 decimal), and
      the minimum value cannot be smaller than 0.  The value of
      a gauge32 has its maximum value whenever the information
      being modeled is greater than or equal to its maximum
      value, and has its minimum value whenever the information
      being modeled is smaller than or equal to its minimum value.
      If the information being modeled subsequently decreases
      below (increases above) the maximum (minimum) value, the
      gauge32 also decreases (increases).

      In the value set and its semantics, this type is equivalent
      to the Gauge32 type of the SMIv2.";
    reference
     "RFC 2578: Structure of Management Information Version 2
                (SMIv2)";
  }

  typedef gauge64 {
    type uint64;
    description
     "The gauge64 type represents a non-negative integer, which
      may increase or decrease, but shall never exceed a maximum
      value, nor fall below a minimum value.  The maximum value
      cannot be greater than 2^64-1 (18446744073709551615), and
      the minimum value cannot be smaller than 0.  The value of
      a gauge64 has its maximum value whenever the information
      being modeled is greater than or equal to its maximum
      value, and has its minimum value whenever the information
      being modeled is smaller than or equal to its minimum value.
      If the information being modeled subsequently decreases
      below (increases above) the maximum (minimum) value, the
      gauge64 also decreases (increases).

      In the value set and its semantics, this type is equivalent
      to the CounterBasedGauge64 SMIv2 textual convention defined
      in RFC 2856";
    reference
     "RFC 2856: Textual Conventions for Additional High Capacity
                Data Types";
  }

  /*** collection of identifier-related types ***/

  typedef object-identifier {
    type string {
      pattern '(([0-1](\.[1-3]?[0-9]))|(2\.(0|([1-9]\d*))))'
            + '(\.(0|([1-9]\d*)))*';
    }
    description
     "The object-identifier type represents administratively
      assigned names in a registration-hierarchical-name tree.

      Values of this type are denoted as a sequence of numerical
      non-negative sub-identifier values.  Each sub-identifier
      value MUST NOT exceed 2^32-1 (4294967295).  Sub-identifiers
      are separated by single dots and without any intermediate
      whitespace.

      The ASN.1 standard restricts the value space of the first
      sub-identifier to 0, 1, or 2.  Furthermore, the value space
      of the second sub-identifier is restricted to the range
      0 to 39 if the first sub-identifier is 0 or 1.  Finally,
      the ASN.1 standard requires that an object identifier
      has always at least two sub-identifiers.  The pattern
      captures these restrictions.

      Although the number of sub-identifiers is not limited,
      module designers should realize that there may be
      implementations that stick with the SMIv2 limit of 128
      sub-identifiers.

      This type is a superset of the SMIv2 OBJECT IDENTIFIER type
      since it is not restricted to 128 sub-identifiers.  Hence,
      this type SHOULD NOT be used to represent the SMIv2 OBJECT
      IDENTIFIER type; the object-identifier-128 type SHOULD be
      used instead.";
    reference
     "ISO9834-1: Information technology -- Open Systems
      Interconnection -- Procedures for the operation of OSI
      Registration Authorities: General procedures and top
      arcs of the ASN.1 Object Identifier tree";
  }

  typedef object-identifier-128 {
    type object-identifier {
      pattern '\d*(\.\d*){1,127}';
    }
    description
     "This type represents object-identifiers restricted to 128
      sub-identifiers.

      In the value set and its semantics, this type is equivalent
      to the OBJECT IDENTIFIER type of the SMIv2.";
    reference
     "RFC 2578: Structure of Management Information Version 2
                (SMIv2)";
  }

  typedef yang-identifier {
    type string {
      length "1..max";
      pattern '[a-zA-Z_][a-zA-Z0-9\-_.]*';
      pattern '.|..|[^xX].*|.[^mM].*|..[^lL].*';
    }
    description
      "A YANG identifier string as defined by the 'identifier'
       rule in Section 12 of RFC 6020.  An identifier must
       start with an alphabetic character or an underscore
       followed by an arbitrary sequence of alphabetic or
       numeric characters, underscores, hyphens, or dots.

       A YANG identifier MUST NOT start with any possible
       combination of the lowercase or uppercase character
       sequence 'xml'.";
    reference
      "RFC 6020: YANG - A Data Modeling Language for the Network
                 Configuration Protocol (NETCONF)";
  }

  /*** collection of types related to date and time***/

  typedef date-and-time {
    type string {
      pattern '\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?'
            + '(Z|[\+\-]\d{2}:\d{2})';
    }
    description
     "The date-and-time type is a profile of the ISO 8601
      standard for representation of dates and times using the
      Gregorian calendar.  The profile is defined by the
      date-time production in Section 5.6 of RFC 3339.

      The date-and-time type is compatible with the dateTime XML
      schema type with the following notable exceptions:

      (a) The date-and-time type does not allow negative years.

      (b) The date-and-time time-offset -00:00 indicates an unknown
          time zone (see RFC 3339) while -00:00 and +00:00 and Z
          all represent the same time zone in dateTime.

      (c) The canonical format (see below) of data-and-time values
          differs from the canonical format used by the dateTime XML
          schema type, which requires all times to be in UTC using
          the time-offset 'Z'.

      This type is not equivalent to the DateAndTime textual
      convention of the SMIv2 since RFC 3339 uses a different
      separator between full-date and full-time and provides
      higher resolution of time-secfrac.

      The canonical format for date-and-time values with a known time
      zone uses a numeric time zone offset that is calculated using
      the device's configured known offset to UTC time.  A change of
      the device's offset to UTC time will cause date-and-time values
      to change accordingly.  Such changes might happen periodically
      in case a server follows automatically daylight saving time
      (DST) time zone offset changes.  The canonical format for
      date-and-time values with an unknown time zone (usually
      referring to the notion of local time) uses the time-offset
      -00:00.";
    reference
     "RFC 3339: Date and Time on the Internet: Timestamps
      RFC 2579: Textual Conventions for SMIv2
      XSD-TYPES: XML Schema Part 2: Datatypes Second Edition";
  }

  typedef timeticks {
    type uint32;
    description
     "The timeticks type represents a non-negative integer that
      represents the time, modulo 2^32 (4294967296 decimal), in
      hundredths of a second between two epochs.  When a schema
      node is defined that uses this type, the description of
      the schema node identifies both of the reference epochs.

      In the value set and its semantics, this type is equivalent
      to the TimeTicks type of the SMIv2.";
    reference
     "RFC 2578: Structure of Management Information Version 2
                (SMIv2)";
  }

  typedef timestamp {
    type yang:timeticks;
    description
     "The timestamp type represents the value of an associated
      timeticks schema node at which a specific occurrence
      happened.  The specific occurrence must be defined in the
      description of any schema node defined using this type.  When
      the specific occurrence occurred prior to the last time the
      associated timeticks attribute was zero, then the timestamp
      value is zero.  Note that this requires all timestamp values
      to be reset to zero when the value of the associated timeticks
      attribute reaches 497+ days and wraps around to zero.

      The associated timeticks schema node must be specified
      in the description of any schema node using this type.

      In the value set and its semantics, this type is equivalent
      to the TimeStamp textual convention of the SMIv2.";
    reference
     "RFC 2579: Textual Conventions for SMIv2";
  }

  /*** collection of generic address types ***/

  typedef phys-address {
    type string {
      pattern '([0-9a-fA-F]{2}(:[0-9a-fA-F]{2})*)?';
    }

    description
     "Represents media- or physical-level addresses represented
      as a sequence octets, each octet represented by two hexadecimal
      numbers.  Octets are separated by colons.  The canonical
      representation uses lowercase characters.

      In the value set and its semantics, this type is equivalent
      to the PhysAddress textual convention of the SMIv2.";
    reference
     "RFC 2579: Textual Conventions for SMIv2";
  }

  typedef mac-address {
    type string {
      pattern '[0-9a-fA-F]{2}(:[0-9a-fA-F]{2}){5}';
    }
    description
     "The mac-address type represents an IEEE 802 MAC address.
      The canonical representation uses lowercase characters.

      In the value set and its semantics, this type is equivalent
      to the MacAddress textual convention of the SMIv2.";
    reference
     "IEEE 802: IEEE Standard for Local and Metropolitan Area
                Networks: Overview and Architecture
      RFC 2579: Textual Conventions for SMIv2";
  }

  /*** collection of XML-specific types ***/

  typedef xpath1.0 {
    type string;
    description
     "This type represents an XPATH 1.0 expression.

      When a schema node is defined that uses this type, the
      description of the schema node MUST specify the XPath
      context in which the XPath expression is evaluated.";
    reference
     "XPATH: XML Path Language (XPath) Version 1.0";
  }

  /*** collection of string types ***/

  typedef hex-string {
    type string {
      pattern '([0-9a-fA-F]{2}(:[0-9a-fA-F]{2})*)?';
    }
    description
     "A hexadecimal string with octets represented as hex digits
      separated by colons.  The canonical representation uses
      lowercase characters.";
  }

  typedef uuid {
    type string {
      pattern '[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-'
            + '[0-9a-fA-F]{4}-[0-9a-fA-F]{12}';
    }
    description
     "A Universally Unique IDentifier in the string representation
      defined in RFC 4122.  The canonical representation uses
      lowercase characters.

      The following is an example of a UUID in string representation:
      f81d4fae-7dec-11d0-a765-00a0c91e6bf6
      ";
    reference
     "RFC 4122: A Universally Unique IDentifier (UUID) URN
                Namespace";
  }

  typedef dotted-quad {
    type string {
      pattern
        '(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
      + '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';
    }
    description
      "An unsigned 32-bit number expressed in the dotted-quad
       notation, i.e., four octets written as decimal numbers
       and separated with the '.' (full stop) character.";
  }
}

+o-ran-smo-teiv-cloud   urn:o-ran:smo-teiv-cloud        CLOUD   []      2024-10-04      module o-ran-smo-teiv-cloud {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-cloud";
    prefix or-teiv-cloud;

    import o-ran-smo-teiv-common-yang-types {prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }

    import ietf-geo-location {
        prefix geo;
        reference "RFC 9179: A YANG Grouping for Geographic Locations";
    }

    organization "ORAN";
    contact "The Authors";
    description
        "RAN Cloud topology model.

        This model contains the topology entities and relations in the
        RAN CLOUD domain, which comprises cloud infrastructure and
        deployment aspects that can be used in the topology model.

        Copyright (C) 2024 Ericsson
        Modifications Copyright (C) 2024 OpenInfra Foundation Europe

        Licensed under the Apache License, Version 2.0 (the \"License\");
        you may not use this file except in compliance with the License.
        You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

        Unless required by applicable law or agreed to in writing, software
        distributed under the License is distributed on an \"AS IS\" BASIS,
        WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
        See the License for the specific language governing permissions and
        limitations under the License.

        SPDX-License-Identifier: Apache-2.0";

    revision "2024-10-04" {
        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
        to the corresponding topology objects.";
        or-teiv-yext:label 0.4.0;
    }

    revision "2024-05-02" {
        description "Initial revision.";
        or-teiv-yext:label 0.3.0;
    }

    revision "2024-07-15" {
        description "This revision aligns O-RAN Work Group 10 Stage 2 Specification (O-RAN.WG10.TE&IV-CIMI.0-R004.v02.00)";
        or-teiv-yext:label 0.4.0;
    }

    or-teiv-yext:domain CLOUD;

    list CloudifiedNF {
        description "A RAN Network Function software that is deployed in the O-Cloud via one or more NF Deployments.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of Cloudified NF";
                type string;
            }
        }
    }

    list NFDeployment {
        description "A software deployment on O-Cloud resources that realizes, all or part of, a Cloudified NF.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of NF Deployment";
                type string;
            }
        }
    }

    list OCloudNamespace {
        description "OCloudNamespace provide a mechanism for isolating
        groups of resources within a single cluster.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of Cloud Namespace";
                type string;
            }
        }
    }

    list NodeCluster {
        description "A NodeCluster manages a collection of Nodes.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of Node Cluster";
                type string;
            }
        }
    }

    list OCloudSite {
        description "Represents the infrastructure that
        hosts the NF Deployment.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of Cloud Site";
                type string;
            }

            uses geo:geo-location;
        }
    }


    or-teiv-yext:biDirectionalTopologyRelationship CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT { // 1 to 1..n

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list comprised-nFDeployment {
            description "Cloudified NF comprises of these NF Deployment.";
            or-teiv-yext:aSide CloudifiedNF;
            type instance-identifier;
            min-elements 1;
        }

        leaf comprised-by-cloudifiedNF {
            description "NF Deployment part of Cloudified NF.";
            or-teiv-yext:bSide NFDeployment;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE { // 1..n to 1..n

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list deployed-on-ocloudNamespace {
            description "NF Deployment deployed on O-Cloud Namespace.";
            or-teiv-yext:aSide NFDeployment;
            type instance-identifier;
            min-elements 1;
        }

        leaf-list deployed-nFDeployment {
            description "OCloud Namespace deploys NF Deployment.";
            or-teiv-yext:bSide OCloudNamespace;
            type instance-identifier;
            min-elements 1;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER { // 1..n to 1

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf deployed-on-nodeCluster {
            description "O-Cloud Namespace deployed on Node Cluster.";
            or-teiv-yext:aSide OCloudNamespace;
            type instance-identifier;
            mandatory true;
        }

        leaf-list deployed-ocloudNamespace {
            description "Node Cluster deploys O-Cloud Namespace.";
            or-teiv-yext:bSide NodeCluster;
            type instance-identifier;
            min-elements 1;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship NODECLUSTER_LOCATED_AT_OCLOUDSITE { // 1..n to 1..n

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list located-at-ocloudSite {
            description "Node Cluster located at O-Cloud Site.";
            or-teiv-yext:aSide NodeCluster;
            type instance-identifier;
            min-elements 1;
        }

        leaf-list location-of-onodeCluster {
            description "O-Cloud Site is location of Node Cluster.";
            or-teiv-yext:bSide OCloudSite;
            type instance-identifier;
            min-elements 1;
        }
    }
}
+o-ran-smo-teiv-common-yang-extensions  urn:o-ran:smo-teiv-common-yang-extensions       \N      []      2025-02-14      module o-ran-smo-teiv-common-yang-extensions {

  yang-version 1.1;
  namespace "urn:o-ran:smo-teiv-common-yang-extensions";
  prefix or-teiv-yext;

  organization "ORAN";
  contact "The Authors";
  description
  "Topology and Inventory YANG extensions model.
  This model contains extensions to the YANG language that topology and
  inventory models will use to define and annotate types and relationships

  Copyright (C) 2024 Ericsson
  Modifications Copyright (C) 2024-2025 OpenInfra Foundation Europe

  Licensed under the Apache License, Version 2.0 (the \"License\");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0

  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an \"AS IS\" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.

  SPDX-License-Identifier: Apache-2.0";

    revision "2025-02-14" {
        description "Updates for bi-directional relationship.";
        or-teiv-yext:label 1.1.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v02.00";
    }

    revision "2024-10-10" {
        description "Initial revision.";
        or-teiv-yext:label 1.0.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v01.00";
    }

    extension biDirectionalTopologyRelationship {
        argument relationshipName;
        description
            "Defines a bi-directional relationship in the topology.
            A bi-directional-association (BDA) is a relationship comprising of
            an aSide and a bSide. The aSide is considered the originating
            side of the relationship; the bSide is considered the terminating
            side of the relationship. The order of aSide and bSide is of
            importance and MUST NOT be changed once defined.

            Both aSide and bSide are defined on a type, and are given a role.
            A type may have multiple originating and/or terminating sides of a
            relationship, all distinguished by role name.

            The statement MUST only be a substatement of the 'module' statement.
            Multiple 'biDirectionalTopologyRelationship' statements are
            allowed per parent statement.

            Substatements to the 'biDirectionalTopologyRelationship' define
            the aSide and the bSide, respectively, and optionally properties
            of the relationship. Data nodes of types 'leaf' and 'leaf-list' are
            used for this purpose. One of the data nodes MUST be annotated with
            the 'aSide' extension; another data node MUST be annotated with the
            'bSide' extension. Other data nodes define properties of the
            relationship.

            The argument is the name of the relationship. The relationship name
            is scoped to the namespace of the declaring module and MUST be
            unique within the scope.";
    }

    extension aSide {
        argument aSideType;
        description
            "Defines the aSide of a relationship.

            The statement MUST only be a substatement of a 'leaf' or 'leaf-list'
            statement, which itself must be a substatement of the
            'biDirectionalTopologyRelationship' statement.

            The data type of the parent 'leaf' or 'leaf-list' MUST be
            'instance-identifier'. Constraints MAY be used as part of the parent
            'leaf' or 'leaf-list' to enforce cardinality.

            The identifier of the parent 'leaf' or 'leaf-list' is used as name
            of the role of the aSide of the relationship. The name of the role
            is scoped to the type on which the aSide is defined and MUST be
            unique within the scope.

            While the parent 'leaf' or 'leaf-list' does not result in a property
            of the relationship, it is RECOMMENDED to avoid using the name of an
            existing type property as role name to avoid potential ambiguities
            between properties of a type, and roles of a relationship on the type.

            The argument is the name of the type on which the aSide resides.
            If the type is declared in another module, the type must be
            prefixed, and a corresponding 'import' statement be used to declare
            the prefix.";
    }

    extension bSide {
        argument bSideType;
        description
            "Defines the bSide of a relationship.

            The statement MUST only be a substatement of a 'leaf' or 'leaf-list'
            statement, which itself must be a substatement of the
            'biDirectionalTopologyRelationship' statement.

            The data type of the parent 'leaf' or 'leaf-list' MUST be
            'instance-identifier'. Constraints MAY be used as part of the parent
            'leaf' or 'leaf-list' to enforce cardinality.

            The identifier of the parent 'leaf' or 'leaf-list' is used as name
            of the role of the bSide of the relationship. The name of the role
            is scoped to the type on which the bSide is defined and MUST be
            unique within the scope.

            While the parent 'leaf' or 'leaf-list' does not result in a property
            of the relationship, it is RECOMMENDED to avoid using the name of an
            existing type property as role name to avoid potential ambiguities
            between properties of a type, and roles of a relationship on the type.

            The argument is the name of the type on which the bSide resides.
            If the type is declared in another module, the type must be
            prefixed, and a corresponding 'import' statement be used to declare
            the prefix.";
    }

    extension domain {
        argument domainName;
        description "Keyword used to carry domain information.";
    }

    extension label {
        argument semversion;
        description
            "The label can be used to give modules and submodules a semantic
            version, in addition to their revision.

            The format of the label is 'x.y.z' - expressed as pattern, it is
            [0-9]+\\.[0-9]+\\.[0-9]+
            The statement MUST only be a substatement of the revision statement.
            Zero or one revision label statements per parent statement are
            allowed.

            Revision labels MUST be unique amongst all revisions of a module or
            submodule.";
    }
}
+o-ran-smo-teiv-common-yang-types       urn:o-ran:smo-teiv-common-yang-types    \N      []      2025-03-20      module o-ran-smo-teiv-common-yang-types {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-common-yang-types";
    prefix or-teiv-types;

    import ietf-yang-types { prefix yang; }

    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }

    import _3gpp-common-yang-types { prefix types3gpp; }

    organization "ORAN";
    contact "The Authors";
    description
    "Topology and Inventory common types model.

    This model contains re-usable data types that topology and inventory models
    will frequently use as part of types and relationships.

    Copyright (C) 2024 Ericsson
    Modifications Copyright (C) 2024-2025 OpenInfra Foundation Europe

    Licensed under the Apache License, Version 2.0 (the \"License\");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an \"AS IS\" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.

    SPDX-License-Identifier: Apache-2.0";

    revision "2025-03-20" {
        description "Proposed metadata, decorators and classifiers";
        or-teiv-yext:label 1.1.1;
    }

    revision "2025-02-24" {
        description "Renamed Adapter Entity to Origin Entity. Added Geo-Information";
        or-teiv-yext:label 1.1.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v02.00";
    }

    revision "2024-10-10" {
        description "Initial revision.";
        or-teiv-yext:label 1.0.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v01.00.00";
    }

    grouping Top_Grp_Type {
        description "Grouping containing the key attribute common to all types. All types MUST use this grouping.";

        leaf id {
            type string;
            description "Unique identifier of topology entities. Represents the Entity Instance Identifier.";
        }
    }

    grouping Origin_Entity_Mapping_Grp {
        description "Grouping to identify sourceIds on a topology entity.";

        leaf-list sourceIds {
            type sourceId;
            min-elements 1;
            ordered-by user;
            description
                "An ordered list of identities that represent the set of native
                source identifiers for participating entities.

                This must be attached to Topology Entity instance, outside of the
                declared Topology Entity's attributes. This is exposed to the
                consumers and can only be set by the responsible adapter. This
                cannot be instantiated, and it MUST NOT be augmented or deviated
                in any way, unless stated otherwise.";
        }
    }

    grouping Origin_Relationship_Mapping_Grp {
        description "Grouping to identify sourceIds on a topology relationship.";

        leaf-list sourceIds {
            type sourceId;
            min-elements 2;
            ordered-by user;
            description
                "An ordered list of identities that represent the set of native
                source identifiers for participating entities in the relationship.

                This must be attached to the Topology Relation instance, outside of the
                declared Topology Relationship's attributes. This is exposed to the
                consumers and can only be set by the responsible adapter. This
                cannot be instantiated, and it MUST NOT be augmented or deviated in
                any way, unless stated otherwise.";
        }
    }

    typedef sourceId {
        type string;
        description "An identity that represents a native identifier of a topology entity.";
    }

    container metadata {
        description
            "This container serves as an extension point to define metadata. They
            can only be defined in name value pairs.

            This must be attached to the Topology Entity or Topology Relation instance,
            outside of the declared Topology Entity or Topology Relationship's
            attributes. This is exposed to the consumers and can only be set by
            Topology and Inventory Exposure Handling and Discovery and Reconciliation Adapter.
            This cannot be instantiated, and it MUST NOT be augmented or deviated in any way,
            unless stated otherwise.";

        leaf reliabilityIndicator {
            type enumeration {
                enum OK {
                    description "The data is in alignment with the source of truth,
                    as far as Topology and Inventory Exposure Handling is aware.";
                    value 0;
                }
                enum RESTORED {
                    description "The data was restored from backup and the responsible
                    adapters are checking to ensure the data is current.";
                    value 1;
                }
                enum ADVISED {
                    description "Entity implicitly created by Topology and Inventory Exposure
                    Handling and potentially not aligned with the source of truth.";
                    value 2;
                }
            }
        }

        leaf firstDiscovered {
            type yang:date-and-time;
            description "Timestamp indicating when an instance of Topology Entity or Relation
            was first represented in Topology and Inventory Exposure Handling via discovery.";
        }

        leaf lastModified {
            type yang:date-and-time;
            description "Timestamp indicating when an instance of Topology Entity or Relation
            was last updated (excluding classifiers and decorators).";
        }
    }

    container decorators {
        description
            "This container serves as extension point for applications wishing
            to define their own decorators. This is done via augmentations. They
            can only be defined in name value pair.

            This is a consumer data and can be attached to Topology Entity or
            Topology Relation instance, outside of the declared Topology Entity
            or Topology Relationship's attributes. This cannot be instantiated,
            and it MUST NOT be augmented or deviated in any way, unless stated
            otherwise.";
    }

    leaf-list classifiers {
        description
            "Consumer defined tags to topology entities and relationships.

            This is a consumer data and can be attached to Topology Entity or
            Topology Relation instance, outside of the declared Topology Entity
            or Topology Relationship's attributes. This cannot be instantiated,
            and it MUST NOT be augmented or deviated in any way, unless stated
            otherwise.";

        type identityref { base classifier; }
    }

    identity classifier {
        description "The classifier is used as a base to provide all classifiers
        with identity. ";
    }
}
+o-ran-smo-teiv-equipment       urn:o-ran:smo-teiv-equipment    EQUIPMENT       []      2024-10-21      module o-ran-smo-teiv-equipment {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-equipment";
    prefix or-teiv-equip;

    import o-ran-smo-teiv-common-yang-types {prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }

    import ietf-geo-location {
        prefix geo;
        reference "RFC 9179: A YANG Grouping for Geographic Locations";
    }

    organization "ORAN";
    contact "The Authors";
    description
    "RAN Equipment topology model.

    This model contains the topology entities and relations in the
    RAN Equipment domain, which is modelled to understand the physical
    location of equipment such as antennas associated with a cell/carrier
    and their relevant properties e.g. tilt, max power etc.

    Copyright (C) 2024 Ericsson
    Modifications Copyright (C) 2024 OpenInfra Foundation Europe

    Licensed under the Apache License, Version 2.0 (the \"License\");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an \"AS IS\" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and";

    revision "2024-10-21" {
        description "Deprecate AntennaModule attribute antennaBeamWidth.
        To be replaced by horizontalBeamWidth and verticalBeamWidth.";
        or-teiv-yext:label 0.6.0;
    }

    revision "2024-10-08" {
        description "Added azimuth attribute for AntennaModule.";
        or-teiv-yext:label 0.5.0;
    }

    revision "2024-10-04" {
        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
        to the corresponding topology objects.";
        or-teiv-yext:label 0.4.0;
    }

    revision "2024-05-24" {
        description "Initial revision.";
        or-teiv-yext:label 0.3.0;
    }

    or-teiv-yext:domain EQUIPMENT;

    list AntennaModule {
        description "An Antenna Module represents the physical aspect of an
        antenna.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf antennaModelNumber {
                description "Vendor-specific antenna model identifier. This
                attribute is part of AISG v3 ADB Standard and has no
                operational impact.";
                type string;
            }

            leaf mechanicalAntennaBearing {
                description "Antenna bearing on antenna subunit where antenna
                unit is installed.";
                type int32;
            }

            leaf mechanicalAntennaTilt {
                description "The fixed antenna tilt of the installation, defined
                as the inclination of the antenna element respect to the
                vertical plane. It is a signed value. Positive indicates
                downtilt, and negative indicates uptilt.";
                type int32;
            }

            leaf positionWithinSector {
                description "Antenna unit position within sector. This attribute
                is part of AISG v3 ADB Standard and has no operational
                impact.";
                type string;
            }

            leaf totalTilt {
                description "Total antenna elevation including the installed
                tilt and the tilt applied by the Remote Electrical
                Tilt (RET).";
                type int32;
            }

            leaf electricalAntennaTilt {
                description "Electrically-controlled tilt of main beam maximum
                with respect to direction orthogonal to antenna element
                axis (see 3GPP TS 25.466). Value is signed; tilt down is
                positive, tilt up is negative.";
                type int32;
            }

            leaf-list antennaBeamWidth {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the horizontal plane. Measured in
                degrees.

                Deprecated: Since 24.Q4. Replaced by AntennaModule::horizontalBeamWidth
                and AntennaModule::verticalBeamWidth. Planned to be removed.";
                type uint32;
            }

            leaf horizontalBeamWidth  {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the horizontal plane.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            leaf verticalBeamWidth   {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the vertical plane.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            leaf azimuth {
                description "The value of the azimuth of the Antenna Module.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            uses geo:geo-location;
        }
    }

    list Site {
        description "A site is a physical location where an equipment can be
        installed.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf name {
                description "Name of Site";
                type string;
            }

            uses geo:geo-location;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULE_INSTALLED_AT_SITE { // 0..n to 0..1

        description
            "The aSide of this relationship is an instance of the AntennaModule type.
            The bSide of this relationship is an instance of the Site type.
            The Site represents the physical location where the AntennaModule is installed.
            An AntennaModule instance can only be installed at one Site.
            A Site instance can have many installed AntennaModules.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf installed-at-site {
            description "Antenna Module installed at Site.";
            or-teiv-yext:aSide AntennaModule;
            type instance-identifier;
        }

        leaf-list installed-antennaModule {
            description "Site where Antenna Module is installed.";
            or-teiv-yext:bSide Site;
            type instance-identifier;
        }
    }
}
+o-ran-smo-teiv-oam     urn:o-ran:smo-teiv-oam  OAM     []      2024-10-04      bW9kdWxlIG8tcmFuLXNtby10ZWl2LW9hbSB7CiAgICB5YW5nLXZlcnNpb24gMS4xOwogICAgbmFtZXNwYWNlICJ1cm46by1yYW46c21vLXRlaXYtb2FtIjsKICAgIHByZWZpeCBvci10ZWl2LW9hbTsKCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctdHlwZXMgeyBwcmVmaXggb3ItdGVpdi10eXBlczsgfQoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1jb21tb24teWFuZy1leHRlbnNpb25zIHsgcHJlZml4IG9yLXRlaXYteWV4dDsgfQoKICAgIG9yZ2FuaXphdGlvbiAiT1JBTiI7CiAgICBjb250YWN0ICJUaGUgQXV0aG9ycyI7CiAgICBkZXNjcmlwdGlvbiAKICAgICJSQU4gTyZNIHRvcG9sb2d5IG1vZGVsLgoKICAgIFRoaXMgbW9kZWwgY29udGFpbnMgdGhlIHRvcG9sb2d5IGVudGl0aWVzIGFuZCByZWxhdGlvbnMgaW4gdGhlCiAgICBSQU4gTyZNIGRvbWFpbiwgd2hpY2ggYXJlIGludGVuZGVkIHRvIHJlcHJlc2VudCBtYW5hZ2VtZW50IHN5c3RlbXMKICAgIGFuZCBtYW5hZ2VtZW50IGludGVyZmFjZXMuCgogICAgQ29weXJpZ2h0IChDKSAyMDI0IEVyaWNzc29uCiAgICBNb2RpZmljYXRpb25zIENvcHlyaWdodCAoQykgMjAyNCBPcGVuSW5mcmEgRm91bmRhdGlvbiBFdXJvcGUKCiAgICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpOwogICAgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLgogICAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0CgogICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wCgogICAgVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZQogICAgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLAogICAgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuCiAgICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kCiAgICBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS4KCiAgICBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMCI7CgogICAgcmV2aXNpb24gIjIwMjQtMTAtMDQiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiQWRkZWQgZ3JvdXBpbmcsIE9yaWdpbl9FbnRpdHlfTWFwcGluZ19HcnAgdG8gdGhlIHRvcG9sb2d5IG9iamVjdC4iOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjQuMDsKICAgIH0KCiAgICByZXZpc2lvbiAiMjAyNC0wNS0yNCIgewogICAgICAgIGRlc2NyaXB0aW9uICJJbml0aWFsIHJldmlzaW9uLiI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuMy4wOwogICAgfQoKICAgIG9yLXRlaXYteWV4dDpkb21haW4gT0FNOwoKICAgIGxpc3QgTWFuYWdlZEVsZW1lbnQgewogICAgICAgIGRlc2NyaXB0aW9uICJBIE1hbmFnZWQgRWxlbWVudCAoTUUpIGlzIGEgbm9kZSBpbnRvIGEgdGVsZWNvbW11bmljYXRpb24KICAgICAgICBuZXR3b3JrIHByb3ZpZGluZyBzdXBwb3J0IGFuZC9vciBzZXJ2aWNlIHRvIHN1YnNjcmliZXJzLiBBbiBNRQogICAgICAgIGNvbW11bmljYXRlcyB3aXRoIGEgbWFuYWdlciBhcHBsaWNhdGlvbiAoZGlyZWN0bHkgb3IgaW5kaXJlY3RseSkKICAgICAgICBvdmVyIG9uZSBvciBtb3JlIGludGVyZmFjZXMgZm9yIHRoZSBwdXJwb3NlIG9mIGJlaW5nIG1vbml0b3JlZAogICAgICAgIGFuZC9vciBjb250cm9sbGVkLiI7CgogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpUb3BfR3JwX1R5cGU7CiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOk9yaWdpbl9FbnRpdHlfTWFwcGluZ19HcnA7CiAgICAgICAga2V5IGlkOwogICAgfQp9
+o-ran-smo-teiv-ran     urn:o-ran:smo-teiv-ran  RAN     []      2025-03-20      module o-ran-smo-teiv-ran {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-ran";
    prefix or-teiv-ran;

    import o-ran-smo-teiv-common-yang-types {prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }

    import _3gpp-common-yang-types { prefix types3gpp; }

    import ietf-geo-location {
        prefix geo;
        reference "RFC 9179: A YANG Grouping for Geographic Locations";
    }

    organization "ORAN";
    contact "The Authors";
    description "RAN Logical topology model.

        This model contains the topology entities and relations in the
        RAN Logical domain, which represents the functional capability
        of the deployed RAN that are relevant to rApps use cases.

        Copyright (C) 2024 Ericsson
        Modifications Copyright (C) 2024-2025 OpenInfra Foundation Europe

        Licensed under the Apache License, Version 2.0 (the \"License\");
        you may not use this file except in compliance with the License.
        You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

        Unless required by applicable law or agreed to in writing, software
        distributed under the License is distributed on an \"AS IS\" BASIS,
        WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
        See the License for the specific language governing permissions and
        limitations under the License.

        SPDX-License-Identifier: Apache-2.0";

    revision "2025-03-20" {
        description "Proposed entities, relationships and attributes";
        or-teiv-yext:label 1.1.1;
    }

    revision "2025-02-14" {
        description "Revision to rename adapter group to origin group.";
        or-teiv-yext:label 1.1.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v02.00";
    }

    revision "2024-10-10" {
        description "Initial revision.";
        or-teiv-yext:label 1.0.0;
        reference "O-RAN.WG10.TE&IV-DM.0-R004-v01.00";
    }

    or-teiv-yext:domain RAN;

    list ODUFunction {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "O-RAN Distributed Unit (O-DU).

        The O-DU is an O-RAN NF in the O-RAN Architecture. An O-DU, combined with
        one or more O-RU(s) connected to it, supports and is fully compatible
        with the functions of a gNB-DU as defined by 3GPP TS 38.401.

        The O-DU terminates the E2 and the F1 interface, and the Open Fronthaul
        interface (also known as LLS interface) as well as the RLC, MAC, and
        High-PHY functions of the radio interface towards the UE.

        Note: O-DU is a concrete class that extends the ORANNetworkFunction
        abstract class. In Topology, you can create, read, update, and delete the
        O-DU object.

        The management characteristics of the O-DU O-RAN NF is represented by the
        IOC GNBDUFunction as specified in 3GPP NR NRM model, as per 3GPP TS 28.541";

        container attributes {
            description "Container for O-RAN Distributed Unit (O-DU) attributes";

            leaf gNBDUId {
                type int64;
                description "Unique identifier for the DU within a gNodeB";
            }

            leaf gNBId {
                type int64;
                description "Identity of gNodeB within a PLMN";
            }

            leaf gNBIdLength {
                type int32;
                description "Length of gNBId bit string representation";
            }

            container dUpLMNId {
                uses types3gpp:PLMNId;
                description "PLMN identifier used as part of PM Events data";
            }
        }
    }

    list OCUCPFunction {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;
    
        description "O-RAN Central Unit – Control Plane (O-CU-CP)

        The O-CU-CP terminates the NG-c, X2-c, Xn-c, F1-c, and E1 interfaces as
        well as the RRC and PDCP (for SRB) protocols towards the UE as defined by
        3GPP TS 38.401. The O-CU-CP terminates E2 interface to Near-RT RIC and is
        managed via O1 interface by the SMO.

        Note: O-CU-CP is a concrete class that extends the ORANNetworkFunction
        abstract class. In Topology, you can create, read, update, and delete the
        O-CU-CP object.
            
        The management characteristics of the O-CU-CP O-RAN NF is represented by
        the IOC GNBCUCPFunction as specified in 3GPP NR NRM model, as per 3GPP TS
        28.541";

        container attributes {
            description "Container for O-RAN Central Unit – Control Plane (O-CU-CP) attributes";
            leaf gNBCUName {
                type string;
                description "Name of gNodeB-CU";
            }

            leaf gNBId {
                type int64;
                description "Identity of gNodeB within a PLMN";
            }

            leaf gNBIdLength {
                description "Length of gNBId bit string representation";
                type int32;
            }

            container pLMNId {
                uses types3gpp:PLMNId;
                description "PLMN identifier to be used as part of global RAN node identity";
            }
        }
    }

    list OCUUPFunction {        
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "O-RAN Centralized Unit User Plane (O-CU-UP)

        The O-CU-UP terminates the NG-u, X2-u, Xn-u, F1-u, and E1 interfaces as
        well as the PDCP and SDAP protocols towards the UE as defined by 3GPP TS
        38.401. The O-CU-UP terminates E2 interface to Near-RT RIC and is managed
        via O1 interface by the SMO.

        Note: O-CU-UP is a concrete class that extends the ORANNetworkFunction
        abstract class. In Topology, you can create, read, update, and delete the
        O-CU-UP object.

        The management characteristics of the O-CU-UP O-RAN NF is represented by
        the IOC GNBCUUPFunction as specified in 3GPP NR NRM model, as per 3GPP TS
        28.541";

        container attributes {
            description "Container for O-RAN Central Unit – User Plane (O-CU-UP) attributes";
            leaf gNBId {
                type int64;
                description "Identity of gNodeB within a PLMN";
            }

            leaf gNBIdLength {
                type int32;
                description "Length of gNBId bit string representation";
            }

            list pLMNIdList {
                key "mcc mnc";
                description "List of unique identities for PLMN";
                uses types3gpp:PLMNId;
            }
        }
    }

    list NearRTRICFunction {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "Near-Real-Time RAN Intelligent Controller (Near-RT RIC).

        Near-RT RIC is an O-RAN NF that enables near real-time control and
        optimization of services and resources of E2 Nodes via fine-grained data
        collection and actions over the E2 interface with control loops in the
        order of 10 ms-1s.";


        container attributes {
            description "Container for Near-Real-Time RAN Intelligent Controller (Near-RT RIC) attributes";
            container pLMNId {
                description "PLMN identifier to be used as part of global RAN node identity";
                uses types3gpp:PLMNId;
            }

            leaf nearRtRicId {
                    type int64;
                    description "Identifier of Near-RT RIC";
                }
            }
    }

    list ORUFunction {

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "O-RAN Radio Unit (O-RU)

        The O-RU terminates the Open Fronthaul interface (also known as LLS
        interface) as well as Low-PHY functions of the radio interface towards 
        the UE. This is deployed as a PNF.

        The O-RU terminates the Open Fronthaul M-Plane interface towards the O-DU
        and SMO.";


        container attributes {
            description "Container for O-RAN Radio Unit (O-RU) attributes";
            leaf oruId {
                type int64;
                description "Identity of the O-RU as discovered from the source domain based on M-Plane architecture model";
            }
        }
    }

    list NRCellCU {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "Represents an NR Cell in gNodeB-CU.

        5G NR is a new radio access technology (RAT) developed by 3GPP for
        the 5G (fifth generation) mobile network. It is designed to be the
        global standard for the air interface of 5G networks.

        5G NR has synchronization signal that is known as Primary
        Synchronization Signal (PSS) and Secondary Synchronization
        Signal (SSS). These signals are specific to NR physical layer and
        provide the following information required by UE for downlink
        synchronization: PSS provides Radio Frame Boundary (Position of 1st
        Symbol in a Radio frame) SSS provides Subframe Boundary (Position of
        1st Symbol in a Subframe) Physical Layer Cell ID (PCI) information
        using both PSS and SSS.";

        container attributes {
            leaf cellLocalId {
                description "Used together with gNodeB identifier to identify NR
                cell in PLMN. Used together with gNBId to form NCI.";
                type int32;
            }

            container plmnId {
                description "PLMN ID for NR CGI. If empty,
                GNBCUCPFunction::pLMNId is used for PLMN ID in NR CGI";
                uses types3gpp:PLMNId;
            }

            leaf nCI {
                description "NR Cell Identity";
                type int64;
            }

            leaf nRTAC {
                description "NR Tracking Area Code (TAC)";
                type int32;
            }
        }
    }

    list NRCellDU {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "Represents an NR Cell in gNodeB-DU.

        5G NR is a new radio access technology (RAT) developed by 3GPP for
        the 5G (fifth generation) mobile network. It is designed to be the
        global standard for the air interface of 5G networks.

        5G NR has synchronization signal that is known as Primary
        Synchronization signal (PSS) and Secondary Synchronization signal
        (SSS). These signals are specific to NR physical layer and provide
        the following information required by UE for downlink
        synchronization: PSS provides Radio Frame Boundary (Position of 1st
        Symbol in a Radio frame) SSS provides Subframe Boundary (Position of
        1st Symbol in a Subframe) Physical Layer Cell ID (PCI) information
        using both PSS and SSS.";

        container attributes {
            leaf cellLocalId {
                description "Used together with gNodeB identifier to identify NR
                cell in PLMN. Used together with gNBId to form NCI.";
                type int32;
            }

            leaf nCI {
                description "NR Cell Identity.";
                type int64;
            }

            leaf nRPCI {
                description "The Physical Cell Identity (PCI) of the NR cell.";
                type int32;
            }

            leaf nRTAC {
                description "NR Tracking Area Code (TAC).";
                type int32;
            }
        }
    }

    list NRSectorCarrier {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "The NR Sector Carrier object provides the attributes for
        defining the logical characteristics of a carrier (cell) in a
        sector. A sector is a coverage area associated with a base station
        having its own antennas, radio ports, and control channels. The
        concept of sectors was developed to improve co-channel interference
        in cellular systems, and most wireless systems use three sector
        cells.";

        container attributes {
            leaf arfcnDL {
                description "NR Absolute Radio Frequency Channel Number
                (NR-ARFCN) for downlink";
                type int32;
            }

            leaf arfcnUL {
                description "NR Absolute Radio frequency Channel Number
                (NR-ARFCN) for uplink.";
                type int32;
            }

            leaf frequencyDL {
                description "RF Reference Frequency of downlink channel";
                type int32;
            }

            leaf frequencyUL {
                description "RF Reference Frequency of uplink channel";
                type int32;
            }

            leaf bSChannelBwDL {
                description "BS Channel bandwidth in MHz for downlink.";
                type int32;
            }
        }
    }

    list AntennaCapability {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "This MO serves as a mapping between the cell and the RBS
        equipment used to provide coverage in a certain geographical area.
        The MO also controls the maximum output power of the sector.";

        container attributes {
            leaf-list eUtranFqBands {
                description "List of LTE frequency bands that associated
                hardware supports";
                type string;
            }

            leaf-list geranFqBands {
                description "List of GERAN frequency bands that associated
                hardware supports";
                type string;
            }

            leaf-list nRFqBands {
                description "List of NR frequency bands associated hardware
                supports";
                type string;
            }
        }
    }

    list Sector {
        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        description "A group of co-located Cells that have a shared
        coverage area.";

        container attributes {
            leaf sectorId {
                description "Universally unique ID generated by the sector's
                discovery mechanism.";
                type uint64;
            }

            uses geo:geo-location;

            leaf azimuth {
                description "Average value of the azimuths of the cells
                comprising the sector, determined during sector discovery.";
                type decimal64{
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }
        }
    }


    or-teiv-yext:biDirectionalTopologyRelationship ODUFUNCTION_PROVIDES_NRCELLDU { // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ODUFunction type.
            The bSide of this relationship is an instance of the NRCellDU type.
            The ODUFunction represents the DU component of a gNB that provides the NRCellDU.
            A ODUFunction instance can provide many NRCellDUs.
            An NRCellDU instance must be provided by an ODUFunction.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list provided-nrCellDu {
            description "O-DU Function provides NR Cell-DU.";
            or-teiv-yext:aSide ODUFunction;
            type instance-identifier;
        }

        leaf provided-by-oduFunction {
            description "NR Cell-DU provided by O-DU Function.";
            or-teiv-yext:bSide NRCellDU;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship ODUFUNCTION_PROVIDES_NRSECTORCARRIER { // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ODUFunction type.
            The bSide of this relationship is an instance of the NRSectorCarrier type.
            The ODUFunction represents the DU component of a gNB that provides the NRSectorCarrier.
            A ODUFunction instance can provide many NRSectorCarriers.
            An NRSectorCarrier instance must be provided by an ODUFunction.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list provided-nrSectorCarrier {
            description "O-DU Function provides NR Sector Carrier.";
            or-teiv-yext:aSide ODUFunction;
            type instance-identifier;
        }

        leaf provided-by-oduFunction {
            description "NR Sector Carrier provided by O-DU Function.";
            or-teiv-yext:bSide NRSectorCarrier;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship OCUCPFUNCTION_PROVIDES_NRCELLCU { // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the OCUCPFunction type.
            The bSide of this relationship is an instance of the NRCellCU type.
            The OCUCPFunction represents the CU-CP component of a gNB that provides the NRCellCU.
            A OCUCPFunction instance can provide many NRCellCU.
            An NRCellCU instance must be provided by an OCUCPFunction.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list provided-nrCellCu {
            description "O-CU-CP Function provides NR Cell-CU.";
            or-teiv-yext:aSide OCUCPFunction;
            type instance-identifier;
        }

        leaf provided-by-ocucpFunction {
            description "NR Cell-CU provided by O-CU-CP Function.";
            or-teiv-yext:bSide NRCellCU;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship NRCELLDU_USES_NRSECTORCARRIER { // 0..1 to 0..n

        description
            "The aSide of this relationship is an instance of the NRCellDU type.
            The bSide of this relationship is an instance of the NRSectorCarrier type.
            The NRCellDU represents the cell that uses the NRSectorCarrier.
            An NRCellDU instance can use many NRSectorCarriers.
            An NRSectorCarrier instance can only be used by one NRCellDU.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list used-nrSectorCarrier {
            description "NR Cell-DU uses NR Sector Carrier.";
            or-teiv-yext:aSide NRCellDU;
            type instance-identifier;
        }

        leaf used-by-nrCellDu {
            description "NR Sector Carrier used by NR Cell-DU.";
            or-teiv-yext:bSide NRSectorCarrier;
            type instance-identifier;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship NRSECTORCARRIER_USES_ANTENNACAPABILITY { // 0..n to 0..1

        description
            "The aSide of this relationship is an instance of the NRSectorCarrier type.
            The bSide of this relationship is an instance of the AntennaCapability type.
            The NRSectorCarrier represents the carrier that uses the AntennaCapability.
            An NRSectorCarrier instance can use only one AntennaCapability.
            An AntennaCapability instance can be used by many NRSectorCarriers.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf used-antennaCapability {
            description "NR Sector Carrier uses Antenna Capability.";
            or-teiv-yext:aSide NRSectorCarrier;
            type instance-identifier;
        }

        leaf-list used-by-nrSectorCarrier {
            description "Antenna Capability used by NR Sector Carrier.";
            or-teiv-yext:bSide AntennaCapability;
            type instance-identifier;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship SECTOR_GROUPS_NRCELLDU { // 0..1 to 0..n

        description
            "The aSide of this relationship is an instance of the Sector type.
            The bSide of this relationship is an instance of the NRCellDU type.
            The Sector represents the geographical area that groups the NRCellDUs.
            A Sector instance can group many NRCellDUs.
            An NRCellDU instance can only be grouped by one Sector.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list grouped-nrCellDu {
            description "Sector groups NR Cell-DU.";
            or-teiv-yext:aSide Sector;
            type instance-identifier;
        }

        leaf grouped-by-sector {
            description "NR Cell-DU grouped by Sector.";
            or-teiv-yext:bSide NRCellDU;
            type instance-identifier;
        }
    }
}
+o-ran-smo-teiv-rel-cloud-ran   urn:o-ran:smo-teiv-rel-cloud-ran        REL_CLOUD_RAN   ["o-ran-smo-teiv-cloud", "o-ran-smo-teiv-ran"]  2024-10-04      bW9kdWxlIG8tcmFuLXNtby10ZWl2LXJlbC1jbG91ZC1yYW4gewogICAgeWFuZy12ZXJzaW9uIDEuMTsKICAgIG5hbWVzcGFjZSAidXJuOm8tcmFuOnNtby10ZWl2LXJlbC1jbG91ZC1yYW4iOwogICAgcHJlZml4IG9yLXRlaXYtY2xvdWR0b3JhbjsKCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctdHlwZXMge3ByZWZpeCBvci10ZWl2LXR5cGVzOyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LWNvbW1vbi15YW5nLWV4dGVuc2lvbnMge3ByZWZpeCBvci10ZWl2LXlleHQ7IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY2xvdWQge3ByZWZpeCBvci10ZWl2LWNsb3VkOyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LXJhbiB7cHJlZml4IG9yLXRlaXYtcmFuOyB9CgogICAgb3JnYW5pemF0aW9uICJPUkFOIjsKICAgIGNvbnRhY3QgIlRoZSBBdXRob3JzIjsKICAgIGRlc2NyaXB0aW9uCiAgICAgICAgIlJBTiBDbG91ZCB0byBSQU4gTG9naWNhbCB0b3BvbG9neSBtb2RlbC4KCiAgICAgICAgVGhpcyBtb2RlbCBjb250YWlucyB0aGUgUkFOIENsb3VkIHRvIFJBTiBMb2dpY2FsIHRvcG9sb2d5IHJlbGF0aW9ucy4KCiAgICAgICAgQ29weXJpZ2h0IChDKSAyMDI0IEVyaWNzc29uCiAgICAgICAgTW9kaWZpY2F0aW9ucyBDb3B5cmlnaHQgKEMpIDIwMjQgT3BlbkluZnJhIEZvdW5kYXRpb24gRXVyb3BlCgogICAgICAgIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIik7CiAgICAgICAgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLgogICAgICAgIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdAoKICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjAKCiAgICAgICAgVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZQogICAgICAgIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUywKICAgICAgICBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC4KICAgICAgICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kCiAgICAgICAgbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuCgogICAgICAgIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wIjsKCiAgICByZXZpc2lvbiAiMjAyNC0xMC0wNCIgewogICAgICAgIGRlc2NyaXB0aW9uICJBZGRlZCBncm91cGluZywgT3JpZ2luX1JlbGF0aW9uc2hpcF9NYXBwaW5nX0dycCB0byB0aGUgdG9wb2xvZ3kgb2JqZWN0LiI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuNC4wOwogICAgfQoKICAgIHJldmlzaW9uICIyMDI0LTA1LTAyIiB7CiAgICAgICAgZGVzY3JpcHRpb24gIkluaXRpYWwgcmV2aXNpb24uIjsKICAgICAgICBvci10ZWl2LXlleHQ6bGFiZWwgMC4zLjA7CiAgICB9CgogICAgcmV2aXNpb24gIjIwMjQtMDctMTUiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiVGhpcyByZXZpc2lvbiBhbGlnbnMgTy1SQU4gV29yayBHcm91cCAxMCBTdGFnZSAyIFNwZWNpZmljYXRpb24gKE8tUkFOLldHMTAuVEUmSVYtQ0lNSS4wLVIwMDQudjAyLjAwKSI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuNC4wOwogICAgfQoKICAgIG9yLXRlaXYteWV4dDpkb21haW4gUkVMX0NMT1VEX1JBTjsKCiAgICBvci10ZWl2LXlleHQ6YmlEaXJlY3Rpb25hbFRvcG9sb2d5UmVsYXRpb25zaGlwIE5GREVQTE9ZTUVOVF9TRVJWRVNfT0RVRlVOQ1RJT04geyAvLyAwLi5uIHRvIDAuLm0KCiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOlRvcF9HcnBfVHlwZTsKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6T3JpZ2luX1JlbGF0aW9uc2hpcF9NYXBwaW5nX0dycDsKICAgICAgICBrZXkgaWQ7CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aWNlZC1vZHVGdW5jdGlvbiB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJPLURVIEZ1bmN0aW9uIHNlcnZpY2VkIGJ5IHRoaXMgTkYgRGVwbG95bWVudC4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YVNpZGUgb3ItdGVpdi1jbG91ZDpORkRlcGxveW1lbnQ7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aW5nLW5GRGVwbG95bWVudCB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJORiBEZXBsb3ltZW50IHRoYXQgc2VydmVzIHRoaXMgTy1EVSBGdW5jdGlvbi4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YlNpZGUgb3ItdGVpdi1yYW46T0RVRnVuY3Rpb247CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CiAgICB9CgogICAgb3ItdGVpdi15ZXh0OmJpRGlyZWN0aW9uYWxUb3BvbG9neVJlbGF0aW9uc2hpcCBORkRFUExPWU1FTlRfU0VSVkVTX09DVUNQRlVOQ1RJT04geyAvLyAwLi5uIHRvIDAuLm0KCiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOlRvcF9HcnBfVHlwZTsKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6T3JpZ2luX1JlbGF0aW9uc2hpcF9NYXBwaW5nX0dycDsKICAgICAgICBrZXkgaWQ7CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aWNlZC1vY3VjcEZ1bmN0aW9uIHsKICAgICAgICAgICAgZGVzY3JpcHRpb24gIk8tQ1UtQ1AgRnVuY3Rpb24gc2VydmljZWQgYnkgdGhpcyBORiBEZXBsb3ltZW50LiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LWNsb3VkOk5GRGVwbG95bWVudDsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KCiAgICAgICAgbGVhZi1saXN0IHNlcnZpbmctbkZEZXBsb3ltZW50IHsKICAgICAgICAgICAgZGVzY3JpcHRpb24gIk5GIERlcGxveW1lbnQgdGhhdCBzZXJ2ZXMgdGhpcyBPLUNVLUNQIEZ1bmN0aW9uLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDpiU2lkZSBvci10ZWl2LXJhbjpPQ1VDUEZ1bmN0aW9uOwogICAgICAgICAgICB0eXBlIGluc3RhbmNlLWlkZW50aWZpZXI7CiAgICAgICAgfQogICAgfQoKICAgIG9yLXRlaXYteWV4dDpiaURpcmVjdGlvbmFsVG9wb2xvZ3lSZWxhdGlvbnNoaXAgTkZERVBMT1lNRU5UX1NFUlZFU19PQ1VVUEZVTkNUSU9OIHsgLy8gMC4ubiB0byAwLi5tCgogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpUb3BfR3JwX1R5cGU7CiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOk9yaWdpbl9SZWxhdGlvbnNoaXBfTWFwcGluZ19HcnA7CiAgICAgICAga2V5IGlkOwoKICAgICAgICBsZWFmLWxpc3Qgc2VydmljZWQtb2N1dXBGdW5jdGlvbiB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJPLUNVLVVQIEZ1bmN0aW9uIHNlcnZpY2VkIGJ5IHRoaXMgTkYgRGVwbG95bWVudC4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YVNpZGUgb3ItdGVpdi1jbG91ZDpORkRlcGxveW1lbnQ7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aW5nLW5GRGVwbG95bWVudCB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJORiBEZXBsb3ltZW50IHRoYXQgc2VydmVzIHRoaXMgTy1DVS1VUCBGdW5jdGlvbi4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YlNpZGUgb3ItdGVpdi1yYW46T0NVVVBGdW5jdGlvbjsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KICAgIH0KCiAgICBvci10ZWl2LXlleHQ6YmlEaXJlY3Rpb25hbFRvcG9sb2d5UmVsYXRpb25zaGlwIE5GREVQTE9ZTUVOVF9TRVJWRVNfTkVBUlJUUklDRlVOQ1RJT04geyAvLyAwLi5uIHRvIDAuLm0KCiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOlRvcF9HcnBfVHlwZTsKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6T3JpZ2luX1JlbGF0aW9uc2hpcF9NYXBwaW5nX0dycDsKICAgICAgICBrZXkgaWQ7CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aWNlZC1uZWFyUlRSSUNGdW5jdGlvbiB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJOZWFyUlRSSUNGdW5jdGlvbiBzZXJ2aWNlZCBieSB0aGlzIE5GIERlcGxveW1lbnQuIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmFTaWRlIG9yLXRlaXYtY2xvdWQ6TkZEZXBsb3ltZW50OwogICAgICAgICAgICB0eXBlIGluc3RhbmNlLWlkZW50aWZpZXI7CiAgICAgICAgfQoKICAgICAgICBsZWFmLWxpc3Qgc2VydmluZy1uRkRlcGxveW1lbnQgewogICAgICAgICAgICBkZXNjcmlwdGlvbiAiTkYgRGVwbG95bWVudCB0aGF0IHNlcnZlcyB0aGlzIE5lYXJSVFJJQ0Z1bmN0aW9uLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDpiU2lkZSBvci10ZWl2LXJhbjpOZWFyUlRSSUNGdW5jdGlvbjsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KICAgIH0KfQ==
+o-ran-smo-teiv-rel-equipment-ran       urn:o-ran:smo-teiv-rel-equipment-ran    REL_EQUIPMENT_RAN       ["o-ran-smo-teiv-equipment", "o-ran-smo-teiv-ran"]      2024-10-08      bW9kdWxlIG8tcmFuLXNtby10ZWl2LXJlbC1lcXVpcG1lbnQtcmFuIHsKICAgIHlhbmctdmVyc2lvbiAxLjE7CiAgICBuYW1lc3BhY2UgInVybjpvLXJhbjpzbW8tdGVpdi1yZWwtZXF1aXBtZW50LXJhbiI7CiAgICBwcmVmaXggb3ItdGVpdi1yZWwtZXF1aXByYW47CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LWNvbW1vbi15YW5nLXR5cGVzIHsgcHJlZml4IG9yLXRlaXYtdHlwZXM7IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctZXh0ZW5zaW9ucyB7IHByZWZpeCBvci10ZWl2LXlleHQ7IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtZXF1aXBtZW50IHsgcHJlZml4IG9yLXRlaXYtZXF1aXA7IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtcmFuIHsgcHJlZml4IG9yLXRlaXYtcmFuOyB9CgoKICAgIG9yZ2FuaXphdGlvbiAiT1JBTiI7CiAgICBjb250YWN0ICJUaGUgQXV0aG9ycyI7CiAgICBkZXNjcmlwdGlvbiAKICAgICJSQU4gRXF1aXBtZW50IHRvIExvZ2ljYWwgdG9wb2xvZ3kgbW9kZWwuCgogICAgVGhpcyBtb2RlbCBjb250YWlucyB0aGUgUkFOIEVxdWlwbWVudCB0byBMb2dpY2FsIHRvcG9sb2d5CiAgICBlbnRpdGllcyBhbmQgcmVsYXRpb25zLgoKICAgIENvcHlyaWdodCAoQykgMjAyNCBFcmljc3NvbgogICAgTW9kaWZpY2F0aW9ucyBDb3B5cmlnaHQgKEMpIDIwMjQgT3BlbkluZnJhIEZvdW5kYXRpb24gRXVyb3BlCgogICAgTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTsKICAgIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS4KICAgIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdAoKICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMAoKICAgIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmUKICAgIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUywKICAgIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLgogICAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZAogICAgbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuCgogICAgU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjAiOwoKICAgIHJldmlzaW9uICIyMDI0LTEwLTA4IiB7CiAgICAgICAgZGVzY3JpcHRpb24KICAgICAgICAgICAgIkFkZGVkIG5ldyByZWxhdGlvbnNoaXAgQU5URU5OQU1PRFVMRV9TRVJWRVNfTlJDRUxMRFUuIjsKICAgICAgICBvci10ZWl2LXlleHQ6bGFiZWwgMC41LjA7CiAgICB9CgogICAgcmV2aXNpb24gIjIwMjQtMTAtMDQiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiQWRkZWQgZ3JvdXBpbmcsIE9yaWdpbl9SZWxhdGlvbnNoaXBfTWFwcGluZ19HcnAgdG8gdGhlIHRvcG9sb2d5IG9iamVjdC4iOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjQuMDsKICAgIH0KCiAgICByZXZpc2lvbiAiMjAyNC0wNS0yNCIgewogICAgICAgIGRlc2NyaXB0aW9uICJJbml0aWFsIHJldmlzaW9uLiI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuMy4wOwogICAgfQoKICAgIG9yLXRlaXYteWV4dDpkb21haW4gUkVMX0VRVUlQTUVOVF9SQU47CgogICAgb3ItdGVpdi15ZXh0OmJpRGlyZWN0aW9uYWxUb3BvbG9neVJlbGF0aW9uc2hpcCBBTlRFTk5BTU9EVUxFX1NFUlZFU19BTlRFTk5BQ0FQQUJJTElUWSB7IC8vIDAuLm4gdG8gMC4ubQoKICAgICAgICBkZXNjcmlwdGlvbgogICAgICAgICAgICAiVGhlIGFTaWRlIG9mIHRoaXMgcmVsYXRpb25zaGlwIGlzIGFuIGluc3RhbmNlIG9mIHRoZSBBbnRlbm5hTW9kdWxlIHR5cGUuCiAgICAgICAgICAgIFRoZSBiU2lkZSBvZiB0aGlzIHJlbGF0aW9uc2hpcCBpcyBhbiBpbnN0YW5jZSBvZiB0aGUgQW50ZW5uYUNhcGFiaWxpdHkgdHlwZS4KICAgICAgICAgICAgVGhlIEFudGVubmFNb2R1bGUgcmVwcmVzZW50cyB0aGUgcGh5c2ljYWwgYW50ZW5uYSB0aGF0IHNlcnZlcyB0aGUgQW50ZW5uYUNhcGFiaWxpdHkuCiAgICAgICAgICAgIEFuIEFudGVubmFNb2R1bGUgaW5zdGFuY2UgY2FuIHNlcnZlIG1hbnkgQW50ZW5uYUNhcGFiaWxpdGllcy4KICAgICAgICAgICAgQW4gQW50ZW5uYUNhcGFiaWxpdHkgaW5zdGFuY2UgY2FuIGJlIHNlcnZlZCBieSBtYW55IEFudGVubmFNb2R1bGVzLgogICAgICAgICAgICAiOwoKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6VG9wX0dycF9UeXBlOwogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpPcmlnaW5fUmVsYXRpb25zaGlwX01hcHBpbmdfR3JwOwogICAgICAgIGtleSBpZDsKCiAgICAgICAgbGVhZi1saXN0IHNlcnZpY2VkLWFudGVubmFDYXBhYmlsaXR5IHsKICAgICAgICAgICAgZGVzY3JpcHRpb24gIkFudGVubmEgQ2FwYWJpbGl0eSBzZXJ2aWNlZCBieSB0aGlzIEFudGVubmEgTW9kdWxlLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LWVxdWlwOkFudGVubmFNb2R1bGU7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aW5nLWFudGVubmFNb2R1bGUgewogICAgICAgICAgICBkZXNjcmlwdGlvbiAiQW50ZW5uYSBNb2R1bGUgc2VydmVzIHRoaXMgQW50ZW5uYSBDYXBhYmlsaXR5LiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDpiU2lkZSBvci10ZWl2LXJhbjpBbnRlbm5hQ2FwYWJpbGl0eTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KICAgIH0KCiAgICBvci10ZWl2LXlleHQ6YmlEaXJlY3Rpb25hbFRvcG9sb2d5UmVsYXRpb25zaGlwIEFOVEVOTkFNT0RVTEVfU0VSVkVTX05SQ0VMTERVIHsgLy8gMS4ubiB0byAwLi5tCgogICAgICAgIGRlc2NyaXB0aW9uCiAgICAgICAgICAgICJUaGUgYVNpZGUgb2YgdGhpcyByZWxhdGlvbnNoaXAgaXMgYW4gaW5zdGFuY2Ugb2YgdGhlIEFudGVubmFNb2R1bGUgdHlwZS4KICAgICAgICAgICAgVGhlIGJTaWRlIG9mIHRoaXMgcmVsYXRpb25zaGlwIGlzIGFuIGluc3RhbmNlIG9mIHRoZSBOUkNlbGxEVSB0eXBlLgogICAgICAgICAgICBUaGUgQW50ZW5uYU1vZHVsZSByZXByZXNlbnRzIHRoZSBwaHlzaWNhbCBhbnRlbm5hIHRoYXQgc2VydmVzIHRoZSBOUkNlbGxEVS4KICAgICAgICAgICAgQW4gQW50ZW5uYU1vZHVsZSBpbnN0YW5jZSBjYW4gc2VydmUgbWFueSBOUkNlbGxEVXMuCiAgICAgICAgICAgIEFuIE5SQ2VsbERVIGluc3RhbmNlIGNhbiBiZSBzZXJ2ZWQgYnkgbWFueSBBbnRlbm5hTW9kdWxlcy4KICAgICAgICAgICAgIjsKCiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOlRvcF9HcnBfVHlwZTsKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6T3JpZ2luX1JlbGF0aW9uc2hpcF9NYXBwaW5nX0dycDsKICAgICAgICBrZXkgaWQ7CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aWNlZC1uckNlbGxEdSB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJOUiBDZWxsLURVIHNlcnZpY2VkIGJ5IHRoaXMgQW50ZW5uYSBNb2R1bGUuIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmFTaWRlIG9yLXRlaXYtZXF1aXA6QW50ZW5uYU1vZHVsZTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KCiAgICAgICAgbGVhZi1saXN0IHNlcnZpbmctYW50ZW5uYU1vZHVsZSB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJBbnRlbm5hIE1vZHVsZSBzZXJ2ZXMgdGhpcyBOUiBDZWxsLURVLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDpiU2lkZSBvci10ZWl2LXJhbjpOUkNlbGxEVTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgICAgICBtaW4tZWxlbWVudHMgMTsKICAgICAgICB9CiAgICB9CgogICAgb3ItdGVpdi15ZXh0OmJpRGlyZWN0aW9uYWxUb3BvbG9neVJlbGF0aW9uc2hpcCBTRUNUT1JfR1JPVVBTX0FOVEVOTkFNT0RVTEUgeyAvLyAwLi4xIHRvIDAuLm4KCiAgICAgICAgZGVzY3JpcHRpb24KICAgICAgICAgICAgIlRoZSBhU2lkZSBvZiB0aGlzIHJlbGF0aW9uc2hpcCBpcyBhbiBpbnN0YW5jZSBvZiB0aGUgU2VjdG9yIHR5cGUuCiAgICAgICAgICAgIFRoZSBiU2lkZSBvZiB0aGlzIHJlbGF0aW9uc2hpcCBpcyBhbiBpbnN0YW5jZSBvZiB0aGUgQW50ZW5uYU1vZHVsZSB0eXBlLgogICAgICAgICAgICBUaGUgU2VjdG9yIHJlcHJlc2VudHMgdGhlIGdlb2dyYXBoaWNhbCBhcmVhIHRoYXQgZ3JvdXBzIHRoZSBBbnRlbm5hTW9kdWxlcy4KICAgICAgICAgICAgQSBTZWN0b3IgaW5zdGFuY2UgY2FuIGdyb3VwIG1hbnkgQW50ZW5uYU1vZHVsZXMuCiAgICAgICAgICAgIEFuIEFudGVubmFNb2R1bGUgaW5zdGFuY2UgY2FuIG9ubHkgYmUgZ3JvdXBlZCBieSBvbmUgU2VjdG9yLgogICAgICAgICAgICAiOwoKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6VG9wX0dycF9UeXBlOwogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpPcmlnaW5fUmVsYXRpb25zaGlwX01hcHBpbmdfR3JwOwogICAgICAgIGtleSBpZDsKCiAgICAgICAgbGVhZi1saXN0IGdyb3VwZWQtYW50ZW5uYU1vZHVsZSB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJTZWN0b3IgZ3JvdXBzIEFudGVubmEgTW9kdWxlLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LXJhbjpTZWN0b3I7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYgZ3JvdXBlZC1ieS1zZWN0b3IgewogICAgICAgICAgICBkZXNjcmlwdGlvbiAiQW50ZW5uYSBNb2R1bGUgZ3JvdXBlZCBieSBTZWN0b3IuIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmJTaWRlIG9yLXRlaXYtZXF1aXA6QW50ZW5uYU1vZHVsZTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KICAgIH0KfQ==
+o-ran-smo-teiv-rel-oam-cloud   urn:o-ran:smo-teiv-rel-oam-cloud        REL_OAM_CLOUD   ["o-ran-smo-teiv-oam", "o-ran-smo-teiv-cloud"]  2024-10-04      bW9kdWxlIG8tcmFuLXNtby10ZWl2LXJlbC1vYW0tY2xvdWQgewogICAgeWFuZy12ZXJzaW9uIDEuMTsKICAgIG5hbWVzcGFjZSAidXJuOm8tcmFuOnNtby10ZWl2LXJlbC1vYW0tY2xvdWQiOwogICAgcHJlZml4IG9yLXRlaXYtb2FtdG9jbG91ZDsKCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctdHlwZXMge3ByZWZpeCBvci10ZWl2LXR5cGVzOyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LWNvbW1vbi15YW5nLWV4dGVuc2lvbnMge3ByZWZpeCBvci10ZWl2LXlleHQ7IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtb2FtIHtwcmVmaXggb3ItdGVpdi1vYW07IH0KCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY2xvdWQge3ByZWZpeCBvci10ZWl2LWNsb3VkOyB9CgogICAgb3JnYW5pemF0aW9uICJPUkFOIjsKICAgIGNvbnRhY3QgIlRoZSBBdXRob3JzIjsKICAgIGRlc2NyaXB0aW9uCiAgICAgICAgIlJBTiBPJk0gdG8gQ2xvdWQgdG9wb2xvZ3kgbW9kZWwuCgogICAgICAgIFRoaXMgbW9kZWwgY29udGFpbnMgdGhlIFJBTiBPJk0gdG8gQ2xvdWQgdG9wb2xvZ3kgcmVsYXRpb25zCgogICAgICAgIENvcHlyaWdodCAoQykgMjAyNCBFcmljc3NvbgogICAgICAgIE1vZGlmaWNhdGlvbnMgQ29weXJpZ2h0IChDKSAyMDI0IE9wZW5JbmZyYSBGb3VuZGF0aW9uIEV1cm9wZQoKICAgICAgICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpOwogICAgICAgIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS4KICAgICAgICBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXQKCiAgICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wCgogICAgICAgIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmUKICAgICAgICBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsCiAgICAgICAgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuCiAgICAgICAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZAogICAgICAgIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLgoKICAgICAgICBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMCI7CgogICAgcmV2aXNpb24gIjIwMjQtMTAtMDQiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiQWRkZWQgZ3JvdXBpbmcsIE9yaWdpbl9SZWxhdGlvbnNoaXBfTWFwcGluZ19HcnAgdG8gdGhlIHRvcG9sb2d5IG9iamVjdC4iOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjQuMDsKICAgIH0KCiAgICByZXZpc2lvbiAiMjAyNC0wNS0wMiIgewogICAgICAgIGRlc2NyaXB0aW9uICJJbml0aWFsIHJldmlzaW9uLiI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuMy4wOwogICAgfQoKICAgIHJldmlzaW9uICIyMDI0LTA3LTE1IiB7CiAgICAgICAgZGVzY3JpcHRpb24gIlRoaXMgcmV2aXNpb24gYWxpZ25zIE8tUkFOIFdvcmsgR3JvdXAgMTAgU3RhZ2UgMiBTcGVjaWZpY2F0aW9uIChPLVJBTi5XRzEwLlRFJklWLUNJTUkuMC1SMDA0LnYwMi4wMCkiOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjQuMDsKICAgIH0KCiAgICBvci10ZWl2LXlleHQ6ZG9tYWluIFJFTF9PQU1fQ0xPVUQ7CgogICAgb3ItdGVpdi15ZXh0OmJpRGlyZWN0aW9uYWxUb3BvbG9neVJlbGF0aW9uc2hpcCBNQU5BR0VERUxFTUVOVF9ERVBMT1lFRF9BU19DTE9VRElGSUVETkYgeyAgLy8gMC4uMSB0byAxCgogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpUb3BfR3JwX1R5cGU7CiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOk9yaWdpbl9SZWxhdGlvbnNoaXBfTWFwcGluZ19HcnA7CiAgICAgICAga2V5IGlkOwoKICAgICAgICBsZWFmIGRlcGxveWVkLWFzLWNsb3VkaWZpZWRORiB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJNYW5hZ2VkIEVsZW1lbnQgZGVwbG95ZWQgYXMgQ2xvdWRpZmllZCBORi4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YVNpZGUgb3ItdGVpdi1vYW06TWFuYWdlZEVsZW1lbnQ7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYgZGVwbG95ZWQtbWFuYWdlZEVsZW1lbnQgewogICAgICAgICAgICBkZXNjcmlwdGlvbiAiQ2xvdWRpZmllZCBORiBkZXBsb3lzIE1hbmFnZWQgRWxlbWVudC4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YlNpZGUgb3ItdGVpdi1jbG91ZDpDbG91ZGlmaWVkTkY7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICAgICAgbWFuZGF0b3J5IHRydWU7CiAgICAgICAgfQogICAgfQoKICAgIG9yLXRlaXYteWV4dDpiaURpcmVjdGlvbmFsVG9wb2xvZ3lSZWxhdGlvbnNoaXAgTkZERVBMT1lNRU5UX1NFUlZFU19NQU5BR0VERUxFTUVOVCB7IC8vIDEuLm4gdG8gMQoKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6VG9wX0dycF9UeXBlOwogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpPcmlnaW5fUmVsYXRpb25zaGlwX01hcHBpbmdfR3JwOwogICAgICAgIGtleSBpZDsKCiAgICAgICAgbGVhZiBzZXJ2aWNlZC1tYW5hZ2VkRWxlbWVudCB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJNYW5hZ2VkIEVsZW1lbnQgc2VydmljZWQgYnkgdGhpcyBORiBEZXBsb3ltZW50LiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LWNsb3VkOk5GRGVwbG95bWVudDsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgICAgICBtYW5kYXRvcnkgdHJ1ZTsKICAgICAgICB9CgogICAgICAgIGxlYWYtbGlzdCBzZXJ2aW5nLW5GRGVwbG95bWVudCB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJORiBEZXBsb3ltZW50IHRoYXQgc2VydmVzIHRoaXMgTWFuYWdlZCBFbGVtZW50LiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDpiU2lkZSBvci10ZWl2LW9hbTpNYW5hZ2VkRWxlbWVudDsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgICAgICBtaW4tZWxlbWVudHMgMTsKICAgICAgICB9CiAgICB9Cn0=
+o-ran-smo-teiv-rel-oam-ran     urn:o-ran:smo-teiv-rel-oam-ran  REL_OAM_RAN     ["o-ran-smo-teiv-oam", "o-ran-smo-teiv-ran"]    2024-10-04      module o-ran-smo-teiv-rel-oam-ran {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-rel-oam-ran";
    prefix or-teiv-rel-oamran;

    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }

    import o-ran-smo-teiv-oam { prefix or-teiv-oam; }

    import o-ran-smo-teiv-ran { prefix or-teiv-ran; }

    organization "ORAN";
    contact "The Authors";
    description
        "RAN O&M to Logical topology model.

        This model contains the RAN O&M to Logical topology relations

        Copyright (C) 2024 Ericsson
        Modifications Copyright (C) 2024 OpenInfra Foundation Europe

        Licensed under the Apache License, Version 2.0 (the \"License\");
        you may not use this file except in compliance with the License.
        You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

        Unless required by applicable law or agreed to in writing, software
        distributed under the License is distributed on an \"AS IS\" BASIS,
        WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
        See the License for the specific language governing permissions and
        limitations under the License.

        SPDX-License-Identifier: Apache-2.0";

    revision "2024-10-04" {
        description "Added grouping, Origin_Relationship_Mapping_Grp to the topology object.";
        or-teiv-yext:label 0.5.0;
    }

    revision "2024-07-15" {
        description "This revision aligns O-RAN Work Group 10 Stage 2 Specification (O-RAN.WG10.TE&IV-CIMI.0-R004.v02.00)";
        or-teiv-yext:label 0.4.0;
    }

    revision "2024-05-24" {
        description "Initial revision.";
        or-teiv-yext:label 0.3.0;
    }

    or-teiv-yext:domain REL_OAM_RAN;

    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENT_MANAGES_ODUFUNCTION {    // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ManagedElement type.
            The bSide of this relationship is an instance of the ODUFunction type.
            The ManagedElement represents the node that manages the ODUFunction.
            A ManagedElement instance can manage many ODUFunctions.
            An ODUFunction instance must be managed by one ManagedElement.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list managed-oduFunction {
            description "Managed Element manages O-DU Function.";
            or-teiv-yext:aSide or-teiv-oam:ManagedElement;
            type instance-identifier;
        }

        leaf managed-by-managedElement {
            description "O-DU Function managed by Managed Element.";
            or-teiv-yext:bSide or-teiv-ran:ODUFunction;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENT_MANAGES_OCUCPFUNCTION {    // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ManagedElement type.
            The bSide of this relationship is an instance of the OCUCPFunction type.
            The ManagedElement represents the node that manages the OCUCPFunction.
            A ManagedElement instance can manage many OCUCPFunctions.
            An OCUCPFunction instance must be managed by one ManagedElement.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list managed-ocucpFunction {
            description "Managed Element manages O-CU-CP Function.";
            or-teiv-yext:aSide or-teiv-oam:ManagedElement;
            type instance-identifier;
        }

        leaf managed-by-managedElement {
            description "O-CU-CP Function managed by Managed Element.";
            or-teiv-yext:bSide or-teiv-ran:OCUCPFunction;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENT_MANAGES_OCUUPFUNCTION {    // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ManagedElement type.
            The bSide of this relationship is an instance of the OCUUPFunction type.
            The ManagedElement represents the node that manages the OCUUPFunction.
            A ManagedElement instance can manage many OCUUPFunctions.
            An OCUUPFunction instance must be managed by one ManagedElement.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list managed-ocuupFunction {
            description "Managed Element manages O-CU-UP Function.";
            or-teiv-yext:aSide or-teiv-oam:ManagedElement;
            type instance-identifier;
        }

        leaf managed-by-managedElement {
            description "O-CU-UP Function managed by Managed Element.";
            or-teiv-yext:bSide or-teiv-ran:OCUUPFunction;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENT_MANAGES_ORUFUNCTION {    // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ManagedElement type.
            The bSide of this relationship is an instance of the ORUFunction type.
            The ManagedElement represents the node that manages the ORUFunction.
            A ManagedElement instance can manage many ORUFunction.
            An ORUFunction instance must be managed by one ManagedElement.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list managed-oruFunction {
            description "Managed Element manages O-RU Function.";
            or-teiv-yext:aSide or-teiv-oam:ManagedElement;
            type instance-identifier;
        }

        leaf managed-by-managedElement {
            description "O-RU Function managed by Managed Element.";
            or-teiv-yext:bSide or-teiv-ran:ORUFunction;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION {    // 1 to 0..n

        description
            "The aSide of this relationship is an instance of the ManagedElement type.
            The bSide of this relationship is an instance of the NearRTRICFunction type.
            The ManagedElement represents the node that manages the NearRTRICFunction.
            A ManagedElement instance can manage many NearRTRICFunction.
            An NearRTRICFunction instance must be managed by one ManagedElement.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list managed-nearRTRICFunction {
            description "Managed Element manages Near RT RIC Function.";
            or-teiv-yext:aSide or-teiv-oam:ManagedElement;
            type instance-identifier;
        }

        leaf managed-by-managedElement {
            description "Near RT RIC Function managed by Managed Element.";
            or-teiv-yext:bSide or-teiv-ran:NearRTRICFunction;
            type instance-identifier;
            mandatory true;
        }
    }
}
+o-ran-smo-teiv-equipment-test  urn:o-ran:smo-teiv-equipment-test       EQUIPMENT       []      2024-10-21      module o-ran-smo-teiv-equipment-test {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-equipment-test";
    prefix or-teiv-equip-test;

    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }

    import ietf-geo-location {
        prefix geo;
        reference "RFC 9179: A YANG Grouping for Geographic Locations";
    }

    organization "ORAN";
    contact "The Authors";
    description
        "These are just test Equipment topology model";

    revision "2024-10-21" {
        description "Deprecate AntennaModule attribute antennaBeamWidth.
        To be replaced by horizontalBeamWidth and verticalBeamWidth.";
        or-teiv-yext:label 0.6.0;
    }

    revision "2024-10-08" {
        description "Added azimuth attribute for AntennaModule.";
        or-teiv-yext:label 0.5.0;
    }

    revision "2024-10-04" {
        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
        to the corresponding topology objects.";
        or-teiv-yext:label 0.4.0;
    }

    revision "2024-05-24" {
        description "Initial revision.";
        or-teiv-yext:label 0.3.0;
    }

    or-teiv-yext:domain EQUIPMENT;

    list AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee {
        description "An Antenna Module represents the physical aspect of an
        antenna.";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Entity_Mapping_Grp;
        key id;

        container attributes {
            leaf antennaModelNumber {
                description "Vendor-specific antenna model identifier. This
                attribute is part of AISG v3 ADB Standard and has no
                operational impact.";
                type string;
            }

            leaf mechanicalAntennaBearing {
                description "Antenna bearing on antenna subunit where antenna
                unit is installed.";
                type int32;
            }

            leaf mechanicalAntennaTilt {
                description "The fixed antenna tilt of the installation, defined
                as the inclination of the antenna element respect to the
                vertical plane. It is a signed value. Positive indicates
                downtilt, and negative indicates uptilt.";
                type int32;
            }

            leaf positionWithinSector {
                description "Antenna unit position within sector. This attribute
                is part of AISG v3 ADB Standard and has no operational
                impact.";
                type string;
            }

            leaf totalTilt {
                description "Total antenna elevation including the installed
                tilt and the tilt applied by the Remote Electrical
                Tilt (RET).";
                type int32;
            }

            leaf electricalAntennaTilt {
                description "Electrically-controlled tilt of main beam maximum
                with respect to direction orthogonal to antenna element
                axis (see 3GPP TS 25.466). Value is signed; tilt down is
                positive, tilt up is negative.";
                type int32;
            }

            leaf-list antennaBeamWidth {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the horizontal plane. Measured in
                degrees.

                Deprecated: Since 24.Q4. Replaced by AntennaModule::horizontalBeamWidth
                and AntennaModule::verticalBeamWidth. Planned to be removed.";
                type uint32;
            }

            leaf horizontalBeamWidth  {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the horizontal plane.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            leaf verticalBeamWidth   {
                description "The angular span of the main lobe of the antenna
                radiation pattern in the vertical plane.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            leaf azimuth {
                description "The value of the azimuth of the Antenna Module.";
                type decimal64 {
                    fraction-digits 1;
                    range "0..360";
                }
                units "decimal degrees";
            }

            uses geo:geo-location;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE {

        description
            "The aSide of this relationship is an instance of the AntennaModule type.
            The bSide of this relationship is an instance of the AntennaModule type.
            The AntennaModule represents the physical antenna that realised by the AntennaModule.
            An AntennaModule instance can realised one AntennaModule.
            An AntennaModule instance can be realised by many AntennaModules.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list realised-antennaModule {
            description "Antenna Module realised by many Antenna Modules.";
            or-teiv-yext:aSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
            type instance-identifier;
        }

        leaf-list realising-antennaModule {
            description "Antenna Module realising this Antenna Module.";
            or-teiv-yext:bSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
            type instance-identifier;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE { // 1..n to 0..m

        description
            "The aSide of this relationship is an instance of the AntennaModule type.
            The bSide of this relationship is an instance of the AntennaModule type.
            The AntennaModule represents the physical antenna that developed on the AntennaModule.
            An AntennaModule instance can developed one AntennaModule.
            An AntennaModule instance can be developed on one AntennaModule.
            ";

        uses or-teiv-types:Top_Grp_Type;
        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
        key id;

        leaf-list developed-on-antennaModule {
            description "Antenna Module developed on this Antenna Module.";
            or-teiv-yext:aSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
            type instance-identifier;
        }

        leaf-list developing-antennaModule {
            description "Antenna Module developing this Antenna Module.";
            or-teiv-yext:bSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
            type instance-identifier;
        }
    }
}
+o-ran-smo-teiv-oam-test        urn:o-ran:smo-teiv-oam-test     OAM     []      2024-10-04      bW9kdWxlIG8tcmFuLXNtby10ZWl2LW9hbS10ZXN0IHsKICAgIHlhbmctdmVyc2lvbiAxLjE7CiAgICBuYW1lc3BhY2UgInVybjpvLXJhbjpzbW8tdGVpdi1vYW0tdGVzdCI7CiAgICBwcmVmaXggb3ItdGVpdi1vYW0tdGVzdDsKCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctdHlwZXMgeyBwcmVmaXggb3ItdGVpdi10eXBlczsgfQoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1jb21tb24teWFuZy1leHRlbnNpb25zIHsgcHJlZml4IG9yLXRlaXYteWV4dDsgfQoKICAgIG9yZ2FuaXphdGlvbiAiT1JBTiI7CiAgICBjb250YWN0ICJUaGUgQXV0aG9ycyI7CiAgICBkZXNjcmlwdGlvbgogICAgICAgICJUaGVzZSBhcmUganVzdCB0ZXN0IE8mTSB0b3BvbG9neSBtb2RlbC4iOwoKICAgIHJldmlzaW9uICIyMDI0LTEwLTA0IiB7CiAgICAgICAgZGVzY3JpcHRpb24gIkFkZGVkIGdyb3VwaW5nLCBPcmlnaW5fRW50aXR5X01hcHBpbmdfR3JwIHRvIHRoZSB0b3BvbG9neSBvYmplY3QuIjsKICAgICAgICBvci10ZWl2LXlleHQ6bGFiZWwgMC40LjA7CiAgICB9CgogICAgcmV2aXNpb24gIjIwMjQtMDUtMjQiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiSW5pdGlhbCByZXZpc2lvbi4iOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjMuMDsKICAgIH0KCiAgICBvci10ZWl2LXlleHQ6ZG9tYWluIE9BTTsKCiAgICBsaXN0IE1hbmFnZWRFbGVtZW50dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHQgewogICAgICAgIGRlc2NyaXB0aW9uICJBIE1hbmFnZWQgRWxlbWVudCAoTUUpIGlzIGEgbm9kZSBpbnRvIGEgdGVsZWNvbW11bmljYXRpb24KICAgICAgICBuZXR3b3JrIHByb3ZpZGluZyBzdXBwb3J0IGFuZC9vciBzZXJ2aWNlIHRvIHN1YnNjcmliZXJzLiBBbiBNRQogICAgICAgIGNvbW11bmljYXRlcyB3aXRoIGEgbWFuYWdlciBhcHBsaWNhdGlvbiAoZGlyZWN0bHkgb3IgaW5kaXJlY3RseSkKICAgICAgICBvdmVyIG9uZSBvciBtb3JlIGludGVyZmFjZXMgZm9yIHRoZSBwdXJwb3NlIG9mIGJlaW5nIG1vbml0b3JlZAogICAgICAgIGFuZC9vciBjb250cm9sbGVkLiI7CgogICAgICAgIHVzZXMgb3ItdGVpdi10eXBlczpUb3BfR3JwX1R5cGU7CiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOk9yaWdpbl9FbnRpdHlfTWFwcGluZ19HcnA7CiAgICAgICAga2V5IGlkOwogICAgfQp9
+o-ran-smo-teiv-ran-test        urn:o-ran:smo-teiv-ran-test     RAN     []      2024-10-08      module o-ran-smo-teiv-ran-test {
    yang-version 1.1;
    namespace "urn:o-ran:smo-teiv-ran-test";
    prefix or-teiv-ran-test;

    import o-ran-smo-teiv-common-yang-types {prefix or-teiv-types; }

    import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }

    import _3gpp-common-yang-types { prefix types3gpp; }

    import ietf-geo-location {
        prefix geo;
        reference "RFC 9179: A YANG Grouping for Geographic Locations";
    }

    organization "ORAN";
    contact "The Authors";
    description
        "These are just test RAN topology model.";

    revision "2024-10-08" {
        description "Added range for azimuth attribute of Sector.";
        or-teiv-yext:label 0.5.0;
    }

    revision "2024-10-04" {
        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
        to the corresponding topology object.";
        or-teiv-yext:label 0.4.0;
    }

    revision "2024-05-24" {
        description "Initial revision.";
        or-teiv-yext:label 0.3.0;
    }

    or-teiv-yext:domain RAN;

    list ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn {
        description "gNodeB Distributed Unit (gNB-DU).

        A gNB may consist of a gNB-Centralized Unit (gNB-CU) and a gNB-DU.
        The CU processes non-real time protocols and services, and the DU
        processes PHY level protocol and real time services. The gNB-CU and
        the gNB-DU units are connected via F1 logical interface.

        The following is true for a gNB-DU:
        Is connected to the gNB-CU-CP through the F1-C interface. Is
        connected to the gNB-CU-UP through the F1-U interface. One gNB-DU is
        connected to only one gNB-CU-CP. One gNB-DU can be connected to
        multiple gNB-CU-UPs under the control of the same gNB-CU-CP.

        Note: A gNB may consist of a gNB-CU-CP, multiple gNB-CU-UPs and
        multiple gNB-DUs. gNB-DU is a concrete class that extends the NG-RAN
        node object. In Topology, you can create, read, update, and delete
        the gNB-DU object.";

        uses or-teiv-types:Top_Grp_Type;
        key id;

        container attributes {
            container dUpLMNId {
                description "PLMN identifier used as part of PM Events data";
                uses types3gpp:PLMNId;
            }

            leaf gNBDUId {
                description "Unique identifier for the DU within a gNodeB";
                type int64;
            }

            leaf gNBId {
                description "Identity of gNodeB within a PLMN";
                type int64;
            }

            leaf gNBIdLength {
                description "Length of gNBId bit string representation";
                type int32;
            }
        }
    }


    list NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU  {
        description "Represents an NR Cell in gNodeB-DU.

        5G NR is a new radio access technology (RAT) developed by 3GPP for
        the 5G (fifth generation) mobile network. It is designed to be the
        global standard for the air interface of 5G networks.

        5G NR has synchronization signal that is known as Primary
        Synchronization signal (PSS) and Secondary Synchronization signal
        (SSS). These signals are specific to NR physical layer and provide
        the following information required by UE for downlink
        synchronization: PSS provides Radio Frame Boundary (Position of 1st
        Symbol in a Radio frame) SSS provides Subframe Boundary (Position of
        1st Symbol in a Subframe) Physical Layer Cell ID (PCI) information
        using both PSS and SSS.";

        uses or-teiv-types:Top_Grp_Type;
        key id;

        container attributes {
            leaf cellLocalIdddddddddddddddddddddddddddddddddddddddddddddddddddddd {
                description "Used together with gNodeB identifier to identify NR
                cell in PLMN. Used together with gNBId to form NCI.";
                type int32;
            }

            leaf nCI {
                description "NR Cell Identity.";
                type int64;
            }

            leaf nRPCI {
                description "The Physical Cell Identity (PCI) of the NR cell.";
                type int32;
            }

            leaf nRTAC {
                description "NR Tracking Area Code (TAC).";
                type int32;
            }
        }
    }

    list AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy {
        description "This MO serves as a mapping between the cell and the RBS
        equipment used to provide coverage in a certain geographical area.
        The MO also controls the maximum output power of the sector.";

        uses or-teiv-types:Top_Grp_Type;
        key id;

        container attributes {
            leaf-list eUtranFqBands {
                description "List of LTE frequency bands that associated
                hardware supports";
                type string;
            }

            leaf-list geranFqBands {
                description "List of GERAN frequency bands that associated
                hardware supports";
                type string;
            }

            leaf-list nRFqBands {
                description "List of NR frequency bands associated hardware
                supports";
                type string;
            }
        }
    }

    list LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr {
        description "The LTE Sector Carrier object provides the attributes for
        defining the logical characteristics of a carrier (cell) in a
        sector. A sector is a coverage area associated with a base station
        having its own antennas, radio ports, and control channels. The
        concept of sectors was developed to improve co-channel interference
        in cellular systems, and most wireless systems use three sector
        cells.";

        uses or-teiv-types:Top_Grp_Type;
        key id;

        container attributes {
            leaf sectorCarrierType {
                description "Indicates whether or not the sector carrier
                modelled by MO SectorCarrier is a digital sector.";
                type enumeration {
                    enum normal_sector {
                        value 0;
                        description "Not a digital sector";
                    }
                    enum left_digital_sector {
                        value 1;
                        description "Left digital sector for 2DS";
                    }
                    enum right_digital_sector {
                        value 2;
                        description "Right digital sector for 2DS";
                    }
                    enum left_digital_sector_3ds {
                        value 3;
                        description "Left digital sector for 3DS";
                    }
                    enum right_digital_sector_3ds {
                        value 4;
                        description "Right digital sector for 3DS";
                    }
                    enum middle_digital_sector_3ds {
                        value 5;
                        description "Middle digital sector for 3DS";
                    }
                }
            }
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU { // 1 to 0..n

        uses or-teiv-types:Top_Grp_Type;
        key id;

        leaf-list provided-nrCellDu {
            description "gNodeB-DU Function provides NR Cell-DU.";
            or-teiv-yext:aSide ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn;
            type instance-identifier;
        }

        leaf provided-by-gnbduFunction {
            description "NR Cell-DU provided by gNodeB-DU Function.";
            or-teiv-yext:bSide NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU;
            type instance-identifier;
            mandatory true;
        }
    }

    or-teiv-yext:biDirectionalTopologyRelationship LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY { // 0..n to 0..1

        uses or-teiv-types:Top_Grp_Type;
        key id;

        leaf used-antennaCapability {
            description "LTE Sector Carrier uses Antenna Capability.";
            or-teiv-yext:aSide LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr;
            type instance-identifier;
        }

        leaf-list used-by-lteSectorCarrier {
            description "Antenna Capability used by LTE Sector Carrier.";
            or-teiv-yext:bSide AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy;
            type instance-identifier;
        }
    }
}
+o-ran-smo-teiv-rel-equipment-ran-test  urn:o-ran:smo-teiv-rel-equipment-ran    REL_EQUIPMENT_RAN       ["o-ran-smo-teiv-equipment-test", "o-ran-smo-teiv-ran-test"]    2024-05-24      bW9kdWxlIG8tcmFuLXNtby10ZWl2LXJlbC1lcXVpcG1lbnQtcmFuLXRlc3QgewogICAgeWFuZy12ZXJzaW9uIDEuMTsKICAgIG5hbWVzcGFjZSAidXJuOm8tcmFuOnNtby10ZWl2LXJlbC1lcXVpcG1lbnQtcmFuIjsKICAgIHByZWZpeCBvci10ZWl2LXJlbC1lcXVpcHJhbi10ZXN0OwoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1jb21tb24teWFuZy10eXBlcyB7IHByZWZpeCBvci10ZWl2LXR5cGVzOyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LWNvbW1vbi15YW5nLWV4dGVuc2lvbnMgeyBwcmVmaXggb3ItdGVpdi15ZXh0OyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LWVxdWlwbWVudC10ZXN0IHsgcHJlZml4IG9yLXRlaXYtZXF1aXAtdGVzdDsgfQoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1yYW4tdGVzdCB7IHByZWZpeCBvci10ZWl2LXJhbi10ZXN0OyB9CgogICAgb3JnYW5pemF0aW9uICJPUkFOIjsKICAgIGNvbnRhY3QgIlRoZSBBdXRob3JzIjsKICAgIGRlc2NyaXB0aW9uCiAgICAgICAgIlRoZXNlIGFyZSBqdXN0IHRlc3QgRXF1aXBtZW50IGFuZCBSQU4gdG9wb2xvZ3kgcmVsYXRpb24gbW9kZWwuIjsKCiAgICByZXZpc2lvbiAiMjAyNC0wNS0yNCIgewogICAgICAgIGRlc2NyaXB0aW9uICJJbml0aWFsIHJldmlzaW9uLiI7CiAgICAgICAgb3ItdGVpdi15ZXh0OmxhYmVsIDAuMy4wOwogICAgfQoKICAgIG9yLXRlaXYteWV4dDpkb21haW4gUkVMX0VRVUlQTUVOVF9SQU47CgogICAgb3ItdGVpdi15ZXh0OmJpRGlyZWN0aW9uYWxUb3BvbG9neVJlbGF0aW9uc2hpcCBBTlRFTk5BTU9EVUxFRUVFRUVFRUVFRUVFRUVFRUVFRV9TRVJWRVNfQU5URU5OQUNBUEFCSUxJVFlZWVlZWVlZWVlZWVlZWVlZWSB7IC8vIDAuLm4gdG8gMC4ubQoKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6VG9wX0dycF9UeXBlOwogICAgICAgIGtleSBpZDsKCiAgICAgICAgbGVhZi1saXN0IHNlcnZpY2VkLWFudGVubmFDYXBhYmlsaXR5IHsKICAgICAgICAgICAgZGVzY3JpcHRpb24gIkFudGVubmEgQ2FwYWJpbGl0eSBzZXJ2aWNlZCBieSB0aGlzIEFudGVubmEgTW9kdWxlLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LWVxdWlwLXRlc3Q6QW50ZW5uYU1vZHVsZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZWVlZTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KCiAgICAgICAgbGVhZi1saXN0IHNlcnZpbmctYW50ZW5uYU1vZHVsZSB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJBbnRlbm5hIE1vZHVsZSBzZXJ2ZXMgdGhpcyBBbnRlbm5hIENhcGFiaWxpdHkuIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmJTaWRlIG9yLXRlaXYtcmFuLXRlc3Q6QW50ZW5uYUNhcGFiaWxpdHl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5eXl5OwogICAgICAgICAgICB0eXBlIGluc3RhbmNlLWlkZW50aWZpZXI7CiAgICAgICAgfQogICAgfQp9
+o-ran-smo-teiv-rel-oam-ran-test        urn:o-ran:smo-teiv-rel-oam-ran-test     REL_OAM_RAN     ["o-ran-smo-teiv-oam-test", "o-ran-smo-teiv-ran-test"]  2024-10-04      bW9kdWxlIG8tcmFuLXNtby10ZWl2LXJlbC1vYW0tcmFuLXRlc3QgewogICAgeWFuZy12ZXJzaW9uIDEuMTsKICAgIG5hbWVzcGFjZSAidXJuOm8tcmFuOnNtby10ZWl2LXJlbC1vYW0tcmFuLXRlc3QiOwogICAgcHJlZml4IG9yLXRlaXYtcmVsLW9hbS1yYW4tdGVzdDsKCiAgICBpbXBvcnQgby1yYW4tc21vLXRlaXYtY29tbW9uLXlhbmctdHlwZXMgeyBwcmVmaXggb3ItdGVpdi10eXBlczsgfQoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1jb21tb24teWFuZy1leHRlbnNpb25zIHsgcHJlZml4IG9yLXRlaXYteWV4dDsgfQoKICAgIGltcG9ydCBvLXJhbi1zbW8tdGVpdi1vYW0tdGVzdCB7IHByZWZpeCBvci10ZWl2LW9hbS10ZXN0OyB9CgogICAgaW1wb3J0IG8tcmFuLXNtby10ZWl2LXJhbi10ZXN0IHsgcHJlZml4IG9yLXRlaXYtcmFuLXRlc3Q7IH0KCiAgICBvcmdhbml6YXRpb24gIk9SQU4iOwogICAgY29udGFjdCAiVGhlIEF1dGhvcnMiOwogICAgZGVzY3JpcHRpb24KICAgICAgICAiVGhlc2UgYXJlIGp1c3QgdGVzdCBPJk0gYW5kIFJBTiB0b3BvbG9neSByZWxhdGlvbiBtb2RlbC4iOwoKICAgIHJldmlzaW9uICIyMDI0LTEwLTA0IiB7CiAgICAgICAgZGVzY3JpcHRpb24gIkFkZGVkIGdyb3VwaW5nLCBPcmlnaW5fUmVsYXRpb25zaGlwX01hcHBpbmdfR3JwIHRvIHRoZSB0b3BvbG9neSBvYmplY3QuIjsKICAgICAgICBvci10ZWl2LXlleHQ6bGFiZWwgMC40LjA7CiAgICB9CgogICAgcmV2aXNpb24gIjIwMjQtMDUtMjQiIHsKICAgICAgICBkZXNjcmlwdGlvbiAiSW5pdGlhbCByZXZpc2lvbi4iOwogICAgICAgIG9yLXRlaXYteWV4dDpsYWJlbCAwLjMuMDsKICAgIH0KCiAgICBvci10ZWl2LXlleHQ6ZG9tYWluIFJFTF9PQU1fUkFOOwoKICAgIG9yLXRlaXYteWV4dDpiaURpcmVjdGlvbmFsVG9wb2xvZ3lSZWxhdGlvbnNoaXAgTWFuYWdlZEVsZW1lbnR0dHR0dHR0dHR0dHR0dHR0dF9VU0VTX05SQ2VsbERVVVVVVVVVVVVVVVUgeyAvLyAxIHRvIDAuLjEKCiAgICAgICAgdXNlcyBvci10ZWl2LXR5cGVzOlRvcF9HcnBfVHlwZTsKICAgICAgICBrZXkgaWQ7CgogICAgICAgIGxlYWYgdXNlZC1uckNlbGxEdSB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJnTm9kZUItRFUgRnVuY3Rpb24gdXNlcyBOUiBDZWxsLURVLiI7CiAgICAgICAgICAgIG9yLXRlaXYteWV4dDphU2lkZSBvci10ZWl2LW9hbS10ZXN0Ok1hbmFnZWRFbGVtZW50dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHQ7CiAgICAgICAgICAgIHR5cGUgaW5zdGFuY2UtaWRlbnRpZmllcjsKICAgICAgICB9CgogICAgICAgIGxlYWYgdXNlZC1ieS1tYW5hZ2VkRWxlbWVudCB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJOUiBDZWxsLURVIHVzZWQgYnkgbWFuYWdlZEVsZW1lbnQuIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmJTaWRlIG9yLXRlaXYtcmFuLXRlc3Q6TlJDZWxsRFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVTsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgICAgICBtYW5kYXRvcnkgdHJ1ZTsKICAgICAgICB9CgogICAgfQoKICAgIG9yLXRlaXYteWV4dDpiaURpcmVjdGlvbmFsVG9wb2xvZ3lSZWxhdGlvbnNoaXAgTUFOQUdFREVMRU1FTlRUVFRUVFRUVFRUVFRUVF9NQU5BR0VTX0dOQkRVRlVOQ1RJT05OTk5OTk5OTk5OTk5OTiB7ICAgIC8vIDEgdG8gMC4ubgoKICAgICAgICB1c2VzIG9yLXRlaXYtdHlwZXM6VG9wX0dycF9UeXBlOwogICAgICAgIGtleSBpZDsKCiAgICAgICAgbGVhZi1saXN0IG1hbmFnZWQtZ25iZHVGdW5jdGlvbiB7CiAgICAgICAgICAgIGRlc2NyaXB0aW9uICJNYW5hZ2VkIEVsZW1lbnQgbWFuYWdlcyBnTm9kZUItRFUgRnVuY3Rpb24uIjsKICAgICAgICAgICAgb3ItdGVpdi15ZXh0OmFTaWRlIG9yLXRlaXYtb2FtLXRlc3Q6TWFuYWdlZEVsZW1lbnR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dHR0dDsKICAgICAgICAgICAgdHlwZSBpbnN0YW5jZS1pZGVudGlmaWVyOwogICAgICAgIH0KCiAgICAgICAgbGVhZiBtYW5hZ2VkLWJ5LW1hbmFnZWRFbGVtZW50IHsKICAgICAgICAgICAgZGVzY3JpcHRpb24gImdOb2RlQi1EVSBGdW5jdGlvbiBtYW5hZ2VkIGJ5IE1hbmFnZWQgRWxlbWVudC4iOwogICAgICAgICAgICBvci10ZWl2LXlleHQ6YlNpZGUgb3ItdGVpdi1yYW4tdGVzdDpHTkJEVUZ1bmN0aW9ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5ubm5uOwogICAgICAgICAgICB0eXBlIGluc3RhbmNlLWlkZW50aWZpZXI7CiAgICAgICAgICAgIG1hbmRhdG9yeSB0cnVlOwogICAgICAgIH0KICAgIH0KfQ==
+\.
+
+COPY teiv_model.entity_info("storedAt", "name", "moduleReferenceName", "attributeNames") FROM stdin;
+o-ran-smo-teiv-cloud_CloudifiedNF      CloudifiedNF    o-ran-smo-teiv-cloud    ["name"]
+o-ran-smo-teiv-cloud_NFDeployment      NFDeployment    o-ran-smo-teiv-cloud    ["name"]
+o-ran-smo-teiv-cloud_NodeCluster       NodeCluster     o-ran-smo-teiv-cloud    ["name"]
+o-ran-smo-teiv-cloud_OCloudNamespace   OCloudNamespace o-ran-smo-teiv-cloud    ["name"]
+o-ran-smo-teiv-cloud_OCloudSite        OCloudSite      o-ran-smo-teiv-cloud    ["geo-location", "name"]
+o-ran-smo-teiv-equipment_AntennaModule AntennaModule   o-ran-smo-teiv-equipment        ["antennaBeamWidth", "antennaModelNumber", "azimuth", "electricalAntennaTilt", "geo-location", "horizontalBeamWidth", "mechanicalAntennaBearing", "mechanicalAntennaTilt", "positionWithinSector", "totalTilt", "verticalBeamWidth"]
+o-ran-smo-teiv-equipment_Site  Site    o-ran-smo-teiv-equipment        ["geo-location", "name"]
+o-ran-smo-teiv-oam_ManagedElement      ManagedElement  o-ran-smo-teiv-oam      []
+o-ran-smo-teiv-ran_AntennaCapability   AntennaCapability       o-ran-smo-teiv-ran      ["eUtranFqBands", "geranFqBands", "nRFqBands"]
+o-ran-smo-teiv-ran_NRCellCU    NRCellCU        o-ran-smo-teiv-ran      ["cellLocalId", "nCI", "nRTAC", "plmnId"]
+o-ran-smo-teiv-ran_NRCellDU    NRCellDU        o-ran-smo-teiv-ran      ["cellLocalId", "nCI", "nRPCI", "nRTAC"]
+o-ran-smo-teiv-ran_NRSectorCarrier     NRSectorCarrier o-ran-smo-teiv-ran      ["arfcnDL", "arfcnUL", "bSChannelBwDL", "frequencyDL", "frequencyUL"]
+o-ran-smo-teiv-ran_NearRTRICFunction   NearRTRICFunction       o-ran-smo-teiv-ran      ["nearRtRicId", "pLMNId"]
+o-ran-smo-teiv-ran_OCUCPFunction       OCUCPFunction   o-ran-smo-teiv-ran      ["gNBCUName", "gNBId", "gNBIdLength", "pLMNId"]
+o-ran-smo-teiv-ran_OCUUPFunction       OCUUPFunction   o-ran-smo-teiv-ran      ["gNBId", "gNBIdLength", "pLMNIdList"]
+o-ran-smo-teiv-ran_ODUFunction ODUFunction     o-ran-smo-teiv-ran      ["dUpLMNId", "gNBDUId", "gNBId", "gNBIdLength"]
+o-ran-smo-teiv-ran_ORUFunction ORUFunction     o-ran-smo-teiv-ran      ["oruId"]
+o-ran-smo-teiv-ran_Sector      Sector  o-ran-smo-teiv-ran      ["azimuth", "geo-location", "sectorId"]
+o-ran-smo-teiv-equipment-test_AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   ["antennaBeamWidth", "antennaModelNumber", "azimuth", "electricalAntennaTilt", "geo-location", "horizontalBeamWidth", "mechanicalAntennaBearing", "mechanicalAntennaTilt", "positionWithinSector", "totalTilt", "verticalBeamWidth"]
+o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt       ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt        o-ran-smo-teiv-oam-test []
+o-ran-smo-teiv-ran-test_AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy     AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy      o-ran-smo-teiv-ran-test ["eUtranFqBands", "geranFqBands", "nRFqBands"]
+o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn  o-ran-smo-teiv-ran-test ["dUpLMNId", "gNBDUId", "gNBId", "gNBIdLength"]
+o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr  o-ran-smo-teiv-ran-test ["sectorCarrierType"]
+o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU       NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU        o-ran-smo-teiv-ran-test ["cellLocalIdddddddddddddddddddddddddddddddddddddddddddddddddddddd", "nCI", "nRPCI", "nRTAC"]
+\.
+
+COPY teiv_model.relationship_info("name", "aSideAssociationName", "aSideMOType", "aSideModule", "aSideMinCardinality", "aSideMaxCardinality", "bSideAssociationName", "bSideMOType", "bSideModule", "bSideMinCardinality", "bSideMaxCardinality", "associationKind", "connectSameEntity", "relationshipDataLocation", "storedAt", "moduleReferenceName") FROM stdin;
+ANTENNAMODULE_INSTALLED_AT_SITE        installed-at-site       AntennaModule   o-ran-smo-teiv-equipment        0       9223372036854775807     installed-antennaModule Site    o-ran-smo-teiv-equipment        0       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-equipment_AntennaModule  o-ran-smo-teiv-equipment
+ANTENNAMODULE_SERVES_ANTENNACAPABILITY serviced-antennaCapability      AntennaModule   o-ran-smo-teiv-equipment        0       9223372036854775807     serving-antennaModule   AntennaCapability       o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_ANTENNACAPABILITY o-ran-smo-teiv-rel-equipment-ran
+ANTENNAMODULE_SERVES_NRCELLDU  serviced-nrCellDu       AntennaModule   o-ran-smo-teiv-equipment        1       9223372036854775807     serving-antennaModule   NRCellDU        o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-equipment-ran_ANTENNAMODULE_SERVES_NRCELLDU  o-ran-smo-teiv-rel-equipment-ran
+CLOUDIFIEDNF_COMPRISES_NFDEPLOYMENT    comprised-nFDeployment  CloudifiedNF    o-ran-smo-teiv-cloud    1       1       comprised-by-cloudifiedNF       NFDeployment    o-ran-smo-teiv-cloud    1       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-cloud_NFDeployment       o-ran-smo-teiv-cloud
+MANAGEDELEMENT_DEPLOYED_AS_CLOUDIFIEDNF        deployed-as-cloudifiedNF        ManagedElement  o-ran-smo-teiv-oam      1       1       deployed-managedElement CloudifiedNF    o-ran-smo-teiv-cloud    0       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-oam_ManagedElement       o-ran-smo-teiv-rel-oam-cloud
+MANAGEDELEMENT_MANAGES_NEARRTRICFUNCTION       managed-nearRTRICFunction       ManagedElement  o-ran-smo-teiv-oam      1       1       managed-by-managedElement       NearRTRICFunction       o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NearRTRICFunction    o-ran-smo-teiv-rel-oam-ran
+MANAGEDELEMENT_MANAGES_OCUCPFUNCTION   managed-ocucpFunction   ManagedElement  o-ran-smo-teiv-oam      1       1       managed-by-managedElement       OCUCPFunction   o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_OCUCPFunction        o-ran-smo-teiv-rel-oam-ran
+MANAGEDELEMENT_MANAGES_OCUUPFUNCTION   managed-ocuupFunction   ManagedElement  o-ran-smo-teiv-oam      1       1       managed-by-managedElement       OCUUPFunction   o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_OCUUPFunction        o-ran-smo-teiv-rel-oam-ran
+MANAGEDELEMENT_MANAGES_ODUFUNCTION     managed-oduFunction     ManagedElement  o-ran-smo-teiv-oam      1       1       managed-by-managedElement       ODUFunction     o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_ODUFunction  o-ran-smo-teiv-rel-oam-ran
+MANAGEDELEMENT_MANAGES_ORUFUNCTION     managed-oruFunction     ManagedElement  o-ran-smo-teiv-oam      1       1       managed-by-managedElement       ORUFunction     o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_ORUFunction  o-ran-smo-teiv-rel-oam-ran
+NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE       deployed-on-ocloudNamespace     NFDeployment    o-ran-smo-teiv-cloud    1       9223372036854775807     deployed-nFDeployment   OCloudNamespace o-ran-smo-teiv-cloud    1       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-cloud_NFDEPLOYMENT_DEPLOYED_ON_OCLOUDNAMESPACE   o-ran-smo-teiv-cloud
+NFDEPLOYMENT_SERVES_MANAGEDELEMENT     serviced-managedElement NFDeployment    o-ran-smo-teiv-cloud    1       9223372036854775807     serving-nFDeployment    ManagedElement  o-ran-smo-teiv-oam      1       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-cloud_NFDeployment       o-ran-smo-teiv-rel-oam-cloud
+NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION  serviced-nearRTRICFunction      NFDeployment    o-ran-smo-teiv-cloud    0       9223372036854775807     serving-nFDeployment    NearRTRICFunction       o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_NEARRTRICFUNCTION      o-ran-smo-teiv-rel-cloud-ran
+NFDEPLOYMENT_SERVES_OCUCPFUNCTION      serviced-ocucpFunction  NFDeployment    o-ran-smo-teiv-cloud    0       9223372036854775807     serving-nFDeployment    OCUCPFunction   o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUCPFUNCTION  o-ran-smo-teiv-rel-cloud-ran
+NFDEPLOYMENT_SERVES_OCUUPFUNCTION      serviced-ocuupFunction  NFDeployment    o-ran-smo-teiv-cloud    0       9223372036854775807     serving-nFDeployment    OCUUPFunction   o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_OCUUPFUNCTION  o-ran-smo-teiv-rel-cloud-ran
+NFDEPLOYMENT_SERVES_ODUFUNCTION        serviced-oduFunction    NFDeployment    o-ran-smo-teiv-cloud    0       9223372036854775807     serving-nFDeployment    ODUFunction     o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-cloud-ran_NFDEPLOYMENT_SERVES_ODUFUNCTION    o-ran-smo-teiv-rel-cloud-ran
+NODECLUSTER_LOCATED_AT_OCLOUDSITE      located-at-ocloudSite   NodeCluster     o-ran-smo-teiv-cloud    1       9223372036854775807     location-of-onodeCluster        OCloudSite      o-ran-smo-teiv-cloud    1       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-cloud_NODECLUSTER_LOCATED_AT_OCLOUDSITE  o-ran-smo-teiv-cloud
+NRCELLDU_USES_NRSECTORCARRIER  used-nrSectorCarrier    NRCellDU        o-ran-smo-teiv-ran      0       1       used-by-nrCellDu        NRSectorCarrier o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NRSectorCarrier      o-ran-smo-teiv-ran
+NRSECTORCARRIER_USES_ANTENNACAPABILITY used-antennaCapability  NRSectorCarrier o-ran-smo-teiv-ran      0       9223372036854775807     used-by-nrSectorCarrier AntennaCapability       o-ran-smo-teiv-ran      0       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-ran_NRSectorCarrier      o-ran-smo-teiv-ran
+OCLOUDNAMESPACE_DEPLOYED_ON_NODECLUSTER        deployed-on-nodeCluster OCloudNamespace o-ran-smo-teiv-cloud    1       9223372036854775807     deployed-ocloudNamespace        NodeCluster     o-ran-smo-teiv-cloud    1       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-cloud_OCloudNamespace    o-ran-smo-teiv-cloud
+OCUCPFUNCTION_PROVIDES_NRCELLCU        provided-nrCellCu       OCUCPFunction   o-ran-smo-teiv-ran      1       1       provided-by-ocucpFunction       NRCellCU        o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NRCellCU     o-ran-smo-teiv-ran
+ODUFUNCTION_PROVIDES_NRCELLDU  provided-nrCellDu       ODUFunction     o-ran-smo-teiv-ran      1       1       provided-by-oduFunction NRCellDU        o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NRCellDU     o-ran-smo-teiv-ran
+ODUFUNCTION_PROVIDES_NRSECTORCARRIER   provided-nrSectorCarrier        ODUFunction     o-ran-smo-teiv-ran      1       1       provided-by-oduFunction NRSectorCarrier o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NRSectorCarrier      o-ran-smo-teiv-ran
+SECTOR_GROUPS_ANTENNAMODULE    grouped-antennaModule   Sector  o-ran-smo-teiv-ran      0       1       grouped-by-sector       AntennaModule   o-ran-smo-teiv-equipment        0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-equipment_AntennaModule  o-ran-smo-teiv-rel-equipment-ran
+SECTOR_GROUPS_NRCELLDU grouped-nrCellDu        Sector  o-ran-smo-teiv-ran      0       1       grouped-by-sector       NRCellDU        o-ran-smo-teiv-ran      0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran_NRCellDU     o-ran-smo-teiv-ran
+ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY     serviced-antennaCapability      AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   0       9223372036854775807     serving-antennaModule   AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy      o-ran-smo-teiv-ran-test 0       9223372036854775807     BI_DIRECTIONAL  false   RELATION        o-ran-smo-teiv-rel-equipment-ran-test_ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY        o-ran-smo-teiv-rel-equipment-ran-test
+ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE       developed-on-antennaModule      AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   0       9223372036854775807     developing-antennaModule        AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   0       9223372036854775807     BI_DIRECTIONAL  true    RELATION        o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE  o-ran-smo-teiv-equipment-test
+ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE       realised-antennaModule  AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   0       9223372036854775807     realising-antennaModule AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee        o-ran-smo-teiv-equipment-test   0       9223372036854775807     BI_DIRECTIONAL  true    RELATION        o-ran-smo-teiv-equipment-test_ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE  o-ran-smo-teiv-equipment-test
+ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU provided-nrCellDu       ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn  o-ran-smo-teiv-ran-test 1       1       provided-by-oduFunction NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU        o-ran-smo-teiv-ran-test 0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran-test_NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU        o-ran-smo-teiv-ran-test
+LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY      used-antennaCapability  LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr  o-ran-smo-teiv-ran-test 0       9223372036854775807     used-by-lteSectorCarrier        AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy      o-ran-smo-teiv-ran-test 0       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-ran-test_LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr  o-ran-smo-teiv-ran-test
+MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_ODUFUNCTIONNNNNNNNNNNNNNN managed-oduFunction     ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt        o-ran-smo-teiv-oam-test 1       1       managed-by-managedElement       ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn  o-ran-smo-teiv-ran-test 0       9223372036854775807     BI_DIRECTIONAL  false   B_SIDE  o-ran-smo-teiv-ran-test_ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn  o-ran-smo-teiv-rel-oam-ran-test
+ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU       used-nrCellDu   ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt        o-ran-smo-teiv-oam-test 1       1       used-by-managedElement  NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU        o-ran-smo-teiv-ran-test 0       1       BI_DIRECTIONAL  false   A_SIDE  o-ran-smo-teiv-oam-test_ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt        o-ran-smo-teiv-rel-oam-ran-test
+\.
+
+;
+
+COMMIT;
\ No newline at end of file
index 9207aa1..b1b03da 100644 (file)
 
 BEGIN;
 
+COPY teiv_data."o-ran-smo-teiv-oam_ManagedElement" ("id", "CD_sourceIds", "CD_classifiers", "CD_decorators", "metadata" ) FROM stdin;
+urn:3gpp:dn:SubNetwork=ManagedElementForDeletion,MeContext=1,ManagedElement=1  ["urn:3gpp:dn:SubNetwork=ManagedElementForDeletion,MeContext=1,ManagedElement=1","urn:cmHandle:C4388D6BB970EC663F88B46CC14F8620"]       []      {}      {"reliabilityIndicator":"RESTORED","firstDiscovered":"2025-01-08T10:40:36.46156500Z","lastModified":"2025-01-08T10:40:36.46156500Z"}
+\.
+
+COPY teiv_data."o-ran-smo-teiv-ran_ODUFunction" ("id", "dUpLMNId", "gNBDUId", "gNBId", "gNBIdLength", "CD_sourceIds", "CD_classifiers", "CD_decorators", "REL_FK_managed-by-managedElement", "REL_ID_MANAGEDELEMENT_MANAGES_ODUFUNCTION", "REL_CD_sourceIds_MANAGEDELEMENT_MANAGES_ODUFUNCTION", "REL_CD_classifiers_MANAGEDELEMENT_MANAGES_ODUFUNCTION", "REL_CD_decorators_MANAGEDELEMENT_MANAGES_ODUFUNCTION", "metadata", "REL_metadata_MANAGEDELEMENT_MANAGES_ODUFUNCTION" ) FROM stdin;
+urn:3gpp:dn:SubNetwork=ODUFunctionForDeletion,MeContext=1,ManagedElement=1,ODUFunction=1       {"mcc":"123","mnc":"82"}        \N      9       1       ["urn:3gpp:dn:SubNetwork=ODUFunctionForDeletion,MeContext=1,ManagedElement=1,ODUFunction=1","urn:cmHandle:C4388D6BB970EC663F88B46CC14F8619"]    ["test-app-module:Indoor","test-app-module:Weekend"]    {"test-app-module:textdata":"Ericsson"} urn:3gpp:dn:SubNetwork=ManagedElementForDeletion,MeContext=1,ManagedElement=1   urn:o-ran:smo:teiv:sha512:MANAGEDELEMENT_MANAGES_ODUFUNCTION=9243B48F7D6A6CF471226915C74CF5FE4BDA6FA3CF7D897473007B46DF7FC50230BD6B8B4256116A6AFBF4D822CF9379EB56DE9490C1C0B54238263F2574B345   ["urn:3gpp:dn:SubNetwork=ManagedElementForDeletion,MeContext=1,ManagedElement=1"]       ["test-app-module:Indoor","test-app-module:Weekend"]    {"test-app-module:textdata":"Ericsson"} {"reliabilityIndicator":"OK","firstDiscovered":"2025-01-09T10:40:36.461565Z","lastModified":"2025-01-09T10:40:36.461565Z"}      {"reliabilityIndicator":"ADVISED","firstDiscovered":"2025-01-09T10:40:36.461565Z","lastModified":"2025-01-09T10:40:36.461565Z"}
+\.
+
 COPY teiv_data."o-ran-smo-teiv-ran_NRCellDU" ("id", "metadata", "cellLocalId", "nCI", "nRPCI", "nRTAC") FROM stdin;
 myReliabilityCell_1    {"reliabilityIndicator":"OK","firstDiscovered":"2025-01-08T10:40:36.46156500Z","lastModified":"2025-01-08T10:40:36.46156500Z"}  51      61      \N      \N
 myReliabilityCell_2    {"reliabilityIndicator":"OK","firstDiscovered":"2025-01-08T10:40:36.46156500Z","lastModified":"2025-01-08T10:40:36.46156500Z"}  51      61      701     \N
diff --git a/teiv/src/test/resources/yang/models/o-ran-smo-teiv-equipment-test.yang b/teiv/src/test/resources/yang/models/o-ran-smo-teiv-equipment-test.yang
new file mode 100644 (file)
index 0000000..512bfb4
--- /dev/null
@@ -0,0 +1,192 @@
+module o-ran-smo-teiv-equipment-test {
+    yang-version 1.1;
+    namespace "urn:o-ran:smo-teiv-equipment-test";
+    prefix or-teiv-equip-test;
+
+    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }
+
+    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }
+
+    import ietf-geo-location {
+        prefix geo;
+        reference "RFC 9179: A YANG Grouping for Geographic Locations";
+    }
+
+    organization "ORAN";
+    contact "The Authors";
+    description
+        "These are just test Equipment topology model";
+
+    revision "2024-10-21" {
+        description "Deprecate AntennaModule attribute antennaBeamWidth.
+        To be replaced by horizontalBeamWidth and verticalBeamWidth.";
+        or-teiv-yext:label 0.6.0;
+    }
+
+    revision "2024-10-08" {
+        description "Added azimuth attribute for AntennaModule.";
+        or-teiv-yext:label 0.5.0;
+    }
+
+    revision "2024-10-04" {
+        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
+        to the corresponding topology objects.";
+        or-teiv-yext:label 0.4.0;
+    }
+
+    revision "2024-05-24" {
+        description "Initial revision.";
+        or-teiv-yext:label 0.3.0;
+    }
+
+    or-teiv-yext:domain EQUIPMENT;
+
+    list AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee {
+        description "An Antenna Module represents the physical aspect of an
+        antenna.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        uses or-teiv-types:Origin_Entity_Mapping_Grp;
+        key id;
+
+        container attributes {
+            leaf antennaModelNumber {
+                description "Vendor-specific antenna model identifier. This
+                attribute is part of AISG v3 ADB Standard and has no
+                operational impact.";
+                type string;
+            }
+
+            leaf mechanicalAntennaBearing {
+                description "Antenna bearing on antenna subunit where antenna
+                unit is installed.";
+                type int32;
+            }
+
+            leaf mechanicalAntennaTilt {
+                description "The fixed antenna tilt of the installation, defined
+                as the inclination of the antenna element respect to the
+                vertical plane. It is a signed value. Positive indicates
+                downtilt, and negative indicates uptilt.";
+                type int32;
+            }
+
+            leaf positionWithinSector {
+                description "Antenna unit position within sector. This attribute
+                is part of AISG v3 ADB Standard and has no operational
+                impact.";
+                type string;
+            }
+
+            leaf totalTilt {
+                description "Total antenna elevation including the installed
+                tilt and the tilt applied by the Remote Electrical
+                Tilt (RET).";
+                type int32;
+            }
+
+            leaf electricalAntennaTilt {
+                description "Electrically-controlled tilt of main beam maximum
+                with respect to direction orthogonal to antenna element
+                axis (see 3GPP TS 25.466). Value is signed; tilt down is
+                positive, tilt up is negative.";
+                type int32;
+            }
+
+            leaf-list antennaBeamWidth {
+                description "The angular span of the main lobe of the antenna
+                radiation pattern in the horizontal plane. Measured in
+                degrees.
+
+                Deprecated: Since 24.Q4. Replaced by AntennaModule::horizontalBeamWidth
+                and AntennaModule::verticalBeamWidth. Planned to be removed.";
+                type uint32;
+            }
+
+            leaf horizontalBeamWidth  {
+                description "The angular span of the main lobe of the antenna
+                radiation pattern in the horizontal plane.";
+                type decimal64 {
+                    fraction-digits 1;
+                    range "0..360";
+                }
+                units "decimal degrees";
+            }
+
+            leaf verticalBeamWidth   {
+                description "The angular span of the main lobe of the antenna
+                radiation pattern in the vertical plane.";
+                type decimal64 {
+                    fraction-digits 1;
+                    range "0..360";
+                }
+                units "decimal degrees";
+            }
+
+            leaf azimuth {
+                description "The value of the azimuth of the Antenna Module.";
+                type decimal64 {
+                    fraction-digits 1;
+                    range "0..360";
+                }
+                units "decimal degrees";
+            }
+
+            uses geo:geo-location;
+        }
+    }
+
+    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULEEEEEEEEEEEE_REALISED_BY_ANTENNAMODULEEEEEEEEEEEEEEE {
+
+        description
+            "The aSide of this relationship is an instance of the AntennaModule type.
+            The bSide of this relationship is an instance of the AntennaModule type.
+            The AntennaModule represents the physical antenna that realised by the AntennaModule.
+            An AntennaModule instance can realised one AntennaModule.
+            An AntennaModule instance can be realised by many AntennaModules.
+            ";
+
+        uses or-teiv-types:Top_Grp_Type;
+        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
+        key id;
+
+        leaf-list realised-antennaModule {
+            description "Antenna Module realised by many Antenna Modules.";
+            or-teiv-yext:aSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
+            type instance-identifier;
+        }
+
+        leaf-list realising-antennaModule {
+            description "Antenna Module realising this Antenna Module.";
+            or-teiv-yext:bSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
+            type instance-identifier;
+        }
+    }
+
+    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULEEEEEEEEEEEE_DEPLOYED_ON_ANTENNAMODULEEEEEEEEEEEEEEE { // 1..n to 0..m
+
+        description
+            "The aSide of this relationship is an instance of the AntennaModule type.
+            The bSide of this relationship is an instance of the AntennaModule type.
+            The AntennaModule represents the physical antenna that developed on the AntennaModule.
+            An AntennaModule instance can developed one AntennaModule.
+            An AntennaModule instance can be developed on one AntennaModule.
+            ";
+
+        uses or-teiv-types:Top_Grp_Type;
+        uses or-teiv-types:Origin_Relationship_Mapping_Grp;
+        key id;
+
+        leaf-list developed-on-antennaModule {
+            description "Antenna Module developed on this Antenna Module.";
+            or-teiv-yext:aSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
+            type instance-identifier;
+        }
+
+        leaf-list developing-antennaModule {
+            description "Antenna Module developing this Antenna Module.";
+            or-teiv-yext:bSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
+            type instance-identifier;
+        }
+    }
+}
\ No newline at end of file
diff --git a/teiv/src/test/resources/yang/models/o-ran-smo-teiv-oam-test.yang b/teiv/src/test/resources/yang/models/o-ran-smo-teiv-oam-test.yang
new file mode 100644 (file)
index 0000000..21ca695
--- /dev/null
@@ -0,0 +1,38 @@
+module o-ran-smo-teiv-oam-test {
+    yang-version 1.1;
+    namespace "urn:o-ran:smo-teiv-oam-test";
+    prefix or-teiv-oam-test;
+
+    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }
+
+    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }
+
+    organization "ORAN";
+    contact "The Authors";
+    description
+        "These are just test O&M topology model.";
+
+    revision "2024-10-04" {
+        description "Added grouping, Origin_Entity_Mapping_Grp to the topology object.";
+        or-teiv-yext:label 0.4.0;
+    }
+
+    revision "2024-05-24" {
+        description "Initial revision.";
+        or-teiv-yext:label 0.3.0;
+    }
+
+    or-teiv-yext:domain OAM;
+
+    list ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt {
+        description "A Managed Element (ME) is a node into a telecommunication
+        network providing support and/or service to subscribers. An ME
+        communicates with a manager application (directly or indirectly)
+        over one or more interfaces for the purpose of being monitored
+        and/or controlled.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        uses or-teiv-types:Origin_Entity_Mapping_Grp;
+        key id;
+    }
+}
\ No newline at end of file
diff --git a/teiv/src/test/resources/yang/models/o-ran-smo-teiv-ran-test.yang b/teiv/src/test/resources/yang/models/o-ran-smo-teiv-ran-test.yang
new file mode 100644 (file)
index 0000000..ff8c7c3
--- /dev/null
@@ -0,0 +1,240 @@
+module o-ran-smo-teiv-ran-test {
+    yang-version 1.1;
+    namespace "urn:o-ran:smo-teiv-ran-test";
+    prefix or-teiv-ran-test;
+
+    import o-ran-smo-teiv-common-yang-types {prefix or-teiv-types; }
+
+    import o-ran-smo-teiv-common-yang-extensions {prefix or-teiv-yext; }
+
+    import _3gpp-common-yang-types { prefix types3gpp; }
+
+    import ietf-geo-location {
+        prefix geo;
+        reference "RFC 9179: A YANG Grouping for Geographic Locations";
+    }
+
+    organization "ORAN";
+    contact "The Authors";
+    description
+        "These are just test RAN topology model.";
+
+    revision "2024-10-08" {
+        description "Added range for azimuth attribute of Sector.";
+        or-teiv-yext:label 0.5.0;
+    }
+
+    revision "2024-10-04" {
+        description "Added groupings, Origin_Entity_Mapping_Grp or Origin_Relationship_Mapping_Grp
+        to the corresponding topology object.";
+        or-teiv-yext:label 0.4.0;
+    }
+
+    revision "2024-05-24" {
+        description "Initial revision.";
+        or-teiv-yext:label 0.3.0;
+    }
+
+    or-teiv-yext:domain RAN;
+
+    list ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn {
+        description "gNodeB Distributed Unit (gNB-DU).
+
+        A gNB may consist of a gNB-Centralized Unit (gNB-CU) and a gNB-DU.
+        The CU processes non-real time protocols and services, and the DU
+        processes PHY level protocol and real time services. The gNB-CU and
+        the gNB-DU units are connected via F1 logical interface.
+
+        The following is true for a gNB-DU:
+        Is connected to the gNB-CU-CP through the F1-C interface. Is
+        connected to the gNB-CU-UP through the F1-U interface. One gNB-DU is
+        connected to only one gNB-CU-CP. One gNB-DU can be connected to
+        multiple gNB-CU-UPs under the control of the same gNB-CU-CP.
+
+        Note: A gNB may consist of a gNB-CU-CP, multiple gNB-CU-UPs and
+        multiple gNB-DUs. gNB-DU is a concrete class that extends the NG-RAN
+        node object. In Topology, you can create, read, update, and delete
+        the gNB-DU object.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        container attributes {
+            container dUpLMNId {
+                description "PLMN identifier used as part of PM Events data";
+                uses types3gpp:PLMNId;
+            }
+
+            leaf gNBDUId {
+                description "Unique identifier for the DU within a gNodeB";
+                type int64;
+            }
+
+            leaf gNBId {
+                description "Identity of gNodeB within a PLMN";
+                type int64;
+            }
+
+            leaf gNBIdLength {
+                description "Length of gNBId bit string representation";
+                type int32;
+            }
+        }
+    }
+
+
+    list NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU  {
+        description "Represents an NR Cell in gNodeB-DU.
+
+        5G NR is a new radio access technology (RAT) developed by 3GPP for
+        the 5G (fifth generation) mobile network. It is designed to be the
+        global standard for the air interface of 5G networks.
+
+        5G NR has synchronization signal that is known as Primary
+        Synchronization signal (PSS) and Secondary Synchronization signal
+        (SSS). These signals are specific to NR physical layer and provide
+        the following information required by UE for downlink
+        synchronization: PSS provides Radio Frame Boundary (Position of 1st
+        Symbol in a Radio frame) SSS provides Subframe Boundary (Position of
+        1st Symbol in a Subframe) Physical Layer Cell ID (PCI) information
+        using both PSS and SSS.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        container attributes {
+            leaf cellLocalIdddddddddddddddddddddddddddddddddddddddddddddddddddddd {
+                description "Used together with gNodeB identifier to identify NR
+                cell in PLMN. Used together with gNBId to form NCI.";
+                type int32;
+            }
+
+            leaf nCI {
+                description "NR Cell Identity.";
+                type int64;
+            }
+
+            leaf nRPCI {
+                description "The Physical Cell Identity (PCI) of the NR cell.";
+                type int32;
+            }
+
+            leaf nRTAC {
+                description "NR Tracking Area Code (TAC).";
+                type int32;
+            }
+        }
+    }
+
+    list AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy {
+        description "This MO serves as a mapping between the cell and the RBS
+        equipment used to provide coverage in a certain geographical area.
+        The MO also controls the maximum output power of the sector.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        container attributes {
+            leaf-list eUtranFqBands {
+                description "List of LTE frequency bands that associated
+                hardware supports";
+                type string;
+            }
+
+            leaf-list geranFqBands {
+                description "List of GERAN frequency bands that associated
+                hardware supports";
+                type string;
+            }
+
+            leaf-list nRFqBands {
+                description "List of NR frequency bands associated hardware
+                supports";
+                type string;
+            }
+        }
+    }
+
+    list LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr {
+        description "The LTE Sector Carrier object provides the attributes for
+        defining the logical characteristics of a carrier (cell) in a
+        sector. A sector is a coverage area associated with a base station
+        having its own antennas, radio ports, and control channels. The
+        concept of sectors was developed to improve co-channel interference
+        in cellular systems, and most wireless systems use three sector
+        cells.";
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        container attributes {
+            leaf sectorCarrierType {
+                description "Indicates whether or not the sector carrier
+                modelled by MO SectorCarrier is a digital sector.";
+                type enumeration {
+                    enum normal_sector {
+                        value 0;
+                        description "Not a digital sector";
+                    }
+                    enum left_digital_sector {
+                        value 1;
+                        description "Left digital sector for 2DS";
+                    }
+                    enum right_digital_sector {
+                        value 2;
+                        description "Right digital sector for 2DS";
+                    }
+                    enum left_digital_sector_3ds {
+                        value 3;
+                        description "Left digital sector for 3DS";
+                    }
+                    enum right_digital_sector_3ds {
+                        value 4;
+                        description "Right digital sector for 3DS";
+                    }
+                    enum middle_digital_sector_3ds {
+                        value 5;
+                        description "Middle digital sector for 3DS";
+                    }
+                }
+            }
+        }
+    }
+
+    or-teiv-yext:biDirectionalTopologyRelationship ODUFUNCTIONNNNNNNNNNNNNNNNN_PROVIDES_NRCELLDUUUUUUUUUUUUUUUUUU { // 1 to 0..n
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        leaf-list provided-nrCellDu {
+            description "gNodeB-DU Function provides NR Cell-DU.";
+            or-teiv-yext:aSide ODUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn;
+            type instance-identifier;
+        }
+
+        leaf provided-by-gnbduFunction {
+            description "NR Cell-DU provided by gNodeB-DU Function.";
+            or-teiv-yext:bSide NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU;
+            type instance-identifier;
+            mandatory true;
+        }
+    }
+
+    or-teiv-yext:biDirectionalTopologyRelationship LTESECTORCARRIERRRRRRRRRRRRRRRRRRRRR_USES_ANTENNACAPABILITYYYYYYYYYYYYYYY { // 0..n to 0..1
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        leaf used-antennaCapability {
+            description "LTE Sector Carrier uses Antenna Capability.";
+            or-teiv-yext:aSide LTESectorCarrierrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr;
+            type instance-identifier;
+        }
+
+        leaf-list used-by-lteSectorCarrier {
+            description "Antenna Capability used by LTE Sector Carrier.";
+            or-teiv-yext:bSide AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy;
+            type instance-identifier;
+        }
+    }
+}
\ No newline at end of file
diff --git a/teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-equipment-ran-test.yang b/teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-equipment-ran-test.yang
new file mode 100644 (file)
index 0000000..d143ea2
--- /dev/null
@@ -0,0 +1,43 @@
+module o-ran-smo-teiv-rel-equipment-ran-test {
+    yang-version 1.1;
+    namespace "urn:o-ran:smo-teiv-rel-equipment-ran";
+    prefix or-teiv-rel-equipran-test;
+
+    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }
+
+    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }
+
+    import o-ran-smo-teiv-equipment-test { prefix or-teiv-equip-test; }
+
+    import o-ran-smo-teiv-ran-test { prefix or-teiv-ran-test; }
+
+    organization "ORAN";
+    contact "The Authors";
+    description
+        "These are just test Equipment and RAN topology relation model.";
+
+    revision "2024-05-24" {
+        description "Initial revision.";
+        or-teiv-yext:label 0.3.0;
+    }
+
+    or-teiv-yext:domain REL_EQUIPMENT_RAN;
+
+    or-teiv-yext:biDirectionalTopologyRelationship ANTENNAMODULEEEEEEEEEEEEEEEEEEEE_SERVES_ANTENNACAPABILITYYYYYYYYYYYYYYYYYY { // 0..n to 0..m
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        leaf-list serviced-antennaCapability {
+            description "Antenna Capability serviced by this Antenna Module.";
+            or-teiv-yext:aSide or-teiv-equip-test:AntennaModuleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
+            type instance-identifier;
+        }
+
+        leaf-list serving-antennaModule {
+            description "Antenna Module serves this Antenna Capability.";
+            or-teiv-yext:bSide or-teiv-ran-test:AntennaCapabilityyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy;
+            type instance-identifier;
+        }
+    }
+}
\ No newline at end of file
diff --git a/teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-oam-ran-test.yang b/teiv/src/test/resources/yang/models/o-ran-smo-teiv-rel-oam-ran-test.yang
new file mode 100644 (file)
index 0000000..161736c
--- /dev/null
@@ -0,0 +1,69 @@
+module o-ran-smo-teiv-rel-oam-ran-test {
+    yang-version 1.1;
+    namespace "urn:o-ran:smo-teiv-rel-oam-ran-test";
+    prefix or-teiv-rel-oam-ran-test;
+
+    import o-ran-smo-teiv-common-yang-types { prefix or-teiv-types; }
+
+    import o-ran-smo-teiv-common-yang-extensions { prefix or-teiv-yext; }
+
+    import o-ran-smo-teiv-oam-test { prefix or-teiv-oam-test; }
+
+    import o-ran-smo-teiv-ran-test { prefix or-teiv-ran-test; }
+
+    organization "ORAN";
+    contact "The Authors";
+    description
+        "These are just test O&M and RAN topology relation model.";
+
+    revision "2024-10-04" {
+        description "Added grouping, Origin_Relationship_Mapping_Grp to the topology object.";
+        or-teiv-yext:label 0.4.0;
+    }
+
+    revision "2024-05-24" {
+        description "Initial revision.";
+        or-teiv-yext:label 0.3.0;
+    }
+
+    or-teiv-yext:domain REL_OAM_RAN;
+
+    or-teiv-yext:biDirectionalTopologyRelationship ManagedElementttttttttttttttttt_USES_NRCellDUUUUUUUUUUUU { // 1 to 0..1
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        leaf used-nrCellDu {
+            description "gNodeB-DU Function uses NR Cell-DU.";
+            or-teiv-yext:aSide or-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt;
+            type instance-identifier;
+        }
+
+        leaf used-by-managedElement {
+            description "NR Cell-DU used by managedElement.";
+            or-teiv-yext:bSide or-teiv-ran-test:NRCellDUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU;
+            type instance-identifier;
+            mandatory true;
+        }
+
+    }
+
+    or-teiv-yext:biDirectionalTopologyRelationship MANAGEDELEMENTTTTTTTTTTTTTTT_MANAGES_GNBDUFUNCTIONNNNNNNNNNNNNNN {    // 1 to 0..n
+
+        uses or-teiv-types:Top_Grp_Type;
+        key id;
+
+        leaf-list managed-gnbduFunction {
+            description "Managed Element manages gNodeB-DU Function.";
+            or-teiv-yext:aSide or-teiv-oam-test:ManagedElementtttttttttttttttttttttttttttttttttttttttttttttttttt;
+            type instance-identifier;
+        }
+
+        leaf managed-by-managedElement {
+            description "gNodeB-DU Function managed by Managed Element.";
+            or-teiv-yext:bSide or-teiv-ran-test:GNBDUFunctionnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn;
+            type instance-identifier;
+            mandatory true;
+        }
+    }
+}
\ No newline at end of file