Sha256: c75c47a448f31b72f6e71c453a3d8044f36e66c226a3b95fb072dba7fa3b0592

Contents?: true

Size: 1.77 KB

Versions: 2

Compression:

Stored size: 1.77 KB

Contents

# frozen-string-literal: true

module Rodauth
  Feature.define(:webauthn_autofill, :WebauthnAutofill) do
    depends :webauthn_login

    auth_value_method :webauthn_autofill?, true
    auth_value_method :webauthn_autofill_js, File.binread(File.expand_path('../../../../javascript/webauthn_autofill.js', __FILE__)).freeze

    translatable_method :webauthn_invalid_webauthn_id_message, "no webauthn key with given id found"

    route(:webauthn_autofill_js) do |r|
      before_webauthn_autofill_js_route
      r.get do
        response['Content-Type'] = 'text/javascript'
        webauthn_autofill_js
      end
    end

    def webauthn_allow
      return [] unless logged_in? || account
      super
    end

    def webauthn_user_verification
      'preferred'
    end

    def webauthn_authenticator_selection
      super.merge({ 'residentKey' => 'required', 'requireResidentKey' => true })
    end

    def login_field_autocomplete_value
      request.path_info == login_path ? "#{super} webauthn" : super
    end

    private

    def _login_form_footer
      footer = super
      footer += render("webauthn-autofill") if webauthn_autofill? && !valid_login_entered?
      footer
    end

    def account_from_webauthn_login
      return super if param_or_nil(login_param)

      credential_id = webauthn_auth_data["id"]
      account_id = db[webauthn_keys_table]
        .where(webauthn_keys_webauthn_id_column => credential_id)
        .get(webauthn_keys_account_id_column)

      unless account_id
        throw_error_reason(:invalid_webauthn_id, invalid_field_error_status, webauthn_auth_param, webauthn_invalid_webauthn_id_message)
      end

      account_from_id(account_id)
    end

    def webauthn_login_options?
      return true unless param_or_nil(login_param)
      super
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
rodauth-2.38.0 lib/rodauth/features/webauthn_autofill.rb
rodauth-2.37.0 lib/rodauth/features/webauthn_autofill.rb