try mutiple dummies

This commit is contained in:
Travis Shears 2026-03-24 19:34:40 +01:00
parent 86e40f90a1
commit 1f4942726e
Signed by: travisshears
GPG key ID: CB9BF1910F3F7469
2 changed files with 86 additions and 26 deletions

47
src/mqtt.gleam Normal file
View file

@ -0,0 +1,47 @@
import config
import gleam/erlang/process
import gleam/int
import gleam/io
import gleam/option.{None}
import gleam/string
import spoke/mqtt
import spoke/mqtt_actor
import spoke/tcp
pub fn start(cfg: config.Config) {
let client_id = cfg.mqtt_client_id
let topic = "spoke-test"
let assert Ok(started) =
tcp.connector_with_defaults(cfg.mqtt_host)
|> mqtt.connect_with_id(client_id)
|> mqtt_actor.build()
|> mqtt_actor.start(100)
let client = started.data
let updates = process.new_subject()
mqtt_actor.subscribe_to_updates(client, updates)
mqtt_actor.connect(client, True, None)
let assert Ok(mqtt.ConnectionStateChanged(mqtt.ConnectAccepted(_))) =
process.receive(updates, 5000)
let assert Ok(_) =
mqtt_actor.subscribe(client, [
mqtt.SubscribeRequest(topic, mqtt.ExactlyOnce),
])
let message =
mqtt.PublishData(
topic,
<<"Hello from spoke!">>,
mqtt.AtLeastOnce,
retain: False,
)
mqtt_actor.publish(client, message)
let message = process.receive(updates, 1000)
io.println(string.inspect(message))
mqtt_actor.disconnect(client)
}

View file

@ -1,45 +1,58 @@
import config import config
import gleam/erlang/process import gleam/erlang/process
import gleam/io import gleam/io
// import mqtt
import mqtt_dummy import mqtt_dummy
import sensors import sensors
pub fn main() -> Nil { pub fn main() -> Nil {
let cfg = config.load_config() let _cfg = config.load_config()
io.println("Config loaded successfully!") io.println("Config loaded successfully!")
let assert Ok(subject) = mqtt_dummy.start() let assert Ok(dummy_one) = mqtt_dummy.start()
let mailbox = mqtt_dummy.subscribe(subject) let assert Ok(dummy_two) = mqtt_dummy.start()
process.send_after(dummy_one, 1000, mqtt_dummy.Proc)
// Kick off the first message process.send_after(dummy_two, 1000, mqtt_dummy.Proc)
process.send_after(subject, 1000, mqtt_dummy.Proc) loop(LoopState(
dummy_one_receive_subject: mqtt_dummy.subscribe(dummy_one),
receive_and_reschedule(mailbox, subject) dummy_one_send_subject: dummy_one,
// case process.receive(mailbox, 5000) { dummy_two_receive_subject: mqtt_dummy.subscribe(dummy_two),
// Ok(msg) -> { dummy_two_send_subject: dummy_two,
// io.println("Got message:" <> msg) ))
// // process_messages(mailbox, n - 1)
// }
// Error(Nil) -> {
// io.println("Timeout waiting for message")
// }
// }
Nil Nil
} }
fn receive_and_reschedule( type LoopState {
mailbox: process.Subject(sensors.SensorReading), LoopState(
subject: process.Subject(mqtt_dummy.Message), dummy_one_receive_subject: process.Subject(sensors.SensorReading),
) -> Nil { dummy_one_send_subject: process.Subject(mqtt_dummy.Message),
case process.receive(mailbox, 2000) { dummy_two_receive_subject: process.Subject(sensors.SensorReading),
dummy_two_send_subject: process.Subject(mqtt_dummy.Message),
)
}
fn loop(state: LoopState) -> Nil {
case process.receive(state.dummy_one_receive_subject, 1500) {
Ok(msg) -> { Ok(msg) -> {
sensors.print_sensor_reading(msg) sensors.print_sensor_reading(msg)
process.send_after(subject, 1000, mqtt_dummy.Proc) process.send_after(state.dummy_one_send_subject, 1000, mqtt_dummy.Proc)
receive_and_reschedule(mailbox, subject) Nil
} }
Error(Nil) -> { Error(Nil) -> {
io.println("Timeout - waiting again...") io.println("Timeout on dummy one")
receive_and_reschedule(mailbox, subject)
} }
} }
case process.receive(state.dummy_two_receive_subject, 1500) {
Ok(msg) -> {
sensors.print_sensor_reading(msg)
process.send_after(state.dummy_two_send_subject, 1000, mqtt_dummy.Proc)
Nil
}
Error(Nil) -> {
io.println("Timeout on dummy two..")
}
}
loop(state)
} }