Skip to content

Commit

Permalink
In case of an error it, log the error in the file and continue to pro…
Browse files Browse the repository at this point in the history
…cess other rows
  • Loading branch information
richajaindce committed Sep 13, 2024
1 parent 794c9ae commit 9baca44
Showing 1 changed file with 26 additions and 4 deletions.
30 changes: 26 additions & 4 deletions ipa-core/src/cli/crypto.rs
Original file line number Diff line number Diff line change
Expand Up @@ -180,7 +180,7 @@ pub async fn decrypt_and_reconstruct(args: DecryptArgs) -> Result<(), BoxError>
.create_new(true)
.open(args.output_file)?,
);

let mut first_error = None;
for (idx, (dec_report1, (dec_report2, dec_report3))) in decrypted_reports1
.zip(decrypted_reports2.zip(decrypted_reports3))
.enumerate()
Expand Down Expand Up @@ -236,11 +236,33 @@ pub async fn decrypt_and_reconstruct(args: DecryptArgs) -> Result<(), BoxError>
trigger_value,
)?;
}
_ => println!("Decryption failed for record no {idx}"),
(Err(e1), _, _) => {
writeln!(writer, "Decryption failed Record: {idx} Reason:{e1}",)?;
eprintln!("Decryption failed Record: {idx} Reason:{e1}");
if first_error.is_none() {
first_error = Some(e1);
}
}
(Ok(_), Err(e2), _) => {
writeln!(writer, "Decryption failed Record: {idx} Reason:{e2}",)?;
eprintln!("Decryption failed Record: {idx} Reason:{e2}");
if first_error.is_none() {
first_error = Some(e2);
}
}
(Ok(_), Ok(_), Err(e3)) => {
writeln!(writer, "Decryption failed Record: {idx} Reason:{e3}",)?;
eprintln!("Decryption failed Record: {idx} Reason:{e3}");
if first_error.is_none() {
first_error = Some(e3);
}
}
}
}

Ok(())
match first_error {
None => Ok(()),
Some(err) => Err(Box::new(err)),
}
}

#[cfg(test)]
Expand Down

0 comments on commit 9baca44

Please sign in to comment.