mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-06-17 11:36:39 +00:00

* [NOD-1191] Convert wire protocol to 100% protobuf * [NOD-1191] Simplify wire interface and remove redundant messages * [NOD-1191] Map all proto to wire conversions * [NOD-1203] Create netadapter outside of protocol manager * [NOD-1191] Fix nil errors * [NOD-1191] Fix comments * [NOD-1191] Add converter interface * [NOD-1191] Add missing GetBlockLocator message * [NOD-1191] Change message names that starts with 'get' to 'request' * [NOD-1191] Change message commands values * [NOD-1191] Remove redundant methods * [NOD-1191] Rename message constructors * [NOD-1191] Change message commands to use iota * [NOD-1191] Add missing outputs to protobuf conversion * [NOD-1191] Make block header a required field * [NOD-1191] Rename variables * [NOD-1212] Fix test names * [NOD-1191] Rename flow names * [NOD-1191] Fix infinite loop
199 lines
4.0 KiB
Protocol Buffer
199 lines
4.0 KiB
Protocol Buffer
syntax = "proto3";
|
|
package protowire;
|
|
|
|
option go_package = "github.com/kaspanet/kaspad/protowire";
|
|
|
|
message KaspadMessage {
|
|
oneof payload {
|
|
AddressesMessage addresses = 1;
|
|
BlockMessage block = 2;
|
|
TransactionMessage transaction = 3;
|
|
RequestBlockLocatorMessage requestBlockLocator = 4;
|
|
BlockLocatorMessage blockLocator = 5;
|
|
RequestAddressesMessage requestAddresses = 6;
|
|
RequestIBDBlocksMessage requestIBDBlocks = 7;
|
|
RequestRelayBlocksMessage requestRelayBlocks = 8;
|
|
RequestSelectedTipMessage requestSelectedTip = 9;
|
|
RequestTransactionsMessage requestTransactions = 10;
|
|
BlockMessage ibdBlock = 11;
|
|
InvRelayBlockMessage invRelayBlock = 12;
|
|
InvTransactionsMessage invTransactions = 13;
|
|
PingMessage ping = 14;
|
|
PongMessage pong = 15;
|
|
SelectedTipMessage selectedTip = 16;
|
|
VerackMessage verack = 17;
|
|
VersionMessage version = 18;
|
|
}
|
|
}
|
|
|
|
// AddressesMessage start
|
|
message AddressesMessage{
|
|
bool includeAllSubnetworks = 1;
|
|
SubnetworkID subnetworkID = 2;
|
|
repeated NetAddress addressList = 3;
|
|
}
|
|
|
|
message NetAddress{
|
|
int64 timestamp = 1;
|
|
uint64 services = 2;
|
|
bytes ip = 3;
|
|
uint32 port = 4;
|
|
}
|
|
|
|
message SubnetworkID{
|
|
bytes bytes = 1;
|
|
}
|
|
// AddressesMessage end
|
|
|
|
// GetAddressesMessage start
|
|
message RequestAddressesMessage{
|
|
bool includeAllSubnetworks = 1;
|
|
SubnetworkID subnetworkID = 2;
|
|
}
|
|
// GetAddressesMessage end
|
|
|
|
// TransactionMessage start
|
|
message TransactionMessage{
|
|
int32 version = 1;
|
|
repeated TransactionInput inputs = 2;
|
|
repeated TransactionOutput outputs = 3;
|
|
uint64 lockTime = 4;
|
|
SubnetworkID subnetworkID = 5;
|
|
uint64 gas = 6;
|
|
Hash payloadHash = 7;
|
|
bytes Payload = 8;
|
|
}
|
|
|
|
message TransactionInput{
|
|
Outpoint PreviousOutpoint = 1;
|
|
bytes SignatureScript = 2;
|
|
uint64 Sequence = 3;
|
|
}
|
|
|
|
message Outpoint{
|
|
TransactionID transactionID = 1;
|
|
uint32 index = 2;
|
|
}
|
|
|
|
message TransactionID{
|
|
bytes bytes = 1;
|
|
}
|
|
|
|
message TransactionOutput{
|
|
uint64 value = 1;
|
|
bytes ScriptPubKey = 2;
|
|
}
|
|
// TransactionMessage end
|
|
|
|
// BlockMessage start
|
|
message BlockMessage{
|
|
BlockHeader header = 1;
|
|
repeated TransactionMessage transactions = 2;
|
|
}
|
|
|
|
message BlockHeader{
|
|
int32 version = 1;
|
|
repeated Hash parentHashes = 2;
|
|
Hash hashMerkleRoot = 3;
|
|
Hash acceptedIDMerkleRoot = 4;
|
|
Hash utxoCommitment = 5;
|
|
int64 timestamp = 6;
|
|
uint32 bits = 7;
|
|
uint64 nonce = 8;
|
|
}
|
|
|
|
message Hash{
|
|
bytes bytes = 1;
|
|
}
|
|
// BlockMessage end
|
|
|
|
// GetBlockLocatorMessage start
|
|
message RequestBlockLocatorMessage{
|
|
Hash lowHash = 1;
|
|
Hash highHash = 2;
|
|
}
|
|
// GetBlockLocatorMessage end
|
|
|
|
// BlockLocatorMessage start
|
|
message BlockLocatorMessage{
|
|
repeated Hash hashes = 1;
|
|
}
|
|
// BlockLocatorMessage end
|
|
|
|
// GetBlocksMessage start
|
|
message RequestIBDBlocksMessage{
|
|
Hash lowHash = 1;
|
|
Hash highHash = 2;
|
|
}
|
|
// GetBlocksMessage end
|
|
|
|
// GetRelayBlocksMessage start
|
|
message RequestRelayBlocksMessage{
|
|
repeated Hash hashes = 1;
|
|
}
|
|
// GetRelayBlocksMessage end
|
|
|
|
// GetSelectedTipMessage start
|
|
message RequestSelectedTipMessage{
|
|
}
|
|
// GetSelectedTipMessage end
|
|
|
|
// GetTransactionsMessage start
|
|
message RequestTransactionsMessage{
|
|
repeated TransactionID ids = 1;
|
|
}
|
|
// GetTransactionsMessage end
|
|
|
|
// InvRelayBlockMessage start
|
|
message InvRelayBlockMessage{
|
|
Hash hash = 1;
|
|
}
|
|
// InvRelayBlockMessage end
|
|
|
|
// InvTransactionMessage start
|
|
message InvTransactionsMessage{
|
|
repeated TransactionID ids = 1;
|
|
}
|
|
// InvTransactionMessage end
|
|
|
|
// PingMessage start
|
|
message PingMessage{
|
|
uint64 nonce = 1;
|
|
}
|
|
// PingMessage end
|
|
|
|
// PongMessage start
|
|
message PongMessage{
|
|
uint64 nonce = 1;
|
|
}
|
|
// PongMessage end
|
|
|
|
// SelectedTipMessage start
|
|
message SelectedTipMessage{
|
|
Hash selectedTipHash = 1;
|
|
}
|
|
// SelectedTipMessage end
|
|
|
|
// VerackMessage start
|
|
message VerackMessage{
|
|
}
|
|
// VerackMessage end
|
|
|
|
// VersionMessage start
|
|
message VersionMessage{
|
|
uint32 protocolVersion = 1;
|
|
uint64 services = 2;
|
|
int64 timestamp = 3;
|
|
NetAddress address = 4;
|
|
bytes id = 5;
|
|
string userAgent = 6;
|
|
Hash selectedTipHash = 7;
|
|
bool disableRelayTx = 8;
|
|
SubnetworkID subnetworkID = 9;
|
|
}
|
|
// VersionMessage end
|
|
|
|
service P2P {
|
|
rpc MessageStream (stream KaspadMessage) returns (stream KaspadMessage) {}
|
|
}
|