use std::path::PathBuf; use bft_crdt_derive::add_crdt_fields; use bft_json_crdt::{ json_crdt::{BaseCrdt, CrdtNode, IntoCrdtNode}, keypair::{make_keypair, Ed25519KeyPair, KeyPair}, list_crdt::ListCrdt, }; use serde::{Deserialize, Serialize}; use serde_json::{json, Value}; use websockets::WebSocket; use crate::keys; #[add_crdt_fields] #[derive(Clone, CrdtNode, Serialize, Deserialize)] pub(crate) struct CrdtList { pub(crate) list: ListCrdt, // switch to Transaction as soon as char is working } /// A fake Transaction struct we can use as a simulated payload #[add_crdt_fields] #[derive(Clone, CrdtNode, Serialize, Deserialize)] pub(crate) struct Transaction { from: String, to: String, amount: f64, } pub(crate) fn new(side_dir: PathBuf) -> (BaseCrdt, Ed25519KeyPair) { let keys = keys::load_from_file(side_dir); // let keys = make_keypair(); let bft_crdt = BaseCrdt::::new(&keys); println!("Author is {}", keys.public().to_string()); (bft_crdt, keys) } pub(crate) async fn send( count: u32, bft_crdt: &mut BaseCrdt, ws: &mut WebSocket, keys: &Ed25519KeyPair, ) -> Result<(), websockets::WebSocketError> { // generate a placeholder transaction let transaction = generate_transaction(count, keys.public().to_string()); // next job is to keep adding to this guy let next = bft_crdt.doc.list.ops.len(); let signed_op = bft_crdt .doc .list .insert_idx(next - 1, transaction.clone()) .sign(&keys); Ok(ws .send_text(serde_json::to_string(&signed_op).unwrap()) .await?) } fn generate_transaction(count: u32, pubkey: String) -> Value { json!({ "from": pubkey, "to": "Bob", "amount": count }) }