2016-12-20 14:26:45 +01:00
|
|
|
// Copyright (c) 2014-2017 The Dash Core developers
|
2016-09-27 09:50:04 +02:00
|
|
|
// Distributed under the MIT/X11 software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef NETFULFILLEDMAN_H
|
|
|
|
#define NETFULFILLEDMAN_H
|
|
|
|
|
|
|
|
#include "netbase.h"
|
|
|
|
#include "protocol.h"
|
|
|
|
#include "serialize.h"
|
|
|
|
#include "sync.h"
|
|
|
|
|
|
|
|
class CNetFulfilledRequestManager;
|
|
|
|
extern CNetFulfilledRequestManager netfulfilledman;
|
|
|
|
|
|
|
|
// Fulfilled requests are used to prevent nodes from asking for the same data on sync
|
|
|
|
// and from being banned for doing so too often.
|
|
|
|
class CNetFulfilledRequestManager
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
typedef std::map<std::string, int64_t> fulfilledreqmapentry_t;
|
|
|
|
typedef std::map<CNetAddr, fulfilledreqmapentry_t> fulfilledreqmap_t;
|
|
|
|
|
|
|
|
//keep track of what node has/was asked for and when
|
|
|
|
fulfilledreqmap_t mapFulfilledRequests;
|
|
|
|
CCriticalSection cs_mapFulfilledRequests;
|
|
|
|
|
|
|
|
public:
|
|
|
|
CNetFulfilledRequestManager() {}
|
|
|
|
|
|
|
|
ADD_SERIALIZE_METHODS;
|
|
|
|
|
|
|
|
template <typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action, int nType, int nVersion) {
|
|
|
|
LOCK(cs_mapFulfilledRequests);
|
|
|
|
READWRITE(mapFulfilledRequests);
|
|
|
|
}
|
|
|
|
|
|
|
|
void AddFulfilledRequest(CAddress addr, std::string strRequest); // expire after 1 hour by default
|
|
|
|
bool HasFulfilledRequest(CAddress addr, std::string strRequest);
|
|
|
|
void RemoveFulfilledRequest(CAddress addr, std::string strRequest);
|
|
|
|
|
|
|
|
void CheckAndRemove();
|
|
|
|
void Clear();
|
|
|
|
|
|
|
|
std::string ToString() const;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|