mirror of
https://github.com/danog/toncontest.git
synced 2024-12-02 09:27:47 +01:00
67 lines
2.4 KiB
Plaintext
Executable File
67 lines
2.4 KiB
Plaintext
Executable File
#!/usr/bin/env -S fift -s
|
|
"TonUtil.fif" include
|
|
|
|
{
|
|
."usage: " @' $0 type ." <filename-base> <key> <key-id> <dest-addr> <seqno> <amount> [-B <body-boc>] [<savefile>]" cr
|
|
."Creates a request to shared wallet created by wallet-create.fif, with private key loaded from file <key>.pk "
|
|
."and address from <filename-base>.addr, and saves it into <savefile>.boc ('wallet-query.boc' by default)" cr 1 halt
|
|
} : usage
|
|
def? $8 { @' $7 "-B" $= { @' $8 =: body-boc-file [forget] $8 def? $9 { @' $9 =: $7 [forget] $9 } { [forget] $7 } cond
|
|
@' $# 2- =: $# } if } if
|
|
$# dup 6 < swap 6 7 or ' usage if
|
|
|
|
true constant bounce
|
|
|
|
$1 =: file-base
|
|
$2 =: key
|
|
$3 (number) =: key-id
|
|
$4 bounce parse-load-address =: bounce 2=: dest_addr
|
|
$5 parse-int =: seqno
|
|
$6 $>GR =: amount
|
|
def? $7 { @' $7 } { "wallet-query" } cond constant savefile
|
|
3 constant send-mode // mode for SENDRAWMSG: +1 - sender pays fees, +2 - ignore errors
|
|
60 constant timeout // external message expires in 60 seconds
|
|
|
|
file-base +".addr" load-address
|
|
2dup 2constant wallet_addr
|
|
."Source wallet address = " 2dup .addr cr 6 .Addr cr
|
|
file-base +".pk" load-keypair nip constant wallet_pk
|
|
|
|
def? body-boc-file { @' body-boc-file file>B B>boc } { <b 0 32 u, "TESTv2" $, b> } cond
|
|
constant body-cell
|
|
|
|
."Transferring " amount .GR ."to account "
|
|
dest_addr 2dup bounce 7 + .Addr ." = " .addr
|
|
."seqno=0x" seqno x. ."bounce=" bounce . cr
|
|
."Body of transfer message is " body-cell <s csr. cr
|
|
|
|
// create a message
|
|
<b b{01} s, bounce 1 i, b{000100} s, dest_addr addr, amount Gram, 0 9 64 32 + + 1+ u,
|
|
body-cell <s 2dup s-fits? not rot over 1 i, -rot { drop body-cell ref, } { s, } cond
|
|
b>
|
|
// create wrapper message
|
|
//modeMessage$_ mode:uint8 body:^(Message X) = ModeMessage X;
|
|
//wrappedMessage$_ expires_at:uint32 seqno:uint32 body:(ModeMessage X) = WrappedMessage X;
|
|
<b now timeout + 32 u, seqno 32 u, send-mode 8 u, swap ref, b>
|
|
|
|
dup ."signing message: " <s csr. cr
|
|
dup hash wallet_pk ed25519_sign_uint
|
|
|
|
// signature$_ R:bits256 s:bits256 = Signature;
|
|
256 B>u@+ 256 B>u@+
|
|
<b swap 256 swap u, swap 256 swap u, b>
|
|
<b swap ref,
|
|
|
|
// key ID => signature
|
|
//multiSigWrapper$0 signatures:(HashmapE 4 ^Signature) message:(WrappedMessage X) = MultiSigWrapper X;
|
|
<b swap key-id dictnew 4 dict, swap ref, b>
|
|
|
|
<b b{1000100} s, wallet_addr addr, 0 Gram, b{00} s,
|
|
swap B, swap <s s, b>
|
|
|
|
dup ."resulting external message: " <s csr. cr
|
|
2 boc+>B dup Bx. cr
|
|
savefile +".boc" tuck B>file
|
|
."Query expires in " timeout . ."seconds" cr
|
|
."(Saved to file " type .")" cr
|