2025-10-29 15:34:11 -03:00
|
|
|
use nssa_core::program::{
|
|
|
|
|
ChainedCall, ProgramId, ProgramInput, read_nssa_inputs, write_nssa_outputs_with_chained_call,
|
|
|
|
|
};
|
|
|
|
|
use risc0_zkvm::serde::to_vec;
|
|
|
|
|
|
|
|
|
|
type Instruction = (u128, ProgramId);
|
|
|
|
|
|
2025-11-12 19:08:46 -03:00
|
|
|
/// A program that calls another program twice.
|
2025-10-30 10:52:31 -03:00
|
|
|
/// It permutes the order of the input accounts on the subsequent call
|
2025-10-29 15:34:11 -03:00
|
|
|
fn main() {
|
|
|
|
|
let ProgramInput {
|
|
|
|
|
pre_states,
|
|
|
|
|
instruction: (balance, program_id),
|
|
|
|
|
} = read_nssa_inputs::<Instruction>();
|
|
|
|
|
|
|
|
|
|
let [sender_pre, receiver_pre] = match pre_states.try_into() {
|
|
|
|
|
Ok(array) => array,
|
|
|
|
|
Err(_) => return,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let instruction_data = to_vec(&balance).unwrap();
|
|
|
|
|
|
2025-11-12 19:08:46 -03:00
|
|
|
let chained_call = vec![
|
|
|
|
|
ChainedCall {
|
|
|
|
|
program_id,
|
|
|
|
|
instruction_data: instruction_data.clone(),
|
|
|
|
|
account_indices: vec![0, 1],
|
|
|
|
|
},
|
|
|
|
|
ChainedCall {
|
|
|
|
|
program_id,
|
|
|
|
|
instruction_data,
|
|
|
|
|
account_indices: vec![1, 0], // <- Account order permutation here
|
|
|
|
|
},
|
|
|
|
|
];
|
2025-10-29 15:34:11 -03:00
|
|
|
|
|
|
|
|
write_nssa_outputs_with_chained_call(
|
|
|
|
|
vec![sender_pre.clone(), receiver_pre.clone()],
|
|
|
|
|
vec![sender_pre.account, receiver_pre.account],
|
|
|
|
|
chained_call,
|
|
|
|
|
);
|
|
|
|
|
}
|