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

* Add files via upload * Create linode-setup.md * Create cloudflare-setup.md * Update cloudflare-setup.md * Delete 4-linode.png * Delete 3-linode.png * Add files via upload * Add files via upload * Update cloudflare-setup.md * Update linode-setup.md * Rename cloudflare-setup.md to cloudflare.md * Rename linode-setup.md to linode.md * Update mkdocs.yml * Update cloudflare.md * Update linode.md * Update README.md * Update README.md * Update linode.md sentence in Italian * v1 The frontend has been completed, along with the .env variables. However, there is an issue of infinite loading thereafter. * Fix email and remove deprecated GitHub passport * Update user_auth_system.md add How to Set Up a Github Authentication * Update .env.example Improved the comment above the GitHub client ID and secret. * Update user_auth_system.md * Update package.json * Remove unnecessary passport GitHub package * fixed conflicts fixed conflicts between Berry-13:main and danny-avila:main in api/server/index.js 45:54 * Delete e -i HEAD~2 * (WIP) Discord Login * Fix duplicate githubLoginEnabled * .env.example restore * Update user_auth_system.md Discord Login * Fix and new Feature 1. Added Discord login to .env.example. 2. Created Google, Github, and Discord icons in client\src\components\svg. 3. Added the social login option in the .env file; it fixes the ---or---. Check Discord for more information. * fix Login.tsx and Registration.tsx * Update user_auth_system.md * Update .env.example * Added OpenID Icon * quick discord icon fix * discord strategy fix * remove comment * fix discord authorize every time
51 lines
1.6 KiB
JavaScript
51 lines
1.6 KiB
JavaScript
const passport = require('passport');
|
|
const { Strategy: DiscordStrategy } = require('passport-discord');
|
|
const User = require('../models/User');
|
|
const config = require('../../config/loader');
|
|
const domains = config.domains;
|
|
|
|
const discordLogin = new DiscordStrategy(
|
|
{
|
|
clientID: process.env.DISCORD_CLIENT_ID,
|
|
clientSecret: process.env.DISCORD_CLIENT_SECRET,
|
|
callbackURL: `${domains.server}${process.env.DISCORD_CALLBACK_URL}`,
|
|
scope: ['identify', 'email'], // Request scopes
|
|
authorizationURL: 'https://discord.com/api/oauth2/authorize?prompt=none' // Add the prompt query parameter
|
|
},
|
|
async (accessToken, refreshToken, profile, cb) => {
|
|
try {
|
|
const email = profile.email;
|
|
const discordId = profile.id;
|
|
|
|
const oldUser = await User.findOne({ email });
|
|
if (oldUser) {
|
|
return cb(null, oldUser);
|
|
}
|
|
|
|
let avatarURL;
|
|
if (profile.avatar) {
|
|
const format = profile.avatar.startsWith('a_') ? 'gif' : 'png';
|
|
avatarURL = `https://cdn.discordapp.com/avatars/${profile.id}/${profile.avatar}.${format}`;
|
|
} else {
|
|
const defaultAvatarNum = Number(profile.discriminator) % 5;
|
|
avatarURL = `https://cdn.discordapp.com/embed/avatars/${defaultAvatarNum}.png`;
|
|
}
|
|
|
|
const newUser = await User.create({
|
|
provider: 'discord',
|
|
discordId,
|
|
username: profile.username,
|
|
email,
|
|
name: profile.global_name,
|
|
avatar: avatarURL
|
|
});
|
|
|
|
cb(null, newUser);
|
|
} catch (err) {
|
|
console.error(err);
|
|
cb(err);
|
|
}
|
|
}
|
|
);
|
|
|
|
passport.use(discordLogin);
|