From d38e17b32a1ba6a33f7595bb1014213994b74778 Mon Sep 17 00:00:00 2001 From: Hassan Ben Jobrane Date: Thu, 28 Nov 2024 12:12:10 +0100 Subject: [PATCH] feat: add support for sign-in with id token (#149) * feat: add support for signin with id token * fix: remove mfa and add metdata options * feat: add linkIdToken method to HasuraAuthClient * fix dart linter error --- .../nhost_auth_dart/lib/src/auth_client.dart | 77 +++++++++++++++++++ .../lib/src/base/hasura_auth_client.dart | 6 ++ 2 files changed, 83 insertions(+) diff --git a/packages/nhost_auth_dart/lib/src/auth_client.dart b/packages/nhost_auth_dart/lib/src/auth_client.dart index 63a73b55..a621324e 100644 --- a/packages/nhost_auth_dart/lib/src/auth_client.dart +++ b/packages/nhost_auth_dart/lib/src/auth_client.dart @@ -263,6 +263,83 @@ class NhostAuthClient implements HasuraAuthClient { return res; } + /// Authenticates a user using an ID token from a third-party provider. + /// + /// This method allows users to sign in using an OpenID Connect [idToken] from a specified + /// [provider] (google, apple). An optional [nonce] parameter can be provided for additional security. + /// + /// Throws an [NhostException] if sign in fails. + @override + Future signInIdToken({ + required String provider, + required String idToken, + String? nonce, + String? locale, + String? defaultRole, + Map? metadata, + List? roles, + String? displayName, + String? redirectTo, + }) async { + log.finer('Attempting sign in (idToken)'); + AuthResponse? res; + + try { + res = await _apiClient.post( + '/signin/idtoken', + jsonBody: { + 'provider': provider, + 'idToken': idToken, + if (nonce != null) 'nonce': nonce, + if (locale != null) 'locale': locale, + if (defaultRole != null) 'defaultRole': defaultRole, + if (metadata != null) 'metadata': metadata, + if (roles != null) 'roles': roles, + if (displayName != null) 'displayName': displayName, + if (redirectTo != null) 'redirectTo': redirectTo, + }, + responseDeserializer: AuthResponse.fromJson, + ); + } catch (e, st) { + log.finer('Sign in failed', e, st); + await clearSession(); + rethrow; + } + + if (res != null) { + log.finer('Sign in successful'); + await setSession(res.session!); + return res; + } else { + throw AuthServiceException( + 'Sign in failed', + ); + } + } + + /// Links an existing user account to a third-party provider using an OpenID Connect [idToken]. + /// + /// This method enables linking a user account with an OpenID Connect [idToken] from a specified + /// [provider], such as "google" or "apple". You can optionally provide a [nonce] for enhanced security. + /// + /// Throws an [NhostException] if the link attempt fails. + @override + Future linkIdToken({ + required String provider, + required String idToken, + String? nonce, + }) async { + await _apiClient.post( + '/link/idtoken', + jsonBody: { + 'provider': provider, + 'idToken': idToken, + if (nonce != null) 'nonce': nonce, + }, + headers: _session.authenticationHeaders, + ); + } + /// Signs in a user with a magic link. /// /// An email will be sent to the [email] with a link. When the user diff --git a/packages/nhost_sdk/lib/src/base/hasura_auth_client.dart b/packages/nhost_sdk/lib/src/base/hasura_auth_client.dart index 03ee6228..3e54b0db 100644 --- a/packages/nhost_sdk/lib/src/base/hasura_auth_client.dart +++ b/packages/nhost_sdk/lib/src/base/hasura_auth_client.dart @@ -38,6 +38,12 @@ abstract class HasuraAuthClient { required String password, }); + Future signInIdToken( + {required String provider, required String idToken, String? nonce}); + + Future linkIdToken( + {required String provider, required String idToken, String? nonce}); + Future signInWithEmailPasswordless( String email, { String? redirectTo,