This is a demonstration project for using WebAssembly to sandbox untrusted code with minimal overhead.
The site is designed to allow anyone to uploaded their own bot to play rock-paper-scissors in multiple different programming languages. The bots are run in WebAssembly for sandboxing, and do not rely on OS-level sandboxing or separate processes.
You'll need node and yarn for the frontend client code. See: Installing Node and Installing Yarn
For the backend server, you'll need a Rust toolchain and Postgres installed. See Installing Rust and Cargo and Installing Postgres
The UI code is stored in the client
folder. It's a fairly standard React/TypeScript app.
Install dependencies:
cd client
yarn
To run the development server:
yarn start
This should automatically open a browser window at http://localhost:3000/
.
The client code isn't very useful without the server and database behind it.
The client devserver is configured to proxy to localhost:3001
for server requests (the default) so you can develop the client and server at the same time, despite the client running as a separate webserver.
Create a fresh postgres DB called snippy
createdb snippy
Then there's a script to create the necessary tables and populate it with some sample bots.
NOTE: This will also create a database user called snippyuser
with login and (insecure) password.
This is for local development only.
psql snippy < ./wasi-runner/local_setup.sql
In the wasi-runner
folder, create a file called .env
with the following contents.
DB_PASSWORD="snippy123"
Note: You can also set DB_HOST
, DB_PORT
and DB_USER
but they default to localhost:5432
and snippyuser
if not specified.
In a separate terminal to the client devserver, go to the wasi-runner
folder and run cargo run
.
cd wasi-runner
cargo run
This will start the server on port 3001, the client devserver is set up to proxy API calls to this port.
The server may take about 15 seconds (or more depending on your machine) to start up because it loads the wasm engine and modules before starting the http server.
Check that the server is running correctly by visiting http://localhost:3001/ in the browser. If that loads, then the UI should also be able to run bots and tournaments via the API.
Run:
docker compose -f docker-compose.yaml up
If there were changes after the initial build, you can rebuild the image with:
docker compose -f docker-compose.yaml up --build