Pass the owner's keypair to fullnode-config
This commit is contained in:
committed by
Greg Fitzgerald
parent
77543d83ff
commit
545f4f1c87
@@ -71,6 +71,7 @@ done
|
|||||||
|
|
||||||
leader_address_args=("$ip_address_arg")
|
leader_address_args=("$ip_address_arg")
|
||||||
validator_address_args=("$ip_address_arg" -b 9000)
|
validator_address_args=("$ip_address_arg" -b 9000)
|
||||||
|
keypair_arg=(--keypair="$SOLANA_CONFIG_PRIVATE_DIR/id.json")
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
@@ -78,11 +79,12 @@ echo "Cleaning $SOLANA_CONFIG_DIR"
|
|||||||
rm -rvf "$SOLANA_CONFIG_DIR"
|
rm -rvf "$SOLANA_CONFIG_DIR"
|
||||||
mkdir -p "$SOLANA_CONFIG_DIR"
|
mkdir -p "$SOLANA_CONFIG_DIR"
|
||||||
|
|
||||||
|
|
||||||
if $node_type_leader; then
|
|
||||||
rm -rvf "$SOLANA_CONFIG_PRIVATE_DIR"
|
rm -rvf "$SOLANA_CONFIG_PRIVATE_DIR"
|
||||||
mkdir -p "$SOLANA_CONFIG_PRIVATE_DIR"
|
mkdir -p "$SOLANA_CONFIG_PRIVATE_DIR"
|
||||||
|
|
||||||
|
$solana_keygen -o "$SOLANA_CONFIG_PRIVATE_DIR"/id.json
|
||||||
|
|
||||||
|
if $node_type_leader; then
|
||||||
echo "Creating $SOLANA_CONFIG_DIR/mint.json with $num_tokens tokens"
|
echo "Creating $SOLANA_CONFIG_DIR/mint.json with $num_tokens tokens"
|
||||||
$solana_keygen -o "$SOLANA_CONFIG_PRIVATE_DIR"/mint.json
|
$solana_keygen -o "$SOLANA_CONFIG_PRIVATE_DIR"/mint.json
|
||||||
|
|
||||||
@@ -90,13 +92,13 @@ if $node_type_leader; then
|
|||||||
$solana_genesis --tokens="$num_tokens" < "$SOLANA_CONFIG_PRIVATE_DIR"/mint.json > "$SOLANA_CONFIG_DIR"/genesis.log
|
$solana_genesis --tokens="$num_tokens" < "$SOLANA_CONFIG_PRIVATE_DIR"/mint.json > "$SOLANA_CONFIG_DIR"/genesis.log
|
||||||
|
|
||||||
echo "Creating $SOLANA_CONFIG_DIR/leader.json"
|
echo "Creating $SOLANA_CONFIG_DIR/leader.json"
|
||||||
$solana_fullnode_config "${leader_address_args[@]}" > "$SOLANA_CONFIG_DIR"/leader.json
|
$solana_fullnode_config "${keypair_arg}" "${leader_address_args[@]}" > "$SOLANA_CONFIG_DIR"/leader.json
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
if $node_type_validator; then
|
if $node_type_validator; then
|
||||||
echo "Creating $SOLANA_CONFIG_DIR/validator.json"
|
echo "Creating $SOLANA_CONFIG_DIR/validator.json"
|
||||||
$solana_fullnode_config "${validator_address_args[@]}" > "$SOLANA_CONFIG_DIR"/validator.json
|
$solana_fullnode_config "${keypair_arg}" "${validator_address_args[@]}" > "$SOLANA_CONFIG_DIR"/validator.json
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ls -lh "$SOLANA_CONFIG_DIR"/
|
ls -lh "$SOLANA_CONFIG_DIR"/
|
||||||
|
@@ -6,6 +6,8 @@ use clap::{App, Arg};
|
|||||||
use solana::crdt::{get_ip_addr, parse_port_or_addr};
|
use solana::crdt::{get_ip_addr, parse_port_or_addr};
|
||||||
use solana::fullnode::Config;
|
use solana::fullnode::Config;
|
||||||
use solana::nat::get_public_ip_addr;
|
use solana::nat::get_public_ip_addr;
|
||||||
|
use solana::signature::read_pkcs8;
|
||||||
|
use std::env;
|
||||||
use std::io;
|
use std::io;
|
||||||
use std::net::SocketAddr;
|
use std::net::SocketAddr;
|
||||||
|
|
||||||
@@ -18,6 +20,14 @@ fn main() {
|
|||||||
.takes_value(false)
|
.takes_value(false)
|
||||||
.help("detect network address from local machine configuration"),
|
.help("detect network address from local machine configuration"),
|
||||||
)
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("keypair")
|
||||||
|
.short("k")
|
||||||
|
.long("keypair")
|
||||||
|
.value_name("PATH")
|
||||||
|
.takes_value(true)
|
||||||
|
.help("/path/to/id.json"),
|
||||||
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::with_name("public")
|
Arg::with_name("public")
|
||||||
.short("p")
|
.short("p")
|
||||||
@@ -54,9 +64,18 @@ fn main() {
|
|||||||
bind_addr
|
bind_addr
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let mut path = env::home_dir().expect("home directory");
|
||||||
|
let id_path = if matches.is_present("keypair") {
|
||||||
|
matches.value_of("keypair").unwrap()
|
||||||
|
} else {
|
||||||
|
path.extend(&[".config", "solana", "id.json"]);
|
||||||
|
path.to_str().unwrap()
|
||||||
|
};
|
||||||
|
let pkcs8 = read_pkcs8(id_path).expect("client keypair");
|
||||||
|
|
||||||
// we need all the receiving sockets to be bound within the expected
|
// we need all the receiving sockets to be bound within the expected
|
||||||
// port range that we open on aws
|
// port range that we open on aws
|
||||||
let config = Config::new(&bind_addr);
|
let config = Config::new(&bind_addr, pkcs8);
|
||||||
let stdout = io::stdout();
|
let stdout = io::stdout();
|
||||||
serde_json::to_writer(stdout, &config).expect("serialize");
|
serde_json::to_writer(stdout, &config).expect("serialize");
|
||||||
}
|
}
|
||||||
|
@@ -7,7 +7,6 @@ use entry_writer;
|
|||||||
use ledger::Block;
|
use ledger::Block;
|
||||||
use ncp::Ncp;
|
use ncp::Ncp;
|
||||||
use packet::BlobRecycler;
|
use packet::BlobRecycler;
|
||||||
use ring::rand::SystemRandom;
|
|
||||||
use rpu::Rpu;
|
use rpu::Rpu;
|
||||||
use service::Service;
|
use service::Service;
|
||||||
use signature::{KeyPair, KeyPairUtil};
|
use signature::{KeyPair, KeyPairUtil};
|
||||||
@@ -50,11 +49,7 @@ pub struct Config {
|
|||||||
|
|
||||||
/// Structure to be replicated by the network
|
/// Structure to be replicated by the network
|
||||||
impl Config {
|
impl Config {
|
||||||
pub fn new(bind_addr: &SocketAddr) -> Self {
|
pub fn new(bind_addr: &SocketAddr, pkcs8: Vec<u8>) -> Self {
|
||||||
let rnd = SystemRandom::new();
|
|
||||||
let pkcs8 = KeyPair::generate_pkcs8(&rnd)
|
|
||||||
.expect("generate_pkcs8 in mint pub fn new")
|
|
||||||
.to_vec();
|
|
||||||
let keypair =
|
let keypair =
|
||||||
KeyPair::from_pkcs8(Input::from(&pkcs8)).expect("from_pkcs8 in fullnode::Config new");
|
KeyPair::from_pkcs8(Input::from(&pkcs8)).expect("from_pkcs8 in fullnode::Config new");
|
||||||
let pubkey = keypair.pubkey();
|
let pubkey = keypair.pubkey();
|
||||||
|
@@ -92,9 +92,14 @@ impl SecureRandom for GenKeys {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn read_keypair(path: &str) -> Result<KeyPair, Box<error::Error>> {
|
pub fn read_pkcs8(path: &str) -> Result<Vec<u8>, Box<error::Error>> {
|
||||||
let file = File::open(path.to_string())?;
|
let file = File::open(path.to_string())?;
|
||||||
let pkcs8: Vec<u8> = serde_json::from_reader(file)?;
|
let pkcs8: Vec<u8> = serde_json::from_reader(file)?;
|
||||||
|
Ok(pkcs8)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn read_keypair(path: &str) -> Result<KeyPair, Box<error::Error>> {
|
||||||
|
let pkcs8 = read_pkcs8(path)?;
|
||||||
let keypair = Ed25519KeyPair::from_pkcs8(Input::from(&pkcs8))?;
|
let keypair = Ed25519KeyPair::from_pkcs8(Input::from(&pkcs8))?;
|
||||||
Ok(keypair)
|
Ok(keypair)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user