Skip to content

Commit

Permalink
MQTT API
Browse files Browse the repository at this point in the history
Signed-off-by: itowlson <[email protected]>
  • Loading branch information
itowlson committed Mar 26, 2024
1 parent 4bf6839 commit 869cde6
Show file tree
Hide file tree
Showing 4 changed files with 103 additions and 0 deletions.
1 change: 1 addition & 0 deletions content/spin/v2/api-guides-overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,5 +20,6 @@ The following table shows the status of the interfaces Spin provides to applicat
| [Key-value Storage](./kv-store-api-guide) | Stabilizing | Yes |
| [Serverless AI](./serverless-ai-api-guide) | Experimental | Yes |
| [SQLite Storage](./sqlite-api-guide) | Experimental | Yes |
| [MQTT Messaging](./mqtt-outbound) | Experimental | No |

For more information about what is possible in the programming language of your choice, please see our [Language Support Overview](./language-support-overview).
4 changes: 4 additions & 0 deletions content/spin/v2/language-support-overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ This page contains information about language support for Spin features:
| [PostgreSQL](./rdbms-storage#using-mysql-and-postgresql-from-applications) | Supported |
| [Outbound Redis](./rust-components.md#storing-data-in-redis-from-rust-components) | Supported |
| [Serverless AI](./serverless-ai-api-guide) | Supported |
| [MQTT Messaging](./mqtt-outbound) | Supported |
| **Extensibility** |
| [Authoring Custom Triggers](./extending-and-embedding) | Supported |

Expand All @@ -52,6 +53,7 @@ This page contains information about language support for Spin features:
| [PostgreSQL](./rdbms-storage#using-mysql-and-postgresql-from-applications) | Supported |
| [Outbound Redis](./javascript-components#storing-data-in-redis-from-jsts-components) | Supported |
| [Serverless AI](./serverless-ai-api-guide) | Supported |
| [MQTT Messaging](./mqtt-outbound) | Not Supported |
| **Extensibility** |
| Authoring Custom Triggers | Not Supported |

Expand All @@ -75,6 +77,7 @@ This page contains information about language support for Spin features:
| PostgreSQL | Supported |
| [Outbound Redis](./python-components#an-outbound-redis-example) | Supported |
| [Serverless AI](./serverless-ai-api-guide) | Supported |
| [MQTT Messaging](./mqtt-outbound) | Not Supported |
| **Extensibility** |
| Authoring Custom Triggers | Not Supported |

Expand All @@ -98,6 +101,7 @@ This page contains information about language support for Spin features:
| [PostgreSQL](./rdbms-storage#using-mysql-and-postgresql-from-applications) | Supported |
| [Outbound Redis](./go-components#storing-data-in-redis-from-go-components) | Supported |
| [Serverless AI](./serverless-ai-api-guide) | Supported |
| [MQTT Messaging](./mqtt-outbound) | Not Supported |
| **Extensibility** |
| Authoring Custom Triggers | Not Supported |

Expand Down
95 changes: 95 additions & 0 deletions content/spin/v2/mqtt-outbound.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
title = "MQTT Messaging"
template = "spin_main"
date = "2023-11-04T00:00:01Z"
enable_shortcodes = true
[extra]
url = "https://github.com/fermyon/developer/blob/main/content/spin/v2/mqtt-outbound.md"

---
- [Sending MQTT Messages From Applications](#sending-mqtt-messages-from-applications)
- [Granting Network Permissions to Components](#granting-network-permissions-to-components)
- [Configuration-Based Permissions](#configuration-based-permissions)
- [Known Issues](#known-issues)

Spin provides an experimental interface for you to send messages using the MQTT protocol.

{{ details "Why do I need a Spin interface? Why can't I just use my language's MQTT library?" "Few MQTT libraries have been updated to work over the WASI 0.2 sockets interface. The Spin interface means Wasm modules can bypass this limitation by asking Spin to make the MQTT connection on their behalf." }}

> Want to receive MQTT messages? Use [the MQTT trigger](https://github.com/spinkube/spin-trigger-mqtt) to handle messages in your Spin application.
## Sending MQTT Messages From Applications

The Spin SDK surfaces the Spin MQTT interface to your language. The set of operations defined in Spin's API is as follows:

| Operation | Parameters | Returns | Behavior |
|--------------|---------------------|---------|----------|
| `open` | address, username, password, keep-alive | connection resource | Opens a connection to the specified MQTT server. The host must be listed in `allowed_outbound_hosts`. Other operations must be called through a connection. |
| `publish` | topic, payload, QoS | - | Publishes the payload (a binary blob) as a message to the specified topic. |

The exact detail of calling these operations from your application depends on your language:

{{ tabs "sdk-type" }}

{{ startTab "Rust"}}

> [**Want to go straight to the reference documentation?** Find it here.](https://docs.rs/spin-sdk/latest/spin_sdk/mqtt/index.html)
MQTT functions are available in the `spin_sdk::mqtt` module.

To access an MQTT server, use the `Connection::open` function.

```rust
let connection = spin_sdk::mqtt::Connection::open(&address, &username, &password, keep_alive_secs)?;
```

You can then call the `Connection::publish` function to send MQTT messages:

```rust
let cat_picture: Vec<u8> = request.body().to_vec();
connection.publish("pets", &cat_picture, spin_sdk::mqtt::Qos::AtLeastOnce)?;
```

For full details of the MQTT API, see the [Spin SDK reference documentation](https://docs.rs/spin-sdk/latest/spin_sdk/mqtt/index.html);

You can find a complete Rust code example for using outbound MQTT from an HTTP component in the [Spin Rust SDK repository on GitHub](https://github.com/fermyon/spin-rust-sdk/tree/main/examples/mqtt-outbound).

{{ blockEnd }}

{{ startTab "TypeScript"}}

MQTT is not available in the current version of the JavaScript/TypeScript SDK.

{{ blockEnd }}

{{ startTab "Python"}}

MQTT is not available in the current version of the Python SDK.

{{ blockEnd }}

{{ startTab "TinyGo"}}

MQTT is not available in the current version of the Go SDK.

{{ blockEnd }}

{{ blockEnd }}

## Granting Network Permissions to Components

By default, Spin components are not allowed to make outgoing network requests, including MQTT. This follows the general Wasm rule that modules must be explicitly granted capabilities, which is important to sandboxing. To grant a component permission to make network requests to a particular host, use the `allowed_outbound_hosts` field in the component manifest, specifying the host and allowed port:

```toml
[component.uses-mqtt]
allowed_outbound_hosts = ["mqtt://messaging.example.com:1883"]
```

### Configuration-Based Permissions

You can use [application variables](./variables.md#adding-variables-to-your-applications) in the `allowed_outbound_hosts` field. However, this feature is not yet available on Fermyon Cloud.

## Known Issues

The MQTT API is experimental and subject to change. The following issues are known:

* The MQTT sender interface in the current version of Spin is known to occasionally drop errors, especially if under load. A fix is in progress.
3 changes: 3 additions & 0 deletions templates/spin_sidebar_v2.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,9 @@
href="{{site.info.base_url}}/spin/v2/kv-store-api-guide">Key
Value
Store</a></li>
<li><a {{#if (active_project request.spin-full-url "/spin/v2/mqtt-outbound" )}} class="active"
{{/if}} href="{{site.info.base_url}}/spin/v2/mqtt-outbound">MQTT Messaging</a>
</li>
<li><a {{#if (active_project request.spin-full-url "/spin/v2/serverless-ai-api-guide" )}}
class="active" {{/if}}
href="{{site.info.base_url}}/spin/v2/serverless-ai-api-guide">Serverless
Expand Down

0 comments on commit 869cde6

Please sign in to comment.