mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 19:17:58 +00:00
Batch signature verification (#5023)
* create parallel tasks extension * make type system happy * basic externalities * test for dynamic extensions * batching test * remove premature verify_batch * shnschnorrkel batch * alter test * shnschnorrkel test * executive batching * some docs * also multi/any signatgures * error propagation * styling * make verification extension optional * experimental ed25519 parallelization * some merge fallout * utilize task executor * merge fallout * utilize task executor more * another merge fallout * feature-gate sp-io * arrange toml * fix no-std * sr25519 batching and refactoring * add docs * fix name * add newline * fix block import test * long sr25519 test * blocking instead of parking * move everything in crypto * return batch_verify to check :) * use condvars * use multi-threaded executor for benches * don't call via host interface * try no spawning * add true * cleanup * straighten batching * remove signature check from this test (?) * remove now pointless test * remove another now useless test * fix warnings * Revert "remove another now useless test" This reverts commit bbdec24bb67ed4373072daef7c863e1a8825bd8b. * rethink the sp-io-part * Revert "remove now pointless test" This reverts commit 4d553066322e65782264caa6053d4cd5538df977. * fix wording * add wording * add todo and fix * return check and fix * add logging in sp-io * Update primitives/io/src/batch_verifier.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * address review and use std condvar * account for early exit * address reivew * address review * more suggestions * add docs for batch verification * remove unused * more review suggestions * move to sp-runtime * add expects * remove blocks * use entry * Update primitives/io/src/batch_verifier.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Update primitives/externalities/src/extensions.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * update overlooked note * remove stupid return * Update primitives/io/src/lib.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Update primitives/io/src/lib.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * fix wording * bump spec_version Co-authored-by: cheme <emericchevalier.pro@gmail.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com>
This commit is contained in:
@@ -611,6 +611,45 @@ impl CryptoType for Pair {
|
||||
type Pair = Pair;
|
||||
}
|
||||
|
||||
/// Batch verification.
|
||||
///
|
||||
/// `messages`, `signatures` and `pub_keys` should all have equal length.
|
||||
///
|
||||
/// Returns `true` if all signatures are correct, `false` otherwise.
|
||||
#[cfg(feature = "std")]
|
||||
pub fn verify_batch(
|
||||
messages: Vec<&[u8]>,
|
||||
signatures: Vec<&Signature>,
|
||||
pub_keys: Vec<&Public>,
|
||||
) -> bool {
|
||||
let mut sr_pub_keys = Vec::with_capacity(pub_keys.len());
|
||||
for pub_key in pub_keys {
|
||||
match schnorrkel::PublicKey::from_bytes(pub_key.as_ref()) {
|
||||
Ok(pk) => sr_pub_keys.push(pk),
|
||||
Err(_) => return false,
|
||||
};
|
||||
}
|
||||
|
||||
let mut sr_signatures = Vec::with_capacity(signatures.len());
|
||||
for signature in signatures {
|
||||
match schnorrkel::Signature::from_bytes(signature.as_ref()) {
|
||||
Ok(s) => sr_signatures.push(s),
|
||||
Err(_) => return false
|
||||
};
|
||||
}
|
||||
|
||||
let mut messages: Vec<merlin::Transcript> = messages.into_iter().map(
|
||||
|msg| signing_context(SIGNING_CTX).bytes(msg)
|
||||
).collect();
|
||||
|
||||
schnorrkel::verify_batch(
|
||||
&mut messages,
|
||||
&sr_signatures,
|
||||
&sr_pub_keys,
|
||||
true,
|
||||
).is_ok()
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod compatibility_test {
|
||||
use super::*;
|
||||
|
||||
Reference in New Issue
Block a user