Skip to content

sbergen/spoke

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

spoke

Package Version Hex Docs

Spoke is a MQTT 3.1.1 client written in Gleam for the Erlang runtime.

Example usage:

gleam add spoke
gleam add spoke_tcp
import gleam/erlang/process
import gleam/int
import gleam/io
import gleam/string
import spoke
import spoke/tcp

pub fn main() {
  let client_id = "spoke" <> string.inspect(int.random(999_999_999))
  let topic = "spoke-test"

  let client =
    tcp.connector_with_defaults("test.mosquitto.org")
    |> spoke.connect_with_id(client_id)
    |> spoke.start_session

  spoke.connect(client, True)

  let assert Ok(_) =
    spoke.subscribe(client, [spoke.SubscribeRequest(topic, spoke.AtLeastOnce)])

  let message =
    spoke.PublishData(
      topic,
      <<"Hello from spoke!">>,
      spoke.AtLeastOnce,
      retain: False,
    )
  spoke.publish(client, message)

  let updates = spoke.updates(client)

  let assert Ok(spoke.ConnectionStateChanged(spoke.ConnectAccepted(_))) =
    process.receive(updates, 1000)

  let message = process.receive(updates, 1000)
  io.println(string.inspect(message))

  spoke.disconnect(client)
}

This should print the following, assuming test.mosquitto.org is up (it's not rare for it to be down):

Ok(ReceivedMessage("spoke-test", "Hello from spoke!", False))

Design choices

Spoke aspires to be as high-level as possible, without being opinionated. This means that the only things you'll need to handle yourself are persistent session management and re-connections. If you don't care about persistent sessions or overloading the server, simply cleaning the session on each connect and immediately reconnecting on unexpected disconnects should give you a reliable client.

Transport channels

The core spoke package is transport channel agnostic. At the time of writing, spoke_tcp is the only implementation of transport channels for spoke. Instead of using spoke_tcp, you can also bring your own transport channel. See TransportChannelConnector for the required functions to make this work.

If you'd have use for a WebSocket channel, please leave a feature request, and I might implement it.

About

MQTT Client implemented in Gleam ๐Ÿ›ž

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages