basic working client

This commit is contained in:
Silas Bartha 2023-11-11 00:03:24 -05:00
parent 347d29d1e1
commit d10f633980
3 changed files with 1639 additions and 2 deletions

1482
Cargo.lock generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -6,3 +6,6 @@ edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
async-std = { version = "1.12.0", features = ["attributes"] }
clap = { version = "4.4.8", features = ["derive"] }
zbus = "3.14.1"

View File

@ -1,3 +1,155 @@
fn main() {
println!("Hello, world!");
use std::{error::Error, time::Duration};
use clap::{Parser, Subcommand};
use zbus::Connection;
#[derive(Debug, Parser)]
#[clap(name = "pomc", version)]
struct Pomc {
#[clap(subcommand)]
command: Command,
}
#[derive(Debug, Subcommand)]
enum Command {
Start,
Pause,
Stop,
Skip,
GetIteration,
GetRemaining,
IsRunning,
IsOnBreak,
}
#[async_std::main]
async fn main() -> Result<(), Box<dyn Error>> {
let args = Pomc::parse();
let connection = Connection::session().await?;
match args.command {
Command::Start => start(&connection).await?,
Command::Pause => pause(&connection).await?,
Command::Stop => stop(&connection).await?,
Command::Skip => skip(&connection).await?,
Command::GetIteration => get_iteration(&connection).await?,
Command::GetRemaining => get_remaining(&connection).await?,
Command::IsRunning => is_running(&connection).await?,
Command::IsOnBreak => is_on_break(&connection).await?,
}
Ok(())
}
async fn start(connection: &Connection) -> Result<(), Box<dyn Error>> {
connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"Start",
&(),
)
.await?;
Ok(())
}
async fn pause(connection: &Connection) -> Result<(), Box<dyn Error>> {
connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"Pause",
&(),
)
.await?;
Ok(())
}
async fn stop(connection: &Connection) -> Result<(), Box<dyn Error>> {
connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"Stop",
&(),
)
.await?;
Ok(())
}
async fn skip(connection: &Connection) -> Result<(), Box<dyn Error>> {
connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"Skip",
&(),
)
.await?;
Ok(())
}
async fn get_iteration(connection: &Connection) -> Result<(), Box<dyn Error>> {
let m = connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"GetIteration",
&(),
)
.await?;
let iteration: u8 = m.body().unwrap();
println!("{}", iteration + 1);
Ok(())
}
async fn get_remaining(connection: &Connection) -> Result<(), Box<dyn Error>> {
let m = connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"GetRemaining",
&(),
)
.await?;
let remaining: Duration = m.body().unwrap();
let remaining_secs = remaining.as_secs();
println!("{:02}:{:02}", remaining_secs / 60, remaining_secs % 60);
Ok(())
}
async fn is_running(connection: &Connection) -> Result<(), Box<dyn Error>> {
let m = connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"IsRunning",
&(),
)
.await?;
let is_running: bool = m.body().unwrap();
println!("{}", is_running as u8);
Ok(())
}
async fn is_on_break(connection: &Connection) -> Result<(), Box<dyn Error>> {
let m = connection
.call_method(
Some("dev.exvacuum.pomd"),
"/dev/exvacuum/pomd",
Some("dev.exvacuum.pomd"),
"IsOnBreak",
&(),
)
.await?;
let is_on_break: bool = m.body().unwrap();
println!("{}", is_on_break as u8);
Ok(())
}