Add Anchor error and Result wrapper.
Change-Id: I6374dc81737ea711ead1fedd9e29007dbb625500
This commit is contained in:
parent
d169caa0fe
commit
a63af890b6
|
@ -1,6 +1,7 @@
|
||||||
use anchor_lang::{prelude::*, solana_program};
|
use anchor_lang::{prelude::*, solana_program};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
Result,
|
||||||
accounts,
|
accounts,
|
||||||
anchor_bridge::Bridge,
|
anchor_bridge::Bridge,
|
||||||
types::{BridgeConfig, Index},
|
types::{BridgeConfig, Index},
|
||||||
|
@ -14,7 +15,7 @@ pub fn initialize(
|
||||||
len_guardians: u8,
|
len_guardians: u8,
|
||||||
initial_guardian_key: [[u8; 20]; MAX_LEN_GUARDIAN_KEYS],
|
initial_guardian_key: [[u8; 20]; MAX_LEN_GUARDIAN_KEYS],
|
||||||
config: BridgeConfig,
|
config: BridgeConfig,
|
||||||
) -> Result<Bridge, ProgramError> {
|
) -> Result<Bridge> {
|
||||||
let index = Index(0);
|
let index = Index(0);
|
||||||
|
|
||||||
// Initialize the Guardian Set for the first time.
|
// Initialize the Guardian Set for the first time.
|
||||||
|
|
|
@ -5,8 +5,9 @@ use crate::{
|
||||||
anchor_bridge::Bridge,
|
anchor_bridge::Bridge,
|
||||||
types::{BridgeConfig, Index},
|
types::{BridgeConfig, Index},
|
||||||
PublishMessage,
|
PublishMessage,
|
||||||
|
Result,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn publish_message(bridge: &mut Bridge, ctx: Context<PublishMessage>) -> ProgramResult {
|
pub fn publish_message(bridge: &mut Bridge, ctx: Context<PublishMessage>) -> Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use anchor_lang::{prelude::*, solana_program};
|
use anchor_lang::{prelude::*, solana_program};
|
||||||
|
|
||||||
use crate::{accounts, anchor_bridge::Bridge, VerifySig, VerifySigsData, MAX_LEN_GUARDIAN_KEYS};
|
use crate::{Result, accounts, anchor_bridge::Bridge, VerifySig, VerifySigsData, MAX_LEN_GUARDIAN_KEYS};
|
||||||
use byteorder::ByteOrder;
|
use byteorder::ByteOrder;
|
||||||
use sha3::Digest;
|
use sha3::Digest;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
|
@ -43,7 +43,7 @@ pub fn verify_signatures(
|
||||||
hash: [u8; 32],
|
hash: [u8; 32],
|
||||||
signers: [i8; MAX_LEN_GUARDIAN_KEYS],
|
signers: [i8; MAX_LEN_GUARDIAN_KEYS],
|
||||||
initial_creation: bool,
|
initial_creation: bool,
|
||||||
) -> ProgramResult {
|
) -> Result<()> {
|
||||||
let sig_infos = filter_empty_signatures(&signers);
|
let sig_infos = filter_empty_signatures(&signers);
|
||||||
let ix_acc = &ctx.accounts.instruction_sysvar;
|
let ix_acc = &ctx.accounts.instruction_sysvar;
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ pub fn verify_signatures(
|
||||||
solana_program::sysvar::instructions::load_current_index(&ix_acc.try_borrow_data()?);
|
solana_program::sysvar::instructions::load_current_index(&ix_acc.try_borrow_data()?);
|
||||||
|
|
||||||
if current_ix_idx == 0 {
|
if current_ix_idx == 0 {
|
||||||
return Err(ProgramError::InvalidInstructionData);
|
return Err(ProgramError::InvalidInstructionData.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Retrieve the previous instruction
|
// Retrieve the previous instruction
|
||||||
|
@ -64,13 +64,13 @@ pub fn verify_signatures(
|
||||||
|
|
||||||
// Does prev_ix call the right program?
|
// Does prev_ix call the right program?
|
||||||
if prev_ix.program_id != solana_program::secp256k1_program::id() {
|
if prev_ix.program_id != solana_program::secp256k1_program::id() {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is the data correctly sized?
|
// Is the data correctly sized?
|
||||||
let prev_data_len = prev_ix.data.len();
|
let prev_data_len = prev_ix.data.len();
|
||||||
if prev_data_len < MIN_SECP_PROGRAM_DATA_LEN {
|
if prev_data_len < MIN_SECP_PROGRAM_DATA_LEN {
|
||||||
return Err(ProgramError::InvalidAccountData);
|
return Err(ProgramError::InvalidAccountData.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Parse the instruction data for verification
|
// Parse the instruction data for verification
|
||||||
|
@ -95,7 +95,7 @@ pub fn verify_signatures(
|
||||||
index += 1;
|
index += 1;
|
||||||
|
|
||||||
if address_ix != prev_ix_idx || msg_ix != prev_ix_idx || sig_ix != prev_ix_idx {
|
if address_ix != prev_ix_idx || msg_ix != prev_ix_idx || sig_ix != prev_ix_idx {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
let address: &[u8] = &prev_ix.data[address_offset..address_offset + 20];
|
let address: &[u8] = &prev_ix.data[address_offset..address_offset + 20];
|
||||||
|
@ -104,7 +104,7 @@ pub fn verify_signatures(
|
||||||
// Make sure that all messages are equal
|
// Make sure that all messages are equal
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
if msg_offset != secp_ixs[0].msg_offset || msg_size != secp_ixs[0].msg_size {
|
if msg_offset != secp_ixs[0].msg_offset || msg_size != secp_ixs[0].msg_size {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
secp_ixs.push(SecpInstructionPart {
|
secp_ixs.push(SecpInstructionPart {
|
||||||
|
@ -116,7 +116,7 @@ pub fn verify_signatures(
|
||||||
}
|
}
|
||||||
|
|
||||||
if sig_infos.len() != secp_ixs.len() {
|
if sig_infos.len() != secp_ixs.len() {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check message
|
// Check message
|
||||||
|
@ -125,11 +125,11 @@ pub fn verify_signatures(
|
||||||
|
|
||||||
let mut h = sha3::Keccak256::default();
|
let mut h = sha3::Keccak256::default();
|
||||||
if let Err(_) = h.write(message) {
|
if let Err(_) = h.write(message) {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
};
|
};
|
||||||
let msg_hash: [u8; 32] = h.finalize().into();
|
let msg_hash: [u8; 32] = h.finalize().into();
|
||||||
if msg_hash != hash {
|
if msg_hash != hash {
|
||||||
return Err(ProgramError::InvalidArgument);
|
return Err(ProgramError::InvalidArgument.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------ 8>< *SNIP <>8 --------
|
// ------ 8>< *SNIP <>8 --------
|
||||||
|
|
|
@ -111,7 +111,7 @@ pub mod anchor_bridge {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Bridge {
|
impl Bridge {
|
||||||
pub fn new(ctx: Context<Initialize>, data: InitializeData) -> Result<Self, ProgramError> {
|
pub fn new(ctx: Context<Initialize>, data: InitializeData) -> Result<Self> {
|
||||||
api::initialize(
|
api::initialize(
|
||||||
ctx,
|
ctx,
|
||||||
data.len_guardians,
|
data.len_guardians,
|
||||||
|
@ -120,18 +120,18 @@ pub mod anchor_bridge {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn publish_message(&mut self, ctx: Context<PublishMessage>, data: PublishMessageData) -> ProgramResult {
|
pub fn publish_message(&mut self, ctx: Context<PublishMessage>, data: PublishMessageData) -> Result<()> {
|
||||||
api::publish_message(
|
api::publish_message(
|
||||||
self,
|
self,
|
||||||
ctx,
|
ctx,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn verify_signatures(&mut self, ctx: Context<VerifySig>, data: VerifySigsData) -> ProgramResult {
|
pub fn verify_signatures(&mut self, ctx: Context<VerifySig>, data: VerifySigsData) -> Result<()> {
|
||||||
// We check this manually because the type-level checks are not available for
|
// We check this manually because the type-level checks are not available for
|
||||||
// Instructions yet. See the VerifySig struct for more info.
|
// Instructions yet. See the VerifySig struct for more info.
|
||||||
if *ctx.accounts.instruction_sysvar.key != solana_program::sysvar::instructions::id() {
|
if *ctx.accounts.instruction_sysvar.key != solana_program::sysvar::instructions::id() {
|
||||||
return Err(ProgramError::Custom(42));
|
return Err(ErrorCode::InvalidSysVar.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
api::verify_signatures(
|
api::verify_signatures(
|
||||||
|
@ -144,3 +144,9 @@ pub mod anchor_bridge {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[error]
|
||||||
|
pub enum ErrorCode {
|
||||||
|
#[msg("System account pubkey did not match expected address.")]
|
||||||
|
InvalidSysVar,
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue