2017-02-10 01:11:36 +00:00
|
|
|
angular.module('portainer.services')
|
2017-07-11 07:56:28 +00:00
|
|
|
.factory('ImageService', ['$q', 'Image', 'ImageHelper', 'RegistryService', 'HttpRequestHelper', 'SystemService', function ImageServiceFactory($q, Image, ImageHelper, RegistryService, HttpRequestHelper, SystemService) {
|
2017-02-10 01:11:36 +00:00
|
|
|
'use strict';
|
|
|
|
var service = {};
|
|
|
|
|
2017-03-20 11:01:35 +00:00
|
|
|
service.image = function(imageId) {
|
2017-02-10 01:11:36 +00:00
|
|
|
var deferred = $q.defer();
|
2017-03-20 11:01:35 +00:00
|
|
|
Image.get({id: imageId}).$promise
|
|
|
|
.then(function success(data) {
|
|
|
|
if (data.message) {
|
|
|
|
deferred.reject({ msg: data.message });
|
|
|
|
} else {
|
|
|
|
var image = new ImageDetailsViewModel(data);
|
|
|
|
deferred.resolve(image);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to retrieve image details', err: err });
|
|
|
|
});
|
|
|
|
return deferred.promise;
|
|
|
|
};
|
|
|
|
|
|
|
|
service.images = function() {
|
|
|
|
var deferred = $q.defer();
|
2017-07-11 07:56:28 +00:00
|
|
|
|
|
|
|
$q.all({
|
|
|
|
dataUsage: SystemService.dataUsage(),
|
|
|
|
images: Image.query({}).$promise
|
|
|
|
})
|
2017-03-20 11:01:35 +00:00
|
|
|
.then(function success(data) {
|
2017-07-11 07:56:28 +00:00
|
|
|
var images = data.images.map(function(item) {
|
|
|
|
item.dataUsage = data.dataUsage.Images.find(function(usage) {
|
|
|
|
return item.Id === usage.Id;
|
|
|
|
});
|
|
|
|
|
2017-03-20 11:01:35 +00:00
|
|
|
return new ImageViewModel(item);
|
|
|
|
});
|
|
|
|
deferred.resolve(images);
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to retrieve images', err: err });
|
|
|
|
});
|
|
|
|
return deferred.promise;
|
|
|
|
};
|
|
|
|
|
2017-07-08 06:59:32 +00:00
|
|
|
service.history = function(imageId) {
|
|
|
|
var deferred = $q.defer();
|
|
|
|
Image.history({id: imageId}).$promise
|
|
|
|
.then(function success(data) {
|
|
|
|
if (data.message) {
|
|
|
|
deferred.reject({ msg: data.message });
|
|
|
|
} else {
|
|
|
|
var layers = [];
|
|
|
|
angular.forEach(data, function(imageLayer) {
|
|
|
|
layers.push(new ImageLayerViewModel(imageLayer));
|
|
|
|
});
|
|
|
|
deferred.resolve(layers);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to retrieve image details', err: err });
|
|
|
|
});
|
|
|
|
return deferred.promise;
|
|
|
|
};
|
|
|
|
|
2017-06-20 11:00:32 +00:00
|
|
|
service.pushImage = function(tag, registry) {
|
|
|
|
var deferred = $q.defer();
|
|
|
|
|
|
|
|
var authenticationDetails = registry.Authentication ? RegistryService.encodedCredentials(registry) : '';
|
|
|
|
HttpRequestHelper.setRegistryAuthenticationHeader(authenticationDetails);
|
|
|
|
Image.push({tag: tag}).$promise
|
|
|
|
.then(function success(data) {
|
|
|
|
if (data[data.length - 1].error) {
|
|
|
|
deferred.reject({ msg: data[data.length - 1].error });
|
|
|
|
} else {
|
|
|
|
deferred.resolve();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to push image tag', err: err });
|
|
|
|
});
|
|
|
|
return deferred.promise;
|
|
|
|
};
|
|
|
|
|
2017-06-29 14:05:39 +00:00
|
|
|
function pullImageAndIgnoreErrors(imageConfiguration) {
|
2017-03-20 11:01:35 +00:00
|
|
|
var deferred = $q.defer();
|
2017-06-20 11:00:32 +00:00
|
|
|
|
2017-06-29 14:05:39 +00:00
|
|
|
Image.create({}, imageConfiguration).$promise
|
|
|
|
.finally(function final() {
|
|
|
|
deferred.resolve();
|
|
|
|
});
|
|
|
|
|
|
|
|
return deferred.promise;
|
|
|
|
}
|
|
|
|
|
|
|
|
function pullImageAndAcknowledgeErrors(imageConfiguration) {
|
|
|
|
var deferred = $q.defer();
|
2017-06-20 11:00:32 +00:00
|
|
|
|
|
|
|
Image.create({}, imageConfiguration).$promise
|
2017-02-10 01:11:36 +00:00
|
|
|
.then(function success(data) {
|
2017-05-23 18:25:56 +00:00
|
|
|
var err = data.length > 0 && data[data.length - 1].hasOwnProperty('message');
|
2017-02-10 01:11:36 +00:00
|
|
|
if (err) {
|
|
|
|
var detail = data[data.length - 1];
|
2017-05-23 18:25:56 +00:00
|
|
|
deferred.reject({ msg: detail.message });
|
2017-02-10 01:11:36 +00:00
|
|
|
} else {
|
|
|
|
deferred.resolve(data);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to pull image', err: err });
|
|
|
|
});
|
2017-03-20 11:01:35 +00:00
|
|
|
|
2017-06-20 11:00:32 +00:00
|
|
|
return deferred.promise;
|
2017-06-29 14:05:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
service.pullImage = function(image, registry, ignoreErrors) {
|
|
|
|
var imageDetails = ImageHelper.extractImageAndRegistryFromRepository(image);
|
|
|
|
var imageConfiguration = ImageHelper.createImageConfigForContainer(imageDetails.image, registry.URL);
|
|
|
|
var authenticationDetails = registry.Authentication ? RegistryService.encodedCredentials(registry) : '';
|
|
|
|
HttpRequestHelper.setRegistryAuthenticationHeader(authenticationDetails);
|
|
|
|
|
|
|
|
if (ignoreErrors) {
|
|
|
|
return pullImageAndIgnoreErrors(imageConfiguration);
|
|
|
|
}
|
|
|
|
return pullImageAndAcknowledgeErrors(imageConfiguration);
|
2017-05-23 18:25:56 +00:00
|
|
|
};
|
|
|
|
|
2017-03-20 11:01:35 +00:00
|
|
|
service.tagImage = function(id, image, registry) {
|
|
|
|
var imageConfig = ImageHelper.createImageConfigForCommit(image, registry);
|
|
|
|
return Image.tag({id: id, tag: imageConfig.tag, repo: imageConfig.repo}).$promise;
|
|
|
|
};
|
|
|
|
|
|
|
|
service.deleteImage = function(id, forceRemoval) {
|
|
|
|
var deferred = $q.defer();
|
|
|
|
Image.remove({id: id, force: forceRemoval}).$promise
|
|
|
|
.then(function success(data) {
|
|
|
|
if (data[0].message) {
|
|
|
|
deferred.reject({ msg: data[0].message });
|
|
|
|
} else {
|
|
|
|
deferred.resolve();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function error(err) {
|
|
|
|
deferred.reject({ msg: 'Unable to remove image', err: err });
|
|
|
|
});
|
|
|
|
return deferred.promise;
|
|
|
|
};
|
|
|
|
|
2017-02-10 01:11:36 +00:00
|
|
|
return service;
|
|
|
|
}]);
|