2021-02-09 08:09:06 +00:00
|
|
|
package endpoints
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
httperror "github.com/portainer/libhttp/error"
|
|
|
|
"github.com/portainer/libhttp/request"
|
|
|
|
"github.com/portainer/libhttp/response"
|
|
|
|
portainer "github.com/portainer/portainer/api"
|
|
|
|
"github.com/portainer/portainer/api/bolt/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
type endpointSettingsUpdatePayload struct {
|
2021-02-23 03:21:39 +00:00
|
|
|
// Whether non-administrator should be able to use bind mounts when creating containers
|
|
|
|
AllowBindMountsForRegularUsers *bool `json:"allowBindMountsForRegularUsers" example:"false"`
|
|
|
|
// Whether non-administrator should be able to use privileged mode when creating containers
|
|
|
|
AllowPrivilegedModeForRegularUsers *bool `json:"allowPrivilegedModeForRegularUsers" example:"false"`
|
|
|
|
// Whether non-administrator should be able to browse volumes
|
|
|
|
AllowVolumeBrowserForRegularUsers *bool `json:"allowVolumeBrowserForRegularUsers" example:"true"`
|
|
|
|
// Whether non-administrator should be able to use the host pid
|
|
|
|
AllowHostNamespaceForRegularUsers *bool `json:"allowHostNamespaceForRegularUsers" example:"true"`
|
|
|
|
// Whether non-administrator should be able to use device mapping
|
|
|
|
AllowDeviceMappingForRegularUsers *bool `json:"allowDeviceMappingForRegularUsers" example:"true"`
|
|
|
|
// Whether non-administrator should be able to manage stacks
|
|
|
|
AllowStackManagementForRegularUsers *bool `json:"allowStackManagementForRegularUsers" example:"true"`
|
|
|
|
// Whether non-administrator should be able to use container capabilities
|
|
|
|
AllowContainerCapabilitiesForRegularUsers *bool `json:"allowContainerCapabilitiesForRegularUsers" example:"true"`
|
2021-04-12 07:40:45 +00:00
|
|
|
// Whether non-administrator should be able to use sysctl settings
|
|
|
|
AllowSysctlSettingForRegularUsers *bool `json:"allowSysctlSettingForRegularUsers" example:"true"`
|
2021-02-23 03:21:39 +00:00
|
|
|
// Whether host management features are enabled
|
|
|
|
EnableHostManagementFeatures *bool `json:"enableHostManagementFeatures" example:"true"`
|
2021-02-09 08:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (payload *endpointSettingsUpdatePayload) Validate(r *http.Request) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-02-23 03:21:39 +00:00
|
|
|
// @id EndpointSettingsUpdate
|
2021-10-11 23:12:08 +00:00
|
|
|
// @summary Update settings for an environment(endpoint)
|
|
|
|
// @description Update settings for an environment(endpoint).
|
|
|
|
// @description **Access policy**: authenticated
|
2021-11-30 02:31:16 +00:00
|
|
|
// @security ApiKeyAuth
|
2021-02-23 03:21:39 +00:00
|
|
|
// @security jwt
|
|
|
|
// @tags endpoints
|
|
|
|
// @accept json
|
|
|
|
// @produce json
|
2021-09-20 00:14:22 +00:00
|
|
|
// @param id path int true "Environment(Endpoint) identifier"
|
|
|
|
// @param body body endpointSettingsUpdatePayload true "Environment(Endpoint) details"
|
2021-02-23 03:21:39 +00:00
|
|
|
// @success 200 {object} portainer.Endpoint "Success"
|
|
|
|
// @failure 400 "Invalid request"
|
2021-09-20 00:14:22 +00:00
|
|
|
// @failure 404 "Environment(Endpoint) not found"
|
2021-02-23 03:21:39 +00:00
|
|
|
// @failure 500 "Server error"
|
2021-10-11 23:12:08 +00:00
|
|
|
// @router /endpoints/{id}/settings [put]
|
2021-02-09 08:09:06 +00:00
|
|
|
func (handler *Handler) endpointSettingsUpdate(w http.ResponseWriter, r *http.Request) *httperror.HandlerError {
|
|
|
|
endpointID, err := request.RetrieveNumericRouteVariableValue(r, "id")
|
|
|
|
if err != nil {
|
2021-09-08 08:42:17 +00:00
|
|
|
return &httperror.HandlerError{http.StatusBadRequest, "Invalid environment identifier route variable", err}
|
2021-02-09 08:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var payload endpointSettingsUpdatePayload
|
|
|
|
err = request.DecodeAndValidateJSONPayload(r, &payload)
|
|
|
|
if err != nil {
|
|
|
|
return &httperror.HandlerError{http.StatusBadRequest, "Invalid request payload", err}
|
|
|
|
}
|
|
|
|
|
|
|
|
endpoint, err := handler.DataStore.Endpoint().Endpoint(portainer.EndpointID(endpointID))
|
|
|
|
if err == errors.ErrObjectNotFound {
|
2021-09-08 08:42:17 +00:00
|
|
|
return &httperror.HandlerError{http.StatusNotFound, "Unable to find an environment with the specified identifier inside the database", err}
|
2021-02-09 08:09:06 +00:00
|
|
|
} else if err != nil {
|
2021-09-08 08:42:17 +00:00
|
|
|
return &httperror.HandlerError{http.StatusInternalServerError, "Unable to find an environment with the specified identifier inside the database", err}
|
2021-02-09 08:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
securitySettings := endpoint.SecuritySettings
|
|
|
|
|
|
|
|
if payload.AllowBindMountsForRegularUsers != nil {
|
|
|
|
securitySettings.AllowBindMountsForRegularUsers = *payload.AllowBindMountsForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowContainerCapabilitiesForRegularUsers != nil {
|
|
|
|
securitySettings.AllowContainerCapabilitiesForRegularUsers = *payload.AllowContainerCapabilitiesForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowDeviceMappingForRegularUsers != nil {
|
|
|
|
securitySettings.AllowDeviceMappingForRegularUsers = *payload.AllowDeviceMappingForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowHostNamespaceForRegularUsers != nil {
|
|
|
|
securitySettings.AllowHostNamespaceForRegularUsers = *payload.AllowHostNamespaceForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowPrivilegedModeForRegularUsers != nil {
|
|
|
|
securitySettings.AllowPrivilegedModeForRegularUsers = *payload.AllowPrivilegedModeForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowStackManagementForRegularUsers != nil {
|
|
|
|
securitySettings.AllowStackManagementForRegularUsers = *payload.AllowStackManagementForRegularUsers
|
|
|
|
}
|
|
|
|
|
|
|
|
if payload.AllowVolumeBrowserForRegularUsers != nil {
|
|
|
|
securitySettings.AllowVolumeBrowserForRegularUsers = *payload.AllowVolumeBrowserForRegularUsers
|
|
|
|
}
|
|
|
|
|
2021-04-12 07:40:45 +00:00
|
|
|
if payload.AllowSysctlSettingForRegularUsers != nil {
|
|
|
|
securitySettings.AllowSysctlSettingForRegularUsers = *payload.AllowSysctlSettingForRegularUsers
|
|
|
|
}
|
|
|
|
|
2021-02-09 08:09:06 +00:00
|
|
|
if payload.EnableHostManagementFeatures != nil {
|
|
|
|
securitySettings.EnableHostManagementFeatures = *payload.EnableHostManagementFeatures
|
|
|
|
}
|
|
|
|
|
|
|
|
endpoint.SecuritySettings = securitySettings
|
|
|
|
|
|
|
|
err = handler.DataStore.Endpoint().UpdateEndpoint(portainer.EndpointID(endpointID), endpoint)
|
|
|
|
if err != nil {
|
2021-09-08 08:42:17 +00:00
|
|
|
return &httperror.HandlerError{http.StatusInternalServerError, "Failed persisting environment in database", err}
|
2021-02-09 08:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return response.JSON(w, endpoint)
|
|
|
|
}
|