An open API service indexing awesome lists of open source software.

https://github.com/idimetrix/fetch-with-proxy

fetch-with-proxy is an Axios-based utility that adds proxy support to HTTP(S) requests. It manages network issues and timeouts via a specified proxy, with options for retry count, delay, backoff strategies, and error handling, improving reliability.
https://github.com/idimetrix/fetch-with-proxy

Last synced: 5 months ago
JSON representation

fetch-with-proxy is an Axios-based utility that adds proxy support to HTTP(S) requests. It manages network issues and timeouts via a specified proxy, with options for retry count, delay, backoff strategies, and error handling, improving reliability.

Awesome Lists containing this project

README

          

# fetch-with-proxy3 (axios-based)
fetch-with-proxy3 is a utility function built on top of the Axios library, designed to make HTTP(S) requests with automatic retry logic. When a request fails due to issues like network errors, timeouts, or specific status codes, it retries the operation a set number of times. It can be customized with options like retry count, delay between retries, backoff strategies, and error handling, leveraging Axios' capabilities while enhancing reliability in unstable network environments.

### Options

```
function fetchWithProxy(
url: string, // URL
options?: AxiosRequestConfig, // Options (axios based)
proxies: Proxy[] = [], // Proxies: http, https, socks4, socks5
attempts: number = 3, // Number of attempts
delay: number = 1500, // Delay in milliseconds
timeout: number = 30 * 1000, // Timeout in milliseconds
): Promise & { ok: boolean; error?: Error }>
```

### GET example
``` GET
import { fetchWithProxy } from 'fetch-with-proxy3';

const result = await fetchWithProxy('https://api.example.com/data', {
method: 'GET',
});

if (result.ok) {
console.log('GET Request Success:', result.data);
} else {
console.error('GET Request Failed:', result.error);
}
```

### POST example
``` POST
import { fetchWithProxy } from 'fetch-with-proxy3';

const result = await fetchWithProxy('https://api.example.com/data', {
method: 'POST',
data: { key: 'value' }, // Example payload
headers: { 'Content-Type': 'application/json' },
});

if (result.ok) {
console.log('POST Request Success:', result.data);
} else {
console.error('POST Request Failed:', result.error);
}
```

## tsup
Bundle your TypeScript library with no config, powered by esbuild.

https://tsup.egoist.dev/

## How to use this
1. install dependencies
```
# pnpm
$ pnpm install

# yarn
$ yarn install

# npm
$ npm install
```
2. Add your code to `src`
3. Add export statement to `src/index.ts`
4. Test build command to build `src`.
Once the command works properly, you will see `dist` folder.

```zsh
# pnpm
$ pnpm run build

# yarn
$ yarn run build

# npm
$ npm run build
```
5. Publish your package

```zsh
$ npm publish
```

## test package
https://www.npmjs.com/package/fetch-with-proxy3