2

我已经能够设置我的代码,以便当您向 api 函数发出请求时,oAuthHandler 函数会自动为您处理身份验证。我遇到的问题是我找不到在多个调用中缓存令牌的方法,所以我只在它已经过期时才请求新令牌。

我已将所有相关代码文件的示例和我的测试文件放在以下 GIST 中。我只从文件中删除了服务器连接详细信息。要点:https ://gist.github.com/jgpeak/56e82c58b368429d4aad

4

1 回答 1

1

我发现我在令牌缓存方面做错了。我不需要在模块导出之外启动一个变量,而是需要在第一个导出的函数中启动它,以便它绑定到我创建的实例以传递给下面更新的 oAuthHandler 的其他 api 方法。

(function() {
'use strict';

//Required Modules
// ===============
const request = require('./requestHandler');
const cache = require('memory-cache');

//Hidden Variables
// ===============

module.exports = (oAuth) => {
  var cachedToken = null;
  return (processor, options, postData) => new Promise(function (resolve, reject) {

    var errorProcessor = (err) => {
      //If authorization failure refresh token and try one more time
      if(err.statusCode && err.statusCode === 401){
        return oAuth.getToken()
          .then((token)=>{
            cachedToken = token;
            return request(token, processor, options, postData);
          })
          .then((response) => resolve(response))
          .catch((err) => {
            reject(err);
          });
      }
      return reject(err);
    };

    if(cachedToken){
      return request(cachedToken, processor, options, postData)
        .then((response) => resolve(response))
        .catch(errorProcessor);
    }
    else {
      return oAuth.getToken()
        .then((token)=>{
          cachedToken = token;
          return request(token, processor, options, postData);
        })
        .then((response) => resolve(response))
        .catch(errorProcessor);
    }
  });
};

}());
于 2016-03-12T15:55:35.017 回答