/* * ============LICENSE_START======================================================= * Copyright (C) 2020-2022 Nordix Foundation. * Modifications Copyright (C) 2021 Pantheon.tech * Modifications Copyright (C) 2022 Bell Canada * ================================================================================ * 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.onap.cps.spi; import java.util.Collection; import java.util.List; import java.util.Map; import org.onap.cps.spi.model.DataNode; /* Data Store interface that is responsible for handling yang data. Please follow guidelines in https://gerrit.nordix.org/#/c/onap/ccsdk/features/+/6698/19/cps/interface-proposal/src/main/java/cps/javadoc/spi/DataStoreService.java when adding methods. */ public interface CpsDataPersistenceService { /** * Store a datanode. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param dataNode data node */ void storeDataNode(String dataspaceName, String anchorName, DataNode dataNode); /** * Add a child to a Fragment. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param parentXpath parent xpath * @param dataNode dataNode */ void addChildDataNode(String dataspaceName, String anchorName, String parentXpath, DataNode dataNode); /** * Adds list child elements to a Fragment. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param parentNodeXpath parent node xpath * @param listElementsCollection collection of data nodes representing list elements */ void addListElements(String dataspaceName, String anchorName, String parentNodeXpath, Collection listElementsCollection); /** * Retrieves datanode by XPath for given dataspace and anchor. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param xpath xpath * @param fetchDescendantsOption defines the scope of data to fetch: either single node or all the descendant nodes * (recursively) as well * @return data node object */ DataNode getDataNode(String dataspaceName, String anchorName, String xpath, FetchDescendantsOption fetchDescendantsOption); /** * Updates leaves for existing data node. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param xpath xpath * @param leaves the leaves as a map where key is a leaf name and a value is a leaf value */ void updateDataLeaves(String dataspaceName, String anchorName, String xpath, Map leaves); /** * Replaces existing data node content including descendants. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param dataNode data node */ void replaceDataNodeTree(String dataspaceName, String anchorName, DataNode dataNode); /** * Replaces list content by removing all existing elements and inserting the given new elements * under given parent, anchor and dataspace. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param parentNodeXpath parent node xpath * @param newListElements collection of data nodes representing the new list content */ void replaceListContent(String dataspaceName, String anchorName, String parentNodeXpath, Collection newListElements); /** * Deletes any dataNode, yang container or yang list or yang list element. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param targetXpath xpath to list or list element (include [@key=value] to delete a single list element) */ void deleteDataNode(String dataspaceName, String anchorName, String targetXpath); /** * Deletes all dataNodes in a given anchor. * * @param dataspaceName dataspace name * @param anchorName anchor name */ void deleteDataNodes(String dataspaceName, String anchorName); /** * Deletes existing a single list element or the whole list. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param targetXpath xpath to list or list element (include [@key=value] to delete a single list element) */ void deleteListDataNode(String dataspaceName, String anchorName, String targetXpath); /** * Get a datanode by cps path. * * @param dataspaceName dataspace name * @param anchorName anchor name * @param cpsPath cps path * @param fetchDescendantsOption defines whether the descendants of the node(s) found by the query should be * included in the output * @return the data nodes found i.e. 0 or more data nodes */ List queryDataNodes(String dataspaceName, String anchorName, String cpsPath, FetchDescendantsOption fetchDescendantsOption); /** * Starts a session which allows use of locks and batch interaction with the persistence service. * * @return Session ID string */ String startSession(); /** * Close session. * * @param sessionId session ID */ void closeSession(String sessionId); /** * Lock anchor. * To release locks(s), the session holding the lock(s) must be closed. * * @param sessionID session ID * @param dataspaceName dataspace name * @param anchorName anchor name * @param timeoutInMilliseconds lock attempt timeout in milliseconds */ void lockAnchor(String sessionID, String dataspaceName, String anchorName, Long timeoutInMilliseconds); }