From 44ffc5a3365ffd16d6971d1c3f691a2f3f80ba3b Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Fri, 31 Dec 2010 15:30:50 +0000 Subject: [PATCH] Remove the limitation on characters that can be used in custom_field, issue_status, role, tracker, user names (#5152). git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4599 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/models/custom_field.rb | 1 - app/models/issue_status.rb | 1 - app/models/role.rb | 1 - app/models/tracker.rb | 1 - app/models/user.rb | 1 - lib/tasks/migrate_from_mantis.rake | 4 +--- lib/tasks/migrate_from_trac.rake | 4 ++-- 7 files changed, 3 insertions(+), 10 deletions(-) diff --git a/app/models/custom_field.rb b/app/models/custom_field.rb index 7cc6e865d71..3aacd468650 100644 --- a/app/models/custom_field.rb +++ b/app/models/custom_field.rb @@ -23,7 +23,6 @@ class CustomField < ActiveRecord::Base validates_presence_of :name, :field_format validates_uniqueness_of :name, :scope => :type validates_length_of :name, :maximum => 30 - validates_format_of :name, :with => /^[\w\s\.\'\-]*$/i validates_inclusion_of :field_format, :in => Redmine::CustomFieldFormat.available_formats def initialize(attributes = nil) diff --git a/app/models/issue_status.rb b/app/models/issue_status.rb index f376d5d15bb..8171cdb79f1 100644 --- a/app/models/issue_status.rb +++ b/app/models/issue_status.rb @@ -25,7 +25,6 @@ class IssueStatus < ActiveRecord::Base validates_presence_of :name validates_uniqueness_of :name validates_length_of :name, :maximum => 30 - validates_format_of :name, :with => /^[\w\s\'\-]*$/i validates_inclusion_of :default_done_ratio, :in => 0..100, :allow_nil => true def after_save diff --git a/app/models/role.rb b/app/models/role.rb index d1bebdb6d63..6a4b9e4e3b9 100644 --- a/app/models/role.rb +++ b/app/models/role.rb @@ -43,7 +43,6 @@ def copy(source_role) validates_presence_of :name validates_uniqueness_of :name validates_length_of :name, :maximum => 30 - validates_format_of :name, :with => /^[\w\s\'\-]*$/i def permissions read_attribute(:permissions) || [] diff --git a/app/models/tracker.rb b/app/models/tracker.rb index 9ee045ce14a..93fdd4035cd 100644 --- a/app/models/tracker.rb +++ b/app/models/tracker.rb @@ -31,7 +31,6 @@ def copy(source_tracker) validates_presence_of :name validates_uniqueness_of :name validates_length_of :name, :maximum => 30 - validates_format_of :name, :with => /^[\w\s\'\-]*$/i def to_s; name end diff --git a/app/models/user.rb b/app/models/user.rb index 91d6c5fd02b..7d0014c8d8c 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -68,7 +68,6 @@ class User < Principal # Login must contain lettres, numbers, underscores only validates_format_of :login, :with => /^[a-z0-9_\-@\.]*$/i validates_length_of :login, :maximum => 30 - validates_format_of :firstname, :lastname, :with => /^[\w\s\'\-\.]*$/i validates_length_of :firstname, :lastname, :maximum => 30 validates_format_of :mail, :with => /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i, :allow_nil => true validates_length_of :mail, :maximum => 60, :allow_nil => true diff --git a/lib/tasks/migrate_from_mantis.rake b/lib/tasks/migrate_from_mantis.rake index e9244fcaf7f..cd82872c18d 100644 --- a/lib/tasks/migrate_from_mantis.rake +++ b/lib/tasks/migrate_from_mantis.rake @@ -88,13 +88,11 @@ task :migrate_from_mantis => :environment do def firstname @firstname = realname.blank? ? username : realname.split.first[0..29] - @firstname.gsub!(/[^\w\s\'\-]/i, '') @firstname end def lastname @lastname = realname.blank? ? '-' : realname.split[1..-1].join(' ')[0..29] - @lastname.gsub!(/[^\w\s\'\-]/i, '') @lastname = '-' if @lastname.blank? @lastname end @@ -224,7 +222,7 @@ task :migrate_from_mantis => :environment do end def name - read_attribute(:name)[0..29].gsub(/[^\w\s\'\-]/, '-') + read_attribute(:name)[0..29] end end diff --git a/lib/tasks/migrate_from_trac.rake b/lib/tasks/migrate_from_trac.rake index 0510be51e69..f124703d422 100644 --- a/lib/tasks/migrate_from_trac.rake +++ b/lib/tasks/migrate_from_trac.rake @@ -246,8 +246,8 @@ namespace :redmine do ln = ($2 || '-').strip u = User.new :mail => mail.gsub(/[^-@a-z0-9\.]/i, '-'), - :firstname => fn[0, limit_for(User, 'firstname')].gsub(/[^\w\s\'\-]/i, '-'), - :lastname => ln[0, limit_for(User, 'lastname')].gsub(/[^\w\s\'\-]/i, '-') + :firstname => fn[0, limit_for(User, 'firstname')], + :lastname => ln[0, limit_for(User, 'lastname')] u.login = username[0,limit_for(User, 'login')].gsub(/[^a-z0-9_\-@\.]/i, '-') u.password = 'trac'