about summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
authoryuzu <yuzu@b9215c17-b818-4693-b096-d1e41a411fef>2025-06-01 04:59:07 +0000
committeryuzu <yuzu@b9215c17-b818-4693-b096-d1e41a411fef>2025-06-01 04:59:07 +0000
commit0d58b22d4fecd19370b92e4a12803f08ade0dd32 (patch)
treef4a498ba25f075674cf514594ad58d1cc59583d8 /src
parentb4789899f7151bc5607ee4519e3bf542ed0721dd (diff)
downloadsalaryman-0d58b22d4fecd19370b92e4a12803f08ade0dd32.tar.gz
salaryman-0d58b22d4fecd19370b92e4a12803f08ade0dd32.tar.bz2
salaryman-0d58b22d4fecd19370b92e4a12803f08ade0dd32.zip
get config together
git-svn-id: svn+ssh://diminuette.aengel.lesbianunix.dev/salaryman/trunk@5 b9215c17-b818-4693-b096-d1e41a411fef
Diffstat (limited to 'src')
-rw-r--r--src/main.rs112
1 files changed, 100 insertions, 12 deletions
diff --git a/src/main.rs b/src/main.rs
index 5538077..82dc2f9 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,25 +1,113 @@
-use serde::{Deserialize, Serialize};
-use surrealdb::{RecordId, Surreal, engine::local::RocksDb};
+use serde::{
+    Deserialize,
+    Serialize,
+};
+use clap::Parser;
 
-use std::io::Read;
-use std::process::{Child, Command, Stdio};
+use tokio::fs::read_to_string;
 
-fn exec(image: &str, args: Vec<&str>) -> Result<Child, Box<dyn std::error::Error>> {
-    let child = Command::new(image)
-        .args(args)
-        .stdin(Stdio::piped())
-        .stdout(Stdio::piped())
-        .spawn()?;
-    Ok(child)
+use std::{
+    fs::canonicalize,
+    io::Read,
+    process::{
+        Child,
+        Command,
+        Stdio
+    },
+    path::PathBuf,
+    net::IpAddr,
+};
+
+#[derive(Parser)]
+#[command(version, about, long_about = None)]
+struct Args {
+    #[arg(short, long, value_name = "FILE")]
+    config: Option<PathBuf>,
+    #[arg(short, long, value_name = "ADDR")]
+    address: Option<IpAddr>,
+    #[arg(short, long, value_name = "PORT")]
+    port: Option<u16>,
+}
+
+#[derive(Serialize, Deserialize)]
+struct Service {
+    name: String,
+    command: String,
+    args: String,
+    directory: Option<PathBuf>,
+}
+impl Service {
+    fn new() -> Self {
+        Self {
+            name: String::new(),
+            command: String::new(),
+            args: String::new(),
+            directory: None,
+        }
+    }
+}
+
+#[derive(Serialize, Deserialize)]
+struct Config {
+    address: Option<IpAddr>,
+    port: Option<u16>,
+    service: Vec<Service>,
+}
+impl Config {
+    fn new() -> Self {
+        Self {
+            address: None,
+            port: None,
+            service: Vec::new(),
+        }
+    }
+}
+
+fn exec(image: &str, args: Vec<&str>, dir: Option<PathBuf>) -> Result<Child, Box<dyn std::error::Error>> {
+    if let Some(cwd) = dir {
+        let child = Command::new(image)
+            .args(args)
+            .current_dir(canonicalize(cwd)?)
+            .stdin(Stdio::piped())
+            .stdout(Stdio::piped())
+            .stderr(Stdio::piped())
+            .spawn()?;
+        Ok(child)
+    } else {
+        let child = Command::new(image)
+            .args(args)
+            .stdin(Stdio::piped())
+            .stdout(Stdio::piped())
+            .stderr(Stdio::piped())
+            .spawn()?;
+        Ok(child)
+    }
+}
+
+async fn load_config(file: PathBuf) -> Result<Config, Box<dyn std::error::Error>> {
+    let config: Config = toml::from_str(read_to_string(file).await?.as_str())?;
+    Ok(config)
 }
 
 #[tokio::main]
 async fn main() -> Result<(), Box<dyn std::error::Error>> {
-    let mut child = exec("java", vec!["-jar", "minecraft_server.jar"])?;
+    let args = Args::parse();
+    let mut conf: Config = Config::new();
+    if let Some(file) = args.config.as_deref() {
+        conf = load_config(PathBuf::from(file)).await?;
+    } else {
+        conf = load_config(PathBuf::from("salaryman.toml")).await?;
+    }
+    
+    let mut child = exec("java", vec!["-jar", "minecraft_server.jar"], None)?;
     std::thread::sleep(std::time::Duration::from_secs(60));
     let mut buf: [u8; 512] = [0; 512];
+    let mut ebuf: [u8; 512] = [0; 512];
     child.stdout.as_mut().unwrap().read(&mut buf[..])?;
+    child.stderr.as_mut().unwrap().read(&mut ebuf[..])?;
     println!("{}", String::from_utf8_lossy(&buf));
+    println!("{}", String::from_utf8_lossy(&ebuf));
     child.kill()?;
     Ok(())
 }
+