aboutsummaryrefslogtreecommitdiffstats
path: root/openo-portal/portal-lifecyclemgr/src/main/webapp
diff options
context:
space:
mode:
authorLuji7 <lu.ji3@zte.com.cn>2016-09-29 01:38:05 +0800
committerLuji7 <lu.ji3@zte.com.cn>2016-09-29 01:38:05 +0800
commitf58cce8d5398868d4d7735f33774b86ffa258d69 (patch)
tree953e9fb5bc1b97ff596c7a88d2463544f1915be1 /openo-portal/portal-lifecyclemgr/src/main/webapp
parent7246f3b9758d903dc0420e9704f6de30f4a82e40 (diff)
refactor to use jquery promise api instead of synchroize ajax invocation for creating service instance
Change-Id: Ic2c247fc59c86ced56822dcdf60815476e9adbcc Signed-off-by: Luji7 <lu.ji3@zte.com.cn>
Diffstat (limited to 'openo-portal/portal-lifecyclemgr/src/main/webapp')
-rw-r--r--openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/gsolcm.js177
1 files changed, 66 insertions, 111 deletions
diff --git a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/gsolcm.js b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/gsolcm.js
index 8ef9ee6d..42a5aa7f 100644
--- a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/gsolcm.js
+++ b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/gsolcm.js
@@ -42,7 +42,7 @@ lcmHandler.prototype = {
};
var gatewayService = 'http://localhost:8080/openoapi/servicegateway/v1/services';
$.when(
- fetchServiceTemplateBy2(serviceInstance.serviceTemplateId)
+ fetchServiceTemplateBy(serviceInstance.serviceTemplateId)
).then(
function(template) {
serviceInstance.templateName = template.name;
@@ -65,7 +65,7 @@ function renderTemplateParametersTab() {
templateParameters = translateToTemplateParameters(templateParameterResponse[0].inputs);
var vims = translateToVimInfo(vimsInfoResponse[0]);
var components = transfromToComponents(templateParameters.parameters, vims);
-
+
//TODO need to address the issue of the dynamic loading of parameter tab,,,
// document.getElementById("parameterTab").innerHTML = components;
});
@@ -168,7 +168,7 @@ function transformToOptions(vims) {
return options;
}
-function fetchServiceTemplateBy2(templateId) {
+function fetchServiceTemplateBy(templateId) {
var defer = $.Deferred();
var serviceTemplateUri = 'http://localhost:8080/openoapi/catalog/v1/servicetemplates/' + templateId;
var template = {};
@@ -290,45 +290,6 @@ function collectServiceParameters(parameters) {
return serviceParameters;
}
-function fetchServiceTemplateBy(templateId) {
- var serviceTemplateUri = 'http://localhost:8080/openoapi/catalog/v1/servicetemplates/' + templateId;
- var template;
- $.ajax({
- type: "GET",
- async: false,
- url: serviceTemplateUri,
- contentType: "application/json",
- dataType: "json",
- success: function (jsonResp) {
- template = {
- name: jsonResp.templateName,
- gsarId: jsonResp.csarId
- }
- },
- error: function (xhr, ajaxOptions, thrownError) {
- alert("Error on page : " + xhr.responseText);
- }
- });
- if (template === undefined) {
- return template;
- }
- var queryCsarUri = 'http://localhost:8080/openoapi/catalog/v1/csars/' + template.gsarId;
- $.ajax({
- type: "GET",
- async: false,
- url: queryCsarUri,
- contentType: "application/json",
- dataType: "json",
- success: function (jsonResp) {
- template.csarType = jsonResp.type
- },
- error: function (xhr, ajaxOptions, thrownError) {
- alert("Error on page : " + xhr.responseText);
- }
- });
- return template;
-}
-
function updateTable(serviceInstance) {
appendOenRow(serviceInstance);
addDeleteEventRegistration();
@@ -365,94 +326,88 @@ function addDeleteEventRegistration() {
var templateId = $(spanElement).text();
var inputElement = $(tdElement).children("input")[0];
var instanceId = $(inputElement).val();
- var result = deleteServiceInstance(templateId, instanceId);
- if (result) {
- trElement.remove();
- alert("Service instance deleted successfully!");
- }
+
+ var gatewayService = 'http://localhost:8080/openoapi/servicegateway/v1/services';
+ $.when(
+ fetchServiceTemplateBy(templateId)
+ ).then(
+ function(template) {
+ if (template.csarType === 'GSAR') {
+ return deleteGsoServiceInstance(gatewayService, instanceId);
+ } else if (template.csarType === 'NSAR' || serviceTemplate.csarType === 'NFAR') {
+ var nfvoNsUri = '/openoapi/nslcm/v1.0/ns';
+ return deleteServiceInstance(gatewayService, nfvoNsUri, instanceId);
+ } else if (template.csarType === 'SSAR') {
+ var sdnoNsUri = '/openoapi/sdnonslcm/v1.0/ns';
+ return deleteServiceInstance(gatewayService, sdnoNsUri, instanceId);
+ }
+ }
+ ).then(
+ function() {
+ trElement.remove();
+ }
+ );
});
}
-function deleteServiceInstance(templateId, instanceId) {
- var serviceTemplate = fetchServiceTemplateBy(templateId);
- if (serviceTemplate === undefined) {
- return;
- }
- var gatewayService = '/openoapi/servicegateway/v1/services';
- var result = false;
- if (serviceTemplate.csarType === 'GSAR') {
- result = deleteGsoServiceInstance(gatewayService, instanceId);
- } else if (serviceTemplate.csarType === 'NSAR' || serviceTemplate.csarType === 'NFAR') {
- result = deleteNfvoServiceInstance(gatewayService, instanceId);
- } else if (serviceTemplate.csarType === 'SSAR') {
- result = deleteSdnoServiceInstance(gatewayService, instanceId);
- }
- return result;
+function deleteGsoServiceInstance(gatewayService, instanceId) {
+ var defer = $.Deferred();
+ var gsoLcmUri = '/openoapi/lifecyclemgr/v1/services';
+ $.when(
+ deleteNetworkServiceInstance(gatewayService, gsoLcmUri, instanceId);
+ ).then(
+ function(response) {
+ defer.resolve();
+ });
+ return defer;
}
-function deleteGsoServiceInstance(gatewayService, instanceId) {
- var gsoLcmUrl = '/openoapi/lifecyclemgr/v1/services/' + instanceId;
- var operation = 'DELETE';
- return sendDeleteRequest(operation, gatewayService, gsoLcmUrl);
+function deleteServiceInstance(gatewayService, nsUri, instanceId) {
+ var defer = $.Deferred();
+ $.when(
+ terminateNetworkServiceInstance(gatewayService, nsUri, instanceId)
+ ).then(
+ function(response) {
+ return deleteNetworkServiceInstance(gatewayService, nsUri, instanceId);
+ }
+ ).then(
+ function(response) {
+ defer.resolve();
+ }
+ )
+ return defer;
}
-function deleteNfvoServiceInstance(gatewayService, instanceId) {
- var nfvoNsUrl = '/openoapi/nslcm/v1.0/ns/' + instanceId;
- var nfvoNsTerminateUrl = nfvoNsUrl + '/terminate';
- var terminateParameter = {
- 'nsInstanceId': instanceId,
- 'terminationType': "graceful",
- 'gracefulTerminationTimeout': "60",
- 'operation': "POST",
- 'gatewayUri': nfvoNsTerminateUrl
+function deleteNetworkServiceInstance(gatewayService, nsUri, instanceId) {
+ var instanceUri = nsUri + '/' + instanceId;
+ var parameter = {
+ 'operation': "DELETE",
+ 'gatewayUri': instanceUri
};
- var result = sendRequest(gatewayService, terminateParameter);
- if (result) {
- var serviceParameter = {
- 'operation': "DELETE",
- 'gatewayUri': nfvoNsUrl
- };
- result = sendRequest(gatewayService, serviceParameter);
- }
- return result;
+ return $.ajax({
+ type: "DELETE",
+ url: gatewayService,
+ contentType: "application/json",
+ dataType: "json",
+ data: JSON.stringify(parameter)
+ });
}
-function deleteSdnoServiceInstance(gatewayService, instanceId) {
- var sdnoNsUrl = '/openoapi/sdnonslcm/v1.0/ns/' + instanceId;
- var sdnoNsTerminateUrl = sdnoNsUrl + '/terminate';
+function terminateNetworkServiceInstance(gatewayService, nsUri, instanceId) {
+ var instanceUri = nsUri + '/' + instanceId;
+ var nsTerminateUri = instanceUri + '/terminate';
var terminateParameter = {
'nsInstanceId': instanceId,
'terminationType': "graceful",
'gracefulTerminationTimeout': "60",
'operation': "POST",
- 'gatewayUri': sdnoNsTerminateUrl
+ 'gatewayUri': nsTerminateUri
};
- var result = sendDeleteRequest(gatewayService, terminateParameter);
- if (result) {
- var serviceParameter = {
- 'operation': "DELETE",
- 'gatewayUri': sdnoNsUrl
- };
- result = sendDeleteRequest(gatewayService, serviceParameter);
- }
- return result;
-}
-
-function sendDeleteRequest(gatewayService, parameter) {
- var result = false;
- $.ajax({
+ return $.ajax({
type: "DELETE",
- async: false,
url: gatewayService,
contentType: "application/json",
dataType: "json",
- data: JSON.stringify(parameter),
- success: function (jsonResp) {
- result = true;
- },
- error: function (xhr, ajaxOptions, thrownError) {
- alert("Error on page : " + xhr.responseText);
- }
+ data: JSON.stringify(terminateParameter)
});
- return result;
}