summaryrefslogtreecommitdiffstats
path: root/cps-nf-proxy-rest/src/main
diff options
context:
space:
mode:
authorBruno Sakoto <bruno.sakoto@bell.ca>2021-02-26 17:48:12 +0000
committerGerrit Code Review <gerrit@onap.org>2021-02-26 17:48:12 +0000
commitc04e212a1418d298aa88680b9c87f5905b206de0 (patch)
treec677557d3540faba095d755980240c21e9716e8d /cps-nf-proxy-rest/src/main
parentb87f3238bd57a866f7682055c5357bc232c391f2 (diff)
parentb5d573b02c7d1376e92e59887371965a2fb43c25 (diff)
Merge "CPS-240 - Create REST End-point on NF-Proxy for DataNode Update & cpsPath Query"
Diffstat (limited to 'cps-nf-proxy-rest/src/main')
-rw-r--r--cps-nf-proxy-rest/src/main/java/org/onap/cps/nfproxy/rest/controller/NfProxyController.java28
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);
+ }
}