2019-10-01 22:08:41 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
require 'webauthn/security_key_base_validation_service'
|
|
|
|
require 'webauthn/security_key_registration_service'
|
|
|
|
require 'webauthn/security_key_authentication_service'
|
|
|
|
|
|
|
|
module Webauthn
|
|
|
|
ACCEPTABLE_REGISTRATION_TYPE = "webauthn.create".freeze
|
|
|
|
ACCEPTABLE_AUTHENTICATION_TYPE = "webauthn.get".freeze
|
2019-11-21 00:45:36 -05:00
|
|
|
|
|
|
|
# -7 - ES256
|
|
|
|
# -257 - RS256 (Windows Hello supported alg.)
|
|
|
|
SUPPORTED_ALGORITHMS = [-7, -257].freeze
|
2019-10-01 22:08:41 -04:00
|
|
|
VALID_ATTESTATION_FORMATS = ['none', 'packed', 'fido-u2f'].freeze
|
|
|
|
|
|
|
|
class SecurityKeyError < StandardError; end
|
|
|
|
|
|
|
|
class InvalidOriginError < SecurityKeyError; end
|
|
|
|
class InvalidRelyingPartyIdError < SecurityKeyError; end
|
|
|
|
class UserVerificationError < SecurityKeyError; end
|
|
|
|
class ChallengeMismatchError < SecurityKeyError; end
|
|
|
|
class InvalidTypeError < SecurityKeyError; end
|
|
|
|
class UnsupportedPublicKeyAlgorithmError < SecurityKeyError; end
|
|
|
|
class UnsupportedAttestationFormatError < SecurityKeyError; end
|
|
|
|
class CredentialIdInUseError < SecurityKeyError; end
|
|
|
|
class MalformedAttestationError < SecurityKeyError; end
|
|
|
|
class NotFoundError < SecurityKeyError; end
|
|
|
|
class OwnershipError < SecurityKeyError; end
|
|
|
|
class PublicKeyError < SecurityKeyError; end
|
|
|
|
end
|