mirror of https://github.com/portainer/portainer
95 lines
3.7 KiB
JavaScript
95 lines
3.7 KiB
JavaScript
export default class DockerFeaturesConfigurationController {
|
|
/* @ngInject */
|
|
constructor($async, EndpointService, Notifications, StateManager) {
|
|
this.$async = $async;
|
|
this.EndpointService = EndpointService;
|
|
this.Notifications = Notifications;
|
|
this.StateManager = StateManager;
|
|
|
|
this.formValues = {
|
|
enableHostManagementFeatures: false,
|
|
allowVolumeBrowserForRegularUsers: false,
|
|
disableBindMountsForRegularUsers: false,
|
|
disablePrivilegedModeForRegularUsers: false,
|
|
disableHostNamespaceForRegularUsers: false,
|
|
disableStackManagementForRegularUsers: false,
|
|
disableDeviceMappingForRegularUsers: false,
|
|
disableContainerCapabilitiesForRegularUsers: false,
|
|
};
|
|
|
|
this.isAgent = false;
|
|
|
|
this.state = {
|
|
actionInProgress: false,
|
|
};
|
|
|
|
this.save = this.save.bind(this);
|
|
}
|
|
|
|
isContainerEditDisabled() {
|
|
const {
|
|
disableBindMountsForRegularUsers,
|
|
disableHostNamespaceForRegularUsers,
|
|
disablePrivilegedModeForRegularUsers,
|
|
disableDeviceMappingForRegularUsers,
|
|
disableContainerCapabilitiesForRegularUsers,
|
|
} = this.formValues;
|
|
return (
|
|
disableBindMountsForRegularUsers ||
|
|
disableHostNamespaceForRegularUsers ||
|
|
disablePrivilegedModeForRegularUsers ||
|
|
disableDeviceMappingForRegularUsers ||
|
|
disableContainerCapabilitiesForRegularUsers
|
|
);
|
|
}
|
|
|
|
async save() {
|
|
return this.$async(async () => {
|
|
try {
|
|
this.state.actionInProgress = true;
|
|
const securitySettings = {
|
|
enableHostManagementFeatures: this.formValues.enableHostManagementFeatures,
|
|
allowBindMountsForRegularUsers: !this.formValues.disableBindMountsForRegularUsers,
|
|
allowPrivilegedModeForRegularUsers: !this.formValues.disablePrivilegedModeForRegularUsers,
|
|
allowVolumeBrowserForRegularUsers: this.formValues.allowVolumeBrowserForRegularUsers,
|
|
allowHostNamespaceForRegularUsers: !this.formValues.disableHostNamespaceForRegularUsers,
|
|
allowDeviceMappingForRegularUsers: !this.formValues.disableDeviceMappingForRegularUsers,
|
|
allowStackManagementForRegularUsers: !this.formValues.disableStackManagementForRegularUsers,
|
|
allowContainerCapabilitiesForRegularUsers: !this.formValues.disableContainerCapabilitiesForRegularUsers,
|
|
};
|
|
|
|
await this.EndpointService.updateSecuritySettings(this.endpoint.Id, securitySettings);
|
|
|
|
this.endpoint.SecuritySettings = securitySettings;
|
|
this.Notifications.success('Saved settings successfully');
|
|
} catch (e) {
|
|
this.Notifications.error('Failure', e, 'Failed saving settings');
|
|
}
|
|
this.state.actionInProgress = false;
|
|
});
|
|
}
|
|
|
|
checkAgent() {
|
|
const applicationState = this.StateManager.getState();
|
|
return applicationState.endpoint.mode.agentProxy;
|
|
}
|
|
|
|
$onInit() {
|
|
const securitySettings = this.endpoint.SecuritySettings;
|
|
|
|
const isAgent = this.checkAgent();
|
|
this.isAgent = isAgent;
|
|
|
|
this.formValues = {
|
|
enableHostManagementFeatures: isAgent && securitySettings.enableHostManagementFeatures,
|
|
allowVolumeBrowserForRegularUsers: isAgent && securitySettings.allowVolumeBrowserForRegularUsers,
|
|
disableBindMountsForRegularUsers: !securitySettings.allowBindMountsForRegularUsers,
|
|
disablePrivilegedModeForRegularUsers: !securitySettings.allowPrivilegedModeForRegularUsers,
|
|
disableHostNamespaceForRegularUsers: !securitySettings.allowHostNamespaceForRegularUsers,
|
|
disableDeviceMappingForRegularUsers: !securitySettings.allowDeviceMappingForRegularUsers,
|
|
disableStackManagementForRegularUsers: !securitySettings.allowStackManagementForRegularUsers,
|
|
disableContainerCapabilitiesForRegularUsers: !securitySettings.allowContainerCapabilitiesForRegularUsers,
|
|
};
|
|
}
|
|
}
|