To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / .svn / pristine / 01 / 01df356dd5562f68f76338bddccfd73e2d039ee5.svn-base @ 1298:4f746d8966dd

History | View | Annotate | Download (4.08 KB)

1
# Redmine - project management software
2
# Copyright (C) 2006-2012  Jean-Philippe Lang
3
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8
#
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17

    
18
module Redmine
19
  module Acts
20
    module Attachable
21
      def self.included(base)
22
        base.extend ClassMethods
23
      end
24

    
25
      module ClassMethods
26
        def acts_as_attachable(options = {})
27
          cattr_accessor :attachable_options
28
          self.attachable_options = {}
29
          attachable_options[:view_permission] = options.delete(:view_permission) || "view_#{self.name.pluralize.underscore}".to_sym
30
          attachable_options[:delete_permission] = options.delete(:delete_permission) || "edit_#{self.name.pluralize.underscore}".to_sym
31

    
32
          has_many :attachments, options.merge(:as => :container,
33
                                               :order => "#{Attachment.table_name}.created_on ASC, #{Attachment.table_name}.id ASC",
34
                                               :dependent => :destroy)
35
          send :include, Redmine::Acts::Attachable::InstanceMethods
36
          before_save :attach_saved_attachments
37
        end
38
      end
39

    
40
      module InstanceMethods
41
        def self.included(base)
42
          base.extend ClassMethods
43
        end
44

    
45
        def attachments_visible?(user=User.current)
46
          (respond_to?(:visible?) ? visible?(user) : true) &&
47
            user.allowed_to?(self.class.attachable_options[:view_permission], self.project)
48
        end
49

    
50
        def attachments_deletable?(user=User.current)
51
          (respond_to?(:visible?) ? visible?(user) : true) &&
52
            user.allowed_to?(self.class.attachable_options[:delete_permission], self.project)
53
        end
54

    
55
        def saved_attachments
56
          @saved_attachments ||= []
57
        end
58

    
59
        def unsaved_attachments
60
          @unsaved_attachments ||= []
61
        end
62

    
63
        def save_attachments(attachments, author=User.current)
64
          if attachments.is_a?(Hash)
65
            attachments = attachments.stringify_keys
66
            attachments = attachments.to_a.sort {|a, b|
67
              if a.first.to_i > 0 && b.first.to_i > 0
68
                a.first.to_i <=> b.first.to_i
69
              elsif a.first.to_i > 0
70
                1
71
              elsif b.first.to_i > 0
72
                -1
73
              else
74
                a.first <=> b.first
75
              end
76
            }
77
            attachments = attachments.map(&:last)
78
          end
79
          if attachments.is_a?(Array)
80
            attachments.each do |attachment|
81
              a = nil
82
              if file = attachment['file']
83
                next unless file.size > 0
84
                a = Attachment.create(:file => file, :author => author)
85
              elsif token = attachment['token']
86
                a = Attachment.find_by_token(token)
87
                next unless a
88
                a.filename = attachment['filename'] unless attachment['filename'].blank?
89
                a.content_type = attachment['content_type']
90
              end
91
              next unless a
92
              a.description = attachment['description'].to_s.strip
93
              if a.new_record?
94
                unsaved_attachments << a
95
              else
96
                saved_attachments << a
97
              end
98
            end
99
          end
100
          {:files => saved_attachments, :unsaved => unsaved_attachments}
101
        end
102

    
103
        def attach_saved_attachments
104
          saved_attachments.each do |attachment|
105
            self.attachments << attachment
106
          end
107
        end
108

    
109
        module ClassMethods
110
        end
111
      end
112
    end
113
  end
114
end