1
;; Simple wallet smart contract
3
() recv_internal(slice in_msg) impure {
4
;; do nothing for internal messages
7
() recv_external(slice in_msg) impure {
8
var signature = in_msg~load_bits(512);
10
var (subwallet_id, valid_until, msg_seqno) = (cs~load_uint(32), cs~load_uint(32), cs~load_uint(32));
11
throw_if(35, valid_until <= now());
12
var ds = get_data().begin_parse();
13
var (stored_seqno, stored_subwallet, public_key) = (ds~load_uint(32), ds~load_uint(32), ds~load_uint(256));
15
throw_unless(33, msg_seqno == stored_seqno);
16
throw_unless(34, subwallet_id == stored_subwallet);
17
throw_unless(35, check_signature(slice_hash(in_msg), signature, public_key));
20
while (cs.slice_refs()) {
21
var mode = cs~load_uint(8);
22
send_raw_message(cs~load_ref(), mode);
25
.store_uint(stored_seqno + 1, 32)
26
.store_uint(stored_subwallet, 32)
27
.store_uint(public_key, 256)
33
int seqno() method_id {
34
return get_data().begin_parse().preload_uint(32);
37
int get_public_key() method_id {
38
var cs = get_data().begin_parse();
40
return cs.preload_uint(256);