2023-12-11 01:17:25 +08:00
|
|
|
mod client;
|
|
|
|
|
2023-12-11 00:00:01 +08:00
|
|
|
use ed25519_dalek::{Signature, Signer, SigningKey};
|
2023-12-11 18:17:55 +08:00
|
|
|
use rust_socketio::{ClientBuilder, Event, Payload, RawClient};
|
2023-12-11 00:00:01 +08:00
|
|
|
use std::time::Duration;
|
|
|
|
|
|
|
|
#[allow(unused)]
|
|
|
|
fn require_auth_callback(payload: Payload, client: RawClient) {
|
2023-12-11 18:17:55 +08:00
|
|
|
let key = std::env::args().nth(2).expect("No key given");
|
2023-12-11 00:00:01 +08:00
|
|
|
let auth_key = match payload {
|
|
|
|
Payload::String(str) => Some(str),
|
|
|
|
Payload::Binary(_) => None,
|
|
|
|
}
|
2023-12-11 18:17:55 +08:00
|
|
|
.expect("Payload should be String");
|
2023-12-11 00:00:01 +08:00
|
|
|
let auth_key = &auth_key[1..auth_key.len() - 1];
|
|
|
|
|
|
|
|
println!("auth_key: {}", auth_key);
|
|
|
|
|
2023-12-11 18:17:55 +08:00
|
|
|
let array_key: [u8; 32] = hex::decode(key)
|
|
|
|
.expect("Key should be hex")
|
|
|
|
.try_into()
|
|
|
|
.expect("Key should be 32 bytes");
|
2023-12-11 00:00:01 +08:00
|
|
|
|
|
|
|
let signing_key: SigningKey = SigningKey::from_bytes(&array_key);
|
|
|
|
|
2023-12-11 18:17:55 +08:00
|
|
|
let salt = hex::decode(auth_key).expect("Got an invalid salt from the server");
|
2023-12-11 00:00:01 +08:00
|
|
|
let signature: Signature = signing_key.sign(salt.as_slice());
|
|
|
|
// let sign = hex::encode(signature.to_bytes());
|
|
|
|
let sign = signature.to_bytes().to_vec();
|
|
|
|
client.emit("auth", sign).unwrap();
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(unused)]
|
|
|
|
fn any_event(event: Event, payload: Payload, _client: RawClient) {
|
|
|
|
// println!("event: {} | {:#?}", event, payload);
|
|
|
|
match payload {
|
|
|
|
Payload::Binary(bin) => println!("event: {} |bin: {:?}", event, bin),
|
|
|
|
Payload::String(str) => println!("event: {} |str: {:?}", event, str),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn ws_main() {
|
|
|
|
// define a callback which is called when a payload is received
|
|
|
|
// this callback gets the payload as well as an instance of the
|
|
|
|
// socket to communicate with the server
|
|
|
|
let connect_call_back = |payload: Payload, _client: RawClient| {
|
|
|
|
println!("Connect callback: {:#?}", payload);
|
|
|
|
};
|
2023-12-11 18:17:55 +08:00
|
|
|
// 从命令行获取 host 和 key
|
|
|
|
let host = std::env::args().nth(1).expect("No host given");
|
2023-12-11 00:00:01 +08:00
|
|
|
|
|
|
|
// get a socket that is connected to the admin namespace
|
|
|
|
|
2023-12-11 18:17:55 +08:00
|
|
|
let socket = ClientBuilder::new(host)
|
2023-12-11 00:00:01 +08:00
|
|
|
// .namespace("/admin")
|
|
|
|
.on_any(any_event)
|
|
|
|
.on("connect", connect_call_back)
|
|
|
|
.on("requireAuth", require_auth_callback)
|
|
|
|
.connect()
|
|
|
|
.expect("Connection failed");
|
|
|
|
|
|
|
|
std::thread::sleep(Duration::from_secs(10));
|
|
|
|
|
|
|
|
socket.disconnect().expect("Disconnect failed")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
ws_main();
|
|
|
|
}
|