1
0
mirror of https://github.com/spacebarchat/server.git synced 2024-11-23 10:52:30 +01:00

🐛 fix login + register

This commit is contained in:
Flam3rboy 2021-03-04 22:00:17 +01:00
parent b5722fd3fd
commit 65eeb4d80a
2 changed files with 11 additions and 5 deletions

View File

@ -21,11 +21,14 @@ router.post(
}), }),
async (req: Request, res: Response) => { async (req: Request, res: Response) => {
const { login, password } = req.body; const { login, password } = req.body;
const email = adjustEmail(login);
const query: any[] = [{ phone: login }];
if (email) query.push({ email });
// * MongoDB Specific query for user with same email or phone number // * MongoDB Specific query for user with same email or phone number
const user = await UserModel.findOne( const user = await UserModel.findOne(
{ {
$or: [{ email: adjustEmail(login) }, { phone: login }], $or: query,
}, },
`hash id user_settings.locale user_settings.theme` `hash id user_settings.locale user_settings.theme`
).exec(); ).exec();

View File

@ -37,10 +37,10 @@ router.post(
} = req.body; } = req.body;
// TODO: automatically join invite // TODO: automatically join invite
// TODO: gift_code_sku_id? // TODO: gift_code_sku_id?
// TODO: check passwort strength // TODO: check password strength
// adjusted_email will be slightly modified version of the user supplied email -> e.g. protection against GMail Trick // adjusted_email will be slightly modified version of the user supplied email -> e.g. protection against GMail Trick
let adjusted_email: string = email; let adjusted_email: string | undefined = adjustEmail(email);
// adjusted_password will be the hash of the password // adjusted_password will be the hash of the password
let adjusted_password: string = ""; let adjusted_password: string = "";
@ -77,7 +77,7 @@ router.post(
if (email) { if (email) {
// replace all dots and chars after +, if its a gmail.com email // replace all dots and chars after +, if its a gmail.com email
adjusted_email = adjustEmail(email); if (!adjusted_email) throw FieldErrors({ email: { code: "INVALID_EMAIL", message: "Invalid Email format" } });
// check if there is already an account with this email // check if there is already an account with this email
const exists = await UserModel.findOne({ email: adjusted_email }).exec(); const exists = await UserModel.findOne({ email: adjusted_email }).exec();
@ -203,6 +203,7 @@ router.post(
enable_tts_command: true, enable_tts_command: true,
explicit_content_filter: 0, explicit_content_filter: 0,
friend_source_flags: { all: true }, friend_source_flags: { all: true },
gateway_connected: false,
gif_auto_play: true, gif_auto_play: true,
guild_folders: [], guild_folders: [],
guild_positions: [], guild_positions: [],
@ -230,9 +231,11 @@ router.post(
} }
); );
export function adjustEmail(email: string) { export function adjustEmail(email: string): string | undefined {
// body parser already checked if it is a valid email // body parser already checked if it is a valid email
const parts = <RegExpMatchArray>email.match(EMAIL_REGEX); const parts = <RegExpMatchArray>email.match(EMAIL_REGEX);
// @ts-ignore
if (!parts || parts.length < 5) return undefined;
const domain = parts[5]; const domain = parts[5];
const user = parts[1]; const user = parts[1];