2016-03-28 22:33:20 +02:00
|
|
|
'use strict';
|
|
|
|
|
2016-04-08 10:01:32 +02:00
|
|
|
const cookies = require('js-cookie');
|
2016-03-28 22:33:20 +02:00
|
|
|
const request = require('superagent');
|
|
|
|
const config = require('./config.js');
|
2016-04-07 19:03:49 +02:00
|
|
|
const events = require('./events.js');
|
2016-03-28 22:33:20 +02:00
|
|
|
|
|
|
|
class Api {
|
2016-03-30 20:45:37 +02:00
|
|
|
constructor() {
|
2016-03-30 22:05:57 +02:00
|
|
|
this.user = null;
|
2016-03-30 20:45:37 +02:00
|
|
|
this.userName = null;
|
|
|
|
this.userPassword = null;
|
|
|
|
}
|
|
|
|
|
2016-03-28 22:33:20 +02:00
|
|
|
get(url) {
|
|
|
|
const fullUrl = this.getFullUrl(url);
|
2016-03-30 21:01:18 +02:00
|
|
|
return this._process(fullUrl, () => request.get(fullUrl));
|
2016-03-28 22:33:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
post(url, data) {
|
|
|
|
const fullUrl = this.getFullUrl(url);
|
2016-03-30 21:01:18 +02:00
|
|
|
return this._process(fullUrl, () => request.post(fullUrl).send(data));
|
2016-03-28 22:33:20 +02:00
|
|
|
}
|
|
|
|
|
2016-04-07 22:54:45 +02:00
|
|
|
put(url, data) {
|
|
|
|
const fullUrl = this.getFullUrl(url);
|
|
|
|
return this._process(fullUrl, () => request.put(fullUrl).send(data));
|
|
|
|
}
|
|
|
|
|
2016-03-30 21:01:18 +02:00
|
|
|
_process(url, requestFactory) {
|
2016-03-28 22:33:20 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
let req = requestFactory();
|
|
|
|
if (this.userName && this.userPassword) {
|
|
|
|
req.auth(this.userName, this.userPassword);
|
|
|
|
}
|
|
|
|
req.set('Accept', 'application/json')
|
|
|
|
.end((error, response) => {
|
|
|
|
if (error) {
|
2016-04-02 18:57:17 +02:00
|
|
|
reject(response && response.body ? response.body : {
|
|
|
|
'title': 'Networking error',
|
|
|
|
'description': error.message});
|
2016-03-28 22:33:20 +02:00
|
|
|
} else {
|
|
|
|
resolve(response.body);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-03-30 22:05:57 +02:00
|
|
|
hasPrivilege(lookup) {
|
|
|
|
let minViableRank = null;
|
|
|
|
for (let privilege of Object.keys(config.privileges)) {
|
|
|
|
if (!privilege.startsWith(lookup)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
const rankName = config.privileges[privilege];
|
2016-04-06 20:38:45 +02:00
|
|
|
const rankIndex = config.ranks.indexOf(rankName);
|
2016-03-30 22:05:57 +02:00
|
|
|
if (minViableRank === null || rankIndex < minViableRank) {
|
|
|
|
minViableRank = rankIndex;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (minViableRank === null) {
|
|
|
|
console.error('Bad privilege name: ' + lookup);
|
|
|
|
}
|
|
|
|
let myRank = this.user !== null ?
|
2016-04-06 20:38:45 +02:00
|
|
|
config.ranks.indexOf(this.user.rank) :
|
2016-03-30 22:05:57 +02:00
|
|
|
0;
|
|
|
|
return myRank >= minViableRank;
|
2016-03-30 20:45:37 +02:00
|
|
|
}
|
|
|
|
|
2016-04-08 10:01:32 +02:00
|
|
|
loginFromCookies() {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
const auth = cookies.getJSON('auth');
|
|
|
|
if (auth && auth.user && auth.password) {
|
|
|
|
this.login(auth.user, auth.password, true)
|
|
|
|
.then(resolve)
|
|
|
|
.catch(errorMessage => {
|
|
|
|
reject(errorMessage);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
login(userName, userPassword, doRemember) {
|
|
|
|
cookies.remove('auth');
|
2016-03-30 21:01:18 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
this.userName = userName;
|
|
|
|
this.userPassword = userPassword;
|
2016-04-03 15:12:15 +02:00
|
|
|
this.get('/user/' + userName + '?bump-login=true')
|
2016-03-30 22:05:57 +02:00
|
|
|
.then(response => {
|
2016-04-08 10:01:32 +02:00
|
|
|
const options = {};
|
|
|
|
if (doRemember) {
|
|
|
|
options.expires = 365;
|
|
|
|
}
|
|
|
|
cookies.set(
|
|
|
|
'auth',
|
|
|
|
{'user': userName, 'password': userPassword},
|
|
|
|
options);
|
2016-03-30 22:05:57 +02:00
|
|
|
this.user = response.user;
|
|
|
|
resolve();
|
2016-04-07 19:03:49 +02:00
|
|
|
events.notify(events.Authentication);
|
2016-03-30 22:05:57 +02:00
|
|
|
}).catch(response => {
|
2016-03-30 21:01:18 +02:00
|
|
|
reject(response.description);
|
|
|
|
this.logout();
|
2016-04-07 19:03:49 +02:00
|
|
|
events.notify(events.Authentication);
|
2016-03-30 21:01:18 +02:00
|
|
|
});
|
|
|
|
});
|
2016-03-30 20:45:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
logout() {
|
2016-04-08 10:01:32 +02:00
|
|
|
cookies.remove('auth');
|
2016-04-01 13:09:07 +02:00
|
|
|
this.user = null;
|
2016-03-30 20:45:37 +02:00
|
|
|
this.userName = null;
|
|
|
|
this.userPassword = null;
|
2016-04-07 19:03:49 +02:00
|
|
|
events.notify(events.Authentication);
|
2016-03-30 20:45:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
isLoggedIn() {
|
|
|
|
return this.userName !== null;
|
|
|
|
}
|
|
|
|
|
2016-03-28 22:33:20 +02:00
|
|
|
getFullUrl(url) {
|
2016-04-06 20:38:45 +02:00
|
|
|
return (config.apiUrl + '/' + url).replace(/([^:])\/+/g, '$1/');
|
2016-03-28 22:33:20 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-01 00:20:34 +02:00
|
|
|
module.exports = new Api();
|