3 releases
0.1.2 | Mar 29, 2023 |
---|---|
0.1.1 | Mar 29, 2023 |
0.1.0 | Mar 28, 2023 |
#191 in WebSocket
36 downloads per month
45KB
865 lines
moonsock
Moonsock is a simple way to connect to a klipper/moonraker 3D printer websocket using Rust from anywhere where tokio can be ran and you can access your 3D printer though the internet (generally within your local network).
Usage
When opening up a MoonConnection, make sure you set both the read and write buffers large enough for your use case. In the example below, both are set to 1000.
Connect to a printer
Open up the websocket by creating a new MoonConnection inside a tokio runtime.
// I prefer starting my own tokio runtimes for this sort of use-case.
use tokio::runtime::Builder;
use moonsock::{MoonConnection, MoonMSG, MoonMethod};
println!("Starting Main Runtime");
let moon_rt = Builder::new_multi_thread()
.worker_threads(1)
.thread_name("Moonraker Websocket Main")
.enable_all()
.build()
.unwrap();
// Note: the port might be different for you, but 7125 is moonraker's default port. Check your moonraker.conf if you have problems
let url = "ws://[printer ip or hostname]:7125/websocket";
let mut connection = moon_rt.block_on(MoonConnection::new(URL.to_string(), 1000, 1000));
Basic Send Message
The below examples need to be ran in a tokio runtime.
let id = 4242;
connection.send(MoonMSG::gcode(
String::from("G90"),
id,
)).await.unwrap();
// Using our moon_rt from above it could be called like this:
moon_rt.block_on(connection.send(MoonMSG::gcode(
String::from("G90"),
id,
)).await.unwrap());
Send Message and Wait for It's Response
The send_listen
method will send a message and return the response for that specific message. To be clear, it does not return the next received response, it returns the first response that has an id that matches the id of the sent message. The send_listen
method is async so it doesn't block the thread while waiting. An id should be set on the sent message or else the future might never return.
let temp_id = 42342;
let message = MoonMSG::new(MoonMethod::ServerTemperatureStore, None, Some(temp_id));
match connection.send_listen(message.clone()).await {
Ok(message) => {
...
},
Err(err) => println!("ERROR: {}", err),
}
Receive Messages
match connection.recv().await {
Some(msg) => println!("Received: {:?}", msg),
None => println!("Failed to receive message from connection"),
}
Completeness of the crate
Not all message types are supported by the parser currently, but most of the important ones are. If you want support for more messages feel free to upen up an issue or fork this and add support yourself.
Dependencies
~6–18MB
~242K SLoC