aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorQuentin <quentin@deuxfleurs.fr>2020-11-02 15:48:39 +0100
committerQuentin <quentin@deuxfleurs.fr>2020-11-02 15:48:39 +0100
commitcea871d944e36222f5fdabe3e907cb8cf86d26e8 (patch)
treea2928e83176e21f19fe9dc319c6753677742cb4a /src
parent104e2ce0a25917dfaaab7e62042cc611fc05125a (diff)
downloadgarage-cea871d944e36222f5fdabe3e907cb8cf86d26e8.tar.gz
garage-cea871d944e36222f5fdabe3e907cb8cf86d26e8.zip
Skeleton to the new web API
Diffstat (limited to 'src')
-rw-r--r--src/garage/server.rs6
-rw-r--r--src/util/config.rs2
-rw-r--r--src/web/Cargo.toml43
-rw-r--r--src/web/lib.rs5
-rw-r--r--src/web/web_server.rs37
5 files changed, 92 insertions, 1 deletions
diff --git a/src/garage/server.rs b/src/garage/server.rs
index 6caea5eb..8962a8da 100644
--- a/src/garage/server.rs
+++ b/src/garage/server.rs
@@ -9,6 +9,7 @@ use garage_util::config::*;
use garage_util::error::Error;
use garage_api::api_server;
+use garage_web::web_server;
use garage_model::garage::Garage;
use garage_rpc::rpc_server::RpcServer;
@@ -56,6 +57,7 @@ pub async fn run_server(config_file: PathBuf) -> Result<(), Error> {
info!("Initializing RPC and API servers...");
let run_rpc_server = Arc::new(rpc_server).run(wait_from(watch_cancel.clone()));
let api_server = api_server::run_api_server(garage.clone(), wait_from(watch_cancel.clone()));
+ let web_server = web_server::run_web_server(garage.clone(), wait_from(watch_cancel.clone()));
futures::try_join!(
garage
@@ -78,6 +80,10 @@ pub async fn run_server(config_file: PathBuf) -> Result<(), Error> {
info!("API server exited");
rv
}),
+ web_server.map(|rv| {
+ info!("Web server exited");
+ rv
+ }),
background.run().map(|rv| {
info!("Background runner exited");
Ok(rv)
diff --git a/src/util/config.rs b/src/util/config.rs
index a78ef830..a5fbe4b4 100644
--- a/src/util/config.rs
+++ b/src/util/config.rs
@@ -54,7 +54,7 @@ pub struct ApiConfig {
#[derive(Deserialize, Debug, Clone)]
pub struct WebConfig {
- pub website_bind_addr: SocketAddr,
+ pub web_bind_addr: SocketAddr,
}
fn default_max_concurrent_rpc_requests() -> usize {
diff --git a/src/web/Cargo.toml b/src/web/Cargo.toml
new file mode 100644
index 00000000..8b3743dc
--- /dev/null
+++ b/src/web/Cargo.toml
@@ -0,0 +1,43 @@
+[package]
+name = "garage_web"
+version = "0.1.0"
+authors = ["Alex Auvolat <alex@adnab.me>", "Quentin Dufour <quentin@dufour.io>"]
+edition = "2018"
+license = "GPL-3.0"
+description = "Utility crate for the Garage object store"
+repository = "https://git.deuxfleurs.fr/Deuxfleurs/garage"
+
+[lib]
+path = "lib.rs"
+
+# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
+
+[dependencies]
+garage_util = { version = "0.1", path = "../util" }
+garage_table = { version = "0.1.1", path = "../table" }
+garage_model = { version = "0.1.1", path = "../model" }
+
+rand = "0.7"
+hex = "0.3"
+sha2 = "0.8"
+err-derive = "0.2.3"
+log = "0.4"
+
+sled = "0.31"
+
+toml = "0.5"
+rmp-serde = "0.14.3"
+serde = { version = "1.0", default-features = false, features = ["derive", "rc"] }
+serde_json = "1.0"
+
+futures = "0.3"
+futures-util = "0.3"
+tokio = { version = "0.2", default-features = false, features = ["rt-core", "rt-threaded", "io-driver", "net", "tcp", "time", "macros", "sync", "signal", "fs"] }
+
+http = "0.2"
+hyper = "0.13"
+rustls = "0.17"
+webpki = "0.21"
+
+roxmltree = "0.11"
+
diff --git a/src/web/lib.rs b/src/web/lib.rs
new file mode 100644
index 00000000..80957669
--- /dev/null
+++ b/src/web/lib.rs
@@ -0,0 +1,5 @@
+#[macro_use]
+extern crate log;
+
+pub mod web_server;
+
diff --git a/src/web/web_server.rs b/src/web/web_server.rs
new file mode 100644
index 00000000..cb81e433
--- /dev/null
+++ b/src/web/web_server.rs
@@ -0,0 +1,37 @@
+use std::sync::Arc;
+
+use futures::future::Future;
+
+use hyper::server::conn::AddrStream;
+use hyper::{Body,Request,Response,Server};
+use hyper::service::{make_service_fn, service_fn};
+
+use garage_util::error::Error;
+use garage_model::garage::Garage;
+
+pub async fn run_web_server(
+ garage: Arc<Garage>,
+ shutdown_signal: impl Future<Output = ()>,
+) -> Result<(), Error> {
+ let addr = &garage.config.s3_web.web_bind_addr;
+
+ let service = make_service_fn(|conn: &AddrStream| {
+ let garage = garage.clone();
+ let client_addr = conn.remote_addr();
+ info!("{:?}", client_addr);
+ async move {
+ Ok::<_, Error>(service_fn(move |req: Request<Body>| {
+ let garage = garage.clone();
+ //handler(garage, req, client_addr)
+ async move { Ok::<Response<Body>, Error>(Response::new(Body::from("hello world\n"))) }
+ }))
+ }
+ });
+
+ let server = Server::bind(&addr).serve(service);
+ let graceful = server.with_graceful_shutdown(shutdown_signal);
+ info!("Web server listening on http://{}", addr);
+
+ graceful.await?;
+ Ok(())
+}