@wigetapp/accesstoken
Version:
wxs 微信系开发脚手架之微信 accesstoken
113 lines • 5.2 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const util = require("util");
const kits_1 = require("@wigetapp/kits");
const AccessToken_1 = require("../AccessToken");
const QyApiConfigKit_1 = require("../wxcp/QyApiConfigKit");
const OpenCpAccessTokenApi_1 = require("./OpenCpAccessTokenApi");
/**
* @author wigetapp
* @copyright wx@wigetapp.com
* @description 获取授权企业的 AccessToken \n
* 第三方服务商在取得企业的永久授权码后,通过此接口可以获取到企业的access_token。\n
* 获取后可通过通讯录、应用、消息等企业接口来运营这些应用。\n
*/
class OpenCorpAccessTokenApi {
/**
* 获取 AccessToken
* @param authCorpid 授权方corpid
* @param permanentCode 永久授权码
*/
static getAccessToken(authCorpid, permanentCode) {
return __awaiter(this, void 0, void 0, function* () {
if (!authCorpid || !permanentCode) {
throw new Error('authCorpid 和 permanentCode 不能为空');
}
let accessToken = yield this.getAvailableAccessToken(authCorpid, permanentCode);
if (accessToken) {
if (QyApiConfigKit_1.QyApiConfigKit.isDevMode()) {
console.debug('缓存中的 accesstoken');
}
return accessToken;
}
if (QyApiConfigKit_1.QyApiConfigKit.isDevMode()) {
console.debug('刷新 accesstoken');
}
return yield this.refreshAccessToken(authCorpid, permanentCode);
});
}
/**
* 获取可用的 AccessToken
* @param authCorpid 授权方corpid
* @param permanentCode 永久授权码
*/
static getAvailableAccessToken(authCorpid, permanentCode) {
return __awaiter(this, void 0, void 0, function* () {
let result;
let cache = QyApiConfigKit_1.QyApiConfigKit.getCache;
const cacheKey = this.getCacheKey(authCorpid, permanentCode);
let accessTokenJson = yield cache.get(cacheKey);
if (accessTokenJson) {
result = new AccessToken_1.AccessToken(accessTokenJson);
}
if (result && result.isAvailable()) {
return result;
}
else {
return undefined;
}
});
}
/**
* 刷新 AccessToken
* @param authCorpid 授权方corpid
* @param permanentCode 永久授权码
*/
static refreshAccessToken(authCorpid, permanentCode) {
return __awaiter(this, void 0, void 0, function* () {
try {
let accessToken = yield OpenCpAccessTokenApi_1.OpenCpAccessTokenApi.getAccessToken(AccessToken_1.AccessTokenType.SUITE_TOKEN);
let url = util.format(this.getCorpTokenUrl, accessToken.getAccessToken);
const postData = JSON.stringify({
auth_corpid: authCorpid,
permanent_code: permanentCode
});
let data = yield kits_1.HttpKit.getHttpDelegate.httpPost(url, postData);
if (!data) {
throw new Error('获取accessToken返回数据为空');
}
data = JSON.stringify(data);
let corpAccessToken = new AccessToken_1.AccessToken(data);
// 缓存 AccessToken
let cache = QyApiConfigKit_1.QyApiConfigKit.getCache;
const cacheKey = this.getCacheKey(authCorpid, permanentCode);
yield cache.set(cacheKey, corpAccessToken.getCacheJson);
return corpAccessToken;
}
catch (error) {
console.error('获取企业 AccessToken 异常:', error);
throw new Error(`获取企业 AccessToken 异常: ${error.message || error}`);
}
});
}
/**
* 获取缓存键
* @param authCorpid 授权方corpid
* @param permanentCode 永久授权码
*/
static getCacheKey(authCorpid, permanentCode) {
return `${authCorpid}_${permanentCode}`;
}
}
exports.OpenCorpAccessTokenApi = OpenCorpAccessTokenApi;
OpenCorpAccessTokenApi.getCorpTokenUrl = 'https://qyapi.weixin.qq.com/cgi-bin/service/get_corp_token?suite_access_token=%s';
//# sourceMappingURL=OpenCorpAccessTokenApi.js.map