From 0b6f2af77b75822721046be319e73d74f32aee7d Mon Sep 17 00:00:00 2001 From: Vlad Frangu Date: Mon, 11 Dec 2023 14:35:02 +0200 Subject: [PATCH] fix: correct types for got scraping --- CHANGELOG.md | 5 +++ package.json | 2 +- src/context.ts | 6 ++- src/resolve-protocol.ts | 2 +- src/types.ts | 88 +++++++++++++++++++++++++++++++++++++---- 5 files changed, 91 insertions(+), 12 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8b86ec1..7e7aa4d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,8 @@ +4.0.3 / 2023/12/11 +==================== +- Fixed missing extended types for `gotScraping.stream` and `gotScraping.paginate` +- Fixed general type issues with `got-scraping`, including not reporting incorrect types for known properties like `proxyUrl` + 4.0.2 / 2023/11/29 ==================== - Fixed runtime exceptions when using `got-scraping` in a project with older versions of node.js 16 diff --git a/package.json b/package.json index 75b3a06..b03de03 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "got-scraping", - "version": "4.0.2", + "version": "4.0.3", "description": "HTTP client made for scraping based on got.", "engines": { "node": ">=16" diff --git a/src/context.ts b/src/context.ts index bfcf7be..ab8fd28 100644 --- a/src/context.ts +++ b/src/context.ts @@ -2,13 +2,15 @@ import type { OptionsInit as GotOptionsInit } from 'got'; export type { GotOptionsInit }; -export interface Context extends Record { +export interface Context { proxyUrl?: string; headerGeneratorOptions?: Record; useHeaderGenerator?: boolean; headerGenerator?: { getHeaders: (options: Record) => Record }; insecureHTTPParser?: boolean; sessionToken?: object; + /** @private */ + sessionData?: unknown; } -export interface OptionsInit extends Context, GotOptionsInit {} +export type OptionsInit = GotOptionsInit & Context; diff --git a/src/resolve-protocol.ts b/src/resolve-protocol.ts index 6d31fb3..1e03998 100644 --- a/src/resolve-protocol.ts +++ b/src/resolve-protocol.ts @@ -68,7 +68,7 @@ const createCaches = () => ({ const defaults = createCaches(); -interface ProtocolCache { +export interface ProtocolCache { protocolCache?: typeof defaults.protocolCache; resolveAlpnQueue?: typeof defaults.resolveAlpnQueue; } diff --git a/src/types.ts b/src/types.ts index 4e7fe61..8c5485b 100644 --- a/src/types.ts +++ b/src/types.ts @@ -1,10 +1,10 @@ -import type { CancelableRequest, ExtendOptions, Got, HTTPAlias, Options, Request, Response } from 'got'; +import type { CancelableRequest, ExtendOptions, Got, HTTPAlias, Options, PaginateData, PaginationOptions, Request, Response } from 'got'; import type { OptionsInit } from './context.js'; type Except = Pick>; type Merge = Except> & SecondType; -export interface ExtendedGotRequestFunction { +export type ExtendedGotRequestFunction = { (url: string | URL, options?: ExtendedOptionsOfTextResponseBody): CancelableRequest>; (url: string | URL, options?: ExtendedOptionsOfJSONResponseBody): CancelableRequest>; (url: string | URL, options?: ExtendedOptionsOfBufferResponseBody): CancelableRequest>; @@ -28,13 +28,13 @@ export interface ExtendedGotRequestFunction { (url: string | URL, options?: OptionsInit): CancelableRequest | Request; (options: OptionsInit): CancelableRequest | Request; (url: undefined, options: undefined, defaults: Options): CancelableRequest | Request; -} +}; export type ExtendedOptionsOfTextResponseBody = Merge +}>; export type ExtendedOptionsOfJSONResponseBody = Merge) => Request) & ((options?: Merge) => Request); + export type ExtendedExtendOptions = ExtendOptions & OptionsInit; -export interface GotScraping extends Record, ExtendedGotRequestFunction { - stream: Got['stream']; - paginate: Got['paginate']; +export type ExtendedGotStream = ExtendedGotStreamFunction & Record; + +export type ExtendedPaginationOptions = PaginationOptions & { + paginate?: (data: PaginateData) => OptionsInit | false; +}; + +export type ExtendedOptionsWithPagination = Merge; +}>; + +export type ExtendedGotPaginate = { + /** + Same as `GotPaginate.each`. + */ + (url: string | URL, options?: ExtendedOptionsWithPagination): AsyncIterableIterator; + /** + Same as `GotPaginate.each`. + */ + (options?: ExtendedOptionsWithPagination): AsyncIterableIterator; + /** + Returns an async iterator. + + See pagination.options for more pagination options. + + @example + ``` + import { gotScraping } from 'got-scraping'; + + const countLimit = 10; + + const pagination = gotScraping.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: ((url: string | URL, options?: ExtendedOptionsWithPagination) => AsyncIterableIterator) + & ((options?: ExtendedOptionsWithPagination) => AsyncIterableIterator); + /** + Returns a Promise for an array of all results. + + See pagination.options for more pagination options. + + @example + ``` + import { gotScraping } from 'got-scraping'; + + const countLimit = 10; + + const results = await gotScraping.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: ((url: string | URL, options?: ExtendedOptionsWithPagination) => Promise) + & ((options?: ExtendedOptionsWithPagination) => Promise); +}; + +export type GotScraping = { + stream: ExtendedGotStream; + paginate: ExtendedGotPaginate; defaults: Got['defaults']; extend: (...instancesOrOptions: Array) => GotScraping; -} +} & Record & ExtendedGotRequestFunction;