summaryrefslogtreecommitdiff
path: root/users/app/models/account.rb
blob: 5368a1bfcb922efb848db182cd8b339b7d9865b0 (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
#
# A Composition of a User record and it's identity records.
#
class Account

  attr_reader :user

  def initialize(user = nil)
    @user = user
  end

  # Returns the user record so it can be used in views.
  def self.create(attrs)
    @user = User.create(attrs).tap do |user|
      Identity.create_for user
    end
  end

  def update(attrs)
    if attrs[:password_verifier].present?
      update_login(attrs[:login])
      @user.update_attributes attrs.slice(:password_verifier, :password_salt)
    end
    # TODO: move into identity controller
    update_pgp_key(attrs[:public_key]) if attrs.has_key? :public_key
    @user.save && save_identities
    @user.refresh_identity
  end

  def destroy
    return unless @user
    Identity.by_user_id.key(@user.id).each do |identity|
      identity.destroy
    end
    @user.destroy
  end

  protected

  def update_login(login)
    return unless login.present?
    @old_identity = Identity.for(@user)
    @user.login = login
    @new_identity = Identity.for(@user) # based on the new login
    @old_identity.destination = @user.email_address # alias old -> new
  end

  def update_pgp_key(key)
    @new_identity ||= Identity.for(@user)
    @new_identity.set_key(:pgp, key)
  end

  def save_identities
    @new_identity.try(:save) && @old_identity.try(:save)
  end

end