Sem descrição

zinobias 3052faddb5 serviceworker.js: Adjusted a comment in, to clarify the ifstatement in doRegister(). há 2 anos atrás
assets 3f3035d581 README: Add image há 2 anos atrás
examples 512332d439 Initial commit há 3 anos atrás
tun 8a3da023d1 Use new network classes from tailscale_tun há 2 anos atrás
xterm 0a1d4a8602 Remove xterm's SourceMap warnings há 2 anos atrás
README.md 15d2c5298a Add information about self-hosting to README há 2 anos atrás
favicon.ico a925d0ae89 New favicon: red tower on black background há 2 anos atrás
index.html 21ca588a34 Serviceworker with primary goal to add COI when unsupported. há 2 anos atrás
login.html 0d37154516 Revert "Experimental function calling across tabs" há 2 anos atrás
network.js 8a3da023d1 Use new network classes from tailscale_tun há 2 anos atrás
nginx.conf 512332d439 Initial commit há 3 anos atrás
scrollbar.css e71bbc97a5 Scrollbar há 2 anos atrás
serviceWorker.js 3052faddb5 serviceworker.js: Adjusted a comment in, to clarify the ifstatement in doRegister(). há 2 anos atrás
tinycore.html 21ca588a34 Serviceworker with primary goal to add COI when unsupported. há 2 anos atrás
tower.ico 9977f694c8 Move favicon to red tower on black background há 2 anos atrás

README.md

WebVM

This repository hosts the source code of for https://webvm.io, a Linux virtual machine that runs in your browser.

WebVM is a server-less virtual environment running fully client-side in HTML5/WebAssembly. It's designed to be Linux ABI-compatible. It runs an unmodified Debian distribution including many native development toolchains.

WebVM is powered by the CheerpX virtualization engine, and enables safe, sandboxed client-side execution of x86 binaries on any browser. CheerpX includes an x86-to-WebAssembly JIT compiler, a virtual block-based file system, and a Linux syscall emulator.

How to: general usage

How to: enable networking

  • go to https://webvm.io
  • click "Tailscale Login" in the top right corner
  • log in to Tailscale (create an accout if you don't have one)
  • if you want to access the public internet, you need an Exit Node. See here for how to set one up. If you just want to access a machine in your Tailscale Network, you don't need it
  • depending on your network speed, you may need to wait a few moments for the Tailscale Wasm module to be downloaded
  • log in with your Tailscale credentials
  • go back to the WebVM tab. You will see your IP address in the top right
  • start firing network requests!

How to: login to Tailscale with an Auth key

  • Add #authKey=<your-key> at the end of the URL
  • Done. You don't need to manually log in anymore

It is recommended to use an ephemeral key.

How to: login to a self-hosted Tailscale network (Headscale)

  • Add #controlUrl=<your-control-url> at the end of the URL
  • You can combine this option with authKey with a &: #controlUrl=<url>&authKey=<key>

How to host WebVM locally

  • Replace CX_VERSION in index.html and tinycore.html with a valid version of CheerpX. The latest version can be found at https://webvm.io
  • Run nginx -p . -c nginx.conf in the root of the WebVM directory. WebVM can then be found at http://localhost:8081

Bugs and Issues

Please use Issues to report any bug. Or come to say hello / share your feedback on Discord.

Browsers support

WebVM and CheerpX are compatible with any browser, both Desktop and Mobile, provided support for SAB, IndexedDB, and the device having enough memory.

More links

Thanks to...

This project depends on:

License

Copyright (c) Leaning Technologies Limited. All rights reserved.