2020-04-28 14:33:56 -07:00
|
|
|
//! @brief Example Rust-based BPF program that issues a cross-program-invocation
|
|
|
|
|
2020-10-22 10:23:50 -07:00
|
|
|
use solana_program_sdk::{
|
2020-04-28 14:33:56 -07:00
|
|
|
instruction::{AccountMeta, Instruction},
|
|
|
|
pubkey::Pubkey,
|
|
|
|
};
|
|
|
|
|
2020-05-08 12:24:36 -07:00
|
|
|
pub const TEST_VERIFY_TRANSLATIONS: u8 = 0;
|
|
|
|
pub const TEST_RETURN_ERROR: u8 = 1;
|
|
|
|
pub const TEST_DERIVED_SIGNERS: u8 = 2;
|
|
|
|
pub const TEST_VERIFY_NESTED_SIGNERS: u8 = 3;
|
|
|
|
pub const TEST_VERIFY_WRITER: u8 = 4;
|
2020-05-26 01:02:31 -07:00
|
|
|
pub const TEST_VERIFY_PRIVILEGE_ESCALATION: u8 = 5;
|
|
|
|
pub const TEST_NESTED_INVOKE: u8 = 6;
|
2020-05-08 12:24:36 -07:00
|
|
|
|
2020-04-28 14:33:56 -07:00
|
|
|
pub fn create_instruction(
|
|
|
|
program_id: Pubkey,
|
|
|
|
arguments: &[(&Pubkey, bool, bool)],
|
|
|
|
data: Vec<u8>,
|
|
|
|
) -> Instruction {
|
|
|
|
let accounts = arguments
|
|
|
|
.iter()
|
|
|
|
.map(|(key, is_writable, is_signer)| {
|
|
|
|
if *is_writable {
|
|
|
|
AccountMeta::new(**key, *is_signer)
|
|
|
|
} else {
|
|
|
|
AccountMeta::new_readonly(**key, *is_signer)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.collect();
|
|
|
|
Instruction {
|
|
|
|
program_id,
|
|
|
|
accounts,
|
|
|
|
data,
|
|
|
|
}
|
|
|
|
}
|