obtain valid token on every API request

This commit is contained in:
Bilal Catic
2019-08-31 00:06:01 +02:00
parent 333733099b
commit d24913689d
3 changed files with 40 additions and 7 deletions

View File

@@ -1,7 +1,6 @@
BASIC_AUTH_USERNAME=username BASIC_AUTH_USERNAME=username
BASIC_AUTH_PASSWORD=password BASIC_AUTH_PASSWORD=password
OFFICE_RnD_TOKEN=token for Office RnD API requests
MAX_BACK_TO_BACK_DIFFERENCE=Time in minutes MAX_BACK_TO_BACK_DIFFERENCE=Time in minutes
EARLIEST_UNLOCK=Time in minutes EARLIEST_UNLOCK=Time in minutes

View File

@@ -1,10 +1,28 @@
const axios = require('axios'); const axios = require('axios');
const officeRnDToken = process.env.OFFICE_RnD_TOKEN; const { getToken } = require('../services/officeRnD/oauth');
console.log('API file');
const API = axios.create({ const API = axios.create({
baseURL: 'https://app.officernd.com/api/v1/organizations/sima-space-test-environment', baseURL: 'https://app.officernd.com/api/v1/organizations/sima-space-test-environment',
headers: {'Authorization': `Bearer ${officeRnDToken}`} headers: {'Authorization': `Bearer TOKEN`}
});
// request interceptor
API.interceptors.request.use((config) => {
return new Promise((resolve, reject) => {
getToken(true)
.then((token) => {
config.headers.Authorization = `Bearer ${token}`;
resolve(config);
})
.catch((error) => {
reject(error);
});
});
}, (error) => {
// Do something with request error
return Promise.reject(error);
}); });
module.exports = { module.exports = {

View File

@@ -26,7 +26,7 @@ const updateToken = (token, validUntil) => {
}); });
}; };
const getToken = () => { const getToken = (returnTokenOnly = false) => {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
db.accessToken.findAll() db.accessToken.findAll()
.then((results) => { .then((results) => {
@@ -36,14 +36,30 @@ const getToken = () => {
const validUntilMoment = moment(validUntil); const validUntilMoment = moment(validUntil);
if (validUntilMoment.isBefore(moment())){ if (validUntilMoment.isBefore(moment())){
refreshOauthToken() refreshOauthToken()
.then((oauthResult) => resolve(oauthResult)) .then((oauthResult) => {
if (returnTokenOnly){
resolve(oauthResult.token);
}else{
resolve(oauthResult);
}
})
.catch((error) => reject(error)); .catch((error) => reject(error));
}else{ }else{
if (returnTokenOnly){
resolve(token);
}else {
resolve({token, validUntil}); resolve({token, validUntil});
} }
}
}else{ }else{
refreshOauthToken() refreshOauthToken()
.then((oauthResult) => resolve(oauthResult)) .then((oauthResult) => {
if (returnTokenOnly){
resolve(oauthResult.token);
}else{
resolve(oauthResult);
}
})
.catch((error) => reject(error)); .catch((error) => reject(error));
} }
}) })