annotate app/models/wiki_content.rb @ 1296:038ba2d95de8 redmine-2.2

Fix redmine-2.2 branch update (add missing svn files)
author Chris Cannam
date Fri, 14 Jun 2013 09:05:06 +0100
parents 433d4f72a19b
children 622f24f53b42 261b3d9a4903
rev   line source
Chris@1115 1 # Redmine - project management software
Chris@1115 2 # Copyright (C) 2006-2012 Jean-Philippe Lang
Chris@0 3 #
Chris@0 4 # This program is free software; you can redistribute it and/or
Chris@0 5 # modify it under the terms of the GNU General Public License
Chris@0 6 # as published by the Free Software Foundation; either version 2
Chris@0 7 # of the License, or (at your option) any later version.
Chris@441 8 #
Chris@0 9 # This program is distributed in the hope that it will be useful,
Chris@0 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 12 # GNU General Public License for more details.
Chris@441 13 #
Chris@0 14 # You should have received a copy of the GNU General Public License
Chris@0 15 # along with this program; if not, write to the Free Software
Chris@0 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 17
Chris@0 18 require 'zlib'
Chris@0 19
Chris@0 20 class WikiContent < ActiveRecord::Base
Chris@1115 21 self.locking_column = 'version'
Chris@0 22 belongs_to :page, :class_name => 'WikiPage', :foreign_key => 'page_id'
Chris@0 23 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
Chris@0 24 validates_presence_of :text
Chris@0 25 validates_length_of :comments, :maximum => 255, :allow_nil => true
Chris@441 26
Chris@0 27 acts_as_versioned
Chris@441 28
Chris@0 29 def visible?(user=User.current)
Chris@0 30 page.visible?(user)
Chris@0 31 end
Chris@441 32
Chris@0 33 def project
Chris@0 34 page.project
Chris@0 35 end
Chris@441 36
Chris@0 37 def attachments
Chris@0 38 page.nil? ? [] : page.attachments
Chris@0 39 end
Chris@441 40
Chris@0 41 # Returns the mail adresses of users that should be notified
Chris@0 42 def recipients
Chris@0 43 notified = project.notified_users
Chris@0 44 notified.reject! {|user| !visible?(user)}
Chris@0 45 notified.collect(&:mail)
Chris@0 46 end
Chris@441 47
Chris@909 48 # Return true if the content is the current page content
Chris@909 49 def current_version?
Chris@909 50 true
Chris@909 51 end
Chris@909 52
Chris@0 53 class Version
Chris@0 54 belongs_to :page, :class_name => '::WikiPage', :foreign_key => 'page_id'
Chris@0 55 belongs_to :author, :class_name => '::User', :foreign_key => 'author_id'
Chris@0 56 attr_protected :data
Chris@0 57
Chris@0 58 acts_as_event :title => Proc.new {|o| "#{l(:label_wiki_edit)}: #{o.page.title} (##{o.version})"},
Chris@0 59 :description => :comments,
Chris@0 60 :datetime => :updated_on,
Chris@0 61 :type => 'wiki-page',
chris@37 62 :url => Proc.new {|o| {:controller => 'wiki', :action => 'show', :project_id => o.page.wiki.project, :id => o.page.title, :version => o.version}}
Chris@0 63
Chris@0 64 acts_as_activity_provider :type => 'wiki_edits',
Chris@0 65 :timestamp => "#{WikiContent.versioned_table_name}.updated_on",
Chris@0 66 :author_key => "#{WikiContent.versioned_table_name}.author_id",
Chris@0 67 :permission => :view_wiki_edits,
Chris@0 68 :find_options => {:select => "#{WikiContent.versioned_table_name}.updated_on, #{WikiContent.versioned_table_name}.comments, " +
Chris@0 69 "#{WikiContent.versioned_table_name}.#{WikiContent.version_column}, #{WikiPage.table_name}.title, " +
Chris@0 70 "#{WikiContent.versioned_table_name}.page_id, #{WikiContent.versioned_table_name}.author_id, " +
Chris@0 71 "#{WikiContent.versioned_table_name}.id",
Chris@0 72 :joins => "LEFT JOIN #{WikiPage.table_name} ON #{WikiPage.table_name}.id = #{WikiContent.versioned_table_name}.page_id " +
Chris@0 73 "LEFT JOIN #{Wiki.table_name} ON #{Wiki.table_name}.id = #{WikiPage.table_name}.wiki_id " +
Chris@0 74 "LEFT JOIN #{Project.table_name} ON #{Project.table_name}.id = #{Wiki.table_name}.project_id"}
Chris@0 75
Chris@1115 76 after_destroy :page_update_after_destroy
Chris@1115 77
Chris@0 78 def text=(plain)
Chris@0 79 case Setting.wiki_compression
Chris@0 80 when 'gzip'
Chris@0 81 begin
Chris@0 82 self.data = Zlib::Deflate.deflate(plain, Zlib::BEST_COMPRESSION)
Chris@0 83 self.compression = 'gzip'
Chris@0 84 rescue
Chris@0 85 self.data = plain
Chris@0 86 self.compression = ''
Chris@0 87 end
Chris@0 88 else
Chris@0 89 self.data = plain
Chris@0 90 self.compression = ''
Chris@0 91 end
Chris@0 92 plain
Chris@0 93 end
Chris@441 94
Chris@0 95 def text
Chris@1115 96 @text ||= begin
Chris@1115 97 str = case compression
Chris@1115 98 when 'gzip'
Chris@1115 99 Zlib::Inflate.inflate(data)
Chris@1115 100 else
Chris@1115 101 # uncompressed data
Chris@1115 102 data
Chris@1115 103 end
Chris@909 104 str.force_encoding("UTF-8") if str.respond_to?(:force_encoding)
Chris@909 105 str
Chris@441 106 end
Chris@0 107 end
Chris@441 108
Chris@0 109 def project
Chris@0 110 page.project
Chris@0 111 end
Chris@441 112
Chris@909 113 # Return true if the content is the current page content
Chris@909 114 def current_version?
Chris@909 115 page.content.version == self.version
Chris@909 116 end
Chris@909 117
Chris@0 118 # Returns the previous version or nil
Chris@0 119 def previous
Chris@1115 120 @previous ||= WikiContent::Version.
Chris@1115 121 reorder('version DESC').
Chris@1115 122 includes(:author).
Chris@1115 123 where("wiki_content_id = ? AND version < ?", wiki_content_id, version).first
Chris@1115 124 end
Chris@1115 125
Chris@1115 126 # Returns the next version or nil
Chris@1115 127 def next
Chris@1115 128 @next ||= WikiContent::Version.
Chris@1115 129 reorder('version ASC').
Chris@1115 130 includes(:author).
Chris@1115 131 where("wiki_content_id = ? AND version > ?", wiki_content_id, version).first
Chris@1115 132 end
Chris@1115 133
Chris@1115 134 private
Chris@1115 135
Chris@1115 136 # Updates page's content if the latest version is removed
Chris@1115 137 # or destroys the page if it was the only version
Chris@1115 138 def page_update_after_destroy
Chris@1115 139 latest = page.content.versions.reorder("#{self.class.table_name}.version DESC").first
Chris@1115 140 if latest && page.content.version != latest.version
Chris@1115 141 raise ActiveRecord::Rollback unless page.content.revert_to!(latest)
Chris@1115 142 elsif latest.nil?
Chris@1115 143 raise ActiveRecord::Rollback unless page.destroy
Chris@1115 144 end
Chris@0 145 end
Chris@0 146 end
Chris@0 147 end