mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-09 19:57:59 +00:00
6963272451
* draft * revert * WIP * all that remains is tests * update Cargo.lock * tests WIP * WIP refactor node-template-runtime and node-runtime * implments sc_cli::RuntimeAdapter for node_template_runtime::Runtime * final draft * fix update_config for subcommands * proper AccountId decoding * test-runtime tests * revert * move RuntimeAdapter to cli-utils * use &'static str for TryFrom::<&'a str>::Error for Ss58AddressFormat * tests * add frame-system to sc-cli dev-dependencies * add frame-system to sc-cli dev-dependencies * fix ui test * wip * fixed inspect test * bump impl version * bump impl version, fixx spaces remove todos * pallet-balances-cli, rustc for some reason cannot resolve pallet_balances_cli in node-cli 😩 * wip * Subcommand::run takes &self * can't believe i missed that 🤦🏾♂️ * bump wasm-bindgen for some reason * adds key subcommand, rename generate-node-key to generate-node-id * cargo update and crossed fingers 🤞🏽 * update ui test * update more ui tests * should be all good now * revert subkey change * revert subkey change * adds frame-utilities-cli * Apply suggestions from code review Co-authored-by: Benjamin Kampmann <ben@gnunicorn.org> * removes frame from sc-cli, fix license * my editor and ci disagrees on line width * bump spec version * turn off default features for parity-scale-codec * enable full_crypto feature for sp-core in cli-utils * merge frame-utilities-cli with pallet-balances-cli * remove full_crypto feature from sp_core in cli-utils * bump Cargo.lock * cli-utils -> frame-utils * rename BlockNumber to GenericNumber, fix spaces * fix spaces * construct additional_signed manually * sign test * remove unused vars * implement subkey with frame-utilities-cli and sc_cli * fix moduleid test * CI and clion disagree on line widths * adds associated Params type to SignedExtensionProvider * Apply suggestions from code review Co-authored-by: Benjamin Kampmann <ben@gnunicorn.org> * move some code around * removes unneccesary generic params * moves module_id back to frame_utilities_cli * Apply suggestions from code review Co-authored-by: Benjamin Kampmann <ben@gnunicorn.org> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * remove print_ext * remove MaybeDisplay from pallet_balances::Trait::Balance * a lot of stuff tbh * adds ExtrasParamsBuilder * remove tests for ModuleIdCmd * address comments from PR * bump Cargo.lock * manually insert key into keystore * remove unnecessary SharedParams * add validation to vanity pattern, remove unused arg * remove SharedParams from Sign, Vanity, Verify * remove SharedParams from ModuleIdCmd, remove expect from Verify, new line to Cargo.toml * remove SharedParams from InsertCmd * 🤦🏾♂️ * deleted prometheus.yml * move a few things around * fix vanity test Co-authored-by: Benjamin Kampmann <ben@gnunicorn.org> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Benjamin Kampmann <ben@parity.io>
95 lines
2.9 KiB
Rust
95 lines
2.9 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2020 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.
|
|
|
|
//! Implementation of the `insert` subcommand
|
|
|
|
use crate::{Error, KeystoreParams, CryptoSchemeFlag, SharedParams, utils, with_crypto_scheme};
|
|
use structopt::StructOpt;
|
|
use sp_core::{crypto::KeyTypeId, traits::BareCryptoStore};
|
|
use std::convert::TryFrom;
|
|
use sc_service::config::KeystoreConfig;
|
|
use sc_keystore::Store as KeyStore;
|
|
use sp_core::crypto::SecretString;
|
|
|
|
/// The `insert` command
|
|
#[derive(Debug, StructOpt)]
|
|
#[structopt(
|
|
name = "insert",
|
|
about = "Insert a key to the keystore of a node."
|
|
)]
|
|
pub struct InsertCmd {
|
|
/// The secret key URI.
|
|
/// If the value is a file, the file content is used as URI.
|
|
/// If not given, you will be prompted for the URI.
|
|
#[structopt(long)]
|
|
suri: Option<String>,
|
|
|
|
/// Key type, examples: "gran", or "imon"
|
|
#[structopt(long)]
|
|
key_type: String,
|
|
|
|
#[allow(missing_docs)]
|
|
#[structopt(flatten)]
|
|
pub shared_params: SharedParams,
|
|
|
|
#[allow(missing_docs)]
|
|
#[structopt(flatten)]
|
|
pub keystore_params: KeystoreParams,
|
|
|
|
#[allow(missing_docs)]
|
|
#[structopt(flatten)]
|
|
pub crypto_scheme: CryptoSchemeFlag,
|
|
}
|
|
|
|
impl InsertCmd {
|
|
/// Run the command
|
|
pub fn run(&self) -> Result<(), Error> {
|
|
let suri = utils::read_uri(self.suri.as_ref())?;
|
|
let base_path = self.shared_params.base_path.as_ref()
|
|
.ok_or_else(|| Error::Other("please supply base path".into()))?;
|
|
|
|
let (keystore, public) = match self.keystore_params.keystore_config(base_path)? {
|
|
KeystoreConfig::Path { path, password } => {
|
|
let public = with_crypto_scheme!(
|
|
self.crypto_scheme.scheme,
|
|
to_vec(&suri, password.clone())
|
|
)?;
|
|
let keystore = KeyStore::open(path, password)
|
|
.map_err(|e| format!("{}", e))?;
|
|
(keystore, public)
|
|
},
|
|
_ => unreachable!("keystore_config always returns path and password; qed")
|
|
};
|
|
|
|
let key_type = KeyTypeId::try_from(self.key_type.as_str())
|
|
.map_err(|_| {
|
|
Error::Other("Cannot convert argument to keytype: argument should be 4-character string".into())
|
|
})?;
|
|
|
|
keystore.write()
|
|
.insert_unknown(key_type, &suri, &public[..])
|
|
.map_err(|e| Error::Other(format!("{:?}", e)))?;
|
|
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
fn to_vec<P: sp_core::Pair>(uri: &str, pass: Option<SecretString>) -> Result<Vec<u8>, Error> {
|
|
let p = utils::pair_from_suri::<P>(uri, pass)?;
|
|
Ok(p.public().as_ref().to_vec())
|
|
}
|