[Launch Instance Fix] Filter AKI and ARI Images
AKI and ARI image types should be filtered from the list of available images. They are not directly launchable. In addition, only images with status of active should be shown. Change-Id: I1f9117df94351f5777e26e431370a3419422eb55 Closes-Bug: #1434287
This commit is contained in:
parent
bffd06910f
commit
dbf5b11b2c
@ -50,7 +50,8 @@
|
|||||||
allNamespacesPromise;
|
allNamespacesPromise;
|
||||||
|
|
||||||
// Constants (const in ES6)
|
// Constants (const in ES6)
|
||||||
var SOURCE_TYPE_IMAGE = 'image',
|
var NON_BOOTABLE_IMAGE_TYPES = ['aki', 'ari'],
|
||||||
|
SOURCE_TYPE_IMAGE = 'image',
|
||||||
SOURCE_TYPE_SNAPSHOT = 'snapshot',
|
SOURCE_TYPE_SNAPSHOT = 'snapshot',
|
||||||
SOURCE_TYPE_VOLUME = 'volume',
|
SOURCE_TYPE_VOLUME = 'volume',
|
||||||
SOURCE_TYPE_VOLUME_SNAPSHOT = 'volume_snapshot';
|
SOURCE_TYPE_VOLUME_SNAPSHOT = 'volume_snapshot';
|
||||||
@ -184,7 +185,7 @@
|
|||||||
model.allowedBootSources.length = 0;
|
model.allowedBootSources.length = 0;
|
||||||
|
|
||||||
promise = $q.all(
|
promise = $q.all(
|
||||||
glanceAPI.getImages().then(onGetImages),
|
getImages(),
|
||||||
neutronAPI.getNetworks().then(onGetNetworks),
|
neutronAPI.getNetworks().then(onGetNetworks),
|
||||||
novaAPI.getAvailabilityZones().then(onGetAvailabilityZones),
|
novaAPI.getAvailabilityZones().then(onGetAvailabilityZones),
|
||||||
novaAPI.getFlavors().then(onGetFlavors),
|
novaAPI.getFlavors().then(onGetFlavors),
|
||||||
@ -339,16 +340,29 @@
|
|||||||
|
|
||||||
// Boot Source
|
// Boot Source
|
||||||
|
|
||||||
|
function getImages(){
|
||||||
|
return glanceAPI.getImages({status:'active'}).then(onGetImages);
|
||||||
|
}
|
||||||
|
|
||||||
|
function isBootableImageType(image){
|
||||||
|
// This is a blacklist of images that can not be booted.
|
||||||
|
// If the image container type is in the blacklist
|
||||||
|
// The evaluation will result in a 0 or greater index.
|
||||||
|
return NON_BOOTABLE_IMAGE_TYPES.indexOf(image.container_format) < 0;
|
||||||
|
}
|
||||||
|
|
||||||
function onGetImages(data) {
|
function onGetImages(data) {
|
||||||
model.images.length = 0;
|
model.images.length = 0;
|
||||||
push.apply(model.images, data.data.items.filter(function (image) {
|
push.apply(model.images, data.data.items.filter(function (image) {
|
||||||
return !image.properties || image.properties.image_type !== 'snapshot';
|
return isBootableImageType(image) &&
|
||||||
|
(!image.properties || image.properties.image_type !== 'snapshot');
|
||||||
}));
|
}));
|
||||||
addAllowedBootSource(model.images, SOURCE_TYPE_IMAGE, gettext('Image'));
|
addAllowedBootSource(model.images, SOURCE_TYPE_IMAGE, gettext('Image'));
|
||||||
|
|
||||||
model.imageSnapshots.length = 0;
|
model.imageSnapshots.length = 0;
|
||||||
push.apply(model.imageSnapshots, data.data.items.filter(function (image) {
|
push.apply(model.imageSnapshots,data.data.items.filter(function (image) {
|
||||||
return image.properties && image.properties.image_type === 'snapshot';
|
return isBootableImageType(image) &&
|
||||||
|
(image.properties && image.properties.image_type === 'snapshot');
|
||||||
}));
|
}));
|
||||||
|
|
||||||
addAllowedBootSource(model.imageSnapshots, SOURCE_TYPE_SNAPSHOT, gettext('Instance Snapshot'));
|
addAllowedBootSource(model.imageSnapshots, SOURCE_TYPE_SNAPSHOT, gettext('Instance Snapshot'));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user