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
		
			
				
	
	
		
			68 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
;; Simple wallet smart contract
 | 
						|
 | 
						|
cell create_state(int seqno, int public_key) {
 | 
						|
  return begin_cell().store_uint(seqno, 32).store_uint(public_key, 256).end_cell();
 | 
						|
}
 | 
						|
 | 
						|
(int, int) load_state() {
 | 
						|
  var cs2 = begin_parse(get_data());
 | 
						|
  return (cs2~load_uint(32), cs2~load_uint(256));
 | 
						|
}
 | 
						|
 | 
						|
() save_state(int seqno, int public_key) impure {
 | 
						|
  set_data(create_state(seqno, public_key));
 | 
						|
}
 | 
						|
 | 
						|
() recv_internal(slice in_msg) impure {
 | 
						|
  ;; do nothing for internal messages
 | 
						|
}
 | 
						|
 | 
						|
slice do_verify_message(slice in_msg, int seqno, int public_key) {
 | 
						|
  var signature = in_msg~load_bits(512);
 | 
						|
  var cs = in_msg;
 | 
						|
  int msg_seqno = cs~load_uint(32);
 | 
						|
  throw_unless(33, msg_seqno == seqno);
 | 
						|
  throw_unless(34, check_signature(slice_hash(in_msg), signature, public_key));
 | 
						|
  return cs;
 | 
						|
}
 | 
						|
 | 
						|
() recv_external(slice in_msg) impure {
 | 
						|
  (int stored_seqno, int public_key) = load_state();
 | 
						|
  var cs = do_verify_message(in_msg, stored_seqno, public_key);
 | 
						|
  accept_message();
 | 
						|
  cs~touch();
 | 
						|
  if (cs.slice_refs()) {
 | 
						|
    var mode = cs~load_uint(8);
 | 
						|
    send_raw_message(cs~load_ref(), mode);
 | 
						|
  }
 | 
						|
  cs.end_parse();
 | 
						|
  save_state(stored_seqno + 1, public_key);
 | 
						|
}
 | 
						|
 | 
						|
;; Get methods
 | 
						|
 | 
						|
int seqno() method_id {
 | 
						|
  return get_data().begin_parse().preload_uint(32);
 | 
						|
}
 | 
						|
 | 
						|
int get_public_key() method_id {
 | 
						|
  var (seqno, public_key) = load_state();
 | 
						|
  return public_key;
 | 
						|
}
 | 
						|
 | 
						|
cell create_init_state(int public_key) method_id {
 | 
						|
  return create_state(0, public_key);
 | 
						|
}
 | 
						|
 | 
						|
cell prepare_send_message_with_seqno(int mode, cell msg, int seqno) method_id {
 | 
						|
  return begin_cell().store_uint(seqno, 32).store_uint(mode, 8).store_ref(msg).end_cell();
 | 
						|
}
 | 
						|
 | 
						|
cell prepare_send_message(int mode, cell msg) method_id {
 | 
						|
  return prepare_send_message_with_seqno(mode, msg, seqno());
 | 
						|
}
 | 
						|
 | 
						|
slice verify_message(slice msg) method_id {
 | 
						|
  var (stored_seqno, public_key) = load_state();
 | 
						|
  return do_verify_message(msg, stored_seqno, public_key);
 | 
						|
}
 |