|
|
|
@ -1,42 +1,42 @@
|
|
|
|
|
angular.module('templates', [])
|
|
|
|
|
.controller('TemplatesController', ['$scope', '$q', '$state', '$filter', 'Config', 'Container', 'Image', 'Volume', 'Network', 'Templates', 'Messages', 'errorMsgFilter',
|
|
|
|
|
function ($scope, $q, $state, $filter, Config, Container, Image, Volume, Network, Templates, Messages, errorMsgFilter) {
|
|
|
|
|
$scope.templates = [];
|
|
|
|
|
$scope.selectedTemplate = null;
|
|
|
|
|
$scope.formValues = {
|
|
|
|
|
network: "",
|
|
|
|
|
name: ""
|
|
|
|
|
};
|
|
|
|
|
.controller('TemplatesController', ['$scope', '$q', '$state', '$filter', 'Config', 'Container', 'ContainerHelper', 'Image', 'Volume', 'Network', 'Templates', 'Messages', 'errorMsgFilter',
|
|
|
|
|
function ($scope, $q, $state, $filter, Config, Container, ContainerHelper, Image, Volume, Network, Templates, Messages, errorMsgFilter) {
|
|
|
|
|
$scope.templates = [];
|
|
|
|
|
$scope.selectedTemplate = null;
|
|
|
|
|
$scope.formValues = {
|
|
|
|
|
network: "",
|
|
|
|
|
name: ""
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var selectedItem = -1;
|
|
|
|
|
var selectedItem = -1;
|
|
|
|
|
|
|
|
|
|
// TODO: centralize, already present in createContainerController
|
|
|
|
|
function createContainer(config) {
|
|
|
|
|
Container.create(config, function (d) {
|
|
|
|
|
if (d.Id) {
|
|
|
|
|
var reqBody = config.HostConfig || {};
|
|
|
|
|
reqBody.id = d.Id;
|
|
|
|
|
Container.start(reqBody, function (cd) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.send('Container Started', d.Id);
|
|
|
|
|
$state.go('containers', {}, {reload: true});
|
|
|
|
|
}, function (e) {
|
|
|
|
|
// TODO: centralize, already present in createContainerController
|
|
|
|
|
function createContainer(config) {
|
|
|
|
|
Container.create(config, function (d) {
|
|
|
|
|
if (d.Id) {
|
|
|
|
|
var reqBody = config.HostConfig || {};
|
|
|
|
|
reqBody.id = d.Id;
|
|
|
|
|
Container.start(reqBody, function (cd) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.send('Container Started', d.Id);
|
|
|
|
|
$state.go('containers', {}, {reload: true});
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', errorMsgFilter(e));
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', errorMsgFilter(e));
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
Messages.error('Error', errorMsgFilter(d));
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', errorMsgFilter(d));
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', errorMsgFilter(e));
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
Messages.error('Error', errorMsgFilter(e));
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO: centralize, already present in createContainerController
|
|
|
|
|
function pullImageAndCreateContainer(imageConfig, containerConfig) {
|
|
|
|
|
Image.create(imageConfig, function (data) {
|
|
|
|
|
// TODO: centralize, already present in createContainerController
|
|
|
|
|
function pullImageAndCreateContainer(imageConfig, containerConfig) {
|
|
|
|
|
Image.create(imageConfig, function (data) {
|
|
|
|
|
var err = data.length > 0 && data[data.length - 1].hasOwnProperty('error');
|
|
|
|
|
if (err) {
|
|
|
|
|
var detail = data[data.length - 1];
|
|
|
|
@ -45,167 +45,151 @@ function pullImageAndCreateContainer(imageConfig, containerConfig) {
|
|
|
|
|
} else {
|
|
|
|
|
createContainer(containerConfig);
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', 'Unable to pull image ' + image);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#createContainerSpinner').hide();
|
|
|
|
|
Messages.error('Error', 'Unable to pull image ' + image);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getInitialConfiguration() {
|
|
|
|
|
return {
|
|
|
|
|
Env: [],
|
|
|
|
|
OpenStdin: false,
|
|
|
|
|
Tty: false,
|
|
|
|
|
ExposedPorts: {},
|
|
|
|
|
HostConfig: {
|
|
|
|
|
RestartPolicy: {
|
|
|
|
|
Name: 'no'
|
|
|
|
|
function getInitialConfiguration() {
|
|
|
|
|
return {
|
|
|
|
|
Env: [],
|
|
|
|
|
OpenStdin: false,
|
|
|
|
|
Tty: false,
|
|
|
|
|
ExposedPorts: {},
|
|
|
|
|
HostConfig: {
|
|
|
|
|
RestartPolicy: {
|
|
|
|
|
Name: 'no'
|
|
|
|
|
},
|
|
|
|
|
PortBindings: {},
|
|
|
|
|
Binds: [],
|
|
|
|
|
NetworkMode: $scope.formValues.network.Name,
|
|
|
|
|
Privileged: false
|
|
|
|
|
},
|
|
|
|
|
PortBindings: {},
|
|
|
|
|
Binds: [],
|
|
|
|
|
NetworkMode: $scope.formValues.network.Name,
|
|
|
|
|
Privileged: false
|
|
|
|
|
},
|
|
|
|
|
Volumes: {},
|
|
|
|
|
name: $scope.formValues.name
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
Volumes: {},
|
|
|
|
|
name: $scope.formValues.name
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createConfigFromTemplate(template) {
|
|
|
|
|
var containerConfig = getInitialConfiguration();
|
|
|
|
|
containerConfig.Image = template.image;
|
|
|
|
|
if (template.env) {
|
|
|
|
|
template.env.forEach(function (v) {
|
|
|
|
|
if (v.value || v.set) {
|
|
|
|
|
var val;
|
|
|
|
|
if (v.type && v.type === 'container') {
|
|
|
|
|
if ($scope.swarm && $scope.formValues.network.Scope === 'global') {
|
|
|
|
|
val = $filter('swarmcontainername')(v.value);
|
|
|
|
|
function createConfigFromTemplate(template) {
|
|
|
|
|
var containerConfig = getInitialConfiguration();
|
|
|
|
|
containerConfig.Image = template.image;
|
|
|
|
|
if (template.env) {
|
|
|
|
|
template.env.forEach(function (v) {
|
|
|
|
|
if (v.value || v.set) {
|
|
|
|
|
var val;
|
|
|
|
|
if (v.type && v.type === 'container') {
|
|
|
|
|
if ($scope.swarm && $scope.formValues.network.Scope === 'global') {
|
|
|
|
|
val = $filter('swarmcontainername')(v.value);
|
|
|
|
|
} else {
|
|
|
|
|
var container = v.value;
|
|
|
|
|
val = container.NetworkSettings.Networks[Object.keys(container.NetworkSettings.Networks)[0]].IPAddress;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
var container = v.value;
|
|
|
|
|
val = container.NetworkSettings.Networks[Object.keys(container.NetworkSettings.Networks)[0]].IPAddress;
|
|
|
|
|
val = v.set ? v.set : v.value;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
val = v.set ? v.set : v.value;
|
|
|
|
|
containerConfig.Env.push(v.name + "=" + val);
|
|
|
|
|
}
|
|
|
|
|
containerConfig.Env.push(v.name + "=" + val);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
if (template.ports) {
|
|
|
|
|
template.ports.forEach(function (p) {
|
|
|
|
|
containerConfig.ExposedPorts[p] = {};
|
|
|
|
|
containerConfig.HostConfig.PortBindings[p] = [{ HostPort: ""}];
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
return containerConfig;
|
|
|
|
|
}
|
|
|
|
|
if (template.ports) {
|
|
|
|
|
template.ports.forEach(function (p) {
|
|
|
|
|
containerConfig.ExposedPorts[p] = {};
|
|
|
|
|
containerConfig.HostConfig.PortBindings[p] = [{ HostPort: ""}];
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
function prepareVolumeQueries(template, containerConfig) {
|
|
|
|
|
var volumeQueries = [];
|
|
|
|
|
if (template.volumes) {
|
|
|
|
|
template.volumes.forEach(function (vol) {
|
|
|
|
|
volumeQueries.push(
|
|
|
|
|
Volume.create({}, function (d) {
|
|
|
|
|
if (d.Name) {
|
|
|
|
|
Messages.send("Volume created", d.Name);
|
|
|
|
|
containerConfig.Volumes[vol] = {};
|
|
|
|
|
containerConfig.HostConfig.Binds.push(d.Name + ':' + vol);
|
|
|
|
|
} else {
|
|
|
|
|
Messages.error('Unable to create volume', errorMsgFilter(d));
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error('Unable to create volume', e.data);
|
|
|
|
|
}).$promise
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
return volumeQueries;
|
|
|
|
|
}
|
|
|
|
|
return containerConfig;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function prepareVolumeQueries(template, containerConfig) {
|
|
|
|
|
var volumeQueries = [];
|
|
|
|
|
if (template.volumes) {
|
|
|
|
|
template.volumes.forEach(function (vol) {
|
|
|
|
|
volumeQueries.push(
|
|
|
|
|
Volume.create({}, function (d) {
|
|
|
|
|
if (d.Name) {
|
|
|
|
|
Messages.send("Volume created", d.Name);
|
|
|
|
|
containerConfig.Volumes[vol] = {};
|
|
|
|
|
containerConfig.HostConfig.Binds.push(d.Name + ':' + vol);
|
|
|
|
|
} else {
|
|
|
|
|
Messages.error('Unable to create volume', errorMsgFilter(d));
|
|
|
|
|
}
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error('Unable to create volume', e.data);
|
|
|
|
|
}).$promise
|
|
|
|
|
);
|
|
|
|
|
$scope.createTemplate = function() {
|
|
|
|
|
$('#createContainerSpinner').show();
|
|
|
|
|
var template = $scope.selectedTemplate;
|
|
|
|
|
var containerConfig = createConfigFromTemplate(template);
|
|
|
|
|
var imageConfig = {
|
|
|
|
|
fromImage: template.image.split(':')[0],
|
|
|
|
|
tag: template.image.split(':')[1] ? template.image.split(':')[1] : 'latest'
|
|
|
|
|
};
|
|
|
|
|
var createVolumeQueries = prepareVolumeQueries(template, containerConfig);
|
|
|
|
|
$q.all(createVolumeQueries).then(function (d) {
|
|
|
|
|
pullImageAndCreateContainer(imageConfig, containerConfig);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
return volumeQueries;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.createTemplate = function() {
|
|
|
|
|
$('#createContainerSpinner').show();
|
|
|
|
|
var template = $scope.selectedTemplate;
|
|
|
|
|
var containerConfig = createConfigFromTemplate(template);
|
|
|
|
|
var imageConfig = {
|
|
|
|
|
fromImage: template.image.split(':')[0],
|
|
|
|
|
tag: template.image.split(':')[1] ? template.image.split(':')[1] : 'latest'
|
|
|
|
|
$scope.selectTemplate = function(id) {
|
|
|
|
|
$('#template_' + id).toggleClass("container-template--selected");
|
|
|
|
|
if (selectedItem === id) {
|
|
|
|
|
selectedItem = -1;
|
|
|
|
|
$scope.selectedTemplate = null;
|
|
|
|
|
} else {
|
|
|
|
|
$('#template_' + selectedItem).toggleClass("container-template--selected");
|
|
|
|
|
selectedItem = id;
|
|
|
|
|
$scope.selectedTemplate = $scope.templates[id];
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
var createVolumeQueries = prepareVolumeQueries(template, containerConfig);
|
|
|
|
|
$q.all(createVolumeQueries).then(function (d) {
|
|
|
|
|
pullImageAndCreateContainer(imageConfig, containerConfig);
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.selectTemplate = function(id) {
|
|
|
|
|
$('#template_' + id).toggleClass("container-template--selected");
|
|
|
|
|
if (selectedItem === id) {
|
|
|
|
|
selectedItem = -1;
|
|
|
|
|
$scope.selectedTemplate = null;
|
|
|
|
|
} else {
|
|
|
|
|
$('#template_' + selectedItem).toggleClass("container-template--selected");
|
|
|
|
|
selectedItem = id;
|
|
|
|
|
$scope.selectedTemplate = $scope.templates[id];
|
|
|
|
|
function initTemplates() {
|
|
|
|
|
Templates.get(function (data) {
|
|
|
|
|
$scope.templates = data;
|
|
|
|
|
$('#loadTemplatesSpinner').hide();
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#loadTemplatesSpinner').hide();
|
|
|
|
|
Messages.error("Unable to retrieve apps list", e.data);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function initTemplates() {
|
|
|
|
|
Templates.get(function (data) {
|
|
|
|
|
$scope.templates = data;
|
|
|
|
|
$('#loadTemplatesSpinner').hide();
|
|
|
|
|
}, function (e) {
|
|
|
|
|
$('#loadTemplatesSpinner').hide();
|
|
|
|
|
Messages.error("Unable to retrieve apps list", e.data);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO: centralize (already exist in containersController)
|
|
|
|
|
var hideContainers = function (containers) {
|
|
|
|
|
return containers.filter(function (container) {
|
|
|
|
|
var filterContainer = false;
|
|
|
|
|
hiddenLabels.forEach(function(label, index) {
|
|
|
|
|
if (_.has(container.Labels, label.name) &&
|
|
|
|
|
container.Labels[label.name] === label.value) {
|
|
|
|
|
filterContainer = true;
|
|
|
|
|
Config.$promise.then(function (c) {
|
|
|
|
|
$scope.swarm = c.swarm;
|
|
|
|
|
var containersToHideLabels = c.hiddenLabels;
|
|
|
|
|
Network.query({}, function (d) {
|
|
|
|
|
var networks = d;
|
|
|
|
|
if ($scope.swarm) {
|
|
|
|
|
networks = d.filter(function (network) {
|
|
|
|
|
if (network.Scope === 'global') {
|
|
|
|
|
return network;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
$scope.globalNetworkCount = networks.length;
|
|
|
|
|
networks.push({Scope: "local", Name: "bridge"});
|
|
|
|
|
networks.push({Scope: "local", Name: "host"});
|
|
|
|
|
networks.push({Scope: "local", Name: "none"});
|
|
|
|
|
} else {
|
|
|
|
|
$scope.formValues.network = _.find(networks, function(o) { return o.Name === "bridge"; });
|
|
|
|
|
}
|
|
|
|
|
$scope.availableNetworks = networks;
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error("Unable to retrieve available networks", e.data);
|
|
|
|
|
});
|
|
|
|
|
if (!filterContainer) {
|
|
|
|
|
return container;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Config.$promise.then(function (c) {
|
|
|
|
|
$scope.swarm = c.swarm;
|
|
|
|
|
hiddenLabels = c.hiddenLabels;
|
|
|
|
|
Network.query({}, function (d) {
|
|
|
|
|
var networks = d;
|
|
|
|
|
if ($scope.swarm) {
|
|
|
|
|
networks = d.filter(function (network) {
|
|
|
|
|
if (network.Scope === 'global') {
|
|
|
|
|
return network;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
$scope.globalNetworkCount = networks.length;
|
|
|
|
|
networks.push({Scope: "local", Name: "bridge"});
|
|
|
|
|
networks.push({Scope: "local", Name: "host"});
|
|
|
|
|
networks.push({Scope: "local", Name: "none"});
|
|
|
|
|
} else {
|
|
|
|
|
$scope.formValues.network = _.find(networks, function(o) { return o.Name === "bridge"; });
|
|
|
|
|
}
|
|
|
|
|
$scope.availableNetworks = networks;
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error("Unable to retrieve available networks", e.data);
|
|
|
|
|
});
|
|
|
|
|
Container.query({all: 0}, function (d) {
|
|
|
|
|
var containers = d;
|
|
|
|
|
if (hiddenLabels) {
|
|
|
|
|
containers = hideContainers(d);
|
|
|
|
|
}
|
|
|
|
|
$scope.runningContainers = containers;
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error("Unable to retrieve running containers", e.data);
|
|
|
|
|
Container.query({all: 0}, function (d) {
|
|
|
|
|
var containers = d;
|
|
|
|
|
if (containersToHideLabels) {
|
|
|
|
|
containers = ContainerHelper.hideContainers(d, containersToHideLabels);
|
|
|
|
|
}
|
|
|
|
|
$scope.runningContainers = containers;
|
|
|
|
|
}, function (e) {
|
|
|
|
|
Messages.error("Unable to retrieve running containers", e.data);
|
|
|
|
|
});
|
|
|
|
|
initTemplates();
|
|
|
|
|
});
|
|
|
|
|
initTemplates();
|
|
|
|
|
});
|
|
|
|
|
}]);
|
|
|
|
|