diff options
author | Azul <azul@riseup.net> | 2016-07-04 20:19:21 +0200 |
---|---|---|
committer | Azul <azul@riseup.net> | 2016-07-05 08:56:05 +0200 |
commit | 638acc59a241e141cf0fc9ccbf4e3c5578b98f0c (patch) | |
tree | 82c09920af4053b42eaac22365af239078491000 /lib/login_format_validation.rb | |
parent | 949e17c7c30c5b179ba6545782ae995178481f78 (diff) |
Fix db:migrate and similar tasks
We saw errors from duplicate loading of LocalEmail and
LoginFormatValidation. The latter resulted in a crash.
In an attempt to ensure all subclasses of Couchrest::Model::Base are
loaded Couchrest::Model::Utils::Migrate requires all files in app/models.
We have an extension that does the same for the engines.
During this process LoginFormatValidation and LocalEmail were autoloaded
when 'identity' was required. Afterwards they were required again.
It looks like rails' autoload mechanism does not play nicely with require.
So to make sure they are not autoloaded first move the concerns and
helper classes into the lib directory and require them explicitly.
Diffstat (limited to 'lib/login_format_validation.rb')
-rw-r--r-- | lib/login_format_validation.rb | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/login_format_validation.rb b/lib/login_format_validation.rb new file mode 100644 index 0000000..c1fcf70 --- /dev/null +++ b/lib/login_format_validation.rb @@ -0,0 +1,21 @@ +module LoginFormatValidation + extend ActiveSupport::Concern + + #TODO: Probably will replace this. Playing with using it for aliases too, but won't want it connected to login field. + + included do + # Have multiple regular expression validations so we can get specific error messages: + validates :login, + :format => { :with => /\A.{2,}\z/, + :message => "Must have at least two characters"} + validates :login, + :format => { :with => /\A[a-z\d_\.-]+\z/, + :message => "Only lowercase letters, digits, . - and _ allowed."} + validates :login, + :format => { :with => /\A[a-z].*\z/, + :message => "Must begin with a lowercase letter"} + validates :login, + :format => { :with => /\A.*[a-z\d]\z/, + :message => "Must end with a letter or digit"} + end +end |