staking plumbing part 3, 3.5 (#4216)
This commit is contained in:
@ -7,6 +7,7 @@ use solana_sdk::fee_calculator::FeeCalculator;
|
|||||||
use solana_sdk::genesis_block::GenesisBlock;
|
use solana_sdk::genesis_block::GenesisBlock;
|
||||||
use solana_sdk::signature::{read_keypair, KeypairUtil};
|
use solana_sdk::signature::{read_keypair, KeypairUtil};
|
||||||
use solana_sdk::system_program;
|
use solana_sdk::system_program;
|
||||||
|
use solana_stake_api::stake_state;
|
||||||
use solana_vote_api::vote_state;
|
use solana_vote_api::vote_state;
|
||||||
use std::error;
|
use std::error;
|
||||||
|
|
||||||
@ -63,6 +64,15 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
|||||||
.value_name("BOOTSTRAP VOTE KEYPAIR")
|
.value_name("BOOTSTRAP VOTE KEYPAIR")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.required(true)
|
.required(true)
|
||||||
|
.help("Path to file containing the bootstrap leader's voting keypair"),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("bootstrap_stake_keypair_file")
|
||||||
|
.short("k")
|
||||||
|
.long("bootstrap-stake-keypair")
|
||||||
|
.value_name("BOOTSTRAP STAKE KEYPAIR")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
.help("Path to file containing the bootstrap leader's staking keypair"),
|
.help("Path to file containing the bootstrap leader's staking keypair"),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
@ -86,35 +96,51 @@ fn main() -> Result<(), Box<dyn error::Error>> {
|
|||||||
|
|
||||||
let bootstrap_leader_keypair_file = matches.value_of("bootstrap_leader_keypair_file").unwrap();
|
let bootstrap_leader_keypair_file = matches.value_of("bootstrap_leader_keypair_file").unwrap();
|
||||||
let bootstrap_vote_keypair_file = matches.value_of("bootstrap_vote_keypair_file").unwrap();
|
let bootstrap_vote_keypair_file = matches.value_of("bootstrap_vote_keypair_file").unwrap();
|
||||||
let ledger_path = matches.value_of("ledger_path").unwrap();
|
let bootstrap_stake_keypair_file = matches.value_of("bootstrap_stake_keypair_file").unwrap();
|
||||||
let mint_keypair_file = matches.value_of("mint_keypair_file").unwrap();
|
let mint_keypair_file = matches.value_of("mint_keypair_file").unwrap();
|
||||||
|
let ledger_path = matches.value_of("ledger_path").unwrap();
|
||||||
let lamports = value_t_or_exit!(matches, "lamports", u64);
|
let lamports = value_t_or_exit!(matches, "lamports", u64);
|
||||||
let bootstrap_leader_lamports = value_t_or_exit!(matches, "bootstrap_leader_lamports", u64);
|
let bootstrap_leader_stake_lamports =
|
||||||
|
value_t_or_exit!(matches, "bootstrap_leader_lamports", u64);
|
||||||
|
|
||||||
let bootstrap_leader_keypair = read_keypair(bootstrap_leader_keypair_file)?;
|
let bootstrap_leader_keypair = read_keypair(bootstrap_leader_keypair_file)?;
|
||||||
let bootstrap_vote_keypair = read_keypair(bootstrap_vote_keypair_file)?;
|
let bootstrap_vote_keypair = read_keypair(bootstrap_vote_keypair_file)?;
|
||||||
|
let bootstrap_stake_keypair = read_keypair(bootstrap_stake_keypair_file)?;
|
||||||
let mint_keypair = read_keypair(mint_keypair_file)?;
|
let mint_keypair = read_keypair(mint_keypair_file)?;
|
||||||
|
|
||||||
|
// TODO: de-duplicate the stake once passive staking
|
||||||
|
// is fully implemented
|
||||||
|
// https://github.com/solana-labs/solana/issues/4213
|
||||||
|
let (vote_account, vote_state) = vote_state::create_bootstrap_leader_account(
|
||||||
|
&bootstrap_vote_keypair.pubkey(),
|
||||||
|
&bootstrap_leader_keypair.pubkey(),
|
||||||
|
0,
|
||||||
|
bootstrap_leader_stake_lamports,
|
||||||
|
);
|
||||||
|
|
||||||
let mut genesis_block = GenesisBlock::new(
|
let mut genesis_block = GenesisBlock::new(
|
||||||
&bootstrap_leader_keypair.pubkey(),
|
&bootstrap_leader_keypair.pubkey(),
|
||||||
&[
|
&[
|
||||||
|
// the mint
|
||||||
(
|
(
|
||||||
mint_keypair.pubkey(),
|
mint_keypair.pubkey(),
|
||||||
Account::new(
|
Account::new(lamports, 0, &system_program::id()),
|
||||||
lamports - bootstrap_leader_lamports,
|
|
||||||
0,
|
|
||||||
&system_program::id(),
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
|
// node needs an account to issue votes from
|
||||||
(
|
(
|
||||||
bootstrap_vote_keypair.pubkey(),
|
bootstrap_leader_keypair.pubkey(),
|
||||||
vote_state::create_bootstrap_leader_account(
|
Account::new(1, 0, &system_program::id()),
|
||||||
|
),
|
||||||
|
// where votes go to
|
||||||
|
(bootstrap_vote_keypair.pubkey(), vote_account),
|
||||||
|
// passive bootstrap leader stake, duplicates above temporarily
|
||||||
|
(
|
||||||
|
bootstrap_stake_keypair.pubkey(),
|
||||||
|
stake_state::create_delegate_stake_account(
|
||||||
&bootstrap_vote_keypair.pubkey(),
|
&bootstrap_vote_keypair.pubkey(),
|
||||||
&bootstrap_leader_keypair.pubkey(),
|
&vote_state,
|
||||||
0,
|
bootstrap_leader_stake_lamports,
|
||||||
bootstrap_leader_lamports,
|
),
|
||||||
)
|
|
||||||
.0,
|
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
&[
|
&[
|
||||||
|
@ -11,7 +11,7 @@ set -e
|
|||||||
$solana_keygen -o "$SOLANA_CONFIG_DIR"/mint-id.json
|
$solana_keygen -o "$SOLANA_CONFIG_DIR"/mint-id.json
|
||||||
$solana_keygen -o "$SOLANA_CONFIG_DIR"/bootstrap-leader-id.json
|
$solana_keygen -o "$SOLANA_CONFIG_DIR"/bootstrap-leader-id.json
|
||||||
$solana_keygen -o "$SOLANA_CONFIG_DIR"/bootstrap-leader-vote-id.json
|
$solana_keygen -o "$SOLANA_CONFIG_DIR"/bootstrap-leader-vote-id.json
|
||||||
|
$solana_keygen -o "$SOLANA_CONFIG_DIR"/bootstrap-leader-stake-id.json
|
||||||
|
|
||||||
default_arg() {
|
default_arg() {
|
||||||
declare name=$1
|
declare name=$1
|
||||||
@ -33,6 +33,7 @@ default_arg() {
|
|||||||
args=("$@")
|
args=("$@")
|
||||||
default_arg --bootstrap-leader-keypair "$SOLANA_CONFIG_DIR"/bootstrap-leader-id.json
|
default_arg --bootstrap-leader-keypair "$SOLANA_CONFIG_DIR"/bootstrap-leader-id.json
|
||||||
default_arg --bootstrap-vote-keypair "$SOLANA_CONFIG_DIR"/bootstrap-leader-vote-id.json
|
default_arg --bootstrap-vote-keypair "$SOLANA_CONFIG_DIR"/bootstrap-leader-vote-id.json
|
||||||
|
default_arg --bootstrap-stake-keypair "$SOLANA_CONFIG_DIR"/bootstrap-leader-stake-id.json
|
||||||
default_arg --ledger "$SOLANA_RSYNC_CONFIG_DIR"/ledger
|
default_arg --ledger "$SOLANA_RSYNC_CONFIG_DIR"/ledger
|
||||||
default_arg --mint "$SOLANA_CONFIG_DIR"/mint-id.json
|
default_arg --mint "$SOLANA_CONFIG_DIR"/mint-id.json
|
||||||
default_arg --lamports 100000000000000
|
default_arg --lamports 100000000000000
|
||||||
|
2
run.sh
2
run.sh
@ -41,6 +41,7 @@ dataDir=$PWD/target/"$(basename "$0" .sh)"
|
|||||||
set -x
|
set -x
|
||||||
solana-keygen -o "$dataDir"/config/leader-keypair.json
|
solana-keygen -o "$dataDir"/config/leader-keypair.json
|
||||||
solana-keygen -o "$dataDir"/config/leader-vote-account-keypair.json
|
solana-keygen -o "$dataDir"/config/leader-vote-account-keypair.json
|
||||||
|
solana-keygen -o "$dataDir"/config/leader-stake-account-keypair.json
|
||||||
solana-keygen -o "$dataDir"/config/drone-keypair.json
|
solana-keygen -o "$dataDir"/config/drone-keypair.json
|
||||||
|
|
||||||
leaderVoteAccountPubkey=$(\
|
leaderVoteAccountPubkey=$(\
|
||||||
@ -56,6 +57,7 @@ solana-genesis \
|
|||||||
--mint "$dataDir"/config/drone-keypair.json \
|
--mint "$dataDir"/config/drone-keypair.json \
|
||||||
--bootstrap-leader-keypair "$dataDir"/config/leader-keypair.json \
|
--bootstrap-leader-keypair "$dataDir"/config/leader-keypair.json \
|
||||||
--bootstrap-vote-keypair "$dataDir"/config/leader-vote-account-keypair.json \
|
--bootstrap-vote-keypair "$dataDir"/config/leader-vote-account-keypair.json \
|
||||||
|
--bootstrap-stake-keypair "$dataDir"/config/leader-stake-account-keypair.json \
|
||||||
--ledger "$dataDir"/ledger
|
--ledger "$dataDir"/ledger
|
||||||
|
|
||||||
solana-drone --keypair "$dataDir"/config/drone-keypair.json &
|
solana-drone --keypair "$dataDir"/config/drone-keypair.json &
|
||||||
|
Reference in New Issue
Block a user