aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--Cargo.lock30
-rw-r--r--Cargo.toml4
m---------libs/hbb_common0
-rw-r--r--src/lic.rs84
-rw-r--r--src/main.rs3
5 files changed, 119 insertions, 2 deletions
diff --git a/Cargo.lock b/Cargo.lock
index 0a7d169..89b72c2 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -618,15 +618,19 @@ dependencies = [
name = "hbbs"
version = "1.1.3"
dependencies = [
+ "base64 0.13.0",
"clap",
"hbb_common",
"lazy_static",
+ "mac_address",
+ "machine-uid",
"reqwest",
"rocksdb",
"rust-ini",
"serde",
"serde_derive",
"serde_json",
+ "whoami",
]
[[package]]
@@ -873,6 +877,15 @@ dependencies = [
]
[[package]]
+name = "machine-uid"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1f1595709b0a7386bcd56ba34d250d626e5503917d05d32cdccddcd68603e212"
+dependencies = [
+ "winreg 0.6.2",
+]
+
+[[package]]
name = "matches"
version = "0.1.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -1420,7 +1433,7 @@ dependencies = [
"wasm-bindgen",
"wasm-bindgen-futures",
"web-sys",
- "winreg",
+ "winreg 0.7.0",
]
[[package]]
@@ -2073,6 +2086,12 @@ dependencies = [
]
[[package]]
+name = "whoami"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7884773ab69074615cb8f8425d0e53f11710786158704fca70f53e71b0e05504"
+
+[[package]]
name = "winapi"
version = "0.2.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -2117,6 +2136,15 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
[[package]]
name = "winreg"
+version = "0.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b2986deb581c4fe11b621998a5e53361efe6b48a151178d0cd9eeffa4dc6acc9"
+dependencies = [
+ "winapi 0.3.9",
+]
+
+[[package]]
+name = "winreg"
version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0120db82e8a1e0b9fb3345a539c478767c0048d842860994d96113d5b667bd69"
diff --git a/Cargo.toml b/Cargo.toml
index 875dc3b..cb543ee 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -20,6 +20,10 @@ lazy_static = "1.4"
clap = "2.33"
rust-ini = "0.16"
reqwest = "0.10"
+machine-uid = "0.2"
+mac_address = "1.1"
+whoami = "0.9"
+base64 = "0.13"
[build-dependencies]
hbb_common = { path = "libs/hbb_common" }
diff --git a/libs/hbb_common b/libs/hbb_common
-Subproject 20bea85903acbd701aed45d195e9206f2ea09ed
+Subproject 98257ca5b799ecae53e2fc3ec20bb997a2f6206
diff --git a/src/lic.rs b/src/lic.rs
index 74f7d76..67a8745 100644
--- a/src/lic.rs
+++ b/src/lic.rs
@@ -1,6 +1,90 @@
+use hbb_common::{bail, log, sodiumoxide::crypto::sign, ResultType};
+use serde_derive::{Deserialize, Serialize};
+use std::io::prelude::*;
+use std::path::Path;
+
+#[derive(Debug, PartialEq, Default, Serialize, Deserialize, Clone)]
+pub struct License {
+ #[serde(default)]
+ pub hostname: String,
+ #[serde(default)]
+ pub uid: String,
+ #[serde(default)]
+ pub mac: String,
+}
+
+const LICENSE_FILE: &'static str = ".license.txt";
+
pub fn check_lic(email: &str) -> bool {
+ let lic = get_lic();
+ let path = Path::new(LICENSE_FILE);
+ if Path::is_file(&path) {
+ let contents = std::fs::read_to_string(&path).unwrap_or("".to_owned());
+ if let Ok(old_lic) = dec_lic(&contents) {
+ if lic == old_lic {
+ return true;
+ }
+ }
+ }
+
+ if email.is_empty() {
+ log::error!("Registered email required.");
+ return false;
+ }
+
+ if let Ok(s) = enc_lic(&lic) {
+ if let Ok(mut f) = std::fs::File::create(path) {
+ f.write_all(s.as_bytes()).ok();
+ f.sync_all().ok();
+ }
+ }
true
}
+pub fn get_lic() -> License {
+ let hostname = whoami::hostname();
+ let uid = machine_uid::get().unwrap_or("".to_owned());
+ let mac = if let Ok(Some(ma)) = mac_address::get_mac_address() {
+ base64::encode_config(ma.bytes(), base64::URL_SAFE_NO_PAD)
+ } else {
+ "".to_owned()
+ };
+ License { hostname, uid, mac }
+}
+
+pub fn enc_lic(lic: &License) -> ResultType<String> {
+ let tmp = serde_json::to_vec::<License>(lic)?;
+ const SK: &[u64] = &[
+ 139, 164, 88, 86, 6, 123, 221, 248, 96, 36, 106, 207, 99, 124, 27, 196, 5, 159, 58, 253,
+ 238, 94, 3, 184, 237, 236, 122, 59, 205, 95, 6, 189, 88, 168, 68, 104, 60, 5, 163, 198,
+ 165, 38, 12, 85, 114, 203, 96, 163, 70, 48, 0, 131, 57, 12, 46, 129, 83, 17, 84, 193, 119,
+ 197, 130, 103,
+ ];
+ let sk: Vec<u8> = SK.iter().map(|x| *x as u8).collect();
+ let mut sk_ = [0u8; sign::SECRETKEYBYTES];
+ sk_[..].copy_from_slice(&sk);
+ let sk = sign::SecretKey(sk_);
+ let tmp = base64::encode_config(sign::sign(&tmp, &sk), base64::URL_SAFE_NO_PAD);
+ let tmp: String = tmp.chars().rev().collect();
+ Ok(tmp)
+}
+
+pub fn dec_lic(s: &str) -> ResultType<License> {
+ let tmp: String = s.chars().rev().collect();
+ const PK: &[u64] = &[
+ 88, 168, 68, 104, 60, 5, 163, 198, 165, 38, 12, 85, 114, 203, 96, 163, 70, 48, 0, 131, 57,
+ 12, 46, 129, 83, 17, 84, 193, 119, 197, 130, 103,
+ ];
+ let pk: Vec<u8> = PK.iter().map(|x| *x as u8).collect();
+ let mut pk_ = [0u8; sign::PUBLICKEYBYTES];
+ pk_[..].copy_from_slice(&pk);
+ let pk = sign::PublicKey(pk_);
+ if let Ok(data) = sign::verify(&base64::decode_config(tmp, base64::URL_SAFE_NO_PAD)?, &pk) {
+ Ok(serde_json::from_slice::<License>(&data)?)
+ } else {
+ bail!("sign:verify failed");
+ }
+}
+
pub const EMAIL_ARG: &'static str =
"-m, --email=[EMAIL] 'Sets your email address registered with RustDesk'";
diff --git a/src/main.rs b/src/main.rs
index 16de822..0b8c919 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -20,7 +20,8 @@ fn main() -> ResultType<()> {
-C, --change-id=[BOOL(default=Y)] 'Sets if support to change id'
{}
-k, --key=[KEY] 'Only allow the client with the same key'",
- DEFAULT_PORT, lic::EMAIL_ARG
+ DEFAULT_PORT,
+ lic::EMAIL_ARG
);
let matches = App::new("hbbs")
.version(crate::VERSION)