danicoin/src/P2p/P2pProtocolDefinitions.h
2016-01-18 15:33:29 +00:00

296 lines
7.1 KiB
C++
Executable file

// Copyright (c) 2011-2016 The Cryptonote developers
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
#pragma once
#include "P2pProtocolTypes.h"
#include "crypto/crypto.h"
#include "CryptoNoteConfig.h"
#include "CryptoNoteCore/CryptoNoteStatInfo.h"
// new serialization
#include "Serialization/ISerializer.h"
#include "Serialization/SerializationOverloads.h"
#include "CryptoNoteCore/CryptoNoteSerialization.h"
namespace CryptoNote
{
inline bool serialize(uuid& v, Common::StringView name, ISerializer& s) {
return s.binary(&v, sizeof(v), name);
}
struct network_config
{
void serialize(ISerializer& s) {
KV_MEMBER(connections_count)
KV_MEMBER(handshake_interval)
KV_MEMBER(packet_max_size)
KV_MEMBER(config_id)
}
uint32_t connections_count;
uint32_t connection_timeout;
uint32_t ping_connection_timeout;
uint32_t handshake_interval;
uint32_t packet_max_size;
uint32_t config_id;
uint32_t send_peerlist_sz;
};
enum P2PProtocolVersion : uint8_t {
V0 = 0,
V1 = 1,
CURRENT = V1
};
struct basic_node_data
{
uuid network_id;
uint8_t version;
uint64_t local_time;
uint32_t my_port;
PeerIdType peer_id;
void serialize(ISerializer& s) {
KV_MEMBER(network_id)
if (s.type() == ISerializer::INPUT) {
version = 0;
}
KV_MEMBER(version)
KV_MEMBER(peer_id)
KV_MEMBER(local_time)
KV_MEMBER(my_port)
}
};
struct CORE_SYNC_DATA
{
uint32_t current_height;
Crypto::Hash top_id;
void serialize(ISerializer& s) {
KV_MEMBER(current_height)
KV_MEMBER(top_id)
}
};
#define P2P_COMMANDS_POOL_BASE 1000
/************************************************************************/
/* */
/************************************************************************/
struct COMMAND_HANDSHAKE
{
enum { ID = P2P_COMMANDS_POOL_BASE + 1 };
struct request
{
basic_node_data node_data;
CORE_SYNC_DATA payload_data;
void serialize(ISerializer& s) {
KV_MEMBER(node_data)
KV_MEMBER(payload_data)
}
};
struct response
{
basic_node_data node_data;
CORE_SYNC_DATA payload_data;
std::list<PeerlistEntry> local_peerlist;
void serialize(ISerializer& s) {
KV_MEMBER(node_data)
KV_MEMBER(payload_data)
serializeAsBinary(local_peerlist, "local_peerlist", s);
}
};
};
/************************************************************************/
/* */
/************************************************************************/
struct COMMAND_TIMED_SYNC
{
enum { ID = P2P_COMMANDS_POOL_BASE + 2 };
struct request
{
CORE_SYNC_DATA payload_data;
void serialize(ISerializer& s) {
KV_MEMBER(payload_data)
}
};
struct response
{
uint64_t local_time;
CORE_SYNC_DATA payload_data;
std::list<PeerlistEntry> local_peerlist;
void serialize(ISerializer& s) {
KV_MEMBER(local_time)
KV_MEMBER(payload_data)
serializeAsBinary(local_peerlist, "local_peerlist", s);
}
};
};
/************************************************************************/
/* */
/************************************************************************/
struct COMMAND_PING
{
/*
Used to make "callback" connection, to be sure that opponent node
have accessible connection point. Only other nodes can add peer to peerlist,
and ONLY in case when peer has accepted connection and answered to ping.
*/
enum { ID = P2P_COMMANDS_POOL_BASE + 3 };
#define PING_OK_RESPONSE_STATUS_TEXT "OK"
struct request
{
/*actually we don't need to send any real data*/
void serialize(ISerializer& s) {}
};
struct response
{
std::string status;
PeerIdType peer_id;
void serialize(ISerializer& s) {
KV_MEMBER(status)
KV_MEMBER(peer_id)
}
};
};
#ifdef ALLOW_DEBUG_COMMANDS
//These commands are considered as insecure, and made in debug purposes for a limited lifetime.
//Anyone who feel unsafe with this commands can disable the ALLOW_GET_STAT_COMMAND macro.
struct proof_of_trust
{
PeerIdType peer_id;
uint64_t time;
Crypto::Signature sign;
void serialize(ISerializer& s) {
KV_MEMBER(peer_id)
KV_MEMBER(time)
KV_MEMBER(sign)
}
};
inline Crypto::Hash get_proof_of_trust_hash(const proof_of_trust& pot) {
std::string s;
s.append(reinterpret_cast<const char*>(&pot.peer_id), sizeof(pot.peer_id));
s.append(reinterpret_cast<const char*>(&pot.time), sizeof(pot.time));
return Crypto::cn_fast_hash(s.data(), s.size());
}
struct COMMAND_REQUEST_STAT_INFO
{
enum { ID = P2P_COMMANDS_POOL_BASE + 4 };
struct request
{
proof_of_trust tr;
void serialize(ISerializer& s) {
KV_MEMBER(tr)
}
};
struct response
{
std::string version;
std::string os_version;
uint64_t connections_count;
uint64_t incoming_connections_count;
core_stat_info payload_info;
void serialize(ISerializer& s) {
KV_MEMBER(version)
KV_MEMBER(os_version)
KV_MEMBER(connections_count)
KV_MEMBER(incoming_connections_count)
KV_MEMBER(payload_info)
}
};
};
/************************************************************************/
/* */
/************************************************************************/
struct COMMAND_REQUEST_NETWORK_STATE
{
enum { ID = P2P_COMMANDS_POOL_BASE + 5 };
struct request
{
proof_of_trust tr;
void serialize(ISerializer& s) {
KV_MEMBER(tr)
}
};
struct response
{
std::list<PeerlistEntry> local_peerlist_white;
std::list<PeerlistEntry> local_peerlist_gray;
std::list<connection_entry> connections_list;
PeerIdType my_id;
uint64_t local_time;
void serialize(ISerializer& s) {
serializeAsBinary(local_peerlist_white, "local_peerlist_white", s);
serializeAsBinary(local_peerlist_gray, "local_peerlist_gray", s);
serializeAsBinary(connections_list, "connections_list", s);
KV_MEMBER(my_id)
KV_MEMBER(local_time)
}
};
};
/************************************************************************/
/* */
/************************************************************************/
struct COMMAND_REQUEST_PEER_ID
{
enum { ID = P2P_COMMANDS_POOL_BASE + 6 };
struct request
{
void serialize(ISerializer& s) {}
};
struct response
{
PeerIdType my_id;
void serialize(ISerializer& s) {
KV_MEMBER(my_id)
}
};
};
#endif
}