framework/js/lib/Session.js

64 lines
1.4 KiB
JavaScript
Raw Normal View History

/**
* The `Session` class defines the current user session. It stores a reference
* to the current authenticated user, and provides methods to log in/out.
*/
export default class Session {
constructor(token, user) {
/**
* The current authenticated user.
*
* @type {User|null}
* @public
*/
this.user = user;
/**
* The token that was used for authentication.
*
* @type {String|null}
* @public
*/
this.token = token;
2015-04-25 20:58:39 +08:00
}
/**
* Attempt to log in a user.
*
* @param {String} identification The username/email.
* @param {String} password
* @param {Object} [options]
* @return {Promise}
* @public
*/
login(identification, password, options = {}) {
return app.request(Object.assign({
2015-04-25 20:58:39 +08:00
method: 'POST',
url: app.forum.attribute('baseUrl') + '/login',
data: {identification, password}
}, options))
.then(() => window.location.reload());
2015-04-25 20:58:39 +08:00
}
/**
* Log the user out.
*
* @public
*/
2015-04-25 20:58:39 +08:00
logout() {
window.location = app.forum.attribute('baseUrl') + '/logout?token=' + this.token;
2015-04-25 20:58:39 +08:00
}
/**
* Apply an authorization header with the current token to the given
* XMLHttpRequest object.
*
* @param {XMLHttpRequest} xhr
* @public
*/
2015-04-25 20:58:39 +08:00
authorize(xhr) {
if (this.token) {
xhr.setRequestHeader('Authorization', 'Token ' + this.token);
}
2015-04-25 20:58:39 +08:00
}
}