wip: initial web server wiring
This commit is contained in:
parent
394b0b5b77
commit
5dcbf57d15
1
Cargo.lock
generated
1
Cargo.lock
generated
@ -304,6 +304,7 @@ version = "0.1.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"axum",
|
"axum",
|
||||||
"serde",
|
"serde",
|
||||||
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -3,6 +3,14 @@ name = "offline-web"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[[bin]]
|
||||||
|
name = "example"
|
||||||
|
path = "src/main.rs"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
axum = "0.8.3"
|
axum = "0.8.3"
|
||||||
serde = { version = "1.0.219", features = ["derive", "rc"] }
|
serde = { version = "1.0.219", features = ["derive", "rc"] }
|
||||||
|
tokio = "1.44.1"
|
||||||
|
20
src/lib.rs
20
src/lib.rs
@ -1,10 +1,24 @@
|
|||||||
|
use std::rc::Rc;
|
||||||
|
|
||||||
use axum::{
|
use axum::{
|
||||||
routing::get,
|
routing::get,
|
||||||
Router
|
Router,
|
||||||
|
Json,
|
||||||
};
|
};
|
||||||
|
use datamodel::Reference;
|
||||||
|
|
||||||
mod datamodel;
|
mod datamodel;
|
||||||
|
|
||||||
pub fn endpoints() -> Router {
|
async fn all_references() -> Json<Rc<Reference>> {
|
||||||
Router::new().route("/api/v1/ref/all/username", get(|| async { "hello world" }))
|
Json(datamodel::Reference::new("silly id".to_string(), "all/username".to_string()).to_rc())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn endpoints() -> Router {
|
||||||
|
Router::new().route("/api/v1/ref/all/username", get(all_references))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn serve() {
|
||||||
|
// run our app with hyper, listening globally on port 3000
|
||||||
|
let listener = tokio::net::TcpListener::bind("127.0.0.1:3000").await.unwrap();
|
||||||
|
axum::serve(listener, endpoints()).await.unwrap();
|
||||||
}
|
}
|
||||||
|
5
src/main.rs
Normal file
5
src/main.rs
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
|
||||||
|
#[tokio::main(flavor = "current_thread")]
|
||||||
|
async fn main() {
|
||||||
|
offline_web::serve().await;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user