aboutsummaryrefslogtreecommitdiff
path: root/src/server/authentication/AuthenticationManager.ts
diff options
context:
space:
mode:
authorbobzel <zzzman@gmail.com>2022-07-07 13:02:33 -0400
committerbobzel <zzzman@gmail.com>2022-07-07 13:02:33 -0400
commitdd16695b0c5fe8c54bc276a230381ae36e19e5ac (patch)
tree0544131ca2fb0d6f3cfae81aa5bbbb8b603b61ac /src/server/authentication/AuthenticationManager.ts
parenta9f704fbd5676bb9a8adf4c4f7ea61bf9b3f7603 (diff)
trying to fix errors in compiles
Diffstat (limited to 'src/server/authentication/AuthenticationManager.ts')
-rw-r--r--src/server/authentication/AuthenticationManager.ts306
1 files changed, 165 insertions, 141 deletions
diff --git a/src/server/authentication/AuthenticationManager.ts b/src/server/authentication/AuthenticationManager.ts
index b736f0d35..3622be4c5 100644
--- a/src/server/authentication/AuthenticationManager.ts
+++ b/src/server/authentication/AuthenticationManager.ts
@@ -1,14 +1,14 @@
-import { default as User, DashUserModel } from "./DashUserModel";
-import { Request, Response, NextFunction } from "express";
-import * as passport from "passport";
-import { IVerifyOptions } from "passport-local";
-import "./Passport";
-import flash = require("express-flash");
+import { default as User, DashUserModel } from './DashUserModel';
+import { Request, Response, NextFunction } from 'express';
+import * as passport from 'passport';
+import { IVerifyOptions } from 'passport-local';
+import './Passport';
+import flash = require('express-flash');
import * as async from 'async';
import * as nodemailer from 'nodemailer';
-import c = require("crypto");
-import { Utils } from "../../Utils";
-import { MailOptions } from "nodemailer/lib/stream-transport";
+import c = require('crypto');
+import { emptyFunction, Utils } from '../../Utils';
+import { MailOptions } from 'nodemailer/lib/stream-transport';
/**
* GET /signup
@@ -17,10 +17,10 @@ import { MailOptions } from "nodemailer/lib/stream-transport";
*/
export let getSignup = (req: Request, res: Response) => {
if (req.user) {
- return res.redirect("/home");
+ return res.redirect('/home');
}
- res.render("signup.pug", {
- title: "Sign Up",
+ res.render('signup.pug', {
+ title: 'Sign Up',
user: req.user,
});
};
@@ -30,15 +30,15 @@ export let getSignup = (req: Request, res: Response) => {
* Create a new local account.
*/
export let postSignup = (req: Request, res: Response, next: NextFunction) => {
- req.assert("email", "Email is not valid").isEmail();
- req.assert("password", "Password must be at least 4 characters long").len({ min: 4 });
- req.assert("confirmPassword", "Passwords do not match").equals(req.body.password);
- req.sanitize("email").normalizeEmail({ gmail_remove_dots: false });
+ req.assert('email', 'Email is not valid').isEmail();
+ req.assert('password', 'Password must be at least 4 characters long').len({ min: 4 });
+ req.assert('confirmPassword', 'Passwords do not match').equals(req.body.password);
+ req.sanitize('email').normalizeEmail({ gmail_remove_dots: false });
const errors = req.validationErrors();
if (errors) {
- return res.redirect("/signup");
+ return res.redirect('/signup');
}
const email = req.body.email as String;
@@ -50,25 +50,30 @@ export let postSignup = (req: Request, res: Response, next: NextFunction) => {
userDocumentId: Utils.GenerateGuid(),
sharingDocumentId: Utils.GenerateGuid(),
linkDatabaseId: Utils.GenerateGuid(),
- cacheDocumentIds: ""
+ cacheDocumentIds: '',
} as Partial<DashUserModel>;
const user = new User(model);
User.findOne({ email }, (err: any, existingUser: any) => {
- if (err) { return next(err); }
+ if (err) {
+ return next(err);
+ }
if (existingUser) {
- return res.redirect("/login");
+ return res.redirect('/login');
}
user.save((err: any) => {
- if (err) { return next(err); }
- req.logIn(user, (err) => {
- if (err) { return next(err); }
+ if (err) {
+ return next(err);
+ }
+ req.logIn(user, err => {
+ if (err) {
+ return next(err);
+ }
tryRedirectToTarget(req, res);
});
});
});
-
};
const tryRedirectToTarget = (req: Request, res: Response) => {
@@ -76,11 +81,10 @@ const tryRedirectToTarget = (req: Request, res: Response) => {
if (req.session && target) {
res.redirect(target);
} else {
- res.redirect("/home");
+ res.redirect('/home');
}
};
-
/**
* GET /login
* Login page.
@@ -88,11 +92,11 @@ const tryRedirectToTarget = (req: Request, res: Response) => {
export let getLogin = (req: Request, res: Response) => {
if (req.user) {
//req.session.target = undefined;
- return res.redirect("/home");
+ return res.redirect('/home');
}
- res.render("login.pug", {
- title: "Log In",
- user: req.user
+ res.render('login.pug', {
+ title: 'Log In',
+ user: req.user,
});
};
@@ -102,24 +106,30 @@ export let getLogin = (req: Request, res: Response) => {
* On failure, redirect to signup page
*/
export let postLogin = (req: Request, res: Response, next: NextFunction) => {
- req.assert("email", "Email is not valid").isEmail();
- req.assert("password", "Password cannot be blank").notEmpty();
- req.sanitize("email").normalizeEmail({ gmail_remove_dots: false });
+ req.assert('email', 'Email is not valid').isEmail();
+ req.assert('password', 'Password cannot be blank').notEmpty();
+ req.sanitize('email').normalizeEmail({ gmail_remove_dots: false });
const errors = req.validationErrors();
if (errors) {
- req.flash("errors", "Unable to login at this time. Please try again.");
- return res.redirect("/signup");
+ req.flash('errors', 'Unable to login at this time. Please try again.');
+ return res.redirect('/signup');
}
- passport.authenticate("local", (err: Error, user: DashUserModel, _info: IVerifyOptions) => {
- if (err) { next(err); return; }
+ passport.authenticate('local', (err: Error, user: DashUserModel, _info: IVerifyOptions) => {
+ if (err) {
+ next(err);
+ return;
+ }
if (!user) {
- return res.redirect("/signup");
+ return res.redirect('/signup');
}
- req.logIn(user, (err) => {
- if (err) { next(err); return; }
+ req.logIn(user, err => {
+ if (err) {
+ next(err);
+ return;
+ }
tryRedirectToTarget(req, res);
});
})(req, res, next);
@@ -131,140 +141,154 @@ export let postLogin = (req: Request, res: Response, next: NextFunction) => {
* and destroys the user's current session.
*/
export let getLogout = (req: Request, res: Response) => {
- req.logout();
+ req.logout(emptyFunction);
const sess = req.session;
if (sess) {
- sess.destroy((err) => { if (err) { console.log(err); } });
+ sess.destroy(err => {
+ if (err) {
+ console.log(err);
+ }
+ });
}
- res.redirect("/login");
+ res.redirect('/login');
};
export let getForgot = function (req: Request, res: Response) {
- res.render("forgot.pug", {
- title: "Recover Password",
+ res.render('forgot.pug', {
+ title: 'Recover Password',
user: req.user,
});
};
export let postForgot = function (req: Request, res: Response, next: NextFunction) {
const email = req.body.email;
- async.waterfall([
- function (done: any) {
- c.randomBytes(20, function (err: any, buffer: Buffer) {
- if (err) {
- done(null);
- return;
- }
- done(null, buffer.toString('hex'));
- });
- },
- function (token: string, done: any) {
- User.findOne({ email }, function (err: any, user: DashUserModel) {
- if (!user) {
- // NO ACCOUNT WITH SUBMITTED EMAIL
- res.redirect("/forgotPassword");
- return;
- }
- user.passwordResetToken = token;
- user.passwordResetExpires = new Date(Date.now() + 3600000); // 1 HOUR
- user.save(function (err: any) {
- done(null, token, user);
+ async.waterfall(
+ [
+ function (done: any) {
+ c.randomBytes(20, function (err: any, buffer: Buffer) {
+ if (err) {
+ done(null);
+ return;
+ }
+ done(null, buffer.toString('hex'));
});
- });
- },
- function (token: Uint16Array, user: DashUserModel, done: any) {
- const smtpTransport = nodemailer.createTransport({
- service: 'Gmail',
- auth: {
- user: 'browndashptc@gmail.com',
- pass: 'TsarNicholas#2'
- }
- });
- const mailOptions = {
- to: user.email,
- from: 'browndashptc@gmail.com',
- subject: 'Dash Password Reset',
- text: 'You are receiving this because you (or someone else) have requested the reset of the password for your account.\n\n' +
- 'Please click on the following link, or paste this into your browser to complete the process:\n\n' +
- 'http://' + req.headers.host + '/resetPassword/' + token + '\n\n' +
- 'If you did not request this, please ignore this email and your password will remain unchanged.\n'
- } as MailOptions;
- smtpTransport.sendMail(mailOptions, function (err: Error | null) {
- // req.flash('info', 'An e-mail has been sent to ' + user.email + ' with further instructions.');
- done(null, err, 'done');
- });
+ },
+ function (token: string, done: any) {
+ User.findOne({ email }, function (err: any, user: DashUserModel) {
+ if (!user) {
+ // NO ACCOUNT WITH SUBMITTED EMAIL
+ res.redirect('/forgotPassword');
+ return;
+ }
+ user.passwordResetToken = token;
+ user.passwordResetExpires = new Date(Date.now() + 3600000); // 1 HOUR
+ user.save(function (err: any) {
+ done(null, token, user);
+ });
+ });
+ },
+ function (token: Uint16Array, user: DashUserModel, done: any) {
+ const smtpTransport = nodemailer.createTransport({
+ service: 'Gmail',
+ auth: {
+ user: 'browndashptc@gmail.com',
+ pass: 'TsarNicholas#2',
+ },
+ });
+ const mailOptions = {
+ to: user.email,
+ from: 'browndashptc@gmail.com',
+ subject: 'Dash Password Reset',
+ text:
+ 'You are receiving this because you (or someone else) have requested the reset of the password for your account.\n\n' +
+ 'Please click on the following link, or paste this into your browser to complete the process:\n\n' +
+ 'http://' +
+ req.headers.host +
+ '/resetPassword/' +
+ token +
+ '\n\n' +
+ 'If you did not request this, please ignore this email and your password will remain unchanged.\n',
+ } as MailOptions;
+ smtpTransport.sendMail(mailOptions, function (err: Error | null) {
+ // req.flash('info', 'An e-mail has been sent to ' + user.email + ' with further instructions.');
+ done(null, err, 'done');
+ });
+ },
+ ],
+ function (err) {
+ if (err) return next(err);
+ res.redirect('/forgotPassword');
}
- ], function (err) {
- if (err) return next(err);
- res.redirect("/forgotPassword");
- });
+ );
};
export let getReset = function (req: Request, res: Response) {
User.findOne({ passwordResetToken: req.params.token, passwordResetExpires: { $gt: Date.now() } }, function (err: any, user: DashUserModel) {
if (!user || err) {
- return res.redirect("/forgotPassword");
+ return res.redirect('/forgotPassword');
}
- res.render("reset.pug", {
- title: "Reset Password",
+ res.render('reset.pug', {
+ title: 'Reset Password',
user: req.user,
});
});
};
export let postReset = function (req: Request, res: Response) {
- async.waterfall([
- function (done: any) {
- User.findOne({ passwordResetToken: req.params.token, passwordResetExpires: { $gt: Date.now() } }, function (err: any, user: DashUserModel) {
- if (!user || err) {
- return res.redirect('back');
- }
+ async.waterfall(
+ [
+ function (done: any) {
+ User.findOne({ passwordResetToken: req.params.token, passwordResetExpires: { $gt: Date.now() } }, function (err: any, user: DashUserModel) {
+ if (!user || err) {
+ return res.redirect('back');
+ }
- req.assert("password", "Password must be at least 4 characters long").len({ min: 4 });
- req.assert("confirmPassword", "Passwords do not match").equals(req.body.password);
+ req.assert('password', 'Password must be at least 4 characters long').len({ min: 4 });
+ req.assert('confirmPassword', 'Passwords do not match').equals(req.body.password);
- if (req.validationErrors()) {
- return res.redirect('back');
- }
+ if (req.validationErrors()) {
+ return res.redirect('back');
+ }
- user.password = req.body.password;
- user.passwordResetToken = undefined;
- user.passwordResetExpires = undefined;
+ user.password = req.body.password;
+ user.passwordResetToken = undefined;
+ user.passwordResetExpires = undefined;
- user.save(function (err) {
- if (err) {
- res.redirect("/login");
- return;
- }
- req.logIn(user, function (err) {
+ user.save(function (err) {
if (err) {
+ res.redirect('/login');
return;
}
+ req.logIn(user, function (err) {
+ if (err) {
+ return;
+ }
+ });
+ done(null, user);
});
- done(null, user);
});
- });
- },
- function (user: DashUserModel, done: any) {
- const smtpTransport = nodemailer.createTransport({
- service: 'Gmail',
- auth: {
- user: 'browndashptc@gmail.com',
- pass: 'TsarNicholas#2'
- }
- });
- const mailOptions = {
- to: user.email,
- from: 'browndashptc@gmail.com',
- subject: 'Your password has been changed',
- text: 'Hello,\n\n' +
- 'This is a confirmation that the password for your account ' + user.email + ' has just been changed.\n'
- } as MailOptions;
- smtpTransport.sendMail(mailOptions, function (err) {
- done(null, err);
- });
+ },
+ function (user: DashUserModel, done: any) {
+ const smtpTransport = nodemailer.createTransport({
+ service: 'Gmail',
+ auth: {
+ user: 'browndashptc@gmail.com',
+ pass: 'TsarNicholas#2',
+ },
+ });
+ const mailOptions = {
+ to: user.email,
+ from: 'browndashptc@gmail.com',
+ subject: 'Your password has been changed',
+ text: 'Hello,\n\n' + 'This is a confirmation that the password for your account ' + user.email + ' has just been changed.\n',
+ } as MailOptions;
+ smtpTransport.sendMail(mailOptions, function (err) {
+ done(null, err);
+ });
+ },
+ ],
+ function (err) {
+ res.redirect('/login');
}
- ], function (err) {
- res.redirect("/login");
- });
-}; \ No newline at end of file
+ );
+};