mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-20 11:05:54 +00:00
Rearrange sources (#4997)
This commit is contained in:
committed by
John Freeman
parent
2e902dee53
commit
e416ee72ca
131
src/xrpld/app/misc/HashRouter.cpp
Normal file
131
src/xrpld/app/misc/HashRouter.cpp
Normal file
@@ -0,0 +1,131 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
This file is part of rippled: https://github.com/ripple/rippled
|
||||
Copyright (c) 2012, 2013 Ripple Labs Inc.
|
||||
|
||||
Permission to use, copy, modify, and/or distribute this software for any
|
||||
purpose with or without fee is hereby granted, provided that the above
|
||||
copyright notice and this permission notice appear in all copies.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||
ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
//==============================================================================
|
||||
|
||||
#include <ripple/app/misc/HashRouter.h>
|
||||
|
||||
namespace ripple {
|
||||
|
||||
auto
|
||||
HashRouter::emplace(uint256 const& key) -> std::pair<Entry&, bool>
|
||||
{
|
||||
auto iter = suppressionMap_.find(key);
|
||||
|
||||
if (iter != suppressionMap_.end())
|
||||
{
|
||||
suppressionMap_.touch(iter);
|
||||
return std::make_pair(std::ref(iter->second), false);
|
||||
}
|
||||
|
||||
// See if any supressions need to be expired
|
||||
expire(suppressionMap_, holdTime_);
|
||||
|
||||
return std::make_pair(
|
||||
std::ref(suppressionMap_.emplace(key, Entry()).first->second), true);
|
||||
}
|
||||
|
||||
void
|
||||
HashRouter::addSuppression(uint256 const& key)
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
emplace(key);
|
||||
}
|
||||
|
||||
bool
|
||||
HashRouter::addSuppressionPeer(uint256 const& key, PeerShortID peer)
|
||||
{
|
||||
return addSuppressionPeerWithStatus(key, peer).first;
|
||||
}
|
||||
|
||||
std::pair<bool, std::optional<Stopwatch::time_point>>
|
||||
HashRouter::addSuppressionPeerWithStatus(const uint256& key, PeerShortID peer)
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
auto result = emplace(key);
|
||||
result.first.addPeer(peer);
|
||||
return {result.second, result.first.relayed()};
|
||||
}
|
||||
|
||||
bool
|
||||
HashRouter::addSuppressionPeer(uint256 const& key, PeerShortID peer, int& flags)
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
auto [s, created] = emplace(key);
|
||||
s.addPeer(peer);
|
||||
flags = s.getFlags();
|
||||
return created;
|
||||
}
|
||||
|
||||
bool
|
||||
HashRouter::shouldProcess(
|
||||
uint256 const& key,
|
||||
PeerShortID peer,
|
||||
int& flags,
|
||||
std::chrono::seconds tx_interval)
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
auto result = emplace(key);
|
||||
auto& s = result.first;
|
||||
s.addPeer(peer);
|
||||
flags = s.getFlags();
|
||||
return s.shouldProcess(suppressionMap_.clock().now(), tx_interval);
|
||||
}
|
||||
|
||||
int
|
||||
HashRouter::getFlags(uint256 const& key)
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
return emplace(key).first.getFlags();
|
||||
}
|
||||
|
||||
bool
|
||||
HashRouter::setFlags(uint256 const& key, int flags)
|
||||
{
|
||||
assert(flags != 0);
|
||||
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
auto& s = emplace(key).first;
|
||||
|
||||
if ((s.getFlags() & flags) == flags)
|
||||
return false;
|
||||
|
||||
s.setFlags(flags);
|
||||
return true;
|
||||
}
|
||||
|
||||
auto
|
||||
HashRouter::shouldRelay(uint256 const& key)
|
||||
-> std::optional<std::set<PeerShortID>>
|
||||
{
|
||||
std::lock_guard lock(mutex_);
|
||||
|
||||
auto& s = emplace(key).first;
|
||||
|
||||
if (!s.shouldRelay(suppressionMap_.clock().now(), holdTime_))
|
||||
return {};
|
||||
|
||||
return s.releasePeerSet();
|
||||
}
|
||||
|
||||
} // namespace ripple
|
||||
Reference in New Issue
Block a user