summaryrefslogtreecommitdiff
path: root/lib/api/project_snippets.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-01-17 00:09:00 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-01-17 00:09:00 +0000
commitefb0c7f501e4a8883796b5acfdc584e2720febba (patch)
treea5870a33d1154a555a46b293aac42dbb4197b31d /lib/api/project_snippets.rb
parent727b1a890c8e44440414c59611e9ead34d6edc93 (diff)
downloadgitlab-ce-efb0c7f501e4a8883796b5acfdc584e2720febba.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/api/project_snippets.rb')
-rw-r--r--lib/api/project_snippets.rb16
1 files changed, 12 insertions, 4 deletions
diff --git a/lib/api/project_snippets.rb b/lib/api/project_snippets.rb
index b4545295d54..ecada843972 100644
--- a/lib/api/project_snippets.rb
+++ b/lib/api/project_snippets.rb
@@ -64,7 +64,8 @@ module API
snippet_params = declared_params(include_missing: false).merge(request: request, api: true)
snippet_params[:content] = snippet_params.delete(:code) if snippet_params[:code].present?
- snippet = CreateSnippetService.new(user_project, current_user, snippet_params).execute
+ service_response = ::Snippets::CreateService.new(user_project, current_user, snippet_params).execute
+ snippet = service_response.payload[:snippet]
render_spam_error! if snippet.spam?
@@ -103,8 +104,8 @@ module API
snippet_params[:content] = snippet_params.delete(:code) if snippet_params[:code].present?
- UpdateSnippetService.new(user_project, current_user, snippet,
- snippet_params).execute
+ service_response = ::Snippets::UpdateService.new(user_project, current_user, snippet_params).execute(snippet)
+ snippet = service_response.payload[:snippet]
render_spam_error! if snippet.spam?
@@ -127,7 +128,14 @@ module API
authorize! :admin_project_snippet, snippet
- destroy_conditionally!(snippet)
+ destroy_conditionally!(snippet) do |snippet|
+ service = ::Snippets::DestroyService.new(current_user, snippet)
+ response = service.execute
+
+ if response.error?
+ render_api_error!({ error: response.message }, response.http_status)
+ end
+ end
end
# rubocop: enable CodeReuse/ActiveRecord