2018-10-19 16:17:02 +01:00
|
|
|
// This is used by all acl routes to check whether
|
|
|
|
// acls are enabled on the server, and whether the user
|
|
|
|
// has a valid token
|
|
|
|
// Right now this is very acl specific, but is likely to be
|
|
|
|
// made a bit more less specific
|
2018-11-02 14:44:36 +00:00
|
|
|
|
|
|
|
export default function(isValidServerError, P = Promise) {
|
2018-10-19 16:17:02 +01:00
|
|
|
return function(obj) {
|
|
|
|
const propName = Object.keys(obj)[0];
|
|
|
|
const p = obj[propName];
|
|
|
|
let authorize;
|
|
|
|
let enable;
|
|
|
|
return {
|
|
|
|
isAuthorized: new P(function(resolve) {
|
|
|
|
authorize = function(bool) {
|
|
|
|
resolve(bool);
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
isEnabled: new P(function(resolve) {
|
|
|
|
enable = function(bool) {
|
|
|
|
resolve(bool);
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
[propName]: p
|
|
|
|
.catch(function(e) {
|
2018-12-04 17:04:01 +00:00
|
|
|
if (e.errors && e.errors[0]) {
|
|
|
|
switch (e.errors[0].status) {
|
|
|
|
case '500':
|
|
|
|
if (isValidServerError(e)) {
|
|
|
|
enable(true);
|
|
|
|
authorize(false);
|
|
|
|
} else {
|
|
|
|
enable(false);
|
|
|
|
authorize(false);
|
|
|
|
return P.reject(e);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '403':
|
2018-11-02 14:44:36 +00:00
|
|
|
enable(true);
|
|
|
|
authorize(false);
|
2018-12-04 17:04:01 +00:00
|
|
|
break;
|
|
|
|
case '401':
|
|
|
|
enable(false);
|
|
|
|
authorize(false);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
enable(false);
|
|
|
|
authorize(false);
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
return [];
|
2018-10-19 16:17:02 +01:00
|
|
|
}
|
2018-12-04 17:04:01 +00:00
|
|
|
enable(false);
|
|
|
|
authorize(false);
|
|
|
|
throw e;
|
2018-10-19 16:17:02 +01:00
|
|
|
})
|
|
|
|
.then(function(res) {
|
|
|
|
enable(true);
|
|
|
|
authorize(true);
|
|
|
|
return res;
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|