2013-06-06 05:37:51 -04:00
|
|
|
module API
|
|
|
|
class ProjectSnippets < Grape::API
|
2016-12-04 12:11:19 -05:00
|
|
|
include PaginationParams
|
|
|
|
|
2013-06-06 05:37:51 -04:00
|
|
|
before { authenticate! }
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
params do
|
|
|
|
requires :id, type: String, desc: 'The ID of a project'
|
|
|
|
end
|
2017-08-31 07:44:49 -04:00
|
|
|
resource :projects, requirements: API::PROJECT_ENDPOINT_REQUIREMENTS do
|
2013-06-06 05:37:51 -04:00
|
|
|
helpers do
|
|
|
|
def handle_project_member_errors(errors)
|
|
|
|
if errors[:project_access].any?
|
|
|
|
error!(errors[:project_access], 422)
|
|
|
|
end
|
2018-01-11 11:34:01 -05:00
|
|
|
|
2013-06-06 05:37:51 -04:00
|
|
|
not_found!
|
|
|
|
end
|
2016-04-25 00:45:26 -04:00
|
|
|
|
|
|
|
def snippets_for_current_user
|
2017-04-28 18:06:27 -04:00
|
|
|
SnippetsFinder.new(current_user, project: user_project).execute
|
2016-04-25 00:45:26 -04:00
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
desc 'Get all project snippets' do
|
|
|
|
success Entities::ProjectSnippet
|
|
|
|
end
|
2016-12-04 12:11:19 -05:00
|
|
|
params do
|
|
|
|
use :pagination
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
get ":id/snippets" do
|
2016-04-25 00:45:26 -04:00
|
|
|
present paginate(snippets_for_current_user), with: Entities::ProjectSnippet
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
desc 'Get a single project snippet' do
|
|
|
|
success Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
params do
|
|
|
|
requires :snippet_id, type: Integer, desc: 'The ID of a project snippet'
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
get ":id/snippets/:snippet_id" do
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet = snippets_for_current_user.find(params[:snippet_id])
|
|
|
|
present snippet, with: Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Create a new project snippet' do
|
|
|
|
success Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
params do
|
|
|
|
requires :title, type: String, desc: 'The title of the snippet'
|
|
|
|
requires :file_name, type: String, desc: 'The file name of the snippet'
|
|
|
|
requires :code, type: String, desc: 'The content of the snippet'
|
2017-05-03 11:26:49 -04:00
|
|
|
optional :description, type: String, desc: 'The description of a snippet'
|
2017-03-01 10:16:29 -05:00
|
|
|
requires :visibility, type: String,
|
|
|
|
values: Gitlab::VisibilityLevel.string_values,
|
|
|
|
desc: 'The visibility of the snippet'
|
2016-11-21 09:06:32 -05:00
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
post ":id/snippets" do
|
2015-06-26 09:55:56 -04:00
|
|
|
authorize! :create_project_snippet, user_project
|
2017-03-01 15:23:00 -05:00
|
|
|
snippet_params = declared_params.merge(request: request, api: true)
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet_params[:content] = snippet_params.delete(:code)
|
2013-06-06 05:37:51 -04:00
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet = CreateSnippetService.new(user_project, current_user, snippet_params).execute
|
2013-06-06 05:37:51 -04:00
|
|
|
|
2017-02-14 14:07:11 -05:00
|
|
|
render_spam_error! if snippet.spam?
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
if snippet.persisted?
|
|
|
|
present snippet, with: Entities::ProjectSnippet
|
2015-03-10 20:21:09 -04:00
|
|
|
else
|
2016-11-21 09:06:32 -05:00
|
|
|
render_validation_error!(snippet)
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
desc 'Update an existing project snippet' do
|
|
|
|
success Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
params do
|
|
|
|
requires :snippet_id, type: Integer, desc: 'The ID of a project snippet'
|
|
|
|
optional :title, type: String, desc: 'The title of the snippet'
|
|
|
|
optional :file_name, type: String, desc: 'The file name of the snippet'
|
|
|
|
optional :code, type: String, desc: 'The content of the snippet'
|
2017-05-03 11:26:49 -04:00
|
|
|
optional :description, type: String, desc: 'The description of a snippet'
|
2017-03-01 10:16:29 -05:00
|
|
|
optional :visibility, type: String,
|
|
|
|
values: Gitlab::VisibilityLevel.string_values,
|
|
|
|
desc: 'The visibility of the snippet'
|
2016-11-21 09:06:32 -05:00
|
|
|
at_least_one_of :title, :file_name, :code, :visibility_level
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
put ":id/snippets/:snippet_id" do
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet = snippets_for_current_user.find_by(id: params.delete(:snippet_id))
|
|
|
|
not_found!('Snippet') unless snippet
|
|
|
|
|
|
|
|
authorize! :update_project_snippet, snippet
|
|
|
|
|
2017-03-01 15:23:00 -05:00
|
|
|
snippet_params = declared_params(include_missing: false)
|
2017-02-14 14:07:11 -05:00
|
|
|
.merge(request: request, api: true)
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet_params[:content] = snippet_params.delete(:code) if snippet_params[:code].present?
|
2013-06-06 05:37:51 -04:00
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
UpdateSnippetService.new(user_project, current_user, snippet,
|
|
|
|
snippet_params).execute
|
2013-06-06 05:37:51 -04:00
|
|
|
|
2017-02-14 14:07:11 -05:00
|
|
|
render_spam_error! if snippet.spam?
|
|
|
|
|
|
|
|
if snippet.valid?
|
2016-11-21 09:06:32 -05:00
|
|
|
present snippet, with: Entities::ProjectSnippet
|
2015-03-07 14:47:06 -05:00
|
|
|
else
|
2016-11-21 09:06:32 -05:00
|
|
|
render_validation_error!(snippet)
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
desc 'Delete a project snippet'
|
|
|
|
params do
|
|
|
|
requires :snippet_id, type: Integer, desc: 'The ID of a project snippet'
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
delete ":id/snippets/:snippet_id" do
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet = snippets_for_current_user.find_by(id: params[:snippet_id])
|
|
|
|
not_found!('Snippet') unless snippet
|
|
|
|
|
|
|
|
authorize! :admin_project_snippet, snippet
|
2017-03-01 08:35:48 -05:00
|
|
|
|
2017-03-02 07:14:13 -05:00
|
|
|
destroy_conditionally!(snippet)
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
|
2016-11-21 09:06:32 -05:00
|
|
|
desc 'Get a raw project snippet'
|
|
|
|
params do
|
|
|
|
requires :snippet_id, type: Integer, desc: 'The ID of a project snippet'
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
get ":id/snippets/:snippet_id/raw" do
|
2016-11-21 09:06:32 -05:00
|
|
|
snippet = snippets_for_current_user.find_by(id: params[:snippet_id])
|
|
|
|
not_found!('Snippet') unless snippet
|
2013-06-06 09:10:24 -04:00
|
|
|
|
|
|
|
env['api.format'] = :txt
|
2013-06-06 05:37:51 -04:00
|
|
|
content_type 'text/plain'
|
2016-11-21 09:06:32 -05:00
|
|
|
present snippet.content
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
2017-07-07 09:54:39 -04:00
|
|
|
|
|
|
|
desc 'Get the user agent details for a project snippet' do
|
|
|
|
success Entities::UserAgentDetail
|
|
|
|
end
|
|
|
|
params do
|
|
|
|
requires :snippet_id, type: Integer, desc: 'The ID of a project snippet'
|
|
|
|
end
|
|
|
|
get ":id/snippets/:snippet_id/user_agent_detail" do
|
|
|
|
authenticated_as_admin!
|
|
|
|
|
2018-01-17 09:30:07 -05:00
|
|
|
snippet = Snippet.find_by!(id: params[:snippet_id], project_id: params[:id])
|
2017-07-07 09:54:39 -04:00
|
|
|
|
|
|
|
return not_found!('UserAgentDetail') unless snippet.user_agent_detail
|
|
|
|
|
|
|
|
present snippet.user_agent_detail, with: Entities::UserAgentDetail
|
|
|
|
end
|
2013-06-06 05:37:51 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|