Class: Wiki

Inherits:
ActiveRecord::Base
  • Object
show all
Includes:
Redmine::SafeAttributes
Defined in:
app/models/wiki.rb

Overview

Redmine - project management software Copyright (C) 2006-2016 Jean-Philippe Lang

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.

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Redmine::SafeAttributes

#delete_unsafe_attributes, included, #safe_attribute?, #safe_attribute_names, #safe_attributes=

Class Method Details

.find_page(title, options = {}) ⇒ Object

Finds a page by title The given string can be of one of the forms: “title” or “project:title” Examples:

Wiki.find_page("bar", project => foo)
Wiki.find_page("foo:bar")


85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'app/models/wiki.rb', line 85

def self.find_page(title, options = {})
  project = options[:project]
  if title.to_s =~ %r{^([^\:]+)\:(.*)$}
    project_identifier, title = $1, $2
    project = Project.find_by_identifier(project_identifier) || Project.find_by_name(project_identifier)
  end
  if project && project.wiki
    page = project.wiki.find_page(title)
    if page && page.content
      page
    end
  end
end

.titleize(title) ⇒ Object

turn a string into a valid page title



100
101
102
103
104
105
106
# File 'app/models/wiki.rb', line 100

def self.titleize(title)
  # replace spaces with _ and remove unwanted caracters
  title = title.gsub(/\s+/, '_').delete(',./?;|:') if title
  # upcase the first letter
  title = (title.slice(0..0).upcase + (title.slice(1..-1) || '')) if title
  title
end

Instance Method Details

#delete_redirectsObject

Deletes all redirects from/to the wiki



75
76
77
78
# File 'app/models/wiki.rb', line 75

def delete_redirects
  WikiRedirect.where(:wiki_id => id).delete_all
  WikiRedirect.where(:redirects_to_wiki_id => id).delete_all
end

#find_or_new_page(title) ⇒ Object

find the page with the given title if page doesn't exist, return a new page



47
48
49
50
# File 'app/models/wiki.rb', line 47

def find_or_new_page(title)
  title = start_page if title.blank?
  find_page(title) || WikiPage.new(:wiki => self, :title => Wiki.titleize(title))
end

#find_page(title, options = {}) ⇒ Object

find the page with the given title



53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
# File 'app/models/wiki.rb', line 53

def find_page(title, options = {})
  @page_found_with_redirect = false
  title = start_page if title.blank?
  title = Wiki.titleize(title)
  page = pages.where("LOWER(title) = LOWER(?)", title).first
  if page.nil? && options[:with_redirect] != false
    # search for a redirect
    redirect = redirects.where("LOWER(title) = LOWER(?)", title).first
    if redirect
      page = redirect.target_page
      @page_found_with_redirect = true
    end
  end
  page
end

#page_found_with_redirect?Boolean

Returns true if the last page was found with a redirect

Returns:

  • (Boolean)


70
71
72
# File 'app/models/wiki.rb', line 70

def page_found_with_redirect?
  @page_found_with_redirect
end

Returns the wiki page that acts as the sidebar content or nil if no such page exists



41
42
43
# File 'app/models/wiki.rb', line 41

def sidebar
  @sidebar ||= find_page('Sidebar', :with_redirect => false)
end

#visible?(user = User.current) ⇒ Boolean

Returns:

  • (Boolean)


35
36
37
# File 'app/models/wiki.rb', line 35

def visible?(user=User.current)
  !user.nil? && user.allowed_to?(:view_wiki_pages, project)
end