mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 06:00:56 +02:00

* implemented Apple Auth login. Closes: #3438 TODO: - write config Doc * removed some comments * removed comment * Add unit tests for Apple login strategy Introduce comprehensive tests for the Apple login strategy, covering new user creation, existing user updates, and error handling scenarios during the authentication flow. Mocks implemented for external dependencies to ensure isolated testing. * Remove unnecessary blank line in socialLogins.js
53 lines
1.7 KiB
JavaScript
53 lines
1.7 KiB
JavaScript
const socialLogin = require('./socialLogin');
|
|
const { Strategy: AppleStrategy } = require('passport-apple');
|
|
const { logger } = require('~/config');
|
|
const jwt = require('jsonwebtoken');
|
|
|
|
/**
|
|
* Extract profile details from the decoded idToken
|
|
* @param {Object} params - Parameters from the verify callback
|
|
* @param {string} params.idToken - The ID token received from Apple
|
|
* @param {Object} params.profile - The profile object (may contain partial info)
|
|
* @returns {Object} - The extracted user profile details
|
|
*/
|
|
const getProfileDetails = ({ idToken, profile }) => {
|
|
if (!idToken) {
|
|
logger.error('idToken is missing');
|
|
throw new Error('idToken is missing');
|
|
}
|
|
|
|
const decoded = jwt.decode(idToken);
|
|
|
|
logger.debug(
|
|
`Decoded Apple JWT: ${JSON.stringify(decoded, null, 2)}`,
|
|
);
|
|
|
|
return {
|
|
email: decoded.email,
|
|
id: decoded.sub,
|
|
avatarUrl: null, // Apple does not provide an avatar URL
|
|
username: decoded.email
|
|
? decoded.email.split('@')[0].toLowerCase()
|
|
: `user_${decoded.sub}`,
|
|
name: decoded.name
|
|
? `${decoded.name.firstName} ${decoded.name.lastName}`
|
|
: profile.displayName || null,
|
|
emailVerified: true, // Apple verifies the email
|
|
};
|
|
};
|
|
|
|
// Initialize the social login handler for Apple
|
|
const appleLogin = socialLogin('apple', getProfileDetails);
|
|
|
|
module.exports = () =>
|
|
new AppleStrategy(
|
|
{
|
|
clientID: process.env.APPLE_CLIENT_ID,
|
|
teamID: process.env.APPLE_TEAM_ID,
|
|
callbackURL: `${process.env.DOMAIN_SERVER}${process.env.APPLE_CALLBACK_URL}`,
|
|
keyID: process.env.APPLE_KEY_ID,
|
|
privateKeyLocation: process.env.APPLE_PRIVATE_KEY_PATH,
|
|
passReqToCallback: false, // Set to true if you need to access the request in the callback
|
|
},
|
|
appleLogin,
|
|
);
|