2013-06-06 05:37:51 -04:00
|
|
|
module API
|
|
|
|
# Projects API
|
|
|
|
class ProjectSnippets < Grape::API
|
|
|
|
before { authenticate! }
|
|
|
|
|
|
|
|
resource :projects do
|
|
|
|
helpers do
|
|
|
|
def handle_project_member_errors(errors)
|
|
|
|
if errors[:project_access].any?
|
|
|
|
error!(errors[:project_access], 422)
|
|
|
|
end
|
|
|
|
not_found!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Get a project snippets
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# Example Request:
|
|
|
|
# GET /projects/:id/snippets
|
|
|
|
get ":id/snippets" do
|
|
|
|
present paginate(user_project.snippets), with: Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
|
|
|
|
# Get a project snippet
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# snippet_id (required) - The ID of a project snippet
|
|
|
|
# Example Request:
|
|
|
|
# GET /projects/:id/snippets/:snippet_id
|
|
|
|
get ":id/snippets/:snippet_id" do
|
|
|
|
@snippet = user_project.snippets.find(params[:snippet_id])
|
|
|
|
present @snippet, with: Entities::ProjectSnippet
|
|
|
|
end
|
|
|
|
|
|
|
|
# Create a new project snippet
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# title (required) - The title of a snippet
|
|
|
|
# file_name (required) - The name of a snippet file
|
|
|
|
# lifetime (optional) - The expiration date of a snippet
|
|
|
|
# code (required) - The content of a snippet
|
|
|
|
# Example Request:
|
|
|
|
# POST /projects/:id/snippets
|
|
|
|
post ":id/snippets" do
|
|
|
|
authorize! :write_project_snippet, user_project
|
|
|
|
required_attributes! [:title, :file_name, :code]
|
|
|
|
|
|
|
|
attrs = attributes_for_keys [:title, :file_name]
|
|
|
|
attrs[:expires_at] = params[:lifetime] if params[:lifetime].present?
|
|
|
|
attrs[:content] = params[:code] if params[:code].present?
|
|
|
|
@snippet = user_project.snippets.new attrs
|
|
|
|
@snippet.author = current_user
|
|
|
|
|
|
|
|
if @snippet.save
|
|
|
|
present @snippet, with: Entities::ProjectSnippet
|
|
|
|
else
|
|
|
|
not_found!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update an existing project snippet
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# snippet_id (required) - The ID of a project snippet
|
|
|
|
# title (optional) - The title of a snippet
|
|
|
|
# file_name (optional) - The name of a snippet file
|
|
|
|
# lifetime (optional) - The expiration date of a snippet
|
|
|
|
# code (optional) - The content of a snippet
|
|
|
|
# Example Request:
|
|
|
|
# PUT /projects/:id/snippets/:snippet_id
|
|
|
|
put ":id/snippets/:snippet_id" do
|
|
|
|
@snippet = user_project.snippets.find(params[:snippet_id])
|
|
|
|
authorize! :modify_project_snippet, @snippet
|
|
|
|
|
|
|
|
attrs = attributes_for_keys [:title, :file_name]
|
|
|
|
attrs[:expires_at] = params[:lifetime] if params[:lifetime].present?
|
|
|
|
attrs[:content] = params[:code] if params[:code].present?
|
|
|
|
|
|
|
|
if @snippet.update_attributes attrs
|
|
|
|
present @snippet, with: Entities::ProjectSnippet
|
|
|
|
else
|
|
|
|
not_found!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Delete a project snippet
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# snippet_id (required) - The ID of a project snippet
|
|
|
|
# Example Request:
|
|
|
|
# DELETE /projects/:id/snippets/:snippet_id
|
|
|
|
delete ":id/snippets/:snippet_id" do
|
|
|
|
begin
|
|
|
|
@snippet = user_project.snippets.find(params[:snippet_id])
|
|
|
|
authorize! :modify_project_snippet, @snippet
|
|
|
|
@snippet.destroy
|
|
|
|
rescue
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Get a raw project snippet
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a project
|
|
|
|
# snippet_id (required) - The ID of a project snippet
|
|
|
|
# Example Request:
|
|
|
|
# GET /projects/:id/snippets/:snippet_id/raw
|
|
|
|
get ":id/snippets/:snippet_id/raw" do
|
|
|
|
@snippet = user_project.snippets.find(params[:snippet_id])
|
2013-06-06 09:10:24 -04:00
|
|
|
|
|
|
|
env['api.format'] = :txt
|
2013-06-06 05:37:51 -04:00
|
|
|
content_type 'text/plain'
|
|
|
|
present @snippet.content
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|