[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:
Travis Tripp 2015-03-10 11:35:21 -06:00
parent bffd06910f
commit dbf5b11b2c

View File

@ -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'));