miclockwork_thread_program/instructions/
thread_withdraw.rs1use {
2 crate::{errors::*, state::*},
3 anchor_lang::prelude::*,
4};
5
6#[derive(Accounts)]
8#[instruction(amount: u64)]
9pub struct ThreadWithdraw<'info> {
10 #[account()]
12 pub authority: Signer<'info>,
13
14 #[account(mut)]
16 pub pay_to: SystemAccount<'info>,
17
18 #[account(
20 mut,
21 seeds = [
22 SEED_THREAD,
23 thread.authority.as_ref(),
24 thread.id.as_slice(),
25 ],
26 bump = thread.bump,
27 has_one = authority,
28 )]
29 pub thread: Account<'info, Thread>,
30}
31
32pub fn handler(ctx: Context<ThreadWithdraw>, amount: u64) -> Result<()> {
33 let pay_to = &mut ctx.accounts.pay_to;
35 let thread = &mut ctx.accounts.thread;
36
37 let data_len = 8 + thread.try_to_vec()?.len();
39 let minimum_rent = Rent::get().unwrap().minimum_balance(data_len);
40 let post_balance = thread
41 .to_account_info()
42 .lamports()
43 .checked_sub(amount)
44 .unwrap();
45 require!(
46 post_balance.gt(&minimum_rent),
47 ClockworkError::WithdrawalTooLarge
48 );
49
50 **thread.to_account_info().try_borrow_mut_lamports()? = thread
52 .to_account_info()
53 .lamports()
54 .checked_sub(amount)
55 .unwrap();
56 **pay_to.to_account_info().try_borrow_mut_lamports()? = pay_to
57 .to_account_info()
58 .lamports()
59 .checked_add(amount)
60 .unwrap();
61
62 Ok(())
63}