aboutsummaryrefslogtreecommitdiffstats
path: root/app/models/change_email_validator.rb
blob: 37eb3c176703a55bc471f28644ad4c4395cd55f1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# == Schema Information
# Schema version: 114
#
# Table name: change_email_validators
#
#  old_email         :string
#  new_email         :string
#  password          :string
#  user_circumstance :string
#

# models/changeemail_validator.rb:
# Validates email change form submissions.
#
# Copyright (c) 2010 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/

class ChangeEmailValidator < ActiveRecord::BaseWithoutTable
    strip_attributes!

    column :old_email, :string
    column :new_email, :string
    column :password, :string
    column :user_circumstance, :string

    attr_accessor :logged_in_user

    validates_presence_of :old_email, :message => N_("Please enter your old email address")
    validates_presence_of :new_email, :message => N_("Please enter your new email address")
    validates_presence_of :password, :message => N_("Please enter your password"), :unless => :changing_email
    validate :password_and_format_of_email

    def changing_email()
      self.user_circumstance == 'change_email'
    end

    private

    def password_and_format_of_email
        if !self.old_email.blank? && !MySociety::Validate.is_valid_email(self.old_email)
            errors.add(:old_email, _("Old email doesn't look like a valid address"))
        end

        if errors[:old_email].blank?
            if self.old_email.downcase != self.logged_in_user.email.downcase
                errors.add(:old_email, _("Old email address isn't the same as the address of the account you are logged in with"))
            elsif (!self.changing_email) && (!self.logged_in_user.has_this_password?(self.password))
                if errors[:password].blank?
                    errors.add(:password, _("Password is not correct"))
                end
            end
        end

        if !self.new_email.blank? && !MySociety::Validate.is_valid_email(self.new_email)
            errors.add(:new_email, _("New email doesn't look like a valid address"))
        end
    end

end