* feat(endpoint): migrate security settings to endpoint * feat(endpoint): check for specific endpoint settings * feat(endpoint): check security settings * feat(docker): add config page * feat(endpoint): save settings page * feat(endpoints): disable features when not agent * feat(sidebar): hide docker settings for regular user * fix(docker): small fixes in configs * fix(volumes): hide browse button for non admins * refactor(docker): introduce switch component * refactor(components/switch): seprate label from switch * feat(app/components): align switch label * refactor(app/components): move switch css * fix(docker/settings): add ngijnect * feat(endpoints): set default security values * style(portainer): sort types * fix(endpoint): rename security heading * fix(endpoints): update endpoints settings
157 lines
4.8 KiB
JavaScript
157 lines
4.8 KiB
JavaScript
import { PortainerEndpointCreationTypes } from 'Portainer/models/endpoint/models';
|
|
|
|
angular.module('portainer.app').factory('EndpointService', [
|
|
'$q',
|
|
'Endpoints',
|
|
'FileUploadService',
|
|
function EndpointServiceFactory($q, Endpoints, FileUploadService) {
|
|
'use strict';
|
|
var service = {
|
|
updateSecuritySettings,
|
|
};
|
|
|
|
service.endpoint = function (endpointID) {
|
|
return Endpoints.get({ id: endpointID }).$promise;
|
|
};
|
|
|
|
service.endpoints = function (start, limit, { search, type, tagIds, endpointIds, tagsPartialMatch } = {}) {
|
|
if (tagIds && !tagIds.length) {
|
|
return Promise.resolve({ value: [], totalCount: 0 });
|
|
}
|
|
return Endpoints.query({ start, limit, search, type, tagIds: JSON.stringify(tagIds), endpointIds: JSON.stringify(endpointIds), tagsPartialMatch }).$promise;
|
|
};
|
|
|
|
service.snapshotEndpoints = function () {
|
|
return Endpoints.snapshots({}, {}).$promise;
|
|
};
|
|
|
|
service.snapshotEndpoint = function (endpointID) {
|
|
return Endpoints.snapshot({ id: endpointID }, {}).$promise;
|
|
};
|
|
|
|
service.endpointsByGroup = function (start, limit, search, groupId) {
|
|
return Endpoints.query({ start, limit, search, groupId }).$promise;
|
|
};
|
|
|
|
service.updateAccess = function (id, userAccessPolicies, teamAccessPolicies) {
|
|
return Endpoints.updateAccess({ id: id }, { UserAccessPolicies: userAccessPolicies, TeamAccessPolicies: teamAccessPolicies }).$promise;
|
|
};
|
|
|
|
service.updateEndpoint = function (id, payload) {
|
|
var deferred = $q.defer();
|
|
FileUploadService.uploadTLSFilesForEndpoint(id, payload.TLSCACert, payload.TLSCert, payload.TLSKey)
|
|
.then(function success() {
|
|
deferred.notify({ upload: false });
|
|
return Endpoints.update({ id: id }, payload).$promise;
|
|
})
|
|
.then(function success(data) {
|
|
deferred.resolve(data);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.notify({ upload: false });
|
|
deferred.reject({ msg: 'Unable to update endpoint', err: err });
|
|
});
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.deleteEndpoint = function (endpointID) {
|
|
return Endpoints.remove({ id: endpointID }).$promise;
|
|
};
|
|
|
|
service.createLocalEndpoint = function (name = 'local') {
|
|
var deferred = $q.defer();
|
|
|
|
FileUploadService.createEndpoint(name, PortainerEndpointCreationTypes.LocalDockerEnvironment, '', '', 1, [], false)
|
|
.then(function success(response) {
|
|
deferred.resolve(response.data);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to create endpoint', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.createRemoteEndpoint = function (
|
|
name,
|
|
creationType,
|
|
URL,
|
|
PublicURL,
|
|
groupID,
|
|
tagIds,
|
|
TLS,
|
|
TLSSkipVerify,
|
|
TLSSkipClientVerify,
|
|
TLSCAFile,
|
|
TLSCertFile,
|
|
TLSKeyFile,
|
|
checkinInterval
|
|
) {
|
|
var deferred = $q.defer();
|
|
|
|
var endpointURL = URL;
|
|
if (creationType !== PortainerEndpointCreationTypes.EdgeAgentEnvironment) {
|
|
endpointURL = 'tcp://' + URL;
|
|
}
|
|
|
|
FileUploadService.createEndpoint(
|
|
name,
|
|
creationType,
|
|
endpointURL,
|
|
PublicURL,
|
|
groupID,
|
|
tagIds,
|
|
TLS,
|
|
TLSSkipVerify,
|
|
TLSSkipClientVerify,
|
|
TLSCAFile,
|
|
TLSCertFile,
|
|
TLSKeyFile,
|
|
checkinInterval
|
|
)
|
|
.then(function success(response) {
|
|
deferred.resolve(response.data);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to create endpoint', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.createLocalKubernetesEndpoint = function (name = 'local') {
|
|
var deferred = $q.defer();
|
|
|
|
FileUploadService.createEndpoint(name, PortainerEndpointCreationTypes.LocalKubernetesEnvironment, '', '', 1, [], true, true, true)
|
|
.then(function success(response) {
|
|
deferred.resolve(response.data);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to create endpoint', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.createAzureEndpoint = function (name, applicationId, tenantId, authenticationKey, groupId, tagIds) {
|
|
var deferred = $q.defer();
|
|
|
|
FileUploadService.createAzureEndpoint(name, applicationId, tenantId, authenticationKey, groupId, tagIds)
|
|
.then(function success(response) {
|
|
deferred.resolve(response.data);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to connect to Azure', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
return service;
|
|
|
|
function updateSecuritySettings(id, securitySettings) {
|
|
return Endpoints.updateSecuritySettings({ id }, securitySettings).$promise;
|
|
}
|
|
},
|
|
]);
|