mirror of
https://github.com/ton-blockchain/ton
synced 2025-03-09 15:40:10 +00:00
updated smartcontracts
- updated smartcontracts - updated fullnode database layout - fixed memory leak in blockchain-explorer - updated tonlib
This commit is contained in:
parent
9c9248a9ae
commit
c860ce3d1e
104 changed files with 7309 additions and 1335 deletions
64
crypto/smc-envelope/MultisigWallet.h
Normal file
64
crypto/smc-envelope/MultisigWallet.h
Normal file
|
@ -0,0 +1,64 @@
|
|||
#pragma once
|
||||
#include "vm/cells.h"
|
||||
|
||||
#include "SmartContract.h"
|
||||
#include "Ed25519.h"
|
||||
|
||||
#include <bitset>
|
||||
|
||||
namespace ton {
|
||||
class MultisigWallet : public ton::SmartContract {
|
||||
public:
|
||||
MultisigWallet(State state) : SmartContract(std::move(state)) {
|
||||
}
|
||||
|
||||
using Mask = std::bitset<128>;
|
||||
struct QueryState {
|
||||
enum State { Unknown, NotReady, Sent } state = Unknown;
|
||||
Mask mask;
|
||||
};
|
||||
|
||||
class QueryBuilder {
|
||||
public:
|
||||
QueryBuilder(td::int64 query_id, td::Ref<vm::Cell> msg, int mode = 3);
|
||||
void sign(td::int32 id, td::Ed25519::PrivateKey& pk);
|
||||
|
||||
td::Ref<vm::Cell> create_inner() const;
|
||||
td::Ref<vm::Cell> create(td::int32 id, td::Ed25519::PrivateKey& pk) const;
|
||||
Mask get_mask() const {
|
||||
return mask_;
|
||||
}
|
||||
|
||||
private:
|
||||
vm::Ref<vm::Cell> dict_;
|
||||
td::Ref<vm::Cell> msg_;
|
||||
Mask mask_;
|
||||
};
|
||||
|
||||
MultisigWallet* make_copy() const override {
|
||||
return new MultisigWallet{state_};
|
||||
}
|
||||
|
||||
// creation
|
||||
static td::Ref<MultisigWallet> create(td::Ref<vm::Cell> data = {});
|
||||
|
||||
td::Ref<vm::Cell> create_init_data(std::vector<td::SecureString> public_keys, int k) const;
|
||||
static td::Ref<vm::Cell> create_init_data_fast(std::vector<td::SecureString> public_keys, int k);
|
||||
|
||||
// get methods
|
||||
int processed(td::uint64 query_id) const;
|
||||
QueryState get_query_state(td::uint64 query_id) const;
|
||||
std::vector<td::SecureString> get_public_keys() const;
|
||||
td::Ref<vm::Cell> merge_queries(td::Ref<vm::Cell> a, td::Ref<vm::Cell> b) const;
|
||||
std::pair<int, Mask> check_query_signatures(td::Ref<vm::Cell> a) const;
|
||||
std::pair<int, int> get_n_k() const;
|
||||
Mask to_mask(td::RefInt256 mask) const;
|
||||
|
||||
struct Message {
|
||||
td::uint64 query_id;
|
||||
Mask signed_by;
|
||||
td::Ref<vm::Cell> message;
|
||||
};
|
||||
std::vector<Message> get_unsigned_messaged(int id = -1) const;
|
||||
};
|
||||
} // namespace ton
|
Loading…
Add table
Add a link
Reference in a new issue