2016-03-19 21:37:04 +01:00
|
|
|
'use strict';
|
|
|
|
|
2016-06-12 20:11:43 +02:00
|
|
|
const router = require('../router.js');
|
2016-04-01 00:20:34 +02:00
|
|
|
const api = require('../api.js');
|
2016-04-07 19:03:49 +02:00
|
|
|
const events = require('../events.js');
|
2016-06-13 22:34:39 +02:00
|
|
|
const TopNavigation = require('../models/top_navigation.js');
|
2016-04-01 00:20:34 +02:00
|
|
|
const LoginView = require('../views/login_view.js');
|
2016-04-06 17:56:34 +02:00
|
|
|
const PasswordResetView = require('../views/password_reset_view.js');
|
2016-03-28 22:33:20 +02:00
|
|
|
|
2016-03-19 21:37:04 +01:00
|
|
|
class AuthController {
|
2016-04-01 00:20:34 +02:00
|
|
|
constructor() {
|
2016-05-20 21:35:12 +02:00
|
|
|
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-06 21:49:26 +02:00
|
|
|
registerRoutes() {
|
2016-06-12 20:11:43 +02:00
|
|
|
router.enter(
|
|
|
|
/\/password-reset\/([^:]+):([^:]+)$/,
|
2016-04-06 21:49:26 +02:00
|
|
|
(ctx, next) => {
|
2016-05-20 21:35:12 +02:00
|
|
|
this._passwordResetFinishRoute(ctx.params[0], ctx.params[1]);
|
2016-04-06 21:49:26 +02:00
|
|
|
});
|
2016-06-12 20:11:43 +02:00
|
|
|
router.enter(
|
|
|
|
'/password-reset',
|
|
|
|
(ctx, next) => { this._passwordResetRoute(); });
|
|
|
|
router.enter(
|
|
|
|
'/login',
|
|
|
|
(ctx, next) => { this._loginRoute(); });
|
|
|
|
router.enter(
|
|
|
|
'/logout',
|
|
|
|
(ctx, next) => { this._logoutRoute(); });
|
2016-04-06 21:49:26 +02:00
|
|
|
}
|
|
|
|
|
2016-05-20 21:35:12 +02:00
|
|
|
_loginRoute() {
|
2016-05-08 17:25:55 +02:00
|
|
|
api.forget();
|
2016-06-13 22:34:39 +02:00
|
|
|
TopNavigation.activate('login');
|
2016-05-20 21:35:12 +02:00
|
|
|
this._loginView.render({
|
2016-03-30 21:01:18 +02:00
|
|
|
login: (name, password, doRemember) => {
|
2016-03-28 22:33:20 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
2016-04-09 19:53:53 +02:00
|
|
|
api.forget();
|
2016-04-08 10:01:32 +02:00
|
|
|
api.login(name, password, doRemember)
|
2016-03-30 21:01:18 +02:00
|
|
|
.then(() => {
|
2016-03-28 22:33:20 +02:00
|
|
|
resolve();
|
2016-06-12 20:11:43 +02:00
|
|
|
router.show('/');
|
2016-04-07 19:03:49 +02:00
|
|
|
events.notify(events.Success, 'Logged in');
|
2016-04-09 23:41:56 +02:00
|
|
|
}, errorMessage => {
|
2016-04-08 13:17:00 +02:00
|
|
|
reject(errorMessage);
|
|
|
|
events.notify(events.Error, errorMessage);
|
|
|
|
});
|
2016-03-28 22:33:20 +02:00
|
|
|
});
|
2016-03-28 00:19:44 +02:00
|
|
|
}});
|
2016-03-19 21:37:04 +01:00
|
|
|
}
|
|
|
|
|
2016-05-20 21:35:12 +02:00
|
|
|
_logoutRoute() {
|
2016-04-09 19:53:53 +02:00
|
|
|
api.forget();
|
2016-04-01 00:20:34 +02:00
|
|
|
api.logout();
|
2016-06-12 20:11:43 +02:00
|
|
|
router.show('/');
|
2016-04-07 19:03:49 +02:00
|
|
|
events.notify(events.Success, 'Logged out');
|
2016-03-19 21:37:04 +01:00
|
|
|
}
|
2016-04-06 17:56:34 +02:00
|
|
|
|
2016-05-20 21:35:12 +02:00
|
|
|
_passwordResetRoute() {
|
2016-06-13 22:34:39 +02:00
|
|
|
TopNavigation.activate('login');
|
2016-05-20 21:35:12 +02:00
|
|
|
this._passwordResetView.render({
|
2016-04-08 13:17:00 +02:00
|
|
|
proceed: (...args) => {
|
|
|
|
return this._passwordReset(...args);
|
2016-04-06 17:56:34 +02:00
|
|
|
}});
|
|
|
|
}
|
|
|
|
|
2016-05-20 21:35:12 +02:00
|
|
|
_passwordResetFinishRoute(name, token) {
|
2016-04-09 19:53:53 +02:00
|
|
|
api.forget();
|
2016-04-06 17:56:34 +02:00
|
|
|
api.logout();
|
|
|
|
api.post('/password-reset/' + name, {token: token})
|
|
|
|
.then(response => {
|
|
|
|
const password = response.password;
|
2016-04-09 23:41:56 +02:00
|
|
|
return api.login(name, password, false);
|
|
|
|
}, response => {
|
|
|
|
return Promise.reject(response.description);
|
|
|
|
}).then(() => {
|
2016-06-12 20:11:43 +02:00
|
|
|
router.show('/');
|
2016-04-09 23:41:56 +02:00
|
|
|
events.notify(events.Success, 'New password: ' + password);
|
|
|
|
}, errorMessage => {
|
2016-06-12 20:11:43 +02:00
|
|
|
router.show('/');
|
2016-04-09 23:41:56 +02:00
|
|
|
events.notify(events.Error, errorMessage);
|
2016-04-06 17:56:34 +02:00
|
|
|
});
|
|
|
|
}
|
2016-04-08 13:17:00 +02:00
|
|
|
|
|
|
|
_passwordReset(nameOrEmail) {
|
2016-04-09 19:53:53 +02:00
|
|
|
api.forget();
|
2016-04-08 13:17:00 +02:00
|
|
|
api.logout();
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
api.get('/password-reset/' + nameOrEmail)
|
|
|
|
.then(() => {
|
|
|
|
resolve();
|
|
|
|
events.notify(
|
|
|
|
events.Success,
|
|
|
|
'E-mail has been sent. To finish the procedure, ' +
|
|
|
|
'please click the link it contains.');
|
2016-04-09 23:41:56 +02:00
|
|
|
}, response => {
|
2016-04-08 13:17:00 +02:00
|
|
|
reject();
|
|
|
|
events.notify(events.Error, response.description);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2016-03-19 21:37:04 +01:00
|
|
|
}
|
|
|
|
|
2016-04-01 00:20:34 +02:00
|
|
|
module.exports = new AuthController();
|