Ton
1;; Simple wallet smart contract
2
3() recv_internal(slice in_msg) impure {
4;; do nothing for internal messages
5}
6
7() recv_external(slice in_msg) impure {
8var signature = in_msg~load_bits(512);
9var cs = in_msg;
10int msg_seqno = cs~load_uint(32);
11var cs2 = begin_parse(get_data());
12var stored_seqno = cs2~load_uint(32);
13var public_key = cs2~load_uint(256);
14cs2.end_parse();
15throw_unless(33, msg_seqno == stored_seqno);
16throw_unless(34, check_signature(slice_hash(in_msg), signature, public_key));
17accept_message();
18cs~touch();
19if (cs.slice_refs()) {
20var mode = cs~load_uint(8);
21send_raw_message(cs~load_ref(), mode);
22}
23cs.end_parse();
24set_data(begin_cell().store_uint(stored_seqno + 1, 32).store_uint(public_key, 256).end_cell());
25}
26