rconn

Crates.iorconn
lib.rsrconn
version1.0.0-a2
created_at2023-11-13 10:53:22.740216+00
updated_at2025-04-03 09:35:12.644975+00
descriptionA simple network protocol.
homepagehttps://github.com/Majjcom/rconn
repositoryhttps://github.com/Majjcom/rconn
max_upload_size
id1033489
size42,635
Majjcom (Majjcom)

documentation

README

Rconn

This is a simple network service with its own protocol.

Usage

Create a server

use std::net::TcpStream;
use rconn::prelude::*;
use serde::Serialize;
use serde_json::Value;

struct Handler;

rhandle_impl_new!(Handler);

impl Default for Handler {
    fn default() -> Self {
        Handler {}
    }
}

#[derive(Serialize)]
struct Response {
    result: String,
}

impl RHandle for Handler {
    fn handle(&mut self, tcp: &mut TcpStream, _: &Value, _: &Vec<u8>, cipher: &RCipher) {
        let resp = Response {
            result: String::from("OK"),
        };
        let cusd = Vec::new();
        Server::send_data(tcp, &resp, &cusdm, cipher);
    }
}

static MAIN_HANDLER: Lazy<THandle> = Lazy::new(|| Handler::new());

fn matcher(act: &str) -> THandle {
    println!("Matcher: match {}", act);
    match act {
        _ => MAIN_HANDLER.clone(),
    }
}

fn main() {
    let mut s = Server::new("0.0.0.0:5000", 16);
    s.set_matcher(&matcher);
    s.start();
}

Client

use crate::client::{
    serde::{Deserialize, Serialize},
    Client,
};

#[derive(Serialize, Deserialize)]
struct Test;

fn main() {
    let mut client = Client::new("127.0.0.1", 5000, 10000, "").unwrap();
    let ndata = Test {};
    let cusd = Vec::new();
    let readed = client.request("test", &ndata, &cusd).unwrap();
    println!("Get: {:?}", readed);
}
Commit count: 51

cargo fmt