Skip to content

Commit

Permalink
Merge pull request #1410 from itowlson/exterminate-js2wasm
Browse files Browse the repository at this point in the history
Remove js2wasm from v3 docs
  • Loading branch information
itowlson authored Nov 4, 2024
2 parents 5b70d2e + 3ad02bc commit 3d06a63
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 48 deletions.
34 changes: 16 additions & 18 deletions content/spin/v3/managing-plugins.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ url = "https://github.com/fermyon/developer/blob/main/content/spin/v3/managing-p
- [Downgrading Plugins](#downgrading-plugins)
- [Next Steps](#next-steps)

Plugins are a way to extend the functionality of Spin. Spin provides commands for installing and removing them, so you don't need to use separate installation tools. When you have installed a plugin into Spin, you can call it as if it were a Spin subcommand. For example, the JavaScript SDK uses a tool called `js2wasm` to package JavaScript code into a Wasm module, and JavaScript applications run it via the `spin js2wasm` command.
Plugins are a way to extend the functionality of Spin. Spin provides commands for installing and removing them, so you don't need to use separate installation tools. When you have installed a plugin into Spin, you can call it as if it were a Spin subcommand. For example, Fermyon Cloud can be accessed with a plugin called `cloud`, and you run it via the `spin cloud` command.

## Installing Plugins

Expand All @@ -33,7 +33,7 @@ The Spin maintainers curate a catalogue of "known" plugins. You can install plug
<!-- @selectiveCpy -->

```bash
$ spin plugins install js2wasm
$ spin plugins install cloud
```

Spin checks that the plugin is available for your version of Spin and your operating system, and prompts you to confirm the installation. To skip the prompt, pass the `--yes` flag.
Expand All @@ -47,7 +47,7 @@ To install a specific version of a plugin, pass the `--version` flag:
<!-- @nocpy -->

```bash
$ spin plugins install js2wasm --version 0.4.0
$ spin plugins install cloud --version 0.9.1
```

### Installing a Plugin From a URL
Expand Down Expand Up @@ -77,7 +77,7 @@ You run plugins in the same way as built-in Spin subcommands. For example:
<!-- @selectiveCpy -->

```bash
$ spin js2wasm --help
$ spin cloud --help
```

## Viewing Available Plugins
Expand All @@ -89,8 +89,8 @@ To see what plugins are available in the catalogue, run `spin plugins search`:
```bash
$ spin plugins search
befunge2wasm 1.4.0 [incompatible]
js2wasm 0.3.0 [installed]
js2wasm 0.4.0
cloud 0.8.0 [installed]
cloud 0.9.0
trigger-sqs 0.1.0
```

Expand Down Expand Up @@ -130,13 +130,13 @@ The `spin plugins upgrade` command has the same options as the `spin plugins ins

> The `upgrade` command uses your local cache of the catalogue. This might not include recently added plugins or versions. So always remember to run `spin plugins update` to refresh your local cache of the catalogue before performing the `spin plugins upgrade` command.
The following example shows how to upgrade one plugin at a time (i.e. the `js2wasm` plugin):
The following example shows how to upgrade one plugin at a time (i.e. the `cloud` plugin):

<!-- @selectiveCpy -->

```bash
$ spin plugins update
$ spin plugins upgrade js2wasm
$ spin plugins upgrade cloud
```

The following example shows how to upgrade all installed plugins at once:
Expand All @@ -161,27 +161,25 @@ $ spin plugins upgrade --file ~/dev/spin-befunge-sdk/befunge2wasm.json

## Downgrading Plugins

By default, Spin will only _upgrade_ plugins. Pass the `--downgrade` flag and specify the `--version` if you want Spin to roll back to an earlier version. The following abridged example (which doesn't list the full console output for simplicity) lists the versions of plugins, downgrades the `js2wasm` to an older version (`0.6.0`) and then lists the versions again to show the results:
By default, Spin will only _upgrade_ plugins. Pass the `--downgrade` flag and specify the `--version` if you want Spin to roll back to an earlier version. The following abridged example (which doesn't list the full console output for simplicity) lists the versions of plugins, downgrades the `cloud` to an older version (`0.9.0`) and then lists the versions again to show the results:

<!-- @nocpy -->

```bash
$ spin plugins update
$ spin plugins list
// --snip--
js2wasm 0.6.0
js2wasm 0.6.1 [installed]
$ spin plugins upgrade js2wasm --downgrade --version 0.6.0
cloud 0.9.0
cloud 0.9.1 [installed]
$ spin plugins upgrade cloud --downgrade --version 0.9.0
$ spin plugins list
// --snip--
js2wasm 0.6.0 [installed]
js2wasm 0.6.1
cloud 0.9.0 [installed]
cloud 0.9.1
```

After downgrading, the `[installed]` indicator is aligned with the `0.6.0` version of `js2wasm`, as intended in the example.
After downgrading, the `[installed]` indicator is aligned with the `0.9.0` version of `cloud`, as intended in the example.

## Next Steps

- [Install the JavaScript or Python plugins](quickstart)
- [Use the JavaScript or Python plugins to build a Wasm module](build)
- [Checkout the spin cloud plugin](https://github.com/fermyon/cloud-plugin)
- [Check out the spin cloud plugin](https://github.com/fermyon/cloud-plugin)
15 changes: 6 additions & 9 deletions content/spin/v3/plugin-authoring.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ Spin plugins add new functionality or subcommands to Spin without modifying the
Spin codebase. They make Spin easily extensible while keeping it lightweight.
Spin plugins can add new triggers to Spin (such as the [example timer
trigger](https://github.com/fermyon/spin/blob/main/examples/spin-timer/trigger-timer.json)),
enable new language SDKs (such as
[`js2wasm`](https://github.com/fermyon/spin-plugins/blob/main/manifests/js2wasm/js2wasm.json)),
add deployment integrations (such as
[`kube`](https://github.com/fermyon/spin-plugins/blob/main/manifests/kube/kube.json)),
and more.

This document will cover what Spin plugins are, how to use a plugin, and how to
Expand All @@ -46,19 +46,16 @@ and creates a local snapshot. To ensure that the local snapshot is up to date,
it is best to run `spin plugins update` before installing any plugins.

To list available plugins, run `spin plugins search`. Now, decide which plugin to
install. For example, the `js2wasm` plugin, which is needed in order to build
JavaScript Spin applications, can be installed by running:
install. For example, the `kube` plugin, which is needed in order to deploy
applications to [SpinKube](https://www.spinkube.dev/), can be installed by running:

<!-- @selectiveCpy -->

```bash
$ spin plugins install js2wasm
$ spin plugins install kube
```

With the plugin installed, you can now call `spin js2wasm` to run it. In this
case, for example, you might call it from your JavaScript application's npm
build script. Learn more about building Spin components in JavaScript
[here](./javascript-components.md).
With the plugin installed, you can now call `spin kube` to run it.

To upgrade installed plugins to newer versions, run `spin plugin update` to
fetch the latest plugins to the local catalogue and `spin plugin upgrade` to perform the
Expand Down
29 changes: 8 additions & 21 deletions content/spin/v3/quickstart.md
Original file line number Diff line number Diff line change
Expand Up @@ -194,16 +194,7 @@ $ rustup target add wasm32-wasi

{{ startTab "TypeScript" }}

> If you used the installer script above, the `js2wasm` plugin is already installed, and you can skip this section!
You'll need the Spin `js2wasm` plugin:

<!-- @selectiveCpy -->

```bash
$ spin plugins update
$ spin plugins install js2wasm --yes
```
You will need `npm` installed and on the path. `npm` will install any additional build tools as part of building the application.

[Learn more in the language guide.](javascript-components)

Expand Down Expand Up @@ -410,18 +401,15 @@ Now let's have a look at the code. Below is the complete source
code for a Spin HTTP component written in TypeScript — a regular function named `handleRequest` that
takes an HTTP request as a parameter and returns an HTTP response. (The
JavaScript version looks slightly different, but is still a function with
the same signature.) The Spin `js2wasm` plugin looks for the `handleRequest` function
the same signature.) The Spin integration looks for the `handler` function
by name when building your application into a Wasm module:

```javascript
import { HandleRequest, HttpRequest, HttpResponse } from "@fermyon/spin-sdk"

export const handleRequest: HandleRequest = async function (request: HttpRequest): Promise<HttpResponse> {
return {
status: 200,
headers: { "content-type": "text/plain" },
body: "Hello from TS-SDK"
}
import { ResponseBuilder } from "@fermyon/spin-sdk";

export async function handler(req: Request, res: ResponseBuilder) {
console.log(req);
res.send("hello universe");
}
```

Expand Down Expand Up @@ -743,7 +731,7 @@ $ spin build
Executing the build command for component hello-typescript: npm run build

> hello-typescript@1.0.0 build
> npx webpack --mode=production && mkdir -p target && spin js2wasm -o target/spin-http-js.wasm dist/spin.js
> npx webpack --mode=production && npx mkdirp target && npx j2w -i dist.js -d combined-wit -n combined -o target/hello-typescript.wasm

asset spin.js 4.57 KiB [emitted] (name: main)
runtime modules 670 bytes 3 modules
Expand All @@ -761,7 +749,6 @@ If the build fails, check:

* Are you in the `hello_typescript` directory?
* Did you run `npm install` before building`?
* Did you install the `js2wasm` plugin?

If you would like to know what build command Spin runs for a component, you can find it in the manifest, in the `component.(id).build` section:

Expand Down

0 comments on commit 3d06a63

Please sign in to comment.