mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
CLOUDSTACK-2569: UI > Infrastructure menu > zone > physical network > network service providers > Cisco VNMC > If Cisco VNMC provider doesn't exist, show Add action and hide enable, disable action.
This commit is contained in:
parent
57623832b0
commit
9fb71c30a8
@ -16,18 +16,20 @@
|
|||||||
// under the License.
|
// under the License.
|
||||||
(function ($, cloudStack) {
|
(function ($, cloudStack) {
|
||||||
cloudStack.modules.vnmcNetworkProvider = function (module) {
|
cloudStack.modules.vnmcNetworkProvider = function (module) {
|
||||||
var vnmcDeviceViewAll = window._m = [
|
var vnmcDeviceViewAll = window._m = [{
|
||||||
{
|
|
||||||
label: 'VNMC Devices',
|
label: 'VNMC Devices',
|
||||||
path: '_zone.vnmcDevices'
|
path: '_zone.vnmcDevices'
|
||||||
}
|
}];
|
||||||
];
|
|
||||||
|
|
||||||
var vnmcListView = {
|
var vnmcListView = {
|
||||||
id: 'vnmcDevices',
|
id: 'vnmcDevices',
|
||||||
fields: {
|
fields: {
|
||||||
resourcename: { label: 'Resource Name' },
|
resourcename: {
|
||||||
provider: { label: 'Provider' }
|
label: 'Resource Name'
|
||||||
|
},
|
||||||
|
provider: {
|
||||||
|
label: 'Provider'
|
||||||
|
}
|
||||||
},
|
},
|
||||||
dataProvider: function (args) {
|
dataProvider: function (args) {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
@ -58,16 +60,22 @@
|
|||||||
fields: {
|
fields: {
|
||||||
hostname: {
|
hostname: {
|
||||||
label: 'label.host',
|
label: 'label.host',
|
||||||
validation: { required: true }
|
validation: {
|
||||||
|
required: true
|
||||||
|
}
|
||||||
},
|
},
|
||||||
username: {
|
username: {
|
||||||
label: 'label.username',
|
label: 'label.username',
|
||||||
validation: { required: true }
|
validation: {
|
||||||
|
required: true
|
||||||
|
}
|
||||||
},
|
},
|
||||||
password: {
|
password: {
|
||||||
label: 'label.password',
|
label: 'label.password',
|
||||||
isPassword: true,
|
isPassword: true,
|
||||||
validation: { required: true }
|
validation: {
|
||||||
|
required: true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -85,12 +93,10 @@
|
|||||||
var ciscoVnmcProvider = items[0];
|
var ciscoVnmcProvider = items[0];
|
||||||
if (ciscoVnmcProvider.state == 'Enabled') {
|
if (ciscoVnmcProvider.state == 'Enabled') {
|
||||||
addCiscoVnmcResourceFn();
|
addCiscoVnmcResourceFn();
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
enableCiscoVnmcProviderFn(ciscoVnmcProvider);
|
enableCiscoVnmcProviderFn(ciscoVnmcProvider);
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: createURL("addNetworkServiceProvider"),
|
url: createURL("addNetworkServiceProvider"),
|
||||||
data: {
|
data: {
|
||||||
@ -107,15 +113,13 @@
|
|||||||
var result = json.queryasyncjobresultresponse;
|
var result = json.queryasyncjobresultresponse;
|
||||||
if (result.jobstatus == 0) {
|
if (result.jobstatus == 0) {
|
||||||
return; //Job has not completed
|
return; //Job has not completed
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
clearInterval(addVnmcProviderIntervalID);
|
clearInterval(addVnmcProviderIntervalID);
|
||||||
if (result.jobstatus == 1) {
|
if (result.jobstatus == 1) {
|
||||||
//nspMap["CiscoVnmc"] = json.queryasyncjobresultresponse.jobresult.networkserviceprovider;
|
//nspMap["CiscoVnmc"] = json.queryasyncjobresultresponse.jobresult.networkserviceprovider;
|
||||||
var ciscoVnmcProvider = json.queryasyncjobresultresponse.jobresult.networkserviceprovider;
|
var ciscoVnmcProvider = json.queryasyncjobresultresponse.jobresult.networkserviceprovider;
|
||||||
enableCiscoVnmcProviderFn(ciscoVnmcProvider);
|
enableCiscoVnmcProviderFn(ciscoVnmcProvider);
|
||||||
}
|
} else if (result.jobstatus == 2) {
|
||||||
else if (result.jobstatus == 2) {
|
|
||||||
args.response.error(_s(result.jobresult.errortext));
|
args.response.error(_s(result.jobresult.errortext));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -150,13 +154,11 @@
|
|||||||
var result = json.queryasyncjobresultresponse;
|
var result = json.queryasyncjobresultresponse;
|
||||||
if (result.jobstatus == 0) {
|
if (result.jobstatus == 0) {
|
||||||
return; //Job has not completed
|
return; //Job has not completed
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
clearInterval(enableVnmcProviderIntervalID);
|
clearInterval(enableVnmcProviderIntervalID);
|
||||||
if (result.jobstatus == 1) {
|
if (result.jobstatus == 1) {
|
||||||
addCiscoVnmcResourceFn();
|
addCiscoVnmcResourceFn();
|
||||||
}
|
} else if (result.jobstatus == 2) {
|
||||||
else if (result.jobstatus == 2) {
|
|
||||||
args.response.error(_s(result.jobresult.errortext));
|
args.response.error(_s(result.jobresult.errortext));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -180,7 +182,9 @@
|
|||||||
data: data,
|
data: data,
|
||||||
success: function (json) {
|
success: function (json) {
|
||||||
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
||||||
args.response.success({data: item});
|
args.response.success({
|
||||||
|
data: item
|
||||||
|
});
|
||||||
},
|
},
|
||||||
error: function (data) {
|
error: function (data) {
|
||||||
args.response.error(parseXMLHttpResponse(data));
|
args.response.error(parseXMLHttpResponse(data));
|
||||||
@ -235,16 +239,21 @@
|
|||||||
tabs: {
|
tabs: {
|
||||||
details: {
|
details: {
|
||||||
title: 'label.details',
|
title: 'label.details',
|
||||||
fields: [
|
fields: [{
|
||||||
{
|
resourcename: {
|
||||||
resourcename: { label: 'Resource Name' }
|
label: 'Resource Name'
|
||||||
},
|
|
||||||
{
|
|
||||||
resourceid: { label: 'Resource ID'},
|
|
||||||
provider: { label: 'Provider' },
|
|
||||||
RESOURCE_NAME: { label: 'Resource Name'}
|
|
||||||
}
|
}
|
||||||
],
|
}, {
|
||||||
|
resourceid: {
|
||||||
|
label: 'Resource ID'
|
||||||
|
},
|
||||||
|
provider: {
|
||||||
|
label: 'Provider'
|
||||||
|
},
|
||||||
|
RESOURCE_NAME: {
|
||||||
|
label: 'Resource Name'
|
||||||
|
}
|
||||||
|
}],
|
||||||
dataProvider: function (args) {
|
dataProvider: function (args) {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: createURL('listCiscoVnmcResources'),
|
url: createURL('listCiscoVnmcResources'),
|
||||||
@ -269,6 +278,56 @@
|
|||||||
label: 'VNMC',
|
label: 'VNMC',
|
||||||
viewAll: vnmcDeviceViewAll,
|
viewAll: vnmcDeviceViewAll,
|
||||||
actions: {
|
actions: {
|
||||||
|
add: {
|
||||||
|
label: 'Add VNMC provider',
|
||||||
|
|
||||||
|
messages: {
|
||||||
|
confirm: function (args) {
|
||||||
|
return 'Please confirm you would like to add the VNMC provider.';
|
||||||
|
},
|
||||||
|
notification: function (args) {
|
||||||
|
return 'Add VNMC device';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
action: function (args) {
|
||||||
|
$.ajax({
|
||||||
|
url: createURL("addNetworkServiceProvider"),
|
||||||
|
data: {
|
||||||
|
name: 'CiscoVnmc',
|
||||||
|
physicalnetworkid: args.context.physicalNetworks[0].id
|
||||||
|
},
|
||||||
|
success: function (json) {
|
||||||
|
var jobId = json.addnetworkserviceproviderresponse.jobid;
|
||||||
|
var addVnmcProviderIntervalID = setInterval(function () {
|
||||||
|
$.ajax({
|
||||||
|
url: createURL("queryAsyncJobResult&jobId=" + jobId),
|
||||||
|
dataType: "json",
|
||||||
|
success: function (json) {
|
||||||
|
var result = json.queryasyncjobresultresponse;
|
||||||
|
if (result.jobstatus == 0) {
|
||||||
|
return; //Job has not completed
|
||||||
|
} else {
|
||||||
|
clearInterval(addVnmcProviderIntervalID);
|
||||||
|
if (result.jobstatus == 1) {
|
||||||
|
var item = json.queryasyncjobresultresponse.jobresult.networkserviceprovider;
|
||||||
|
args.response.success({
|
||||||
|
data: item
|
||||||
|
});
|
||||||
|
} else if (result.jobstatus == 2) {
|
||||||
|
args.response.error(_s(result.jobresult.errortext));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function (XMLHttpResponse) {
|
||||||
|
args.response.error(parseXMLHttpResponse(data));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}, g_queryAsyncJobResultInterval);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
enable: {
|
enable: {
|
||||||
label: 'Enable VNMC provider',
|
label: 'Enable VNMC provider',
|
||||||
|
|
||||||
@ -319,12 +378,14 @@
|
|||||||
var result = json.queryasyncjobresultresponse;
|
var result = json.queryasyncjobresultresponse;
|
||||||
if (result.jobstatus == 0) {
|
if (result.jobstatus == 0) {
|
||||||
return; //Job has not completed
|
return; //Job has not completed
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
if (result.jobstatus == 1) {
|
if (result.jobstatus == 1) {
|
||||||
args.response.success({ data: { state: 'Enabled' } });
|
args.response.success({
|
||||||
|
data: {
|
||||||
|
state: 'Enabled'
|
||||||
}
|
}
|
||||||
else if (result.jobstatus == 2) {
|
});
|
||||||
|
} else if (result.jobstatus == 2) {
|
||||||
args.response.error(_s(result.jobresult.errortext));
|
args.response.error(_s(result.jobresult.errortext));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -348,7 +409,9 @@
|
|||||||
data: data,
|
data: data,
|
||||||
success: function (json) {
|
success: function (json) {
|
||||||
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
||||||
args.response.success({data: item});
|
args.response.success({
|
||||||
|
data: item
|
||||||
|
});
|
||||||
},
|
},
|
||||||
error: function (data) {
|
error: function (data) {
|
||||||
args.response.error(parseXMLHttpResponse(data));
|
args.response.error(parseXMLHttpResponse(data));
|
||||||
@ -414,13 +477,15 @@
|
|||||||
var result = json.queryasyncjobresultresponse;
|
var result = json.queryasyncjobresultresponse;
|
||||||
if (result.jobstatus == 0) {
|
if (result.jobstatus == 0) {
|
||||||
return; //Job has not completed
|
return; //Job has not completed
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
clearInterval(disableVnmcProviderIntervalID);
|
clearInterval(disableVnmcProviderIntervalID);
|
||||||
if (result.jobstatus == 1) {
|
if (result.jobstatus == 1) {
|
||||||
args.response.success({ data: { state: 'Disabled' } });
|
args.response.success({
|
||||||
|
data: {
|
||||||
|
state: 'Disabled'
|
||||||
}
|
}
|
||||||
else if (result.jobstatus == 2) {
|
});
|
||||||
|
} else if (result.jobstatus == 2) {
|
||||||
args.response.error(_s(result.jobresult.errortext));
|
args.response.error(_s(result.jobresult.errortext));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -444,7 +509,9 @@
|
|||||||
data: data,
|
data: data,
|
||||||
success: function (json) {
|
success: function (json) {
|
||||||
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
var item = json.addCiscoVnmcResource.CiscoVnmcResource;
|
||||||
args.response.success({data: item});
|
args.response.success({
|
||||||
|
data: item
|
||||||
|
});
|
||||||
},
|
},
|
||||||
error: function (data) {
|
error: function (data) {
|
||||||
args.response.error(parseXMLHttpResponse(data));
|
args.response.error(parseXMLHttpResponse(data));
|
||||||
@ -463,13 +530,17 @@
|
|||||||
tabs: {
|
tabs: {
|
||||||
details: {
|
details: {
|
||||||
title: 'label.details',
|
title: 'label.details',
|
||||||
fields: [
|
fields: [{
|
||||||
{
|
name: {
|
||||||
name: { label: 'label.name' }
|
label: 'label.name'
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
state: {
|
||||||
|
label: 'label.state'
|
||||||
|
},
|
||||||
|
id: {
|
||||||
|
label: 'label.id'
|
||||||
},
|
},
|
||||||
{
|
|
||||||
state: { label: 'label.state' },
|
|
||||||
id: { label: 'label.id' },
|
|
||||||
servicelist: {
|
servicelist: {
|
||||||
label: 'Services',
|
label: 'Services',
|
||||||
converter: function (args) {
|
converter: function (args) {
|
||||||
@ -479,8 +550,7 @@
|
|||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}],
|
||||||
],
|
|
||||||
dataProvider: function (args) {
|
dataProvider: function (args) {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: createURL('listNetworkServiceProviders'),
|
url: createURL('listNetworkServiceProviders'),
|
||||||
@ -491,9 +561,10 @@
|
|||||||
success: function (json) {
|
success: function (json) {
|
||||||
var items = json.listnetworkserviceprovidersresponse.networkserviceprovider;
|
var items = json.listnetworkserviceprovidersresponse.networkserviceprovider;
|
||||||
if (items != null && items.length > 0) {
|
if (items != null && items.length > 0) {
|
||||||
args.response.success({ data: items[0] });
|
args.response.success({
|
||||||
}
|
data: items[0]
|
||||||
else {
|
});
|
||||||
|
} else {
|
||||||
args.response.success({
|
args.response.success({
|
||||||
data: {
|
data: {
|
||||||
name: 'CiscoVnmc',
|
name: 'CiscoVnmc',
|
||||||
@ -510,34 +581,38 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
var vnmcActionFilter = function (args) {
|
var vnmcActionFilter = function (args) {
|
||||||
var enabledActions = ['enable'];
|
var allowedActions = [];
|
||||||
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: createURL('listNetworkServiceProviders'),
|
url: createURL('listNetworkServiceProviders'),
|
||||||
async: false,
|
|
||||||
data: {
|
data: {
|
||||||
name: 'CiscoVnmc',
|
name: 'CiscoVnmc',
|
||||||
physicalnetworkid: args.context.physicalNetworks[0].id
|
physicalnetworkid: args.context.physicalNetworks[0].id
|
||||||
},
|
},
|
||||||
|
async: false,
|
||||||
success: function (json) {
|
success: function (json) {
|
||||||
var items = json.listnetworkserviceprovidersresponse.networkserviceprovider;
|
var items = json.listnetworkserviceprovidersresponse.networkserviceprovider;
|
||||||
if (items != null && items.length > 0) {
|
if (items != null && items.length > 0) {
|
||||||
var ciscoVnmcProvider = items[0];
|
var ciscoVnmcProvider = items[0];
|
||||||
|
if (ciscoVnmcProvider.state == 'Enabled') {
|
||||||
if (ciscoVnmcProvider.state === 'Enabled') {
|
allowedActions.push('disable');
|
||||||
enabledActions = ['disable'];
|
} else if (ciscoVnmcProvider.state == 'Disabled') {
|
||||||
|
allowedActions.push('enable');
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
allowedActions.push('add');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
return allowedActions;
|
||||||
return enabledActions;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
module.pluginAPI.extend({
|
module.pluginAPI.extend({
|
||||||
addDevice: function (device) {
|
addDevice: function (device) {
|
||||||
cloudStack.sections.system.subsections[device.id] = device;
|
cloudStack.sections.system.subsections[device.id] = device;
|
||||||
vnmcDeviceViewAll.push({ label: device.title, path: '_zone.' + device.id });
|
vnmcDeviceViewAll.push({
|
||||||
|
label: device.title,
|
||||||
|
path: '_zone.' + device.id
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user