Sha256: 2f53887ce9bc8c4e4263c39f0c59288b5db46b67e9107bf1a113f67a08ce31ed

Contents?: true

Size: 1.82 KB

Versions: 3

Compression:

Stored size: 1.82 KB

Contents

# frozen-string-literal: true

module Rodauth
  Feature.define(:email_base, :EmailBase) do
    translatable_method :email_subject_prefix, ''
    auth_value_method :require_mail?, true
    auth_value_method :allow_raw_email_token?, false

    redirect :default_post_email

    auth_value_methods(
      :email_from
    )

    auth_methods(
      :create_email,
      :email_to,
      :send_email
    )

    def post_configure
      super
      require 'mail' if require_mail?
    end

    def email_from
      "webmaster@#{domain}"
    end

    def email_to
      account[login_column]
    end

    private

    def send_email(email)
      email.deliver!
    end

    def create_email(subject, body)
      create_email_to(email_to, subject, body)
    end

    def create_email_to(to, subject, body)
      m = Mail.new
      m.from = email_from
      m.to = to
      m.subject = "#{email_subject_prefix}#{subject}"
      m.body = body
      m
    end

    def token_link(route, param, key)
      route_url(route, param => token_param_value(key))
    end

    def token_param_value(key)
      "#{account_id}#{token_separator}#{convert_email_token_key(key)}"
    end

    def convert_email_token_key(key)
      convert_token_key(key)
    end

    def account_from_key(token, status_id=nil)
      id, key = split_token(token)
      id = convert_token_id(id)
      return unless id && key

      return unless actual = yield(id)

      unless (hmac_secret && timing_safe_eql?(key, convert_email_token_key(actual))) ||
         (hmac_secret_rotation? && timing_safe_eql?(key, compute_old_hmac(actual))) ||
         ((!hmac_secret || allow_raw_email_token?) && timing_safe_eql?(key, actual))
        return
      end
      ds = account_ds(id)
      ds = ds.where(account_status_column=>status_id) if status_id && !skip_status_checks?
      ds.first
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
rodauth-2.34.0 lib/rodauth/features/email_base.rb
rodauth-2.33.0 lib/rodauth/features/email_base.rb
rodauth-2.32.0 lib/rodauth/features/email_base.rb