71 lines
2 KiB
Ruby
71 lines
2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Projects::StaticSiteEditorController < Projects::ApplicationController
|
|
include ExtractsPath
|
|
include CreatesCommit
|
|
|
|
layout 'fullscreen'
|
|
|
|
content_security_policy do |policy|
|
|
next if policy.directives.blank?
|
|
|
|
frame_src_values = Array.wrap(policy.directives['frame-src']) | ['https://www.youtube.com']
|
|
policy.frame_src(*frame_src_values)
|
|
end
|
|
|
|
prepend_before_action :authenticate_user!, only: [:show]
|
|
before_action :assign_ref_and_path, only: [:show]
|
|
before_action :authorize_edit_tree!, only: [:show]
|
|
|
|
feature_category :static_site_editor
|
|
|
|
def index
|
|
render_404
|
|
end
|
|
|
|
def show
|
|
service_response = ::StaticSiteEditor::ConfigService.new(
|
|
container: project,
|
|
current_user: current_user,
|
|
params: {
|
|
ref: @ref,
|
|
path: @path,
|
|
return_url: params[:return_url]
|
|
}
|
|
).execute
|
|
|
|
if service_response.success?
|
|
Gitlab::UsageDataCounters::StaticSiteEditorCounter.increment_views_count
|
|
|
|
@data = serialize_necessary_payload_values_to_json(service_response.payload)
|
|
else
|
|
# TODO: For now, if the service returns any error, the user is redirected
|
|
# to the root project page with the error message displayed as an alert.
|
|
# See https://gitlab.com/gitlab-org/gitlab/-/issues/213285#note_414808004
|
|
# for discussion of plans to handle this via a page owned by the Static Site Editor.
|
|
flash[:alert] = service_response.message
|
|
redirect_to project_path(project)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def serialize_necessary_payload_values_to_json(payload)
|
|
# This will convert booleans, Array-like and Hash-like objects to JSON
|
|
payload.transform_values do |value|
|
|
if value.is_a?(String) || value.is_a?(Integer)
|
|
value
|
|
elsif value.nil?
|
|
''
|
|
else
|
|
value.to_json
|
|
end
|
|
end
|
|
end
|
|
|
|
def assign_ref_and_path
|
|
@ref, @path = extract_ref(params.fetch(:id))
|
|
|
|
render_404 if @ref.blank? || @path.blank?
|
|
end
|
|
end
|