Merge pull request #1552 from opf/feature/api-create-attachments-show-endpoint
Feature/api create attachments show endpointpull/1554/head
commit
db3f016a81
@ -0,0 +1,47 @@ |
||||
#-- encoding: UTF-8 |
||||
#-- copyright |
||||
# OpenProject is a project management system. |
||||
# Copyright (C) 2012-2014 the OpenProject Foundation (OPF) |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License version 3. |
||||
# |
||||
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: |
||||
# Copyright (C) 2006-2013 Jean-Philippe Lang |
||||
# Copyright (C) 2010-2013 the ChiliProject Team |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License |
||||
# as published by the Free Software Foundation; either version 2 |
||||
# of the License, or (at your option) any later version. |
||||
# |
||||
# This program is distributed in the hope that it will be useful, |
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
# GNU General Public License for more details. |
||||
# |
||||
# You should have received a copy of the GNU General Public License |
||||
# along with this program; if not, write to the Free Software |
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
||||
# |
||||
# See doc/COPYRIGHT.rdoc for more details. |
||||
#++ |
||||
|
||||
require 'reform' |
||||
require 'reform/form/coercion' |
||||
|
||||
module API |
||||
module V3 |
||||
module Attachments |
||||
class AttachmentModel < Reform::Form |
||||
include Coercion |
||||
|
||||
property :filename, type: String |
||||
property :disk_filename, type: String |
||||
property :description, type: String |
||||
property :content_type, type: String |
||||
property :digest, type: String |
||||
end |
||||
end |
||||
end |
||||
end |
@ -0,0 +1,75 @@ |
||||
#-- encoding: UTF-8 |
||||
#-- copyright |
||||
# OpenProject is a project management system. |
||||
# Copyright (C) 2012-2014 the OpenProject Foundation (OPF) |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License version 3. |
||||
# |
||||
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: |
||||
# Copyright (C) 2006-2013 Jean-Philippe Lang |
||||
# Copyright (C) 2010-2013 the ChiliProject Team |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License |
||||
# as published by the Free Software Foundation; either version 2 |
||||
# of the License, or (at your option) any later version. |
||||
# |
||||
# This program is distributed in the hope that it will be useful, |
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
# GNU General Public License for more details. |
||||
# |
||||
# You should have received a copy of the GNU General Public License |
||||
# along with this program; if not, write to the Free Software |
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
||||
# |
||||
# See doc/COPYRIGHT.rdoc for more details. |
||||
#++ |
||||
|
||||
require 'roar/decorator' |
||||
require 'roar/representer/json/hal' |
||||
|
||||
module API |
||||
module V3 |
||||
module Attachments |
||||
class AttachmentRepresenter < Roar::Decorator |
||||
include Roar::Representer::JSON::HAL |
||||
include Roar::Representer::Feature::Hypermedia |
||||
include OpenProject::StaticRouting::UrlHelpers |
||||
|
||||
self.as_strategy = API::Utilities::CamelCasingStrategy.new |
||||
|
||||
property :_type, exec_context: :decorator |
||||
|
||||
link :self do |
||||
{ href: "#{root_url}api/v3/attachments/#{represented.model.id}", title: "#{represented.model.filename}" } |
||||
end |
||||
|
||||
link :work_package do |
||||
work_package = represented.model.container |
||||
{ href: "#{root_url}api/v3/work_packages/#{work_package.id}", title: "#{work_package.subject}" } unless work_package.nil? |
||||
end |
||||
|
||||
link :author do |
||||
author = represented.model.author |
||||
{ href: "#{root_url}api/v3/users/#{author.id}", title: "#{author.name} - #{author.login}" } unless author.nil? |
||||
end |
||||
|
||||
property :id, getter: -> (*) { model.id }, render_nil: true |
||||
property :filename, as: :fileName, render_nil: true |
||||
property :disk_filename, as: :diskFileName, render_nil: true |
||||
property :description, render_nil: true |
||||
property :file_size, getter: -> (*) { model.filesize }, render_nil: true |
||||
property :content_type, getter: -> (*) { model.content_type }, render_nil: true |
||||
property :digest, render_nil: true |
||||
property :downloads, getter: -> (*) { model.downloads }, render_nil: true |
||||
property :created_at, getter: -> (*) { model.created_on.utc.iso8601 }, render_nil: true |
||||
|
||||
def _type |
||||
'Attachment' |
||||
end |
||||
end |
||||
end |
||||
end |
||||
end |
@ -0,0 +1,30 @@ |
||||
module API |
||||
module V3 |
||||
module Attachments |
||||
class AttachmentsAPI < Grape::API |
||||
|
||||
resources :attachments do |
||||
|
||||
params do |
||||
requires :id, desc: 'Attachment id' |
||||
end |
||||
namespace ':id' do |
||||
|
||||
before do |
||||
@attachment = Attachment.find(params[:id]) |
||||
model = ::API::V3::Attachments::AttachmentModel.new(@attachment) |
||||
@representer = ::API::V3::Attachments::AttachmentRepresenter.new(model) |
||||
end |
||||
|
||||
get do |
||||
@representer.to_json |
||||
end |
||||
|
||||
end |
||||
|
||||
end |
||||
|
||||
end |
||||
end |
||||
end |
||||
end |
@ -0,0 +1,70 @@ |
||||
#-- copyright |
||||
# OpenProject is a project management system. |
||||
# Copyright (C) 2012-2014 the OpenProject Foundation (OPF) |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License version 3. |
||||
# |
||||
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: |
||||
# Copyright (C) 2006-2013 Jean-Philippe Lang |
||||
# Copyright (C) 2010-2013 the ChiliProject Team |
||||
# |
||||
# This program is free software; you can redistribute it and/or |
||||
# modify it under the terms of the GNU General Public License |
||||
# as published by the Free Software Foundation; either version 2 |
||||
# of the License, or (at your option) any later version. |
||||
# |
||||
# This program is distributed in the hope that it will be useful, |
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
# GNU General Public License for more details. |
||||
# |
||||
# You should have received a copy of the GNU General Public License |
||||
# along with this program; if not, write to the Free Software |
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
||||
# |
||||
# See doc/COPYRIGHT.rdoc for more details. |
||||
#++ |
||||
|
||||
require 'spec_helper' |
||||
|
||||
describe ::API::V3::Attachments::AttachmentRepresenter do |
||||
let(:attachment) { FactoryGirl.create(:attachment) } |
||||
let(:model) { ::API::V3::Attachments::AttachmentModel.new(attachment) } |
||||
let(:representer) { ::API::V3::Attachments::AttachmentRepresenter.new(model) } |
||||
|
||||
context 'generation' do |
||||
subject(:generated) { representer.to_json } |
||||
|
||||
it { should include_json('Attachment'.to_json).at_path('_type') } |
||||
|
||||
describe 'attachment' do |
||||
it { should have_json_path('id') } |
||||
it { should have_json_path('fileName') } |
||||
it { should have_json_path('diskFileName') } |
||||
it { should have_json_path('description') } |
||||
it { should have_json_path('fileSize') } |
||||
it { should have_json_path('contentType') } |
||||
it { should have_json_path('digest') } |
||||
it { should have_json_path('downloads') } |
||||
it { should have_json_path('createdAt') } |
||||
end |
||||
|
||||
describe '_links' do |
||||
it { should have_json_type(Object).at_path('_links') } |
||||
|
||||
it 'should link to self' do |
||||
expect(subject).to have_json_path('_links/self/href') |
||||
end |
||||
|
||||
it 'should link to a work package' do |
||||
expect(subject).to have_json_path('_links/work_package/href') |
||||
end |
||||
|
||||
it 'should link to an author' do |
||||
expect(subject).to have_json_path('_links/author/href') |
||||
end |
||||
end |
||||
|
||||
end |
||||
end |
Loading…
Reference in new issue