renovate 39.184.0 → 39.185.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/config/options/index.js +1 -1
- package/dist/config/options/index.js.map +1 -1
- package/dist/modules/manager/terraform/lockfile/hash.d.ts +1 -1
- package/dist/modules/platform/github/common.d.ts +2 -0
- package/dist/modules/platform/github/common.js +16 -0
- package/dist/modules/platform/github/common.js.map +1 -1
- package/dist/modules/platform/github/index.d.ts +1 -1
- package/dist/modules/platform/github/index.js +6 -4
- package/dist/modules/platform/github/index.js.map +1 -1
- package/dist/util/http/bitbucket-server.d.ts +2 -3
- package/dist/util/http/bitbucket-server.js +2 -2
- package/dist/util/http/bitbucket-server.js.map +1 -1
- package/dist/util/http/bitbucket.d.ts +2 -3
- package/dist/util/http/bitbucket.js +6 -7
- package/dist/util/http/bitbucket.js.map +1 -1
- package/dist/util/http/errors.d.ts +2 -0
- package/dist/util/http/errors.js +8 -0
- package/dist/util/http/errors.js.map +1 -0
- package/dist/util/http/gerrit.d.ts +2 -3
- package/dist/util/http/gerrit.js +2 -2
- package/dist/util/http/gerrit.js.map +1 -1
- package/dist/util/http/gitea.d.ts +2 -3
- package/dist/util/http/gitea.js +2 -2
- package/dist/util/http/gitea.js.map +1 -1
- package/dist/util/http/github.d.ts +9 -8
- package/dist/util/http/github.js +2 -2
- package/dist/util/http/github.js.map +1 -1
- package/dist/util/http/gitlab.d.ts +2 -3
- package/dist/util/http/gitlab.js +2 -2
- package/dist/util/http/gitlab.js.map +1 -1
- package/dist/util/http/got.d.ts +9 -0
- package/dist/util/http/got.js +54 -0
- package/dist/util/http/got.js.map +1 -0
- package/dist/util/http/http.d.ts +79 -3
- package/dist/util/http/http.js +336 -0
- package/dist/util/http/http.js.map +1 -1
- package/dist/util/http/index.d.ts +6 -81
- package/dist/util/http/index.js +5 -372
- package/dist/util/http/index.js.map +1 -1
- package/dist/util/http/types.d.ts +5 -8
- package/dist/util/http/types.js.map +1 -1
- package/package.json +1 -1
package/dist/util/http/index.js
CHANGED
@@ -1,379 +1,12 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.Http = exports.EmptyResultError = exports.HttpError = void 0;
|
4
|
-
const
|
5
|
-
|
6
|
-
require("./
|
7
|
-
const is_1 = tslib_1.__importDefault(require("@sindresorhus/is"));
|
8
|
-
const deepmerge_1 = tslib_1.__importDefault(require("deepmerge"));
|
9
|
-
const got_1 = tslib_1.__importStar(require("got"));
|
4
|
+
const errors_1 = require("./errors");
|
5
|
+
Object.defineProperty(exports, "EmptyResultError", { enumerable: true, get: function () { return errors_1.EmptyResultError; } });
|
6
|
+
const got_1 = require("./got");
|
10
7
|
Object.defineProperty(exports, "HttpError", { enumerable: true, get: function () { return got_1.RequestError; } });
|
11
|
-
const
|
12
|
-
|
13
|
-
const error_messages_1 = require("../../constants/error-messages");
|
14
|
-
const expose_cjs_1 = require("../../expose.cjs");
|
15
|
-
const logger_1 = require("../../logger");
|
16
|
-
const external_host_error_1 = require("../../types/errors/external-host-error");
|
17
|
-
const memCache = tslib_1.__importStar(require("../cache/memory"));
|
18
|
-
const hash_1 = require("../hash");
|
19
|
-
const result_1 = require("../result");
|
20
|
-
const stats_1 = require("../stats");
|
21
|
-
const url_1 = require("../url");
|
22
|
-
const yaml_1 = require("../yaml");
|
23
|
-
const auth_1 = require("./auth");
|
24
|
-
const hooks_1 = require("./hooks");
|
25
|
-
const host_rules_1 = require("./host-rules");
|
26
|
-
const queue_1 = require("./queue");
|
27
|
-
const retry_after_1 = require("./retry-after");
|
28
|
-
const throttle_1 = require("./throttle");
|
29
|
-
const util_1 = require("./util");
|
30
|
-
class EmptyResultError extends Error {
|
31
|
-
}
|
32
|
-
exports.EmptyResultError = EmptyResultError;
|
33
|
-
function applyDefaultHeaders(options) {
|
34
|
-
const renovateVersion = expose_cjs_1.pkg.version;
|
35
|
-
options.headers = {
|
36
|
-
...options.headers,
|
37
|
-
'user-agent': global_1.GlobalConfig.get('userAgent') ??
|
38
|
-
`RenovateBot/${renovateVersion} (https://github.com/renovatebot/renovate)`,
|
39
|
-
};
|
40
|
-
}
|
41
|
-
async function gotTask(url, options, queueStats) {
|
42
|
-
logger_1.logger.trace({ url, options }, 'got request');
|
43
|
-
let duration = 0;
|
44
|
-
let statusCode = 0;
|
45
|
-
try {
|
46
|
-
// Cheat the TS compiler using `as` to pick a specific overload.
|
47
|
-
// Otherwise it doesn't typecheck.
|
48
|
-
const resp = await (0, got_1.default)(url, { ...options, hooks: hooks_1.hooks });
|
49
|
-
statusCode = resp.statusCode;
|
50
|
-
duration =
|
51
|
-
resp.timings.phases.total ?? /* v8 ignore next: can't be tested */ 0;
|
52
|
-
return resp;
|
53
|
-
}
|
54
|
-
catch (error) {
|
55
|
-
if (error instanceof got_1.RequestError) {
|
56
|
-
statusCode = error.response?.statusCode ?? -1;
|
57
|
-
duration =
|
58
|
-
error.timings?.phases.total ?? /* v8 ignore next: can't be tested */ -1;
|
59
|
-
const method = options.method.toUpperCase();
|
60
|
-
const code = error.code ?? /* v8 ignore next */ 'UNKNOWN';
|
61
|
-
const retryCount = error.request?.retryCount ?? /* v8 ignore next */ -1;
|
62
|
-
logger_1.logger.debug(`${method} ${url} = (code=${code}, statusCode=${statusCode} retryCount=${retryCount}, duration=${duration})`);
|
63
|
-
}
|
64
|
-
throw error;
|
65
|
-
/* v8 ignore next: 🐛 https://github.com/bcoe/c8/issues/229 */
|
66
|
-
}
|
67
|
-
finally {
|
68
|
-
stats_1.HttpStats.write({
|
69
|
-
method: options.method,
|
70
|
-
url,
|
71
|
-
reqMs: duration,
|
72
|
-
queueMs: queueStats.queueMs,
|
73
|
-
status: statusCode,
|
74
|
-
});
|
75
|
-
}
|
76
|
-
}
|
77
|
-
class Http {
|
78
|
-
hostType;
|
79
|
-
options;
|
80
|
-
get baseUrl() {
|
81
|
-
return undefined;
|
82
|
-
}
|
83
|
-
constructor(hostType, options = {}) {
|
84
|
-
this.hostType = hostType;
|
85
|
-
const retryLimit = process.env.NODE_ENV === 'test' ? 0 : 2;
|
86
|
-
this.options = (0, deepmerge_1.default)(options, {
|
87
|
-
method: 'get',
|
88
|
-
context: { hostType },
|
89
|
-
retry: {
|
90
|
-
calculateDelay: (retryObject) => this.calculateRetryDelay(retryObject),
|
91
|
-
limit: retryLimit,
|
92
|
-
maxRetryAfter: 0, // Don't rely on `got` retry-after handling, just let it fail and then we'll handle it
|
93
|
-
},
|
94
|
-
}, { isMergeableObject: is_1.default.plainObject });
|
95
|
-
}
|
96
|
-
async request(requestUrl, httpOptions) {
|
97
|
-
const resolvedUrl = this.resolveUrl(requestUrl, httpOptions);
|
98
|
-
const url = resolvedUrl.toString();
|
99
|
-
this.processOptions(resolvedUrl, httpOptions);
|
100
|
-
let options = (0, deepmerge_1.default)({
|
101
|
-
...this.options,
|
102
|
-
hostType: this.hostType,
|
103
|
-
}, httpOptions, { isMergeableObject: is_1.default.plainObject });
|
104
|
-
logger_1.logger.trace(`HTTP request: ${options.method.toUpperCase()} ${url}`);
|
105
|
-
options.hooks = {
|
106
|
-
beforeRedirect: [auth_1.removeAuthorization],
|
107
|
-
};
|
108
|
-
applyDefaultHeaders(options);
|
109
|
-
if (is_1.default.undefined(options.readOnly) &&
|
110
|
-
['head', 'get'].includes(options.method)) {
|
111
|
-
options.readOnly = true;
|
112
|
-
}
|
113
|
-
const hostRule = (0, host_rules_1.findMatchingRule)(url, options);
|
114
|
-
options = (0, host_rules_1.applyHostRule)(url, options, hostRule);
|
115
|
-
if (options.enabled === false) {
|
116
|
-
logger_1.logger.debug(`Host is disabled - rejecting request. HostUrl: ${url}`);
|
117
|
-
throw new Error(error_messages_1.HOST_DISABLED);
|
118
|
-
}
|
119
|
-
options = (0, auth_1.applyAuthorization)(options);
|
120
|
-
options.timeout ??= 60000;
|
121
|
-
const { cacheProvider } = options;
|
122
|
-
const cachedResponse = await cacheProvider?.bypassServer(url);
|
123
|
-
if (cachedResponse) {
|
124
|
-
return cachedResponse;
|
125
|
-
}
|
126
|
-
const memCacheKey = options.memCache !== false &&
|
127
|
-
(options.method === 'get' || options.method === 'head')
|
128
|
-
? (0, hash_1.hash)(`got-${JSON.stringify({
|
129
|
-
url,
|
130
|
-
headers: options.headers,
|
131
|
-
method: options.method,
|
132
|
-
})}`)
|
133
|
-
: null;
|
134
|
-
let resPromise = null;
|
135
|
-
// Cache GET requests unless memCache=false
|
136
|
-
if (memCacheKey) {
|
137
|
-
resPromise = memCache.get(memCacheKey);
|
138
|
-
}
|
139
|
-
if (!resPromise) {
|
140
|
-
if (cacheProvider) {
|
141
|
-
await cacheProvider.setCacheHeaders(url, options);
|
142
|
-
}
|
143
|
-
const startTime = Date.now();
|
144
|
-
const httpTask = () => {
|
145
|
-
const queueMs = Date.now() - startTime;
|
146
|
-
return gotTask(url, options, { queueMs });
|
147
|
-
};
|
148
|
-
const throttle = (0, throttle_1.getThrottle)(url);
|
149
|
-
const throttledTask = throttle ? () => throttle.add(httpTask) : httpTask;
|
150
|
-
const queue = (0, queue_1.getQueue)(url);
|
151
|
-
const queuedTask = queue ? () => queue.add(throttledTask) : throttledTask;
|
152
|
-
const { maxRetryAfter = 60 } = hostRule;
|
153
|
-
resPromise = (0, retry_after_1.wrapWithRetry)(queuedTask, url, retry_after_1.getRetryAfter, maxRetryAfter);
|
154
|
-
if (memCacheKey) {
|
155
|
-
memCache.set(memCacheKey, resPromise);
|
156
|
-
}
|
157
|
-
}
|
158
|
-
try {
|
159
|
-
const res = await resPromise;
|
160
|
-
const deepCopyNeeded = !!memCacheKey && res.statusCode !== 304;
|
161
|
-
const resCopy = (0, util_1.copyResponse)(res, deepCopyNeeded);
|
162
|
-
resCopy.authorization = !!options?.headers?.authorization;
|
163
|
-
if (cacheProvider) {
|
164
|
-
return await cacheProvider.wrapServerResponse(url, resCopy);
|
165
|
-
}
|
166
|
-
return resCopy;
|
167
|
-
}
|
168
|
-
catch (err) {
|
169
|
-
const { abortOnError, abortIgnoreStatusCodes } = options;
|
170
|
-
if (abortOnError && !abortIgnoreStatusCodes?.includes(err.statusCode)) {
|
171
|
-
throw new external_host_error_1.ExternalHostError(err);
|
172
|
-
}
|
173
|
-
const staleResponse = await cacheProvider?.bypassServer(url, true);
|
174
|
-
if (staleResponse) {
|
175
|
-
logger_1.logger.debug({ err }, `Request error: returning stale cache instead for ${url}`);
|
176
|
-
return staleResponse;
|
177
|
-
}
|
178
|
-
this.handleError(requestUrl, httpOptions, err);
|
179
|
-
}
|
180
|
-
}
|
181
|
-
processOptions(_url, _options) {
|
182
|
-
// noop
|
183
|
-
}
|
184
|
-
handleError(_url, _httpOptions, err) {
|
185
|
-
throw err;
|
186
|
-
}
|
187
|
-
resolveUrl(requestUrl, options) {
|
188
|
-
let url = requestUrl;
|
189
|
-
if (url instanceof URL) {
|
190
|
-
// already a aboslute URL
|
191
|
-
return url;
|
192
|
-
}
|
193
|
-
const baseUrl = options?.baseUrl ?? this.baseUrl;
|
194
|
-
if (baseUrl) {
|
195
|
-
url = (0, url_1.resolveBaseUrl)(baseUrl, url);
|
196
|
-
}
|
197
|
-
const parsedUrl = (0, url_1.parseUrl)(url);
|
198
|
-
if (!parsedUrl || !(0, url_1.isHttpUrl)(parsedUrl)) {
|
199
|
-
logger_1.logger.error({ url: requestUrl }, 'Request Error: cannot parse url');
|
200
|
-
throw new Error('Invalid URL');
|
201
|
-
}
|
202
|
-
return parsedUrl;
|
203
|
-
}
|
204
|
-
calculateRetryDelay({ computedValue }) {
|
205
|
-
return computedValue;
|
206
|
-
}
|
207
|
-
get(url, options = {}) {
|
208
|
-
return this.request(url, options);
|
209
|
-
}
|
210
|
-
head(url, options = {}) {
|
211
|
-
// to complex to validate
|
212
|
-
return this.request(url, {
|
213
|
-
...options,
|
214
|
-
responseType: 'text',
|
215
|
-
method: 'head',
|
216
|
-
});
|
217
|
-
}
|
218
|
-
getText(url, options = {}) {
|
219
|
-
return this.request(url, { ...options, responseType: 'text' });
|
220
|
-
}
|
221
|
-
getBuffer(url, options = {}) {
|
222
|
-
return this.request(url, { ...options, responseType: 'buffer' });
|
223
|
-
}
|
224
|
-
requestJsonUnsafe(method, { url, httpOptions: requestOptions }) {
|
225
|
-
const { body: json, ...httpOptions } = { ...requestOptions };
|
226
|
-
const opts = {
|
227
|
-
...httpOptions,
|
228
|
-
method,
|
229
|
-
};
|
230
|
-
// signal that we expect a json response
|
231
|
-
opts.headers = {
|
232
|
-
accept: 'application/json',
|
233
|
-
...opts.headers,
|
234
|
-
};
|
235
|
-
if (json) {
|
236
|
-
opts.json = json;
|
237
|
-
}
|
238
|
-
return this.request(url, { ...opts, responseType: 'json' });
|
239
|
-
}
|
240
|
-
async requestJson(method, options) {
|
241
|
-
const res = await this.requestJsonUnsafe(method, options);
|
242
|
-
if (options.schema) {
|
243
|
-
res.body = await options.schema.parseAsync(res.body);
|
244
|
-
}
|
245
|
-
return res;
|
246
|
-
}
|
247
|
-
resolveArgs(arg1, arg2, arg3) {
|
248
|
-
const res = { url: arg1 };
|
249
|
-
if (arg2 instanceof zod_1.ZodType) {
|
250
|
-
res.schema = arg2;
|
251
|
-
}
|
252
|
-
else if (arg2) {
|
253
|
-
res.httpOptions = arg2;
|
254
|
-
}
|
255
|
-
if (arg3) {
|
256
|
-
res.schema = arg3;
|
257
|
-
}
|
258
|
-
return res;
|
259
|
-
}
|
260
|
-
async getPlain(url, options) {
|
261
|
-
const opt = options ?? {};
|
262
|
-
return await this.getText(url, {
|
263
|
-
headers: {
|
264
|
-
Accept: 'text/plain',
|
265
|
-
},
|
266
|
-
...opt,
|
267
|
-
});
|
268
|
-
}
|
269
|
-
/**
|
270
|
-
* @deprecated use `getYaml` instead
|
271
|
-
*/
|
272
|
-
async getYamlUnchecked(url, options) {
|
273
|
-
const res = await this.getText(url, options);
|
274
|
-
const body = (0, yaml_1.parseSingleYaml)(res.body);
|
275
|
-
return { ...res, body };
|
276
|
-
}
|
277
|
-
async getYaml(arg1, arg2, arg3) {
|
278
|
-
const url = arg1;
|
279
|
-
let schema;
|
280
|
-
let httpOptions;
|
281
|
-
if (arg3) {
|
282
|
-
schema = arg3;
|
283
|
-
httpOptions = arg2;
|
284
|
-
}
|
285
|
-
else {
|
286
|
-
schema = arg2;
|
287
|
-
}
|
288
|
-
const opts = {
|
289
|
-
...httpOptions,
|
290
|
-
method: 'get',
|
291
|
-
};
|
292
|
-
const res = await this.getText(url, opts);
|
293
|
-
const body = await schema.parseAsync((0, yaml_1.parseSingleYaml)(res.body));
|
294
|
-
return { ...res, body };
|
295
|
-
}
|
296
|
-
getYamlSafe(arg1, arg2, arg3) {
|
297
|
-
const url = arg1;
|
298
|
-
let schema;
|
299
|
-
let httpOptions;
|
300
|
-
if (arg3) {
|
301
|
-
schema = arg3;
|
302
|
-
httpOptions = arg2;
|
303
|
-
}
|
304
|
-
else {
|
305
|
-
schema = arg2;
|
306
|
-
}
|
307
|
-
let res;
|
308
|
-
if (httpOptions) {
|
309
|
-
res = result_1.Result.wrap(this.getYaml(url, httpOptions, schema));
|
310
|
-
}
|
311
|
-
else {
|
312
|
-
res = result_1.Result.wrap(this.getYaml(url, schema));
|
313
|
-
}
|
314
|
-
return res.transform((response) => result_1.Result.ok(response.body));
|
315
|
-
}
|
316
|
-
/**
|
317
|
-
* Request JSON and return the response without any validation.
|
318
|
-
*
|
319
|
-
* The usage of this method is discouraged, please use `getJson` instead.
|
320
|
-
*
|
321
|
-
* If you're new to Zod schema validation library:
|
322
|
-
* - consult the [documentation of Zod library](https://github.com/colinhacks/zod?tab=readme-ov-file#basic-usage)
|
323
|
-
* - search the Renovate codebase for 'zod' module usage
|
324
|
-
* - take a look at the `schema-utils.ts` file for Renovate-specific schemas and utilities
|
325
|
-
*/
|
326
|
-
getJsonUnchecked(url, options) {
|
327
|
-
return this.requestJson('get', { url, httpOptions: options });
|
328
|
-
}
|
329
|
-
getJson(arg1, arg2, arg3) {
|
330
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
331
|
-
return this.requestJson('get', args);
|
332
|
-
}
|
333
|
-
getJsonSafe(arg1, arg2, arg3) {
|
334
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
335
|
-
return result_1.Result.wrap(this.requestJson('get', args)).transform((response) => result_1.Result.ok(response.body));
|
336
|
-
}
|
337
|
-
headJson(url, httpOptions) {
|
338
|
-
return this.requestJson('head', { url, httpOptions });
|
339
|
-
}
|
340
|
-
postJson(arg1, arg2, arg3) {
|
341
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
342
|
-
return this.requestJson('post', args);
|
343
|
-
}
|
344
|
-
putJson(arg1, arg2, arg3) {
|
345
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
346
|
-
return this.requestJson('put', args);
|
347
|
-
}
|
348
|
-
patchJson(arg1, arg2, arg3) {
|
349
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
350
|
-
return this.requestJson('patch', args);
|
351
|
-
}
|
352
|
-
deleteJson(arg1, arg2, arg3) {
|
353
|
-
const args = this.resolveArgs(arg1, arg2, arg3);
|
354
|
-
return this.requestJson('delete', args);
|
355
|
-
}
|
356
|
-
stream(url, options) {
|
357
|
-
// TODO: fix types (#22198)
|
358
|
-
let combinedOptions = {
|
359
|
-
...this.options,
|
360
|
-
hostType: this.hostType,
|
361
|
-
...options,
|
362
|
-
};
|
363
|
-
const resolvedUrl = this.resolveUrl(url, options).toString();
|
364
|
-
applyDefaultHeaders(combinedOptions);
|
365
|
-
if (is_1.default.undefined(combinedOptions.readOnly) &&
|
366
|
-
['head', 'get'].includes(combinedOptions.method)) {
|
367
|
-
combinedOptions.readOnly = true;
|
368
|
-
}
|
369
|
-
const hostRule = (0, host_rules_1.findMatchingRule)(url, combinedOptions);
|
370
|
-
combinedOptions = (0, host_rules_1.applyHostRule)(resolvedUrl, combinedOptions, hostRule);
|
371
|
-
if (combinedOptions.enabled === false) {
|
372
|
-
throw new Error(error_messages_1.HOST_DISABLED);
|
373
|
-
}
|
374
|
-
combinedOptions = (0, auth_1.applyAuthorization)(combinedOptions);
|
375
|
-
return got_1.default.stream(resolvedUrl, combinedOptions);
|
376
|
-
}
|
8
|
+
const http_1 = require("./http");
|
9
|
+
class Http extends http_1.HttpBase {
|
377
10
|
}
|
378
11
|
exports.Http = Http;
|
379
12
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/util/http/index.ts"],"names":[],"mappings":"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","sourcesContent":["// TODO: refactor code to remove this (#9651)\nimport './legacy';\n\nimport is from '@sindresorhus/is';\nimport merge from 'deepmerge';\nimport type { Options, RetryObject } from 'got';\nimport got, { RequestError } from 'got';\nimport type { SetRequired } from 'type-fest';\nimport type { infer as Infer, ZodError } from 'zod';\nimport { ZodType } from 'zod';\nimport { GlobalConfig } from '../../config/global';\nimport { HOST_DISABLED } from '../../constants/error-messages';\nimport { pkg } from '../../expose.cjs';\nimport { logger } from '../../logger';\nimport { ExternalHostError } from '../../types/errors/external-host-error';\nimport * as memCache from '../cache/memory';\nimport { hash } from '../hash';\nimport { type AsyncResult, Result } from '../result';\nimport { type HttpRequestStatsDataPoint, HttpStats } from '../stats';\nimport { isHttpUrl, parseUrl, resolveBaseUrl } from '../url';\nimport { parseSingleYaml } from '../yaml';\nimport { applyAuthorization, removeAuthorization } from './auth';\nimport { hooks } from './hooks';\nimport { applyHostRule, findMatchingRule } from './host-rules';\nimport type {\n InternalGotOptions,\n InternalHttpOptions,\n InternalJsonOptions,\n InternalJsonUnsafeOptions,\n} from './http';\nimport { getQueue } from './queue';\nimport { getRetryAfter, wrapWithRetry } from './retry-after';\nimport { getThrottle } from './throttle';\nimport type {\n GotBufferOptions,\n GotOptions,\n GotTask,\n HttpMethod,\n HttpOptions,\n HttpResponse,\n} from './types';\nimport { copyResponse } from './util';\n\nexport { RequestError as HttpError };\n\nexport class EmptyResultError extends Error {}\nexport type SafeJsonError = RequestError | ZodError | EmptyResultError;\n\nfunction applyDefaultHeaders(options: Options): void {\n const renovateVersion = pkg.version;\n options.headers = {\n ...options.headers,\n 'user-agent':\n GlobalConfig.get('userAgent') ??\n `RenovateBot/${renovateVersion} (https://github.com/renovatebot/renovate)`,\n };\n}\n\ntype QueueStatsData = Pick<HttpRequestStatsDataPoint, 'queueMs'>;\n\nasync function gotTask(\n url: string,\n options: SetRequired<GotOptions, 'method'>,\n queueStats: QueueStatsData,\n): Promise<HttpResponse<unknown>> {\n logger.trace({ url, options }, 'got request');\n\n let duration = 0;\n let statusCode = 0;\n try {\n // Cheat the TS compiler using `as` to pick a specific overload.\n // Otherwise it doesn't typecheck.\n const resp = await got(url, { ...options, hooks } as GotBufferOptions);\n statusCode = resp.statusCode;\n duration =\n resp.timings.phases.total ?? /* v8 ignore next: can't be tested */ 0;\n return resp;\n } catch (error) {\n if (error instanceof RequestError) {\n statusCode = error.response?.statusCode ?? -1;\n duration =\n error.timings?.phases.total ?? /* v8 ignore next: can't be tested */ -1;\n const method = options.method.toUpperCase();\n const code = error.code ?? /* v8 ignore next */ 'UNKNOWN';\n const retryCount = error.request?.retryCount ?? /* v8 ignore next */ -1;\n logger.debug(\n `${method} ${url} = (code=${code}, statusCode=${statusCode} retryCount=${retryCount}, duration=${duration})`,\n );\n }\n\n throw error;\n /* v8 ignore next: 🐛 https://github.com/bcoe/c8/issues/229 */\n } finally {\n HttpStats.write({\n method: options.method,\n url,\n reqMs: duration,\n queueMs: queueStats.queueMs,\n status: statusCode,\n });\n }\n}\n\nexport class Http<Opts extends HttpOptions = HttpOptions> {\n private readonly options: InternalGotOptions;\n\n protected get baseUrl(): string | undefined {\n return undefined;\n }\n\n constructor(\n protected hostType: string,\n options: HttpOptions = {},\n ) {\n const retryLimit = process.env.NODE_ENV === 'test' ? 0 : 2;\n this.options = merge<InternalGotOptions>(\n options,\n {\n method: 'get',\n context: { hostType },\n retry: {\n calculateDelay: (retryObject) =>\n this.calculateRetryDelay(retryObject),\n limit: retryLimit,\n maxRetryAfter: 0, // Don't rely on `got` retry-after handling, just let it fail and then we'll handle it\n },\n },\n { isMergeableObject: is.plainObject },\n );\n }\n private async request(\n requestUrl: string | URL,\n httpOptions: InternalHttpOptions,\n ): Promise<HttpResponse<string>>;\n private async request(\n requestUrl: string | URL,\n httpOptions: InternalHttpOptions & { responseType: 'text' },\n ): Promise<HttpResponse<string>>;\n private async request(\n requestUrl: string | URL,\n httpOptions: InternalHttpOptions & { responseType: 'buffer' },\n ): Promise<HttpResponse<Buffer>>;\n private async request<T = unknown>(\n requestUrl: string | URL,\n httpOptions: InternalHttpOptions & { responseType: 'json' },\n ): Promise<HttpResponse<T>>;\n\n private async request(\n requestUrl: string | URL,\n httpOptions: InternalHttpOptions,\n ): Promise<HttpResponse<unknown>> {\n const resolvedUrl = this.resolveUrl(requestUrl, httpOptions);\n const url = resolvedUrl.toString();\n\n this.processOptions(resolvedUrl, httpOptions);\n\n let options = merge<InternalGotOptions, InternalHttpOptions>(\n {\n ...this.options,\n hostType: this.hostType,\n },\n httpOptions,\n { isMergeableObject: is.plainObject },\n );\n\n logger.trace(`HTTP request: ${options.method.toUpperCase()} ${url}`);\n\n options.hooks = {\n beforeRedirect: [removeAuthorization],\n };\n\n applyDefaultHeaders(options);\n\n if (\n is.undefined(options.readOnly) &&\n ['head', 'get'].includes(options.method)\n ) {\n options.readOnly = true;\n }\n\n const hostRule = findMatchingRule(url, options);\n options = applyHostRule(url, options, hostRule);\n if (options.enabled === false) {\n logger.debug(`Host is disabled - rejecting request. HostUrl: ${url}`);\n throw new Error(HOST_DISABLED);\n }\n options = applyAuthorization(options);\n options.timeout ??= 60000;\n\n const { cacheProvider } = options;\n const cachedResponse = await cacheProvider?.bypassServer<string | Buffer>(\n url,\n );\n if (cachedResponse) {\n return cachedResponse;\n }\n\n const memCacheKey =\n options.memCache !== false &&\n (options.method === 'get' || options.method === 'head')\n ? hash(\n `got-${JSON.stringify({\n url,\n headers: options.headers,\n method: options.method,\n })}`,\n )\n : null;\n\n let resPromise: Promise<HttpResponse<unknown>> | null = null;\n\n // Cache GET requests unless memCache=false\n if (memCacheKey) {\n resPromise = memCache.get(memCacheKey);\n }\n\n if (!resPromise) {\n if (cacheProvider) {\n await cacheProvider.setCacheHeaders(url, options);\n }\n\n const startTime = Date.now();\n const httpTask: GotTask = () => {\n const queueMs = Date.now() - startTime;\n return gotTask(url, options, { queueMs });\n };\n\n const throttle = getThrottle(url);\n const throttledTask = throttle ? () => throttle.add(httpTask) : httpTask;\n\n const queue = getQueue(url);\n const queuedTask = queue ? () => queue.add(throttledTask) : throttledTask;\n\n const { maxRetryAfter = 60 } = hostRule;\n resPromise = wrapWithRetry(queuedTask, url, getRetryAfter, maxRetryAfter);\n\n if (memCacheKey) {\n memCache.set(memCacheKey, resPromise);\n }\n }\n\n try {\n const res = await resPromise;\n const deepCopyNeeded = !!memCacheKey && res.statusCode !== 304;\n const resCopy = copyResponse(res, deepCopyNeeded);\n resCopy.authorization = !!options?.headers?.authorization;\n\n if (cacheProvider) {\n return await cacheProvider.wrapServerResponse(url, resCopy);\n }\n\n return resCopy;\n } catch (err) {\n const { abortOnError, abortIgnoreStatusCodes } = options;\n if (abortOnError && !abortIgnoreStatusCodes?.includes(err.statusCode)) {\n throw new ExternalHostError(err);\n }\n\n const staleResponse = await cacheProvider?.bypassServer<string | Buffer>(\n url,\n true,\n );\n if (staleResponse) {\n logger.debug(\n { err },\n `Request error: returning stale cache instead for ${url}`,\n );\n return staleResponse;\n }\n\n this.handleError(requestUrl, httpOptions, err);\n }\n }\n\n protected processOptions(_url: URL, _options: InternalHttpOptions): void {\n // noop\n }\n\n protected handleError(\n _url: string | URL,\n _httpOptions: HttpOptions,\n err: Error,\n ): never {\n throw err;\n }\n\n protected resolveUrl(\n requestUrl: string | URL,\n options: HttpOptions | undefined,\n ): URL {\n let url = requestUrl;\n\n if (url instanceof URL) {\n // already a aboslute URL\n return url;\n }\n\n const baseUrl = options?.baseUrl ?? this.baseUrl;\n if (baseUrl) {\n url = resolveBaseUrl(baseUrl, url);\n }\n\n const parsedUrl = parseUrl(url);\n if (!parsedUrl || !isHttpUrl(parsedUrl)) {\n logger.error({ url: requestUrl }, 'Request Error: cannot parse url');\n throw new Error('Invalid URL');\n }\n return parsedUrl;\n }\n\n protected calculateRetryDelay({ computedValue }: RetryObject): number {\n return computedValue;\n }\n\n get(\n url: string,\n options: HttpOptions = {},\n ): Promise<HttpResponse<string | Buffer>> {\n return this.request(url, options);\n }\n\n head(url: string, options: HttpOptions = {}): Promise<HttpResponse<never>> {\n // to complex to validate\n return this.request(url, {\n ...options,\n responseType: 'text',\n method: 'head',\n }) as Promise<HttpResponse<never>>;\n }\n\n getText(\n url: string | URL,\n options: HttpOptions = {},\n ): Promise<HttpResponse<string>> {\n return this.request(url, { ...options, responseType: 'text' });\n }\n\n getBuffer(\n url: string | URL,\n options: HttpOptions = {},\n ): Promise<HttpResponse<Buffer>> {\n return this.request(url, { ...options, responseType: 'buffer' });\n }\n\n protected requestJsonUnsafe<ResT>(\n method: HttpMethod,\n { url, httpOptions: requestOptions }: InternalJsonUnsafeOptions<Opts>,\n ): Promise<HttpResponse<ResT>> {\n const { body: json, ...httpOptions } = { ...requestOptions };\n const opts: InternalHttpOptions = {\n ...httpOptions,\n method,\n };\n // signal that we expect a json response\n opts.headers = {\n accept: 'application/json',\n ...opts.headers,\n };\n if (json) {\n opts.json = json;\n }\n return this.request<ResT>(url, { ...opts, responseType: 'json' });\n }\n\n private async requestJson<ResT, Schema extends ZodType<ResT> = ZodType<ResT>>(\n method: HttpMethod,\n options: InternalJsonOptions<Opts, ResT, Schema>,\n ): Promise<HttpResponse<ResT>> {\n const res = await this.requestJsonUnsafe<ResT>(method, options);\n\n if (options.schema) {\n res.body = await options.schema.parseAsync(res.body);\n }\n\n return res;\n }\n\n private resolveArgs<ResT = unknown>(\n arg1: string,\n arg2: Opts | ZodType<ResT> | undefined,\n arg3: ZodType<ResT> | undefined,\n ): InternalJsonOptions<Opts, ResT> {\n const res: InternalJsonOptions<Opts, ResT> = { url: arg1 };\n\n if (arg2 instanceof ZodType) {\n res.schema = arg2;\n } else if (arg2) {\n res.httpOptions = arg2;\n }\n\n if (arg3) {\n res.schema = arg3;\n }\n\n return res;\n }\n\n async getPlain(url: string, options?: Opts): Promise<HttpResponse> {\n const opt = options ?? {};\n return await this.getText(url, {\n headers: {\n Accept: 'text/plain',\n },\n ...opt,\n });\n }\n\n /**\n * @deprecated use `getYaml` instead\n */\n async getYamlUnchecked<ResT>(\n url: string,\n options?: Opts,\n ): Promise<HttpResponse<ResT>> {\n const res = await this.getText(url, options);\n const body = parseSingleYaml<ResT>(res.body);\n return { ...res, body };\n }\n\n async getYaml<Schema extends ZodType<any, any, any>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n async getYaml<Schema extends ZodType<any, any, any>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n async getYaml<Schema extends ZodType<any, any, any>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): Promise<HttpResponse<Infer<Schema>>> {\n const url = arg1;\n let schema: Schema;\n let httpOptions: Opts | undefined;\n if (arg3) {\n schema = arg3;\n httpOptions = arg2 as Opts;\n } else {\n schema = arg2 as Schema;\n }\n\n const opts: InternalHttpOptions = {\n ...httpOptions,\n method: 'get',\n };\n\n const res = await this.getText(url, opts);\n const body = await schema.parseAsync(parseSingleYaml(res.body));\n return { ...res, body };\n }\n\n getYamlSafe<\n ResT extends NonNullable<unknown>,\n Schema extends ZodType<ResT> = ZodType<ResT>,\n >(url: string, schema: Schema): AsyncResult<Infer<Schema>, SafeJsonError>;\n getYamlSafe<\n ResT extends NonNullable<unknown>,\n Schema extends ZodType<ResT> = ZodType<ResT>,\n >(\n url: string,\n options: Opts,\n schema: Schema,\n ): AsyncResult<Infer<Schema>, SafeJsonError>;\n getYamlSafe<\n ResT extends NonNullable<unknown>,\n Schema extends ZodType<ResT> = ZodType<ResT>,\n >(\n arg1: string,\n arg2: Opts | Schema,\n arg3?: Schema,\n ): AsyncResult<ResT, SafeJsonError> {\n const url = arg1;\n let schema: Schema;\n let httpOptions: Opts | undefined;\n if (arg3) {\n schema = arg3;\n httpOptions = arg2 as Opts;\n } else {\n schema = arg2 as Schema;\n }\n\n let res: AsyncResult<HttpResponse<ResT>, SafeJsonError>;\n if (httpOptions) {\n res = Result.wrap(this.getYaml(url, httpOptions, schema));\n } else {\n res = Result.wrap(this.getYaml(url, schema));\n }\n\n return res.transform((response) => Result.ok(response.body));\n }\n\n /**\n * Request JSON and return the response without any validation.\n *\n * The usage of this method is discouraged, please use `getJson` instead.\n *\n * If you're new to Zod schema validation library:\n * - consult the [documentation of Zod library](https://github.com/colinhacks/zod?tab=readme-ov-file#basic-usage)\n * - search the Renovate codebase for 'zod' module usage\n * - take a look at the `schema-utils.ts` file for Renovate-specific schemas and utilities\n */\n getJsonUnchecked<ResT = unknown>(\n url: string,\n options?: Opts,\n ): Promise<HttpResponse<ResT>> {\n return this.requestJson<ResT>('get', { url, httpOptions: options });\n }\n\n /**\n * Request JSON with a Zod schema for the response,\n * throwing an error if the response is not valid.\n *\n * @param url\n * @param schema Zod schema for the response\n */\n getJson<Schema extends ZodType<any, any, any>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n getJson<Schema extends ZodType<any, any, any>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n getJson<Schema extends ZodType<any, any, any>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): Promise<HttpResponse<Infer<Schema>>> {\n const args = this.resolveArgs<Infer<Schema>>(arg1, arg2, arg3);\n return this.requestJson<Infer<Schema>>('get', args);\n }\n\n /**\n * Request JSON with a Zod schema for the response,\n * wrapping response data in a `Result` class.\n *\n * @param url\n * @param schema Zod schema for the response\n */\n getJsonSafe<ResT extends NonNullable<unknown>, Schema extends ZodType<ResT>>(\n url: string,\n schema: Schema,\n ): AsyncResult<Infer<Schema>, SafeJsonError>;\n getJsonSafe<ResT extends NonNullable<unknown>, Schema extends ZodType<ResT>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): AsyncResult<Infer<Schema>, SafeJsonError>;\n getJsonSafe<ResT extends NonNullable<unknown>, Schema extends ZodType<ResT>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): AsyncResult<ResT, SafeJsonError> {\n const args = this.resolveArgs<ResT>(arg1, arg2, arg3);\n return Result.wrap(this.requestJson<ResT>('get', args)).transform(\n (response) => Result.ok(response.body),\n );\n }\n\n headJson(url: string, httpOptions?: Opts): Promise<HttpResponse<never>> {\n return this.requestJson<never>('head', { url, httpOptions });\n }\n\n postJson<T>(url: string, options?: Opts): Promise<HttpResponse<T>>;\n postJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n postJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n postJson<T = unknown, Schema extends ZodType<T> = ZodType<T>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): Promise<HttpResponse<T>> {\n const args = this.resolveArgs(arg1, arg2, arg3);\n return this.requestJson<T>('post', args);\n }\n\n putJson<T>(url: string, options?: Opts): Promise<HttpResponse<T>>;\n putJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n putJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n putJson<T = unknown, Schema extends ZodType<T> = ZodType<T>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: ZodType,\n ): Promise<HttpResponse<T>> {\n const args = this.resolveArgs(arg1, arg2, arg3);\n return this.requestJson<T>('put', args);\n }\n\n patchJson<T>(url: string, options?: Opts): Promise<HttpResponse<T>>;\n patchJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n patchJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n patchJson<T = unknown, Schema extends ZodType<T> = ZodType<T>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): Promise<HttpResponse<T>> {\n const args = this.resolveArgs(arg1, arg2, arg3);\n return this.requestJson<T>('patch', args);\n }\n\n deleteJson<T>(url: string, options?: Opts): Promise<HttpResponse<T>>;\n deleteJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n deleteJson<T, Schema extends ZodType<T> = ZodType<T>>(\n url: string,\n options: Opts,\n schema: Schema,\n ): Promise<HttpResponse<Infer<Schema>>>;\n deleteJson<T = unknown, Schema extends ZodType<T> = ZodType<T>>(\n arg1: string,\n arg2?: Opts | Schema,\n arg3?: Schema,\n ): Promise<HttpResponse<T>> {\n const args = this.resolveArgs(arg1, arg2, arg3);\n return this.requestJson<T>('delete', args);\n }\n\n stream(url: string, options?: HttpOptions): NodeJS.ReadableStream {\n // TODO: fix types (#22198)\n let combinedOptions: any = {\n ...this.options,\n hostType: this.hostType,\n ...options,\n };\n\n const resolvedUrl = this.resolveUrl(url, options).toString();\n\n applyDefaultHeaders(combinedOptions);\n\n if (\n is.undefined(combinedOptions.readOnly) &&\n ['head', 'get'].includes(combinedOptions.method)\n ) {\n combinedOptions.readOnly = true;\n }\n\n const hostRule = findMatchingRule(url, combinedOptions);\n combinedOptions = applyHostRule(resolvedUrl, combinedOptions, hostRule);\n if (combinedOptions.enabled === false) {\n throw new Error(HOST_DISABLED);\n }\n combinedOptions = applyAuthorization(combinedOptions);\n\n return got.stream(resolvedUrl, combinedOptions);\n }\n}\n"]}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/util/http/index.ts"],"names":[],"mappings":";;;AAAA,qCAA4C;AAIR,iGAJ3B,yBAAgB,OAI2B;AAHpD,+BAAqC;AAGZ,0FAHhB,kBAAY,OAGa;AAFlC,iCAAkC;AAMlC,MAAa,IAAK,SAAQ,eAAQ;CAAG;AAArC,oBAAqC","sourcesContent":["import { EmptyResultError } from './errors';\nimport { RequestError } from './got';\nimport { HttpBase } from './http';\n\nexport { RequestError as HttpError, EmptyResultError };\n\nexport type * from './types';\n\nexport class Http extends HttpBase {}\n"]}
|
@@ -1,6 +1,8 @@
|
|
1
1
|
import type { IncomingHttpHeaders } from 'node:http';
|
2
|
-
import type { OptionsOfBufferResponseBody, OptionsOfJSONResponseBody, OptionsOfTextResponseBody } from 'got';
|
2
|
+
import type { Options, OptionsOfBufferResponseBody, OptionsOfJSONResponseBody, OptionsOfTextResponseBody, RequestError } from 'got';
|
3
|
+
import type { ZodError } from 'zod';
|
3
4
|
import type { HttpCacheProvider } from './cache/types';
|
5
|
+
import type { EmptyResultError } from './errors';
|
4
6
|
export type GotContextOptions = {
|
5
7
|
authType?: string;
|
6
8
|
} & Record<string, unknown>;
|
@@ -8,6 +10,7 @@ export type GotOptions = GotBufferOptions | GotTextOptions | GotJSONOptions;
|
|
8
10
|
export type GotBufferOptions = OptionsOfBufferResponseBody & GotExtraOptions;
|
9
11
|
export type GotTextOptions = OptionsOfTextResponseBody & GotExtraOptions;
|
10
12
|
export type GotJSONOptions = OptionsOfJSONResponseBody & GotExtraOptions;
|
13
|
+
export type GotStreamOptions = Options & GotExtraOptions;
|
11
14
|
export interface GotExtraOptions {
|
12
15
|
abortOnError?: boolean;
|
13
16
|
abortIgnoreStatusCodes?: number[];
|
@@ -18,13 +21,6 @@ export interface GotExtraOptions {
|
|
18
21
|
noAuth?: boolean;
|
19
22
|
context?: GotContextOptions;
|
20
23
|
}
|
21
|
-
export interface RequestStats {
|
22
|
-
method: string;
|
23
|
-
url: string;
|
24
|
-
duration: number;
|
25
|
-
queueDuration: number;
|
26
|
-
statusCode: number;
|
27
|
-
}
|
28
24
|
export type OutgoingHttpHeaders = Record<string, string | string[] | undefined>;
|
29
25
|
export type GraphqlVariables = Record<string, unknown>;
|
30
26
|
export interface GraphqlOptions {
|
@@ -73,3 +69,4 @@ export interface ConcurrencyLimitRule {
|
|
73
69
|
matchHost: string;
|
74
70
|
concurrency: number;
|
75
71
|
}
|
72
|
+
export type SafeJsonError = RequestError | ZodError | EmptyResultError;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../lib/util/http/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { IncomingHttpHeaders } from 'node:http';\nimport type {\n OptionsOfBufferResponseBody,\n OptionsOfJSONResponseBody,\n OptionsOfTextResponseBody,\n} from 'got';\nimport type { HttpCacheProvider } from './cache/types';\n\nexport type GotContextOptions = {\n authType?: string;\n} & Record<string, unknown>;\n\n// TODO: Move options to context\nexport type GotOptions = GotBufferOptions | GotTextOptions | GotJSONOptions;\nexport type GotBufferOptions = OptionsOfBufferResponseBody & GotExtraOptions;\nexport type GotTextOptions = OptionsOfTextResponseBody & GotExtraOptions;\nexport type GotJSONOptions = OptionsOfJSONResponseBody & GotExtraOptions;\n\nexport interface GotExtraOptions {\n abortOnError?: boolean;\n abortIgnoreStatusCodes?: number[];\n token?: string;\n hostType?: string;\n enabled?: boolean;\n memCache?: boolean;\n noAuth?: boolean;\n context?: GotContextOptions;\n}\n\nexport
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../lib/util/http/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { IncomingHttpHeaders } from 'node:http';\nimport type {\n Options,\n OptionsOfBufferResponseBody,\n OptionsOfJSONResponseBody,\n OptionsOfTextResponseBody,\n RequestError,\n} from 'got';\nimport type { ZodError } from 'zod';\nimport type { HttpCacheProvider } from './cache/types';\nimport type { EmptyResultError } from './errors';\n\nexport type GotContextOptions = {\n authType?: string;\n} & Record<string, unknown>;\n\n// TODO: Move options to context\nexport type GotOptions = GotBufferOptions | GotTextOptions | GotJSONOptions;\nexport type GotBufferOptions = OptionsOfBufferResponseBody & GotExtraOptions;\nexport type GotTextOptions = OptionsOfTextResponseBody & GotExtraOptions;\nexport type GotJSONOptions = OptionsOfJSONResponseBody & GotExtraOptions;\n\nexport type GotStreamOptions = Options & GotExtraOptions;\n\nexport interface GotExtraOptions {\n abortOnError?: boolean;\n abortIgnoreStatusCodes?: number[];\n token?: string;\n hostType?: string;\n enabled?: boolean;\n memCache?: boolean;\n noAuth?: boolean;\n context?: GotContextOptions;\n}\n\nexport type OutgoingHttpHeaders = Record<string, string | string[] | undefined>;\n\nexport type GraphqlVariables = Record<string, unknown>;\n\nexport interface GraphqlOptions {\n variables?: GraphqlVariables;\n paginate?: boolean;\n count?: number;\n limit?: number;\n cursor?: string | null;\n acceptHeader?: string;\n token?: string;\n readOnly?: boolean;\n}\n\nexport interface HttpOptions {\n body?: any;\n username?: string;\n password?: string;\n baseUrl?: string;\n headers?: OutgoingHttpHeaders;\n\n /**\n * Do not use authentication\n */\n noAuth?: boolean;\n\n throwHttpErrors?: boolean;\n\n token?: string;\n memCache?: boolean;\n cacheProvider?: HttpCacheProvider;\n readOnly?: boolean;\n}\n\nexport interface HttpHeaders extends IncomingHttpHeaders {\n link?: string | undefined;\n}\n\nexport type HttpMethod = 'get' | 'post' | 'put' | 'patch' | 'delete' | 'head';\n\nexport interface HttpResponse<T = string> {\n statusCode: number;\n body: T;\n headers: HttpHeaders;\n authorization?: boolean;\n}\n\nexport type Task<T> = () => Promise<T>;\nexport type GotTask<T = unknown> = Task<HttpResponse<T>>;\n\nexport interface ThrottleLimitRule {\n matchHost: string;\n throttleMs: number;\n}\n\nexport interface ConcurrencyLimitRule {\n matchHost: string;\n concurrency: number;\n}\n\nexport type SafeJsonError = RequestError | ZodError | EmptyResultError;\n"]}
|