如何使用async和await這對組合設計統一的取Access Token的函式

注销發表於2019-10-14

最近我在使用SAP雲平臺的機器學習API做和SAP系統的整合,因為SAP Cloud Platform Leonardo上的機器學期API,每次消費時需要傳一個Access Token,故在每次實際呼叫API前,我需要先發一個請求去獲取Access Token. 該請求的響應,除了返回實際的token外,還有一個過期時間,expires_in欄位:

如何使用async和await這對組合設計統一的取Access Token的函式

根據OAuth 2.0標準定義,expires_in欄位代表伺服器頒發的該token,距離過期時間還剩的秒數。

如何使用async和await這對組合設計統一的取Access Token的函式

我的程式碼如下:

const request = require('request-promise-native');
var config = require('../config.js');
 
var TOKEN = undefined;
var EXPIRES_IN = undefined;
var TOKEN_FETCHED_SINCE = undefined;
function isCurrentDateExpired(){
    var current = new Date();
    var diffInMilliSeconds = current - TOKEN_FETCHED_SINCE;
    var diffInSecond = Math.ceil(diffInMilliSeconds/1000);
    var expired = diffInSecond >= EXPIRES_IN ? true:false;
    // for debug;
    // expired = true; 
    return expired;
}
async function getAccessToken(){
    if( TOKEN === undefined || isCurrentDateExpired()){
        var raw = new Buffer(config.username + ":" + config.password);
        const accessToken = await request({
            method: 'GET',
            headers: {
                'Authorization': 'Basic ' + raw.toString('base64')
            },
            url: config.ACCESS_TOKEN,
            json: false
        });
        var oToken = JSON.parse(accessToken);
        EXPIRES_IN = oToken.expires_in;
        TOKEN = oToken.access_token;
        TOKEN_FETCHED_SINCE = new Date();
        return oToken.access_token;
    }
    else{
        return TOKEN;
    }
}
var request1 = getAccessToken();
var freshNewToken, secondTimeToken;
request1.then(function(o){
    // console.log("token1: " + o);
     freshNewToken = o;
});
function test2(){
    var b = getAccessToken();
    b.then(function(o){
    // console.log("token2: " + o);
        secondTimeToken = o;
        console.log("they should be equal: " + (freshNewToken == secondTimeToken));
    });
}
setTimeout( test2, 6000);

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

如何使用async和await這對組合設計統一的取Access Token的函式


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2658626/,如需轉載,請註明出處,否則將追究法律責任。

相關文章