Code fix for attach and detach volumes
Cherry-picked to split up commit https://gerrit.onap.org/r/#/c/31149/
into individual jira tickets.
open stack consumes cdp-pal openstack jars to connect to cinder,
this fix retrives set of volumes from volumeservice provider
and performs attach or detach through compute service.
Change-Id: I59bce60d9f79ba9285f284fe1f56945e63d0bcba
Signed-off-by: Patrick Brady <pb071s@att.com>
Signed-off-by: kusuma kumari M <km583p@att.com>
Issue-ID: APPC-448
diff --git a/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/AttachVolumeServer.java b/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/AttachVolumeServer.java
index fe42076..e27b159 100644
--- a/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/AttachVolumeServer.java
+++ b/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/AttachVolumeServer.java
@@ -2,7 +2,7 @@
* ============LICENSE_START=======================================================
* ONAP : APPC
* ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
* =============================================================================
@@ -25,7 +25,6 @@
import static org.onap.appc.adapter.iaas.provider.operation.common.enums.Operation.ATTACHVOLUME_SERVICE;
import static org.onap.appc.adapter.utils.Constants.ADAPTER_NAME;
-
import com.att.cdp.exceptions.ZoneException;
import com.att.cdp.zones.ComputeService;
import com.att.cdp.zones.Context;
@@ -74,48 +73,57 @@
String identStr = (ident == null) ? null : ident.toString();
context = getContext(requestContext, vmUrl, identStr);
if (context != null) {
- tenantName = context.getTenantName();// this variable also is used in case of exception
+ tenantName = context.getTenantName();// this variable also is
+ // used in case of
+ // exception
requestContext.reset();
server = lookupServer(requestContext, context, vm.getServerId());
logger.debug(Msg.SERVER_FOUND, vmUrl, context.getTenantName(), server.getStatus().toString());
Context contx = server.getContext();
ComputeService service = contx.getComputeService();
VolumeService volumeService = contx.getVolumeService();
- logger.info("Collecting volume status for volume id: " + volumeId);
+ logger.info("collecting volume status for volume -id:" + volumeId);
List<Volume> volumes = volumeService.getVolumes();
- logger.info("Size of volume list: " + volumes.size());
- for (Volume volume : volumes) {
- logger.info("Processing volume with id: " + volume.getId());
- if (!volume.getId().equals(volumeId)) {
+ Volume volume = new Volume();
+ logger.info("Size of volume list :" + volumes.size());
+ if (volumes != null && !volumes.isEmpty()) {
+ if (!(volumes.contains(volumeId))) {
volume.setId(volumeId);
- logger.info("Ready to Attach Volume to the server: " + Volume.Status.ATTACHING);
+ logger.info("Ready to Attach Volume to the server:");
service.attachVolume(server, volume, device);
- logger.info("Volume status after performing attach: " + volume.getStatus());
-
- validateAttach(volumeService, volumeId, requestContext);
+ logger.info("Volume status after performing attach:" + volume.getStatus());
+ if (validateAttach(volumeService, volumeId)) {
+ ctx.setAttribute("VOLUME_STATUS", "SUCCESS");
+ doSuccess(requestContext);
+ } else {
+ String msg = "Failed to attach Volume";
+ logger.info("Volume with " + volumeId + " unable to attach");
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
+ doFailure(requestContext, HttpStatus.NOT_IMPLEMENTED_501, msg);
+ }
} else {
- String msg = "Volume with id: " + volumeId + " cannot be attached as it already exists";
- logger.info(msg);
+ String msg = "Volume with volume id " + volumeId + " cannot be attached as it already exists";
+ logger.info("Alreday volumes exists:");
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
doFailure(requestContext, HttpStatus.NOT_IMPLEMENTED_501, msg);
}
}
context.close();
- doSuccess(requestContext);
- ctx.setAttribute("VOLUME_STATUS", "SUCCESS");
} else {
ctx.setAttribute("VOLUME_STATUS", "CONTEXT_NOT_FOUND");
}
} catch (ZoneException e) {
String msg = EELFResourceManager.format(Msg.SERVER_NOT_FOUND, e, vmUrl);
logger.error(msg);
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
doFailure(requestContext, HttpStatus.NOT_FOUND_404, msg);
} catch (RequestFailedException e) {
- logger.error("An error occurred in attachVolume", e);
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
doFailure(requestContext, e.getStatus(), e.getMessage());
} catch (Exception ex) {
String msg = EELFResourceManager.format(Msg.SERVER_OPERATION_EXCEPTION, ex, ex.getClass().getSimpleName(),
- ATTACHVOLUME_SERVICE.toString(), vmUrl, tenantName);
- logger.error(msg, ex);
+ ATTACHVOLUME_SERVICE.toString(), vmUrl, tenantName);
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
doFailure(requestContext, HttpStatus.INTERNAL_SERVER_ERROR_500, msg);
}
return server;
@@ -123,24 +131,22 @@
@Override
protected ModelObject executeProviderOperation(Map<String, String> params, SvcLogicContext context)
- throws APPCException {
+ throws APPCException {
setMDC(Operation.ATTACHVOLUME_SERVICE.toString(), "App-C IaaS Adapter:attachVolume", ADAPTER_NAME);
logOperation(Msg.ATTACHINGVOLUME_SERVER, params, context);
return attachVolume(params, context);
}
- private void validateAttach(VolumeService vs, String volId, RequestContext requestContext)
- throws RequestFailedException, ZoneException {
-
- List<Volume> volList = vs.getVolumes();
- for (Volume v : volList) {
- if (v.getId().equals(volId)) {
- logger.info("Volume with id: " + volId + " attached successfully");
- doSuccess(requestContext);
- } else {
- logger.info("Failed to attach volume with id: " + volId);
- }
+ protected boolean validateAttach(VolumeService volumeService, String volumeId)
+ throws RequestFailedException, ZoneException {
+ boolean flag = false;
+ List<Volume> volumeList = volumeService.getVolumes();
+ if (volumeList.contains(volumeId)) {
+ flag = true;
+ } else {
+ flag = false;
}
+ logger.info("validateAttach flag-->" + flag);
+ return flag;
}
-
}
diff --git a/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/DettachVolumeServer.java b/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/DettachVolumeServer.java
index 6f0ab87..d9b30cb 100644
--- a/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/DettachVolumeServer.java
+++ b/appc-adapters/appc-iaas-adapter/appc-iaas-adapter-bundle/src/main/java/org/onap/appc/adapter/iaas/provider/operation/impl/DettachVolumeServer.java
@@ -2,7 +2,7 @@
* ============LICENSE_START=======================================================
* ONAP : APPC
* ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
* =============================================================================
@@ -23,9 +23,8 @@
*/
package org.onap.appc.adapter.iaas.provider.operation.impl;
-import static org.onap.appc.adapter.iaas.provider.operation.common.enums.Operation.ATTACHVOLUME_SERVICE;
+import static org.onap.appc.adapter.iaas.provider.operation.common.enums.Operation.DETACHVOLUME_SERVICE;
import static org.onap.appc.adapter.utils.Constants.ADAPTER_NAME;
-
import com.att.cdp.exceptions.ZoneException;
import com.att.cdp.zones.ComputeService;
import com.att.cdp.zones.Context;
@@ -52,12 +51,11 @@
import org.onap.ccsdk.sli.core.sli.SvcLogicContext;
public class DettachVolumeServer extends ProviderServerOperation {
-
private final EELFLogger logger = EELFManager.getInstance().getLogger(DettachVolumeServer.class);
@Override
protected ModelObject executeProviderOperation(Map<String, String> params, SvcLogicContext context)
- throws APPCException {
+ throws APPCException {
setMDC(Operation.DETACHVOLUME_SERVICE.toString(), "App-C IaaS Adapter:dettachVolume", ADAPTER_NAME);
logOperation(Msg.DETTACHINGVOLUME_SERVER, params, context);
return dettachVolume(params, context);
@@ -65,84 +63,86 @@
private Server dettachVolume(Map<String, String> params, SvcLogicContext ctx) {
Server server = null;
- RequestContext rc = new RequestContext(ctx);
- rc.isAlive();
+ RequestContext requestContext = new RequestContext(ctx);
+ requestContext.isAlive();
String appName = configuration.getProperty(Constants.PROPERTY_APPLICATION_NAME);
String vmUrl = params.get(ProviderAdapter.PROPERTY_INSTANCE_URL);
String volumeId = params.get(ProviderAdapter.VOLUME_ID);
VMURL vm = VMURL.parseURL(vmUrl);
Context context;
- String tenantName = "Unknown";//to be used also in case of exception
+ String tenantName = "Unknown";// to be used also in case of exception
try {
- if (validateVM(rc, appName, vmUrl, vm)) {
+ if (validateVM(requestContext, appName, vmUrl, vm)) {
return null;
}
IdentityURL ident = IdentityURL.parseURL(params.get(ProviderAdapter.PROPERTY_IDENTITY_URL));
String identStr = (ident == null) ? null : ident.toString();
- context = getContext(rc, vmUrl, identStr);
+ context = getContext(requestContext, vmUrl, identStr);
if (context != null) {
- tenantName = context.getTenantName();//this variable also is used in case of exception
- rc.reset();
- server = lookupServer(rc, context, vm.getServerId());
+ tenantName = context.getTenantName();// this variable also is
+ // used in case of
+ // exception
+ requestContext.reset();
+ server = lookupServer(requestContext, context, vm.getServerId());
logger.debug(Msg.SERVER_FOUND, vmUrl, context.getTenantName(), server.getStatus().toString());
Context contx = server.getContext();
ComputeService service = contx.getComputeService();
- VolumeService vs = contx.getVolumeService();
+ VolumeService volumeService = contx.getVolumeService();
logger.info("collecting volume status for volume -id: " + volumeId);
- List<Volume> volList = vs.getVolumes();
- logger.info("Size of volume list: " + volList.size());
- if (!volList.isEmpty()) {
- for (Volume v : volList) {
- logger.info("list of volumesif exists: " + v.getId());
- if (v.getId().equals(volumeId)) {
- v.setId(volumeId);
- logger.info("Ready to Detach Volume from the server: " + Volume.Status.DETACHING);
- service.detachVolume(server, v);
- logger.info("Volume status after performing detach: " + v.getStatus());
- if (validateDetach(vs, volumeId)) {
- doSuccess(rc);
- }
+ List<Volume> volumes = volumeService.getVolumes();
+ Volume volume = new Volume();
+ logger.info("Size of volume list: " + volumes.size());
+ if (volumes != null && !volumes.isEmpty()) {
+ if (volumes.contains(volumeId)) {
+ volume.setId(volumeId);
+ logger.info("Ready to Detach Volume from the server: " + Volume.Status.DETACHING);
+ service.detachVolume(server, volume);
+ logger.info("Volume status after performing detach: " + volume.getStatus());
+ if (validateDetach(volumeService, volumeId)) {
+ doSuccess(requestContext);
} else {
- String msg =
- "Volume with volume id " + volumeId + " cannot be detached as it doesn't exists";
- doFailure(rc, HttpStatus.NOT_IMPLEMENTED_501, msg);
+ String msg = "Volume with volume id " + volumeId + " cannot be detached ";
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
+ doFailure(requestContext, HttpStatus.NOT_IMPLEMENTED_501, msg);
+ logger.info("unable to detach volume from the server");
}
+ } else {
+ String msg = "Volume with volume id " + volumeId + " cannot be detached as it doesn't exists";
+ ctx.setAttribute("VOLUME_STATUS", "FAILURE");
+ doFailure(requestContext, HttpStatus.NOT_IMPLEMENTED_501, msg);
}
+ logger.info("volumestatus:" + ctx.getAttribute("VOLUME_STATUS"));
}
context.close();
- doSuccess(rc);
- ctx.setAttribute("VOLUME_STATUS", "SUCCESS");
} else {
ctx.setAttribute("VOLUME_STATUS", "CONTEXT_NOT_FOUND");
}
} catch (ZoneException e) {
String msg = EELFResourceManager.format(Msg.SERVER_NOT_FOUND, e, vmUrl);
logger.error(msg);
- doFailure(rc, HttpStatus.NOT_FOUND_404, msg);
+ doFailure(requestContext, HttpStatus.NOT_FOUND_404, msg);
} catch (RequestFailedException e) {
logger.error("An error occurred when processing the request", e);
- doFailure(rc, e.getStatus(), e.getMessage());
+ doFailure(requestContext, e.getStatus(), e.getMessage());
} catch (Exception e) {
String msg = EELFResourceManager.format(Msg.SERVER_OPERATION_EXCEPTION, e, e.getClass().getSimpleName(),
- ATTACHVOLUME_SERVICE.toString(), vmUrl, tenantName);
+ DETACHVOLUME_SERVICE.toString(), vmUrl, tenantName);
logger.error(msg, e);
- doFailure(rc, HttpStatus.INTERNAL_SERVER_ERROR_500, msg);
+ doFailure(requestContext, HttpStatus.INTERNAL_SERVER_ERROR_500, msg);
}
return server;
}
- protected boolean validateDetach(VolumeService vs, String volId) throws RequestFailedException, ZoneException {
+ protected boolean validateDetach(VolumeService volumeService, String volId)
+ throws RequestFailedException, ZoneException {
boolean flag = false;
- List<Volume> volList = vs.getVolumes();
- for (Volume v : volList) {
- if (!v.getId().equals(volId)) {
- logger.info("Volume with " + volId + "detached successsfully");
- flag = true;
- } else {
- logger.info("failed to detach volume with id" + volId);
- flag = false;
- }
+ List<Volume> volumes = volumeService.getVolumes();
+ if (!volumes.contains(volId)) {
+ flag = true;
+ } else {
+ flag = false;
}
+ logger.info("validateDetach flag-->" + flag);
return flag;
}
}
diff --git a/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_AttachVolumeVM.json b/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_AttachVolumeVM.json
index 8684afa..2b33c7e 100644
--- a/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_AttachVolumeVM.json
+++ b/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_AttachVolumeVM.json
@@ -1,20 +1,20 @@
[
{
- "id": "8c8d638b.d864e8",
+ "id": "5007ce02.07f1d",
"type": "dgstart",
"name": "DGSTART",
"outputs": 1,
- "x": 84,
- "y": 84,
- "z": "1eca43d0.41972c",
+ "x": 87,
+ "y": 73.11666870117188,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "67bc77ec.cfab9"
+ "7d845d7f.b28f8c"
]
]
},
{
- "id": "67bc77ec.cfab9",
+ "id": "7d845d7f.b28f8c",
"type": "service-logic",
"name": "APPC 4.0.0",
"module": "APPC",
@@ -22,240 +22,240 @@
"comments": "",
"xml": "<service-logic xmlns='http://www.onap.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='APPC' version='4.0.0'>",
"outputs": 1,
- "x": 241,
- "y": 84,
- "z": "1eca43d0.41972c",
+ "x": 220,
+ "y": 38.116668701171875,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "9ab2a765.c334e"
+ "2bf8e045.73a448"
]
]
},
{
- "id": "9ab2a765.c334e",
+ "id": "2bf8e045.73a448",
"type": "method",
"name": "AttachVolume",
"xml": "<method rpc='AttachVolumeVM' mode='sync'>\n",
"comments": "",
"outputs": 1,
- "x": 439,
- "y": 86,
- "z": "1eca43d0.41972c",
+ "x": 418,
+ "y": 40.116668701171875,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "af60ef65.5a714"
+ "468a32bf.35f284"
]
]
},
{
- "id": "9d95111e.b625",
+ "id": "6d9a583d.567f7",
"type": "success",
"name": "success",
"xml": "<outcome value='success'>\n",
"comments": "",
"outputs": 1,
- "x": 806.9999694824219,
- "y": 295.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 785.9999694824219,
+ "y": 250.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "3f10a3d4.fa8644"
+ "9b1062e9.283098"
]
]
},
{
- "id": "98f61d5c.9857e8",
+ "id": "ddd78a95.68e358",
"type": "other",
"name": "other",
"xml": "<outcome value='Other'>\n",
"comments": "",
"outputs": 1,
- "x": 815.9999694824219,
- "y": 174.99996948242188,
- "z": "1eca43d0.41972c",
+ "x": 794.9999694824219,
+ "y": 129.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "b2efb443.b631a"
+ "f06647ab.96aca"
]
]
},
{
- "id": "6be48d2c.b63d8c",
+ "id": "10c52db4.a51652",
"type": "returnSuccess",
"name": "return success",
"xml": "<return status='success'>",
"comments": "",
- "x": 1362.9999694824219,
- "y": 267.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 1341.9999694824219,
+ "y": 222.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": []
},
{
- "id": "3ebaa10e.c55e6e",
+ "id": "84c0dae5.04bb7",
"type": "returnFailure",
"name": "return failure",
"xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='RPC attachVolume not found' />",
"comments": "",
- "x": 1123.9999694824219,
- "y": 174.99996948242188,
- "z": "1eca43d0.41972c",
+ "x": 1102.9999694824219,
+ "y": 129.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": []
},
{
- "id": "3f10a3d4.fa8644",
+ "id": "9b1062e9.283098",
"type": "switchNode",
- "name": "switch error-code",
- "xml": "<switch test='`$error_code`'>\n",
+ "name": "switch status",
+ "xml": "<switch test='`$VOLUME_STATUS`'>\n",
"comments": "",
"outputs": 1,
- "x": 999.9999694824219,
- "y": 296.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 978.9999694824219,
+ "y": 251.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "78e00fc2.178ca8",
- "5cb2873d.ba509"
+ "69b4b801.d2dd58",
+ "4a833666.1d3a3"
]
]
},
{
- "id": "78e00fc2.178ca8",
+ "id": "69b4b801.d2dd58",
"type": "success",
- "name": "SUCCESS 200",
- "xml": "<outcome value='200'>\n",
+ "name": "success",
+ "xml": "<outcome value='SUCCESS'>\n",
"comments": "",
"outputs": 1,
- "x": 1181.9999694824219,
- "y": 266.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 1160.9999694824219,
+ "y": 221.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "6be48d2c.b63d8c"
+ "10c52db4.a51652"
]
]
},
{
- "id": "5cb2873d.ba509",
+ "id": "4a833666.1d3a3",
"type": "outcome",
"name": "ERROR",
"xml": "<outcome value='Other'>\n",
"comments": "",
"outputs": 1,
- "x": 1173.9999694824219,
- "y": 425.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 1152.9999694824219,
+ "y": 380.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "c45d6cad.1266a8"
+ "df65c991.2b7fa8"
]
]
},
{
- "id": "c45d6cad.1266a8",
+ "id": "df65c991.2b7fa8",
"type": "block",
"name": "block",
"xml": "<block>\n",
"atomic": "false",
"comments": "",
"outputs": 1,
- "x": 1306.9999694824219,
- "y": 426.9999694824219,
- "z": "1eca43d0.41972c",
+ "x": 1285.9999694824219,
+ "y": 381.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "4593642b.a03a34",
- "7bdd8ae4.5a04e4"
+ "21987bda.eebd5c",
+ "3d82b93b.845e96"
]
]
},
{
- "id": "4593642b.a03a34",
+ "id": "21987bda.eebd5c",
"type": "returnFailure",
"name": "return failure",
"xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='`$error-message`' />\n",
"comments": "",
- "x": 1441.9999694824219,
- "y": 468,
- "z": "1eca43d0.41972c",
+ "x": 1420.9999694824219,
+ "y": 422.1166687011719,
+ "z": "bb7eafb1.d37d2",
"wires": []
},
{
- "id": "b2efb443.b631a",
+ "id": "f06647ab.96aca",
"type": "block",
"name": "block",
"xml": "<block>\n",
"atomic": "false",
"comments": "",
"outputs": 1,
- "x": 971.9999694824219,
- "y": 174.99996948242188,
- "z": "1eca43d0.41972c",
+ "x": 950.9999694824219,
+ "y": 129.11663818359375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "3ebaa10e.c55e6e"
+ "84c0dae5.04bb7"
]
]
},
{
- "id": "80ee82a0.8401c8",
+ "id": "ff624428.83add8",
"type": "record",
"name": "record",
- "xml": "<record plugin=\"onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field2\" value=\"`'input.payload = ' + $input.payload`\" />\n<parameter name=\"field3\" value=\"`'vm-id in context=' + $vm-id`\" />\n<parameter name=\"field4\" value=\"`'volumeId in context=' + $volumeId`\" />\n",
+ "xml": "<record plugin=\"org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field2\" value=\"`'input.payload = ' + $input.payload`\" />\n<parameter name=\"field3\" value=\"`'vm-id in context=' + $vm-id`\" />\n<parameter name=\"field4\" value=\"`'volumeId in context=' + $volumeId`\" />\n",
"comments": "",
"outputs": 1,
- "x": 806.11669921875,
- "y": 116,
- "z": "1eca43d0.41972c",
+ "x": 785.11669921875,
+ "y": 70.11666870117188,
+ "z": "bb7eafb1.d37d2",
"wires": [
[]
]
},
{
- "id": "af60ef65.5a714",
+ "id": "468a32bf.35f284",
"type": "block",
"name": "block",
"xml": "<block>\n",
"atomic": "false",
"comments": "",
"outputs": 1,
- "x": 627.8666687011719,
- "y": 144.86666870117188,
- "z": "1eca43d0.41972c",
+ "x": 606.8666687011719,
+ "y": 98.98333740234375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "80ee82a0.8401c8",
- "1ecc7492.a889b3"
+ "ff624428.83add8",
+ "18c8070a.4a19b1"
]
]
},
{
- "id": "7bdd8ae4.5a04e4",
+ "id": "3d82b93b.845e96",
"type": "record",
"name": "record",
- "xml": "<record plugin=\"onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field3\" value=\"`'error-message = ' + $error-message`\" />\n<parameter name=\"field4\" value=\"`'error-code = ' + $error_code`\" />",
+ "xml": "<record plugin=\"org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field3\" value=\"`'error-message = ' + $error-message`\" />\n<parameter name=\"field4\" value=\"`'error-code = ' + $error_code`\" />",
"comments": "",
"outputs": 1,
- "x": 1431.8666687011719,
- "y": 398.8666687011719,
- "z": "1eca43d0.41972c",
+ "x": 1410.8666687011719,
+ "y": 352.98333740234375,
+ "z": "bb7eafb1.d37d2",
"wires": [
[]
]
},
{
- "id": "1ecc7492.a889b3",
+ "id": "18c8070a.4a19b1",
"type": "execute",
"name": "attachVolume",
"xml": "<execute plugin='org.onap.appc.adapter.iaas.ProviderAdapter' method='attachVolume'>\n<parameter name=\"org.onap.appc.provider.name\" value=\"OpenStack\" />\n<parameter name=\"org.onap.appc.instance.url\" value=\"`$vm-id`\" />\n<parameter name=\"org.onap.appc.identity.url\" value=\"`$identity-url`\" />\n<parameter name=\"org.onap.appc.volumeid\" value=\"`$volumeAttachment.volumeId`\" />\n<parameter name=\"org.onap.appc.device\" value=\"`$volumeAttachment.device`\" />\n<parameter name=\"org.onap.appc.tag\" value=\"`$volumeAttachment.tag`\" />",
"comments": "",
"outputs": 1,
- "x": 643.9999694824219,
- "y": 230,
- "z": "1eca43d0.41972c",
+ "x": 622.9999694824219,
+ "y": 184.11666870117188,
+ "z": "bb7eafb1.d37d2",
"wires": [
[
- "98f61d5c.9857e8",
- "9d95111e.b625"
+ "ddd78a95.68e358",
+ "6d9a583d.567f7"
]
]
}
diff --git a/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_DetachVolumeVM.json b/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_DetachVolumeVM.json
index 32fe9c2..2fbca8f 100644
--- a/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_DetachVolumeVM.json
+++ b/appc-directed-graph/appc-dgraph/provider/src/main/resources/json/APPC/APPC_DetachVolumeVM.json
@@ -1,262 +1,262 @@
-[
- {
- "id": "eeae9def.4d566",
- "type": "dgstart",
- "name": "DGSTART",
- "outputs": 1,
- "x": 93,
- "y": 92,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "f51d1b93.7d168"
- ]
- ]
- },
- {
- "id": "f51d1b93.7d168",
- "type": "service-logic",
- "name": "APPC 4.0.0",
- "module": "APPC",
- "version": "4.0.0",
- "comments": "",
- "xml": "<service-logic xmlns='http://www.onap.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='APPC' version='4.0.0'>",
- "outputs": 1,
- "x": 250,
- "y": 92,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "10439b1c.b0fbc5"
- ]
- ]
- },
- {
- "id": "10439b1c.b0fbc5",
- "type": "method",
- "name": "DetachVolume",
- "xml": "<method rpc='DetachVolumeVM' mode='sync'>\n",
- "comments": "",
- "outputs": 1,
- "x": 448,
- "y": 94,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "cf4fac38.3b932"
- ]
- ]
- },
- {
- "id": "6f1b4f51.cab76",
- "type": "success",
- "name": "success",
- "xml": "<outcome value='success'>\n",
- "comments": "",
- "outputs": 1,
- "x": 815.9999694824219,
- "y": 303.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "f6364905.533518"
- ]
- ]
- },
- {
- "id": "eda3e619.a190e",
- "type": "other",
- "name": "other",
- "xml": "<outcome value='Other'>\n",
- "comments": "",
- "outputs": 1,
- "x": 824.9999694824219,
- "y": 182.99996948242188,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "b81aef23.ced6e8"
- ]
- ]
- },
- {
- "id": "361abfaa.ca34b8",
- "type": "returnSuccess",
- "name": "return success",
- "xml": "<return status='success'>",
- "comments": "",
- "x": 1371.9999694824219,
- "y": 275.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": []
- },
- {
- "id": "5b028b69.7d6af4",
- "type": "returnFailure",
- "name": "return failure",
- "xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='RPC dettachVolume not found' />",
- "comments": "",
- "x": 1132.9999694824219,
- "y": 182.99996948242188,
- "z": "65f0ae97.bfd7e8",
- "wires": []
- },
- {
- "id": "f6364905.533518",
- "type": "switchNode",
- "name": "switch error-code",
- "xml": "<switch test='`$error_code`'>\n",
- "comments": "",
- "outputs": 1,
- "x": 1008.9999694824219,
- "y": 304.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "567026e7.afed6",
- "ee60ee08.fb232"
- ]
- ]
- },
- {
- "id": "567026e7.afed6",
- "type": "success",
- "name": "SUCCESS 200",
- "xml": "<outcome value='200'>\n",
- "comments": "",
- "outputs": 1,
- "x": 1190.9999694824219,
- "y": 274.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "361abfaa.ca34b8"
- ]
- ]
- },
- {
- "id": "ee60ee08.fb232",
- "type": "outcome",
- "name": "ERROR",
- "xml": "<outcome value='Other'>\n",
- "comments": "",
- "outputs": 1,
- "x": 1182.9999694824219,
- "y": 433.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "285baaf0.7d06de"
- ]
- ]
- },
- {
- "id": "285baaf0.7d06de",
- "type": "block",
- "name": "block",
- "xml": "<block>\n",
- "atomic": "false",
- "comments": "",
- "outputs": 1,
- "x": 1315.9999694824219,
- "y": 434.9999694824219,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "44fe2b94.9c5d94",
- "961f42bf.beb62"
- ]
- ]
- },
- {
- "id": "44fe2b94.9c5d94",
- "type": "returnFailure",
- "name": "return failure",
- "xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='`$error-message`' />\n",
- "comments": "",
- "x": 1450.9999694824219,
- "y": 476,
- "z": "65f0ae97.bfd7e8",
- "wires": []
- },
- {
- "id": "b81aef23.ced6e8",
- "type": "block",
- "name": "block",
- "xml": "<block>\n",
- "atomic": "false",
- "comments": "",
- "outputs": 1,
- "x": 980.9999694824219,
- "y": 182.99996948242188,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "5b028b69.7d6af4"
- ]
- ]
- },
- {
- "id": "34472fd1.b14ab",
- "type": "record",
- "name": "record",
- "xml": "<record plugin=\"onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field2\" value=\"`'input.payload = ' + $input.payload`\" />\n<parameter name=\"field3\" value=\"`'vm-id in context=' + $vm-id`\" />\n<parameter name=\"field4\" value=\"`'volumeId in context=' + $volumeId`\" />\n",
- "comments": "",
- "outputs": 1,
- "x": 815.11669921875,
- "y": 124,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- []
- ]
- },
- {
- "id": "cf4fac38.3b932",
- "type": "block",
- "name": "block",
- "xml": "<block>\n",
- "atomic": "false",
- "comments": "",
- "outputs": 1,
- "x": 636.8666687011719,
- "y": 152.86666870117188,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "34472fd1.b14ab",
- "e021eba0.2f5b7"
- ]
- ]
- },
- {
- "id": "961f42bf.beb62",
- "type": "record",
- "name": "record",
- "xml": "<record plugin=\"onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field3\" value=\"`'error-message = ' + $error-message`\" />\n<parameter name=\"field4\" value=\"`'error-code = ' + $error_code`\" />",
- "comments": "",
- "outputs": 1,
- "x": 1440.8666687011719,
- "y": 406.8666687011719,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- []
- ]
- },
- {
- "id": "e021eba0.2f5b7",
- "type": "execute",
- "name": "DetachVolume",
- "xml": "<execute plugin='org.onap.appc.adapter.iaas.ProviderAdapter' method='dettachVolume'>\n<parameter name=\"org.onap.appc.provider.name\" value=\"OpenStack\" />\n<parameter name=\"org.onap.appc.instance.url\" value=\"`$vm-id`\" />\n<parameter name=\"org.onap.appc.identity.url\" value=\"`$identity-url`\" />\n<parameter name=\"org.onap.appc.volumeid\" value=\"`$volumeAttachment.volumeId`\" />\n<parameter name=\"org.onap.appc.device\" value=\"`$volumeAttachment.device`\" />\n<parameter name=\"org.onap.appc.tag\" value=\"`$volumeAttachment.tag`\"/>",
- "comments": "",
- "outputs": 1,
- "x": 652.9999694824219,
- "y": 238,
- "z": "65f0ae97.bfd7e8",
- "wires": [
- [
- "eda3e619.a190e",
- "6f1b4f51.cab76"
- ]
- ]
- }
-]
+[
+ {
+ "id": "d54b463c.a823b8",
+ "type": "dgstart",
+ "name": "DGSTART",
+ "outputs": 1,
+ "x": 93.11666870117188,
+ "y": 41,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "a2bb678c.5e00c"
+ ]
+ ]
+ },
+ {
+ "id": "a2bb678c.5e00c",
+ "type": "service-logic",
+ "name": "APPC 4.0.0",
+ "module": "APPC",
+ "version": "4.0.0",
+ "comments": "",
+ "xml": "<service-logic xmlns='http://www.onap.org/sdnc/svclogic' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='APPC' version='4.0.0'>",
+ "outputs": 1,
+ "x": 250.11666870117188,
+ "y": 41,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "e60f98b3.977f1"
+ ]
+ ]
+ },
+ {
+ "id": "e60f98b3.977f1",
+ "type": "method",
+ "name": "DetachVolume",
+ "xml": "<method rpc='DetachVolumeVM' mode='sync'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 448.1166687011719,
+ "y": 43,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "e8d72dbd.c9baa"
+ ]
+ ]
+ },
+ {
+ "id": "f548774.5415008",
+ "type": "success",
+ "name": "success",
+ "xml": "<outcome value='success'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 816.1166381835938,
+ "y": 252.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "329389c7.ceb186"
+ ]
+ ]
+ },
+ {
+ "id": "efa29456.b2b9e",
+ "type": "other",
+ "name": "other",
+ "xml": "<outcome value='Other'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 825.1166381835938,
+ "y": 131.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "26584913.762376"
+ ]
+ ]
+ },
+ {
+ "id": "85b565d0.ef33d8",
+ "type": "returnSuccess",
+ "name": "return success",
+ "xml": "<return status='success'>",
+ "comments": "",
+ "x": 1372.1166381835938,
+ "y": 224.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": []
+ },
+ {
+ "id": "8cb513a7.354458",
+ "type": "returnFailure",
+ "name": "return failure",
+ "xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='RPC dettachVolume not found' />",
+ "comments": "",
+ "x": 1133.1166381835938,
+ "y": 131.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": []
+ },
+ {
+ "id": "329389c7.ceb186",
+ "type": "switchNode",
+ "name": "switch status",
+ "xml": "<switch test='`$VOLUME_STATUS`'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 1009.1166381835938,
+ "y": 253.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "720cbf6d.f49518",
+ "1de7a2bc.3c680d"
+ ]
+ ]
+ },
+ {
+ "id": "720cbf6d.f49518",
+ "type": "success",
+ "name": "success",
+ "xml": "<outcome value='SUCCESS'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 1191.1166381835938,
+ "y": 223.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "85b565d0.ef33d8"
+ ]
+ ]
+ },
+ {
+ "id": "1de7a2bc.3c680d",
+ "type": "outcome",
+ "name": "ERROR",
+ "xml": "<outcome value='Other'>\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 1183.1166381835938,
+ "y": 382.9999694824219,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "83ea6cce.ef1b58"
+ ]
+ ]
+ },
+ {
+ "id": "83ea6cce.ef1b58",
+ "type": "block",
+ "name": "block",
+ "xml": "<block>\n",
+ "atomic": "false",
+ "comments": "",
+ "outputs": 1,
+ "x": 1316.1166381835938,
+ "y": 383.9999694824219,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "115510d5.27d387",
+ "6be0b92f.7a4028"
+ ]
+ ]
+ },
+ {
+ "id": "115510d5.27d387",
+ "type": "returnFailure",
+ "name": "return failure",
+ "xml": "<return status='failure'>\n<parameter name='error-code' value='401' />\n<parameter name='error-message' value='`$error-message`' />\n",
+ "comments": "",
+ "x": 1451.1166381835938,
+ "y": 425,
+ "z": "9904acd2.cfae1",
+ "wires": []
+ },
+ {
+ "id": "26584913.762376",
+ "type": "block",
+ "name": "block",
+ "xml": "<block>\n",
+ "atomic": "false",
+ "comments": "",
+ "outputs": 1,
+ "x": 981.1166381835938,
+ "y": 131.99996948242188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "8cb513a7.354458"
+ ]
+ ]
+ },
+ {
+ "id": "88de342c.a6a72",
+ "type": "record",
+ "name": "record",
+ "xml": "<record plugin=\"org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field2\" value=\"`'input.payload = ' + $input.payload`\" />\n<parameter name=\"field3\" value=\"`'vm-id in context=' + $vm-id`\" />\n<parameter name=\"field4\" value=\"`'volumeId in context=' + $volumeId`\" />\n",
+ "comments": "",
+ "outputs": 1,
+ "x": 815.2333679199219,
+ "y": 73,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ []
+ ]
+ },
+ {
+ "id": "e8d72dbd.c9baa",
+ "type": "block",
+ "name": "block",
+ "xml": "<block>\n",
+ "atomic": "false",
+ "comments": "",
+ "outputs": 1,
+ "x": 636.9833374023438,
+ "y": 101.86666870117188,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "88de342c.a6a72",
+ "62735c5f.2a9b9c"
+ ]
+ ]
+ },
+ {
+ "id": "6be0b92f.7a4028",
+ "type": "record",
+ "name": "record",
+ "xml": "<record plugin=\"org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder\">\n<parameter name=\"level\" value=\"info\"/>\n<parameter name=\"logger\" value=\"message-log\"/>\n<parameter name=\"field1\" value=\"__TIMESTAMP__\"/>\n<parameter name=\"field3\" value=\"`'error-message = ' + $error-message`\" />\n<parameter name=\"field4\" value=\"`'error-code = ' + $error_code`\" />",
+ "comments": "",
+ "outputs": 1,
+ "x": 1440.9833374023438,
+ "y": 355.8666687011719,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ []
+ ]
+ },
+ {
+ "id": "62735c5f.2a9b9c",
+ "type": "execute",
+ "name": "DetachVolume",
+ "xml": "<execute plugin='org.onap.appc.adapter.iaas.ProviderAdapter' method='dettachVolume'>\n<parameter name=\"org.onap.appc.provider.name\" value=\"OpenStack\" />\n<parameter name=\"org.onap.appc.instance.url\" value=\"`$vm-id`\" />\n<parameter name=\"org.onap.appc.identity.url\" value=\"`$identity-url`\" />\n<parameter name=\"org.onap.appc.volumeid\" value=\"`$volumeAttachment.volumeId`\" />\n<parameter name=\"org.onap.appc.device\" value=\"`$volumeAttachment.device`\" />\n<parameter name=\"org.onap.appc.tag\" value=\"`$volumeAttachment.tag`\"/>",
+ "comments": "",
+ "outputs": 1,
+ "x": 653.1166381835938,
+ "y": 187,
+ "z": "9904acd2.cfae1",
+ "wires": [
+ [
+ "efa29456.b2b9e",
+ "f548774.5415008"
+ ]
+ ]
+ }
+]