mirror of
https://github.com/dashpay/dash.git
synced 2024-12-27 04:52:59 +01:00
50 lines
1.5 KiB
C
50 lines
1.5 KiB
C
|
// Copyright (c) 2014-2016 The Dash Core developers
|
||
|
// 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
|