mirror of
https://github.com/d0zingcat/ore.git
synced 2026-05-19 15:10:29 +00:00
parsers
This commit is contained in:
@@ -16,7 +16,7 @@ pub fn process_reset<'a, 'info>(
|
||||
accounts: &'a [AccountInfo<'info>],
|
||||
_data: &[u8],
|
||||
) -> ProgramResult {
|
||||
// Validate accounts
|
||||
// Load accounts
|
||||
let [signer, bus_0_info, bus_1_info, bus_2_info, bus_3_info, bus_4_info, bus_5_info, bus_6_info, bus_7_info, mint_info, treasury_info, treasury_tokens_info, token_program] = accounts else {
|
||||
return Err(ProgramError::NotEnoughAccountKeys);
|
||||
};
|
||||
@@ -44,9 +44,9 @@ pub fn process_reset<'a, 'info>(
|
||||
];
|
||||
|
||||
// Validate epoch has ended
|
||||
let clock = Clock::get().unwrap();
|
||||
let clock = Clock::get().or(Err(ProgramError::InvalidAccountData))?;
|
||||
let mut treasury_data = treasury_info.data.borrow_mut();
|
||||
let mut treasury = bytemuck::try_from_bytes_mut::<Treasury>(&mut treasury_data).unwrap();
|
||||
let mut treasury = Treasury::try_from_bytes_mut(&mut treasury_data)?;
|
||||
let epoch_end_at = treasury.epoch_start_at.saturating_add(EPOCH_DURATION);
|
||||
if clock.unix_timestamp.lt(&epoch_end_at) {
|
||||
return Err(OreError::EpochActive.into());
|
||||
@@ -56,7 +56,7 @@ pub fn process_reset<'a, 'info>(
|
||||
let mut total_available_rewards = 0u64;
|
||||
for i in 0..BUS_COUNT {
|
||||
let mut bus_data = busses[i].data.borrow_mut();
|
||||
let mut bus = bytemuck::try_from_bytes_mut::<Bus>(&mut bus_data).unwrap();
|
||||
let mut bus = Bus::try_from_bytes_mut(&mut bus_data)?;
|
||||
total_available_rewards = total_available_rewards.saturating_add(bus.available_rewards);
|
||||
bus.available_rewards = BUS_EPOCH_REWARDS;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user