mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 00:40:14 +01:00
* feat: basic invite-user script * feat: add invite user functionality and registration validation middleware * fix: invite user fixes * refactor: consolidate direct model access to a central place of functions * style(Registration): add spinner to continue button * refactor: import ordrer * feat: improve invite user script and error handling * fix: merge conflict * refactor: remove `console.log` and use `logger` * fix: token operation and checkinvite issues * bring back comment and remove console log * fix: return invalid token when token is not found * fix: getInvite fix * refactor: Update Token.js to use async/await syntax for update and delete operations * feat: Refactor Token.js to use async/await syntax for createToken and findToken functions * refactor(inviteUser): define functions outside of module.exports * Update AuthService.js --------- Co-authored-by: Danny Avila <danny@librechat.ai>
70 lines
2.1 KiB
JavaScript
70 lines
2.1 KiB
JavaScript
const crypto = require('crypto');
|
|
const bcrypt = require('bcryptjs');
|
|
const mongoose = require('mongoose');
|
|
const { createToken, findToken } = require('./Token');
|
|
const logger = require('~/config/winston');
|
|
|
|
/**
|
|
* @module inviteUser
|
|
* @description This module provides functions to create and get user invites
|
|
*/
|
|
|
|
/**
|
|
* @function createInvite
|
|
* @description This function creates a new user invite
|
|
* @param {string} email - The email of the user to invite
|
|
* @returns {Promise<Object>} A promise that resolves to the saved invite document
|
|
* @throws {Error} If there is an error creating the invite
|
|
*/
|
|
const createInvite = async (email) => {
|
|
try {
|
|
let token = crypto.randomBytes(32).toString('hex');
|
|
const hash = bcrypt.hashSync(token, 10);
|
|
const encodedToken = encodeURIComponent(token);
|
|
|
|
const fakeUserId = new mongoose.Types.ObjectId();
|
|
|
|
await createToken({
|
|
userId: fakeUserId,
|
|
email,
|
|
token: hash,
|
|
createdAt: Date.now(),
|
|
expiresIn: 604800,
|
|
});
|
|
|
|
return encodedToken;
|
|
} catch (error) {
|
|
logger.error('[createInvite] Error creating invite', error);
|
|
return { message: 'Error creating invite' };
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @function getInvite
|
|
* @description This function retrieves a user invite
|
|
* @param {string} encodedToken - The token of the invite to retrieve
|
|
* @param {string} email - The email of the user to validate
|
|
* @returns {Promise<Object>} A promise that resolves to the retrieved invite document
|
|
* @throws {Error} If there is an error retrieving the invite, if the invite does not exist, or if the email does not match
|
|
*/
|
|
const getInvite = async (encodedToken, email) => {
|
|
try {
|
|
const token = decodeURIComponent(encodedToken);
|
|
const hash = bcrypt.hashSync(token, 10);
|
|
const invite = await findToken({ token: hash, email });
|
|
|
|
if (!invite) {
|
|
throw new Error('Invite not found or email does not match');
|
|
}
|
|
|
|
return invite;
|
|
} catch (error) {
|
|
logger.error('[getInvite] Error getting invite', error);
|
|
return { error: true, message: error.message };
|
|
}
|
|
};
|
|
|
|
module.exports = {
|
|
createInvite,
|
|
getInvite,
|
|
};
|