Skip to content

Commit

Permalink
Add redelegation functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
bengtlofgren authored and adrianbrink committed Nov 14, 2023
1 parent e89a5a9 commit 583150b
Show file tree
Hide file tree
Showing 4 changed files with 72 additions and 1 deletion.
3 changes: 3 additions & 0 deletions .changelog/unreleased/SDK/2140-sdk-redelegate.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
- A high level function new_redelegate is added to the sdk to allow developers
to make and submit redelegation functions from the minimum number of arguments
required ([\#2140](https://github.com/anoma/namada/pull/2140))
43 changes: 43 additions & 0 deletions sdk/src/args.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1018,6 +1018,49 @@ impl Redelegate {
}
}

impl<C: NamadaTypes> Redelegate<C> {
/// Src validator address
pub fn src_validator(self, src_validator: C::Address) -> Self {
Self {
src_validator,
..self
}
}

/// Dest validator address
pub fn dest_validator(self, dest_validator: C::Address) -> Self {
Self {
dest_validator,
..self
}
}

/// Owner (or delegator or source) of the redelegation
pub fn owner(self, owner: C::Address) -> Self {
Self { owner, ..self }
}

/// Path to the TX WASM code file
pub fn tx_code_path(self, tx_code_path: PathBuf) -> Self {
Self {
tx_code_path,
..self
}
}
}

impl<C: NamadaTypes> TxBuilder<C> for Redelegate<C> {
fn tx<F>(self, func: F) -> Self
where
F: FnOnce(Tx<C>) -> Tx<C>,
{
Redelegate {
tx: func(self.tx),
..self
}
}
}

/// Reveal public key
#[derive(Clone, Debug)]
pub struct RevealPk<C: NamadaTypes = SdkTypes> {
Expand Down
25 changes: 24 additions & 1 deletion sdk/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ use crate::tx::{
ProcessTxResponse, TX_BOND_WASM, TX_BRIDGE_POOL_WASM,
TX_CHANGE_COMMISSION_WASM, TX_CHANGE_METADATA_WASM, TX_CLAIM_REWARDS_WASM,
TX_DEACTIVATE_VALIDATOR_WASM, TX_IBC_WASM, TX_INIT_PROPOSAL,
TX_INIT_VALIDATOR_WASM, TX_REACTIVATE_VALIDATOR_WASM, TX_RESIGN_STEWARD,
TX_INIT_VALIDATOR_WASM, TX_REACTIVATE_VALIDATOR_WASM, TX_REDELEGATE_WASM, TX_RESIGN_STEWARD,
TX_REVEAL_PK, TX_TRANSFER_WASM, TX_UNBOND_WASM, TX_UNJAIL_VALIDATOR_WASM,
TX_UPDATE_ACCOUNT_WASM, TX_UPDATE_STEWARD_COMMISSION, TX_VOTE_PROPOSAL,
TX_WITHDRAW_WASM, VP_USER_WASM,
Expand Down Expand Up @@ -206,6 +206,29 @@ pub trait Namada<'a>: Sized {
}
}

// Make a Redelegation builder for the given minimum set of arguments
fn new_redelegation(
&self,
source: Address,
src_validator: Address,
dest_validator: Address,
amount: token::Amount,
) -> args::Redelegate {
args::Redelegate {
tx: self.tx_builder(),
/// Source validator address
src_validator,
/// Destination validator address
dest_validator,
/// Owner of the bonds that are being redelegated
owner: source,
/// The amount of tokens to redelegate
amount,
/// Path to the TX WASM code file
tx_code_path: PathBuf::from(TX_REDELEGATE_WASM),
}
}

/// Make a TxIbcTransfer builder from the given minimum set of arguments
fn new_ibc_transfer(
&self,
Expand Down
2 changes: 2 additions & 0 deletions sdk/src/tx.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,8 @@ pub const TX_RESIGN_STEWARD: &str = "tx_resign_steward.wasm";
/// Update steward commission WASM path
pub const TX_UPDATE_STEWARD_COMMISSION: &str =
"tx_update_steward_commission.wasm";
/// Redelegat WASM path
pub const TX_REDELEGATE_WASM: &str = "tx_redelegate.wasm";

/// Default timeout in seconds for requests to the `/accepted`
/// and `/applied` ABCI query endpoints.
Expand Down

0 comments on commit 583150b

Please sign in to comment.