Sha256: 9fcece0b09f6b1d6d8956883e22e789558362c2341a17075cf25f3e2d2b49937

Contents?: true

Size: 1.25 KB

Versions: 7

Compression:

Stored size: 1.25 KB

Contents

include All::Permissions::Accounts

view :raw do
  case
  when card.real? then card.content
  # following supports legacy behavior
  # (should be moved to User+*email+*type plus right)
  when card.left.account then card.left.account.email
  else ''
  end
end

view :core, :raw

event :validate_email, :validate, on: :save do
  if content.present? && content !~ /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i
    errors.add :content, 'must be valid address'
  end
end

event :validate_unique_email, after: :validate_email, on: :save do
  if content.present?
    Auth.as_bot do
      wql = { right_id: Card::EmailID, eq: content, return: :id }
      wql[:not] = { id: id } if id
      wql_comment = "email duplicate? (#{content})"
      if Card.search(wql, wql_comment).first
        errors.add :content, 'must be unique'
      end
    end
  end
end

event :downcase_email, :prepare_to_validate, on: :save do
  return if !content || content == content.downcase
  self.content = content.downcase
end

def email_required?
  !built_in?
end

def ok_to_read
  if own_email? || Auth.always_ok?
    true
  else
    deny_because 'viewing email is restricted to administrators and ' \
                 'account holders'
  end
end

def own_email?
  cardname.part_names[0].key == Auth.as_card.key
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
card-1.18.6 mod/05_standard/set/right/email.rb
card-1.18.5 mod/05_standard/set/right/email.rb
card-1.18.4 mod/05_standard/set/right/email.rb
card-1.18.3 mod/05_standard/set/right/email.rb
card-1.18.2 mod/05_standard/set/right/email.rb
card-1.18.1 mod/05_standard/set/right/email.rb
card-1.18.0 mod/05_standard/set/right/email.rb