mirror of
https://github.com/ton-blockchain/ton
synced 2025-03-09 15:40:10 +00:00
tonNode.getOutMsgQueueProof query in public shard overlays (#1413)
* tonNode.getOutMsgQueueProof query in public shard overlays * Allow responding to getOutMsgQueueProof requests one at a time only
This commit is contained in:
parent
9ae88d87e3
commit
7bc50e63d7
37 changed files with 729 additions and 51 deletions
|
@ -22,23 +22,23 @@ namespace ton {
|
|||
|
||||
namespace validator {
|
||||
|
||||
void TokenManager::get_download_token(size_t download_size, td::uint32 priority, td::Timestamp timeout,
|
||||
td::Promise<std::unique_ptr<DownloadToken>> promise) {
|
||||
void TokenManager::get_token(size_t size, td::uint32 priority, td::Timestamp timeout,
|
||||
td::Promise<std::unique_ptr<ActionToken>> promise) {
|
||||
if (free_priority_tokens_ > 0 && priority > 0) {
|
||||
--free_priority_tokens_;
|
||||
promise.set_value(gen_token(download_size, priority));
|
||||
promise.set_value(gen_token(size, priority));
|
||||
return;
|
||||
}
|
||||
if (free_tokens_ > 0) {
|
||||
--free_tokens_;
|
||||
promise.set_value(gen_token(download_size, priority));
|
||||
promise.set_value(gen_token(size, priority));
|
||||
return;
|
||||
}
|
||||
|
||||
pending_.emplace(PendingPromiseKey{download_size, priority, seqno_++}, PendingPromise{timeout, std::move(promise)});
|
||||
pending_.emplace(PendingPromiseKey{size, priority, seqno_++}, PendingPromise{timeout, std::move(promise)});
|
||||
}
|
||||
|
||||
void TokenManager::download_token_cleared(size_t download_size, td::uint32 priority) {
|
||||
void TokenManager::token_cleared(size_t size, td::uint32 priority) {
|
||||
(priority ? free_priority_tokens_ : free_tokens_)++;
|
||||
if (free_priority_tokens_ > max_priority_tokens_) {
|
||||
free_priority_tokens_--;
|
||||
|
@ -47,7 +47,7 @@ void TokenManager::download_token_cleared(size_t download_size, td::uint32 prior
|
|||
|
||||
for (auto it = pending_.begin(); it != pending_.end();) {
|
||||
if (it->first.priority && (free_tokens_ || free_priority_tokens_)) {
|
||||
it->second.promise.set_value(gen_token(download_size, priority));
|
||||
it->second.promise.set_value(gen_token(size, priority));
|
||||
auto it2 = it++;
|
||||
pending_.erase(it2);
|
||||
if (free_priority_tokens_ > 0) {
|
||||
|
@ -56,7 +56,7 @@ void TokenManager::download_token_cleared(size_t download_size, td::uint32 prior
|
|||
free_tokens_--;
|
||||
}
|
||||
} else if (!it->first.priority && free_tokens_) {
|
||||
it->second.promise.set_value(gen_token(download_size, priority));
|
||||
it->second.promise.set_value(gen_token(size, priority));
|
||||
auto it2 = it++;
|
||||
pending_.erase(it2);
|
||||
free_tokens_--;
|
||||
|
@ -69,7 +69,7 @@ void TokenManager::download_token_cleared(size_t download_size, td::uint32 prior
|
|||
void TokenManager::alarm() {
|
||||
for (auto it = pending_.begin(); it != pending_.end();) {
|
||||
if (it->second.timeout.is_in_past()) {
|
||||
it->second.promise.set_error(td::Status::Error(ErrorCode::timeout, "timeout in wait download token"));
|
||||
it->second.promise.set_error(td::Status::Error(ErrorCode::timeout, "timeout in wait token"));
|
||||
it = pending_.erase(it);
|
||||
} else {
|
||||
it++;
|
||||
|
@ -77,23 +77,23 @@ void TokenManager::alarm() {
|
|||
}
|
||||
}
|
||||
|
||||
std::unique_ptr<DownloadToken> TokenManager::gen_token(size_t download_size, td::uint32 priority) {
|
||||
class Token : public DownloadToken {
|
||||
std::unique_ptr<ActionToken> TokenManager::gen_token(size_t size, td::uint32 priority) {
|
||||
class TokenImpl : public ActionToken {
|
||||
public:
|
||||
Token(size_t download_size, td::uint32 priority, td::actor::ActorId<TokenManager> manager)
|
||||
: download_size_(download_size), priority_(priority), manager_(manager) {
|
||||
TokenImpl(size_t size, td::uint32 priority, td::actor::ActorId<TokenManager> manager)
|
||||
: size_(size), priority_(priority), manager_(manager) {
|
||||
}
|
||||
~Token() override {
|
||||
td::actor::send_closure(manager_, &TokenManager::download_token_cleared, download_size_, priority_);
|
||||
~TokenImpl() override {
|
||||
td::actor::send_closure(manager_, &TokenManager::token_cleared, size_, priority_);
|
||||
}
|
||||
|
||||
private:
|
||||
size_t download_size_;
|
||||
size_t size_;
|
||||
td::uint32 priority_;
|
||||
td::actor::ActorId<TokenManager> manager_;
|
||||
};
|
||||
|
||||
return std::make_unique<Token>(download_size, priority, actor_id(this));
|
||||
return std::make_unique<TokenImpl>(size, priority, actor_id(this));
|
||||
}
|
||||
|
||||
} // namespace validator
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue