Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Apple Native Sign In : { "__isAuthError": true, "name": "AuthApiError", "status": 400 } #504

Open
2 tasks done
agrittiwari opened this issue Apr 29, 2024 · 7 comments
Open
2 tasks done
Labels
bug Something isn't working

Comments

@agrittiwari
Copy link

Bug report

  • I confirm this is a bug with Supabase, not with my own application.
  • I confirm I have searched the Docs, GitHub Discussions, and Discord.

Describe the bug

IdentityToken is returned by Apple, but supabase.auth.signInwithIdToken breaks and returns the erro

To Reproduce

Steps to reproduce the behavior, please provide code snippets or a repository:

import * as AppleAuthentication from 'expo-apple-authentication';
import {
  Employee,
  GetLoggedInUserDocument,
  useRegisterUserMutation,
} from 'generated/hooks_and_more';
import { Platform } from 'react-native';
import { useMMKVObject, useMMKVString } from 'react-native-mmkv';
import { captureSentryException } from 'sentry_telemetry/sentryLogger';
import { supabase } from '~/utils/supabase';

export default function AppleSignIn() {
  const [accessToken, setAccessToken] = useMMKVString('access_token');
  const [refreshToken, setRefreshToken] = useMMKVString('refresh_token');
  const [mmkvUser, setMMKVUser] = useMMKVObject<Employee>('mmkv_user');
  const [registerUser, { data: userResponse, loading: registerLoading }] =
    useRegisterUserMutation();
  if (Platform.OS === 'ios')
    return (
      <AppleAuthentication.AppleAuthenticationButton
        buttonType={AppleAuthentication.AppleAuthenticationButtonType.SIGN_IN}
        buttonStyle={AppleAuthentication.AppleAuthenticationButtonStyle.BLACK}
        cornerRadius={5}
        style={{ width: 200, height: 64 }}
        onPress={async () => {
          try {
            const credential = await AppleAuthentication.signInAsync({
              requestedScopes: [
                AppleAuthentication.AppleAuthenticationScope.FULL_NAME,
                AppleAuthentication.AppleAuthenticationScope.EMAIL,
              ],
            });
            // Sign in via Supabase Auth.
            console.log(credential);
            if (credential.identityToken) {
              const {
                error,
                data: { user, session },
              } = await supabase.auth.signInWithIdToken({
                provider: 'apple',
                token: credential.identityToken,
              });
              console.log(JSON.stringify({ error, user }, null, 2));
              if (!error) {
                // User is signed in.
                setAccessToken(session?.access_token || '');
                setRefreshToken(session?.refresh_token || '');
                registerUser({
                  refetchQueries: [{ query: GetLoggedInUserDocument }],
                  onCompleted(data, clientOptions) {
                    setMMKVUser(data?.register);
                    //  setUser(data?.register);
                    //Not deprecating this, As it is used in push notifications and Select services as well.
                    console.log('on registerd in Native Apple Login', accessToken);
                    // user && getAccessToken() && navigation.replace('SetupYourOrganization');
                    // Toast.show('User Created Successfully', {
                    //   duration: Toast.durations.SHORT,
                    //   position: Toast.positions.BOTTOM,
                    //   textColor: 'white',
                    //   backgroundColor: colors?.dark?.green,
                    //   shadow: true,
                    //   animation: true,
                    //   hideOnPress: true,
                    //   delay: 0,
                    // });
                  },
                  onError(error, clientOptions) {
                    console.log('error', error);
                    captureSentryException('Error in creating new user', error as any);
                  },
                });
              }
            } else {
              throw new Error('No identityToken.');
            }
          } catch (e) {
            if (e.code === 'ERR_REQUEST_CANCELED') {
              // handle that the user canceled the sign-in flow
            } else {
              // handle other errors
            }
          }
        }}
      />
    );
  return <>{/* Implement Android Auth options. */}</>;
}

Expected behavior

Expected behavior is for supabase to generate the accessToken and refreshToken for the session

Screenshots

If applicable, add screenshots to help explain your problem.

System information

  • OS: macOS
  • Browser (if applies) [e.g. chrome, safari]
  • Version of supabase-js: [e.g. 6.0.2]
  • Version of Node.js: [e.g. 20.10.0]

Additional context

I am using Expo, went through every code snippet out there and this issue particularly #Issue1401

@agrittiwari agrittiwari added the bug Something isn't working label Apr 29, 2024
@agrittiwari
Copy link
Author

This ticket also related to this ticket #1561

@Kamsou
Copy link

Kamsou commented May 23, 2024

Same error

@dpelletier2017
Copy link

dpelletier2017 commented Aug 9, 2024

I seem to have the same error in a native Swift / SwiftUI project. I've had the error since Novembre 2023 AFAIK.

api(Auth.AuthError.APIError(msg: nil, code: nil, error: Optional("invalid request"), errorDescription: Optional("Bad ID token"), weakPassword: nil))

After doing :

let credentials = OpenIDConnectCredentials(provider: .apple, idToken: token)
let session = try await SupabaseDatabase.client.auth.signInWithIdToken(credentials: credentials)

@kangmingtay kangmingtay transferred this issue from supabase/auth Aug 15, 2024
@grdsdev
Copy link
Collaborator

grdsdev commented Jan 8, 2025

Hi all, is this still an issue?

For the Swift, please make sure to follow example: https://github.com/supabase/supabase-swift/blob/main/Examples/Examples/Auth/SignInWithApple.swift

Thanks.

@dpelletier2017
Copy link

Hi, I changed my code and I've had much less problems with Supabase Auth with Sign In With Apple.

I think it ought to have better documentation though - I used ChatGPT to be able to improve it, but it was also struggling.

I would personally close it. Thanks for the support!

@grdsdev
Copy link
Collaborator

grdsdev commented Jan 9, 2025

Thanks @dpelletier2017

Could you share what was the change that make it work?

@dpelletier2017
Copy link

dpelletier2017 commented Jan 19, 2025

@grdsdev It ended up being something like this.
The part that was new to me was the setSession() if I remember correctly.
I'm still not 100% sure why this works better but it does.

import Supabase
import SwiftUI

@MainActor @Observable final class AuthHelperTest: NSObject, @unchecked Sendable {
    func signInWithApple() async {
        let accessToken = Settings.shared.supabaseAuthAccessToken
        let refreshToken = Settings.shared.supabaseAuthRefreshToken
        
        if accessToken != "" && refreshToken != "" {
            do {
                try await CloudDatabase.client.auth.setSession(
                    accessToken: accessToken,
                    refreshToken: refreshToken
                )
                
                let session = try await CloudDatabase.client.auth.session
                
                updateSessionDetails(session: session)
            } catch {
                // catch error
            }
        } else {
            await refreshSession()
        }
    }
    
    func updateSessionDetails(session: Session) {
        // Step 1. Save Login Tokens
        Settings.shared.supabaseAuthAccessToken = session.accessToken
        Settings.shared.supabaseAuthRefreshToken = session.refreshToken
    }
    
    func refreshSession() async {
        do {
            let session = try await CloudDatabase.client.auth.session
            updateSessionDetails(session: session)
        } catch {
            TelemetryInHouseHelper.send(.error(signal: .init(error: error)))
        }
    }
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

4 participants