Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

BLS Core Crypto attempt #2 #13618

Merged
merged 49 commits into from
May 9, 2023
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
b845210
Cherry pick all crypto related changes from pull-request #13311
drskalman Mar 15, 2023
081ced0
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 20, 2023
f411d74
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 20, 2023
ee61ddb
Import some stuff just if 'full_crypto' is on
davxy Mar 21, 2023
a1e0f13
Remove copyright year
davxy Mar 21, 2023
7023c14
Cleanup
davxy Mar 21, 2023
d92186d
First generic BLS draft
davxy Mar 21, 2023
409b2f4
Finalize generic implementation
davxy Mar 23, 2023
7177bb1
Restore tests
davxy Mar 23, 2023
9b320cd
Merge pull request #13 from davxy/davxyn-skalman-core-bls-crypto-generic
davxy Mar 23, 2023
58d4122
Fix rust docs
davxy Mar 23, 2023
1e331c0
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 23, 2023
a630ead
Fix after master merge
davxy Mar 23, 2023
8a34867
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 24, 2023
5c47d33
Fix after master merge
davxy Mar 24, 2023
fe65fce
Use double bls with G1 as signature group and verify individual signa…
drskalman Mar 28, 2023
b278ba7
Fix inclusions and types used within substrate
davxy Mar 29, 2023
3d50a72
Remove unused cruft
davxy Mar 29, 2023
994a805
Restore usage of upstream crates
davxy Mar 29, 2023
d728537
Fix test
davxy Mar 29, 2023
fbb2f47
Reduce the diff by aligning Cargo.lock to master
davxy Mar 29, 2023
bc52143
Application-crypto provides bls381
davxy Mar 29, 2023
eb8a7ab
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 29, 2023
0acdf5c
Implement bls381 for local keystore
davxy Mar 29, 2023
26d9ce2
Merge branch 'master' into davxyn-skalman-core-bls-crypto
davxy Mar 30, 2023
9de1515
Use new generic keystore features
davxy Mar 30, 2023
267538f
import DoublePublickey[Scheme] from the bls-like root to be less conf…
drskalman Apr 4, 2023
e3c2af8
Merge branch 'master' into davxyn-skalman-core-bls-crypto
andresilva Apr 12, 2023
2a0a0ca
fix compilation
andresilva Apr 12, 2023
de48262
Apply suggestions from code review
davxy Apr 13, 2023
7d709da
Clean leftovers
davxy Apr 13, 2023
a2b7308
- update bls test vector after applying spec change recommendation.
drskalman Apr 13, 2023
478da9b
Merge branch 'davxyn-skalman-core-bls-crypto' of https://github.com/w…
drskalman Apr 13, 2023
426c5ae
Different hard junction ids for different bls12 types
davxy Apr 13, 2023
da36af4
update to new bls-like
drskalman Apr 13, 2023
856881a
Merge branch 'davxyn-skalman-core-bls-crypto' of https://github.com/w…
drskalman Apr 13, 2023
0c7a5f7
bls-like → w3f-bls
drskalman Apr 16, 2023
9218d9c
Make clippy happy
davxy Apr 16, 2023
58c2d94
update test vector after replacing hash and crop with hash to field.
drskalman Apr 19, 2023
6041fec
cargo fmt
drskalman Apr 19, 2023
f9b0da0
Merge branch 'master' into davxyn-skalman-core-bls-crypto
drskalman Apr 19, 2023
758a169
Merge remote-tracking branch 'upstream/master' into HEAD
Lederstrumpf Apr 25, 2023
b11659d
account for #13972
Lederstrumpf Apr 25, 2023
3a9c5ed
hide BLS behind "bls_non_production" feature flag
Lederstrumpf Apr 25, 2023
0bfbcfd
Merge remote-tracking branch 'upstream/master' into davxyn-skalman-co…
Lederstrumpf May 4, 2023
5a1a9cc
Remove Cargo.lock entries duplicated in merge
Lederstrumpf May 4, 2023
2e48a99
add bls377 to primitives/keystore and client/keystore
drskalman May 9, 2023
270b32e
rename feature `bls_non_production` to `bls-experimental`
drskalman May 9, 2023
35b9167
Merge branch 'master' into davxyn-skalman-core-bls-crypto
drskalman May 9, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
172 changes: 172 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

46 changes: 42 additions & 4 deletions client/keystore/src/local.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,11 @@
//! Local keystore implementation

use parking_lot::RwLock;
use sp_application_crypto::{ecdsa, ed25519, sr25519, AppKey, AppPair, IsWrappedBy};
use sp_application_crypto::{bls377, ecdsa, ed25519, sr25519, AppKey, AppPair, IsWrappedBy};
use sp_core::{
crypto::{
ByteArray, CryptoTypePublicPair, ExposeSecret, KeyTypeId, Pair as PairT, SecretString,
},
sr25519::{Pair as Sr25519Pair, Public as Sr25519Public},
Encode,
};
use sp_keystore::{
Expand Down Expand Up @@ -231,11 +230,11 @@ impl Keystore for LocalKeystore {
fn sr25519_vrf_sign(
&self,
key_type: KeyTypeId,
public: &Sr25519Public,
public: &sr25519::Public,
transcript_data: VRFTranscriptData,
) -> std::result::Result<Option<VRFSignature>, TraitError> {
let transcript = make_transcript(transcript_data);
let pair = self.0.read().key_pair_by_type::<Sr25519Pair>(public, key_type)?;
let pair = self.0.read().key_pair_by_type::<sr25519::Pair>(public, key_type)?;

if let Some(pair) = pair {
let (inout, proof, _) = pair.as_ref().vrf_sign(transcript);
Expand All @@ -255,6 +254,45 @@ impl Keystore for LocalKeystore {

pair.map(|k| k.sign_prehashed(msg)).map(Ok).transpose()
}

/// Returns all bls public keys for the given key type.
fn bls377_public_keys(&self, _id: KeyTypeId) -> Vec<bls377::Public> {
unimplemented!()
}

/// Generate a new bls key pair for the given key type and an optional seed.
///
/// If the given seed is `Some(_)`, the key pair will only be stored in memory.
///
/// Returns the public key of the generated key pair.
fn bls377_generate_new(
&self,
_id: KeyTypeId,
_seed: Option<&str>,
) -> std::result::Result<bls377::Public, TraitError> {
unimplemented!()
}

/// Generate an BLS signature for a given message.
///
/// Receives [`KeyTypeId`] and an [`bls377::Public`] key to be able to map
/// them to a private key that exists in the keystore. This private key is,
/// in turn, used for signing the provided message.
///
/// The `msg` argument provided should be a message for which an
/// BLS12-377 signature should be generated.
///
/// Returns an [`bls377::Signature`] or `None` in case the given `id` and
/// `public` combination doesn't exist in the keystore. An `Err` will be
/// returned if generating the signature itself failed.
fn bls377_sign(
&self,
_id: KeyTypeId,
_public: &bls377::Public,
_msg: &[u8],
) -> std::result::Result<Option<bls377::Signature>, TraitError> {
unimplemented!()
}
}

impl Into<KeystorePtr> for LocalKeystore {
Expand Down
62 changes: 62 additions & 0 deletions primitives/application-crypto/src/bls377.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
// This file is part of Substrate.

// Copyright (C) Parity Technologies (UK) Ltd.
// SPDX-License-Identifier: Apache-2.0

// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

//! BLS12-377 crypto applications.

use crate::{KeyTypeId, RuntimePublic};

use sp_std::vec::Vec;

pub use sp_core::bls::bls377::*;

mod app {
use sp_core::testing::BLS377;

crate::app_crypto!(super, BLS377);

impl crate::traits::BoundToRuntimeAppPublic for Public {
type Public = Self;
}
}

#[cfg(feature = "full_crypto")]
pub use app::Pair as AppPair;
pub use app::{Public as AppPublic, Signature as AppSignature};

impl RuntimePublic for Public {
davxy marked this conversation as resolved.
Show resolved Hide resolved
type Signature = Signature;

fn all(_key_type: KeyTypeId) -> crate::Vec<Self> {
unreachable!("no access to the host keystore from runtime")
}

fn generate_pair(_key_type: KeyTypeId, _seed: Option<Vec<u8>>) -> Self {
unreachable!("no access to the host keystore from runtime")
}

fn sign<M: AsRef<[u8]>>(&self, _key_type: KeyTypeId, _msg: &M) -> Option<Self::Signature> {
unreachable!("no access to the host keystore from runtime")
}

fn verify<M: AsRef<[u8]>>(&self, _msg: &M, _signature: &Self::Signature) -> bool {
unreachable!("no access to the host keystore from runtime")
}

fn to_raw_vec(&self) -> Vec<u8> {
sp_core::crypto::ByteArray::to_raw_vec(self)
}
}
1 change: 1 addition & 0 deletions primitives/application-crypto/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ pub use serde;
#[doc(hidden)]
pub use sp_std::{ops::Deref, vec::Vec};

pub mod bls377;
davxy marked this conversation as resolved.
Show resolved Hide resolved
pub mod ecdsa;
pub mod ed25519;
pub mod sr25519;
Expand Down
6 changes: 6 additions & 0 deletions primitives/core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,10 @@ schnorrkel = { version = "0.9.1", features = [
"preaudit_deprecated",
"u64_backend",
], default-features = false, optional = true }
bls-like = {git = "https://github.com/w3f/bls", branch = "skalman-hash-to-curve-wb", default-features = false}
drskalman marked this conversation as resolved.
Show resolved Hide resolved
#bls-like = {version="*", default-features = false }
sha2 = { version = "0.10.0", default-features = false, optional = true }
hex = { version = "0.4", default-features = false, optional = true}
libsecp256k1 = { version = "0.7", default-features = false, features = ["static-context"], optional = true }
merlin = { version = "2.0", default-features = false, optional = true }
secp256k1 = { version = "0.24.0", default-features = false, features = ["recovery", "alloc"], optional = true }
Expand All @@ -64,6 +68,7 @@ rand = "0.8.5"
criterion = "0.4.0"
serde_json = "1.0"
sp-core-hashing-proc-macro = { version = "5.0.0", path = "./hashing/proc-macro" }
hex-literal = "0.3.4"

[[bench]]
name = "bench"
Expand Down Expand Up @@ -116,6 +121,7 @@ std = [
"futures/thread-pool",
"libsecp256k1/std",
"dyn-clonable",
"hex",
]

# This feature enables all crypto primitives for `no_std` builds like microcontrollers
Expand Down
Loading