From 14519559686525121352de3e3c9b9cacc4242038 Mon Sep 17 00:00:00 2001 From: Tomasz Kramkowski Date: Fri, 27 Jun 2025 00:46:44 +0100 Subject: Initial commit --- src/config.rs | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 src/config.rs (limited to 'src/config.rs') diff --git a/src/config.rs b/src/config.rs new file mode 100644 index 0000000..1190b9a --- /dev/null +++ b/src/config.rs @@ -0,0 +1,59 @@ +// SPDX-FileCopyrightText: 2025 Tomasz Kramkowski +// SPDX-License-Identifier: GPL-3.0-or-later + +use std::{collections::HashMap, fs, path::Path, process, time::Duration}; + +use rumqttc::{Client, Connection, MqttOptions}; +use serde::Deserialize; + +use crate::PROGRAM; + +#[derive(Deserialize, Debug)] +pub struct Credentials { + pub username: String, + pub password: String, +} + +fn default_host() -> String { + "localhost".to_string() +} + +fn default_port() -> u16 { + 1883 +} + +fn default_id() -> String { + PROGRAM.to_string() +} + +#[derive(Deserialize, Debug)] +pub struct Config { + #[serde(default = "default_host")] + pub host: String, + #[serde(default = "default_port")] + pub port: u16, + pub credentials: Option, + #[serde(default = "default_id")] + pub id: String, + // TODO: Figure out a way to allow arbitrary unix paths (arbitrary + // non-unicode) without base64 + pub routes: HashMap>>, +} + +impl Config { + pub fn mqtt_client(&self) -> (Client, Connection) { + let client_id = format!("{}_{}", self.id, process::id()); + let mut options = MqttOptions::new(client_id, &self.host, self.port); + if let Some(credentials) = &self.credentials { + options.set_credentials(&credentials.username, &credentials.password); + } + options.set_keep_alive(Duration::from_secs(5)); + options.set_max_packet_size(10 * 1024 * 1024, 10 * 1024 * 1024); + Client::new(options, 10) + } +} + +pub fn load>(path: P) -> anyhow::Result { + let config = fs::read_to_string(&path)?; + Ok(toml::from_str(&config)?) +} -- cgit v1.2.3-70-g09d2