diff options
author | niamhcore <niamh.core@est.tech> | 2021-02-26 10:13:48 +0000 |
---|---|---|
committer | niamhcore <niamh.core@est.tech> | 2021-02-26 17:21:02 +0000 |
commit | b5d573b02c7d1376e92e59887371965a2fb43c25 (patch) | |
tree | 366dd39ab6391c1dc5adbfd684eee943d65b6e6a /cps-nf-proxy-rest/src/main/java | |
parent | d3609db46635b9bdb0a49a7d0e18ebe144bb7f29 (diff) |
CPS-240 - Create REST End-point on NF-Proxy for DataNode Update & cpsPath Query
Issue-ID: CPS-240
Signed-off-by: niamhcore <niamh.core@est.tech>
Change-Id: I2aed92f8ab34282b12e23ae7807a391446165eb0
Diffstat (limited to 'cps-nf-proxy-rest/src/main/java')
-rw-r--r-- | cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java b/cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java index 494e7f6596..93ed06580b 100644 --- a/cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java +++ b/cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java @@ -1,7 +1,7 @@ /* * ============LICENSE_START======================================================= * Copyright (C) 2021 Pantheon.tech - * ================================================================================ + * Modifications (C) 2021 Nordix Foundation * Modification Copyright (C) 2021 highstreet technologies GmbH * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); @@ -21,6 +21,9 @@ package org.onap.cps.nfproxy.rest.controller; +import com.google.gson.Gson; +import com.google.gson.GsonBuilder; +import java.util.Collection; import javax.validation.Valid; import org.onap.cps.nfproxy.api.NfProxyDataService; import org.onap.cps.nfproxy.rest.api.NfProxyApi; @@ -38,6 +41,7 @@ import org.springframework.web.bind.annotation.RestController; @RequestMapping("${rest.api.xnf-base-path}") public class NfProxyController implements NfProxyApi { + private static final Gson GSON = new GsonBuilder().create(); private static final String XPATH_ROOT = "/"; @Autowired @@ -45,7 +49,7 @@ public class NfProxyController implements NfProxyApi { @Override public ResponseEntity<Object> getNodeByCmHandleAndXpath(final String cmHandle, @Valid final String xpath, - @Valid final Boolean includeDescendants) { + @Valid final Boolean includeDescendants) { if (XPATH_ROOT.equals(xpath)) { return new ResponseEntity<>(HttpStatus.NOT_IMPLEMENTED); } @@ -54,4 +58,24 @@ public class NfProxyController implements NfProxyApi { final DataNode dataNode = nfProxyDataService.getDataNode(cmHandle, xpath, fetchDescendantsOption); return new ResponseEntity<>(DataMapUtils.toDataMap(dataNode), HttpStatus.OK); } + + @Override + public ResponseEntity<Object> queryNodesByCmHandleAndCpsPath(final String cmHandle, @Valid final String cpsPath) { + final Collection<DataNode> dataNodes = nfProxyDataService.queryDataNodes(cmHandle, cpsPath); + return new ResponseEntity<>(GSON.toJson(dataNodes), HttpStatus.OK); + } + + @Override + public ResponseEntity<Object> replaceNode(@Valid final String jsonData, final String cmHandle, + @Valid final String parentNodeXpath) { + nfProxyDataService.replaceNodeTree(cmHandle, parentNodeXpath, jsonData); + return new ResponseEntity<>(HttpStatus.OK); + } + + @Override + public ResponseEntity<Object> updateNodeLeaves(@Valid final String jsonData, final String cmHandle, + @Valid final String parentNodeXpath) { + nfProxyDataService.updateNodeLeaves(cmHandle, parentNodeXpath, jsonData); + return new ResponseEntity<>(HttpStatus.OK); + } } |