mirror of
				https://github.com/ton-blockchain/ton
				synced 2025-03-09 15:40:10 +00:00 
			
		
		
		
	- new methods for liteserver/liteclient - added ADNL/DHT client-only work mode - fixed crash in ADNL
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Text
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Text
		
	
	
		
			Executable file
		
	
	
	
	
| #!/usr/bin/fift -s
 | |
| "TonUtil.fif" include
 | |
| "Asm.fif" include
 | |
| 
 | |
| { ."usage: " @' $0 type ." <workchain-id> [<filename-base>]" cr
 | |
|   ."Creates a new advanced wallet in specified workchain, with private key saved to or loaded from <filename-base>.pk" cr
 | |
|   ."('new-wallet.pk' by default)" cr 1 halt
 | |
| } : usage
 | |
| $# 1- -2 and ' usage if
 | |
| 
 | |
| $1 parse-workchain-id =: wc    // set workchain id from command line argument
 | |
| def? $2 { @' $2 } { "new-wallet" } cond constant file-base
 | |
| 
 | |
| ."Creating new advanced wallet in workchain " wc . cr
 | |
| 
 | |
| // Create new advanced wallet; code adapted from `auto/wallet-code.fif`
 | |
| <{ SETCP0 DUP IFNOTRET // return if recv_internal
 | |
|    DUP 85143 INT EQUAL OVER 78748 INT EQUAL OR IFJMP:<{ // "seqno" and "get_public_key" get-methods
 | |
|      1 INT AND c4 PUSHCTR CTOS 32 LDU 256 PLDU CONDSEL  // cnt or pubk
 | |
|    }>
 | |
|    INC 32 THROWIF	// fail unless recv_external
 | |
|    9 PUSHPOW2 LDSLICEX DUP 32 LDU 32 LDU	//  signature in_msg msg_seqno valid_until cs
 | |
|    SWAP NOW LEQ 35 THROWIF	//  signature in_msg msg_seqno cs
 | |
|    c4 PUSH CTOS 32 LDU 256 LDU ENDS	//  signature in_msg msg_seqno cs stored_seqno public_key
 | |
|    s3 s1 XCPU	//  signature in_msg public_key cs stored_seqno msg_seqno stored_seqno
 | |
|    EQUAL 33 THROWIFNOT	//  signature in_msg public_key cs stored_seqno
 | |
|    s0 s3 XCHG HASHSU	//  signature stored_seqno public_key cs hash
 | |
|    s0 s4 s2 XC2PU CHKSIGNU 34 THROWIFNOT	//  cs stored_seqno public_key
 | |
|    ACCEPT
 | |
|    s0 s2 XCHG	//  public_key stored_seqno cs
 | |
|    WHILE:<{
 | |
|      DUP SREFS	//  public_key stored_seqno cs _40
 | |
|    }>DO<{	//  public_key stored_seqno cs
 | |
|      // 3 INT 35 LSHIFT# 3 INT RAWRESERVE    // reserve all but 103 Grams from the balance
 | |
|      8 LDU LDREF s0 s2 XCHG	//  public_key stored_seqno cs _45 mode
 | |
|      SENDRAWMSG	//  public_key stored_seqno cs
 | |
|    }>
 | |
|    ENDS INC	//  public_key seqno'
 | |
|    NEWC 32 STU 256 STU ENDC c4 POP
 | |
| }>c // >libref
 | |
| // code
 | |
| <b 0 32 u, 
 | |
|    file-base +".pk" load-generate-keypair
 | |
|    constant wallet_pk
 | |
|    B, 
 | |
| b> // data
 | |
| null // no libraries
 | |
| <b b{0011} s, 3 roll ref, rot ref, swap dict, b>  // create StateInit
 | |
| dup ."StateInit: " <s csr. cr
 | |
| dup hashu wc swap 2dup 2constant wallet_addr
 | |
| ."new wallet address = " 2dup .addr cr
 | |
| 2dup file-base +".addr" save-address-verbose
 | |
| ."Non-bounceable address (for init): " 2dup 7 .Addr cr
 | |
| ."Bounceable address (for later access): " 6 .Addr cr
 | |
| <b 0 32 u, -1 32 i, b>
 | |
| dup ."signing message: " <s csr. cr
 | |
| dup hashu wallet_pk ed25519_sign_uint rot
 | |
| <b b{1000100} s, wallet_addr addr, b{000010} s, swap <s s, b{0} s, swap B, swap <s s, b>
 | |
| dup ."External message for initialization is " <s csr. cr
 | |
| 2 boc+>B dup Bx. cr
 | |
| file-base +"-query.boc" tuck B>file
 | |
| ."(Saved wallet creating query to file " type .")" cr
 |