From 22e1362ab1f680fdc34064bbc2cb8828d4d37f3c Mon Sep 17 00:00:00 2001 From: Desiders Date: Wed, 18 Dec 2024 20:03:22 +0300 Subject: [PATCH 1/2] Add `user_info_verifier` method to `Client` --- src/client.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/client.rs b/src/client.rs index 8617a1b..a5c0e72 100644 --- a/src/client.rs +++ b/src/client.rs @@ -11,6 +11,7 @@ use crate::{ ResourceOwnerPassword, ResourceOwnerUsername, ResponseMode, ResponseType, RevocableToken, RevocationRequest, RevocationUrl, Scope, SubjectIdentifier, SubjectIdentifierType, TokenIntrospectionResponse, TokenResponse, TokenUrl, UserInfoRequest, UserInfoUrl, + UserInfoVerifier, }; use std::marker::PhantomData; @@ -661,6 +662,20 @@ where verifier } } + + /// Return an user info verifier for use with the [`UserInfoJsonWebToken::claims`](crate::UserInfoJsonWebToken::claims) + /// method. + pub fn user_info_verifier( + &self, + expected_subject: Option, + ) -> UserInfoVerifier { + UserInfoVerifier::new( + self.client_id.clone(), + self.issuer.clone(), + self.jwks.clone(), + expected_subject, + ) + } } /// Methods requiring an authorization endpoint. From a6f13717ec6c5c1e62c3e8e7bf9a260bb130566b Mon Sep 17 00:00:00 2001 From: Desiders Date: Wed, 18 Dec 2024 20:17:40 +0300 Subject: [PATCH 2/2] Change `'static` to `'a` --- src/user_info.rs | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/src/user_info.rs b/src/user_info.rs index be4b94b..c71a974 100644 --- a/src/user_info.rs +++ b/src/user_info.rs @@ -95,12 +95,7 @@ where access_token, require_signed_response: false, response_type: UserInfoResponseType::Json, - signed_response_verifier: UserInfoVerifier::new( - self.client_id.clone(), - self.issuer.clone(), - self.jwks.clone(), - expected_subject, - ), + signed_response_verifier: self.user_info_verifier(expected_subject), } } } @@ -116,7 +111,7 @@ where pub(crate) url: &'a UserInfoUrl, pub(crate) access_token: AccessToken, pub(crate) require_signed_response: bool, - pub(crate) signed_response_verifier: UserInfoVerifier<'static, JE, K>, + pub(crate) signed_response_verifier: UserInfoVerifier<'a, JE, K>, pub(crate) response_type: UserInfoResponseType, } impl<'a, JE, K> UserInfoRequest<'a, JE, K>