front/auth: implement cookie support

This commit is contained in:
rr- 2016-03-30 21:01:18 +02:00
parent e95ed4cc0b
commit bb474e4cf5
3 changed files with 38 additions and 16 deletions

View File

@ -13,6 +13,7 @@
"handlebars": "^4.0.5",
"html-minifier": "^1.3.1",
"ini": "^1.3.4",
"js-cookie": "^2.1.0",
"merge": "^1.2.0",
"page": "^1.7.1",
"superagent": "^1.8.3",

View File

@ -11,15 +11,15 @@ class Api {
get(url) {
const fullUrl = this.getFullUrl(url);
return this.process(fullUrl, () => request.get(fullUrl));
return this._process(fullUrl, () => request.get(fullUrl));
}
post(url, data) {
const fullUrl = this.getFullUrl(url);
return this.process(fullUrl, () => request.post(fullUrl).send(data));
return this._process(fullUrl, () => request.post(fullUrl).send(data));
}
process(url, requestFactory) {
_process(url, requestFactory) {
return new Promise((resolve, reject) => {
let req = requestFactory();
if (this.userName && this.userPassword) {
@ -42,8 +42,16 @@ class Api {
}
login(userName, userPassword) {
return new Promise((resolve, reject) => {
this.userName = userName;
this.userPassword = userPassword;
this.get('/user/' + userName)
.then(() => { resolve(); })
.catch(response => {
reject(response.description);
this.logout();
});
});
}
logout() {

View File

@ -1,5 +1,6 @@
'use strict';
const cookies = require('js-cookie');
const page = require('page');
const config = require('../config.js');
@ -8,32 +9,44 @@ class AuthController {
this.api = api;
this.topNavigationController = topNavigationController;
this.loginView = loginView;
/* TODO: load from cookies */
const auth = cookies.getJSON('auth');
if (auth && auth.user && auth.password) {
this.api.login(auth.user, auth.password).catch(() => {
cookies.remove('auth');
/* TODO: notify the user what just happened */
});
}
}
loginRoute() {
this.topNavigationController.activate('login');
this.loginView.render({
login: (userName, userPassword, doRemember) => {
login: (name, password, doRemember) => {
return new Promise((resolve, reject) => {
this.api.login(userName, userPassword);
this.api.get('/user/' + userName)
.then(response => {
this.api.login(name, password)
.then(() => {
const options = {};
if (doRemember) {
/* TODO: set cookie */
options.expires = 365;
}
cookies.set(
'auth',
{'user': name, 'password': password},
options);
resolve();
page('/');
/* TODO: update top navigation */
})
.catch(response => { reject(response.description); });
/* TODO: notify top navigation */
}).catch(errorMessage => { reject(errorMessage); });
});
}});
}
logoutRoute() {
this.topNavigationController.activate('logout');
/* TODO: clear cookie */
this.api.logout();
cookies.remove('auth');
page('/');
/* TODO: notify top navigation */
}
}