Stellar governance functionalities
This package provides governance modules for Soroban smart contracts:
- Votes: Vote tracking with delegation and historical checkpointing
- Timelock: Time-delayed execution of operations
The votes module provides vote tracking functionality with delegation and historical checkpointing for governance mechanisms.
- Voting Units: The base unit of voting power, typically 1:1 with token balance
- Delegation: Accounts can delegate their voting power to another account (delegatee)
- Checkpoints: Historical snapshots of voting power at specific ledger sequence numbers
- Clock Mode: Uses ledger sequence numbers (
e.ledger().sequence()) as the timepoint reference
- Track voting power per account with historical checkpoints
- Support delegation (an account can delegate its voting power to another account)
- Provide historical vote queries at any past ledger sequence number
- Explicit delegation required (accounts must self-delegate to use their own voting power)
- Non-delegated voting units are not counted as votes
The timelock module provides functionality for time-delayed execution of operations, enabling governance mechanisms where actions must wait for a minimum delay before execution.
- Operations: Actions to be executed on target contracts
- Scheduling: Proposing an operation with a delay period
- Execution: Running the operation after the delay has passed
- Cancellation: Removing a scheduled operation before execution
- Predecessors: Dependencies between operations (operation B requires operation A to be done first)
use soroban_sdk::{contract, contractimpl, Address, BytesN, Env, Symbol, Val, Vec};
use stellar_governance::timelock::{
schedule_operation, execute_operation, cancel_operation,
get_operation_state, set_min_delay, Operation, OperationState,
};
#[contract]
pub struct TimelockController;
#[contractimpl]
impl TimelockController {
pub fn __constructor(e: &Env, min_delay: u32) {
set_min_delay(e, min_delay);
}
pub fn schedule(
e: &Env,
target: Address,
function: Symbol,
args: Vec<Val>,
predecessor: BytesN<32>,
salt: BytesN<32>,
delay: u32,
) -> BytesN<32> {
// Add authorization checks here
let operation = Operation {
target,
function,
args,
predecessor,
salt,
};
schedule_operation(e, &operation, delay)
}
pub fn execute(
e: &Env,
target: Address,
function: Symbol,
args: Vec<Val>,
predecessor: BytesN<32>,
salt: BytesN<32>,
) {
// Add authorization checks here
let operation = Operation {
target,
function,
args,
predecessor,
salt,
};
execute_operation(e, &operation);
}
pub fn cancel(e: &Env, id: BytesN<32>) {
// Add authorization checks here
cancel_operation(e, &id);
}
}Add this to your Cargo.toml:
[dependencies]
# We recommend pinning to a specific version, because rapid iterations are expected as the library is in an active development phase.
stellar-governance = "=0.6.0"See the following examples in the repository:
examples/timelock-controller/- Timelock controller with role-based access control