https://github.com/kaciras/fetch-socks
Socks proxy for Node builtin `fetch`
https://github.com/kaciras/fetch-socks
fetch proxy socks undici
Last synced: about 1 month ago
JSON representation
Socks proxy for Node builtin `fetch`
- Host: GitHub
- URL: https://github.com/kaciras/fetch-socks
- Owner: Kaciras
- License: mit
- Created: 2022-11-28T11:43:21.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2025-04-01T15:47:57.000Z (about 2 months ago)
- Last Synced: 2025-04-02T06:09:26.302Z (about 2 months ago)
- Topics: fetch, proxy, socks, undici
- Language: TypeScript
- Homepage:
- Size: 729 KB
- Stars: 35
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# fetch-socks
[](https://npmjs.com/package/fetch-socks)
[](https://github.com/Kaciras/fetch-socks/actions/workflows/test.yml)
[](https://codecov.io/gh/Kaciras/fetch-socks)
[](https://github.com/plantain-00/type-coverage)Socks proxy for Node builtin (also [undici](https://github.com/nodejs/undici)) `fetch`.
```shell
npm install fetch-socks
```# Usage Examples
Fetch `http://example.com` through `socks5://[::1]:1080`.
```javascript
import { socksDispatcher } from "fetch-socks";const dispatcher = socksDispatcher({
type: 5,
host: "::1",
port: 1080,//userId: "username",
//password: "password",
});const response = await fetch("http://example.com", { dispatcher });
console.log(response.status);
console.log(await response.text());
```Set the proxy globally.
```javascript
import { socksDispatcher } from "fetch-socks";const dispatcher = socksDispatcher({ /* ... */});
global[Symbol.for("undici.globalDispatcher.1")] = dispatcher;
````TypeScript example, fetch through proxy chain with two SOCKS proxies.
```typescript
import { fetch } from "undici";
import { socksDispatcher, SocksProxies } from "fetch-socks";const proxyConfig: SocksProxies = [{
type: 5,
host: "::1",
port: 1080,
}, {
type: 5,
host: "127.0.0.1",
port: 1081,
}];const dispatcher = socksDispatcher(proxyConfig, {
connect: {
// set some TLS options
rejectUnauthorized: false,
},
});const response = await fetch("https://example.com", { dispatcher });
```create a socks connection over HTTP tunnel with `socksConnector`.
```javascript
import { Client, Agent } from "undici";
import { socksConnector } from "fetch-socks";const socksConnect = socksConnector({
type: 5,
host: "::1",
port: 1080,
});async function connect(options, callback) {
// First establish a connection to the HTTP proxy server (localhost:80).
const client = new Client("http://localhost:80");
const { socket, statusCode } = await client.connect({
// Tell the server to connect to the next ([::1]:1080)
path: "[::1]:1080",
});
if (statusCode !== 200) {
callback(new Error("Proxy response !== 200 when HTTP Tunneling"));
} else {
// Perform socks handshake on the connection.
socksConnect({ ...options, httpSocket: socket }, callback);
}
}const dispatcher = new Agent({ connect });
const response = await fetch("https://example.com", { dispatcher });
```# API
## `socksConnector(proxies, connectOptions?)`
Create an [Undici connector](https://undici.nodejs.org/#/docs/api/Connector) which establish the connection through socks proxies.
* `proxies` The proxy server to use or the list of proxy servers to chain. If you pass an empty array it will connect directly.
* `connectOptions` (optional) The options used to perform directly connect or TLS upgrade, see [here](https://undici.nodejs.org/#/docs/api/Connector?id=parameter-buildconnectorbuildoptions)## `socksDispatcher(proxies, options?)`
Create a Undici Agent with socks connector.
* `proxies` Same as `socksConnector`'s.
* `options` (optional) [Agent options](https://undici.nodejs.org/#/docs/api/Agent). The `connect` property will be used to create socks connector.```javascript
import { socksConnector, socksDispatcher } from "fetch-socks";
import { Agent } from "undici";const proxy = { type: 5, host: "::1", port: 1080 };
const connect = { /* ... */ };
const agentOptions = { /* ... */ };socksDispatcher(proxy, { ...agentOptions, connect });
// Is equivalent to
new Agent({ ...agentOptions, connect: socksConnector(proxy, connect) });
```