2011-08-11 18:14:53 +02:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2014-02-08 22:50:24 +01:00
|
|
|
// Copyright (c) 2009-2014 The Bitcoin developers
|
2011-08-11 18:14:53 +02:00
|
|
|
// Distributed under the MIT/X11 software license, see the accompanying
|
2012-05-18 16:02:28 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
2011-08-11 18:14:53 +02:00
|
|
|
|
|
|
|
#include "protocol.h"
|
2013-04-13 07:13:08 +02:00
|
|
|
|
2014-06-04 12:51:29 +02:00
|
|
|
#include "chainparams.h"
|
2011-08-11 18:40:12 +02:00
|
|
|
#include "util.h"
|
2014-09-25 05:32:36 +02:00
|
|
|
#include "utilstrencodings.h"
|
2013-04-13 07:13:08 +02:00
|
|
|
|
2011-10-07 17:02:21 +02:00
|
|
|
#ifndef WIN32
|
2011-08-11 18:40:12 +02:00
|
|
|
# include <arpa/inet.h>
|
|
|
|
#endif
|
|
|
|
|
2011-08-11 18:49:03 +02:00
|
|
|
static const char* ppszTypeName[] =
|
|
|
|
{
|
|
|
|
"ERROR",
|
|
|
|
"tx",
|
|
|
|
"block",
|
2015-02-06 20:07:22 +01:00
|
|
|
"filtered block",
|
|
|
|
"tx lock request",
|
2015-02-09 20:28:29 +01:00
|
|
|
"tx lock vote",
|
2015-02-09 21:22:31 +01:00
|
|
|
"spork",
|
2015-02-09 23:39:50 +01:00
|
|
|
"masternode winner",
|
2015-04-22 16:33:44 +02:00
|
|
|
"masternode scan",
|
|
|
|
"masternode vote",
|
2015-05-04 17:04:09 +02:00
|
|
|
"masternode proposal",
|
2015-04-22 16:33:44 +02:00
|
|
|
"masternode quorum",
|
|
|
|
"masternode announce",
|
|
|
|
"masternode ping",
|
2015-02-09 23:39:50 +01:00
|
|
|
"unknown",
|
|
|
|
"unknown",
|
|
|
|
"unknown",
|
|
|
|
"unknown",
|
2015-03-13 10:28:20 +01:00
|
|
|
"unknown",
|
2015-02-09 23:39:50 +01:00
|
|
|
"unknown"
|
2011-08-11 18:49:03 +02:00
|
|
|
};
|
2011-08-11 18:14:53 +02:00
|
|
|
|
|
|
|
CMessageHeader::CMessageHeader()
|
|
|
|
{
|
2013-05-07 15:16:25 +02:00
|
|
|
memcpy(pchMessageStart, Params().MessageStart(), MESSAGE_START_SIZE);
|
2011-08-11 18:14:53 +02:00
|
|
|
memset(pchCommand, 0, sizeof(pchCommand));
|
|
|
|
nMessageSize = -1;
|
|
|
|
nChecksum = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
CMessageHeader::CMessageHeader(const char* pszCommand, unsigned int nMessageSizeIn)
|
|
|
|
{
|
2013-05-07 15:16:25 +02:00
|
|
|
memcpy(pchMessageStart, Params().MessageStart(), MESSAGE_START_SIZE);
|
2014-09-16 18:13:05 +02:00
|
|
|
memset(pchCommand, 0, sizeof(pchCommand));
|
2011-08-11 18:14:53 +02:00
|
|
|
strncpy(pchCommand, pszCommand, COMMAND_SIZE);
|
|
|
|
nMessageSize = nMessageSizeIn;
|
|
|
|
nChecksum = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string CMessageHeader::GetCommand() const
|
|
|
|
{
|
2015-02-17 22:15:01 +01:00
|
|
|
return std::string(pchCommand, pchCommand + strnlen_int(pchCommand, COMMAND_SIZE));
|
2011-08-11 18:14:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool CMessageHeader::IsValid() const
|
|
|
|
{
|
|
|
|
// Check start string
|
2013-05-07 15:16:25 +02:00
|
|
|
if (memcmp(pchMessageStart, Params().MessageStart(), MESSAGE_START_SIZE) != 0)
|
2011-08-11 18:14:53 +02:00
|
|
|
return false;
|
|
|
|
|
|
|
|
// Check the command string for errors
|
|
|
|
for (const char* p1 = pchCommand; p1 < pchCommand + COMMAND_SIZE; p1++)
|
|
|
|
{
|
|
|
|
if (*p1 == 0)
|
|
|
|
{
|
|
|
|
// Must be all zeros after the first zero
|
|
|
|
for (; p1 < pchCommand + COMMAND_SIZE; p1++)
|
|
|
|
if (*p1 != 0)
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
else if (*p1 < ' ' || *p1 > 0x7E)
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Message size
|
|
|
|
if (nMessageSize > MAX_SIZE)
|
|
|
|
{
|
2014-01-16 16:15:27 +01:00
|
|
|
LogPrintf("CMessageHeader::IsValid() : (%s, %u bytes) nMessageSize > MAX_SIZE\n", GetCommand(), nMessageSize);
|
2011-08-11 18:14:53 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2011-08-11 18:40:12 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
2012-01-03 23:33:31 +01:00
|
|
|
CAddress::CAddress() : CService()
|
2011-08-11 18:40:12 +02:00
|
|
|
{
|
|
|
|
Init();
|
|
|
|
}
|
|
|
|
|
2013-04-13 07:13:08 +02:00
|
|
|
CAddress::CAddress(CService ipIn, uint64_t nServicesIn) : CService(ipIn)
|
2011-08-11 18:40:12 +02:00
|
|
|
{
|
|
|
|
Init();
|
2012-01-03 23:33:31 +01:00
|
|
|
nServices = nServicesIn;
|
2011-08-11 18:40:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void CAddress::Init()
|
|
|
|
{
|
|
|
|
nServices = NODE_NETWORK;
|
|
|
|
nTime = 100000000;
|
|
|
|
nLastTry = 0;
|
|
|
|
}
|
|
|
|
|
2011-08-11 18:49:03 +02:00
|
|
|
CInv::CInv()
|
|
|
|
{
|
|
|
|
type = 0;
|
|
|
|
hash = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
CInv::CInv(int typeIn, const uint256& hashIn)
|
|
|
|
{
|
|
|
|
type = typeIn;
|
|
|
|
hash = hashIn;
|
|
|
|
}
|
|
|
|
|
|
|
|
CInv::CInv(const std::string& strType, const uint256& hashIn)
|
|
|
|
{
|
2012-04-15 22:52:09 +02:00
|
|
|
unsigned int i;
|
2011-08-11 18:49:03 +02:00
|
|
|
for (i = 1; i < ARRAYLEN(ppszTypeName); i++)
|
|
|
|
{
|
|
|
|
if (strType == ppszTypeName[i])
|
|
|
|
{
|
|
|
|
type = i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (i == ARRAYLEN(ppszTypeName))
|
2014-01-16 16:15:27 +01:00
|
|
|
throw std::out_of_range(strprintf("CInv::CInv(string, uint256) : unknown type '%s'", strType));
|
2011-08-11 18:49:03 +02:00
|
|
|
hash = hashIn;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator<(const CInv& a, const CInv& b)
|
|
|
|
{
|
|
|
|
return (a.type < b.type || (a.type == b.type && a.hash < b.hash));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool CInv::IsKnownType() const
|
|
|
|
{
|
2012-04-22 19:51:16 +02:00
|
|
|
return (type >= 1 && type < (int)ARRAYLEN(ppszTypeName));
|
2011-08-11 18:49:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const char* CInv::GetCommand() const
|
|
|
|
{
|
|
|
|
if (!IsKnownType())
|
|
|
|
throw std::out_of_range(strprintf("CInv::GetCommand() : type=%d unknown type", type));
|
|
|
|
return ppszTypeName[type];
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string CInv::ToString() const
|
|
|
|
{
|
2014-01-16 16:15:27 +01:00
|
|
|
return strprintf("%s %s", GetCommand(), hash.ToString());
|
2011-08-11 18:49:03 +02:00
|
|
|
}
|