OidcSiopVerifier

class OidcSiopVerifier(clientIdScheme: OidcSiopVerifier.ClientIdScheme, keyMaterial: KeyMaterial = EphemeralKeyWithoutCert(), verifier: Verifier = VerifierAgent(identifier = clientIdScheme.clientId), jwsService: JwsService = DefaultJwsService(DefaultCryptoService(keyMaterial)), verifierJwsService: VerifierJwsService = DefaultVerifierJwsService(DefaultVerifierCryptoService()), timeLeewaySeconds: Long = 300, clock: Clock = Clock.System, nonceService: NonceService = DefaultNonceService(), stateToNonceStore: MapStore<String, String> = DefaultMapStore(), stateToResponseTypeStore: MapStore<String, String> = DefaultMapStore())(source)

Combines Verifiable Presentations with OpenId Connect. Implements OIDC for VP (2023-04-21) as well as SIOP V2 (2023-01-01).

This class creates the Authentication Request, verifier verifies the response. See OidcSiopWallet for the holder.

Constructors

Link copied to clipboard
constructor(clientIdScheme: OidcSiopVerifier.ClientIdScheme, keyMaterial: KeyMaterial = EphemeralKeyWithoutCert(), verifier: Verifier = VerifierAgent(identifier = clientIdScheme.clientId), jwsService: JwsService = DefaultJwsService(DefaultCryptoService(keyMaterial)), verifierJwsService: VerifierJwsService = DefaultVerifierJwsService(DefaultVerifierCryptoService()), timeLeewaySeconds: Long = 300, clock: Clock = Clock.System, nonceService: NonceService = DefaultNonceService(), stateToNonceStore: MapStore<String, String> = DefaultMapStore(), stateToResponseTypeStore: MapStore<String, String> = DefaultMapStore())

Types

Link copied to clipboard
sealed class AuthnResponseResult
Link copied to clipboard
sealed class ClientIdScheme
Link copied to clipboard
data class RequestOptions(val credentials: Set<OidcSiopVerifier.RequestOptionsCredential>, val responseMode: OpenIdConstants.ResponseMode = OpenIdConstants.ResponseMode.Fragment, val responseUrl: String? = null, val responseType: String = VP_TOKEN, val state: String = uuid4().toString(), val clientMetadataUrl: String? = null, val encryption: Boolean = false)
Link copied to clipboard
data class RequestOptionsCredential(val credentialScheme: ConstantIndex.CredentialScheme, val representation: ConstantIndex.CredentialRepresentation = ConstantIndex.CredentialRepresentation.PLAIN_JWT, val requestedAttributes: List<String>? = null, val requestedOptionalAttributes: List<String>? = null)

Properties

Link copied to clipboard

Serve this result JSON-serialized under /.well-known/jar-issuer (see OpenIdConstants.PATH_WELL_KNOWN_JAR_ISSUER), so that SIOP Wallets can look up the keys used to sign request objects.

Link copied to clipboard
Link copied to clipboard

Functions

Link copied to clipboard

Creates AuthenticationRequestParameters, to be encoded as query params appended to the URL of the Wallet, e.g. https://example.com?repsonse_type=... (see createAuthnRequestUrl)

Link copied to clipboard

Creates an JWS Authorization Request (JAR, RFC9101), wrapping the usual AuthenticationRequestParameters.

Link copied to clipboard
suspend fun createAuthnRequestUrl(walletUrl: String, requestOptions: OidcSiopVerifier.RequestOptions): String

Creates an OIDC Authentication Request, encoded as query parameters to the walletUrl.

Link copied to clipboard
suspend fun createAuthnRequestUrlWithRequestObject(walletUrl: String, requestOptions: OidcSiopVerifier.RequestOptions): KmmResult<String>

Creates an OIDC Authentication Request, encoded as query parameters to the walletUrl, containing a JWS Authorization Request (JAR, RFC9101) in request, containing the request parameters itself.

suspend fun createAuthnRequestUrlWithRequestObjectByReference(walletUrl: String, requestUrl: String, requestOptions: OidcSiopVerifier.RequestOptions): KmmResult<Pair<String, String>>

Creates an OIDC Authentication Request, encoded as query parameters to the walletUrl, containing a reference (request_uri, see AuthenticationRequestParameters.requestUri) to the JWS Authorization Request (JAR, RFC9101), containing the request parameters itself.

Link copied to clipboard
fun createQrCodeUrl(walletUrl: String, clientMetadataUrl: String, requestUrl: String): String

Create a URL to be displayed as a static QR code for Wallet initiation. URL is the walletUrl, with query parameters appended for clientMetadataUrl, requestUrl and clientIdScheme.clientId.

Link copied to clipboard
suspend fun createSignedMetadata(): KmmResult<JwsSigned<RelyingPartyMetadata>>

Creates a JWS containing signed RelyingPartyMetadata, to be served under a client_metadata_uri at the Verifier.

Link copied to clipboard

Validates AuthenticationResponseParameters from the Wallet

Validates the OIDC Authentication Response from the Wallet, where url is the whole URL, containing the AuthenticationResponseParameters as the fragment, e.g. https://example.com#id_token=...

Link copied to clipboard

Validates the OIDC Authentication Response from the Wallet, where content are the HTTP POST encoded AuthenticationResponseParameters, e.g. id_token=...&vp_token=...