An encrypted proxy for browser javascript http://epoxy.r58playz.dev/
Find a file
2024-07-17 16:23:58 -07:00
.cargo tests 2024-03-23 10:05:17 -07:00
certs-grabber add a new Payload struct to allow for one-copy writes and cargo fmt 2024-07-17 16:23:58 -07:00
client add a new Payload struct to allow for one-copy writes and cargo fmt 2024-07-17 16:23:58 -07:00
server add a new Payload struct to allow for one-copy writes and cargo fmt 2024-07-17 16:23:58 -07:00
simple-wisp-client add a new Payload struct to allow for one-copy writes and cargo fmt 2024-07-17 16:23:58 -07:00
wisp add a new Payload struct to allow for one-copy writes and cargo fmt 2024-07-17 16:23:58 -07:00
.envrc nixification 2024-01-09 19:46:05 -08:00
.gitignore add a minimal build 2024-07-03 11:04:02 -07:00
Cargo.lock remove tower from deps 2024-07-13 22:30:47 -07:00
Cargo.toml call wisp v2 extension packet handlers 2024-04-12 17:18:56 -07:00
flake.lock nixification 2024-01-09 19:46:05 -08:00
flake.nix nixification 2024-01-09 19:46:05 -08:00
README.md readme 2024-06-28 06:35:02 -07:00
rustfmt.toml fix the parking-lot issue 2024-07-08 17:12:25 -07:00

epoxy

Epoxy is an encrypted proxy for browser javascript. It allows you to make requests that bypass CORS without compromising security, by running SSL/TLS inside webassembly.

Using the client

Epoxy must be run from within a web worker and must be served with the security headers needed for SharedArrayBuffer. Here is a simple usage example:

import epoxy from "./epoxy-module-bundled.js";
import ROOTS from "./pkg/certs-module.js";
// or
// importScripts("epoxy-bundled.js");
// importScripts("certs.js");

const { EpoxyClient, EpoxyClientOptions } = await epoxy();

let options = new EpoxyClientOptions();
options.user_agent = navigator.userAgent;

let client = await new EpoxyClient("wss://localhost:4000", ROOTS, options);

let response = await client.fetch("https://httpbin.org/get");
console.log(await response.text());

See client/demo.js for more examples.

Using the server

$ cargo r -r --bin epoxy-server -- --help
Implementation of the Wisp protocol in Rust, made for epoxy.

Usage: epoxy-server [OPTIONS]

Options:
      --prefix <PREFIX>  [default: ]
  -p, --port <PORT>      [default: 4000]
  -b, --host <HOST>      [default: 0.0.0.0]
  -u, --unix-socket      
  -h, --help             Print help
  -V, --version          Print version

You can listen on a unix socket by passing the --unix-socket flag and the unix socket path in the --host flag. Example:

cargo r -r -- -u -b "/home/user/epoxy-socket"

Building

Important

Rust nightly is required.

Server

cargo b -r --bin epoxy-server

The executable will be placed at target/release/epoxy-server.

Client

Important

Building the client is only supported on Linux.

Make sure you have the wasm32-unknown-unknown rust target, the rust-std component, and the wasm-bindgen, wasm-opt, and base64 binaries installed.

In the client directory:

bash build.sh

To host a local server with the required headers:

python3 serve.py