wip: add config file to webnsupdate
Some checks failed
/ build (push) Successful in 32s
/ check (clippy) (push) Failing after 11s
/ check (module-ipv4-only-test) (push) Successful in 29s
/ check (module-ipv4-test) (push) Successful in 28s
/ check (module-ipv6-only-test) (push) Successful in 29s
/ check (module-ipv6-test) (push) Successful in 29s
/ check (module-nginx-test) (push) Successful in 29s
/ check (nextest) (push) Successful in 3s
/ check (treefmt) (push) Successful in 3s
/ report-size (push) Successful in 7s

This commit is contained in:
Jalil David Salamé Messina 2025-02-05 23:59:58 +01:00
parent 172076eaad
commit 8c2ad4633f
Signed by: jalil
GPG key ID: F016B9E770737A0B
2 changed files with 103 additions and 1 deletions

101
src/config.rs Normal file
View file

@ -0,0 +1,101 @@
use std::{
net::{IpAddr, Ipv4Addr, Ipv6Addr},
path::PathBuf,
time::Duration,
};
use axum_client_ip::SecureClientIpSource;
use crate::IpType;
#[derive(Debug, serde::Deserialize)]
struct Config {
// --- Server Settings --
/// Ip address of the server
#[serde(default = "default_address")]
address: IpAddr,
/// Port of the server
#[serde(default = "default_port")]
port: u16,
/// Data directory
#[serde(default = "default_data_dir")]
data_dir: PathBuf,
// --- Password Configuration --
/// File containing password to match against
///
/// Should be of the format `username:password` and contain a single password
#[serde(default)]
password_file: Option<PathBuf>,
/// Salt to get more unique hashed passwords and prevent table based attacks
#[serde(default = "default_salt")]
salt: String,
// --- Records Configuration ---
/// Time To Live (in seconds) to set on the DNS records
#[serde(default = "default_ttl")]
ttl: Duration,
/// List of domain names for which to update the IP when an update is requested
#[serde(default)]
records: Vec<String>,
/// If provided, when an IPv6 prefix is provided with an update, this will be used to derive
/// the full IPv6 address of the client
#[serde(default)]
client_id: Option<Ipv6Addr>,
/// If a client id is provided the ipv6 update will be ignored (only the prefix will be used).
/// This domain will point to the ipv6 address instead of the address derived from the client
/// id (usually this is the router).
#[serde(default)]
router_domain: Option<String>,
/// Set client IP source
///
/// see: <https://docs.rs/axum-client-ip/latest/axum_client_ip/enum.SecureClientIpSource.html>
#[serde(default = "default_ip_source")]
ip_source: SecureClientIpSource,
/// Set which IPs to allow updating (ipv4, ipv6 or both)
#[serde(default = "default_ip_type")]
ip_type: IpType,
// --- Nsupdate Configuration ---
/// Keyfile `nsupdate` should use
///
/// If specified, then `webnsupdate` must have read access to the file
#[serde(default)]
key_file: Option<PathBuf>,
}
fn default_ttl() -> Duration {
super::DEFAULT_TTL
}
fn default_salt() -> String {
super::DEFAULT_SALT.into()
}
fn default_data_dir() -> PathBuf {
PathBuf::from(".")
}
fn default_address() -> IpAddr {
IpAddr::V4(Ipv4Addr::LOCALHOST)
}
fn default_port() -> u16 {
5353
}
fn default_ip_source() -> SecureClientIpSource {
SecureClientIpSource::RightmostXForwardedFor
}
fn default_ip_type() -> IpType {
IpType::Both
}

View file

@ -20,6 +20,7 @@ use tracing::{debug, error, info};
use tracing_subscriber::EnvFilter;
mod auth;
mod config;
mod nsupdate;
mod password;
mod records;
@ -93,7 +94,7 @@ struct Opts {
subcommand: Option<Cmd>,
}
#[derive(Debug, Default, Clone, Copy)]
#[derive(Debug, Default, Clone, Copy, serde::Deserialize)]
enum IpType {
#[default]
Both,