Use solana-cli config keypair in solana-keygen (#8074)
* Use solana-cli config keypair in solana-keygen * s/infile/keypair for consistency across modules and more generality across access methods * Move config into separate crate
This commit is contained in:
parent
408ef8b2cb
commit
fab8ef379f
|
@ -3658,7 +3658,6 @@ dependencies = [
|
||||||
"dirs 2.0.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"dirs 2.0.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"humantime 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"humantime 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"indicatif 0.14.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"indicatif 0.14.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"lazy_static 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"log 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"num-traits 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
"num-traits 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"pretty-hex 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"pretty-hex 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -3666,9 +3665,9 @@ dependencies = [
|
||||||
"serde 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
"serde 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"serde_derive 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
"serde_derive 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"serde_json 1.0.44 (registry+https://github.com/rust-lang/crates.io-index)",
|
"serde_json 1.0.44 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"serde_yaml 0.8.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"solana-budget-program 0.24.0",
|
"solana-budget-program 0.24.0",
|
||||||
"solana-clap-utils 0.24.0",
|
"solana-clap-utils 0.24.0",
|
||||||
|
"solana-cli-config 0.24.0",
|
||||||
"solana-client 0.24.0",
|
"solana-client 0.24.0",
|
||||||
"solana-config-program 0.24.0",
|
"solana-config-program 0.24.0",
|
||||||
"solana-core 0.24.0",
|
"solana-core 0.24.0",
|
||||||
|
@ -3685,6 +3684,17 @@ dependencies = [
|
||||||
"url 2.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"url 2.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "solana-cli-config"
|
||||||
|
version = "0.24.0"
|
||||||
|
dependencies = [
|
||||||
|
"dirs 2.0.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"lazy_static 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"serde 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"serde_derive 1.0.104 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"serde_yaml 0.8.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "solana-client"
|
name = "solana-client"
|
||||||
version = "0.24.0"
|
version = "0.24.0"
|
||||||
|
@ -3948,6 +3958,7 @@ dependencies = [
|
||||||
"num_cpus 1.12.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"num_cpus 1.12.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"rpassword 4.0.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rpassword 4.0.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"solana-clap-utils 0.24.0",
|
"solana-clap-utils 0.24.0",
|
||||||
|
"solana-cli-config 0.24.0",
|
||||||
"solana-sdk 0.24.0",
|
"solana-sdk 0.24.0",
|
||||||
"tiny-bip39 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"tiny-bip39 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
|
@ -7,6 +7,7 @@ members = [
|
||||||
"chacha",
|
"chacha",
|
||||||
"chacha-cuda",
|
"chacha-cuda",
|
||||||
"chacha-sys",
|
"chacha-sys",
|
||||||
|
"cli-config",
|
||||||
"client",
|
"client",
|
||||||
"core",
|
"core",
|
||||||
"faucet",
|
"faucet",
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
[package]
|
||||||
|
authors = ["Solana Maintainers <maintainers@solana.com>"]
|
||||||
|
edition = "2018"
|
||||||
|
name = "solana-cli-config"
|
||||||
|
description = "Blockchain, Rebuilt for Scale"
|
||||||
|
version = "0.24.0"
|
||||||
|
repository = "https://github.com/solana-labs/solana"
|
||||||
|
license = "Apache-2.0"
|
||||||
|
homepage = "https://solana.com/"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
dirs = "2.0.2"
|
||||||
|
lazy_static = "1.4.0"
|
||||||
|
serde = "1.0.104"
|
||||||
|
serde_derive = "1.0.103"
|
||||||
|
serde_yaml = "0.8.11"
|
|
@ -1,8 +1,10 @@
|
||||||
// Wallet settings that can be configured for long-term use
|
// Wallet settings that can be configured for long-term use
|
||||||
use serde_derive::{Deserialize, Serialize};
|
use serde_derive::{Deserialize, Serialize};
|
||||||
use std::fs::{create_dir_all, File};
|
use std::{
|
||||||
use std::io::{self, Write};
|
fs::{create_dir_all, File},
|
||||||
use std::path::Path;
|
io::{self, Write},
|
||||||
|
path::Path,
|
||||||
|
};
|
||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
pub static ref CONFIG_FILE: Option<String> = {
|
pub static ref CONFIG_FILE: Option<String> = {
|
|
@ -0,0 +1,4 @@
|
||||||
|
#[macro_use]
|
||||||
|
extern crate lazy_static;
|
||||||
|
|
||||||
|
pub mod config;
|
|
@ -17,7 +17,6 @@ criterion-stats = "0.3.0"
|
||||||
ctrlc = { version = "3.1.3", features = ["termination"] }
|
ctrlc = { version = "3.1.3", features = ["termination"] }
|
||||||
console = "0.9.2"
|
console = "0.9.2"
|
||||||
dirs = "2.0.2"
|
dirs = "2.0.2"
|
||||||
lazy_static = "1.4.0"
|
|
||||||
log = "0.4.8"
|
log = "0.4.8"
|
||||||
indicatif = "0.14.0"
|
indicatif = "0.14.0"
|
||||||
humantime = "2.0.0"
|
humantime = "2.0.0"
|
||||||
|
@ -27,9 +26,9 @@ reqwest = { version = "0.10.1", default-features = false, features = ["blocking"
|
||||||
serde = "1.0.104"
|
serde = "1.0.104"
|
||||||
serde_derive = "1.0.103"
|
serde_derive = "1.0.103"
|
||||||
serde_json = "1.0.44"
|
serde_json = "1.0.44"
|
||||||
serde_yaml = "0.8.11"
|
|
||||||
solana-budget-program = { path = "../programs/budget", version = "0.24.0" }
|
solana-budget-program = { path = "../programs/budget", version = "0.24.0" }
|
||||||
solana-clap-utils = { path = "../clap-utils", version = "0.24.0" }
|
solana-clap-utils = { path = "../clap-utils", version = "0.24.0" }
|
||||||
|
solana-cli-config = { path = "../cli-config", version = "0.24.0" }
|
||||||
solana-client = { path = "../client", version = "0.24.0" }
|
solana-client = { path = "../client", version = "0.24.0" }
|
||||||
solana-config-program = { path = "../programs/config", version = "0.24.0" }
|
solana-config-program = { path = "../programs/config", version = "0.24.0" }
|
||||||
solana-faucet = { path = "../faucet", version = "0.24.0" }
|
solana-faucet = { path = "../faucet", version = "0.24.0" }
|
||||||
|
|
|
@ -1,9 +1,5 @@
|
||||||
#[macro_use]
|
|
||||||
extern crate lazy_static;
|
|
||||||
|
|
||||||
pub mod cli;
|
pub mod cli;
|
||||||
pub mod cluster_query;
|
pub mod cluster_query;
|
||||||
pub mod config;
|
|
||||||
pub mod display;
|
pub mod display;
|
||||||
pub mod nonce;
|
pub mod nonce;
|
||||||
pub mod offline;
|
pub mod offline;
|
||||||
|
|
|
@ -10,9 +10,9 @@ use solana_clap_utils::{
|
||||||
};
|
};
|
||||||
use solana_cli::{
|
use solana_cli::{
|
||||||
cli::{app, parse_command, process_command, CliCommandInfo, CliConfig, CliError},
|
cli::{app, parse_command, process_command, CliCommandInfo, CliConfig, CliError},
|
||||||
config::{self, Config},
|
|
||||||
display::{println_name_value, println_name_value_or},
|
display::{println_name_value, println_name_value_or},
|
||||||
};
|
};
|
||||||
|
use solana_cli_config::config::{Config, CONFIG_FILE};
|
||||||
use solana_sdk::signature::read_keypair_file;
|
use solana_sdk::signature::read_keypair_file;
|
||||||
|
|
||||||
use std::error;
|
use std::error;
|
||||||
|
@ -162,7 +162,7 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.global(true)
|
.global(true)
|
||||||
.help("Configuration file to use");
|
.help("Configuration file to use");
|
||||||
if let Some(ref config_file) = *config::CONFIG_FILE {
|
if let Some(ref config_file) = *CONFIG_FILE {
|
||||||
arg.default_value(&config_file)
|
arg.default_value(&config_file)
|
||||||
} else {
|
} else {
|
||||||
arg
|
arg
|
||||||
|
|
|
@ -15,6 +15,7 @@ dirs = "2.0.2"
|
||||||
num_cpus = "1.12.0"
|
num_cpus = "1.12.0"
|
||||||
rpassword = "4.0"
|
rpassword = "4.0"
|
||||||
solana-clap-utils = { path = "../clap-utils", version = "0.24.0" }
|
solana-clap-utils = { path = "../clap-utils", version = "0.24.0" }
|
||||||
|
solana-cli-config = { path = "../cli-config", version = "0.24.0" }
|
||||||
solana-sdk = { path = "../sdk", version = "0.24.0" }
|
solana-sdk = { path = "../sdk", version = "0.24.0" }
|
||||||
tiny-bip39 = "0.7.0"
|
tiny-bip39 = "0.7.0"
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@ use num_cpus;
|
||||||
use solana_clap_utils::keypair::{
|
use solana_clap_utils::keypair::{
|
||||||
keypair_from_seed_phrase, prompt_passphrase, ASK_KEYWORD, SKIP_SEED_PHRASE_VALIDATION_ARG,
|
keypair_from_seed_phrase, prompt_passphrase, ASK_KEYWORD, SKIP_SEED_PHRASE_VALIDATION_ARG,
|
||||||
};
|
};
|
||||||
|
use solana_cli_config::config::{Config, CONFIG_FILE};
|
||||||
use solana_sdk::{
|
use solana_sdk::{
|
||||||
pubkey::write_pubkey_file,
|
pubkey::write_pubkey_file,
|
||||||
signature::{
|
signature::{
|
||||||
|
@ -44,23 +45,28 @@ fn check_for_overwrite(outfile: &str, matches: &ArgMatches) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_keypair_from_matches(matches: &ArgMatches) -> Result<Keypair, Box<dyn error::Error>> {
|
fn get_keypair_from_matches(
|
||||||
|
matches: &ArgMatches,
|
||||||
|
config: Config,
|
||||||
|
) -> Result<Keypair, Box<dyn error::Error>> {
|
||||||
let mut path = dirs::home_dir().expect("home directory");
|
let mut path = dirs::home_dir().expect("home directory");
|
||||||
let infile = if matches.is_present("infile") {
|
let keypair = if matches.is_present("keypair") {
|
||||||
matches.value_of("infile").unwrap()
|
matches.value_of("keypair").unwrap()
|
||||||
|
} else if config.keypair_path != "" {
|
||||||
|
&config.keypair_path
|
||||||
} else {
|
} else {
|
||||||
path.extend(&[".config", "solana", "id.json"]);
|
path.extend(&[".config", "solana", "id.json"]);
|
||||||
path.to_str().unwrap()
|
path.to_str().unwrap()
|
||||||
};
|
};
|
||||||
|
|
||||||
if infile == "-" {
|
if keypair == "-" {
|
||||||
let mut stdin = std::io::stdin();
|
let mut stdin = std::io::stdin();
|
||||||
read_keypair(&mut stdin)
|
read_keypair(&mut stdin)
|
||||||
} else if infile == ASK_KEYWORD {
|
} else if keypair == ASK_KEYWORD {
|
||||||
let skip_validation = matches.is_present(SKIP_SEED_PHRASE_VALIDATION_ARG.name);
|
let skip_validation = matches.is_present(SKIP_SEED_PHRASE_VALIDATION_ARG.name);
|
||||||
keypair_from_seed_phrase("pubkey recovery", skip_validation, false)
|
keypair_from_seed_phrase("pubkey recovery", skip_validation, false)
|
||||||
} else {
|
} else {
|
||||||
read_keypair_file(infile)
|
read_keypair_file(keypair)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -193,23 +199,38 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
||||||
.about(crate_description!())
|
.about(crate_description!())
|
||||||
.version(solana_clap_utils::version!())
|
.version(solana_clap_utils::version!())
|
||||||
.setting(AppSettings::SubcommandRequiredElseHelp)
|
.setting(AppSettings::SubcommandRequiredElseHelp)
|
||||||
|
.arg({
|
||||||
|
let arg = Arg::with_name("config_file")
|
||||||
|
.short("C")
|
||||||
|
.long("config")
|
||||||
|
.value_name("PATH")
|
||||||
|
.takes_value(true)
|
||||||
|
.global(true)
|
||||||
|
.help("Configuration file to use");
|
||||||
|
if let Some(ref config_file) = *CONFIG_FILE {
|
||||||
|
arg.default_value(&config_file)
|
||||||
|
} else {
|
||||||
|
arg
|
||||||
|
}
|
||||||
|
})
|
||||||
.subcommand(
|
.subcommand(
|
||||||
SubCommand::with_name("verify")
|
SubCommand::with_name("verify")
|
||||||
.about("Verify a keypair can sign and verify a message.")
|
.about("Verify a keypair can sign and verify a message.")
|
||||||
.arg(
|
.arg(
|
||||||
Arg::with_name("infile")
|
Arg::with_name("pubkey")
|
||||||
.index(1)
|
.index(1)
|
||||||
|
.value_name("BASE58_PUBKEY")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
|
.help("Public key"),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("keypair")
|
||||||
|
.index(2)
|
||||||
.value_name("PATH")
|
.value_name("PATH")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.help("Path to keypair file"),
|
.help("Path to keypair file"),
|
||||||
)
|
)
|
||||||
.arg(
|
|
||||||
Arg::with_name("pubkey")
|
|
||||||
.index(2)
|
|
||||||
.value_name("BASE58_PUBKEY")
|
|
||||||
.takes_value(true)
|
|
||||||
.help("Public key"),
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
.subcommand(
|
.subcommand(
|
||||||
SubCommand::with_name("new")
|
SubCommand::with_name("new")
|
||||||
|
@ -301,7 +322,7 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
||||||
.about("Display the pubkey from a keypair file")
|
.about("Display the pubkey from a keypair file")
|
||||||
.setting(AppSettings::DisableVersion)
|
.setting(AppSettings::DisableVersion)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::with_name("infile")
|
Arg::with_name("keypair")
|
||||||
.index(1)
|
.index(1)
|
||||||
.value_name("PATH")
|
.value_name("PATH")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
@ -353,10 +374,15 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
||||||
|
|
||||||
)
|
)
|
||||||
.get_matches();
|
.get_matches();
|
||||||
|
let config = if let Some(config_file) = matches.value_of("config_file") {
|
||||||
|
Config::load(config_file).unwrap_or_default()
|
||||||
|
} else {
|
||||||
|
Config::default()
|
||||||
|
};
|
||||||
|
|
||||||
match matches.subcommand() {
|
match matches.subcommand() {
|
||||||
("pubkey", Some(matches)) => {
|
("pubkey", Some(matches)) => {
|
||||||
let keypair = get_keypair_from_matches(matches)?;
|
let keypair = get_keypair_from_matches(matches, config)?;
|
||||||
|
|
||||||
if matches.is_present("outfile") {
|
if matches.is_present("outfile") {
|
||||||
let outfile = matches.value_of("outfile").unwrap();
|
let outfile = matches.value_of("outfile").unwrap();
|
||||||
|
@ -533,7 +559,7 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
("verify", Some(matches)) => {
|
("verify", Some(matches)) => {
|
||||||
let keypair = get_keypair_from_matches(matches)?;
|
let keypair = get_keypair_from_matches(matches, config)?;
|
||||||
let test_data = b"test";
|
let test_data = b"test";
|
||||||
let signature = Signature::new(&keypair.sign(test_data).to_bytes());
|
let signature = Signature::new(&keypair.sign(test_data).to_bytes());
|
||||||
let pubkey_bs58 = matches.value_of("pubkey").unwrap();
|
let pubkey_bs58 = matches.value_of("pubkey").unwrap();
|
||||||
|
|
Loading…
Reference in New Issue