From 85bfa5c3dbd153bd3e91eb93164f442f92c87bb0 Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 16:19:19 +0300 Subject: [PATCH 1/9] Draft implement try_log! macro. --- src/utils/logger.rs | 34 ++++++++++++++++++++++++++++++++-- src/utils/mod.rs | 1 + 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/src/utils/logger.rs b/src/utils/logger.rs index 4b5af464a6..5c3e7e4f6a 100644 --- a/src/utils/logger.rs +++ b/src/utils/logger.rs @@ -1,9 +1,25 @@ extern crate env_logger; +extern crate log; use std::sync::{Once, ONCE_INIT}; pub struct LoggerUtils {} +struct SimpleLogger; + +use self::log::{LogMetadata, LogRecord, LogLevelFilter}; + +impl log::Log for SimpleLogger { + fn enabled(&self, metadata: &LogMetadata) -> bool { + true + } + fn log(&self, record: &LogRecord) { + if self.enabled(record.metadata()) { + println!("{}:{} - {}", record.level(), record.target(), record.args()); + } + } +} + impl LoggerUtils { pub fn init() { lazy_static! { @@ -11,7 +27,21 @@ impl LoggerUtils { } LOGGER_INIT.call_once(|| { - env_logger::init().unwrap(); + log::set_logger(|max_log_level| { + max_log_level.set(LogLevelFilter::Info); + Box::new(SimpleLogger) + }).unwrap(); }); } -} \ No newline at end of file +} + +#[macro_export] +macro_rules! try_log { + ($expr:expr) => (match $expr { + Ok(val) => val, + Err(err) => { + error!("Error from try_log macro - {}", err); + return Err(From::from(err)) + } + }) +} diff --git a/src/utils/mod.rs b/src/utils/mod.rs index f565be20a2..89ac4de0b8 100644 --- a/src/utils/mod.rs +++ b/src/utils/mod.rs @@ -9,6 +9,7 @@ pub mod cstring; pub mod ccallback; pub mod crypto; +#[macro_use] pub mod logger; #[macro_use] From 1b3c0d9855a769ab1154291f9631bde2103660a1 Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 16:36:39 +0300 Subject: [PATCH 2/9] Fix warnings in api/agents.rs. --- src/api/agent.rs | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/api/agent.rs b/src/api/agent.rs index 24162b3c1a..b3192cfe55 100644 --- a/src/api/agent.rs +++ b/src/api/agent.rs @@ -1,9 +1,6 @@ extern crate libc; use api::ErrorCode; -use errors::ToErrorCode; -use commands::{Command, CommandExecutor}; -use utils::cstring::CStringUtils; use self::libc::c_char; From 35f37c79b253906b504a483c43ad6edc55c9fd37 Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:04:06 +0300 Subject: [PATCH 3/9] Update log format. --- src/utils/logger.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/utils/logger.rs b/src/utils/logger.rs index 5c3e7e4f6a..9151db6473 100644 --- a/src/utils/logger.rs +++ b/src/utils/logger.rs @@ -15,7 +15,7 @@ impl log::Log for SimpleLogger { } fn log(&self, record: &LogRecord) { if self.enabled(record.metadata()) { - println!("{}:{} - {}", record.level(), record.target(), record.args()); + println!("{:>5}|{:<25}|{:>30}:{:<4}| {}", record.level(), record.target(), record.location().file(), record.location().line(), record.args()); } } } @@ -40,7 +40,7 @@ macro_rules! try_log { ($expr:expr) => (match $expr { Ok(val) => val, Err(err) => { - error!("Error from try_log macro - {}", err); + error!("try_log! | {}", err); return Err(From::from(err)) } }) From 79fabb670cdd4fced41f75e868b5df7a705f715a Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:05:32 +0300 Subject: [PATCH 4/9] Use log macros in demo. --- tests/demo.rs | 49 ++++++++++++++++++++++++++++--------------------- 1 file changed, 28 insertions(+), 21 deletions(-) diff --git a/tests/demo.rs b/tests/demo.rs index c0a6035f83..d6d8b566c6 100644 --- a/tests/demo.rs +++ b/tests/demo.rs @@ -9,11 +9,14 @@ extern crate serde_derive; extern crate serde_json; #[macro_use] extern crate lazy_static; +#[macro_use] +extern crate log; #[macro_use] #[path = "utils/mod.rs"] mod utils; +use utils::logger::LoggerUtils; #[cfg(feature = "local_nodes_pool")] use utils::pool::PoolUtils; use utils::test::TestUtils; @@ -64,6 +67,7 @@ use std::thread; #[test] fn anoncreds_demo_works() { + LoggerUtils::init(); TestUtils::cleanup_storage(); let (create_wallet_sender, create_wallet_receiver) = channel(); @@ -174,7 +178,7 @@ fn anoncreds_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, claim_def_json, claim_def_uuid) = issuer_create_claim_definition_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("claim_def_json {:?}", claim_def_json); + info!("claim_def_json {:?}", claim_def_json); assert_eq!(ErrorCode::Success, err); let claim_def_seq_no = 1; @@ -218,7 +222,7 @@ fn anoncreds_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, claim_req_json) = prover_create_claim_req_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("claim_req_json {:?}", claim_req_json); + info!("claim_req_json {:?}", claim_req_json); assert_eq!(ErrorCode::Success, err); let claim_json = "{\ @@ -240,7 +244,7 @@ fn anoncreds_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, revoc_reg_update_json, xclaim_json) = issuer_create_claim_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("xclaim_json {:?}", xclaim_json); + info!("xclaim_json {:?}", xclaim_json); assert_eq!(ErrorCode::Success, err); // 7. Prover process and store Claim @@ -269,7 +273,7 @@ fn anoncreds_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, claims_json) = prover_get_claims_for_proof_req_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("claims_json {:?}", claims_json); + info!("claims_json {:?}", claims_json); assert_eq!(ErrorCode::Success, err); let claims: ProofClaimsJson = serde_json::from_str(&claims_json).unwrap(); let claims_for_attr_1 = claims.attrs.get("attr1_uuid").unwrap(); @@ -301,7 +305,7 @@ fn anoncreds_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, proof_json) = prover_create_proof_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("proof_json {:?}", proof_json); + info!("proof_json {:?}", proof_json); assert_eq!(ErrorCode::Success, err); // 10. Verifier verify proof @@ -325,6 +329,7 @@ fn anoncreds_demo_works() { #[test] #[cfg(feature="local_nodes_pool")] fn ledger_demo_works() { + LoggerUtils::init(); TestUtils::cleanup_storage(); let my_wallet_name = "my_wallet"; let their_wallet_name = "their_wallet"; @@ -450,9 +455,9 @@ fn ledger_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, my_did, my_verkey, my_pk) = create_and_store_my_did_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("did {:?}", my_did); - println!("verkey {:?}", my_verkey); - println!("pk {:?}", my_pk); + info!("did {:?}", my_did); + info!("verkey {:?}", my_verkey); + info!("pk {:?}", my_pk); assert_eq!(ErrorCode::Success, err); // 8. Create Their DID from Trustee1 seed @@ -465,9 +470,9 @@ fn ledger_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, their_did, their_verkey, their_pk) = create_and_store_their_did_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("their_did {:?}", their_did); - println!("their_verkey {:?}", their_verkey); - println!("their_pk {:?}", their_pk); + info!("their_did {:?}", their_did); + info!("their_verkey {:?}", their_verkey); + info!("their_pk {:?}", their_pk); assert_eq!(ErrorCode::Success, err); // 9. Store Their DID @@ -512,7 +517,8 @@ fn ledger_demo_works() { let (err, resp) = submit_receiver.recv_timeout(TimeoutUtils::medium_timeout()).unwrap(); assert_eq!(err, ErrorCode::Success); let nym_resp: Reply = serde_json::from_str(&resp).unwrap(); - println!("nym_resp {:?}\n{:?}", resp, nym_resp); + info!("nym_resp_raw : {:?}", resp); + info!("nym_resp : {:?}", nym_resp); // 12. Prepare and send GET_NYM request let get_nym_req_id = PoolUtils::get_req_id(); @@ -536,7 +542,7 @@ fn ledger_demo_works() { assert_eq!(err, ErrorCode::Success); let get_nym_resp: Reply = serde_json::from_str(&resp).unwrap(); let get_nym_resp_data: ReplyResultData = serde_json::from_str(&get_nym_resp.result.data.as_ref().unwrap()).unwrap(); - println!("get_nym_resp {:?}\n{:?}\n{:?}", resp, get_nym_resp, get_nym_resp_data); + info!("get_nym_resp {:?}\n{:?}\n{:?}", resp, get_nym_resp, get_nym_resp_data); assert_eq!(get_nym_resp_data.dest, my_verkey); @@ -584,6 +590,7 @@ fn ledger_demo_works() { #[test] fn signus_demo_works() { + LoggerUtils::init(); TestUtils::cleanup_storage(); let (create_my_wallet_sender, create_my_wallet_receiver) = channel(); @@ -703,9 +710,9 @@ fn signus_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, my_did, my_verkey, my_pk) = create_and_store_my_did_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("did {:?}", my_did); - println!("verkey {:?}", my_verkey); - println!("pk {:?}", my_pk); + info!("did {:?}", my_did); + info!("verkey {:?}", my_verkey); + info!("pk {:?}", my_pk); assert_eq!(ErrorCode::Success, err); // 6. Create Their DID @@ -718,9 +725,9 @@ fn signus_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, their_did, their_verkey, their_pk) = create_and_store_their_did_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("their_did {:?}", their_did); - println!("their_verkey {:?}", their_verkey); - println!("their_pk {:?}", their_pk); + info!("their_did {:?}", their_did); + info!("their_verkey {:?}", their_verkey); + info!("their_pk {:?}", their_pk); assert_eq!(ErrorCode::Success, err); // 7. Store Their DID @@ -758,7 +765,7 @@ fn signus_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, signed_msg) = sign_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("signature {:?}", signed_msg); + info!("signature {:?}", signed_msg); assert_eq!(ErrorCode::Success, err); // 9. I Verify message @@ -773,7 +780,7 @@ fn signus_demo_works() { assert_eq!(ErrorCode::Success, err); let (err, valid) = verify_receiver.recv_timeout(TimeoutUtils::long_timeout()).unwrap(); - println!("{:?}", err); + info!("{:?}", err); assert!(valid); assert_eq!(ErrorCode::Success, err); From 7f3a8f36f33817d2610e05f42a36ab6f96e8687c Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:06:05 +0300 Subject: [PATCH 5/9] rm println in signus service. --- src/services/signus/mod.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/services/signus/mod.rs b/src/services/signus/mod.rs index 7334cef1d9..b39dffe248 100644 --- a/src/services/signus/mod.rs +++ b/src/services/signus/mod.rs @@ -67,7 +67,7 @@ impl SignusService { Base58::encode(&secret_key), Base58::encode(&ver_key), Base58::encode(&sign_key)); - println!("did {:?}", my_did.did); + info!("did {:?}", my_did.did); Ok(my_did) } From 2ee8411fa70b4c1070c326133e07dae50751c4bd Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:06:42 +0300 Subject: [PATCH 6/9] Use try_log! macro in pool service. --- src/services/pool/mod.rs | 160 ++++++++++++++++++++------------------- 1 file changed, 81 insertions(+), 79 deletions(-) diff --git a/src/services/pool/mod.rs b/src/services/pool/mod.rs index c8dc2eaf20..817e7e4d1f 100644 --- a/src/services/pool/mod.rs +++ b/src/services/pool/mod.rs @@ -61,8 +61,8 @@ struct TransactionHandler { impl PoolWorkerHandler { fn process_msg(&mut self, raw_msg: &String, src_ind: usize) -> Result, PoolError> { - let msg = Message::from_raw_str(raw_msg) - .map_err(PoolError::from_displayable_as_invalid_data)?; + let msg = try_log!(Message::from_raw_str(raw_msg) + .map_err(PoolError::from_displayable_as_invalid_data)); match self { &mut PoolWorkerHandler::CatchupHandler(ref mut ch) => ch.process_msg(msg, raw_msg, src_ind), &mut PoolWorkerHandler::TransactionHandler(ref mut ch) => ch.process_msg(msg, raw_msg, src_ind), @@ -142,11 +142,11 @@ impl TransactionHandler { fn try_send_request(&mut self, cmd: &str, cmd_id: i32) -> Result<(), PoolError> { info!("cmd {:?}", cmd); - let request: Value = serde_json::from_str(cmd) - .map_err(PoolError::from_displayable_as_invalid_data)?; - let request_id: u64 = request["reqId"] + let request: Value = try_log!(serde_json::from_str(cmd) + .map_err(PoolError::from_displayable_as_invalid_data)); + let request_id: u64 = try_log!(request["reqId"] .as_u64() - .ok_or(PoolError::InvalidData("Invalid request: missed requestId field".to_string()))?; + .ok_or(PoolError::InvalidData("Invalid request: missed requestId field".to_string()))); if self.pending_commands.contains_key(&request_id) { self.pending_commands.get_mut(&request_id).unwrap().cmd_ids.push(cmd_id); } else { @@ -158,7 +158,7 @@ impl TransactionHandler { self.pending_commands.insert(request_id, pc); for node in &self.nodes { let node: &RemoteNode = node; - node.send_str(cmd)?; + try_log!(node.send_str(cmd)); } } Ok(()) @@ -174,12 +174,12 @@ impl TransactionHandler { for (_, pending_cmd) in &self.pending_commands { let pending_cmd: &CommandProcess = pending_cmd; for cmd_id in &pending_cmd.cmd_ids { - CommandExecutor::instance() + try_log!(CommandExecutor::instance() .send(Command::Ledger(LedgerCommand::SubmitAck( cmd_id.clone(), Err(PoolError::Terminate)))) .map_err(|err| { PoolError::InvalidState("Can't send ACK cmd".to_string()) - })?; + })); } } Ok(()) @@ -200,7 +200,7 @@ impl Default for TransactionHandler { impl PoolWorker { fn connect_to_known_nodes(&mut self, merkle_tree: Option<&MerkleTree>) -> Result<(), PoolError> { - let merkle_tree: MerkleTree = merkle_tree.map(|x| { x.clone() }) + let merkle_tree: MerkleTree = try_log!(merkle_tree.map(|x| { x.clone() }) .or_else(|| { match self.handler { //TODO default self.handler.get_default_mt() -> Result @@ -208,16 +208,16 @@ impl PoolWorker { PoolWorkerHandler::TransactionHandler(_) => None } }) - .ok_or(PoolError::InvalidState("Expect catchup state".to_string()))?; + .ok_or(PoolError::InvalidState("Expect catchup state".to_string()))); let ctx: zmq::Context = zmq::Context::new(); for gen_txn in &merkle_tree { - let gen_txn: GenTransaction = GenTransaction::from_json(gen_txn) + let gen_txn: GenTransaction = try_log!(GenTransaction::from_json(gen_txn) .map_err(|e| { PoolError::InvalidState(format!("MerkleTree contains invalid data {}", e)) - })?; - let mut rn: RemoteNode = RemoteNode::new(&gen_txn)?; - rn.connect(&ctx)?; - rn.send_str("pi")?; + })); + let mut rn: RemoteNode = try_log!(RemoteNode::new(&gen_txn)); + try_log!(rn.connect(&ctx)); + try_log!(rn.send_str("pi")); self.handler.nodes_mut().push(rn); } self.handler.set_f(PoolWorker::get_f(merkle_tree.count())); //TODO set cnt to connect @@ -226,19 +226,19 @@ impl PoolWorker { fn init_catchup(&mut self) -> Result<(), PoolError> { let catchup_handler = CatchupHandler { - merkle_tree: PoolWorker::_restore_merkle_tree(self.name.as_str())?, + merkle_tree: try_log!(PoolWorker::_restore_merkle_tree(self.name.as_str())), open_cmd_id: self.open_cmd_id, pool_id: self.pool_id, ..Default::default() }; self.handler = PoolWorkerHandler::CatchupHandler(catchup_handler); - self.connect_to_known_nodes(None)?; + try_log!(self.connect_to_known_nodes(None)); Ok(()) } pub fn run(&mut self) -> Result<(), PoolError> { self._run().or_else(|err: PoolError| { - self.handler.flush_requests(Err(PoolError::Terminate))?; + try_log!(self.handler.flush_requests(Err(PoolError::Terminate))); match err { PoolError::Terminate => Ok(()), _ => Err(err), @@ -247,14 +247,14 @@ impl PoolWorker { } fn _run(&mut self) -> Result<(), PoolError> { - self.init_catchup()?; //TODO consider error as PoolOpen error + try_log!(self.init_catchup()); //TODO consider error as PoolOpen error loop { trace!("zmq poll loop >>"); - let actions = self.poll_zmq()?; + let actions = try_log!(self.poll_zmq()); - self.process_actions(actions)?; + try_log!(self.process_actions(actions)); trace!("zmq poll loop <<"); } @@ -267,20 +267,20 @@ impl PoolWorker { return Err(PoolError::Terminate); } &ZMQLoopAction::MessageToProcess(ref msg) => { - if let Some(new_mt) = self.handler.process_msg(&msg.message, msg.node_idx)? { - self.handler.flush_requests(Ok(()))?; + if let Some(new_mt) = try_log!(self.handler.process_msg(&msg.message, msg.node_idx)) { + try_log!(self.handler.flush_requests(Ok(()))); self.handler = PoolWorkerHandler::TransactionHandler(Default::default()); - self.connect_to_known_nodes(Some(&new_mt))?; + try_log!(self.connect_to_known_nodes(Some(&new_mt))); } } &ZMQLoopAction::RequestToSend(ref req) => { - self.handler.send_request(req.request.as_str(), req.id).or_else(|err| { + try_log!(self.handler.send_request(req.request.as_str(), req.id).or_else(|err| { CommandExecutor::instance() .send(Command::Ledger(LedgerCommand::SubmitAck(req.id, Err(err)))) .map_err(|err| { PoolError::InvalidState("Can't send ACK cmd".to_string()) }) - })?; + })); } } } @@ -290,13 +290,13 @@ impl PoolWorker { fn poll_zmq(&mut self) -> Result, PoolError> { let mut actions: Vec = Vec::new(); - let mut poll_items = self.get_zmq_poll_items()?; - let r = zmq::poll(poll_items.as_mut_slice(), -1)?; + let mut poll_items = try_log!(self.get_zmq_poll_items()); + let r = try_log!(zmq::poll(poll_items.as_mut_slice(), -1)); trace!("zmq poll {:?}", r); for i in 0..self.handler.nodes().len() { if poll_items[1 + i].is_readable() { - if let Some(msg) = self.handler.nodes()[i].recv_msg()? { + if let Some(msg) = try_log!(self.handler.nodes()[i].recv_msg()) { actions.push(ZMQLoopAction::MessageToProcess(MessageToProcess { node_idx: i, message: msg, @@ -305,10 +305,10 @@ impl PoolWorker { } } if poll_items[0].is_readable() { - let cmd = self.cmd_sock.recv_multipart(zmq::DONTWAIT)?; + let cmd = try_log!(self.cmd_sock.recv_multipart(zmq::DONTWAIT)); trace!("cmd {:?}", cmd); - let cmd_s = String::from_utf8(cmd[0].clone()) - .map_err(PoolError::from_displayable_as_invalid_data)?; + let cmd_s = try_log!(String::from_utf8(cmd[0].clone()) + .map_err(PoolError::from_displayable_as_invalid_data)); if "exit".eq(cmd_s.as_str()) { actions.push(ZMQLoopAction::Terminate); } else { @@ -325,9 +325,9 @@ impl PoolWorker { let mut poll_items: Vec = Vec::new(); poll_items.push(self.cmd_sock.as_poll_item(zmq::POLLIN)); for ref node in self.handler.nodes() { - let s: &zmq::Socket = node.zsock.as_ref() + let s: &zmq::Socket = try_log!(node.zsock.as_ref() .ok_or(PoolError::InvalidState( - "Try to poll from ZMQ socket for unconnected RemoteNode".to_string()))?; + "Try to poll from ZMQ socket for unconnected RemoteNode".to_string()))); poll_items.push(s.as_poll_item(zmq::POLLIN)); } Ok(poll_items) @@ -336,15 +336,15 @@ impl PoolWorker { fn _restore_merkle_tree(pool_name: &str) -> Result { let mut p = EnvironmentUtils::pool_path(pool_name); - let mut mt = MerkleTree::from_vec(Vec::new())?; + let mut mt = try_log!(MerkleTree::from_vec(Vec::new())); //TODO firstly try to deserialize merkle tree p.push(pool_name); p.set_extension("txn"); - let f = fs::File::open(p)?; + let f = try_log!(fs::File::open(p)); let reader = io::BufReader::new(&f); for line in reader.lines() { - let line: String = line?; - mt.append(line)?; + let line: String = try_log!(line); + try_log!(mt.append(line)); } Ok(mt) } @@ -360,13 +360,13 @@ impl PoolWorker { impl Pool { pub fn new(name: &str, cmd_id: i32) -> Result { let zmq_ctx = zmq::Context::new(); - let recv_cmd_sock = zmq_ctx.socket(zmq::SocketType::PAIR)?; - let send_cmd_sock = zmq_ctx.socket(zmq::SocketType::PAIR)?; + let recv_cmd_sock = try_log!(zmq_ctx.socket(zmq::SocketType::PAIR)); + let send_cmd_sock = try_log!(zmq_ctx.socket(zmq::SocketType::PAIR)); let inproc_sock_name: String = format!("inproc://pool_{}", name); - recv_cmd_sock.bind(inproc_sock_name.as_str())?; + try_log!(recv_cmd_sock.bind(inproc_sock_name.as_str())); - send_cmd_sock.connect(inproc_sock_name.as_str())?; + try_log!(send_cmd_sock.connect(inproc_sock_name.as_str())); let pool_id = SequenceUtils::get_next_id(); let mut pool_worker: PoolWorker = PoolWorker { cmd_sock: recv_cmd_sock, @@ -395,7 +395,7 @@ impl Pool { pub fn send_tx(&self, cmd_id: i32, json: &str) -> Result<(), PoolError> { let mut buf = [0u8; 4]; LittleEndian::write_i32(&mut buf, cmd_id); - Ok(self.cmd_sock.send_multipart(&[json.as_bytes(), &buf], zmq::DONTWAIT)?) + Ok(try_log!(self.cmd_sock.send_multipart(&[json.as_bytes(), &buf], zmq::DONTWAIT))) } } @@ -428,8 +428,8 @@ impl Debug for RemoteNode { impl RemoteNode { fn new(txn: &GenTransaction) -> Result { - let public_key = txn.dest.as_str().from_base58() - .map_err(|e| { PoolError::InvalidData("Invalid field dest in genesis transaction".to_string()) })?; + let public_key = try_log!(txn.dest.as_str().from_base58() + .map_err(|e| { PoolError::InvalidData("Invalid field dest in genesis transaction".to_string()) })); Ok(RemoteNode { verify_key: ED25519::pk_to_curve25519(&public_key), public_key: public_key, @@ -440,17 +440,16 @@ impl RemoteNode { } fn connect(&mut self, ctx: &zmq::Context) -> Result<(), PoolError> { - let key_pair = zmq::CurveKeyPair::new()?; - let s = ctx.socket(zmq::SocketType::DEALER)?; - s.set_identity(key_pair.public_key.as_bytes())?; - s.set_curve_secretkey(key_pair.secret_key.as_str())?; - s.set_curve_publickey(key_pair.public_key.as_str())?; - s.set_curve_serverkey( - zmq::z85_encode(self.verify_key.as_slice()) - .map_err(|err| { PoolError::InvalidData("Can't encode server key as z85".to_string()) })? - .as_str())?; - s.set_linger(0)?; //TODO set correct timeout - s.connect(self.zaddr.as_str())?; + let key_pair = try_log!(zmq::CurveKeyPair::new()); + let s = try_log!(ctx.socket(zmq::SocketType::DEALER)); + try_log!(s.set_identity(key_pair.public_key.as_bytes())); + try_log!(s.set_curve_secretkey(key_pair.secret_key.as_str())); + try_log!(s.set_curve_publickey(key_pair.public_key.as_str())); + let server_key = try_log!(zmq::z85_encode(self.verify_key.as_slice()) + .map_err(|err| { PoolError::InvalidData("Can't encode server key as z85".to_string()) })); + try_log!(s.set_curve_serverkey(server_key.as_str())); + try_log!(s.set_linger(0)); //TODO set correct timeout + try_log!(s.connect(self.zaddr.as_str())); self.zsock = Some(s); Ok(()) } @@ -461,9 +460,12 @@ impl RemoteNode { PoolError::Io(io::Error::from(io::ErrorKind::InvalidData)) } } - let msg: String = self.zsock.as_ref() - .ok_or(PoolError::InvalidState("Try to receive msg for unconnected RemoteNode".to_string()))? - .recv_string(zmq::DONTWAIT)??; + let msg: String = try_log!( + try_log!( + try_log!(self.zsock.as_ref().ok_or(PoolError::InvalidState("Try to receive msg for unconnected RemoteNode".to_string())) + ).recv_string(zmq::DONTWAIT) + ).map_err(|err|{PoolError::InvalidData(format!("{:?}", err))}) + ); info!(target: "RemoteNode_recv_msg", "{} {}", self.name, msg); Ok(Some(msg)) @@ -471,14 +473,14 @@ impl RemoteNode { fn send_str(&self, str: &str) -> Result<(), PoolError> { info!("Sending {:?}", str); - self.zsock.as_ref() - .ok_or(PoolError::InvalidState("Try to send str for unconnected RemoteNode".to_string()))? - .send_str(str, zmq::DONTWAIT)?; + try_log!(try_log!(self.zsock.as_ref() + .ok_or(PoolError::InvalidState("Try to send str for unconnected RemoteNode".to_string()))) + .send_str(str, zmq::DONTWAIT)); Ok(()) } fn send_msg(&self, msg: &Message) -> Result<(), PoolError> { - self.send_str(msg.to_json().map_err(PoolError::from_displayable_as_invalid_data)?.as_str()) + self.send_str(try_log!(msg.to_json().map_err(PoolError::from_displayable_as_invalid_data)).as_str()) } } @@ -492,8 +494,8 @@ impl PoolService { pub fn create(&self, name: &str, config: Option<&str>) -> Result<(), PoolError> { let mut path = EnvironmentUtils::pool_path(name); let pool_config = match config { - Some(config) => PoolConfig::from_json(config) - .map_err(PoolError::from_displayable_as_invalid_config)?, + Some(config) => try_log!(PoolConfig::from_json(config) + .map_err(PoolError::from_displayable_as_invalid_config)), None => PoolConfig::default_for_name(name) }; @@ -501,19 +503,19 @@ impl PoolService { return Err(PoolError::NotCreated("Already created".to_string())); } - fs::create_dir_all(path.as_path())?; + try_log!(fs::create_dir_all(path.as_path())); path.push(name); path.set_extension("txn"); - fs::copy(&pool_config.genesis_txn, path.as_path())?; + try_log!(fs::copy(&pool_config.genesis_txn, path.as_path())); path.pop(); path.push("config"); path.set_extension("json"); - let mut f: fs::File = fs::File::create(path.as_path())?; - f.write(pool_config.to_json() - .map_err(PoolError::from_displayable_as_invalid_config)?.as_bytes())?; - f.flush()?; + let mut f: fs::File = try_log!(fs::File::create(path.as_path())); + try_log!(f.write(try_log!(pool_config.to_json() + .map_err(PoolError::from_displayable_as_invalid_config)).as_bytes())); + try_log!(f.flush()); // TODO probably create another one file pool.json with pool description, // but now there is no info to save (except name witch equal to directory) @@ -526,7 +528,7 @@ impl PoolService { } pub fn open(&self, name: &str, config: Option<&str>) -> Result { - for pool in self.pools.try_borrow()?.values() { + for pool in try_log!(self.pools.try_borrow()).values() { if name.eq(pool.name.as_str()) { //TODO change error return Err(PoolError::InvalidHandle("Already opened".to_string())); @@ -534,18 +536,18 @@ impl PoolService { } let cmd_id: i32 = SequenceUtils::get_next_id(); - let new_pool = Pool::new(name, cmd_id)?; + let new_pool = try_log!(Pool::new(name, cmd_id)); //FIXME process config: check None (use default), transfer to Pool instance - self.pools.try_borrow_mut()?.insert(new_pool.id, new_pool); + try_log!(self.pools.try_borrow_mut()).insert(new_pool.id, new_pool); return Ok(cmd_id); } pub fn send_tx(&self, handle: i32, json: &str) -> Result { let cmd_id: i32 = SequenceUtils::get_next_id(); - self.pools.try_borrow()? - .get(&handle).ok_or(PoolError::InvalidHandle("No pool with requested handle".to_string()))? - .send_tx(cmd_id, json)?; + try_log!(try_log!(try_log!(self.pools.try_borrow()) + .get(&handle).ok_or(PoolError::InvalidHandle("No pool with requested handle".to_string()))) + .send_tx(cmd_id, json)); Ok(cmd_id) } @@ -558,7 +560,7 @@ impl PoolService { } pub fn get_pool_name(&self, handle: i32) -> Result { - self.pools.try_borrow()?.get(&handle).map_or( + try_log!(self.pools.try_borrow()).get(&handle).map_or( Err(PoolError::InvalidHandle("Doesn't exists".to_string())), |pool: &Pool| Ok(pool.name.clone())) } From 0f3adc0652d3c6a7522d339a9d515726b0061c7a Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:18:18 +0300 Subject: [PATCH 7/9] Update trace format --- src/utils/logger.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/utils/logger.rs b/src/utils/logger.rs index 9151db6473..9091cfb3a1 100644 --- a/src/utils/logger.rs +++ b/src/utils/logger.rs @@ -15,7 +15,7 @@ impl log::Log for SimpleLogger { } fn log(&self, record: &LogRecord) { if self.enabled(record.metadata()) { - println!("{:>5}|{:<25}|{:>30}:{:<4}| {}", record.level(), record.target(), record.location().file(), record.location().line(), record.args()); + println!("{:>5}|{:<27}|{:>30}:{:<4}| {}", record.level(), record.target(), record.location().file(), record.location().line(), record.args()); } } } From d9f35ca4cf4357b448f93a4e08c92a49ae7a4426 Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Fri, 26 May 2017 18:19:35 +0300 Subject: [PATCH 8/9] Update trace format --- src/utils/logger.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/utils/logger.rs b/src/utils/logger.rs index 9091cfb3a1..b17a6d6726 100644 --- a/src/utils/logger.rs +++ b/src/utils/logger.rs @@ -15,7 +15,7 @@ impl log::Log for SimpleLogger { } fn log(&self, record: &LogRecord) { if self.enabled(record.metadata()) { - println!("{:>5}|{:<27}|{:>30}:{:<4}| {}", record.level(), record.target(), record.location().file(), record.location().line(), record.args()); + println!("{:>5}|{:<30}|{:>35}:{:<4}| {}", record.level(), record.target(), record.location().file(), record.location().line(), record.args()); } } } From bde7699e3501ff7409daf46b9bc25a9ca76df4c8 Mon Sep 17 00:00:00 2001 From: Sergey Minaev Date: Thu, 1 Jun 2017 13:33:53 +0300 Subject: [PATCH 9/9] Revert "Use try_log! macro in pool service." This reverts commit 2ee8411fa70b4c1070c326133e07dae50751c4bd. --- src/services/pool/mod.rs | 160 +++++++++++++++++++-------------------- 1 file changed, 79 insertions(+), 81 deletions(-) diff --git a/src/services/pool/mod.rs b/src/services/pool/mod.rs index 817e7e4d1f..c8dc2eaf20 100644 --- a/src/services/pool/mod.rs +++ b/src/services/pool/mod.rs @@ -61,8 +61,8 @@ struct TransactionHandler { impl PoolWorkerHandler { fn process_msg(&mut self, raw_msg: &String, src_ind: usize) -> Result, PoolError> { - let msg = try_log!(Message::from_raw_str(raw_msg) - .map_err(PoolError::from_displayable_as_invalid_data)); + let msg = Message::from_raw_str(raw_msg) + .map_err(PoolError::from_displayable_as_invalid_data)?; match self { &mut PoolWorkerHandler::CatchupHandler(ref mut ch) => ch.process_msg(msg, raw_msg, src_ind), &mut PoolWorkerHandler::TransactionHandler(ref mut ch) => ch.process_msg(msg, raw_msg, src_ind), @@ -142,11 +142,11 @@ impl TransactionHandler { fn try_send_request(&mut self, cmd: &str, cmd_id: i32) -> Result<(), PoolError> { info!("cmd {:?}", cmd); - let request: Value = try_log!(serde_json::from_str(cmd) - .map_err(PoolError::from_displayable_as_invalid_data)); - let request_id: u64 = try_log!(request["reqId"] + let request: Value = serde_json::from_str(cmd) + .map_err(PoolError::from_displayable_as_invalid_data)?; + let request_id: u64 = request["reqId"] .as_u64() - .ok_or(PoolError::InvalidData("Invalid request: missed requestId field".to_string()))); + .ok_or(PoolError::InvalidData("Invalid request: missed requestId field".to_string()))?; if self.pending_commands.contains_key(&request_id) { self.pending_commands.get_mut(&request_id).unwrap().cmd_ids.push(cmd_id); } else { @@ -158,7 +158,7 @@ impl TransactionHandler { self.pending_commands.insert(request_id, pc); for node in &self.nodes { let node: &RemoteNode = node; - try_log!(node.send_str(cmd)); + node.send_str(cmd)?; } } Ok(()) @@ -174,12 +174,12 @@ impl TransactionHandler { for (_, pending_cmd) in &self.pending_commands { let pending_cmd: &CommandProcess = pending_cmd; for cmd_id in &pending_cmd.cmd_ids { - try_log!(CommandExecutor::instance() + CommandExecutor::instance() .send(Command::Ledger(LedgerCommand::SubmitAck( cmd_id.clone(), Err(PoolError::Terminate)))) .map_err(|err| { PoolError::InvalidState("Can't send ACK cmd".to_string()) - })); + })?; } } Ok(()) @@ -200,7 +200,7 @@ impl Default for TransactionHandler { impl PoolWorker { fn connect_to_known_nodes(&mut self, merkle_tree: Option<&MerkleTree>) -> Result<(), PoolError> { - let merkle_tree: MerkleTree = try_log!(merkle_tree.map(|x| { x.clone() }) + let merkle_tree: MerkleTree = merkle_tree.map(|x| { x.clone() }) .or_else(|| { match self.handler { //TODO default self.handler.get_default_mt() -> Result @@ -208,16 +208,16 @@ impl PoolWorker { PoolWorkerHandler::TransactionHandler(_) => None } }) - .ok_or(PoolError::InvalidState("Expect catchup state".to_string()))); + .ok_or(PoolError::InvalidState("Expect catchup state".to_string()))?; let ctx: zmq::Context = zmq::Context::new(); for gen_txn in &merkle_tree { - let gen_txn: GenTransaction = try_log!(GenTransaction::from_json(gen_txn) + let gen_txn: GenTransaction = GenTransaction::from_json(gen_txn) .map_err(|e| { PoolError::InvalidState(format!("MerkleTree contains invalid data {}", e)) - })); - let mut rn: RemoteNode = try_log!(RemoteNode::new(&gen_txn)); - try_log!(rn.connect(&ctx)); - try_log!(rn.send_str("pi")); + })?; + let mut rn: RemoteNode = RemoteNode::new(&gen_txn)?; + rn.connect(&ctx)?; + rn.send_str("pi")?; self.handler.nodes_mut().push(rn); } self.handler.set_f(PoolWorker::get_f(merkle_tree.count())); //TODO set cnt to connect @@ -226,19 +226,19 @@ impl PoolWorker { fn init_catchup(&mut self) -> Result<(), PoolError> { let catchup_handler = CatchupHandler { - merkle_tree: try_log!(PoolWorker::_restore_merkle_tree(self.name.as_str())), + merkle_tree: PoolWorker::_restore_merkle_tree(self.name.as_str())?, open_cmd_id: self.open_cmd_id, pool_id: self.pool_id, ..Default::default() }; self.handler = PoolWorkerHandler::CatchupHandler(catchup_handler); - try_log!(self.connect_to_known_nodes(None)); + self.connect_to_known_nodes(None)?; Ok(()) } pub fn run(&mut self) -> Result<(), PoolError> { self._run().or_else(|err: PoolError| { - try_log!(self.handler.flush_requests(Err(PoolError::Terminate))); + self.handler.flush_requests(Err(PoolError::Terminate))?; match err { PoolError::Terminate => Ok(()), _ => Err(err), @@ -247,14 +247,14 @@ impl PoolWorker { } fn _run(&mut self) -> Result<(), PoolError> { - try_log!(self.init_catchup()); //TODO consider error as PoolOpen error + self.init_catchup()?; //TODO consider error as PoolOpen error loop { trace!("zmq poll loop >>"); - let actions = try_log!(self.poll_zmq()); + let actions = self.poll_zmq()?; - try_log!(self.process_actions(actions)); + self.process_actions(actions)?; trace!("zmq poll loop <<"); } @@ -267,20 +267,20 @@ impl PoolWorker { return Err(PoolError::Terminate); } &ZMQLoopAction::MessageToProcess(ref msg) => { - if let Some(new_mt) = try_log!(self.handler.process_msg(&msg.message, msg.node_idx)) { - try_log!(self.handler.flush_requests(Ok(()))); + if let Some(new_mt) = self.handler.process_msg(&msg.message, msg.node_idx)? { + self.handler.flush_requests(Ok(()))?; self.handler = PoolWorkerHandler::TransactionHandler(Default::default()); - try_log!(self.connect_to_known_nodes(Some(&new_mt))); + self.connect_to_known_nodes(Some(&new_mt))?; } } &ZMQLoopAction::RequestToSend(ref req) => { - try_log!(self.handler.send_request(req.request.as_str(), req.id).or_else(|err| { + self.handler.send_request(req.request.as_str(), req.id).or_else(|err| { CommandExecutor::instance() .send(Command::Ledger(LedgerCommand::SubmitAck(req.id, Err(err)))) .map_err(|err| { PoolError::InvalidState("Can't send ACK cmd".to_string()) }) - })); + })?; } } } @@ -290,13 +290,13 @@ impl PoolWorker { fn poll_zmq(&mut self) -> Result, PoolError> { let mut actions: Vec = Vec::new(); - let mut poll_items = try_log!(self.get_zmq_poll_items()); - let r = try_log!(zmq::poll(poll_items.as_mut_slice(), -1)); + let mut poll_items = self.get_zmq_poll_items()?; + let r = zmq::poll(poll_items.as_mut_slice(), -1)?; trace!("zmq poll {:?}", r); for i in 0..self.handler.nodes().len() { if poll_items[1 + i].is_readable() { - if let Some(msg) = try_log!(self.handler.nodes()[i].recv_msg()) { + if let Some(msg) = self.handler.nodes()[i].recv_msg()? { actions.push(ZMQLoopAction::MessageToProcess(MessageToProcess { node_idx: i, message: msg, @@ -305,10 +305,10 @@ impl PoolWorker { } } if poll_items[0].is_readable() { - let cmd = try_log!(self.cmd_sock.recv_multipart(zmq::DONTWAIT)); + let cmd = self.cmd_sock.recv_multipart(zmq::DONTWAIT)?; trace!("cmd {:?}", cmd); - let cmd_s = try_log!(String::from_utf8(cmd[0].clone()) - .map_err(PoolError::from_displayable_as_invalid_data)); + let cmd_s = String::from_utf8(cmd[0].clone()) + .map_err(PoolError::from_displayable_as_invalid_data)?; if "exit".eq(cmd_s.as_str()) { actions.push(ZMQLoopAction::Terminate); } else { @@ -325,9 +325,9 @@ impl PoolWorker { let mut poll_items: Vec = Vec::new(); poll_items.push(self.cmd_sock.as_poll_item(zmq::POLLIN)); for ref node in self.handler.nodes() { - let s: &zmq::Socket = try_log!(node.zsock.as_ref() + let s: &zmq::Socket = node.zsock.as_ref() .ok_or(PoolError::InvalidState( - "Try to poll from ZMQ socket for unconnected RemoteNode".to_string()))); + "Try to poll from ZMQ socket for unconnected RemoteNode".to_string()))?; poll_items.push(s.as_poll_item(zmq::POLLIN)); } Ok(poll_items) @@ -336,15 +336,15 @@ impl PoolWorker { fn _restore_merkle_tree(pool_name: &str) -> Result { let mut p = EnvironmentUtils::pool_path(pool_name); - let mut mt = try_log!(MerkleTree::from_vec(Vec::new())); + let mut mt = MerkleTree::from_vec(Vec::new())?; //TODO firstly try to deserialize merkle tree p.push(pool_name); p.set_extension("txn"); - let f = try_log!(fs::File::open(p)); + let f = fs::File::open(p)?; let reader = io::BufReader::new(&f); for line in reader.lines() { - let line: String = try_log!(line); - try_log!(mt.append(line)); + let line: String = line?; + mt.append(line)?; } Ok(mt) } @@ -360,13 +360,13 @@ impl PoolWorker { impl Pool { pub fn new(name: &str, cmd_id: i32) -> Result { let zmq_ctx = zmq::Context::new(); - let recv_cmd_sock = try_log!(zmq_ctx.socket(zmq::SocketType::PAIR)); - let send_cmd_sock = try_log!(zmq_ctx.socket(zmq::SocketType::PAIR)); + let recv_cmd_sock = zmq_ctx.socket(zmq::SocketType::PAIR)?; + let send_cmd_sock = zmq_ctx.socket(zmq::SocketType::PAIR)?; let inproc_sock_name: String = format!("inproc://pool_{}", name); - try_log!(recv_cmd_sock.bind(inproc_sock_name.as_str())); + recv_cmd_sock.bind(inproc_sock_name.as_str())?; - try_log!(send_cmd_sock.connect(inproc_sock_name.as_str())); + send_cmd_sock.connect(inproc_sock_name.as_str())?; let pool_id = SequenceUtils::get_next_id(); let mut pool_worker: PoolWorker = PoolWorker { cmd_sock: recv_cmd_sock, @@ -395,7 +395,7 @@ impl Pool { pub fn send_tx(&self, cmd_id: i32, json: &str) -> Result<(), PoolError> { let mut buf = [0u8; 4]; LittleEndian::write_i32(&mut buf, cmd_id); - Ok(try_log!(self.cmd_sock.send_multipart(&[json.as_bytes(), &buf], zmq::DONTWAIT))) + Ok(self.cmd_sock.send_multipart(&[json.as_bytes(), &buf], zmq::DONTWAIT)?) } } @@ -428,8 +428,8 @@ impl Debug for RemoteNode { impl RemoteNode { fn new(txn: &GenTransaction) -> Result { - let public_key = try_log!(txn.dest.as_str().from_base58() - .map_err(|e| { PoolError::InvalidData("Invalid field dest in genesis transaction".to_string()) })); + let public_key = txn.dest.as_str().from_base58() + .map_err(|e| { PoolError::InvalidData("Invalid field dest in genesis transaction".to_string()) })?; Ok(RemoteNode { verify_key: ED25519::pk_to_curve25519(&public_key), public_key: public_key, @@ -440,16 +440,17 @@ impl RemoteNode { } fn connect(&mut self, ctx: &zmq::Context) -> Result<(), PoolError> { - let key_pair = try_log!(zmq::CurveKeyPair::new()); - let s = try_log!(ctx.socket(zmq::SocketType::DEALER)); - try_log!(s.set_identity(key_pair.public_key.as_bytes())); - try_log!(s.set_curve_secretkey(key_pair.secret_key.as_str())); - try_log!(s.set_curve_publickey(key_pair.public_key.as_str())); - let server_key = try_log!(zmq::z85_encode(self.verify_key.as_slice()) - .map_err(|err| { PoolError::InvalidData("Can't encode server key as z85".to_string()) })); - try_log!(s.set_curve_serverkey(server_key.as_str())); - try_log!(s.set_linger(0)); //TODO set correct timeout - try_log!(s.connect(self.zaddr.as_str())); + let key_pair = zmq::CurveKeyPair::new()?; + let s = ctx.socket(zmq::SocketType::DEALER)?; + s.set_identity(key_pair.public_key.as_bytes())?; + s.set_curve_secretkey(key_pair.secret_key.as_str())?; + s.set_curve_publickey(key_pair.public_key.as_str())?; + s.set_curve_serverkey( + zmq::z85_encode(self.verify_key.as_slice()) + .map_err(|err| { PoolError::InvalidData("Can't encode server key as z85".to_string()) })? + .as_str())?; + s.set_linger(0)?; //TODO set correct timeout + s.connect(self.zaddr.as_str())?; self.zsock = Some(s); Ok(()) } @@ -460,12 +461,9 @@ impl RemoteNode { PoolError::Io(io::Error::from(io::ErrorKind::InvalidData)) } } - let msg: String = try_log!( - try_log!( - try_log!(self.zsock.as_ref().ok_or(PoolError::InvalidState("Try to receive msg for unconnected RemoteNode".to_string())) - ).recv_string(zmq::DONTWAIT) - ).map_err(|err|{PoolError::InvalidData(format!("{:?}", err))}) - ); + let msg: String = self.zsock.as_ref() + .ok_or(PoolError::InvalidState("Try to receive msg for unconnected RemoteNode".to_string()))? + .recv_string(zmq::DONTWAIT)??; info!(target: "RemoteNode_recv_msg", "{} {}", self.name, msg); Ok(Some(msg)) @@ -473,14 +471,14 @@ impl RemoteNode { fn send_str(&self, str: &str) -> Result<(), PoolError> { info!("Sending {:?}", str); - try_log!(try_log!(self.zsock.as_ref() - .ok_or(PoolError::InvalidState("Try to send str for unconnected RemoteNode".to_string()))) - .send_str(str, zmq::DONTWAIT)); + self.zsock.as_ref() + .ok_or(PoolError::InvalidState("Try to send str for unconnected RemoteNode".to_string()))? + .send_str(str, zmq::DONTWAIT)?; Ok(()) } fn send_msg(&self, msg: &Message) -> Result<(), PoolError> { - self.send_str(try_log!(msg.to_json().map_err(PoolError::from_displayable_as_invalid_data)).as_str()) + self.send_str(msg.to_json().map_err(PoolError::from_displayable_as_invalid_data)?.as_str()) } } @@ -494,8 +492,8 @@ impl PoolService { pub fn create(&self, name: &str, config: Option<&str>) -> Result<(), PoolError> { let mut path = EnvironmentUtils::pool_path(name); let pool_config = match config { - Some(config) => try_log!(PoolConfig::from_json(config) - .map_err(PoolError::from_displayable_as_invalid_config)), + Some(config) => PoolConfig::from_json(config) + .map_err(PoolError::from_displayable_as_invalid_config)?, None => PoolConfig::default_for_name(name) }; @@ -503,19 +501,19 @@ impl PoolService { return Err(PoolError::NotCreated("Already created".to_string())); } - try_log!(fs::create_dir_all(path.as_path())); + fs::create_dir_all(path.as_path())?; path.push(name); path.set_extension("txn"); - try_log!(fs::copy(&pool_config.genesis_txn, path.as_path())); + fs::copy(&pool_config.genesis_txn, path.as_path())?; path.pop(); path.push("config"); path.set_extension("json"); - let mut f: fs::File = try_log!(fs::File::create(path.as_path())); - try_log!(f.write(try_log!(pool_config.to_json() - .map_err(PoolError::from_displayable_as_invalid_config)).as_bytes())); - try_log!(f.flush()); + let mut f: fs::File = fs::File::create(path.as_path())?; + f.write(pool_config.to_json() + .map_err(PoolError::from_displayable_as_invalid_config)?.as_bytes())?; + f.flush()?; // TODO probably create another one file pool.json with pool description, // but now there is no info to save (except name witch equal to directory) @@ -528,7 +526,7 @@ impl PoolService { } pub fn open(&self, name: &str, config: Option<&str>) -> Result { - for pool in try_log!(self.pools.try_borrow()).values() { + for pool in self.pools.try_borrow()?.values() { if name.eq(pool.name.as_str()) { //TODO change error return Err(PoolError::InvalidHandle("Already opened".to_string())); @@ -536,18 +534,18 @@ impl PoolService { } let cmd_id: i32 = SequenceUtils::get_next_id(); - let new_pool = try_log!(Pool::new(name, cmd_id)); + let new_pool = Pool::new(name, cmd_id)?; //FIXME process config: check None (use default), transfer to Pool instance - try_log!(self.pools.try_borrow_mut()).insert(new_pool.id, new_pool); + self.pools.try_borrow_mut()?.insert(new_pool.id, new_pool); return Ok(cmd_id); } pub fn send_tx(&self, handle: i32, json: &str) -> Result { let cmd_id: i32 = SequenceUtils::get_next_id(); - try_log!(try_log!(try_log!(self.pools.try_borrow()) - .get(&handle).ok_or(PoolError::InvalidHandle("No pool with requested handle".to_string()))) - .send_tx(cmd_id, json)); + self.pools.try_borrow()? + .get(&handle).ok_or(PoolError::InvalidHandle("No pool with requested handle".to_string()))? + .send_tx(cmd_id, json)?; Ok(cmd_id) } @@ -560,7 +558,7 @@ impl PoolService { } pub fn get_pool_name(&self, handle: i32) -> Result { - try_log!(self.pools.try_borrow()).get(&handle).map_or( + self.pools.try_borrow()?.get(&handle).map_or( Err(PoolError::InvalidHandle("Doesn't exists".to_string())), |pool: &Pool| Ok(pool.name.clone())) }