Make web server address configurable
This commit is contained in:
parent
3a4a4c1cfa
commit
8b53a22b78
3 changed files with 20 additions and 10 deletions
|
|
@ -1,6 +1,6 @@
|
|||
//! Configuration from a file.
|
||||
|
||||
use std::{fs, io::ErrorKind, path::Path, time::Duration};
|
||||
use std::{fs, io::ErrorKind, net::SocketAddr, path::Path, time::Duration};
|
||||
|
||||
use serde::Deserialize;
|
||||
use tracing::{debug, info};
|
||||
|
|
@ -8,12 +8,17 @@ use tracing::{debug, info};
|
|||
use crate::somehow;
|
||||
|
||||
mod default {
|
||||
use std::time::Duration;
|
||||
use std::{net::SocketAddr, time::Duration};
|
||||
|
||||
pub fn web_base() -> String {
|
||||
"".to_string()
|
||||
}
|
||||
|
||||
pub fn web_address() -> SocketAddr {
|
||||
// Port chosen by fair dice roll
|
||||
"[::]:8221".parse().unwrap()
|
||||
}
|
||||
|
||||
pub fn repo_name() -> String {
|
||||
"local repo".to_string()
|
||||
}
|
||||
|
|
@ -27,12 +32,15 @@ mod default {
|
|||
pub struct Web {
|
||||
#[serde(default = "default::web_base")]
|
||||
pub base: String,
|
||||
#[serde(default = "default::web_address")]
|
||||
pub address: SocketAddr,
|
||||
}
|
||||
|
||||
impl Default for Web {
|
||||
fn default() -> Self {
|
||||
Self {
|
||||
base: default::web_base(),
|
||||
address: default::web_address(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -86,9 +94,10 @@ impl ConfigFile {
|
|||
}
|
||||
|
||||
pub struct Config {
|
||||
pub web_base: String,
|
||||
pub web_address: SocketAddr,
|
||||
pub repo_name: String,
|
||||
pub repo_update_delay: Duration,
|
||||
pub web_base: String,
|
||||
}
|
||||
|
||||
impl Config {
|
||||
|
|
@ -100,9 +109,10 @@ impl Config {
|
|||
let web_base = config_file.web_base();
|
||||
|
||||
Ok(Self {
|
||||
web_base,
|
||||
web_address: config_file.web.address,
|
||||
repo_name: config_file.repo.name,
|
||||
repo_update_delay: config_file.repo.update_delay,
|
||||
web_base,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -28,9 +28,9 @@ async fn recurring_task(state: &Server) {
|
|||
.await;
|
||||
}
|
||||
|
||||
pub async fn run(state: Server) {
|
||||
pub async fn run(server: Server) {
|
||||
loop {
|
||||
recurring_task(&state).await;
|
||||
tokio::time::sleep(state.config.repo_update_delay).await;
|
||||
recurring_task(&server).await;
|
||||
tokio::time::sleep(server.config.repo_update_delay).await;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -39,7 +39,7 @@ impl Base {
|
|||
}
|
||||
}
|
||||
|
||||
pub async fn run(state: Server) -> somehow::Result<()> {
|
||||
pub async fn run(server: Server) -> somehow::Result<()> {
|
||||
// TODO Add text body to body-less status codes
|
||||
|
||||
let app = Router::new()
|
||||
|
|
@ -50,9 +50,9 @@ pub async fn run(state: Server) -> somehow::Result<()> {
|
|||
.route("/queue/table", get(queue::get_table))
|
||||
.route("/queue/:id", get(queue_id::get))
|
||||
.fallback(get(r#static::static_handler))
|
||||
.with_state(state.clone());
|
||||
.with_state(server.clone());
|
||||
|
||||
axum::Server::bind(&"0.0.0.0:8000".parse().unwrap())
|
||||
axum::Server::bind(&server.config.web_address)
|
||||
.serve(app.into_make_service())
|
||||
.await?;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue