2019-09-04 23:56:51 +02:00
|
|
|
# WebAssembly System Interface (WASI)
|
|
|
|
|
2020-04-24 18:43:06 +02:00
|
|
|
<!--introduced_in=v12.16.0-->
|
2019-09-04 23:56:51 +02:00
|
|
|
|
|
|
|
> Stability: 1 - Experimental
|
|
|
|
|
|
|
|
The WASI API provides an implementation of the [WebAssembly System Interface][]
|
|
|
|
specification. WASI gives sandboxed WebAssembly applications access to the
|
|
|
|
underlying operating system via a collection of POSIX-like functions.
|
|
|
|
|
|
|
|
```js
|
|
|
|
'use strict';
|
|
|
|
const fs = require('fs');
|
|
|
|
const { WASI } = require('wasi');
|
|
|
|
const wasi = new WASI({
|
|
|
|
args: process.argv,
|
|
|
|
env: process.env,
|
|
|
|
preopens: {
|
|
|
|
'/sandbox': '/some/real/path/that/wasm/can/access'
|
|
|
|
}
|
|
|
|
});
|
2019-12-15 16:38:58 +01:00
|
|
|
const importObject = { wasi_snapshot_preview1: wasi.wasiImport };
|
2019-09-04 23:56:51 +02:00
|
|
|
|
|
|
|
(async () => {
|
|
|
|
const wasm = await WebAssembly.compile(fs.readFileSync('./binary.wasm'));
|
|
|
|
const instance = await WebAssembly.instantiate(wasm, importObject);
|
|
|
|
|
|
|
|
wasi.start(instance);
|
|
|
|
})();
|
|
|
|
```
|
|
|
|
|
2019-12-15 17:30:45 +01:00
|
|
|
The `--experimental-wasi-unstable-preview1` and `--experimental-wasm-bigint`
|
2019-09-04 23:56:51 +02:00
|
|
|
CLI arguments are needed for the previous example to run.
|
|
|
|
|
2019-12-25 01:07:25 +01:00
|
|
|
## Class: `WASI`
|
2019-09-04 23:56:51 +02:00
|
|
|
<!-- YAML
|
2020-04-24 18:43:06 +02:00
|
|
|
added:
|
|
|
|
- v13.3.0
|
|
|
|
- v12.16.0
|
2019-09-04 23:56:51 +02:00
|
|
|
-->
|
|
|
|
|
|
|
|
The `WASI` class provides the WASI system call API and additional convenience
|
|
|
|
methods for working with WASI-based applications. Each `WASI` instance
|
|
|
|
represents a distinct sandbox environment. For security purposes, each `WASI`
|
|
|
|
instance must have its command line arguments, environment variables, and
|
|
|
|
sandbox directory structure configured explicitly.
|
|
|
|
|
2019-12-25 01:07:25 +01:00
|
|
|
### `new WASI([options])`
|
2019-09-04 23:56:51 +02:00
|
|
|
<!-- YAML
|
2020-04-24 18:43:06 +02:00
|
|
|
added:
|
|
|
|
- v13.3.0
|
|
|
|
- v12.16.0
|
2019-09-04 23:56:51 +02:00
|
|
|
-->
|
|
|
|
|
|
|
|
* `options` {Object}
|
|
|
|
* `args` {Array} An array of strings that the WebAssembly application will
|
|
|
|
see as command line arguments. The first argument is the virtual path to the
|
|
|
|
WASI command itself. **Default:** `[]`.
|
|
|
|
* `env` {Object} An object similar to `process.env` that the WebAssembly
|
|
|
|
application will see as its environment. **Default:** `{}`.
|
|
|
|
* `preopens` {Object} This object represents the WebAssembly application's
|
|
|
|
sandbox directory structure. The string keys of `preopens` are treated as
|
|
|
|
directories within the sandbox. The corresponding values in `preopens` are
|
|
|
|
the real paths to those directories on the host machine.
|
2020-03-05 02:46:02 +01:00
|
|
|
* `returnOnExit` {boolean} By default, WASI applications terminate the Node.js
|
|
|
|
process via the `__wasi_proc_exit()` function. Setting this option to `true`
|
|
|
|
causes `wasi.start()` to return the exit code rather than terminate the
|
|
|
|
process. **Default:** `false`.
|
2020-03-26 05:22:13 +01:00
|
|
|
* `stdin` {integer} The file descriptor used as standard input in the
|
|
|
|
WebAssembly application. **Default:** `0`.
|
|
|
|
* `stdout` {integer} The file descriptor used as standard output in the
|
|
|
|
WebAssembly application. **Default:** `1`.
|
|
|
|
* `stderr` {integer} The file descriptor used as standard error in the
|
|
|
|
WebAssembly application. **Default:** `2`.
|
2019-09-04 23:56:51 +02:00
|
|
|
|
2019-12-25 01:07:25 +01:00
|
|
|
### `wasi.start(instance)`
|
2019-09-04 23:56:51 +02:00
|
|
|
<!-- YAML
|
2020-04-24 18:43:06 +02:00
|
|
|
added:
|
|
|
|
- v13.3.0
|
|
|
|
- v12.16.0
|
2019-09-04 23:56:51 +02:00
|
|
|
-->
|
|
|
|
|
|
|
|
* `instance` {WebAssembly.Instance}
|
|
|
|
|
2020-04-26 07:20:10 +02:00
|
|
|
Attempt to begin execution of `instance` as a WASI command by invoking its
|
|
|
|
`_start()` export. If `instance` does not contain a `_start()` export, or if
|
|
|
|
`instance` contains an `_initialize()` export, then an exception is thrown.
|
2019-09-04 23:56:51 +02:00
|
|
|
|
|
|
|
`start()` requires that `instance` exports a [`WebAssembly.Memory`][] named
|
|
|
|
`memory`. If `instance` does not have a `memory` export an exception is thrown.
|
|
|
|
|
2020-04-26 07:20:10 +02:00
|
|
|
If `start()` is called more than once, an exception is thrown.
|
|
|
|
|
2019-12-25 01:07:25 +01:00
|
|
|
### `wasi.wasiImport`
|
2019-09-04 23:56:51 +02:00
|
|
|
<!-- YAML
|
2020-04-24 18:43:06 +02:00
|
|
|
added:
|
|
|
|
- v13.3.0
|
|
|
|
- v12.16.0
|
2019-09-04 23:56:51 +02:00
|
|
|
-->
|
|
|
|
|
|
|
|
* {Object}
|
|
|
|
|
|
|
|
`wasiImport` is an object that implements the WASI system call API. This object
|
2019-12-15 16:38:58 +01:00
|
|
|
should be passed as the `wasi_snapshot_preview1` import during the instantiation
|
|
|
|
of a [`WebAssembly.Instance`][].
|
2019-09-04 23:56:51 +02:00
|
|
|
|
|
|
|
[`WebAssembly.Instance`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WebAssembly/Instance
|
|
|
|
[`WebAssembly.Memory`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WebAssembly/Memory
|
|
|
|
[WebAssembly System Interface]: https://wasi.dev/
|