aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMelody Horn / boringcactus <melody@boringcactus.com>2021-06-13 11:03:27 -0600
committerMelody Horn / boringcactus <melody@boringcactus.com>2021-06-13 11:03:27 -0600
commitbb7da4934d4a5f0f5184ea382a122724d27d88a4 (patch)
tree91fe511f31a2194ba3cfa853c43f7871ae685792 /src
parent7447a411f0dc4c9eff4cfaf28c1171ca1b4be707 (diff)
downloadtosin-bb7da4934d4a5f0f5184ea382a122724d27d88a4.tar.gz
tosin-bb7da4934d4a5f0f5184ea382a122724d27d88a4.zip
power up CLI
Diffstat (limited to 'src')
-rw-r--r--src/cli/mod.rs23
-rw-r--r--src/cli/run_server.rs20
-rw-r--r--src/lib.rs7
-rw-r--r--src/server.rs11
4 files changed, 45 insertions, 16 deletions
diff --git a/src/cli/mod.rs b/src/cli/mod.rs
new file mode 100644
index 0000000..c656c1c
--- /dev/null
+++ b/src/cli/mod.rs
@@ -0,0 +1,23 @@
+use structopt::StructOpt;
+
+use crate::{Settings, UrlMap};
+
+mod run_server;
+
+#[derive(StructOpt)]
+enum Command {
+ RunServer(run_server::RunServer),
+}
+
+impl Command {
+ fn execute(self, urls: UrlMap, settings: Settings) {
+ match self {
+ Command::RunServer(command) => command.execute(urls, settings),
+ }
+ }
+}
+
+pub fn main(urls: UrlMap, settings: Settings) {
+ let command = Command::from_args();
+ command.execute(urls, settings);
+}
diff --git a/src/cli/run_server.rs b/src/cli/run_server.rs
new file mode 100644
index 0000000..9e4d91c
--- /dev/null
+++ b/src/cli/run_server.rs
@@ -0,0 +1,20 @@
+use structopt::StructOpt;
+
+use crate::{Settings, UrlMap};
+
+#[derive(StructOpt)]
+pub struct RunServer {
+
+}
+
+impl RunServer {
+ pub fn execute(self, urls: UrlMap, _settings: Settings) {
+ let server_task = warp::serve(urls).run(([127, 0, 0, 1], 3030));
+
+ tokio::runtime::Builder::new_multi_thread()
+ .enable_all()
+ .build()
+ .unwrap()
+ .block_on(server_task)
+ }
+}
diff --git a/src/lib.rs b/src/lib.rs
index 112ed57..38ae0e2 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -1,16 +1,13 @@
+mod cli;
pub mod contrib;
pub mod http;
-pub mod server;
pub mod settings;
pub mod urls;
+pub use cli::main;
pub use settings::Settings;
pub use urls::UrlMap;
-pub fn main(urls: UrlMap, settings: Settings) {
- todo!()
-}
-
#[macro_export]
macro_rules! main {
($urls:expr, $settings:expr) => {
diff --git a/src/server.rs b/src/server.rs
deleted file mode 100644
index b275616..0000000
--- a/src/server.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-use crate::urls::UrlMap;
-
-pub fn run_server(filter_stack: UrlMap) {
- let server_task = warp::serve(filter_stack).run(([127, 0, 0, 1], 3030));
-
- tokio::runtime::Builder::new_multi_thread()
- .enable_all()
- .build()
- .unwrap()
- .block_on(server_task)
-}