-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
5cc4dc1
commit 792f767
Showing
3 changed files
with
1 addition
and
184 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -77,146 +77,12 @@ exports.logoutUser = async () => { | |
} | ||
}; | ||
|
||
exports.signInWithGoogle = async () => { | ||
try { | ||
const provider = new GoogleAuthProvider(); | ||
|
||
// Optional: Add any scopes you need | ||
provider.addScope('https://www.googleapis.com/auth/contacts.readonly'); | ||
|
||
// Optional: Customize OAuth parameters | ||
provider.setCustomParameters({ | ||
'login_hint': '[email protected]' | ||
}); | ||
|
||
const result = await signInWithPopup(auth, provider); | ||
|
||
// Get the user and OAuth credentials | ||
const user = result.user; | ||
const credential = GoogleAuthProvider.credentialFromResult(result); | ||
const token = credential.accessToken; | ||
|
||
if (!user) { | ||
throw new Error('Google Sign-In failed'); | ||
} | ||
|
||
const userId = user.uid; | ||
const username = user.displayName; | ||
|
||
// Create a new user node in Neo4j | ||
try { | ||
await createUserNode(userId, username); | ||
} catch (error) { | ||
// If Neo4j user creation fails, delete the created Firebase user | ||
await firebase.auth().deleteUser(userId); | ||
throw new Error('Failed to create user in Neo4j: ' + error.message); | ||
} | ||
|
||
// Generate a custom token for the user | ||
const customToken = await firebase.auth().createCustomToken(userId); | ||
|
||
return { user, customToken, token }; | ||
} catch (error) { | ||
throw error; | ||
} | ||
}; | ||
|
||
exports.signInWithFacebook = async () => { | ||
try { | ||
const provider = new FacebookAuthProvider(); | ||
|
||
// Optional: Add any scopes you need | ||
provider.addScope('user_birthday'); | ||
|
||
// Optional: Customize OAuth parameters | ||
provider.setCustomParameters({ | ||
'display': 'popup' | ||
}); | ||
|
||
const result = await signInWithPopup(auth, provider); | ||
|
||
// Get the user and OAuth credentials | ||
const user = result.user; | ||
const credential = FacebookAuthProvider.credentialFromResult(result); | ||
const accessToken = credential.accessToken; | ||
|
||
if (!user) { | ||
throw new Error('Facebook Sign-In failed'); | ||
} | ||
|
||
const userId = user.uid; | ||
const username = user.displayName; | ||
|
||
// Create a new user node in Neo4j | ||
try { | ||
await createUserNode(userId, username); | ||
} catch (error) { | ||
// If Neo4j user creation fails, delete the created Firebase user | ||
await firebase.auth().deleteUser(userId); | ||
throw new Error('Failed to create user in Neo4j: ' + error.message); | ||
} | ||
|
||
// Generate a custom token for the user | ||
const customToken = await firebase.auth().createCustomToken(userId); | ||
|
||
return { user, customToken, accessToken }; | ||
} catch (error) { | ||
throw error; | ||
} | ||
}; | ||
|
||
|
||
exports.signInWithApple = async () => { | ||
try { | ||
const auth = getAuth(); | ||
const provider = new OAuthProvider('apple.com'); | ||
|
||
// Optional: Add any scopes you need | ||
provider.addScope('email'); | ||
provider.addScope('name'); | ||
|
||
// Optional: Customize OAuth parameters | ||
provider.setCustomParameters({ | ||
// Apple sign-in doesn't have many parameters you can set, but you could customize if necessary | ||
}); | ||
|
||
const result = await signInWithPopup(auth, provider); | ||
|
||
// Get the user and OAuth credentials | ||
const user = result.user; | ||
const credential = OAuthProvider.credentialFromResult(result); | ||
const token = credential.accessToken; | ||
|
||
if (!user) { | ||
throw new Error('Apple Sign-In failed'); | ||
} | ||
|
||
const userId = user.uid; | ||
const username = user.displayName; | ||
|
||
// Create a new user node in Neo4j | ||
try { | ||
await createUserNode(userId, username); | ||
} catch (error) { | ||
// If Neo4j user creation fails, delete the created Firebase user | ||
await firebase.auth().deleteUser(userId); | ||
throw new Error('Failed to create user in Neo4j: ' + error.message); | ||
} | ||
|
||
// Generate a custom token for the user | ||
const customToken = await firebase.auth().createCustomToken(userId); | ||
|
||
return { user, customToken, token }; | ||
} catch (error) { | ||
throw error; | ||
} | ||
}; | ||
|
||
exports.checkEmailVerification = async () => { | ||
console.log("In checkEmailVerification service"); | ||
try { | ||
const user = auth.currentUser; | ||
if (user) { | ||
console.log("Verifying", user); | ||
console.log("User email verified: ", user.emailVerified); | ||
await user.reload(); // Reload user data from Firebase | ||
return user.emailVerified; | ||
|