| 1 | import { ThreadWorker } from 'poolifier' |
| 2 | import nodeFetch, { |
| 3 | type RequestInfo as NodeFetchRequestInfo, |
| 4 | type ResponseInit as NodeFetchRequestInit |
| 5 | } from 'node-fetch' |
| 6 | import axios from 'axios' |
| 7 | import { type WorkerData, type WorkerResponse } from './types.js' |
| 8 | |
| 9 | class HttpClientWorker extends ThreadWorker<WorkerData, WorkerResponse> { |
| 10 | public constructor () { |
| 11 | super({ |
| 12 | node_fetch: async (workerData?: WorkerData) => { |
| 13 | const response = await nodeFetch( |
| 14 | (workerData as WorkerData).input as URL | NodeFetchRequestInfo, |
| 15 | workerData?.init as NodeFetchRequestInit |
| 16 | ) |
| 17 | // The response is not structured-cloneable, so we return the response text body instead. |
| 18 | return { |
| 19 | text: await response.text() |
| 20 | } |
| 21 | }, |
| 22 | fetch: async (workerData?: WorkerData) => { |
| 23 | const response = await fetch( |
| 24 | (workerData as WorkerData).input as URL | RequestInfo, |
| 25 | workerData?.init as RequestInit |
| 26 | ) |
| 27 | // The response is not structured-cloneable, so we return the response text body instead. |
| 28 | return { |
| 29 | text: await response.text() |
| 30 | } |
| 31 | }, |
| 32 | axios: async (workerData?: WorkerData) => { |
| 33 | const response = await axios({ |
| 34 | method: 'get', |
| 35 | url: (workerData as WorkerData).input as string, |
| 36 | ...workerData?.axiosRequestConfig |
| 37 | }) |
| 38 | return { |
| 39 | text: response.data |
| 40 | } |
| 41 | } |
| 42 | }) |
| 43 | } |
| 44 | } |
| 45 | |
| 46 | export const httpClientWorker = new HttpClientWorker() |