2014-11-12 18:11:36 +00:00
|
|
|
angular.module('image', [])
|
2014-11-29 06:06:06 +00:00
|
|
|
.controller('ImageController', ['$scope', '$q', '$routeParams', '$location', 'Image', 'Container', 'Messages', 'LineChart',
|
|
|
|
function($scope, $q, $routeParams, $location, Image, Container, Messages, LineChart) {
|
2014-11-12 18:11:36 +00:00
|
|
|
$scope.history = [];
|
|
|
|
$scope.tag = {repo: '', force: false};
|
|
|
|
|
|
|
|
$scope.remove = function() {
|
|
|
|
Image.remove({id: $routeParams.id}, function(d) {
|
|
|
|
Messages.send("Image Removed", $routeParams.id);
|
|
|
|
}, function(e) {
|
|
|
|
$scope.error = e.data;
|
|
|
|
$('#error-message').show();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.getHistory = function() {
|
|
|
|
Image.history({id: $routeParams.id}, function(d) {
|
|
|
|
$scope.history = d;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.updateTag = function() {
|
|
|
|
var tag = $scope.tag;
|
|
|
|
Image.tag({id: $routeParams.id, repo: tag.repo, force: tag.force ? 1 : 0}, function(d) {
|
|
|
|
Messages.send("Tag Added", $routeParams.id);
|
|
|
|
}, function(e) {
|
|
|
|
$scope.error = e.data;
|
|
|
|
$('#error-message').show();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2014-11-29 06:06:06 +00:00
|
|
|
function getContainersFromImage($q, Container, tag) {
|
|
|
|
var defer = $q.defer();
|
|
|
|
|
|
|
|
Container.query({all:1, notruc:1}, function(d) {
|
|
|
|
var containers = [];
|
|
|
|
for (var i = 0; i < d.length; i++) {
|
|
|
|
var c = d[i];
|
2015-01-04 00:39:40 +00:00
|
|
|
if (c.Image === tag) {
|
2014-11-29 06:06:06 +00:00
|
|
|
containers.push(new ContainerViewModel(c));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
defer.resolve(containers);
|
|
|
|
});
|
|
|
|
|
|
|
|
return defer.promise;
|
|
|
|
}
|
|
|
|
|
2014-11-12 18:11:36 +00:00
|
|
|
Image.get({id: $routeParams.id}, function(d) {
|
|
|
|
$scope.image = d;
|
|
|
|
$scope.tag = d.id;
|
|
|
|
var t = $routeParams.tag;
|
|
|
|
if (t && t !== ":") {
|
|
|
|
$scope.tag = t;
|
|
|
|
var promise = getContainersFromImage($q, Container, t);
|
|
|
|
|
|
|
|
promise.then(function(containers) {
|
2014-11-29 06:06:06 +00:00
|
|
|
LineChart.build('#containers-started-chart', containers, function(c) { return new Date(c.Created * 1000).toLocaleDateString(); });
|
2014-11-12 18:11:36 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}, function(e) {
|
|
|
|
if (e.status === 404) {
|
|
|
|
$('.detail').hide();
|
|
|
|
$scope.error = "Image not found.<br />" + $routeParams.id;
|
|
|
|
} else {
|
|
|
|
$scope.error = e.data;
|
|
|
|
}
|
|
|
|
$('#error-message').show();
|
|
|
|
});
|
|
|
|
|
|
|
|
$scope.getHistory();
|
|
|
|
}]);
|