mirror of https://github.com/portainer/portainer
158 lines
6.0 KiB
JavaScript
158 lines
6.0 KiB
JavaScript
angular.module('templates', [])
|
|
.controller('TemplatesController', ['$scope', '$q', '$state', '$anchorScroll', 'Config', 'ContainerService', 'ContainerHelper', 'ImageService', 'NetworkService', 'TemplateService', 'TemplateHelper', 'VolumeService', 'Messages', 'Pagination', 'ResourceControlService', 'Authentication',
|
|
function ($scope, $q, $state, $anchorScroll, Config, ContainerService, ContainerHelper, ImageService, NetworkService, TemplateService, TemplateHelper, VolumeService, Messages, Pagination, ResourceControlService, Authentication) {
|
|
$scope.state = {
|
|
selectedTemplate: null,
|
|
showAdvancedOptions: false,
|
|
pagination_count: Pagination.getPaginationCount('templates')
|
|
};
|
|
$scope.formValues = {
|
|
Ownership: $scope.applicationState.application.authentication ? 'private' : '',
|
|
network: "",
|
|
name: "",
|
|
};
|
|
|
|
$scope.changePaginationCount = function() {
|
|
Pagination.setPaginationCount('templates', $scope.state.pagination_count);
|
|
};
|
|
|
|
$scope.addVolume = function () {
|
|
$scope.state.selectedTemplate.Volumes.push({ containerPath: '', name: '', readOnly: false, type: 'auto' });
|
|
};
|
|
|
|
$scope.removeVolume = function(index) {
|
|
$scope.state.selectedTemplate.Volumes.splice(index, 1);
|
|
};
|
|
|
|
$scope.addPortBinding = function() {
|
|
$scope.state.selectedTemplate.Ports.push({ hostPort: '', containerPort: '', protocol: 'tcp' });
|
|
};
|
|
|
|
$scope.removePortBinding = function(index) {
|
|
$scope.state.selectedTemplate.Ports.splice(index, 1);
|
|
};
|
|
|
|
$scope.createTemplate = function() {
|
|
$('#createContainerSpinner').show();
|
|
var template = $scope.state.selectedTemplate;
|
|
var templateConfiguration = createTemplateConfiguration(template);
|
|
var generatedVolumeCount = TemplateHelper.determineRequiredGeneratedVolumeCount(template.Volumes);
|
|
VolumeService.createXAutoGeneratedLocalVolumes(generatedVolumeCount)
|
|
.then(function success(data) {
|
|
var volumeResourceControlQueries = [];
|
|
if ($scope.formValues.Ownership === 'private') {
|
|
angular.forEach(data, function (volume) {
|
|
volumeResourceControlQueries.push(ResourceControlService.setVolumeResourceControl(Authentication.getUserDetails().ID, volume.Name));
|
|
});
|
|
}
|
|
TemplateService.updateContainerConfigurationWithVolumes(templateConfiguration.container, template, data);
|
|
return $q.all(volumeResourceControlQueries)
|
|
.then(function success() {
|
|
return ImageService.pullImage(templateConfiguration.image);
|
|
});
|
|
})
|
|
.then(function success(data) {
|
|
return ContainerService.createAndStartContainer(templateConfiguration.container);
|
|
})
|
|
.then(function success(data) {
|
|
Messages.send('Container Started', data.Id);
|
|
if ($scope.formValues.Ownership === 'private') {
|
|
ResourceControlService.setContainerResourceControl(Authentication.getUserDetails().ID, data.Id)
|
|
.then(function success(data) {
|
|
$state.go('containers', {}, {reload: true});
|
|
});
|
|
} else {
|
|
$state.go('containers', {}, {reload: true});
|
|
}
|
|
})
|
|
.catch(function error(err) {
|
|
Messages.error('Failure', err, err.msg);
|
|
})
|
|
.finally(function final() {
|
|
$('#createContainerSpinner').hide();
|
|
});
|
|
};
|
|
|
|
var selectedItem = -1;
|
|
$scope.selectTemplate = function(idx) {
|
|
$('#template_' + idx).toggleClass("container-template--selected");
|
|
if (selectedItem === idx) {
|
|
unselectTemplate();
|
|
} else {
|
|
selectTemplate(idx);
|
|
}
|
|
};
|
|
|
|
function unselectTemplate() {
|
|
selectedItem = -1;
|
|
$scope.state.selectedTemplate = null;
|
|
}
|
|
|
|
function selectTemplate(idx) {
|
|
$('#template_' + selectedItem).toggleClass("container-template--selected");
|
|
selectedItem = idx;
|
|
var selectedTemplate = $scope.templates[idx];
|
|
$scope.state.selectedTemplate = selectedTemplate;
|
|
if (selectedTemplate.Network) {
|
|
$scope.formValues.network = _.find($scope.availableNetworks, function(o) { return o.Name === selectedTemplate.Network; });
|
|
} else {
|
|
$scope.formValues.network = _.find($scope.availableNetworks, function(o) { return o.Name === "bridge"; });
|
|
}
|
|
$anchorScroll('selectedTemplate');
|
|
}
|
|
|
|
function createTemplateConfiguration(template) {
|
|
var network = $scope.formValues.network;
|
|
var name = $scope.formValues.name;
|
|
var containerMapping = determineContainerMapping(network);
|
|
return TemplateService.createTemplateConfiguration(template, name, network, containerMapping);
|
|
}
|
|
|
|
function determineContainerMapping(network) {
|
|
var endpointProvider = $scope.applicationState.endpoint.mode.provider;
|
|
var containerMapping = 'BY_CONTAINER_IP';
|
|
if (endpointProvider === 'DOCKER_SWARM' && network.Scope === 'global') {
|
|
containerMapping = 'BY_SWARM_CONTAINER_NAME';
|
|
} else if (network.Name !== "bridge") {
|
|
containerMapping = 'BY_CONTAINER_NAME';
|
|
}
|
|
return containerMapping;
|
|
}
|
|
|
|
function filterNetworksBasedOnProvider(networks) {
|
|
var endpointProvider = $scope.applicationState.endpoint.mode.provider;
|
|
if (endpointProvider === 'DOCKER_SWARM' || endpointProvider === 'DOCKER_SWARM_MODE') {
|
|
networks = NetworkService.filterGlobalNetworks(networks);
|
|
$scope.globalNetworkCount = networks.length;
|
|
NetworkService.addPredefinedLocalNetworks(networks);
|
|
}
|
|
return networks;
|
|
}
|
|
|
|
function initTemplates() {
|
|
Config.$promise.then(function (c) {
|
|
$q.all({
|
|
templates: TemplateService.getTemplates(),
|
|
containers: ContainerService.getContainers(0, c.hiddenLabels),
|
|
networks: NetworkService.getNetworks(),
|
|
volumes: VolumeService.getVolumes()
|
|
})
|
|
.then(function success(data) {
|
|
$scope.templates = data.templates;
|
|
$scope.runningContainers = data.containers;
|
|
$scope.availableNetworks = filterNetworksBasedOnProvider(data.networks);
|
|
$scope.availableVolumes = data.volumes.Volumes;
|
|
})
|
|
.catch(function error(err) {
|
|
$scope.templates = [];
|
|
Messages.error("Failure", err, "An error occured during apps initialization.");
|
|
})
|
|
.finally(function final(){
|
|
$('#loadTemplatesSpinner').hide();
|
|
});
|
|
});
|
|
}
|
|
|
|
initTemplates();
|
|
}]);
|