85609c117e
Add env_var and file as supported types for CI variables. Variables of type file expose to users existing gitlab-runner behaviour - save variable value into a temp file and set the path to this file in an ENV var named after the variable key. Resolves https://gitlab.com/gitlab-org/gitlab-ce/issues/46806.
51 lines
1.2 KiB
Ruby
51 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Groups
|
|
class VariablesController < Groups::ApplicationController
|
|
before_action :authorize_admin_build!
|
|
|
|
skip_cross_project_access_check :show, :update
|
|
|
|
def show
|
|
respond_to do |format|
|
|
format.json do
|
|
render status: :ok, json: { variables: GroupVariableSerializer.new.represent(@group.variables) }
|
|
end
|
|
end
|
|
end
|
|
|
|
def update
|
|
if @group.update(group_variables_params)
|
|
respond_to do |format|
|
|
format.json { render_group_variables }
|
|
end
|
|
else
|
|
respond_to do |format|
|
|
format.json { render_error }
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def render_group_variables
|
|
render status: :ok, json: { variables: GroupVariableSerializer.new.represent(@group.variables) }
|
|
end
|
|
|
|
def render_error
|
|
render status: :bad_request, json: @group.errors.full_messages
|
|
end
|
|
|
|
def group_variables_params
|
|
params.permit(variables_attributes: [*variable_params_attributes])
|
|
end
|
|
|
|
def variable_params_attributes
|
|
%i[id variable_type key secret_value protected masked _destroy]
|
|
end
|
|
|
|
def authorize_admin_build!
|
|
return render_404 unless can?(current_user, :admin_build, group)
|
|
end
|
|
end
|
|
end
|