szurubooru/client/js/controllers/auth_controller.js

112 lines
3.9 KiB
JavaScript
Raw Normal View History

'use strict';
2016-03-30 21:01:18 +02:00
const cookies = require('js-cookie');
const page = require('page');
const api = require('../api.js');
2016-04-07 19:03:49 +02:00
const events = require('../events.js');
const topNavController = require('../controllers/top_nav_controller.js');
const LoginView = require('../views/login_view.js');
const PasswordResetView = require('../views/password_reset_view.js');
class AuthController {
constructor() {
this.loginView = new LoginView();
this.passwordResetView = new PasswordResetView();
2016-04-07 19:03:49 +02:00
}
2016-03-30 21:01:18 +02:00
2016-04-07 19:03:49 +02:00
login() {
return new Promise((resolve, reject) => {
const auth = cookies.getJSON('auth');
if (auth && auth.user && auth.password) {
api.login(auth.user, auth.password)
.then(resolve)
.catch(errorMessage => {
reject(errorMessage);
});
} else {
resolve();
}
});
}
registerRoutes() {
page(/\/password-reset\/([^:]+):([^:]+)$/,
(ctx, next) => {
this.passwordResetFinishRoute(ctx.params[0], ctx.params[1]);
});
page('/password-reset', (ctx, next) => { this.passwordResetRoute(); });
page('/login', (ctx, next) => { this.loginRoute(); });
page('/logout', (ctx, next) => { this.logoutRoute(); });
}
loginRoute() {
topNavController.activate('login');
2016-03-28 00:19:44 +02:00
this.loginView.render({
2016-03-30 21:01:18 +02:00
login: (name, password, doRemember) => {
return new Promise((resolve, reject) => {
cookies.remove('auth');
api.login(name, password)
2016-03-30 21:01:18 +02:00
.then(() => {
const options = {};
if (doRemember) {
2016-03-30 21:01:18 +02:00
options.expires = 365;
}
2016-03-30 21:01:18 +02:00
cookies.set(
'auth',
{'user': name, 'password': password},
options);
resolve();
page('/');
2016-04-07 19:03:49 +02:00
events.notify(events.Success, 'Logged in');
2016-03-30 21:01:18 +02:00
}).catch(errorMessage => { reject(errorMessage); });
});
2016-03-28 00:19:44 +02:00
}});
}
logoutRoute() {
api.logout();
2016-03-30 21:01:18 +02:00
cookies.remove('auth');
page('/');
2016-04-07 19:03:49 +02:00
events.notify(events.Success, 'Logged out');
}
passwordResetRoute() {
topNavController.activate('login');
this.passwordResetView.render({
proceed: nameOrEmail => {
api.logout();
cookies.remove('auth');
return new Promise((resolve, reject) => {
api.get('/password-reset/' + nameOrEmail)
.then(() => { resolve(); })
.catch(errorMessage => { reject(errorMessage); });
});
}});
}
passwordResetFinishRoute(name, token) {
api.logout();
cookies.remove('auth');
api.post('/password-reset/' + name, {token: token})
.then(response => {
const password = response.password;
api.login(name, password)
.then(() => {
cookies.set(
'auth', {'user': name, 'password': password}, {});
page('/');
2016-04-07 19:03:49 +02:00
events.notify(events.Success,
'New password: ' + password);
}).catch(errorMessage => {
page('/');
2016-04-07 19:03:49 +02:00
events.notify(events.Error, errorMessage);
});
}).catch(response => {
page('/');
2016-04-07 19:03:49 +02:00
events.notify(events.Error, response.description);
});
}
}
module.exports = new AuthController();