@rendomnet/apiservice 1.3.8 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{types.d.ts → index.d.mts} +68 -36
- package/dist/index.d.ts +74 -2
- package/dist/index.js +655 -376
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +651 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +13 -4
- package/dist/AccountManager.d.ts +0 -28
- package/dist/AccountManager.js +0 -84
- package/dist/ApiKeyAuthProvider.d.ts +0 -8
- package/dist/ApiKeyAuthProvider.js +0 -49
- package/dist/BasicAuthProvider.d.ts +0 -7
- package/dist/BasicAuthProvider.js +0 -45
- package/dist/CacheManager.d.ts +0 -28
- package/dist/CacheManager.js +0 -97
- package/dist/FetchError.d.ts +0 -8
- package/dist/FetchError.js +0 -70
- package/dist/HookManager.d.ts +0 -28
- package/dist/HookManager.js +0 -156
- package/dist/HttpClient.d.ts +0 -26
- package/dist/HttpClient.js +0 -223
- package/dist/RetryManager.d.ts +0 -36
- package/dist/RetryManager.js +0 -131
- package/dist/TokenAuthProvider.d.ts +0 -12
- package/dist/TokenAuthProvider.js +0 -93
- package/dist/components.d.ts +0 -11
- package/dist/components.js +0 -62
- package/dist/form.d.ts +0 -1
- package/dist/form.js +0 -95
- package/dist/types.js +0 -6
package/dist/index.js
CHANGED
|
@@ -1,405 +1,684 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
2
29
|
|
|
3
|
-
|
|
4
|
-
|
|
30
|
+
// src/index.ts
|
|
31
|
+
var index_exports = {};
|
|
32
|
+
__export(index_exports, {
|
|
33
|
+
default: () => index_default
|
|
5
34
|
});
|
|
6
|
-
exports
|
|
7
|
-
var _ApiKeyAuthProvider = require("./ApiKeyAuthProvider");
|
|
8
|
-
var _components = require("./components");
|
|
9
|
-
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
10
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
11
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
12
|
-
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
13
|
-
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { if (r) i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n;else { var o = function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); }; o("next", 0), o("throw", 1), o("return", 2); } }, _regeneratorDefine2(e, r, n, t); }
|
|
14
|
-
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
15
|
-
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
16
|
-
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
17
|
-
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
18
|
-
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
19
|
-
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
20
|
-
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
21
|
-
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
22
|
-
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
23
|
-
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
|
|
24
|
-
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
25
|
-
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
26
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
27
|
-
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
28
|
-
/**
|
|
29
|
-
* ApiService - Core API service for making authenticated API calls
|
|
30
|
-
* with caching, retry, and hook support.
|
|
31
|
-
*/
|
|
32
|
-
var ApiService = /*#__PURE__*/function () {
|
|
33
|
-
function ApiService() {
|
|
34
|
-
_classCallCheck(this, ApiService);
|
|
35
|
-
// Service provider name
|
|
36
|
-
_defineProperty(this, "baseUrl", '');
|
|
37
|
-
// Default max attempts for API calls
|
|
38
|
-
_defineProperty(this, "maxAttempts", 10);
|
|
39
|
-
this.provider = '';
|
|
40
|
-
this.authProvider = {};
|
|
35
|
+
module.exports = __toCommonJS(index_exports);
|
|
41
36
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
this.
|
|
46
|
-
this.
|
|
47
|
-
this.
|
|
37
|
+
// src/ApiKeyAuthProvider.ts
|
|
38
|
+
var ApiKeyAuthProvider = class {
|
|
39
|
+
constructor(options) {
|
|
40
|
+
this.apiKey = options.apiKey;
|
|
41
|
+
this.headerName = options.headerName;
|
|
42
|
+
this.queryParamName = options.queryParamName;
|
|
48
43
|
}
|
|
44
|
+
async getAuthHeaders() {
|
|
45
|
+
if (this.headerName) {
|
|
46
|
+
return { [this.headerName]: this.apiKey };
|
|
47
|
+
}
|
|
48
|
+
return {};
|
|
49
|
+
}
|
|
50
|
+
// For API key, refresh is not supported
|
|
51
|
+
};
|
|
49
52
|
|
|
53
|
+
// src/CacheManager.ts
|
|
54
|
+
var CacheManager = class {
|
|
55
|
+
constructor() {
|
|
56
|
+
this.cache = /* @__PURE__ */ new Map();
|
|
57
|
+
this.cacheTime = 2e4;
|
|
58
|
+
}
|
|
59
|
+
// Default cache time of 20 seconds
|
|
50
60
|
/**
|
|
51
|
-
*
|
|
61
|
+
* Get data from cache if available and not expired
|
|
52
62
|
*/
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
63
|
+
getFromCache(apiCallParams) {
|
|
64
|
+
var _a;
|
|
65
|
+
const requestKey = this.getRequestKey(apiCallParams);
|
|
66
|
+
const currentCacheTime = (_a = apiCallParams.cacheTime) != null ? _a : this.cacheTime;
|
|
67
|
+
const cached = this.cache.get(requestKey);
|
|
68
|
+
if (cached && Date.now() - cached.timestamp < currentCacheTime) {
|
|
69
|
+
return cached.data;
|
|
70
|
+
}
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Save data to cache
|
|
75
|
+
*/
|
|
76
|
+
saveToCache(apiCallParams, data) {
|
|
77
|
+
const requestKey = this.getRequestKey(apiCallParams);
|
|
78
|
+
this.cache.set(requestKey, {
|
|
79
|
+
data,
|
|
80
|
+
timestamp: Date.now()
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Generate a unique key for caching based on request parameters
|
|
85
|
+
*/
|
|
86
|
+
getRequestKey(apiCallParams) {
|
|
87
|
+
const { accountId, method, route, base, queryParams, body, data } = apiCallParams;
|
|
88
|
+
return JSON.stringify({
|
|
89
|
+
accountId,
|
|
90
|
+
method,
|
|
91
|
+
route,
|
|
92
|
+
base,
|
|
93
|
+
queryParams,
|
|
94
|
+
body: body || data
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Set the default cache time in milliseconds
|
|
99
|
+
*/
|
|
100
|
+
setCacheTime(milliseconds) {
|
|
101
|
+
this.cacheTime = milliseconds;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Clear the entire cache
|
|
105
|
+
*/
|
|
106
|
+
clearCache() {
|
|
107
|
+
this.cache.clear();
|
|
108
|
+
}
|
|
109
|
+
};
|
|
69
110
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
111
|
+
// src/RetryManager.ts
|
|
112
|
+
var RetryManager = class {
|
|
113
|
+
constructor() {
|
|
114
|
+
this.defaultMaxDelay = 6e4;
|
|
115
|
+
// Default max delay of 1 minute
|
|
116
|
+
this.defaultMaxRetries = 4;
|
|
117
|
+
/**
|
|
118
|
+
* Default exponential backoff strategy with full jitter
|
|
119
|
+
*/
|
|
120
|
+
this.defaultDelayStrategy = {
|
|
121
|
+
calculate: (attempt, response) => {
|
|
122
|
+
const retryAfter = this.getRetryAfterValue(response);
|
|
123
|
+
if (retryAfter) return retryAfter;
|
|
124
|
+
const baseDelay = 1e3;
|
|
125
|
+
const exponentialDelay = baseDelay * Math.pow(2, attempt - 1);
|
|
126
|
+
return Math.floor(Math.random() * exponentialDelay);
|
|
75
127
|
}
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Calculate and wait for appropriate delay time before retry
|
|
132
|
+
*/
|
|
133
|
+
async calculateAndDelay(params) {
|
|
134
|
+
const { attempt, response, hook } = params;
|
|
135
|
+
const delayStrategy = hook.delayStrategy || this.defaultDelayStrategy;
|
|
136
|
+
const maxDelay = hook.maxDelay || this.defaultMaxDelay;
|
|
137
|
+
const calculatedDelay = delayStrategy.calculate(attempt, response);
|
|
138
|
+
const finalDelay = Math.min(calculatedDelay, maxDelay);
|
|
139
|
+
console.log(`\u{1F504} Waiting for ${finalDelay / 1e3} seconds before retrying.`);
|
|
140
|
+
await new Promise((resolve) => setTimeout(resolve, finalDelay));
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Extract retry-after value from response
|
|
144
|
+
*/
|
|
145
|
+
getRetryAfterValue(response) {
|
|
146
|
+
var _a;
|
|
147
|
+
if (!((_a = response == null ? void 0 : response.headers) == null ? void 0 : _a.get)) return null;
|
|
148
|
+
const retryAfter = response.headers.get("Retry-After");
|
|
149
|
+
if (!retryAfter) return null;
|
|
150
|
+
const parsedDelay = parseInt(retryAfter, 10);
|
|
151
|
+
if (!isNaN(parsedDelay)) {
|
|
152
|
+
return parsedDelay * 1e3;
|
|
153
|
+
}
|
|
154
|
+
const date = new Date(retryAfter).getTime();
|
|
155
|
+
const now = Date.now();
|
|
156
|
+
if (date > now) {
|
|
157
|
+
return date - now;
|
|
158
|
+
}
|
|
159
|
+
return null;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get the default maximum number of retries
|
|
163
|
+
*/
|
|
164
|
+
getDefaultMaxRetries() {
|
|
165
|
+
return this.defaultMaxRetries;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Set the default maximum number of retries
|
|
169
|
+
*/
|
|
170
|
+
setDefaultMaxRetries(maxRetries) {
|
|
171
|
+
this.defaultMaxRetries = maxRetries;
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Set the default maximum delay between retries
|
|
175
|
+
*/
|
|
176
|
+
setDefaultMaxDelay(maxDelay) {
|
|
177
|
+
this.defaultMaxDelay = maxDelay;
|
|
178
|
+
}
|
|
179
|
+
};
|
|
76
180
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
181
|
+
// src/HookManager.ts
|
|
182
|
+
var HookManager = class {
|
|
183
|
+
constructor() {
|
|
184
|
+
this.hooks = {};
|
|
185
|
+
this.hookPromises = {};
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Set hooks for different status codes
|
|
189
|
+
*/
|
|
190
|
+
setHooks(hooks) {
|
|
191
|
+
this.hooks = { ...this.hooks, ...hooks };
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Get a hook for a specific status code
|
|
195
|
+
*/
|
|
196
|
+
getHook(status) {
|
|
197
|
+
return this.hooks[status];
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Process a hook for a specific status code
|
|
201
|
+
*/
|
|
202
|
+
async processHook(accountId, status, error) {
|
|
203
|
+
const hook = this.hooks[status];
|
|
204
|
+
if (!hook || !hook.handler) return null;
|
|
205
|
+
const hookKey = `${accountId || "default"}-${status}`;
|
|
206
|
+
try {
|
|
207
|
+
if (hook.preventConcurrentCalls) {
|
|
208
|
+
if (!this.hookPromises[hookKey]) {
|
|
209
|
+
this.hookPromises[hookKey] = Promise.resolve(
|
|
210
|
+
hook.handler(accountId, error.response) || {}
|
|
211
|
+
);
|
|
84
212
|
}
|
|
213
|
+
const result = await this.hookPromises[hookKey];
|
|
214
|
+
delete this.hookPromises[hookKey];
|
|
215
|
+
return result;
|
|
85
216
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
if (typeof cacheTime !== 'undefined') {
|
|
92
|
-
this.cacheManager.setCacheTime(cacheTime);
|
|
217
|
+
return await hook.handler(accountId, error.response) || {};
|
|
218
|
+
} catch (hookError) {
|
|
219
|
+
console.error(`Hook handler failed for status ${status}:`, hookError);
|
|
220
|
+
if (hook.onHandlerError) {
|
|
221
|
+
await hook.onHandlerError(accountId, hookError);
|
|
93
222
|
}
|
|
223
|
+
throw hookError;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Handle a retry failure with the appropriate hook
|
|
228
|
+
*/
|
|
229
|
+
async handleRetryFailure(accountId, status, error) {
|
|
230
|
+
const hook = this.hooks[status];
|
|
231
|
+
if (hook == null ? void 0 : hook.onMaxRetriesExceeded) {
|
|
232
|
+
await hook.onMaxRetriesExceeded(accountId, error);
|
|
94
233
|
}
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* Check if a hook exists and should retry for a given status
|
|
237
|
+
*/
|
|
238
|
+
shouldRetry(status) {
|
|
239
|
+
const hook = this.hooks[status];
|
|
240
|
+
return !!hook && !!hook.shouldRetry;
|
|
241
|
+
}
|
|
242
|
+
};
|
|
95
243
|
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
var _onMaxRetriesExceeded = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2(accountId, error) {
|
|
144
|
-
return _regenerator().w(function (_context2) {
|
|
145
|
-
while (1) switch (_context2.n) {
|
|
146
|
-
case 0:
|
|
147
|
-
console.error("Authentication failed after refresh attempt for ".concat(accountId, ":"), error);
|
|
148
|
-
case 1:
|
|
149
|
-
return _context2.a(2);
|
|
150
|
-
}
|
|
151
|
-
}, _callee2);
|
|
152
|
-
}));
|
|
153
|
-
function onMaxRetriesExceeded(_x2, _x3) {
|
|
154
|
-
return _onMaxRetriesExceeded.apply(this, arguments);
|
|
244
|
+
// src/HttpClient.ts
|
|
245
|
+
var import_qs = __toESM(require("qs"));
|
|
246
|
+
|
|
247
|
+
// src/FetchError.ts
|
|
248
|
+
var FetchError = class extends Error {
|
|
249
|
+
constructor(response, data = {}, code = "FETCH_ERROR") {
|
|
250
|
+
super();
|
|
251
|
+
this.name = "FetchError";
|
|
252
|
+
const defaultMessage = "An unspecified error occurred";
|
|
253
|
+
const getMessage = (data2, locations) => locations.map((item) => {
|
|
254
|
+
const parts = item.split(".");
|
|
255
|
+
let value = data2;
|
|
256
|
+
for (const part of parts) {
|
|
257
|
+
value = value == null ? void 0 : value[part];
|
|
258
|
+
}
|
|
259
|
+
return value;
|
|
260
|
+
}).find((message) => typeof message === "string") || null;
|
|
261
|
+
const messageFromData = getMessage(data, [
|
|
262
|
+
"error.errors.0.message",
|
|
263
|
+
"error.message",
|
|
264
|
+
"error",
|
|
265
|
+
"message"
|
|
266
|
+
]);
|
|
267
|
+
this.message = messageFromData || response.statusText || defaultMessage;
|
|
268
|
+
this.status = response.status;
|
|
269
|
+
this.code = code;
|
|
270
|
+
this.data = data;
|
|
271
|
+
this.message = this.message || defaultMessage;
|
|
272
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
|
|
276
|
+
// src/form.ts
|
|
277
|
+
function deserializeForm(src) {
|
|
278
|
+
const fd = new FormData();
|
|
279
|
+
switch (src.cls) {
|
|
280
|
+
case "FormData": {
|
|
281
|
+
for (const [key, items] of src.value) {
|
|
282
|
+
for (const item of items) {
|
|
283
|
+
let deserializedItem = deserializeForm(item);
|
|
284
|
+
if (deserializedItem instanceof FormData) {
|
|
285
|
+
const entries = deserializedItem;
|
|
286
|
+
for (const [subKey, subValue] of entries.entries()) {
|
|
287
|
+
fd.append(`${key}[${subKey}]`, subValue);
|
|
288
|
+
}
|
|
289
|
+
} else {
|
|
290
|
+
fd.append(key, deserializedItem);
|
|
155
291
|
}
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
break;
|
|
159
295
|
}
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
296
|
+
case "Blob":
|
|
297
|
+
case "File": {
|
|
298
|
+
const { type, name, lastModified } = src;
|
|
299
|
+
const binStr = atob(src.value);
|
|
300
|
+
const arr = new Uint8Array(binStr.length);
|
|
301
|
+
for (let i = 0; i < binStr.length; i++) arr[i] = binStr.charCodeAt(i);
|
|
302
|
+
const data = [arr.buffer];
|
|
303
|
+
const fileOrBlob = src.cls === "File" ? new File(data, name, { type, lastModified }) : new Blob(data, { type });
|
|
304
|
+
fd.append("file", fileOrBlob);
|
|
305
|
+
break;
|
|
306
|
+
}
|
|
307
|
+
case "json": {
|
|
308
|
+
fd.append("json", JSON.stringify(JSON.parse(src.value)));
|
|
309
|
+
break;
|
|
168
310
|
}
|
|
311
|
+
default:
|
|
312
|
+
throw new Error("Unsupported type for deserialization");
|
|
313
|
+
}
|
|
314
|
+
return fd;
|
|
315
|
+
}
|
|
169
316
|
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
317
|
+
// src/HttpClient.ts
|
|
318
|
+
var HttpClient = class {
|
|
319
|
+
/**
|
|
320
|
+
* Make an HTTP request
|
|
321
|
+
*/
|
|
322
|
+
async makeRequest(apiParams, authToken) {
|
|
323
|
+
const {
|
|
324
|
+
accountId,
|
|
325
|
+
method,
|
|
326
|
+
route,
|
|
327
|
+
base,
|
|
328
|
+
body,
|
|
329
|
+
data,
|
|
330
|
+
headers,
|
|
331
|
+
queryParams,
|
|
332
|
+
contentType = "application/json",
|
|
333
|
+
accessToken: forcedAccessToken,
|
|
334
|
+
useAuth = true,
|
|
335
|
+
files,
|
|
336
|
+
abortSignal
|
|
337
|
+
} = apiParams;
|
|
338
|
+
const normalizedMethod = method == null ? void 0 : method.toUpperCase();
|
|
339
|
+
let finalQueryParams = {};
|
|
340
|
+
if (queryParams) {
|
|
341
|
+
if (queryParams instanceof URLSearchParams) {
|
|
342
|
+
queryParams.forEach((val, key) => {
|
|
343
|
+
finalQueryParams[key] = val;
|
|
344
|
+
});
|
|
345
|
+
} else {
|
|
346
|
+
finalQueryParams = { ...queryParams };
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
if (normalizedMethod === "GET") {
|
|
350
|
+
if (body) {
|
|
351
|
+
finalQueryParams = { ...finalQueryParams, ...body };
|
|
352
|
+
}
|
|
353
|
+
if (data) {
|
|
354
|
+
finalQueryParams = { ...finalQueryParams, ...data };
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
const url = this.buildUrl(base, route, finalQueryParams);
|
|
358
|
+
const requestBody = body || data;
|
|
359
|
+
const formData = this.prepareFormData(files);
|
|
360
|
+
const fetchOptions = this.buildFetchOptions({
|
|
361
|
+
method: normalizedMethod,
|
|
362
|
+
body: requestBody,
|
|
363
|
+
formData,
|
|
364
|
+
contentType,
|
|
365
|
+
authToken,
|
|
366
|
+
forcedAccessToken,
|
|
367
|
+
useAuth,
|
|
368
|
+
headers,
|
|
369
|
+
abortSignal
|
|
370
|
+
});
|
|
371
|
+
try {
|
|
372
|
+
console.log(`\u{1F504} Making API call to ${url}`);
|
|
373
|
+
const response = await fetch(url, fetchOptions);
|
|
374
|
+
return await this.handleResponse(response);
|
|
375
|
+
} catch (error) {
|
|
376
|
+
console.error("\u{1F504} Error making API call:", error, "status:", error == null ? void 0 : error.status);
|
|
377
|
+
throw error;
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
/**
|
|
381
|
+
* Build URL with query parameters
|
|
382
|
+
*/
|
|
383
|
+
buildUrl(base, route, queryParams) {
|
|
384
|
+
const baseUrl = base || "";
|
|
385
|
+
let url = `${baseUrl}${route || ""}`;
|
|
386
|
+
if (queryParams && Object.keys(queryParams).length > 0) {
|
|
387
|
+
url += `?${import_qs.default.stringify(queryParams)}`;
|
|
177
388
|
}
|
|
389
|
+
return url;
|
|
390
|
+
}
|
|
391
|
+
/**
|
|
392
|
+
* Prepare form data for file uploads
|
|
393
|
+
*/
|
|
394
|
+
prepareFormData(files) {
|
|
395
|
+
if (!files) return null;
|
|
396
|
+
const formData = deserializeForm(files);
|
|
397
|
+
const entries = formData;
|
|
398
|
+
for (let [key, value] of entries.entries()) {
|
|
399
|
+
console.log(`formdata ${key}:`, value);
|
|
400
|
+
}
|
|
401
|
+
return formData;
|
|
402
|
+
}
|
|
403
|
+
/**
|
|
404
|
+
* Build fetch options for request
|
|
405
|
+
*/
|
|
406
|
+
buildFetchOptions({
|
|
407
|
+
method,
|
|
408
|
+
body,
|
|
409
|
+
formData,
|
|
410
|
+
contentType,
|
|
411
|
+
authToken,
|
|
412
|
+
forcedAccessToken,
|
|
413
|
+
useAuth,
|
|
414
|
+
headers,
|
|
415
|
+
abortSignal
|
|
416
|
+
}) {
|
|
417
|
+
const allowedMethods = ["POST", "PUT", "PATCH"];
|
|
418
|
+
return {
|
|
419
|
+
method,
|
|
420
|
+
signal: abortSignal,
|
|
421
|
+
headers: {
|
|
422
|
+
...useAuth && {
|
|
423
|
+
Authorization: `Bearer ${forcedAccessToken || authToken.access_token}`
|
|
424
|
+
},
|
|
425
|
+
...!formData && { "content-type": contentType },
|
|
426
|
+
...headers || {}
|
|
427
|
+
},
|
|
428
|
+
body: body && allowedMethods.includes(method) ? JSON.stringify(body) : formData || null
|
|
429
|
+
};
|
|
430
|
+
}
|
|
431
|
+
/**
|
|
432
|
+
* Handle API response
|
|
433
|
+
*/
|
|
434
|
+
async handleResponse(response) {
|
|
435
|
+
let data = null;
|
|
436
|
+
try {
|
|
437
|
+
data = await response.json();
|
|
438
|
+
console.log("\u{1F504} Response data:", data);
|
|
439
|
+
} catch (error) {
|
|
440
|
+
}
|
|
441
|
+
if (!response.ok) {
|
|
442
|
+
throw new FetchError(response, data);
|
|
443
|
+
}
|
|
444
|
+
return data;
|
|
445
|
+
}
|
|
446
|
+
};
|
|
178
447
|
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
448
|
+
// src/AccountManager.ts
|
|
449
|
+
var AccountManager = class {
|
|
450
|
+
constructor() {
|
|
451
|
+
this.accounts = {};
|
|
452
|
+
this.DEFAULT_ACCOUNT = "default";
|
|
453
|
+
}
|
|
454
|
+
/**
|
|
455
|
+
* Update account data for a specific account
|
|
456
|
+
*/
|
|
457
|
+
updateAccountData(accountId = this.DEFAULT_ACCOUNT, data) {
|
|
458
|
+
this.accounts[accountId] = {
|
|
459
|
+
...this.accounts[accountId],
|
|
460
|
+
...data
|
|
461
|
+
};
|
|
462
|
+
}
|
|
463
|
+
/**
|
|
464
|
+
* Get account data for a specific account
|
|
465
|
+
*/
|
|
466
|
+
getAccountData(accountId = this.DEFAULT_ACCOUNT) {
|
|
467
|
+
return this.accounts[accountId] || {};
|
|
468
|
+
}
|
|
469
|
+
/**
|
|
470
|
+
* Check if an account's last request failed
|
|
471
|
+
*/
|
|
472
|
+
didLastRequestFail(accountId = this.DEFAULT_ACCOUNT) {
|
|
473
|
+
var _a;
|
|
474
|
+
return !!((_a = this.accounts[accountId]) == null ? void 0 : _a.lastFailed);
|
|
475
|
+
}
|
|
476
|
+
/**
|
|
477
|
+
* Set account's last request as failed
|
|
478
|
+
*/
|
|
479
|
+
setLastRequestFailed(accountId = this.DEFAULT_ACCOUNT, failed = true) {
|
|
480
|
+
this.updateAccountData(accountId, { lastFailed: failed });
|
|
481
|
+
}
|
|
482
|
+
/**
|
|
483
|
+
* Update the last request time for an account
|
|
484
|
+
*/
|
|
485
|
+
updateLastRequestTime(accountId = this.DEFAULT_ACCOUNT) {
|
|
486
|
+
this.updateAccountData(accountId, { lastRequestTime: Date.now() });
|
|
487
|
+
}
|
|
488
|
+
};
|
|
204
489
|
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
490
|
+
// src/index.ts
|
|
491
|
+
var ApiService = class {
|
|
492
|
+
constructor() {
|
|
493
|
+
this.baseUrl = "";
|
|
494
|
+
// Default max attempts for API calls
|
|
495
|
+
this.maxAttempts = 10;
|
|
496
|
+
this.provider = "";
|
|
497
|
+
this.authProvider = {};
|
|
498
|
+
this.cacheManager = new CacheManager();
|
|
499
|
+
this.retryManager = new RetryManager();
|
|
500
|
+
this.hookManager = new HookManager();
|
|
501
|
+
this.httpClient = new HttpClient();
|
|
502
|
+
this.accountManager = new AccountManager();
|
|
503
|
+
}
|
|
504
|
+
/**
|
|
505
|
+
* Setup the API service
|
|
506
|
+
*/
|
|
507
|
+
setup({
|
|
508
|
+
provider,
|
|
509
|
+
authProvider,
|
|
510
|
+
hooks = {},
|
|
511
|
+
cacheTime,
|
|
512
|
+
baseUrl = ""
|
|
513
|
+
}) {
|
|
514
|
+
this.provider = provider;
|
|
515
|
+
this.authProvider = authProvider;
|
|
516
|
+
this.baseUrl = baseUrl;
|
|
517
|
+
const finalHooks = {};
|
|
518
|
+
if (hooks[401] === void 0 && typeof this.authProvider.refresh === "function") {
|
|
519
|
+
finalHooks[401] = this.createDefaultAuthRefreshHandler();
|
|
520
|
+
}
|
|
521
|
+
for (const [statusCode, hook] of Object.entries(hooks)) {
|
|
522
|
+
if (hook) {
|
|
523
|
+
finalHooks[statusCode] = hook;
|
|
225
524
|
}
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
525
|
+
}
|
|
526
|
+
if (Object.keys(finalHooks).length > 0) {
|
|
527
|
+
this.hookManager.setHooks(finalHooks);
|
|
528
|
+
}
|
|
529
|
+
if (typeof cacheTime !== "undefined") {
|
|
530
|
+
this.cacheManager.setCacheTime(cacheTime);
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
/**
|
|
534
|
+
* Create a default handler for 401 (Unauthorized) errors
|
|
535
|
+
* that implements standard credential refresh behavior
|
|
536
|
+
*/
|
|
537
|
+
createDefaultAuthRefreshHandler() {
|
|
538
|
+
return {
|
|
539
|
+
shouldRetry: true,
|
|
540
|
+
useRetryDelay: true,
|
|
541
|
+
preventConcurrentCalls: true,
|
|
542
|
+
maxRetries: 1,
|
|
543
|
+
handler: async (accountId) => {
|
|
544
|
+
try {
|
|
545
|
+
console.log(`\u{1F504} Using default auth refresh handler for ${accountId}`);
|
|
546
|
+
if (!this.authProvider.refresh) {
|
|
547
|
+
throw new Error("No refresh method available on auth provider");
|
|
241
548
|
}
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
549
|
+
await this.authProvider.refresh(accountId);
|
|
550
|
+
return {};
|
|
551
|
+
} catch (error) {
|
|
552
|
+
console.error(`Auth refresh failed for ${accountId}:`, error);
|
|
553
|
+
throw error;
|
|
554
|
+
}
|
|
555
|
+
},
|
|
556
|
+
onMaxRetriesExceeded: async (accountId, error) => {
|
|
557
|
+
console.error(`Authentication failed after refresh attempt for ${accountId}:`, error);
|
|
246
558
|
}
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
_context5.p = 12;
|
|
342
|
-
_context5.n = 13;
|
|
343
|
-
return this.hookManager.processHook(accountId, status, _t3);
|
|
344
|
-
case 13:
|
|
345
|
-
hookResult = _context5.v;
|
|
346
|
-
if (hookResult) {
|
|
347
|
-
currentParams = _objectSpread(_objectSpread({}, currentParams), hookResult);
|
|
348
|
-
}
|
|
349
|
-
_context5.n = 15;
|
|
350
|
-
break;
|
|
351
|
-
case 14:
|
|
352
|
-
_context5.p = 14;
|
|
353
|
-
_t4 = _context5.v;
|
|
354
|
-
this.accountManager.setLastRequestFailed(accountId, true);
|
|
355
|
-
throw _t4;
|
|
356
|
-
case 15:
|
|
357
|
-
if (!(activeHook !== null && activeHook !== void 0 && activeHook.useRetryDelay)) {
|
|
358
|
-
_context5.n = 16;
|
|
359
|
-
break;
|
|
360
|
-
}
|
|
361
|
-
_context5.n = 16;
|
|
362
|
-
return this.retryManager.calculateAndDelay({
|
|
363
|
-
attempt: statusRetries[status],
|
|
364
|
-
response: _t3.response,
|
|
365
|
-
hook: activeHook
|
|
366
|
-
});
|
|
367
|
-
case 16:
|
|
368
|
-
_context5.n = 1;
|
|
369
|
-
break;
|
|
370
|
-
case 17:
|
|
371
|
-
// If we've reached here, we've exceeded our maximum attempts
|
|
372
|
-
this.accountManager.setLastRequestFailed(accountId, true);
|
|
373
|
-
throw new Error("Exceeded maximum attempts (".concat(this.maxAttempts, ") for API call to ").concat(accountId));
|
|
374
|
-
case 18:
|
|
375
|
-
return _context5.a(2);
|
|
559
|
+
};
|
|
560
|
+
}
|
|
561
|
+
/**
|
|
562
|
+
* Set the maximum number of retry attempts
|
|
563
|
+
*/
|
|
564
|
+
setMaxAttempts(attempts) {
|
|
565
|
+
this.maxAttempts = attempts;
|
|
566
|
+
}
|
|
567
|
+
/**
|
|
568
|
+
* Update account data
|
|
569
|
+
*/
|
|
570
|
+
updateAccountData(accountId, data) {
|
|
571
|
+
this.accountManager.updateAccountData(accountId, data);
|
|
572
|
+
}
|
|
573
|
+
/**
|
|
574
|
+
* Make an API call with all features (caching, retry, hooks)
|
|
575
|
+
*/
|
|
576
|
+
async call(apiCallParams) {
|
|
577
|
+
const params = {
|
|
578
|
+
...apiCallParams,
|
|
579
|
+
accountId: apiCallParams.accountId || "default",
|
|
580
|
+
base: apiCallParams.base || this.baseUrl
|
|
581
|
+
};
|
|
582
|
+
if (this.authProvider instanceof ApiKeyAuthProvider && this.authProvider.queryParamName) {
|
|
583
|
+
const queryParamName = this.authProvider.queryParamName;
|
|
584
|
+
const apiKey = this.authProvider.apiKey;
|
|
585
|
+
const urlParams = params.queryParams ? new URLSearchParams(params.queryParams) : new URLSearchParams();
|
|
586
|
+
urlParams.set(queryParamName, apiKey);
|
|
587
|
+
params.queryParams = urlParams;
|
|
588
|
+
}
|
|
589
|
+
console.log("\u{1F504} API call", this.provider, params.accountId, params.method, params.route);
|
|
590
|
+
const cachedData = this.cacheManager.getFromCache(params);
|
|
591
|
+
if (cachedData) return cachedData;
|
|
592
|
+
const result = await this.makeRequestWithRetry(params);
|
|
593
|
+
this.cacheManager.saveToCache(params, result);
|
|
594
|
+
return result;
|
|
595
|
+
}
|
|
596
|
+
/**
|
|
597
|
+
* Legacy method for backward compatibility
|
|
598
|
+
* @deprecated Use call() instead
|
|
599
|
+
*/
|
|
600
|
+
async makeApiCall(apiCallParams) {
|
|
601
|
+
return this.call(apiCallParams);
|
|
602
|
+
}
|
|
603
|
+
/**
|
|
604
|
+
* Make a request with retry capability
|
|
605
|
+
*/
|
|
606
|
+
async makeRequestWithRetry(apiCallParams) {
|
|
607
|
+
var _a;
|
|
608
|
+
const { accountId, abortSignal } = apiCallParams;
|
|
609
|
+
let attempts = 0;
|
|
610
|
+
const statusRetries = {};
|
|
611
|
+
let currentParams = { ...apiCallParams };
|
|
612
|
+
if (this.authProvider instanceof ApiKeyAuthProvider && this.authProvider.queryParamName) {
|
|
613
|
+
const queryParamName = this.authProvider.queryParamName;
|
|
614
|
+
const apiKey = this.authProvider.apiKey;
|
|
615
|
+
const urlParams = currentParams.queryParams ? new URLSearchParams(currentParams.queryParams) : new URLSearchParams();
|
|
616
|
+
urlParams.set(queryParamName, apiKey);
|
|
617
|
+
currentParams.queryParams = urlParams;
|
|
618
|
+
}
|
|
619
|
+
while (attempts < this.maxAttempts) {
|
|
620
|
+
if (abortSignal == null ? void 0 : abortSignal.aborted) {
|
|
621
|
+
throw new Error("Request aborted");
|
|
622
|
+
}
|
|
623
|
+
attempts++;
|
|
624
|
+
try {
|
|
625
|
+
const authHeaders = apiCallParams.useAuth !== false ? await this.authProvider.getAuthHeaders(accountId) : {};
|
|
626
|
+
currentParams.headers = {
|
|
627
|
+
...currentParams.headers || {},
|
|
628
|
+
...authHeaders
|
|
629
|
+
};
|
|
630
|
+
if (apiCallParams.useAuth !== false && Object.keys(authHeaders).length === 0 && !(this.authProvider instanceof ApiKeyAuthProvider && this.authProvider.queryParamName)) {
|
|
631
|
+
throw new Error(`${this.provider} credentials not found for account ID ${accountId}`);
|
|
632
|
+
}
|
|
633
|
+
const response = await this.httpClient.makeRequest(currentParams, {});
|
|
634
|
+
this.accountManager.setLastRequestFailed(accountId, false);
|
|
635
|
+
return response;
|
|
636
|
+
} catch (error) {
|
|
637
|
+
const status = error == null ? void 0 : error.status;
|
|
638
|
+
if (!this.hookManager.shouldRetry(status)) {
|
|
639
|
+
throw error;
|
|
640
|
+
}
|
|
641
|
+
statusRetries[status] = (statusRetries[status] || 0) + 1;
|
|
642
|
+
const activeHook = this.hookManager.getHook(status);
|
|
643
|
+
const maxRetries = (_a = activeHook == null ? void 0 : activeHook.maxRetries) != null ? _a : this.retryManager.getDefaultMaxRetries();
|
|
644
|
+
if (statusRetries[status] > maxRetries) {
|
|
645
|
+
await this.hookManager.handleRetryFailure(accountId, status, error);
|
|
646
|
+
this.accountManager.setLastRequestFailed(accountId, true);
|
|
647
|
+
throw error;
|
|
648
|
+
}
|
|
649
|
+
try {
|
|
650
|
+
const hookResult = await this.hookManager.processHook(accountId, status, error);
|
|
651
|
+
if (hookResult) {
|
|
652
|
+
currentParams = { ...currentParams, ...hookResult };
|
|
376
653
|
}
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
654
|
+
} catch (hookError) {
|
|
655
|
+
this.accountManager.setLastRequestFailed(accountId, true);
|
|
656
|
+
throw hookError;
|
|
657
|
+
}
|
|
658
|
+
if (activeHook == null ? void 0 : activeHook.useRetryDelay) {
|
|
659
|
+
await this.retryManager.calculateAndDelay({
|
|
660
|
+
attempt: statusRetries[status],
|
|
661
|
+
response: error.response,
|
|
662
|
+
hook: activeHook
|
|
663
|
+
});
|
|
664
|
+
}
|
|
381
665
|
}
|
|
382
|
-
return makeRequestWithRetry;
|
|
383
|
-
}()
|
|
384
|
-
/**
|
|
385
|
-
* Set the cache time in milliseconds
|
|
386
|
-
*/
|
|
387
|
-
)
|
|
388
|
-
}, {
|
|
389
|
-
key: "setCacheTime",
|
|
390
|
-
value: function setCacheTime(milliseconds) {
|
|
391
|
-
this.cacheManager.setCacheTime(milliseconds);
|
|
392
666
|
}
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ApiKeyAuthProvider","require","_components","_typeof","o","Symbol","iterator","constructor","prototype","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_regenerator","n","toStringTag","i","c","Generator","u","create","_regeneratorDefine2","f","p","y","G","v","a","d","bind","l","TypeError","call","done","value","GeneratorFunction","GeneratorFunctionPrototype","getPrototypeOf","setPrototypeOf","__proto__","displayName","w","m","_regeneratorDefine","configurable","writable","_invoke","asyncGeneratorStep","Promise","resolve","then","_asyncToGenerator","_next","_throw","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","_arrayLikeToArray","toString","slice","name","Array","from","test","next","isArray","_classCallCheck","_defineProperties","_toPropertyKey","key","_createClass","_toPrimitive","toPrimitive","String","Number","ApiService","provider","authProvider","cacheManager","CacheManager","retryManager","RetryManager","hookManager","HookManager","httpClient","HttpClient","accountManager","AccountManager","setup","_ref","_ref$hooks","hooks","cacheTime","_ref$baseUrl","baseUrl","finalHooks","undefined","refresh","createDefaultAuthRefreshHandler","_i","_Object$entries","entries","_Object$entries$_i","statusCode","hook","setHooks","setCacheTime","_this","shouldRetry","useRetryDelay","preventConcurrentCalls","maxRetries","handler","_handler","_callee","accountId","_t","_context","console","log","concat","Error","error","_x","onMaxRetriesExceeded","_onMaxRetriesExceeded","_callee2","_context2","_x2","_x3","setMaxAttempts","attempts","maxAttempts","updateAccountData","data","_call","_callee3","apiCallParams","params","queryParamName","apiKey","urlParams","cachedData","result","_context3","base","ApiKeyAuthProvider","queryParams","URLSearchParams","set","method","route","getFromCache","makeRequestWithRetry","saveToCache","_x4","_makeApiCall","_callee4","_context4","makeApiCall","_x5","_makeRequestWithRetry","_callee5","abortSignal","statusRetries","currentParams","authHeaders","response","_activeHook$maxRetrie","status","activeHook","hookResult","_t2","_t3","_t4","_context5","aborted","useAuth","getAuthHeaders","headers","makeRequest","setLastRequestFailed","getHook","getDefaultMaxRetries","handleRetryFailure","processHook","calculateAndDelay","attempt","_x6","milliseconds","clearCache","_default","exports"],"sources":["../src/index.ts"],"sourcesContent":["import { \n  AuthProvider,\n  ApiCallParams,\n  HookSettings,\n  StatusCode,\n  Token,\n  OAuthToken\n} from './types';\nimport { ApiKeyAuthProvider } from './ApiKeyAuthProvider';\nimport {\n  CacheManager,\n  RetryManager,\n  HookManager,\n  HttpClient,\n  AccountManager\n} from './components';\n\n/**\n * ApiService - Core API service for making authenticated API calls\n * with caching, retry, and hook support.\n */\nclass ApiService {\n  public provider: string; // Service provider name\n  private authProvider: AuthProvider;\n  private baseUrl: string = ''; // Default base URL\n  \n  // Component managers\n  private cacheManager: CacheManager;\n  private retryManager: RetryManager;\n  private hookManager: HookManager;\n  private httpClient: HttpClient;\n  private accountManager: AccountManager;\n  \n  // Default max attempts for API calls\n  private maxAttempts = 10;\n\n  constructor() {\n    this.provider = '';\n    this.authProvider = {} as AuthProvider;\n    \n    // Initialize component managers\n    this.cacheManager = new CacheManager();\n    this.retryManager = new RetryManager();\n    this.hookManager = new HookManager();\n    this.httpClient = new HttpClient();\n    this.accountManager = new AccountManager();\n  }\n\n  /**\n   * Setup the API service\n   */\n  public setup({\n    provider,\n    authProvider,\n    hooks = {},\n    cacheTime,\n    baseUrl = '',\n  }: {\n    provider: string;\n    authProvider: AuthProvider;\n    hooks?: Record<StatusCode, HookSettings | null>;\n    cacheTime: number;\n    baseUrl?: string;\n  }) {\n    this.provider = provider;\n    this.authProvider = authProvider;\n    this.baseUrl = baseUrl;\n    \n    // Create a copy of hooks to avoid modifying the input\n    const finalHooks: Record<StatusCode, HookSettings> = {};\n    \n    // Apply default 401 handler if:\n    // 1. No 401 hook is explicitly defined (or is explicitly null)\n    // 2. AuthProvider has a refresh method\n    if (hooks[401] === undefined && typeof this.authProvider.refresh === 'function') {\n      finalHooks[401] = this.createDefaultAuthRefreshHandler();\n    }\n    \n    // Add user-defined hooks (skipping null/undefined values)\n    for (const [statusCode, hook] of Object.entries(hooks)) {\n      if (hook) {\n        finalHooks[statusCode] = hook;\n      }\n    }\n    \n    // Set the hooks if we have any\n    if (Object.keys(finalHooks).length > 0) {\n      this.hookManager.setHooks(finalHooks);\n    }\n    \n    if (typeof cacheTime !== 'undefined') {\n      this.cacheManager.setCacheTime(cacheTime);\n    }\n  }\n  \n  /**\n   * Create a default handler for 401 (Unauthorized) errors\n   * that implements standard credential refresh behavior\n   */\n  private createDefaultAuthRefreshHandler(): HookSettings {\n    return {\n      shouldRetry: true,\n      useRetryDelay: true,\n      preventConcurrentCalls: true,\n      maxRetries: 1,\n      handler: async (accountId) => {\n        try {\n          console.log(`🔄 Using default auth refresh handler for ${accountId}`);\n          if (!this.authProvider.refresh) {\n            throw new Error('No refresh method available on auth provider');\n          }\n          // You may want to store refresh token in account data or pass it in another way\n          // For now, assume refresh token is managed internally by the provider\n          await this.authProvider.refresh(accountId);\n          return {};\n        } catch (error) {\n          console.error(`Auth refresh failed for ${accountId}:`, error);\n          throw error;\n        }\n      },\n      onMaxRetriesExceeded: async (accountId, error) => {\n        console.error(`Authentication failed after refresh attempt for ${accountId}:`, error);\n      }\n    };\n  }\n  \n  /**\n   * Set the maximum number of retry attempts\n   */\n  public setMaxAttempts(attempts: number): void {\n    this.maxAttempts = attempts;\n  }\n\n  /**\n   * Update account data\n   */\n  public updateAccountData(accountId: string, data: Partial<Record<string, any>>): void {\n    this.accountManager.updateAccountData(accountId, data);\n  }\n\n  /**\n   * Make an API call with all features (caching, retry, hooks)\n   */\n  public async call(apiCallParams: Omit<ApiCallParams, 'accountId'> & { accountId?: string; abortSignal?: AbortSignal }): Promise<any> {\n    // Use 'default' as fallback if accountId is not provided\n    // and use default baseUrl if not provided\n    const params: ApiCallParams = {\n      ...apiCallParams,\n      accountId: apiCallParams.accountId || 'default',\n      base: apiCallParams.base || this.baseUrl,\n    };\n\n    // If using ApiKeyAuthProvider with queryParamName, add API key to queryParams\n    if (\n      this.authProvider instanceof ApiKeyAuthProvider &&\n      (this.authProvider as any).queryParamName\n    ) {\n      const queryParamName = (this.authProvider as any).queryParamName;\n      const apiKey = (this.authProvider as any).apiKey;\n      const urlParams = params.queryParams ? new URLSearchParams(params.queryParams) : new URLSearchParams();\n      urlParams.set(queryParamName, apiKey);\n      params.queryParams = urlParams;\n    }\n\n    console.log('🔄 API call', this.provider, params.accountId, params.method, params.route);\n    \n    // Check cache first\n    const cachedData = this.cacheManager.getFromCache(params);\n    if (cachedData) return cachedData;\n\n    // Make the API call with retry capability\n    const result = await this.makeRequestWithRetry(params);\n    \n    // Cache the result\n    this.cacheManager.saveToCache(params, result);\n    \n    return result;\n  }\n\n  /**\n   * Legacy method for backward compatibility\n   * @deprecated Use call() instead\n   */\n  public async makeApiCall(apiCallParams: Omit<ApiCallParams, 'accountId'> & { accountId?: string; abortSignal?: AbortSignal }): Promise<any> {\n    return this.call(apiCallParams);\n  }\n\n  /**\n   * Make a request with retry capability\n   */\n  private async makeRequestWithRetry(apiCallParams: ApiCallParams): Promise<any> {\n    const { accountId, abortSignal } = apiCallParams;\n    let attempts = 0;\n    const statusRetries: Record<StatusCode, number> = {};\n    let currentParams = { ...apiCallParams };\n    // If using ApiKeyAuthProvider with queryParamName, add API key to queryParams\n    if (\n      this.authProvider instanceof ApiKeyAuthProvider &&\n      (this.authProvider as any).queryParamName\n    ) {\n      const queryParamName = (this.authProvider as any).queryParamName;\n      const apiKey = (this.authProvider as any).apiKey;\n      const urlParams = currentParams.queryParams ? new URLSearchParams(currentParams.queryParams) : new URLSearchParams();\n      urlParams.set(queryParamName, apiKey);\n      currentParams.queryParams = urlParams;\n    }\n    // Main retry loop\n    while (attempts < this.maxAttempts) {\n      if (abortSignal?.aborted) {\n        throw new Error('Request aborted');\n      }\n      attempts++;\n      \n      try {\n        // Get authentication headers if needed\n        const authHeaders: Record<string, string> = apiCallParams.useAuth !== false\n          ? await this.authProvider.getAuthHeaders(accountId)\n          : {};\n        // Merge auth headers into params.headers\n        currentParams.headers = {\n          ...(currentParams.headers || {}),\n          ...authHeaders,\n        };\n        \n        // Verify we have authentication if required\n        if (\n          apiCallParams.useAuth !== false &&\n          Object.keys(authHeaders).length === 0 &&\n          !(\n            this.authProvider instanceof ApiKeyAuthProvider &&\n            (this.authProvider as any).queryParamName\n          )\n        ) {\n          throw new Error(`${this.provider} credentials not found for account ID ${accountId}`);\n        }\n        \n        // Make the actual API call\n        const response = await this.httpClient.makeRequest(currentParams, {});\n        \n        // Success - update account status and return result\n        this.accountManager.setLastRequestFailed(accountId, false);\n        return response;\n      } \n      catch (error: any) {\n        const status = error?.status;\n        \n        // If no hook exists for this error, or we shouldn't retry, throw\n        if (!this.hookManager.shouldRetry(status)) {\n          throw error;\n        }\n        \n        // Track retries for this status code\n        statusRetries[status] = (statusRetries[status] || 0) + 1;\n        const activeHook = this.hookManager.getHook(status);\n        const maxRetries = activeHook?.maxRetries ?? this.retryManager.getDefaultMaxRetries();\n        \n        // Check if we've exceeded retries for this status\n        if (statusRetries[status] > maxRetries) {\n          await this.hookManager.handleRetryFailure(accountId, status, error);\n          this.accountManager.setLastRequestFailed(accountId, true);\n          throw error;\n        }\n        \n        // Process the hook to get updated params\n        try {\n          const hookResult = await this.hookManager.processHook(accountId, status, error);\n          if (hookResult) {\n            currentParams = { ...currentParams, ...hookResult };\n          }\n        } \n        catch (hookError) {\n          this.accountManager.setLastRequestFailed(accountId, true);\n          throw hookError;\n        }\n        \n        // Wait before retrying if needed\n        if (activeHook?.useRetryDelay) {\n          await this.retryManager.calculateAndDelay({\n            attempt: statusRetries[status],\n            response: error.response,\n            hook: activeHook,\n          });\n        }\n      }\n    }\n    \n    // If we've reached here, we've exceeded our maximum attempts\n    this.accountManager.setLastRequestFailed(accountId, true);\n    throw new Error(`Exceeded maximum attempts (${this.maxAttempts}) for API call to ${accountId}`);\n  }\n\n  /**\n   * Set the cache time in milliseconds\n   */\n  public setCacheTime(milliseconds: number): void {\n    this.cacheManager.setCacheTime(milliseconds);\n  }\n\n  /**\n   * Clear the cache\n   */\n  public clearCache(): void {\n    this.cacheManager.clearCache();\n  }\n}\n\nexport default ApiService;\n"],"mappings":"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","ignoreList":[]}
|
|
667
|
+
this.accountManager.setLastRequestFailed(accountId, true);
|
|
668
|
+
throw new Error(`Exceeded maximum attempts (${this.maxAttempts}) for API call to ${accountId}`);
|
|
669
|
+
}
|
|
670
|
+
/**
|
|
671
|
+
* Set the cache time in milliseconds
|
|
672
|
+
*/
|
|
673
|
+
setCacheTime(milliseconds) {
|
|
674
|
+
this.cacheManager.setCacheTime(milliseconds);
|
|
675
|
+
}
|
|
676
|
+
/**
|
|
677
|
+
* Clear the cache
|
|
678
|
+
*/
|
|
679
|
+
clearCache() {
|
|
680
|
+
this.cacheManager.clearCache();
|
|
681
|
+
}
|
|
682
|
+
};
|
|
683
|
+
var index_default = ApiService;
|
|
684
|
+
//# sourceMappingURL=index.js.map
|