mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-29 13:47:25 +00:00
60e5011c72
* Adding first rough ouline of the repository structure * Remove old CI stuff * add title * formatting fixes * move node-exits job's script to scripts dir * Move docs into subdir * move to bin * move maintainence scripts, configs and helpers into its own dir * add .local to ignore * move core->client * start up 'test' area * move test client * move test runtime * make test move compile * Add dependencies rule enforcement. * Fix indexing. * Update docs to reflect latest changes * Moving /srml->/paint * update docs * move client/sr-* -> primitives/ * clean old readme * remove old broken code in rhd * update lock * Step 1. * starting to untangle client * Fix after merge. * start splitting out client interfaces * move children and blockchain interfaces * Move trie and state-machine to primitives. * Fix WASM builds. * fixing broken imports * more interface moves * move backend and light to interfaces * move CallExecutor * move cli off client * moving around more interfaces * re-add consensus crates into the mix * fix subkey path * relieve client from executor * starting to pull out client from grandpa * move is_decendent_of out of client * grandpa still depends on client directly * lemme tests pass * rename srml->paint * Make it compile. * rename interfaces->client-api * Move keyring to primitives. * fixup libp2p dep * fix broken use * allow dependency enforcement to fail * move fork-tree * Moving wasm-builder * make env * move build-script-utils * fixup broken crate depdencies and names * fix imports for authority discovery * fix typo * update cargo.lock * fixing imports * Fix paths and add missing crates * re-add missing crates
177 lines
3.9 KiB
Rust
177 lines
3.9 KiB
Rust
// Copyright 2018-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Substrate is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use super::{PublicOf, PublicT, Crypto};
|
|
use primitives::Pair;
|
|
use rand::{rngs::OsRng, RngCore};
|
|
|
|
fn good_waypoint(done: u64) -> u64 {
|
|
match done {
|
|
0..=1_000_000 => 100_000,
|
|
0..=10_000_000 => 1_000_000,
|
|
0..=100_000_000 => 10_000_000,
|
|
_ => 100_000_000,
|
|
}
|
|
}
|
|
|
|
fn next_seed(seed: &mut [u8]) {
|
|
for i in 0..seed.len() {
|
|
match seed[i] {
|
|
255 => {
|
|
seed[i] = 0;
|
|
}
|
|
_ => {
|
|
seed[i] += 1;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/// A structure used to carry both Pair and seed.
|
|
/// This should usually NOT been used. If unsure, use Pair.
|
|
pub(super) struct KeyPair<C: Crypto> {
|
|
pub pair: C::Pair,
|
|
pub seed: <C::Pair as Pair>::Seed,
|
|
pub score: usize,
|
|
}
|
|
|
|
/// Calculate the score of a key based on the desired
|
|
/// input.
|
|
fn calculate_score(_desired: &str, key: &str) -> usize {
|
|
for truncate in 0.._desired.len() {
|
|
let snip_size = _desired.len() - truncate;
|
|
let truncated = &_desired[0..snip_size];
|
|
if let Some(pos) = key.find(truncated) {
|
|
return (47 - pos) + (snip_size * 48);
|
|
}
|
|
}
|
|
0
|
|
}
|
|
|
|
pub(super) fn generate_key<C: Crypto>(desired: &str) -> Result<KeyPair<C>, &str> where
|
|
PublicOf<C>: PublicT,
|
|
{
|
|
if desired.is_empty() {
|
|
return Err("Pattern must not be empty");
|
|
}
|
|
|
|
println!("Generating key containing pattern '{}'", desired);
|
|
|
|
let top = 45 + (desired.len() * 48);
|
|
let mut best = 0;
|
|
let mut seed = <C::Pair as Pair>::Seed::default();
|
|
let mut done = 0;
|
|
|
|
loop {
|
|
if done % 100000 == 0 {
|
|
OsRng.fill_bytes(seed.as_mut());
|
|
} else {
|
|
next_seed(seed.as_mut());
|
|
}
|
|
|
|
let p = C::Pair::from_seed(&seed);
|
|
let ss58 = C::ss58_from_pair(&p);
|
|
let score = calculate_score(&desired, &ss58);
|
|
if score > best || desired.len() < 2 {
|
|
best = score;
|
|
let keypair = KeyPair {
|
|
pair: p,
|
|
seed: seed.clone(),
|
|
score: score,
|
|
};
|
|
if best >= top {
|
|
println!("best: {} == top: {}", best, top);
|
|
return Ok(keypair);
|
|
}
|
|
}
|
|
done += 1;
|
|
|
|
if done % good_waypoint(done) == 0 {
|
|
println!("{} keys searched; best is {}/{} complete", done, best, top);
|
|
}
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::super::Ed25519;
|
|
use super::*;
|
|
use primitives::{crypto::Ss58Codec, Pair};
|
|
#[cfg(feature = "bench")]
|
|
use test::Bencher;
|
|
|
|
#[test]
|
|
fn test_generation_with_single_char() {
|
|
assert!(generate_key::<Ed25519>("j")
|
|
.unwrap()
|
|
.pair
|
|
.public()
|
|
.to_ss58check()
|
|
.contains("j"));
|
|
}
|
|
|
|
#[test]
|
|
fn test_score_1_char_100() {
|
|
let score = calculate_score("j", "5jolkadotwHY5k9GpdTgpqs9xjuNvtv8EcwCFpEeyEf3KHim");
|
|
assert_eq!(score, 94);
|
|
}
|
|
|
|
#[test]
|
|
fn test_score_100() {
|
|
let score = calculate_score(
|
|
"Polkadot",
|
|
"5PolkadotwHY5k9GpdTgpqs9xjuNvtv8EcwCFpEeyEf3KHim",
|
|
);
|
|
assert_eq!(score, 430);
|
|
}
|
|
|
|
#[test]
|
|
fn test_score_50_2() {
|
|
// 50% for the position + 50% for the size
|
|
assert_eq!(
|
|
calculate_score(
|
|
"Polkadot",
|
|
"5PolkXXXXwHY5k9GpdTgpqs9xjuNvtv8EcwCFpEeyEf3KHim"
|
|
),
|
|
238
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn test_score_0() {
|
|
assert_eq!(
|
|
calculate_score(
|
|
"Polkadot",
|
|
"5GUWv4bLCchGUHJrzULXnh4JgXsMpTKRnjuXTY7Qo1Kh9uYK"
|
|
),
|
|
0
|
|
);
|
|
}
|
|
|
|
#[cfg(feature = "bench")]
|
|
#[bench]
|
|
fn bench_paranoiac(b: &mut Bencher) {
|
|
b.iter(|| generate_key("polk"));
|
|
}
|
|
|
|
#[cfg(feature = "bench")]
|
|
#[bench]
|
|
fn bench_not_paranoiac(b: &mut Bencher) {
|
|
b.iter(|| generate_key("polk"));
|
|
}
|
|
}
|