Compare commits
10 Commits
43b69c2489
...
6dad6f1e5f
Author | SHA1 | Date | |
---|---|---|---|
6dad6f1e5f | |||
abd4d884f9 | |||
3eb074ac08 | |||
585048dace | |||
4240b6411d | |||
|
8813ced13c | ||
|
3a8a76f5fe | ||
|
6f2f10dbfe | ||
|
c0dbffcf0f | ||
|
d8a4990203 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -10,3 +10,4 @@ Cargo.lock
|
|||||||
# These are backup files generated by rustfmt
|
# These are backup files generated by rustfmt
|
||||||
**/*.rs.bk
|
**/*.rs.bk
|
||||||
|
|
||||||
|
grrs
|
7
Cargo.toml
Normal file
7
Cargo.toml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
[package]
|
||||||
|
name = "sclient"
|
||||||
|
version = "0.1.0"
|
||||||
|
authors = ["lastlink"]
|
||||||
|
edition = "2018"
|
||||||
|
|
||||||
|
[dependencies]
|
13
README.md
13
README.md
@ -1,3 +1,14 @@
|
|||||||
# sclient.rust
|
# sclient.rust
|
||||||
|
|
||||||
compare https://git.rootprojects.org/root/sclient.go/src/branch/master
|
compare https://git.rootprojects.org/root/sclient.go/src/branch/master
|
||||||
|
|
||||||
|
## getting started
|
||||||
|
|
||||||
|
* run directly
|
||||||
|
* `cargo run -- -servername example -k example.com 3000`
|
||||||
|
* `cargo run test`
|
||||||
|
* `cargo run -- --help`
|
||||||
|
* build
|
||||||
|
* `cargo build`
|
||||||
|
* `target/debug/sclient --help` run from build
|
||||||
|
* `.\target\debug\sclient.exe --help` windows cmd
|
||||||
|
72
src/main.rs
72
src/main.rs
@ -1,3 +1,71 @@
|
|||||||
fn main() {
|
use std::env;
|
||||||
println!("Hello, world!");
|
|
||||||
|
fn help() {
|
||||||
|
println!(
|
||||||
|
"Usage: sclient [--servername <string>] [-k | --insecure] [ssh|rsync] <remote> <port>
|
||||||
|
ex: sclient whatever.com 3000
|
||||||
|
(whatever.com:443 localhost:3000)
|
||||||
|
ex: sclient whatever.com:4080 0.0.0.0:3000"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let args: Vec<String> = env::args().collect();
|
||||||
|
|
||||||
|
if args
|
||||||
|
.iter()
|
||||||
|
.any(|element| element == "-h" || element == "--help")
|
||||||
|
{
|
||||||
|
help();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut flags = Flags::default();
|
||||||
|
|
||||||
|
// try!()
|
||||||
|
if args
|
||||||
|
.iter()
|
||||||
|
.any(|element| element == "-k" || element == "--insecure")
|
||||||
|
{
|
||||||
|
flags.insecure = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
let serverNameArg = args
|
||||||
|
.iter()
|
||||||
|
.enumerate()
|
||||||
|
.find(|(index, element)| *element == "-servername");
|
||||||
|
|
||||||
|
if let Some((index, _)) = serverNameArg {
|
||||||
|
flags.servername = args[index + 1].clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
// get port
|
||||||
|
let maybe_port = args[args.len() - 1].parse::<i32>();
|
||||||
|
if maybe_port.is_ok() {
|
||||||
|
// pull out of maybe option error
|
||||||
|
flags.port = maybe_port.unwrap();
|
||||||
|
} else {
|
||||||
|
help();
|
||||||
|
print!("<port> needs to be an integer");
|
||||||
|
}
|
||||||
|
// get remote
|
||||||
|
flags.remote = args[args.len() - 2].clone();
|
||||||
|
|
||||||
|
if args[args.len() - 3] == "ssh" || args[args.len() - 3] == "rsync" {
|
||||||
|
flags.custom = args[args.len() - 3].clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
dbg!(flags);
|
||||||
|
// tls port forward functionality
|
||||||
|
// https://github.com/izderadicka/ptunnel-rust
|
||||||
|
// https://github.com/ctz/rustls
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Default, Debug)]
|
||||||
|
struct Flags {
|
||||||
|
insecure: bool,
|
||||||
|
servername: String,
|
||||||
|
remote: String,
|
||||||
|
custom: String,
|
||||||
|
port: i32,
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user