Code:
Pretty much just copied from appwrite docs
TypeScript
const signInWithOAuth = async (provider) => {
setLoading(true);
try {
// Create a deep link that works across Expo environments
// Ensure localhost is used for the hostname to validation error for success/failure URLs
const deepLink = new URL(makeRedirectUri({ preferLocalhost: false }));
if (!deepLink.hostname) {
deepLink.hostname = 'localhost';
}
console.log("deeplink: ", deepLink)
const scheme = `${deepLink.protocol}//`; // e.g. 'exp://' or 'playground://'
console.log("scheme: ", scheme)
// Start OAuth flow
const loginUrl = await account.createOAuth2Token(
provider,
`${deepLink}`,
`${deepLink}`,
);
console.log("loginUrl: ", loginUrl)
// Open loginUrl and listen for the scheme redirect
const result = await WebBrowser.openAuthSessionAsync(`${loginUrl}`, scheme);
console.log("openAuthSessionAsync: ", result)
// Extract credentials from OAuth redirect URL
const url = new URL(result.url);
const secret = url.searchParams.get('secret');
const userId = url.searchParams.get('userId');
console.log("url: ", url)
// Create session with OAuth credentials
const session = await account.createSession(userId, secret);
// Redirect as needed
console.log(session)
const profile = await account.get();
console.log(profile)
onSuccess(profile);
} catch (err) {
onError(err);
} finally {
setLoading(false);
}
};
Logs:
schemename is the placeholder for the actual name set for scheme in app.json
TypeScript
deeplink: "schemename://localhost"
scheme: schemename://
loginUrl: "https://cloud.appwrite.io/v1/account/tokens/oauth2/google?success=schemename%3A%2F%2Flocalhost&failure=schemename%3A%2F%2Flocalhost&project=projectId"
TL;DR
Developers are encountering a Google OAuth issue with a redirect_uri_mismatch. The code appears to be copied from the Appwrite docs. The issue seems to be related to the deep link and scheme used. The logs show the creation of the deep link and scheme. Checking if the scheme set in app.json matches the one passed in the code could resolve the redirect_uri_mismatch problem.Recommended threads
- Student plan issue
I am using GitHub student plan, I even got access to appwrite's mock phone number. but when I try to use it, it says the phone number limit has reached
- Getting "The current user has been block...
So today I want to deploy something to Appwrite but when I click Sign in with Github, it's redirect me to login site and in the url bar I see this `?error=%7B"m...
- Flutter OAuth2 does not attach Google se...
Hi Appwrite team, I’m using Appwrite Auth in a Flutter mobile app and trying to upgrade an anonymous user to Google OAuth. Docs say that if there is already a...