fix
This commit is contained in:
3
book/node_modules/got/dist/source/as-promise/index.d.ts
generated
vendored
Normal file
3
book/node_modules/got/dist/source/as-promise/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import Request from '../core/index.js';
|
||||
import { type CancelableRequest } from './types.js';
|
||||
export default function asPromise<T>(firstRequest?: Request): CancelableRequest<T>;
|
||||
164
book/node_modules/got/dist/source/as-promise/index.js
generated
vendored
Normal file
164
book/node_modules/got/dist/source/as-promise/index.js
generated
vendored
Normal file
@@ -0,0 +1,164 @@
|
||||
import { EventEmitter } from 'node:events';
|
||||
import is from '@sindresorhus/is';
|
||||
import PCancelable from 'p-cancelable';
|
||||
import { HTTPError, RetryError, } from '../core/errors.js';
|
||||
import Request from '../core/index.js';
|
||||
import { parseBody, isResponseOk, ParseError, } from '../core/response.js';
|
||||
import proxyEvents from '../core/utils/proxy-events.js';
|
||||
import { CancelError } from './types.js';
|
||||
const proxiedRequestEvents = [
|
||||
'request',
|
||||
'response',
|
||||
'redirect',
|
||||
'uploadProgress',
|
||||
'downloadProgress',
|
||||
];
|
||||
export default function asPromise(firstRequest) {
|
||||
let globalRequest;
|
||||
let globalResponse;
|
||||
let normalizedOptions;
|
||||
const emitter = new EventEmitter();
|
||||
const promise = new PCancelable((resolve, reject, onCancel) => {
|
||||
onCancel(() => {
|
||||
globalRequest.destroy();
|
||||
});
|
||||
onCancel.shouldReject = false;
|
||||
onCancel(() => {
|
||||
reject(new CancelError(globalRequest));
|
||||
});
|
||||
const makeRequest = (retryCount) => {
|
||||
// Errors when a new request is made after the promise settles.
|
||||
// Used to detect a race condition.
|
||||
// See https://github.com/sindresorhus/got/issues/1489
|
||||
onCancel(() => { });
|
||||
const request = firstRequest ?? new Request(undefined, undefined, normalizedOptions);
|
||||
request.retryCount = retryCount;
|
||||
request._noPipe = true;
|
||||
globalRequest = request;
|
||||
request.once('response', async (response) => {
|
||||
// Parse body
|
||||
const contentEncoding = (response.headers['content-encoding'] ?? '').toLowerCase();
|
||||
const isCompressed = contentEncoding === 'gzip' || contentEncoding === 'deflate' || contentEncoding === 'br';
|
||||
const { options } = request;
|
||||
if (isCompressed && !options.decompress) {
|
||||
response.body = response.rawBody;
|
||||
}
|
||||
else {
|
||||
try {
|
||||
response.body = parseBody(response, options.responseType, options.parseJson, options.encoding);
|
||||
}
|
||||
catch (error) {
|
||||
// Fall back to `utf8`
|
||||
try {
|
||||
response.body = response.rawBody.toString();
|
||||
}
|
||||
catch (error) {
|
||||
request._beforeError(new ParseError(error, response));
|
||||
return;
|
||||
}
|
||||
if (isResponseOk(response)) {
|
||||
request._beforeError(error);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
try {
|
||||
const hooks = options.hooks.afterResponse;
|
||||
for (const [index, hook] of hooks.entries()) {
|
||||
// @ts-expect-error TS doesn't notice that CancelableRequest is a Promise
|
||||
// eslint-disable-next-line no-await-in-loop
|
||||
response = await hook(response, async (updatedOptions) => {
|
||||
options.merge(updatedOptions);
|
||||
options.prefixUrl = '';
|
||||
if (updatedOptions.url) {
|
||||
options.url = updatedOptions.url;
|
||||
}
|
||||
// Remove any further hooks for that request, because we'll call them anyway.
|
||||
// The loop continues. We don't want duplicates (asPromise recursion).
|
||||
options.hooks.afterResponse = options.hooks.afterResponse.slice(0, index);
|
||||
throw new RetryError(request);
|
||||
});
|
||||
if (!(is.object(response) && is.number(response.statusCode) && !is.nullOrUndefined(response.body))) {
|
||||
throw new TypeError('The `afterResponse` hook returned an invalid value');
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (error) {
|
||||
request._beforeError(error);
|
||||
return;
|
||||
}
|
||||
globalResponse = response;
|
||||
if (!isResponseOk(response)) {
|
||||
request._beforeError(new HTTPError(response));
|
||||
return;
|
||||
}
|
||||
request.destroy();
|
||||
resolve(request.options.resolveBodyOnly ? response.body : response);
|
||||
});
|
||||
const onError = (error) => {
|
||||
if (promise.isCanceled) {
|
||||
return;
|
||||
}
|
||||
const { options } = request;
|
||||
if (error instanceof HTTPError && !options.throwHttpErrors) {
|
||||
const { response } = error;
|
||||
request.destroy();
|
||||
resolve(request.options.resolveBodyOnly ? response.body : response);
|
||||
return;
|
||||
}
|
||||
reject(error);
|
||||
};
|
||||
request.once('error', onError);
|
||||
const previousBody = request.options?.body;
|
||||
request.once('retry', (newRetryCount, error) => {
|
||||
firstRequest = undefined;
|
||||
const newBody = request.options.body;
|
||||
if (previousBody === newBody && is.nodeStream(newBody)) {
|
||||
error.message = 'Cannot retry with consumed body stream';
|
||||
onError(error);
|
||||
return;
|
||||
}
|
||||
// This is needed! We need to reuse `request.options` because they can get modified!
|
||||
// For example, by calling `promise.json()`.
|
||||
normalizedOptions = request.options;
|
||||
makeRequest(newRetryCount);
|
||||
});
|
||||
proxyEvents(request, emitter, proxiedRequestEvents);
|
||||
if (is.undefined(firstRequest)) {
|
||||
void request.flush();
|
||||
}
|
||||
};
|
||||
makeRequest(0);
|
||||
});
|
||||
promise.on = (event, function_) => {
|
||||
emitter.on(event, function_);
|
||||
return promise;
|
||||
};
|
||||
promise.off = (event, function_) => {
|
||||
emitter.off(event, function_);
|
||||
return promise;
|
||||
};
|
||||
const shortcut = (responseType) => {
|
||||
const newPromise = (async () => {
|
||||
// Wait until downloading has ended
|
||||
await promise;
|
||||
const { options } = globalResponse.request;
|
||||
return parseBody(globalResponse, responseType, options.parseJson, options.encoding);
|
||||
})();
|
||||
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
||||
Object.defineProperties(newPromise, Object.getOwnPropertyDescriptors(promise));
|
||||
return newPromise;
|
||||
};
|
||||
promise.json = () => {
|
||||
if (globalRequest.options) {
|
||||
const { headers } = globalRequest.options;
|
||||
if (!globalRequest.writableFinished && !('accept' in headers)) {
|
||||
headers.accept = 'application/json';
|
||||
}
|
||||
}
|
||||
return shortcut('json');
|
||||
};
|
||||
promise.buffer = () => shortcut('buffer');
|
||||
promise.text = () => shortcut('text');
|
||||
return promise;
|
||||
}
|
||||
37
book/node_modules/got/dist/source/as-promise/types.d.ts
generated
vendored
Normal file
37
book/node_modules/got/dist/source/as-promise/types.d.ts
generated
vendored
Normal file
@@ -0,0 +1,37 @@
|
||||
import type { Buffer } from 'node:buffer';
|
||||
import type PCancelable from 'p-cancelable';
|
||||
import { RequestError } from '../core/errors.js';
|
||||
import type Request from '../core/index.js';
|
||||
import { type RequestEvents } from '../core/index.js';
|
||||
import type { Response } from '../core/response.js';
|
||||
/**
|
||||
An error to be thrown when the request is aborted with `.cancel()`.
|
||||
*/
|
||||
export declare class CancelError extends RequestError {
|
||||
readonly response: Response;
|
||||
constructor(request: Request);
|
||||
/**
|
||||
Whether the promise is canceled.
|
||||
*/
|
||||
get isCanceled(): boolean;
|
||||
}
|
||||
export interface CancelableRequest<T extends Response | Response['body'] = Response['body']> extends PCancelable<T>, RequestEvents<CancelableRequest<T>> {
|
||||
/**
|
||||
A shortcut method that gives a Promise returning a JSON object.
|
||||
|
||||
It is semantically the same as settings `options.resolveBodyOnly` to `true` and `options.responseType` to `'json'`.
|
||||
*/
|
||||
json: <ReturnType>() => CancelableRequest<ReturnType>;
|
||||
/**
|
||||
A shortcut method that gives a Promise returning a [Buffer](https://nodejs.org/api/buffer.html).
|
||||
|
||||
It is semantically the same as settings `options.resolveBodyOnly` to `true` and `options.responseType` to `'buffer'`.
|
||||
*/
|
||||
buffer: () => CancelableRequest<Buffer>;
|
||||
/**
|
||||
A shortcut method that gives a Promise returning a string.
|
||||
|
||||
It is semantically the same as settings `options.resolveBodyOnly` to `true` and `options.responseType` to `'text'`.
|
||||
*/
|
||||
text: () => CancelableRequest<string>;
|
||||
}
|
||||
17
book/node_modules/got/dist/source/as-promise/types.js
generated
vendored
Normal file
17
book/node_modules/got/dist/source/as-promise/types.js
generated
vendored
Normal file
@@ -0,0 +1,17 @@
|
||||
import { RequestError } from '../core/errors.js';
|
||||
/**
|
||||
An error to be thrown when the request is aborted with `.cancel()`.
|
||||
*/
|
||||
export class CancelError extends RequestError {
|
||||
constructor(request) {
|
||||
super('Promise was canceled', {}, request);
|
||||
this.name = 'CancelError';
|
||||
this.code = 'ERR_CANCELED';
|
||||
}
|
||||
/**
|
||||
Whether the promise is canceled.
|
||||
*/
|
||||
get isCanceled() {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
4
book/node_modules/got/dist/source/core/calculate-retry-delay.d.ts
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/calculate-retry-delay.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
import type { RetryFunction } from './options.js';
|
||||
type Returns<T extends (...arguments_: any) => unknown, V> = (...arguments_: Parameters<T>) => V;
|
||||
declare const calculateRetryDelay: Returns<RetryFunction, number>;
|
||||
export default calculateRetryDelay;
|
||||
29
book/node_modules/got/dist/source/core/calculate-retry-delay.js
generated
vendored
Normal file
29
book/node_modules/got/dist/source/core/calculate-retry-delay.js
generated
vendored
Normal file
@@ -0,0 +1,29 @@
|
||||
const calculateRetryDelay = ({ attemptCount, retryOptions, error, retryAfter, computedValue, }) => {
|
||||
if (error.name === 'RetryError') {
|
||||
return 1;
|
||||
}
|
||||
if (attemptCount > retryOptions.limit) {
|
||||
return 0;
|
||||
}
|
||||
const hasMethod = retryOptions.methods.includes(error.options.method);
|
||||
const hasErrorCode = retryOptions.errorCodes.includes(error.code);
|
||||
const hasStatusCode = error.response && retryOptions.statusCodes.includes(error.response.statusCode);
|
||||
if (!hasMethod || (!hasErrorCode && !hasStatusCode)) {
|
||||
return 0;
|
||||
}
|
||||
if (error.response) {
|
||||
if (retryAfter) {
|
||||
// In this case `computedValue` is `options.request.timeout`
|
||||
if (retryAfter > computedValue) {
|
||||
return 0;
|
||||
}
|
||||
return retryAfter;
|
||||
}
|
||||
if (error.response.statusCode === 413) {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
const noise = Math.random() * retryOptions.noise;
|
||||
return Math.min(((2 ** (attemptCount - 1)) * 1000), retryOptions.backoffLimit) + noise;
|
||||
};
|
||||
export default calculateRetryDelay;
|
||||
89
book/node_modules/got/dist/source/core/errors.d.ts
generated
vendored
Normal file
89
book/node_modules/got/dist/source/core/errors.d.ts
generated
vendored
Normal file
@@ -0,0 +1,89 @@
|
||||
import type { Timings } from '@szmarczak/http-timer';
|
||||
import type Options from './options.js';
|
||||
import type { TimeoutError as TimedOutTimeoutError } from './timed-out.js';
|
||||
import type { PlainResponse, Response } from './response.js';
|
||||
import type Request from './index.js';
|
||||
type Error = NodeJS.ErrnoException;
|
||||
/**
|
||||
An error to be thrown when a request fails.
|
||||
Contains a `code` property with error class code, like `ECONNREFUSED`.
|
||||
*/
|
||||
export declare class RequestError<T = unknown> extends Error {
|
||||
input?: string;
|
||||
code: string;
|
||||
stack: string;
|
||||
readonly options: Options;
|
||||
readonly response?: Response<T>;
|
||||
readonly request?: Request;
|
||||
readonly timings?: Timings;
|
||||
constructor(message: string, error: Partial<Error & {
|
||||
code?: string;
|
||||
}>, self: Request | Options);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the server redirects you more than ten times.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
export declare class MaxRedirectsError extends RequestError {
|
||||
readonly response: Response;
|
||||
readonly request: Request;
|
||||
readonly timings: Timings;
|
||||
constructor(request: Request);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the server response code is not 2xx nor 3xx if `options.followRedirect` is `true`, but always except for 304.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
export declare class HTTPError<T = any> extends RequestError<T> {
|
||||
readonly response: Response<T>;
|
||||
readonly request: Request;
|
||||
readonly timings: Timings;
|
||||
constructor(response: PlainResponse);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when a cache method fails.
|
||||
For example, if the database goes down or there's a filesystem error.
|
||||
*/
|
||||
export declare class CacheError extends RequestError {
|
||||
readonly request: Request;
|
||||
constructor(error: Error, request: Request);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request body is a stream and an error occurs while reading from that stream.
|
||||
*/
|
||||
export declare class UploadError extends RequestError {
|
||||
readonly request: Request;
|
||||
constructor(error: Error, request: Request);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request is aborted due to a timeout.
|
||||
Includes an `event` and `timings` property.
|
||||
*/
|
||||
export declare class TimeoutError extends RequestError {
|
||||
readonly request: Request;
|
||||
readonly timings: Timings;
|
||||
readonly event: string;
|
||||
constructor(error: TimedOutTimeoutError, timings: Timings, request: Request);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when reading from response stream fails.
|
||||
*/
|
||||
export declare class ReadError extends RequestError {
|
||||
readonly request: Request;
|
||||
readonly response: Response;
|
||||
readonly timings: Timings;
|
||||
constructor(error: Error, request: Request);
|
||||
}
|
||||
/**
|
||||
An error which always triggers a new retry when thrown.
|
||||
*/
|
||||
export declare class RetryError extends RequestError {
|
||||
constructor(request: Request);
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request is aborted by AbortController.
|
||||
*/
|
||||
export declare class AbortError extends RequestError {
|
||||
constructor(request: Request);
|
||||
}
|
||||
export {};
|
||||
139
book/node_modules/got/dist/source/core/errors.js
generated
vendored
Normal file
139
book/node_modules/got/dist/source/core/errors.js
generated
vendored
Normal file
@@ -0,0 +1,139 @@
|
||||
import is from '@sindresorhus/is';
|
||||
// A hacky check to prevent circular references.
|
||||
function isRequest(x) {
|
||||
return is.object(x) && '_onResponse' in x;
|
||||
}
|
||||
/**
|
||||
An error to be thrown when a request fails.
|
||||
Contains a `code` property with error class code, like `ECONNREFUSED`.
|
||||
*/
|
||||
export class RequestError extends Error {
|
||||
input;
|
||||
code;
|
||||
stack;
|
||||
response;
|
||||
request;
|
||||
timings;
|
||||
constructor(message, error, self) {
|
||||
super(message, { cause: error });
|
||||
Error.captureStackTrace(this, this.constructor);
|
||||
this.name = 'RequestError';
|
||||
this.code = error.code ?? 'ERR_GOT_REQUEST_ERROR';
|
||||
this.input = error.input;
|
||||
if (isRequest(self)) {
|
||||
Object.defineProperty(this, 'request', {
|
||||
enumerable: false,
|
||||
value: self,
|
||||
});
|
||||
Object.defineProperty(this, 'response', {
|
||||
enumerable: false,
|
||||
value: self.response,
|
||||
});
|
||||
this.options = self.options;
|
||||
}
|
||||
else {
|
||||
this.options = self;
|
||||
}
|
||||
this.timings = this.request?.timings;
|
||||
// Recover the original stacktrace
|
||||
if (is.string(error.stack) && is.string(this.stack)) {
|
||||
const indexOfMessage = this.stack.indexOf(this.message) + this.message.length;
|
||||
const thisStackTrace = this.stack.slice(indexOfMessage).split('\n').reverse();
|
||||
const errorStackTrace = error.stack.slice(error.stack.indexOf(error.message) + error.message.length).split('\n').reverse();
|
||||
// Remove duplicated traces
|
||||
while (errorStackTrace.length > 0 && errorStackTrace[0] === thisStackTrace[0]) {
|
||||
thisStackTrace.shift();
|
||||
}
|
||||
this.stack = `${this.stack.slice(0, indexOfMessage)}${thisStackTrace.reverse().join('\n')}${errorStackTrace.reverse().join('\n')}`;
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the server redirects you more than ten times.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
export class MaxRedirectsError extends RequestError {
|
||||
constructor(request) {
|
||||
super(`Redirected ${request.options.maxRedirects} times. Aborting.`, {}, request);
|
||||
this.name = 'MaxRedirectsError';
|
||||
this.code = 'ERR_TOO_MANY_REDIRECTS';
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the server response code is not 2xx nor 3xx if `options.followRedirect` is `true`, but always except for 304.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
// TODO: Change `HTTPError<T = any>` to `HTTPError<T = unknown>` in the next major version to enforce type usage.
|
||||
// eslint-disable-next-line @typescript-eslint/naming-convention
|
||||
export class HTTPError extends RequestError {
|
||||
constructor(response) {
|
||||
super(`Response code ${response.statusCode} (${response.statusMessage})`, {}, response.request);
|
||||
this.name = 'HTTPError';
|
||||
this.code = 'ERR_NON_2XX_3XX_RESPONSE';
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when a cache method fails.
|
||||
For example, if the database goes down or there's a filesystem error.
|
||||
*/
|
||||
export class CacheError extends RequestError {
|
||||
constructor(error, request) {
|
||||
super(error.message, error, request);
|
||||
this.name = 'CacheError';
|
||||
this.code = this.code === 'ERR_GOT_REQUEST_ERROR' ? 'ERR_CACHE_ACCESS' : this.code;
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request body is a stream and an error occurs while reading from that stream.
|
||||
*/
|
||||
export class UploadError extends RequestError {
|
||||
constructor(error, request) {
|
||||
super(error.message, error, request);
|
||||
this.name = 'UploadError';
|
||||
this.code = this.code === 'ERR_GOT_REQUEST_ERROR' ? 'ERR_UPLOAD' : this.code;
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request is aborted due to a timeout.
|
||||
Includes an `event` and `timings` property.
|
||||
*/
|
||||
export class TimeoutError extends RequestError {
|
||||
timings;
|
||||
event;
|
||||
constructor(error, timings, request) {
|
||||
super(error.message, error, request);
|
||||
this.name = 'TimeoutError';
|
||||
this.event = error.event;
|
||||
this.timings = timings;
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when reading from response stream fails.
|
||||
*/
|
||||
export class ReadError extends RequestError {
|
||||
constructor(error, request) {
|
||||
super(error.message, error, request);
|
||||
this.name = 'ReadError';
|
||||
this.code = this.code === 'ERR_GOT_REQUEST_ERROR' ? 'ERR_READING_RESPONSE_STREAM' : this.code;
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error which always triggers a new retry when thrown.
|
||||
*/
|
||||
export class RetryError extends RequestError {
|
||||
constructor(request) {
|
||||
super('Retrying', {}, request);
|
||||
this.name = 'RetryError';
|
||||
this.code = 'ERR_RETRYING';
|
||||
}
|
||||
}
|
||||
/**
|
||||
An error to be thrown when the request is aborted by AbortController.
|
||||
*/
|
||||
export class AbortError extends RequestError {
|
||||
constructor(request) {
|
||||
super('This operation was aborted.', {}, request);
|
||||
this.code = 'ERR_ABORTED';
|
||||
this.name = 'AbortError';
|
||||
}
|
||||
}
|
||||
185
book/node_modules/got/dist/source/core/index.d.ts
generated
vendored
Normal file
185
book/node_modules/got/dist/source/core/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,185 @@
|
||||
import { Duplex } from 'node:stream';
|
||||
import { type ClientRequest } from 'node:http';
|
||||
import type { Socket } from 'node:net';
|
||||
import { type Timings } from '@szmarczak/http-timer';
|
||||
import Options from './options.js';
|
||||
import { type PlainResponse, type Response } from './response.js';
|
||||
import { RequestError } from './errors.js';
|
||||
type Error = NodeJS.ErrnoException;
|
||||
export type Progress = {
|
||||
percent: number;
|
||||
transferred: number;
|
||||
total?: number;
|
||||
};
|
||||
export type GotEventFunction<T> =
|
||||
/**
|
||||
`request` event to get the request object of the request.
|
||||
|
||||
__Tip__: You can use `request` event to abort requests.
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
got.stream('https://github.com')
|
||||
.on('request', request => setTimeout(() => request.destroy(), 50));
|
||||
```
|
||||
*/
|
||||
((name: 'request', listener: (request: ClientRequest) => void) => T)
|
||||
/**
|
||||
The `response` event to get the response object of the final request.
|
||||
*/
|
||||
& (<R extends Response>(name: 'response', listener: (response: R) => void) => T)
|
||||
/**
|
||||
The `redirect` event to get the response object of a redirect. The second argument is options for the next request to the redirect location.
|
||||
*/
|
||||
& (<R extends Response, N extends Options>(name: 'redirect', listener: (response: R, nextOptions: N) => void) => T)
|
||||
/**
|
||||
Progress events for uploading (sending a request) and downloading (receiving a response).
|
||||
The `progress` argument is an object like:
|
||||
|
||||
```
|
||||
{
|
||||
percent: 0.1,
|
||||
transferred: 1024,
|
||||
total: 10240
|
||||
}
|
||||
```
|
||||
|
||||
If the `content-length` header is missing, `total` will be `undefined`.
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
const response = await got('https://sindresorhus.com')
|
||||
.on('downloadProgress', progress => {
|
||||
// Report download progress
|
||||
})
|
||||
.on('uploadProgress', progress => {
|
||||
// Report upload progress
|
||||
});
|
||||
|
||||
console.log(response);
|
||||
```
|
||||
*/
|
||||
& ((name: 'uploadProgress' | 'downloadProgress', listener: (progress: Progress) => void) => T)
|
||||
/**
|
||||
To enable retrying on a Got stream, it is required to have a `retry` handler attached.
|
||||
|
||||
When this event is emitted, you should reset the stream you were writing to and prepare the body again.
|
||||
|
||||
See `got.options.retry` for more information.
|
||||
*/
|
||||
& ((name: 'retry', listener: (retryCount: number, error: RequestError) => void) => T);
|
||||
export type RequestEvents<T> = {
|
||||
on: GotEventFunction<T>;
|
||||
once: GotEventFunction<T>;
|
||||
off: GotEventFunction<T>;
|
||||
};
|
||||
type UrlType = ConstructorParameters<typeof Options>[0];
|
||||
type OptionsType = ConstructorParameters<typeof Options>[1];
|
||||
type DefaultsType = ConstructorParameters<typeof Options>[2];
|
||||
export default class Request extends Duplex implements RequestEvents<Request> {
|
||||
['constructor']: typeof Request;
|
||||
_noPipe?: boolean;
|
||||
options: Options;
|
||||
response?: PlainResponse;
|
||||
requestUrl?: URL;
|
||||
redirectUrls: URL[];
|
||||
retryCount: number;
|
||||
private _requestOptions;
|
||||
private _stopRetry;
|
||||
private _downloadedSize;
|
||||
private _uploadedSize;
|
||||
private _stopReading;
|
||||
private readonly _pipedServerResponses;
|
||||
private _request?;
|
||||
private _responseSize?;
|
||||
private _bodySize?;
|
||||
private _unproxyEvents;
|
||||
private _isFromCache?;
|
||||
private _cannotHaveBody;
|
||||
private _triggerRead;
|
||||
private readonly _jobs;
|
||||
private _cancelTimeouts;
|
||||
private readonly _removeListeners;
|
||||
private _nativeResponse?;
|
||||
private _flushed;
|
||||
private _aborted;
|
||||
private _requestInitialized;
|
||||
constructor(url: UrlType, options?: OptionsType, defaults?: DefaultsType);
|
||||
flush(): Promise<void>;
|
||||
_beforeError(error: Error): void;
|
||||
_read(): void;
|
||||
_write(chunk: unknown, encoding: BufferEncoding | undefined, callback: (error?: Error | null) => void): void;
|
||||
_final(callback: (error?: Error | null) => void): void;
|
||||
_destroy(error: Error | null, callback: (error: Error | null) => void): void;
|
||||
pipe<T extends NodeJS.WritableStream>(destination: T, options?: {
|
||||
end?: boolean;
|
||||
}): T;
|
||||
unpipe<T extends NodeJS.WritableStream>(destination: T): this;
|
||||
private _finalizeBody;
|
||||
private _onResponseBase;
|
||||
private _setRawBody;
|
||||
private _onResponse;
|
||||
private _onRequest;
|
||||
private _asyncWrite;
|
||||
private _sendBody;
|
||||
private _prepareCache;
|
||||
private _createCacheableRequest;
|
||||
private _makeRequest;
|
||||
private _error;
|
||||
private _writeRequest;
|
||||
/**
|
||||
The remote IP address.
|
||||
*/
|
||||
get ip(): string | undefined;
|
||||
/**
|
||||
Indicates whether the request has been aborted or not.
|
||||
*/
|
||||
get isAborted(): boolean;
|
||||
get socket(): Socket | undefined;
|
||||
/**
|
||||
Progress event for downloading (receiving a response).
|
||||
*/
|
||||
get downloadProgress(): Progress;
|
||||
/**
|
||||
Progress event for uploading (sending a request).
|
||||
*/
|
||||
get uploadProgress(): Progress;
|
||||
/**
|
||||
The object contains the following properties:
|
||||
|
||||
- `start` - Time when the request started.
|
||||
- `socket` - Time when a socket was assigned to the request.
|
||||
- `lookup` - Time when the DNS lookup finished.
|
||||
- `connect` - Time when the socket successfully connected.
|
||||
- `secureConnect` - Time when the socket securely connected.
|
||||
- `upload` - Time when the request finished uploading.
|
||||
- `response` - Time when the request fired `response` event.
|
||||
- `end` - Time when the response fired `end` event.
|
||||
- `error` - Time when the request fired `error` event.
|
||||
- `abort` - Time when the request fired `abort` event.
|
||||
- `phases`
|
||||
- `wait` - `timings.socket - timings.start`
|
||||
- `dns` - `timings.lookup - timings.socket`
|
||||
- `tcp` - `timings.connect - timings.lookup`
|
||||
- `tls` - `timings.secureConnect - timings.connect`
|
||||
- `request` - `timings.upload - (timings.secureConnect || timings.connect)`
|
||||
- `firstByte` - `timings.response - timings.upload`
|
||||
- `download` - `timings.end - timings.response`
|
||||
- `total` - `(timings.end || timings.error || timings.abort) - timings.start`
|
||||
|
||||
If something has not been measured yet, it will be `undefined`.
|
||||
|
||||
__Note__: The time is a `number` representing the milliseconds elapsed since the UNIX epoch.
|
||||
*/
|
||||
get timings(): Timings | undefined;
|
||||
/**
|
||||
Whether the response was retrieved from the cache.
|
||||
*/
|
||||
get isFromCache(): boolean | undefined;
|
||||
get reusedSocket(): boolean | undefined;
|
||||
}
|
||||
export {};
|
||||
1005
book/node_modules/got/dist/source/core/index.js
generated
vendored
Normal file
1005
book/node_modules/got/dist/source/core/index.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1247
book/node_modules/got/dist/source/core/options.d.ts
generated
vendored
Normal file
1247
book/node_modules/got/dist/source/core/options.d.ts
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1635
book/node_modules/got/dist/source/core/options.js
generated
vendored
Normal file
1635
book/node_modules/got/dist/source/core/options.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
4
book/node_modules/got/dist/source/core/parse-link-header.d.ts
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/parse-link-header.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
export default function parseLinkHeader(link: string): {
|
||||
reference: string;
|
||||
parameters: Record<string, string>;
|
||||
}[];
|
||||
33
book/node_modules/got/dist/source/core/parse-link-header.js
generated
vendored
Normal file
33
book/node_modules/got/dist/source/core/parse-link-header.js
generated
vendored
Normal file
@@ -0,0 +1,33 @@
|
||||
export default function parseLinkHeader(link) {
|
||||
const parsed = [];
|
||||
const items = link.split(',');
|
||||
for (const item of items) {
|
||||
// https://tools.ietf.org/html/rfc5988#section-5
|
||||
const [rawUriReference, ...rawLinkParameters] = item.split(';');
|
||||
const trimmedUriReference = rawUriReference.trim();
|
||||
// eslint-disable-next-line @typescript-eslint/prefer-string-starts-ends-with
|
||||
if (trimmedUriReference[0] !== '<' || trimmedUriReference.at(-1) !== '>') {
|
||||
throw new Error(`Invalid format of the Link header reference: ${trimmedUriReference}`);
|
||||
}
|
||||
const reference = trimmedUriReference.slice(1, -1);
|
||||
const parameters = {};
|
||||
if (rawLinkParameters.length === 0) {
|
||||
throw new Error(`Unexpected end of Link header parameters: ${rawLinkParameters.join(';')}`);
|
||||
}
|
||||
for (const rawParameter of rawLinkParameters) {
|
||||
const trimmedRawParameter = rawParameter.trim();
|
||||
const center = trimmedRawParameter.indexOf('=');
|
||||
if (center === -1) {
|
||||
throw new Error(`Failed to parse Link header: ${link}`);
|
||||
}
|
||||
const name = trimmedRawParameter.slice(0, center).trim();
|
||||
const value = trimmedRawParameter.slice(center + 1).trim();
|
||||
parameters[name] = value;
|
||||
}
|
||||
parsed.push({
|
||||
reference,
|
||||
parameters,
|
||||
});
|
||||
}
|
||||
return parsed;
|
||||
}
|
||||
107
book/node_modules/got/dist/source/core/response.d.ts
generated
vendored
Normal file
107
book/node_modules/got/dist/source/core/response.d.ts
generated
vendored
Normal file
@@ -0,0 +1,107 @@
|
||||
import type { Buffer } from 'node:buffer';
|
||||
import type { IncomingMessageWithTimings, Timings } from '@szmarczak/http-timer';
|
||||
import { RequestError } from './errors.js';
|
||||
import type { ParseJsonFunction, ResponseType } from './options.js';
|
||||
import type Request from './index.js';
|
||||
export type PlainResponse = {
|
||||
/**
|
||||
The original request URL.
|
||||
*/
|
||||
requestUrl: URL;
|
||||
/**
|
||||
The redirect URLs.
|
||||
*/
|
||||
redirectUrls: URL[];
|
||||
/**
|
||||
- `options` - The Got options that were set on this request.
|
||||
|
||||
__Note__: This is not a [http.ClientRequest](https://nodejs.org/api/http.html#http_class_http_clientrequest).
|
||||
*/
|
||||
request: Request;
|
||||
/**
|
||||
The remote IP address.
|
||||
|
||||
This is hopefully a temporary limitation, see [lukechilds/cacheable-request#86](https://web.archive.org/web/20220804165050/https://github.com/jaredwray/cacheable-request/issues/86).
|
||||
|
||||
__Note__: Not available when the response is cached.
|
||||
*/
|
||||
ip?: string;
|
||||
/**
|
||||
Whether the response was retrieved from the cache.
|
||||
*/
|
||||
isFromCache: boolean;
|
||||
/**
|
||||
The status code of the response.
|
||||
*/
|
||||
statusCode: number;
|
||||
/**
|
||||
The request URL or the final URL after redirects.
|
||||
*/
|
||||
url: string;
|
||||
/**
|
||||
The object contains the following properties:
|
||||
|
||||
- `start` - Time when the request started.
|
||||
- `socket` - Time when a socket was assigned to the request.
|
||||
- `lookup` - Time when the DNS lookup finished.
|
||||
- `connect` - Time when the socket successfully connected.
|
||||
- `secureConnect` - Time when the socket securely connected.
|
||||
- `upload` - Time when the request finished uploading.
|
||||
- `response` - Time when the request fired `response` event.
|
||||
- `end` - Time when the response fired `end` event.
|
||||
- `error` - Time when the request fired `error` event.
|
||||
- `abort` - Time when the request fired `abort` event.
|
||||
- `phases`
|
||||
- `wait` - `timings.socket - timings.start`
|
||||
- `dns` - `timings.lookup - timings.socket`
|
||||
- `tcp` - `timings.connect - timings.lookup`
|
||||
- `tls` - `timings.secureConnect - timings.connect`
|
||||
- `request` - `timings.upload - (timings.secureConnect || timings.connect)`
|
||||
- `firstByte` - `timings.response - timings.upload`
|
||||
- `download` - `timings.end - timings.response`
|
||||
- `total` - `(timings.end || timings.error || timings.abort) - timings.start`
|
||||
|
||||
If something has not been measured yet, it will be `undefined`.
|
||||
|
||||
__Note__: The time is a `number` representing the milliseconds elapsed since the UNIX epoch.
|
||||
*/
|
||||
timings: Timings;
|
||||
/**
|
||||
The number of times the request was retried.
|
||||
*/
|
||||
retryCount: number;
|
||||
/**
|
||||
The raw result of the request.
|
||||
*/
|
||||
rawBody?: Buffer;
|
||||
/**
|
||||
The result of the request.
|
||||
*/
|
||||
body?: unknown;
|
||||
/**
|
||||
Whether the response was successful.
|
||||
|
||||
__Note__: Got throws automatically when `response.ok` is `false` and `throwHttpErrors` is `true`.
|
||||
*/
|
||||
ok: boolean;
|
||||
} & IncomingMessageWithTimings;
|
||||
export type Response<T = unknown> = {
|
||||
/**
|
||||
The result of the request.
|
||||
*/
|
||||
body: T;
|
||||
/**
|
||||
The raw result of the request.
|
||||
*/
|
||||
rawBody: Buffer;
|
||||
} & PlainResponse;
|
||||
export declare const isResponseOk: (response: PlainResponse) => boolean;
|
||||
/**
|
||||
An error to be thrown when server response code is 2xx, and parsing body fails.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
export declare class ParseError extends RequestError {
|
||||
readonly response: Response;
|
||||
constructor(error: Error, response: Response);
|
||||
}
|
||||
export declare const parseBody: (response: Response, responseType: ResponseType, parseJson: ParseJsonFunction, encoding?: BufferEncoding) => unknown;
|
||||
41
book/node_modules/got/dist/source/core/response.js
generated
vendored
Normal file
41
book/node_modules/got/dist/source/core/response.js
generated
vendored
Normal file
@@ -0,0 +1,41 @@
|
||||
import { RequestError } from './errors.js';
|
||||
export const isResponseOk = (response) => {
|
||||
const { statusCode } = response;
|
||||
const { followRedirect } = response.request.options;
|
||||
const shouldFollow = typeof followRedirect === 'function' ? followRedirect(response) : followRedirect;
|
||||
const limitStatusCode = shouldFollow ? 299 : 399;
|
||||
return (statusCode >= 200 && statusCode <= limitStatusCode) || statusCode === 304;
|
||||
};
|
||||
/**
|
||||
An error to be thrown when server response code is 2xx, and parsing body fails.
|
||||
Includes a `response` property.
|
||||
*/
|
||||
export class ParseError extends RequestError {
|
||||
constructor(error, response) {
|
||||
const { options } = response.request;
|
||||
super(`${error.message} in "${options.url.toString()}"`, error, response.request);
|
||||
this.name = 'ParseError';
|
||||
this.code = 'ERR_BODY_PARSE_FAILURE';
|
||||
}
|
||||
}
|
||||
export const parseBody = (response, responseType, parseJson, encoding) => {
|
||||
const { rawBody } = response;
|
||||
try {
|
||||
if (responseType === 'text') {
|
||||
return rawBody.toString(encoding);
|
||||
}
|
||||
if (responseType === 'json') {
|
||||
return rawBody.length === 0 ? '' : parseJson(rawBody.toString(encoding));
|
||||
}
|
||||
if (responseType === 'buffer') {
|
||||
return rawBody;
|
||||
}
|
||||
}
|
||||
catch (error) {
|
||||
throw new ParseError(error, response);
|
||||
}
|
||||
throw new ParseError({
|
||||
message: `Unknown body type '${responseType}'`,
|
||||
name: 'Error',
|
||||
}, response);
|
||||
};
|
||||
30
book/node_modules/got/dist/source/core/timed-out.d.ts
generated
vendored
Normal file
30
book/node_modules/got/dist/source/core/timed-out.d.ts
generated
vendored
Normal file
@@ -0,0 +1,30 @@
|
||||
import type { ClientRequest } from 'node:http';
|
||||
declare const reentry: unique symbol;
|
||||
type TimedOutOptions = {
|
||||
host?: string;
|
||||
hostname?: string;
|
||||
protocol?: string;
|
||||
};
|
||||
export type Delays = {
|
||||
lookup?: number;
|
||||
socket?: number;
|
||||
connect?: number;
|
||||
secureConnect?: number;
|
||||
send?: number;
|
||||
response?: number;
|
||||
read?: number;
|
||||
request?: number;
|
||||
};
|
||||
export type ErrorCode = 'ETIMEDOUT' | 'ECONNRESET' | 'EADDRINUSE' | 'ECONNREFUSED' | 'EPIPE' | 'ENOTFOUND' | 'ENETUNREACH' | 'EAI_AGAIN';
|
||||
export declare class TimeoutError extends Error {
|
||||
event: string;
|
||||
code: ErrorCode;
|
||||
constructor(threshold: number, event: string);
|
||||
}
|
||||
export default function timedOut(request: ClientRequest, delays: Delays, options: TimedOutOptions): () => void;
|
||||
declare module 'http' {
|
||||
interface ClientRequest {
|
||||
[reentry]?: boolean;
|
||||
}
|
||||
}
|
||||
export {};
|
||||
129
book/node_modules/got/dist/source/core/timed-out.js
generated
vendored
Normal file
129
book/node_modules/got/dist/source/core/timed-out.js
generated
vendored
Normal file
@@ -0,0 +1,129 @@
|
||||
import net from 'node:net';
|
||||
import unhandler from './utils/unhandle.js';
|
||||
const reentry = Symbol('reentry');
|
||||
const noop = () => { };
|
||||
export class TimeoutError extends Error {
|
||||
event;
|
||||
code;
|
||||
constructor(threshold, event) {
|
||||
super(`Timeout awaiting '${event}' for ${threshold}ms`);
|
||||
this.event = event;
|
||||
this.name = 'TimeoutError';
|
||||
this.code = 'ETIMEDOUT';
|
||||
}
|
||||
}
|
||||
export default function timedOut(request, delays, options) {
|
||||
if (reentry in request) {
|
||||
return noop;
|
||||
}
|
||||
request[reentry] = true;
|
||||
const cancelers = [];
|
||||
const { once, unhandleAll } = unhandler();
|
||||
const addTimeout = (delay, callback, event) => {
|
||||
const timeout = setTimeout(callback, delay, delay, event);
|
||||
timeout.unref?.();
|
||||
const cancel = () => {
|
||||
clearTimeout(timeout);
|
||||
};
|
||||
cancelers.push(cancel);
|
||||
return cancel;
|
||||
};
|
||||
const { host, hostname } = options;
|
||||
const timeoutHandler = (delay, event) => {
|
||||
request.destroy(new TimeoutError(delay, event));
|
||||
};
|
||||
const cancelTimeouts = () => {
|
||||
for (const cancel of cancelers) {
|
||||
cancel();
|
||||
}
|
||||
unhandleAll();
|
||||
};
|
||||
request.once('error', error => {
|
||||
cancelTimeouts();
|
||||
// Save original behavior
|
||||
/* istanbul ignore next */
|
||||
if (request.listenerCount('error') === 0) {
|
||||
throw error;
|
||||
}
|
||||
});
|
||||
if (delays.request !== undefined) {
|
||||
const cancelTimeout = addTimeout(delays.request, timeoutHandler, 'request');
|
||||
once(request, 'response', (response) => {
|
||||
once(response, 'end', cancelTimeout);
|
||||
});
|
||||
}
|
||||
if (delays.socket !== undefined) {
|
||||
const { socket } = delays;
|
||||
const socketTimeoutHandler = () => {
|
||||
timeoutHandler(socket, 'socket');
|
||||
};
|
||||
request.setTimeout(socket, socketTimeoutHandler);
|
||||
// `request.setTimeout(0)` causes a memory leak.
|
||||
// We can just remove the listener and forget about the timer - it's unreffed.
|
||||
// See https://github.com/sindresorhus/got/issues/690
|
||||
cancelers.push(() => {
|
||||
request.removeListener('timeout', socketTimeoutHandler);
|
||||
});
|
||||
}
|
||||
const hasLookup = delays.lookup !== undefined;
|
||||
const hasConnect = delays.connect !== undefined;
|
||||
const hasSecureConnect = delays.secureConnect !== undefined;
|
||||
const hasSend = delays.send !== undefined;
|
||||
if (hasLookup || hasConnect || hasSecureConnect || hasSend) {
|
||||
once(request, 'socket', (socket) => {
|
||||
const { socketPath } = request;
|
||||
/* istanbul ignore next: hard to test */
|
||||
if (socket.connecting) {
|
||||
const hasPath = Boolean(socketPath ?? net.isIP(hostname ?? host ?? '') !== 0);
|
||||
if (hasLookup && !hasPath && socket.address().address === undefined) {
|
||||
const cancelTimeout = addTimeout(delays.lookup, timeoutHandler, 'lookup');
|
||||
once(socket, 'lookup', cancelTimeout);
|
||||
}
|
||||
if (hasConnect) {
|
||||
const timeConnect = () => addTimeout(delays.connect, timeoutHandler, 'connect');
|
||||
if (hasPath) {
|
||||
once(socket, 'connect', timeConnect());
|
||||
}
|
||||
else {
|
||||
once(socket, 'lookup', (error) => {
|
||||
if (error === null) {
|
||||
once(socket, 'connect', timeConnect());
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
if (hasSecureConnect && options.protocol === 'https:') {
|
||||
once(socket, 'connect', () => {
|
||||
const cancelTimeout = addTimeout(delays.secureConnect, timeoutHandler, 'secureConnect');
|
||||
once(socket, 'secureConnect', cancelTimeout);
|
||||
});
|
||||
}
|
||||
}
|
||||
if (hasSend) {
|
||||
const timeRequest = () => addTimeout(delays.send, timeoutHandler, 'send');
|
||||
/* istanbul ignore next: hard to test */
|
||||
if (socket.connecting) {
|
||||
once(socket, 'connect', () => {
|
||||
once(request, 'upload-complete', timeRequest());
|
||||
});
|
||||
}
|
||||
else {
|
||||
once(request, 'upload-complete', timeRequest());
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
if (delays.response !== undefined) {
|
||||
once(request, 'upload-complete', () => {
|
||||
const cancelTimeout = addTimeout(delays.response, timeoutHandler, 'response');
|
||||
once(request, 'response', cancelTimeout);
|
||||
});
|
||||
}
|
||||
if (delays.read !== undefined) {
|
||||
once(request, 'response', (response) => {
|
||||
const cancelTimeout = addTimeout(delays.read, timeoutHandler, 'read');
|
||||
once(response, 'end', cancelTimeout);
|
||||
});
|
||||
}
|
||||
return cancelTimeouts;
|
||||
}
|
||||
2
book/node_modules/got/dist/source/core/utils/get-body-size.d.ts
generated
vendored
Normal file
2
book/node_modules/got/dist/source/core/utils/get-body-size.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import type { ClientRequestArgs } from 'node:http';
|
||||
export default function getBodySize(body: unknown, headers: ClientRequestArgs['headers']): Promise<number | undefined>;
|
||||
22
book/node_modules/got/dist/source/core/utils/get-body-size.js
generated
vendored
Normal file
22
book/node_modules/got/dist/source/core/utils/get-body-size.js
generated
vendored
Normal file
@@ -0,0 +1,22 @@
|
||||
import { Buffer } from 'node:buffer';
|
||||
import { promisify } from 'node:util';
|
||||
import is from '@sindresorhus/is';
|
||||
import isFormData from './is-form-data.js';
|
||||
export default async function getBodySize(body, headers) {
|
||||
if (headers && 'content-length' in headers) {
|
||||
return Number(headers['content-length']);
|
||||
}
|
||||
if (!body) {
|
||||
return 0;
|
||||
}
|
||||
if (is.string(body)) {
|
||||
return Buffer.byteLength(body);
|
||||
}
|
||||
if (is.buffer(body)) {
|
||||
return body.length;
|
||||
}
|
||||
if (isFormData(body)) {
|
||||
return promisify(body.getLength.bind(body))();
|
||||
}
|
||||
return undefined;
|
||||
}
|
||||
4
book/node_modules/got/dist/source/core/utils/is-client-request.d.ts
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/utils/is-client-request.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
import type { Writable, Readable } from 'node:stream';
|
||||
import type { ClientRequest } from 'node:http';
|
||||
declare function isClientRequest(clientRequest: Writable | Readable): clientRequest is ClientRequest;
|
||||
export default isClientRequest;
|
||||
4
book/node_modules/got/dist/source/core/utils/is-client-request.js
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/utils/is-client-request.js
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
function isClientRequest(clientRequest) {
|
||||
return clientRequest.writable && !clientRequest.writableEnded;
|
||||
}
|
||||
export default isClientRequest;
|
||||
7
book/node_modules/got/dist/source/core/utils/is-form-data.d.ts
generated
vendored
Normal file
7
book/node_modules/got/dist/source/core/utils/is-form-data.d.ts
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
import type { Readable } from 'node:stream';
|
||||
type FormData = {
|
||||
getBoundary: () => string;
|
||||
getLength: (callback: (error: Error | null, length: number) => void) => void;
|
||||
} & Readable;
|
||||
export default function isFormData(body: unknown): body is FormData;
|
||||
export {};
|
||||
4
book/node_modules/got/dist/source/core/utils/is-form-data.js
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/utils/is-form-data.js
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
import is from '@sindresorhus/is';
|
||||
export default function isFormData(body) {
|
||||
return is.nodeStream(body) && is.function(body.getBoundary);
|
||||
}
|
||||
1
book/node_modules/got/dist/source/core/utils/is-unix-socket-url.d.ts
generated
vendored
Normal file
1
book/node_modules/got/dist/source/core/utils/is-unix-socket-url.d.ts
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export default function isUnixSocketURL(url: URL): boolean;
|
||||
4
book/node_modules/got/dist/source/core/utils/is-unix-socket-url.js
generated
vendored
Normal file
4
book/node_modules/got/dist/source/core/utils/is-unix-socket-url.js
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
// eslint-disable-next-line @typescript-eslint/naming-convention
|
||||
export default function isUnixSocketURL(url) {
|
||||
return url.protocol === 'unix:' || url.hostname === 'unix';
|
||||
}
|
||||
12
book/node_modules/got/dist/source/core/utils/options-to-url.d.ts
generated
vendored
Normal file
12
book/node_modules/got/dist/source/core/utils/options-to-url.d.ts
generated
vendored
Normal file
@@ -0,0 +1,12 @@
|
||||
export type URLOptions = {
|
||||
href?: string;
|
||||
protocol?: string;
|
||||
host?: string;
|
||||
hostname?: string;
|
||||
port?: string | number;
|
||||
pathname?: string;
|
||||
search?: string;
|
||||
searchParams?: unknown;
|
||||
path?: string;
|
||||
};
|
||||
export default function optionsToUrl(origin: string, options: URLOptions): URL;
|
||||
48
book/node_modules/got/dist/source/core/utils/options-to-url.js
generated
vendored
Normal file
48
book/node_modules/got/dist/source/core/utils/options-to-url.js
generated
vendored
Normal file
@@ -0,0 +1,48 @@
|
||||
const keys = [
|
||||
'protocol',
|
||||
'host',
|
||||
'hostname',
|
||||
'port',
|
||||
'pathname',
|
||||
'search',
|
||||
];
|
||||
export default function optionsToUrl(origin, options) {
|
||||
if (options.path) {
|
||||
if (options.pathname) {
|
||||
throw new TypeError('Parameters `path` and `pathname` are mutually exclusive.');
|
||||
}
|
||||
if (options.search) {
|
||||
throw new TypeError('Parameters `path` and `search` are mutually exclusive.');
|
||||
}
|
||||
if (options.searchParams) {
|
||||
throw new TypeError('Parameters `path` and `searchParams` are mutually exclusive.');
|
||||
}
|
||||
}
|
||||
if (options.search && options.searchParams) {
|
||||
throw new TypeError('Parameters `search` and `searchParams` are mutually exclusive.');
|
||||
}
|
||||
if (!origin) {
|
||||
if (!options.protocol) {
|
||||
throw new TypeError('No URL protocol specified');
|
||||
}
|
||||
origin = `${options.protocol}//${options.hostname ?? options.host ?? ''}`;
|
||||
}
|
||||
const url = new URL(origin);
|
||||
if (options.path) {
|
||||
const searchIndex = options.path.indexOf('?');
|
||||
if (searchIndex === -1) {
|
||||
options.pathname = options.path;
|
||||
}
|
||||
else {
|
||||
options.pathname = options.path.slice(0, searchIndex);
|
||||
options.search = options.path.slice(searchIndex + 1);
|
||||
}
|
||||
delete options.path;
|
||||
}
|
||||
for (const key of keys) {
|
||||
if (options[key]) {
|
||||
url[key] = options[key].toString();
|
||||
}
|
||||
}
|
||||
return url;
|
||||
}
|
||||
2
book/node_modules/got/dist/source/core/utils/proxy-events.d.ts
generated
vendored
Normal file
2
book/node_modules/got/dist/source/core/utils/proxy-events.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import type { EventEmitter } from 'node:events';
|
||||
export default function proxyEvents(from: EventEmitter, to: EventEmitter, events: Readonly<string[]>): () => void;
|
||||
15
book/node_modules/got/dist/source/core/utils/proxy-events.js
generated
vendored
Normal file
15
book/node_modules/got/dist/source/core/utils/proxy-events.js
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
||||
export default function proxyEvents(from, to, events) {
|
||||
const eventFunctions = {};
|
||||
for (const event of events) {
|
||||
const eventFunction = (...arguments_) => {
|
||||
to.emit(event, ...arguments_);
|
||||
};
|
||||
eventFunctions[event] = eventFunction;
|
||||
from.on(event, eventFunction);
|
||||
}
|
||||
return () => {
|
||||
for (const [event, eventFunction] of Object.entries(eventFunctions)) {
|
||||
from.off(event, eventFunction);
|
||||
}
|
||||
};
|
||||
}
|
||||
10
book/node_modules/got/dist/source/core/utils/unhandle.d.ts
generated
vendored
Normal file
10
book/node_modules/got/dist/source/core/utils/unhandle.d.ts
generated
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
import type { EventEmitter } from 'node:events';
|
||||
type Origin = EventEmitter;
|
||||
type Event = string | symbol;
|
||||
type AnyFunction = (...arguments_: any[]) => void;
|
||||
type Unhandler = {
|
||||
once: (origin: Origin, event: Event, function_: AnyFunction) => void;
|
||||
unhandleAll: () => void;
|
||||
};
|
||||
export default function unhandle(): Unhandler;
|
||||
export {};
|
||||
20
book/node_modules/got/dist/source/core/utils/unhandle.js
generated
vendored
Normal file
20
book/node_modules/got/dist/source/core/utils/unhandle.js
generated
vendored
Normal file
@@ -0,0 +1,20 @@
|
||||
// When attaching listeners, it's very easy to forget about them.
|
||||
// Especially if you do error handling and set timeouts.
|
||||
// So instead of checking if it's proper to throw an error on every timeout ever,
|
||||
// use this simple tool which will remove all listeners you have attached.
|
||||
export default function unhandle() {
|
||||
const handlers = [];
|
||||
return {
|
||||
once(origin, event, function_) {
|
||||
origin.once(event, function_);
|
||||
handlers.push({ origin, event, fn: function_ });
|
||||
},
|
||||
unhandleAll() {
|
||||
for (const handler of handlers) {
|
||||
const { origin, event, fn } = handler;
|
||||
origin.removeListener(event, fn);
|
||||
}
|
||||
handlers.length = 0;
|
||||
},
|
||||
};
|
||||
}
|
||||
14
book/node_modules/got/dist/source/core/utils/url-to-options.d.ts
generated
vendored
Normal file
14
book/node_modules/got/dist/source/core/utils/url-to-options.d.ts
generated
vendored
Normal file
@@ -0,0 +1,14 @@
|
||||
import type { UrlWithStringQuery } from 'node:url';
|
||||
export type LegacyUrlOptions = {
|
||||
protocol: string;
|
||||
hostname: string;
|
||||
host: string;
|
||||
hash: string | null;
|
||||
search: string | null;
|
||||
pathname: string;
|
||||
href: string;
|
||||
path: string;
|
||||
port?: number;
|
||||
auth?: string;
|
||||
};
|
||||
export default function urlToOptions(url: URL | UrlWithStringQuery): LegacyUrlOptions;
|
||||
22
book/node_modules/got/dist/source/core/utils/url-to-options.js
generated
vendored
Normal file
22
book/node_modules/got/dist/source/core/utils/url-to-options.js
generated
vendored
Normal file
@@ -0,0 +1,22 @@
|
||||
import is from '@sindresorhus/is';
|
||||
export default function urlToOptions(url) {
|
||||
// Cast to URL
|
||||
url = url;
|
||||
const options = {
|
||||
protocol: url.protocol,
|
||||
hostname: is.string(url.hostname) && url.hostname.startsWith('[') ? url.hostname.slice(1, -1) : url.hostname,
|
||||
host: url.host,
|
||||
hash: url.hash,
|
||||
search: url.search,
|
||||
pathname: url.pathname,
|
||||
href: url.href,
|
||||
path: `${url.pathname || ''}${url.search || ''}`,
|
||||
};
|
||||
if (is.string(url.port) && url.port.length > 0) {
|
||||
options.port = Number(url.port);
|
||||
}
|
||||
if (url.username || url.password) {
|
||||
options.auth = `${url.username || ''}:${url.password || ''}`;
|
||||
}
|
||||
return options;
|
||||
}
|
||||
8
book/node_modules/got/dist/source/core/utils/weakable-map.d.ts
generated
vendored
Normal file
8
book/node_modules/got/dist/source/core/utils/weakable-map.d.ts
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
export default class WeakableMap<K, V> {
|
||||
weakMap: WeakMap<Record<string, unknown>, V>;
|
||||
map: Map<K, V>;
|
||||
constructor();
|
||||
set(key: K, value: V): void;
|
||||
get(key: K): V | undefined;
|
||||
has(key: K): boolean;
|
||||
}
|
||||
28
book/node_modules/got/dist/source/core/utils/weakable-map.js
generated
vendored
Normal file
28
book/node_modules/got/dist/source/core/utils/weakable-map.js
generated
vendored
Normal file
@@ -0,0 +1,28 @@
|
||||
export default class WeakableMap {
|
||||
weakMap;
|
||||
map;
|
||||
constructor() {
|
||||
this.weakMap = new WeakMap();
|
||||
this.map = new Map();
|
||||
}
|
||||
set(key, value) {
|
||||
if (typeof key === 'object') {
|
||||
this.weakMap.set(key, value);
|
||||
}
|
||||
else {
|
||||
this.map.set(key, value);
|
||||
}
|
||||
}
|
||||
get(key) {
|
||||
if (typeof key === 'object') {
|
||||
return this.weakMap.get(key);
|
||||
}
|
||||
return this.map.get(key);
|
||||
}
|
||||
has(key) {
|
||||
if (typeof key === 'object') {
|
||||
return this.weakMap.has(key);
|
||||
}
|
||||
return this.map.has(key);
|
||||
}
|
||||
}
|
||||
3
book/node_modules/got/dist/source/create.d.ts
generated
vendored
Normal file
3
book/node_modules/got/dist/source/create.d.ts
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import type { Got, InstanceDefaults } from './types.js';
|
||||
declare const create: (defaults: InstanceDefaults) => Got;
|
||||
export default create;
|
||||
180
book/node_modules/got/dist/source/create.js
generated
vendored
Normal file
180
book/node_modules/got/dist/source/create.js
generated
vendored
Normal file
@@ -0,0 +1,180 @@
|
||||
import { setTimeout as delay } from 'node:timers/promises';
|
||||
import is, { assert } from '@sindresorhus/is';
|
||||
import asPromise from './as-promise/index.js';
|
||||
import Request from './core/index.js';
|
||||
import Options from './core/options.js';
|
||||
const isGotInstance = (value) => is.function(value);
|
||||
const aliases = [
|
||||
'get',
|
||||
'post',
|
||||
'put',
|
||||
'patch',
|
||||
'head',
|
||||
'delete',
|
||||
];
|
||||
const create = (defaults) => {
|
||||
defaults = {
|
||||
options: new Options(undefined, undefined, defaults.options),
|
||||
handlers: [...defaults.handlers],
|
||||
mutableDefaults: defaults.mutableDefaults,
|
||||
};
|
||||
Object.defineProperty(defaults, 'mutableDefaults', {
|
||||
enumerable: true,
|
||||
configurable: false,
|
||||
writable: false,
|
||||
});
|
||||
// Got interface
|
||||
const got = ((url, options, defaultOptions = defaults.options) => {
|
||||
const request = new Request(url, options, defaultOptions);
|
||||
let promise;
|
||||
const lastHandler = (normalized) => {
|
||||
// Note: `options` is `undefined` when `new Options(...)` fails
|
||||
request.options = normalized;
|
||||
request._noPipe = !normalized?.isStream;
|
||||
void request.flush();
|
||||
if (normalized?.isStream) {
|
||||
return request;
|
||||
}
|
||||
promise ||= asPromise(request);
|
||||
return promise;
|
||||
};
|
||||
let iteration = 0;
|
||||
const iterateHandlers = (newOptions) => {
|
||||
const handler = defaults.handlers[iteration++] ?? lastHandler;
|
||||
const result = handler(newOptions, iterateHandlers);
|
||||
if (is.promise(result) && !request.options?.isStream) {
|
||||
promise ||= asPromise(request);
|
||||
if (result !== promise) {
|
||||
const descriptors = Object.getOwnPropertyDescriptors(promise);
|
||||
for (const key in descriptors) {
|
||||
if (key in result) {
|
||||
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
|
||||
delete descriptors[key];
|
||||
}
|
||||
}
|
||||
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
||||
Object.defineProperties(result, descriptors);
|
||||
result.cancel = promise.cancel;
|
||||
}
|
||||
}
|
||||
return result;
|
||||
};
|
||||
return iterateHandlers(request.options);
|
||||
});
|
||||
got.extend = (...instancesOrOptions) => {
|
||||
const options = new Options(undefined, undefined, defaults.options);
|
||||
const handlers = [...defaults.handlers];
|
||||
let mutableDefaults;
|
||||
for (const value of instancesOrOptions) {
|
||||
if (isGotInstance(value)) {
|
||||
options.merge(value.defaults.options);
|
||||
handlers.push(...value.defaults.handlers);
|
||||
mutableDefaults = value.defaults.mutableDefaults;
|
||||
}
|
||||
else {
|
||||
options.merge(value);
|
||||
if (value.handlers) {
|
||||
handlers.push(...value.handlers);
|
||||
}
|
||||
mutableDefaults = value.mutableDefaults;
|
||||
}
|
||||
}
|
||||
return create({
|
||||
options,
|
||||
handlers,
|
||||
mutableDefaults: Boolean(mutableDefaults),
|
||||
});
|
||||
};
|
||||
// Pagination
|
||||
const paginateEach = (async function* (url, options) {
|
||||
let normalizedOptions = new Options(url, options, defaults.options);
|
||||
normalizedOptions.resolveBodyOnly = false;
|
||||
const { pagination } = normalizedOptions;
|
||||
assert.function(pagination.transform);
|
||||
assert.function(pagination.shouldContinue);
|
||||
assert.function(pagination.filter);
|
||||
assert.function(pagination.paginate);
|
||||
assert.number(pagination.countLimit);
|
||||
assert.number(pagination.requestLimit);
|
||||
assert.number(pagination.backoff);
|
||||
const allItems = [];
|
||||
let { countLimit } = pagination;
|
||||
let numberOfRequests = 0;
|
||||
while (numberOfRequests < pagination.requestLimit) {
|
||||
if (numberOfRequests !== 0) {
|
||||
// eslint-disable-next-line no-await-in-loop
|
||||
await delay(pagination.backoff);
|
||||
}
|
||||
// eslint-disable-next-line no-await-in-loop
|
||||
const response = (await got(undefined, undefined, normalizedOptions));
|
||||
// eslint-disable-next-line no-await-in-loop
|
||||
const parsed = await pagination.transform(response);
|
||||
const currentItems = [];
|
||||
assert.array(parsed);
|
||||
for (const item of parsed) {
|
||||
if (pagination.filter({ item, currentItems, allItems })) {
|
||||
if (!pagination.shouldContinue({ item, currentItems, allItems })) {
|
||||
return;
|
||||
}
|
||||
yield item;
|
||||
if (pagination.stackAllItems) {
|
||||
allItems.push(item);
|
||||
}
|
||||
currentItems.push(item);
|
||||
if (--countLimit <= 0) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
const optionsToMerge = pagination.paginate({
|
||||
response,
|
||||
currentItems,
|
||||
allItems,
|
||||
});
|
||||
if (optionsToMerge === false) {
|
||||
return;
|
||||
}
|
||||
if (optionsToMerge === response.request.options) {
|
||||
normalizedOptions = response.request.options;
|
||||
}
|
||||
else {
|
||||
normalizedOptions.merge(optionsToMerge);
|
||||
assert.any([is.urlInstance, is.undefined], optionsToMerge.url);
|
||||
if (optionsToMerge.url !== undefined) {
|
||||
normalizedOptions.prefixUrl = '';
|
||||
normalizedOptions.url = optionsToMerge.url;
|
||||
}
|
||||
}
|
||||
numberOfRequests++;
|
||||
}
|
||||
});
|
||||
got.paginate = paginateEach;
|
||||
got.paginate.all = (async (url, options) => {
|
||||
const results = [];
|
||||
for await (const item of paginateEach(url, options)) {
|
||||
results.push(item);
|
||||
}
|
||||
return results;
|
||||
});
|
||||
// For those who like very descriptive names
|
||||
got.paginate.each = paginateEach;
|
||||
// Stream API
|
||||
got.stream = ((url, options) => got(url, { ...options, isStream: true }));
|
||||
// Shortcuts
|
||||
for (const method of aliases) {
|
||||
got[method] = ((url, options) => got(url, { ...options, method }));
|
||||
got.stream[method] = ((url, options) => got(url, { ...options, method, isStream: true }));
|
||||
}
|
||||
if (!defaults.mutableDefaults) {
|
||||
Object.freeze(defaults.handlers);
|
||||
defaults.options.freeze();
|
||||
}
|
||||
Object.defineProperty(got, 'defaults', {
|
||||
value: defaults,
|
||||
writable: false,
|
||||
configurable: false,
|
||||
enumerable: true,
|
||||
});
|
||||
return got;
|
||||
};
|
||||
export default create;
|
||||
15
book/node_modules/got/dist/source/index.d.ts
generated
vendored
Normal file
15
book/node_modules/got/dist/source/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
||||
declare const got: import("./types.js").Got;
|
||||
export default got;
|
||||
export { got };
|
||||
export { default as Options } from './core/options.js';
|
||||
export * from './core/options.js';
|
||||
export * from './core/response.js';
|
||||
export type { default as Request } from './core/index.js';
|
||||
export * from './core/index.js';
|
||||
export * from './core/errors.js';
|
||||
export type { Delays } from './core/timed-out.js';
|
||||
export { default as calculateRetryDelay } from './core/calculate-retry-delay.js';
|
||||
export * from './as-promise/types.js';
|
||||
export * from './types.js';
|
||||
export { default as create } from './create.js';
|
||||
export { default as parseLinkHeader } from './core/parse-link-header.js';
|
||||
21
book/node_modules/got/dist/source/index.js
generated
vendored
Normal file
21
book/node_modules/got/dist/source/index.js
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
import create from './create.js';
|
||||
import Options from './core/options.js';
|
||||
const defaults = {
|
||||
options: new Options(),
|
||||
handlers: [],
|
||||
mutableDefaults: false,
|
||||
};
|
||||
const got = create(defaults);
|
||||
export default got;
|
||||
// TODO: Remove this in the next major version.
|
||||
export { got };
|
||||
export { default as Options } from './core/options.js';
|
||||
export * from './core/options.js';
|
||||
export * from './core/response.js';
|
||||
export * from './core/index.js';
|
||||
export * from './core/errors.js';
|
||||
export { default as calculateRetryDelay } from './core/calculate-retry-delay.js';
|
||||
export * from './as-promise/types.js';
|
||||
export * from './types.js';
|
||||
export { default as create } from './create.js';
|
||||
export { default as parseLinkHeader } from './core/parse-link-header.js';
|
||||
307
book/node_modules/got/dist/source/types.d.ts
generated
vendored
Normal file
307
book/node_modules/got/dist/source/types.d.ts
generated
vendored
Normal file
@@ -0,0 +1,307 @@
|
||||
import type { Buffer } from 'node:buffer';
|
||||
import type { Spread } from 'type-fest';
|
||||
import type { CancelableRequest } from './as-promise/types.js';
|
||||
import type { Response } from './core/response.js';
|
||||
import type Options from './core/options.js';
|
||||
import { type PaginationOptions, type OptionsInit } from './core/options.js';
|
||||
import type Request from './core/index.js';
|
||||
type Except<ObjectType, KeysType extends keyof ObjectType> = Pick<ObjectType, Exclude<keyof ObjectType, KeysType>>;
|
||||
type Merge<FirstType, SecondType> = Except<FirstType, Extract<keyof FirstType, keyof SecondType>> & SecondType;
|
||||
/**
|
||||
Defaults for each Got instance.
|
||||
*/
|
||||
export type InstanceDefaults = {
|
||||
/**
|
||||
An object containing the default options of Got.
|
||||
*/
|
||||
options: Options;
|
||||
/**
|
||||
An array of functions. You execute them directly by calling `got()`.
|
||||
They are some sort of "global hooks" - these functions are called first.
|
||||
The last handler (*it's hidden*) is either `asPromise` or `asStream`, depending on the `options.isStream` property.
|
||||
|
||||
@default []
|
||||
*/
|
||||
handlers: HandlerFunction[];
|
||||
/**
|
||||
A read-only boolean describing whether the defaults are mutable or not.
|
||||
If set to `true`, you can update headers over time, for example, update an access token when it expires.
|
||||
|
||||
@default false
|
||||
*/
|
||||
mutableDefaults: boolean;
|
||||
};
|
||||
/**
|
||||
A Request object returned by calling Got, or any of the Got HTTP alias request functions.
|
||||
*/
|
||||
export type GotReturn = Request | CancelableRequest;
|
||||
/**
|
||||
A function to handle options and returns a Request object.
|
||||
It acts sort of like a "global hook", and will be called before any actual request is made.
|
||||
*/
|
||||
export type HandlerFunction = <T extends GotReturn>(options: Options, next: (options: Options) => T) => T | Promise<T>;
|
||||
/**
|
||||
The options available for `got.extend()`.
|
||||
*/
|
||||
export type ExtendOptions = {
|
||||
/**
|
||||
An array of functions. You execute them directly by calling `got()`.
|
||||
They are some sort of "global hooks" - these functions are called first.
|
||||
The last handler (*it's hidden*) is either `asPromise` or `asStream`, depending on the `options.isStream` property.
|
||||
|
||||
@default []
|
||||
*/
|
||||
handlers?: HandlerFunction[];
|
||||
/**
|
||||
A read-only boolean describing whether the defaults are mutable or not.
|
||||
If set to `true`, you can update headers over time, for example, update an access token when it expires.
|
||||
|
||||
@default false
|
||||
*/
|
||||
mutableDefaults?: boolean;
|
||||
} & OptionsInit;
|
||||
export type StrictOptions = Except<OptionsInit, 'isStream' | 'responseType' | 'resolveBodyOnly'>;
|
||||
export type StreamOptions = Merge<OptionsInit, {
|
||||
isStream?: true;
|
||||
}>;
|
||||
export type OptionsWithPagination<T = unknown, R = unknown> = Merge<OptionsInit, {
|
||||
pagination?: PaginationOptions<T, R>;
|
||||
}>;
|
||||
/**
|
||||
An instance of `got.paginate`.
|
||||
*/
|
||||
export type GotPaginate = {
|
||||
/**
|
||||
Same as `GotPaginate.each`.
|
||||
*/
|
||||
<T, R = unknown>(url: string | URL, options?: OptionsWithPagination<T, R>): AsyncIterableIterator<T>;
|
||||
/**
|
||||
Same as `GotPaginate.each`.
|
||||
*/
|
||||
<T, R = unknown>(options?: OptionsWithPagination<T, R>): AsyncIterableIterator<T>;
|
||||
/**
|
||||
Returns an async iterator.
|
||||
|
||||
See pagination.options for more pagination options.
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
const countLimit = 10;
|
||||
|
||||
const pagination = got.paginate('https://api.github.com/repos/sindresorhus/got/commits', {
|
||||
pagination: {countLimit}
|
||||
});
|
||||
|
||||
console.log(`Printing latest ${countLimit} Got commits (newest to oldest):`);
|
||||
|
||||
for await (const commitData of pagination) {
|
||||
console.log(commitData.commit.message);
|
||||
}
|
||||
```
|
||||
*/
|
||||
each: (<T, R = unknown>(url: string | URL, options?: OptionsWithPagination<T, R>) => AsyncIterableIterator<T>) & (<T, R = unknown>(options?: OptionsWithPagination<T, R>) => AsyncIterableIterator<T>);
|
||||
/**
|
||||
Returns a Promise for an array of all results.
|
||||
|
||||
See pagination.options for more pagination options.
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
const countLimit = 10;
|
||||
|
||||
const results = await got.paginate.all('https://api.github.com/repos/sindresorhus/got/commits', {
|
||||
pagination: {countLimit}
|
||||
});
|
||||
|
||||
console.log(`Printing latest ${countLimit} Got commits (newest to oldest):`);
|
||||
console.log(results);
|
||||
```
|
||||
*/
|
||||
all: (<T, R = unknown>(url: string | URL, options?: OptionsWithPagination<T, R>) => Promise<T[]>) & (<T, R = unknown>(options?: OptionsWithPagination<T, R>) => Promise<T[]>);
|
||||
};
|
||||
export type OptionsOfTextResponseBody = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
responseType?: 'text';
|
||||
}>;
|
||||
export type OptionsOfTextResponseBodyOnly = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: true;
|
||||
responseType?: 'text';
|
||||
}>;
|
||||
export type OptionsOfTextResponseBodyWrapped = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: false;
|
||||
responseType?: 'text';
|
||||
}>;
|
||||
export type OptionsOfJSONResponseBody = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
responseType?: 'json';
|
||||
}>;
|
||||
export type OptionsOfJSONResponseBodyOnly = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: true;
|
||||
responseType?: 'json';
|
||||
}>;
|
||||
export type OptionsOfJSONResponseBodyWrapped = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: false;
|
||||
responseType?: 'json';
|
||||
}>;
|
||||
export type OptionsOfBufferResponseBody = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
responseType?: 'buffer';
|
||||
}>;
|
||||
export type OptionsOfBufferResponseBodyOnly = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: true;
|
||||
responseType?: 'buffer';
|
||||
}>;
|
||||
export type OptionsOfBufferResponseBodyWrapped = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: false;
|
||||
responseType?: 'buffer';
|
||||
}>;
|
||||
export type OptionsOfUnknownResponseBody = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
}>;
|
||||
export type OptionsOfUnknownResponseBodyOnly = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: true;
|
||||
}>;
|
||||
export type OptionsOfUnknownResponseBodyWrapped = Merge<StrictOptions, {
|
||||
isStream?: false;
|
||||
resolveBodyOnly: false;
|
||||
}>;
|
||||
export type GotRequestFunction<U extends ExtendOptions = Record<string, unknown>> = {
|
||||
(url: string | URL, options?: OptionsOfTextResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<string> : CancelableRequest<Response<string>>;
|
||||
<T>(url: string | URL, options?: OptionsOfJSONResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<T> : CancelableRequest<Response<T>>;
|
||||
(url: string | URL, options?: OptionsOfBufferResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<Buffer> : CancelableRequest<Response<Buffer>>;
|
||||
(url: string | URL, options?: OptionsOfUnknownResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest : CancelableRequest<Response>;
|
||||
(url: string | URL, options?: OptionsOfTextResponseBodyWrapped): CancelableRequest<Response<string>>;
|
||||
<T>(url: string | URL, options?: OptionsOfJSONResponseBodyWrapped): CancelableRequest<Response<T>>;
|
||||
(url: string | URL, options?: OptionsOfBufferResponseBodyWrapped): CancelableRequest<Response<Buffer>>;
|
||||
(url: string | URL, options?: OptionsOfUnknownResponseBodyWrapped): CancelableRequest<Response>;
|
||||
(url: string | URL, options?: OptionsOfTextResponseBodyOnly): CancelableRequest<string>;
|
||||
<T>(url: string | URL, options?: OptionsOfJSONResponseBodyOnly): CancelableRequest<T>;
|
||||
(url: string | URL, options?: OptionsOfBufferResponseBodyOnly): CancelableRequest<Buffer>;
|
||||
(url: string | URL, options?: OptionsOfUnknownResponseBodyOnly): CancelableRequest;
|
||||
(options: OptionsOfTextResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<string> : CancelableRequest<Response<string>>;
|
||||
<T>(options: OptionsOfJSONResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<T> : CancelableRequest<Response<T>>;
|
||||
(options: OptionsOfBufferResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest<Buffer> : CancelableRequest<Response<Buffer>>;
|
||||
(options: OptionsOfUnknownResponseBody): U['resolveBodyOnly'] extends true ? CancelableRequest : CancelableRequest<Response>;
|
||||
(options: OptionsOfTextResponseBodyWrapped): CancelableRequest<Response<string>>;
|
||||
<T>(options: OptionsOfJSONResponseBodyWrapped): CancelableRequest<Response<T>>;
|
||||
(options: OptionsOfBufferResponseBodyWrapped): CancelableRequest<Response<Buffer>>;
|
||||
(options: OptionsOfUnknownResponseBodyWrapped): CancelableRequest<Response>;
|
||||
(options: OptionsOfTextResponseBodyOnly): CancelableRequest<string>;
|
||||
<T>(options: OptionsOfJSONResponseBodyOnly): CancelableRequest<T>;
|
||||
(options: OptionsOfBufferResponseBodyOnly): CancelableRequest<Buffer>;
|
||||
(options: OptionsOfUnknownResponseBodyOnly): CancelableRequest;
|
||||
(url: string | URL, options?: Merge<OptionsInit, {
|
||||
isStream: true;
|
||||
}>): Request;
|
||||
(options: Merge<OptionsInit, {
|
||||
isStream: true;
|
||||
}>): Request;
|
||||
(url: string | URL, options?: OptionsInit): CancelableRequest | Request;
|
||||
(options: OptionsInit): CancelableRequest | Request;
|
||||
(url: undefined, options: undefined, defaults: Options): CancelableRequest | Request;
|
||||
};
|
||||
/**
|
||||
All available HTTP request methods provided by Got.
|
||||
*/
|
||||
export type HTTPAlias = 'get' | 'post' | 'put' | 'patch' | 'head' | 'delete';
|
||||
type GotStreamFunction = ((url?: string | URL, options?: Merge<OptionsInit, {
|
||||
isStream?: true;
|
||||
}>) => Request) & ((options?: Merge<OptionsInit, {
|
||||
isStream?: true;
|
||||
}>) => Request);
|
||||
/**
|
||||
An instance of `got.stream()`.
|
||||
*/
|
||||
export type GotStream = GotStreamFunction & Record<HTTPAlias, GotStreamFunction>;
|
||||
/**
|
||||
An instance of `got`.
|
||||
*/
|
||||
export type Got<GotOptions extends ExtendOptions = ExtendOptions> = {
|
||||
/**
|
||||
Sets `options.isStream` to `true`.
|
||||
|
||||
Returns a [duplex stream](https://nodejs.org/api/stream.html#stream_class_stream_duplex) with additional events:
|
||||
- request
|
||||
- response
|
||||
- redirect
|
||||
- uploadProgress
|
||||
- downloadProgress
|
||||
- error
|
||||
*/
|
||||
stream: GotStream;
|
||||
/**
|
||||
Returns an async iterator.
|
||||
|
||||
See pagination.options for more pagination options.
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
const countLimit = 10;
|
||||
|
||||
const pagination = got.paginate('https://api.github.com/repos/sindresorhus/got/commits', {
|
||||
pagination: {countLimit}
|
||||
});
|
||||
|
||||
console.log(`Printing latest ${countLimit} Got commits (newest to oldest):`);
|
||||
|
||||
for await (const commitData of pagination) {
|
||||
console.log(commitData.commit.message);
|
||||
}
|
||||
```
|
||||
*/
|
||||
paginate: GotPaginate;
|
||||
/**
|
||||
The Got defaults used in that instance.
|
||||
*/
|
||||
defaults: InstanceDefaults;
|
||||
/**
|
||||
Configure a new `got` instance with default `options`.
|
||||
The `options` are merged with the parent instance's `defaults.options` using `got.mergeOptions`.
|
||||
You can access the resolved options with the `.defaults` property on the instance.
|
||||
|
||||
Additionally, `got.extend()` accepts two properties from the `defaults` object: `mutableDefaults` and `handlers`.
|
||||
|
||||
It is also possible to merges many instances into a single one:
|
||||
- options are merged using `got.mergeOptions()` (including hooks),
|
||||
- handlers are stored in an array (you can access them through `instance.defaults.handlers`).
|
||||
|
||||
@example
|
||||
```
|
||||
import got from 'got';
|
||||
|
||||
const client = got.extend({
|
||||
prefixUrl: 'https://example.com',
|
||||
headers: {
|
||||
'x-unicorn': 'rainbow'
|
||||
}
|
||||
});
|
||||
|
||||
client.get('demo');
|
||||
|
||||
// HTTP Request =>
|
||||
// GET /demo HTTP/1.1
|
||||
// Host: example.com
|
||||
// x-unicorn: rainbow
|
||||
```
|
||||
*/
|
||||
extend<T extends Array<Got | ExtendOptions>>(...instancesOrOptions: T): Got<MergeExtendsConfig<T>>;
|
||||
} & Record<HTTPAlias, GotRequestFunction<GotOptions>> & GotRequestFunction<GotOptions>;
|
||||
export type ExtractExtendOptions<T> = T extends Got<infer GotOptions> ? GotOptions : T;
|
||||
/**
|
||||
Merges the options of multiple Got instances.
|
||||
*/
|
||||
export type MergeExtendsConfig<Value extends Array<Got | ExtendOptions>> = Value extends readonly [Value[0], ...infer NextValue] ? NextValue[0] extends undefined ? Value[0] extends infer OnlyValue ? OnlyValue extends ExtendOptions ? OnlyValue : OnlyValue extends Got<infer GotOptions> ? GotOptions : OnlyValue : never : ExtractExtendOptions<Value[0]> extends infer FirstArg extends ExtendOptions ? ExtractExtendOptions<NextValue[0] extends ExtendOptions | Got ? NextValue[0] : never> extends infer NextArg extends ExtendOptions ? Spread<FirstArg, NextArg> extends infer Merged extends ExtendOptions ? NextValue extends [NextValue[0], ...infer NextRest] ? NextRest extends Array<Got | ExtendOptions> ? MergeExtendsConfig<[Merged, ...NextRest]> : never : never : never : never : never : never;
|
||||
export {};
|
||||
1
book/node_modules/got/dist/source/types.js
generated
vendored
Normal file
1
book/node_modules/got/dist/source/types.js
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export {};
|
||||
9
book/node_modules/got/license
generated
vendored
Normal file
9
book/node_modules/got/license
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (https://sindresorhus.com)
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
154
book/node_modules/got/package.json
generated
vendored
Normal file
154
book/node_modules/got/package.json
generated
vendored
Normal file
@@ -0,0 +1,154 @@
|
||||
{
|
||||
"name": "got",
|
||||
"version": "14.4.5",
|
||||
"description": "Human-friendly and powerful HTTP request library for Node.js",
|
||||
"license": "MIT",
|
||||
"repository": "sindresorhus/got",
|
||||
"funding": "https://github.com/sindresorhus/got?sponsor=1",
|
||||
"type": "module",
|
||||
"exports": {
|
||||
"types": "./dist/source/index.d.ts",
|
||||
"default": "./dist/source/index.js"
|
||||
},
|
||||
"sideEffects": false,
|
||||
"engines": {
|
||||
"node": ">=20"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "xo && tsc --noEmit && NODE_OPTIONS='--import=tsx/esm' ava",
|
||||
"release": "np",
|
||||
"build": "del-cli dist && tsc",
|
||||
"prepare": "npm run build"
|
||||
},
|
||||
"files": [
|
||||
"dist/source"
|
||||
],
|
||||
"keywords": [
|
||||
"http",
|
||||
"https",
|
||||
"http2",
|
||||
"get",
|
||||
"got",
|
||||
"url",
|
||||
"uri",
|
||||
"request",
|
||||
"simple",
|
||||
"curl",
|
||||
"wget",
|
||||
"fetch",
|
||||
"net",
|
||||
"network",
|
||||
"gzip",
|
||||
"brotli",
|
||||
"requests",
|
||||
"human-friendly",
|
||||
"axios",
|
||||
"superagent",
|
||||
"node-fetch",
|
||||
"ky"
|
||||
],
|
||||
"dependencies": {
|
||||
"@sindresorhus/is": "^7.0.1",
|
||||
"@szmarczak/http-timer": "^5.0.1",
|
||||
"cacheable-lookup": "^7.0.0",
|
||||
"cacheable-request": "^12.0.1",
|
||||
"decompress-response": "^6.0.0",
|
||||
"form-data-encoder": "^4.0.2",
|
||||
"http2-wrapper": "^2.2.1",
|
||||
"lowercase-keys": "^3.0.0",
|
||||
"p-cancelable": "^4.0.1",
|
||||
"responselike": "^3.0.0",
|
||||
"type-fest": "^4.26.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@hapi/bourne": "^3.0.0",
|
||||
"@sindresorhus/tsconfig": "^6.0.0",
|
||||
"@sinonjs/fake-timers": "^11.2.2",
|
||||
"@types/benchmark": "^2.1.5",
|
||||
"@types/express": "^5.0.0",
|
||||
"@types/node": "^22.7.5",
|
||||
"@types/pem": "^1.14.4",
|
||||
"@types/readable-stream": "^4.0.14",
|
||||
"@types/request": "^2.48.12",
|
||||
"@types/sinon": "^17.0.2",
|
||||
"@types/sinonjs__fake-timers": "^8.1.5",
|
||||
"ava": "^5.3.1",
|
||||
"axios": "^1.7.7",
|
||||
"benchmark": "^2.1.4",
|
||||
"bluebird": "^3.7.2",
|
||||
"body-parser": "^1.20.3",
|
||||
"create-cert": "^1.0.6",
|
||||
"create-test-server": "^3.0.1",
|
||||
"del-cli": "^6.0.0",
|
||||
"delay": "^6.0.0",
|
||||
"expect-type": "^1.0.0",
|
||||
"express": "^4.21.1",
|
||||
"form-data": "^4.0.0",
|
||||
"formdata-node": "^6.0.3",
|
||||
"get-stream": "^9.0.1",
|
||||
"nock": "^13.5.5",
|
||||
"node-fetch": "^3.3.2",
|
||||
"np": "^10.0.5",
|
||||
"nyc": "^17.1.0",
|
||||
"p-event": "^6.0.1",
|
||||
"pem": "^1.14.8",
|
||||
"pify": "^6.1.0",
|
||||
"readable-stream": "^4.4.2",
|
||||
"request": "^2.88.2",
|
||||
"sinon": "^19.0.2",
|
||||
"slow-stream": "0.0.4",
|
||||
"tempy": "^3.1.0",
|
||||
"then-busboy": "^5.2.1",
|
||||
"tough-cookie": "^4.1.4",
|
||||
"tsx": "^4.19.1",
|
||||
"typescript": "^5.6.3",
|
||||
"xo": "^0.56.0"
|
||||
},
|
||||
"ava": {
|
||||
"files": [
|
||||
"test/*",
|
||||
"!test/*.types.ts"
|
||||
],
|
||||
"timeout": "10m",
|
||||
"extensions": {
|
||||
"ts": "module"
|
||||
},
|
||||
"workerThreads": false
|
||||
},
|
||||
"nyc": {
|
||||
"reporter": [
|
||||
"text",
|
||||
"html",
|
||||
"lcov"
|
||||
],
|
||||
"extension": [
|
||||
".ts"
|
||||
],
|
||||
"exclude": [
|
||||
"**/test/**"
|
||||
]
|
||||
},
|
||||
"xo": {
|
||||
"ignores": [
|
||||
"documentation/examples/*"
|
||||
],
|
||||
"rules": {
|
||||
"@typescript-eslint/no-empty-function": "off",
|
||||
"n/no-deprecated-api": "off",
|
||||
"@typescript-eslint/no-implicit-any-catch": "off",
|
||||
"ava/assertion-arguments": "off",
|
||||
"@typescript-eslint/no-unsafe-member-access": "off",
|
||||
"@typescript-eslint/no-unsafe-return": "off",
|
||||
"@typescript-eslint/no-unsafe-assignment": "off",
|
||||
"@typescript-eslint/no-unsafe-call": "off",
|
||||
"@typescript-eslint/await-thenable": "off",
|
||||
"@typescript-eslint/no-redundant-type-constituents": "off",
|
||||
"@typescript-eslint/no-unsafe-argument": "off",
|
||||
"@typescript-eslint/promise-function-async": "off",
|
||||
"no-lone-blocks": "off",
|
||||
"unicorn/no-await-expression-member": "off",
|
||||
"unicorn/prefer-event-target": "off"
|
||||
}
|
||||
},
|
||||
"runkitExampleFilename": "./documentation/examples/runkit-example.js"
|
||||
}
|
||||
480
book/node_modules/got/readme.md
generated
vendored
Normal file
480
book/node_modules/got/readme.md
generated
vendored
Normal file
@@ -0,0 +1,480 @@
|
||||
<div align="center">
|
||||
<br>
|
||||
<br>
|
||||
<img width="360" src="media/logo.svg" alt="Got">
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<hr>
|
||||
<p>
|
||||
<p>
|
||||
<sup>
|
||||
Sindre's open source work is supported by the community.<br>Special thanks to:
|
||||
</sup>
|
||||
</p>
|
||||
<br>
|
||||
<br>
|
||||
<a href="https://www.fame.fi#gh-light-mode-only">
|
||||
<img src="https://sindresorhus.com/assets/thanks/fame-logo-light.svg" width="200" alt="Fame Helsinki">
|
||||
</a>
|
||||
<a href="https://www.fame.fi#gh-dark-mode-only">
|
||||
<img src="https://sindresorhus.com/assets/thanks/fame-logo-dark.svg" width="200" alt="Fame Helsinki">
|
||||
</a>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<a href="https://encore.dev?utm_campaign=github_repo&utm_medium=referral&utm_content=sindre&utm_source=github">
|
||||
<div>
|
||||
<picture>
|
||||
<source width="230" media="(prefers-color-scheme: dark)" srcset="https://sindresorhus.com/assets/thanks/encore-logo-dark.svg">
|
||||
<source width="230" media="(prefers-color-scheme: light)" srcset="https://sindresorhus.com/assets/thanks/encore-logo-light.svg">
|
||||
<img width="230" src="https://sindresorhus.com/assets/thanks/encore-logo-light.svg" alt="Encore logo">
|
||||
</picture>
|
||||
</div>
|
||||
<b>The development platform for building type-safe distributed systems</b>
|
||||
<div>
|
||||
<sup>End-to-end tooling from local development to automated DevOps and infrastructure in your AWS/GCP.</sup>
|
||||
</div>
|
||||
<br>
|
||||
<br>
|
||||
</a>
|
||||
</p>
|
||||
<hr>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
<br>
|
||||
</div>
|
||||
|
||||
> Human-friendly and powerful HTTP request library for Node.js
|
||||
|
||||
<!-- [](https://codecov.io/gh/sindresorhus/got/branch/main) -->
|
||||
[](https://npmjs.com/got)
|
||||
[](https://packagephobia.com/result?p=got)
|
||||
|
||||
[See how Got compares to other HTTP libraries](#comparison)
|
||||
|
||||
---
|
||||
|
||||
**You probably want [Ky](https://github.com/sindresorhus/ky) instead, by the same people. It's smaller, works in the browser too, and is more stable since it's built upon [`Fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).**
|
||||
|
||||
---
|
||||
|
||||
**Support questions should be asked [here](https://github.com/sindresorhus/got/discussions).**
|
||||
|
||||
## Install
|
||||
|
||||
```sh
|
||||
npm install got
|
||||
```
|
||||
|
||||
**Warning:** This package is native [ESM](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Modules) and no longer provides a CommonJS export. If your project uses CommonJS, you will have to [convert to ESM](https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c). Please don't open issues for questions regarding CommonJS / ESM.
|
||||
|
||||
**Got v11 is no longer maintained and we will not accept any backport requests.**
|
||||
|
||||
## Take a peek
|
||||
|
||||
**A [quick start](documentation/quick-start.md) guide is available.**
|
||||
|
||||
### JSON mode
|
||||
|
||||
Got has a dedicated option for handling JSON payload.\
|
||||
Furthermore, the promise exposes a `.json<T>()` function that returns `Promise<T>`.
|
||||
|
||||
```js
|
||||
import got from 'got';
|
||||
|
||||
const {data} = await got.post('https://httpbin.org/anything', {
|
||||
json: {
|
||||
hello: 'world'
|
||||
}
|
||||
}).json();
|
||||
|
||||
console.log(data);
|
||||
//=> {"hello": "world"}
|
||||
```
|
||||
|
||||
For advanced JSON usage, check out the [`parseJson`](documentation/2-options.md#parsejson) and [`stringifyJson`](documentation/2-options.md#stringifyjson) options.
|
||||
|
||||
**For more useful tips like this, visit the [Tips](documentation/tips.md) page.**
|
||||
|
||||
## Highlights
|
||||
|
||||
- [Used by 10K+ packages and 5M+ repos](https://github.com/sindresorhus/got/network/dependents)
|
||||
- [Actively maintained](https://github.com/sindresorhus/got/graphs/contributors)
|
||||
- [Trusted by many companies](#widely-used)
|
||||
|
||||
## Documentation
|
||||
|
||||
By default, Got will retry on failure. To disable this option, set [`options.retry.limit`](documentation/7-retry.md#retry) to 0.
|
||||
|
||||
#### Main API
|
||||
|
||||
- [x] [Promise API](documentation/1-promise.md)
|
||||
- [x] [Options](documentation/2-options.md)
|
||||
- [x] [Stream API](documentation/3-streams.md)
|
||||
- [x] [Pagination API](documentation/4-pagination.md)
|
||||
- [x] [Advanced HTTPS API](documentation/5-https.md)
|
||||
- [x] [HTTP/2 support](documentation/2-options.md#http2)
|
||||
- [x] [`Response` class](documentation/3-streams.md#response-2)
|
||||
|
||||
#### Timeouts and retries
|
||||
|
||||
- [x] [Advanced timeout handling](documentation/6-timeout.md)
|
||||
- [x] [Retries on failure](documentation/7-retry.md)
|
||||
- [x] [Errors with metadata](documentation/8-errors.md)
|
||||
|
||||
#### Advanced creation
|
||||
|
||||
- [x] [Hooks](documentation/9-hooks.md)
|
||||
- [x] [Instances](documentation/10-instances.md)
|
||||
- [x] [Progress events & other events](documentation/3-streams.md#events)
|
||||
- [x] [Plugins](documentation/lets-make-a-plugin.md)
|
||||
- [x] [Compose](documentation/examples/advanced-creation.js)
|
||||
|
||||
#### Cache, Proxy and UNIX sockets
|
||||
|
||||
- [x] [RFC compliant caching](documentation/cache.md)
|
||||
- [x] [Proxy support](documentation/tips.md#proxying)
|
||||
- [x] [Unix Domain Sockets](documentation/2-options.md#enableunixsockets)
|
||||
|
||||
#### Integration
|
||||
|
||||
- [x] [TypeScript support](documentation/typescript.md)
|
||||
- [x] [AWS](documentation/tips.md#aws)
|
||||
- [x] [Testing](documentation/tips.md#testing)
|
||||
|
||||
---
|
||||
|
||||
### Migration guides
|
||||
|
||||
- [Request migration guide](documentation/migration-guides/request.md)
|
||||
- [*(Note that Request is unmaintained)*](https://github.com/request/request/issues/3142)
|
||||
- [Axios](documentation/migration-guides/axios.md)
|
||||
- [Node.js](documentation/migration-guides/nodejs.md)
|
||||
|
||||
## Got plugins
|
||||
|
||||
- [`got4aws`](https://github.com/SamVerschueren/got4aws) - Got convenience wrapper to interact with AWS v4 signed APIs
|
||||
- [`gh-got`](https://github.com/sindresorhus/gh-got) - Got convenience wrapper to interact with the GitHub API
|
||||
- [`gl-got`](https://github.com/singapore/gl-got) - Got convenience wrapper to interact with the GitLab API
|
||||
- [`gotql`](https://github.com/khaosdoctor/gotql) - Got convenience wrapper to interact with GraphQL using JSON-parsed queries instead of strings
|
||||
- [`got-fetch`](https://github.com/alexghr/got-fetch) - Got with a [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API) interface
|
||||
- [`got-scraping`](https://github.com/apify/got-scraping) - Got wrapper specifically designed for web scraping purposes
|
||||
- [`got-ssrf`](https://github.com/JaneJeon/got-ssrf) - Got wrapper to protect server-side requests against SSRF attacks
|
||||
|
||||
## Comparison
|
||||
|
||||
| | `got` | [`node-fetch`][n0] | [`ky`][k0] | [`axios`][a0] | [`superagent`][s0] |
|
||||
|-----------------------|:-------------------:|:--------------------:|:------------------------:|:------------------:|:----------------------:|
|
||||
| HTTP/2 support | :heavy_check_mark:¹ | :x: | :heavy_check_mark: | :x: | :heavy_check_mark:\*\* |
|
||||
| Browser support | :x: | :heavy_check_mark:\* | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| Promise API | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| Stream API | :heavy_check_mark: | Node.js only | :x: | :x: | :heavy_check_mark: |
|
||||
| Pagination API | :heavy_check_mark: | :x: | :x: | :x: | :x: |
|
||||
| Request cancelation | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| RFC compliant caching | :heavy_check_mark: | :x: | :x: | :x: | :x: |
|
||||
| Cookies (out-of-the-box) | :heavy_check_mark: | :x: | :x: | :x: | :x: |
|
||||
| Follows redirects | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| Retries on failure | :heavy_check_mark: | :x: | :heavy_check_mark: | :x: | :heavy_check_mark: |
|
||||
| Progress events | :heavy_check_mark: | :x: | :heavy_check_mark:\*\*\* | Browser only | :heavy_check_mark: |
|
||||
| Handles gzip/deflate | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| Advanced timeouts | :heavy_check_mark: | :x: | :x: | :x: | :x: |
|
||||
| Timings | :heavy_check_mark: | :x: | :x: | :x: | :x: |
|
||||
| Errors with metadata | :heavy_check_mark: | :x: | :heavy_check_mark: | :heavy_check_mark: | :x: |
|
||||
| JSON mode | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||
| Custom defaults | :heavy_check_mark: | :x: | :heavy_check_mark: | :heavy_check_mark: | :x: |
|
||||
| Composable | :heavy_check_mark: | :x: | :x: | :x: | :heavy_check_mark: |
|
||||
| Hooks | :heavy_check_mark: | :x: | :heavy_check_mark: | :heavy_check_mark: | :x: |
|
||||
| Issues open | [![][gio]][g1] | [![][nio]][n1] | [![][kio]][k1] | [![][aio]][a1] | [![][sio]][s1] |
|
||||
| Issues closed | [![][gic]][g2] | [![][nic]][n2] | [![][kic]][k2] | [![][aic]][a2] | [![][sic]][s2] |
|
||||
| Downloads | [![][gd]][g3] | [![][nd]][n3] | [![][kd]][k3] | [![][ad]][a3] | [![][sd]][s3] |
|
||||
| Coverage | TBD | [![][nc]][n4] | [![][kc]][k4] | [![][ac]][a4] | [![][sc]][s4] |
|
||||
| Build | [![][gb]][g5] | [![][nb]][n5] | [![][kb]][k5] | [![][ab]][a5] | [![][sb]][s5] |
|
||||
| Bugs | [![][gbg]][g6] | [![][nbg]][n6] | [![][kbg]][k6] | [![][abg]][a6] | [![][sbg]][s6] |
|
||||
| Dependents | [![][gdp]][g7] | [![][ndp]][n7] | [![][kdp]][k7] | [![][adp]][a7] | [![][sdp]][s7] |
|
||||
| Install size | [![][gis]][g8] | [![][nis]][n8] | [![][kis]][k8] | [![][ais]][a8] | [![][sis]][s8] |
|
||||
| GitHub stars | [![][gs]][g9] | [![][ns]][n9] | [![][ks]][k9] | [![][as]][a9] | [![][ss]][s9] |
|
||||
| TypeScript support | [![][gts]][g10] | [![][nts]][n10] | [![][kts]][k10] | [![][ats]][a10] | [![][sts]][s11] |
|
||||
| Last commit | [![][glc]][g11] | [![][nlc]][n11] | [![][klc]][k11] | [![][alc]][a11] | [![][slc]][s11] |
|
||||
|
||||
\* It's almost API compatible with the browser `fetch` API.\
|
||||
\*\* Need to switch the protocol manually. Doesn't accept PUSH streams and doesn't reuse HTTP/2 sessions.\
|
||||
\*\*\* Currently, only `DownloadProgress` event is supported, `UploadProgress` event is not supported.\
|
||||
¹ Requires Node.js 15.10.0 or above.\
|
||||
:sparkle: Almost-stable feature, but the API may change. Don't hesitate to try it out!\
|
||||
:grey_question: Feature in early stage of development. Very experimental.
|
||||
|
||||
<!-- GITHUB -->
|
||||
[k0]: https://github.com/sindresorhus/ky
|
||||
[n0]: https://github.com/node-fetch/node-fetch
|
||||
[a0]: https://github.com/axios/axios
|
||||
[s0]: https://github.com/visionmedia/superagent
|
||||
|
||||
<!-- ISSUES OPEN -->
|
||||
[gio]: https://img.shields.io/github/issues-raw/sindresorhus/got?color=gray&label
|
||||
[kio]: https://img.shields.io/github/issues-raw/sindresorhus/ky?color=gray&label
|
||||
[nio]: https://img.shields.io/github/issues-raw/bitinn/node-fetch?color=gray&label
|
||||
[aio]: https://img.shields.io/github/issues-raw/axios/axios?color=gray&label
|
||||
[sio]: https://img.shields.io/github/issues-raw/visionmedia/superagent?color=gray&label
|
||||
|
||||
[g1]: https://github.com/sindresorhus/got/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
|
||||
[k1]: https://github.com/sindresorhus/ky/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
|
||||
[n1]: https://github.com/bitinn/node-fetch/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
|
||||
[a1]: https://github.com/axios/axios/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
|
||||
[s1]: https://github.com/visionmedia/superagent/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
|
||||
|
||||
<!-- ISSUES CLOSED -->
|
||||
[gic]: https://img.shields.io/github/issues-closed-raw/sindresorhus/got?color=blue&label
|
||||
[kic]: https://img.shields.io/github/issues-closed-raw/sindresorhus/ky?color=blue&label
|
||||
[nic]: https://img.shields.io/github/issues-closed-raw/bitinn/node-fetch?color=blue&label
|
||||
[aic]: https://img.shields.io/github/issues-closed-raw/axios/axios?color=blue&label
|
||||
[sic]: https://img.shields.io/github/issues-closed-raw/visionmedia/superagent?color=blue&label
|
||||
|
||||
[g2]: https://github.com/sindresorhus/got/issues?q=is%3Aissue+is%3Aclosed+sort%3Aupdated-desc
|
||||
[k2]: https://github.com/sindresorhus/ky/issues?q=is%3Aissue+is%3Aclosed+sort%3Aupdated-desc
|
||||
[n2]: https://github.com/bitinn/node-fetch/issues?q=is%3Aissue+is%3Aclosed+sort%3Aupdated-desc
|
||||
[a2]: https://github.com/axios/axios/issues?q=is%3Aissue+is%3Aclosed+sort%3Aupdated-desc
|
||||
[s2]: https://github.com/visionmedia/superagent/issues?q=is%3Aissue+is%3Aclosed+sort%3Aupdated-desc
|
||||
|
||||
<!-- DOWNLOADS -->
|
||||
[gd]: https://img.shields.io/npm/dm/got?color=darkgreen&label
|
||||
[kd]: https://img.shields.io/npm/dm/ky?color=darkgreen&label
|
||||
[nd]: https://img.shields.io/npm/dm/node-fetch?color=darkgreen&label
|
||||
[ad]: https://img.shields.io/npm/dm/axios?color=darkgreen&label
|
||||
[sd]: https://img.shields.io/npm/dm/superagent?color=darkgreen&label
|
||||
|
||||
[g3]: https://www.npmjs.com/package/got
|
||||
[k3]: https://www.npmjs.com/package/ky
|
||||
[n3]: https://www.npmjs.com/package/node-fetch
|
||||
[a3]: https://www.npmjs.com/package/axios
|
||||
[s3]: https://www.npmjs.com/package/superagent
|
||||
|
||||
<!-- COVERAGE -->
|
||||
[gc]: https://img.shields.io/coveralls/github/sindresorhus/got?color=0b9062&label
|
||||
[kc]: https://img.shields.io/codecov/c/github/sindresorhus/ky?color=0b9062&label
|
||||
[nc]: https://img.shields.io/coveralls/github/bitinn/node-fetch?color=0b9062&label
|
||||
[ac]: https://img.shields.io/coveralls/github/mzabriskie/axios?color=0b9062&label
|
||||
[sc]: https://img.shields.io/codecov/c/github/visionmedia/superagent?color=0b9062&label
|
||||
|
||||
[g4]: https://coveralls.io/github/sindresorhus/got
|
||||
[k4]: https://codecov.io/gh/sindresorhus/ky
|
||||
[n4]: https://coveralls.io/github/bitinn/node-fetch
|
||||
[a4]: https://coveralls.io/github/mzabriskie/axios
|
||||
[s4]: https://codecov.io/gh/visionmedia/superagent
|
||||
|
||||
<!-- BUILD -->
|
||||
[gb]: https://github.com/sindresorhus/got/actions/workflows/main.yml/badge.svg
|
||||
[kb]: https://github.com/sindresorhus/ky/actions/workflows/main.yml/badge.svg
|
||||
[nb]: https://img.shields.io/travis/bitinn/node-fetch?label
|
||||
[ab]: https://img.shields.io/travis/axios/axios?label
|
||||
[sb]: https://img.shields.io/travis/visionmedia/superagent?label
|
||||
|
||||
[g5]: https://github.com/sindresorhus/got/actions/workflows/main.yml
|
||||
[k5]: https://github.com/sindresorhus/ky/actions/workflows/main.yml
|
||||
[n5]: https://travis-ci.org/github/bitinn/node-fetch
|
||||
[a5]: https://travis-ci.org/github/axios/axios
|
||||
[s5]: https://travis-ci.org/github/visionmedia/superagent
|
||||
|
||||
<!-- BUGS -->
|
||||
[gbg]: https://img.shields.io/github/issues-raw/sindresorhus/got/bug?color=darkred&label
|
||||
[kbg]: https://img.shields.io/github/issues-raw/sindresorhus/ky/bug?color=darkred&label
|
||||
[nbg]: https://img.shields.io/github/issues-raw/bitinn/node-fetch/bug?color=darkred&label
|
||||
[abg]: https://img.shields.io/github/issues-raw/axios/axios/bug-fix?color=darkred&label
|
||||
[sbg]: https://img.shields.io/github/issues-raw/visionmedia/superagent/Bug?color=darkred&label
|
||||
|
||||
[g6]: https://github.com/sindresorhus/got/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3Abug
|
||||
[k6]: https://github.com/sindresorhus/ky/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3Abug
|
||||
[n6]: https://github.com/bitinn/node-fetch/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3Abug
|
||||
[a6]: https://github.com/axios/axios/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22bug-fix%22
|
||||
[s6]: https://github.com/visionmedia/superagent/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3ABug
|
||||
|
||||
<!-- DEPENDENTS -->
|
||||
[gdp]: https://badgen.net/npm/dependents/got?color=orange&label
|
||||
[kdp]: https://badgen.net/npm/dependents/ky?color=orange&label
|
||||
[ndp]: https://badgen.net/npm/dependents/node-fetch?color=orange&label
|
||||
[adp]: https://badgen.net/npm/dependents/axios?color=orange&label
|
||||
[sdp]: https://badgen.net/npm/dependents/superagent?color=orange&label
|
||||
|
||||
[g7]: https://www.npmjs.com/package/got?activeTab=dependents
|
||||
[k7]: https://www.npmjs.com/package/ky?activeTab=dependents
|
||||
[n7]: https://www.npmjs.com/package/node-fetch?activeTab=dependents
|
||||
[a7]: https://www.npmjs.com/package/axios?activeTab=dependents
|
||||
[s7]: https://www.npmjs.com/package/visionmedia?activeTab=dependents
|
||||
|
||||
<!-- INSTALL SIZE -->
|
||||
[gis]: https://packagephobia.com/badge?p=got
|
||||
[kis]: https://packagephobia.com/badge?p=ky
|
||||
[nis]: https://packagephobia.com/badge?p=node-fetch
|
||||
[ais]: https://packagephobia.com/badge?p=axios
|
||||
[sis]: https://packagephobia.com/badge?p=superagent
|
||||
|
||||
[g8]: https://packagephobia.com/result?p=got
|
||||
[k8]: https://packagephobia.com/result?p=ky
|
||||
[n8]: https://packagephobia.com/result?p=node-fetch
|
||||
[a8]: https://packagephobia.com/result?p=axios
|
||||
[s8]: https://packagephobia.com/result?p=superagent
|
||||
|
||||
<!-- GITHUB STARS -->
|
||||
[gs]: https://img.shields.io/github/stars/sindresorhus/got?color=white&label
|
||||
[ks]: https://img.shields.io/github/stars/sindresorhus/ky?color=white&label
|
||||
[ns]: https://img.shields.io/github/stars/bitinn/node-fetch?color=white&label
|
||||
[as]: https://img.shields.io/github/stars/axios/axios?color=white&label
|
||||
[ss]: https://img.shields.io/github/stars/visionmedia/superagent?color=white&label
|
||||
|
||||
[g9]: https://github.com/sindresorhus/got
|
||||
[k9]: https://github.com/sindresorhus/ky
|
||||
[n9]: https://github.com/node-fetch/node-fetch
|
||||
[a9]: https://github.com/axios/axios
|
||||
[s9]: https://github.com/visionmedia/superagent
|
||||
|
||||
<!-- TYPESCRIPT SUPPORT -->
|
||||
[gts]: https://badgen.net/npm/types/got?label
|
||||
[kts]: https://badgen.net/npm/types/ky?label
|
||||
[nts]: https://badgen.net/npm/types/node-fetch?label
|
||||
[ats]: https://badgen.net/npm/types/axios?label
|
||||
[sts]: https://badgen.net/npm/types/superagent?label
|
||||
|
||||
[g10]: https://github.com/sindresorhus/got
|
||||
[k10]: https://github.com/sindresorhus/ky
|
||||
[n10]: https://github.com/node-fetch/node-fetch
|
||||
[a10]: https://github.com/axios/axios
|
||||
[s10]: https://github.com/visionmedia/superagent
|
||||
|
||||
<!-- LAST COMMIT -->
|
||||
[glc]: https://img.shields.io/github/last-commit/sindresorhus/got?color=gray&label
|
||||
[klc]: https://img.shields.io/github/last-commit/sindresorhus/ky?color=gray&label
|
||||
[nlc]: https://img.shields.io/github/last-commit/bitinn/node-fetch?color=gray&label
|
||||
[alc]: https://img.shields.io/github/last-commit/axios/axios?color=gray&label
|
||||
[slc]: https://img.shields.io/github/last-commit/visionmedia/superagent?color=gray&label
|
||||
|
||||
[g11]: https://github.com/sindresorhus/got/commits
|
||||
[k11]: https://github.com/sindresorhus/ky/commits
|
||||
[n11]: https://github.com/node-fetch/node-fetch/commits
|
||||
[a11]: https://github.com/axios/axios/commits
|
||||
[s11]: https://github.com/visionmedia/superagent/commits
|
||||
|
||||
[Click here][InstallSizeOfTheDependencies] to see the install size of the Got dependencies.
|
||||
|
||||
[InstallSizeOfTheDependencies]: https://packagephobia.com/result?p=@sindresorhus/is@7.0.0,@szmarczak/http-timer@5.0.1,cacheable-lookup@7.0.0,cacheable-request@12.0.1,decompress-response@6.0.0,form-data-encoder@4.0.2,http2-wrapper@2.2.1,lowercase-keys@3.0.0,p-cancelable@4.0.1,responselike@3.0.0,type-fest@4.19.0
|
||||
|
||||
## Maintainers
|
||||
|
||||
[](https://sindresorhus.com) | [](https://github.com/szmarczak)
|
||||
---|---
|
||||
[Sindre Sorhus](https://sindresorhus.com) | [Szymon Marczak](https://github.com/szmarczak)
|
||||
|
||||
<a name="widely-used"></a>
|
||||
## These amazing companies are using Got
|
||||
|
||||
<table>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td align="center">
|
||||
<a href="https://segment.com">
|
||||
<img width="90" valign="middle" src="https://user-images.githubusercontent.com/697676/47693700-ddb62500-dbb7-11e8-8332-716a91010c2d.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://antora.org">
|
||||
<img width="100" valign="middle" src="https://user-images.githubusercontent.com/79351/47706840-d874cc80-dbef-11e8-87c6-5f0c60cbf5dc.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://getvoip.com">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/10832620/47869404-429e9480-dddd-11e8-8a7a-ca43d7f06020.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://github.com/exoframejs/exoframe">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/365944/47791460-11a95b80-dd1a-11e8-9070-e8f2a215e03a.png">
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td align="center">
|
||||
<a href="http://karaokes.moe">
|
||||
<img width="140" valign="middle" src="https://karaokes.moe/assets/images/index.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://github.com/renovatebot/renovate">
|
||||
<img width="150" valign="middle" src="https://avatars.githubusercontent.com/u/38656520?s=200&v=4">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://resist.bot">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/3322287/51992724-28736180-2473-11e9-9764-599cfda4b012.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://www.naturalcycles.com">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/170270/92244143-d0a8a200-eec2-11ea-9fc0-1c07f90b2113.png">
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td align="center">
|
||||
<a href="https://microlink.io">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/36894700/91992974-1cc5dc00-ed35-11ea-9d04-f58b42ce6a5e.png">
|
||||
</a>
|
||||
</td>
|
||||
<td align="center">
|
||||
<a href="https://radity.com">
|
||||
<img width="150" valign="middle" src="https://user-images.githubusercontent.com/29518613/91814036-97fb9500-ec44-11ea-8c6c-d198cc23ca29.png">
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<!-- <br> -->
|
||||
|
||||
<!-- *Creating an awesome product? Open an issue to get listed here.* -->
|
||||
|
||||
<br>
|
||||
|
||||
> Segment is a happy user of Got! Got powers the main backend API that our app talks to. It's used by our in-house RPC client that we use to communicate with all microservices.
|
||||
>
|
||||
> — <a href="https://github.com/vadimdemedes">Vadim Demedes</a>
|
||||
|
||||
> Antora, a static site generator for creating documentation sites, uses Got to download the UI bundle. In Antora, the UI bundle (aka theme) is maintained as a separate project. That project exports the UI as a zip file we call the UI bundle. The main site generator downloads that UI from a URL using Got and streams it to vinyl-zip to extract the files. Those files go on to be used to create the HTML pages and supporting assets.
|
||||
>
|
||||
> — <a href="https://github.com/mojavelinux">Dan Allen</a>
|
||||
|
||||
> GetVoIP is happily using Got in production. One of the unique capabilities of Got is the ability to handle Unix sockets which enables us to build a full control interfaces for our docker stack.
|
||||
>
|
||||
> — <a href="https://github.com/danielkalen">Daniel Kalen</a>
|
||||
|
||||
> We're using Got inside of Exoframe to handle all the communication between CLI and server. Exoframe is a self-hosted tool that allows simple one-command deployments using Docker.
|
||||
>
|
||||
> — <a href="https://github.com/yamalight">Tim Ermilov</a>
|
||||
|
||||
> Karaoke Mugen uses Got to fetch content updates from its online server.
|
||||
>
|
||||
> — <a href="https://github.com/AxelTerizaki">Axel Terizaki</a>
|
||||
|
||||
> Renovate uses Got, gh-got and gl-got to send millions of queries per day to GitHub, GitLab, npmjs, PyPi, Packagist, Docker Hub, Terraform, CircleCI, and more.
|
||||
>
|
||||
> — <a href="https://github.com/rarkins">Rhys Arkins</a>
|
||||
|
||||
> Resistbot uses Got to communicate from the API frontend where all correspondence ingresses to the officials lookup database in back.
|
||||
>
|
||||
> — <a href="https://github.com/chris-erickson">Chris Erickson</a>
|
||||
|
||||
> Natural Cycles is using Got to communicate with all kinds of 3rd-party REST APIs (over 9000!).
|
||||
>
|
||||
> — <a href="https://github.com/kirillgroshkov">Kirill Groshkov</a>
|
||||
|
||||
> Microlink is a cloud browser as an API service that uses Got widely as the main HTTP client, serving ~22M requests a month, every time a network call needs to be performed.
|
||||
>
|
||||
> — <a href="https://github.com/Kikobeats">Kiko Beats</a>
|
||||
|
||||
> We’re using Got at Radity. Thanks for such an amazing work!
|
||||
>
|
||||
> — <a href="https://github.com/MirzayevFarid">Mirzayev Farid</a>
|
||||
Reference in New Issue
Block a user