summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2020-12-09 14:11:30 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2020-12-09 14:11:30 +0000
commit42b05f85ea6dd85db44e1360acf21393abda00c4 (patch)
treec371af8f0cbef96df09415d7aeef59e2e45e3f87
parentd30d70a418945396e3e41ded90b61c0f25239af9 (diff)
downloadredmine-42b05f85ea6dd85db44e1360acf21393abda00c4.tar.gz
redmine-42b05f85ea6dd85db44e1360acf21393abda00c4.zip
shorten long line of app/models/project.rb
git-svn-id: http://svn.redmine.org/redmine/trunk@20589 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/models/project.rb128
1 files changed, 97 insertions, 31 deletions
diff --git a/app/models/project.rb b/app/models/project.rb
index 44adeea58..1ea3aaf5f 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -172,10 +172,18 @@ class Project < ActiveRecord::Base
# * :member => true limit the condition to the user projects
def self.allowed_to_condition(user, permission, options={})
perm = Redmine::AccessControl.permission(permission)
- base_statement = (perm && perm.read? ? "#{Project.table_name}.status <> #{Project::STATUS_ARCHIVED}" : "#{Project.table_name}.status = #{Project::STATUS_ACTIVE}")
+ base_statement =
+ if perm && perm.read?
+ "#{Project.table_name}.status <> #{Project::STATUS_ARCHIVED}"
+ else
+ "#{Project.table_name}.status = #{Project::STATUS_ACTIVE}"
+ end
if !options[:skip_pre_condition] && perm && perm.project_module
# If the permission belongs to a project module, make sure the module is enabled
- base_statement += " AND EXISTS (SELECT 1 AS one FROM #{EnabledModule.table_name} em WHERE em.project_id = #{Project.table_name}.id AND em.name='#{perm.project_module}')"
+ base_statement +=
+ " AND EXISTS (SELECT 1 AS one FROM #{EnabledModule.table_name} em" \
+ " WHERE em.project_id = #{Project.table_name}.id" \
+ " AND em.name='#{perm.project_module}')"
end
if project = options[:project]
project_statement = project.project_condition(options[:with_subprojects])
@@ -193,7 +201,10 @@ class Project < ActiveRecord::Base
if user.id
group = role.anonymous? ? Group.anonymous : Group.non_member
principal_ids = [user.id, group.id].compact
- s = "(#{s} AND #{Project.table_name}.id NOT IN (SELECT project_id FROM #{Member.table_name} WHERE user_id IN (#{principal_ids.join(',')})))"
+ s =
+ "(#{s} AND #{Project.table_name}.id NOT IN " \
+ "(SELECT project_id FROM #{Member.table_name} " \
+ "WHERE user_id IN (#{principal_ids.join(',')})))"
end
statement_by_role[role] = s
end
@@ -311,14 +322,19 @@ class Project < ActiveRecord::Base
# project.project_condition(false) => "projects.id = 1"
def project_condition(with_subprojects)
cond = "#{Project.table_name}.id = #{id}"
- cond = "(#{cond} OR (#{Project.table_name}.lft > #{lft} AND #{Project.table_name}.rgt < #{rgt}))" if with_subprojects
+ if with_subprojects
+ cond = "(#{cond} OR (#{Project.table_name}.lft > #{lft} AND " \
+ "#{Project.table_name}.rgt < #{rgt}))"
+ end
cond
end
def self.find(*args)
if args.first && args.first.is_a?(String) && !/^\d*$/.match?(args.first)
project = find_by_identifier(*args)
- raise ActiveRecord::RecordNotFound, "Couldn't find Project with identifier=#{args.first}" if project.nil?
+ if project.nil?
+ raise ActiveRecord::RecordNotFound, "Couldn't find Project with identifier=#{args.first}"
+ end
project
else
@@ -483,7 +499,10 @@ class Project < ActiveRecord::Base
@rolled_up_versions ||=
Version.
joins(:project).
- where("#{Project.table_name}.lft >= ? AND #{Project.table_name}.rgt <= ? AND #{Project.table_name}.status <> ?", lft, rgt, STATUS_ARCHIVED)
+ where(
+ "#{Project.table_name}.lft >= ? AND #{Project.table_name}.rgt <= ?" \
+ " AND #{Project.table_name}.status <> ?", lft, rgt, STATUS_ARCHIVED
+ )
end
# Returns a scope of the Versions used by the project
@@ -492,20 +511,29 @@ class Project < ActiveRecord::Base
Version.
joins(:project).
preload(:project).
- where("#{Project.table_name}.status <> ? AND #{Version.table_name}.sharing = 'system'", STATUS_ARCHIVED)
+ where("#{Project.table_name}.status <> ? AND #{Version.table_name}.sharing = 'system'",
+ STATUS_ARCHIVED)
else
@shared_versions ||= begin
r = root? ? self : root
Version.
joins(:project).
preload(:project).
- where("#{Project.table_name}.id = #{id}" +
- " OR (#{Project.table_name}.status <> #{Project::STATUS_ARCHIVED} AND (" +
- " #{Version.table_name}.sharing = 'system'" +
- " OR (#{Project.table_name}.lft >= #{r.lft} AND #{Project.table_name}.rgt <= #{r.rgt} AND #{Version.table_name}.sharing = 'tree')" +
- " OR (#{Project.table_name}.lft < #{lft} AND #{Project.table_name}.rgt > #{rgt} AND #{Version.table_name}.sharing IN ('hierarchy', 'descendants'))" +
- " OR (#{Project.table_name}.lft > #{lft} AND #{Project.table_name}.rgt < #{rgt} AND #{Version.table_name}.sharing = 'hierarchy')" +
- "))")
+ where(
+ "#{Project.table_name}.id = #{id}" \
+ " OR (#{Project.table_name}.status <> #{Project::STATUS_ARCHIVED} AND (" \
+ " #{Version.table_name}.sharing = 'system'" \
+ " OR (#{Project.table_name}.lft >= #{r.lft}" \
+ " AND #{Project.table_name}.rgt <= #{r.rgt}" \
+ " AND #{Version.table_name}.sharing = 'tree')" \
+ " OR (#{Project.table_name}.lft < #{lft}" \
+ " AND #{Project.table_name}.rgt > #{rgt}" \
+ " AND #{Version.table_name}.sharing IN ('hierarchy', 'descendants'))" \
+ " OR (#{Project.table_name}.lft > #{lft}" \
+ " AND #{Project.table_name}.rgt < #{rgt}" \
+ " AND #{Version.table_name}.sharing = 'hierarchy')" \
+ "))"
+ )
end
end
end
@@ -523,7 +551,9 @@ class Project < ActiveRecord::Base
# TODO: Remove this method in Redmine 5.0
def members_by_role
- ActiveSupport::Deprecation.warn "Project#members_by_role will be removed. Use Project#principals_by_role instead."
+ ActiveSupport::Deprecation.warn(
+ "Project#members_by_role will be removed. Use Project#principals_by_role instead."
+ )
principals_by_role
end
@@ -545,7 +575,10 @@ class Project < ActiveRecord::Base
# Deletes all project's members
def delete_all_members
me, mr = Member.table_name, MemberRole.table_name
- self.class.connection.delete("DELETE FROM #{mr} WHERE #{mr}.member_id IN (SELECT #{me}.id FROM #{me} WHERE #{me}.project_id = #{id})")
+ self.class.connection.delete(
+ "DELETE FROM #{mr} WHERE #{mr}.member_id IN (SELECT #{me}.id FROM #{me} " \
+ "WHERE #{me}.project_id = #{id})"
+ )
Member.where(:project_id => id).delete_all
end
@@ -565,7 +598,10 @@ class Project < ActiveRecord::Base
if tracker
# Rejects users that cannot the view the tracker
- roles = Role.where(:assignable => true).select {|role| role.permissions_tracker?(:view_issues, tracker)}
+ roles =
+ Role.where(:assignable => true).select do |role|
+ role.permissions_tracker?(:view_issues, tracker)
+ end
scope = scope.where(:roles => {:id => roles.map(&:id)})
end
@@ -581,7 +617,12 @@ class Project < ActiveRecord::Base
# Returns the users that should be notified on project events
def notified_users
# TODO: User part should be extracted to User#notify_about?
- members.preload(:principal).select {|m| m.principal.present? && (m.mail_notification? || m.principal.mail_notification == 'all')}.collect {|m| m.principal}
+ users =
+ members.preload(:principal).select do |m|
+ m.principal.present? &&
+ (m.mail_notification? || m.principal.mail_notification == 'all')
+ end
+ users.collect {|m| m.principal}
end
# Returns a scope of all custom fields enabled for project issues
@@ -736,7 +777,11 @@ class Project < ActiveRecord::Base
def enabled_module_names=(module_names)
if module_names && module_names.is_a?(Array)
module_names = module_names.collect(&:to_s).reject(&:blank?)
- self.enabled_modules = module_names.collect {|name| enabled_modules.detect {|mod| mod.name == name} || EnabledModule.new(:name => name)}
+ self.enabled_modules =
+ module_names.collect do |name|
+ enabled_modules.detect {|mod| mod.name == name} ||
+ EnabledModule.new(:name => name)
+ end
else
enabled_modules.clear
end
@@ -874,7 +919,9 @@ class Project < ActiveRecord::Base
to_be_copied.each do |name|
send "copy_#{name}", project
end
- Redmine::Hook.call_hook(:model_project_copy_before_save, :source_project => project, :destination_project => self)
+ Redmine::Hook.call_hook(:model_project_copy_before_save,
+ :source_project => project,
+ :destination_project => self)
save
else
false
@@ -886,7 +933,9 @@ class Project < ActiveRecord::Base
def self.copy_from(project)
project = project.is_a?(Project) ? project : Project.find(project)
# clear unique attributes
- attributes = project.attributes.dup.except('id', 'name', 'identifier', 'status', 'parent_id', 'lft', 'rgt')
+ attributes =
+ project.attributes.dup.except('id', 'name', 'identifier',
+ 'status', 'parent_id', 'lft', 'rgt')
copy = Project.new(attributes)
copy.enabled_module_names = project.enabled_module_names
copy.trackers = project.trackers
@@ -951,7 +1000,9 @@ class Project < ActiveRecord::Base
parent.memberships.each do |parent_member|
member = Member.find_or_new(self.id, parent_member.user_id)
parent_member.member_roles.each do |parent_member_role|
- member.member_roles << MemberRole.new(:role => parent_member_role.role, :inherited_from => parent_member_role.id)
+ member.member_roles <<
+ MemberRole.new(:role => parent_member_role.role,
+ :inherited_from => parent_member_role.id)
end
member.save!
end
@@ -984,11 +1035,14 @@ class Project < ActiveRecord::Base
# Skip pages without content
next if page.content.nil?
- new_wiki_content = WikiContent.new(page.content.attributes.dup.except("id", "page_id", "updated_on"))
- new_wiki_page = WikiPage.new(page.attributes.dup.except("id", "wiki_id", "created_on", "parent_id"))
+ new_wiki_content =
+ WikiContent.new(page.content.attributes.dup.except("id", "page_id", "updated_on"))
+ new_wiki_page =
+ WikiPage.new(page.attributes.dup.except("id", "wiki_id", "created_on", "parent_id"))
new_wiki_page.content = new_wiki_content
wiki.pages << new_wiki_page
- new_wiki_page.attachments = page.attachments.map{|attachement| attachement.copy(:container => new_wiki_page)}
+ new_wiki_page.attachments =
+ page.attachments.map{|attachement| attachement.copy(:container => new_wiki_page)}
wiki_pages_map[page.id] = new_wiki_page
end
@@ -1008,7 +1062,8 @@ class Project < ActiveRecord::Base
def copy_versions(project)
project.versions.each do |version|
new_version = Version.new
- new_version.attributes = version.attributes.dup.except("id", "project_id", "created_on", "updated_on")
+ new_version.attributes =
+ version.attributes.dup.except("id", "project_id", "created_on", "updated_on")
new_version.attachments = version.attachments.map do |attachment|
attachment.copy(:container => new_version)
@@ -1084,7 +1139,12 @@ class Project < ActiveRecord::Base
self.issues << new_issue
if new_issue.new_record?
- logger.info "Project#copy_issues: issue ##{issue.id} could not be copied: #{new_issue.errors.full_messages}" if logger && logger.info?
+ if logger && logger.info?
+ logger.info(
+ "Project#copy_issues: issue ##{issue.id} could not be copied: " \
+ "#{new_issue.errors.full_messages}"
+ )
+ end
else
issues_map[issue.id] = new_issue unless new_issue.new_record?
end
@@ -1106,7 +1166,8 @@ class Project < ActiveRecord::Base
# Relations
issue.relations_from.each do |source_relation|
new_issue_relation = IssueRelation.new
- new_issue_relation.attributes = source_relation.attributes.dup.except("id", "issue_from_id", "issue_to_id")
+ new_issue_relation.attributes =
+ source_relation.attributes.dup.except("id", "issue_from_id", "issue_to_id")
new_issue_relation.issue_to = issues_map[source_relation.issue_to_id]
if new_issue_relation.issue_to.nil? && Setting.cross_project_issue_relations?
new_issue_relation.issue_to = source_relation.issue_to
@@ -1116,7 +1177,8 @@ class Project < ActiveRecord::Base
issue.relations_to.each do |source_relation|
new_issue_relation = IssueRelation.new
- new_issue_relation.attributes = source_relation.attributes.dup.except("id", "issue_from_id", "issue_to_id")
+ new_issue_relation.attributes =
+ source_relation.attributes.dup.except("id", "issue_from_id", "issue_to_id")
new_issue_relation.issue_from = issues_map[source_relation.issue_from_id]
if new_issue_relation.issue_from.nil? && Setting.cross_project_issue_relations?
new_issue_relation.issue_from = source_relation.issue_from
@@ -1151,7 +1213,9 @@ class Project < ActiveRecord::Base
def copy_queries(project)
project.queries.each do |query|
new_query = query.class.new
- new_query.attributes = query.attributes.dup.except("id", "project_id", "sort_criteria", "user_id", "type")
+ new_query.attributes =
+ query.attributes.dup.except("id", "project_id", "sort_criteria",
+ "user_id", "type")
new_query.sort_criteria = query.sort_criteria if query.sort_criteria
new_query.project = self
new_query.user_id = query.user_id
@@ -1164,7 +1228,9 @@ class Project < ActiveRecord::Base
def copy_boards(project)
project.boards.each do |board|
new_board = Board.new
- new_board.attributes = board.attributes.dup.except("id", "project_id", "topics_count", "messages_count", "last_message_id")
+ new_board.attributes =
+ board.attributes.dup.except("id", "project_id", "topics_count",
+ "messages_count", "last_message_id")
new_board.project = self
self.boards << new_board
end