mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-05-22 06:46:46 +00:00

* Extract syncPruningPointUTXOSet to a separate method. * Implement logic to send pruning point utxo set chunks in a loop. * Replace IBDRootUTXOSetAndBlockMessage with IbdRootUtxoSetChunkMessage. * Add a new message: RequestNextIBDRootUTXOSetChunk. * Add a new message: DoneIBDRootUTXOSetChunks. * Protect HandleRequestIBDRootUTXOSetAndBlock from rogue messages. * Reimplement receiveIBDRootUTXOSetAndBlock. * Add CmdDoneIBDRootUTXOSetChunks to the HandleRelayInvs flow. * Decrease the max message size to 10mb. * Fix bad step. * Fix confusion between outgoing/incoming routes. * Measure how long it takes to send/receive the UTXO set. * Use LogAndMeasure in handleRequestIBDRootUTXOSetAndBlockFlow.
189 lines
3.1 KiB
Protocol Buffer
189 lines
3.1 KiB
Protocol Buffer
syntax = "proto3";
|
|
package protowire;
|
|
|
|
option go_package = "github.com/kaspanet/kaspad/protowire";
|
|
|
|
message RequestAddressesMessage{
|
|
bool includeAllSubnetworks = 1;
|
|
SubnetworkId subnetworkId = 2;
|
|
}
|
|
|
|
message AddressesMessage{
|
|
repeated NetAddress addressList = 1;
|
|
}
|
|
|
|
message NetAddress{
|
|
int64 timestamp = 1;
|
|
uint64 services = 2;
|
|
bytes ip = 3;
|
|
uint32 port = 4;
|
|
}
|
|
|
|
message SubnetworkId{
|
|
bytes bytes = 1;
|
|
}
|
|
|
|
message TransactionMessage{
|
|
uint32 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 ScriptPublicKey {
|
|
bytes script = 1;
|
|
uint32 version = 2;
|
|
}
|
|
|
|
message TransactionOutput{
|
|
uint64 value = 1;
|
|
ScriptPublicKey scriptPublicKey = 2;
|
|
}
|
|
|
|
message BlockMessage{
|
|
BlockHeaderMessage header = 1;
|
|
repeated TransactionMessage transactions = 2;
|
|
}
|
|
|
|
message BlockHeaderMessage{
|
|
uint32 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;
|
|
}
|
|
|
|
message RequestBlockLocatorMessage{
|
|
Hash lowHash = 1;
|
|
Hash highHash = 2;
|
|
uint32 limit = 3;
|
|
}
|
|
|
|
message BlockLocatorMessage{
|
|
repeated Hash hashes = 1;
|
|
}
|
|
|
|
message RequestHeadersMessage{
|
|
Hash lowHash = 1;
|
|
Hash highHash = 2;
|
|
}
|
|
|
|
message RequestNextHeadersMessage{
|
|
}
|
|
|
|
message DoneHeadersMessage{
|
|
}
|
|
|
|
message RequestRelayBlocksMessage{
|
|
repeated Hash hashes = 1;
|
|
}
|
|
|
|
message RequestTransactionsMessage {
|
|
repeated TransactionId ids = 1;
|
|
}
|
|
|
|
message TransactionNotFoundMessage{
|
|
TransactionId id = 1;
|
|
}
|
|
|
|
message InvRelayBlockMessage{
|
|
Hash hash = 1;
|
|
}
|
|
|
|
message InvTransactionsMessage{
|
|
repeated TransactionId ids = 1;
|
|
}
|
|
|
|
message PingMessage{
|
|
uint64 nonce = 1;
|
|
}
|
|
|
|
message PongMessage{
|
|
uint64 nonce = 1;
|
|
}
|
|
|
|
message VerackMessage{
|
|
}
|
|
|
|
message VersionMessage{
|
|
uint32 protocolVersion = 1;
|
|
uint64 services = 2;
|
|
int64 timestamp = 3;
|
|
NetAddress address = 4;
|
|
bytes id = 5;
|
|
string userAgent = 6;
|
|
bool disableRelayTx = 8;
|
|
SubnetworkId subnetworkId = 9;
|
|
string network = 10;
|
|
}
|
|
|
|
message RejectMessage{
|
|
string reason = 1;
|
|
}
|
|
|
|
message RequestIBDRootUTXOSetAndBlockMessage{
|
|
Hash ibdRoot = 1;
|
|
}
|
|
|
|
message IbdRootUtxoSetChunkMessage{
|
|
bytes chunk = 1;
|
|
}
|
|
|
|
message RequestNextIbdRootUtxoSetChunkMessage {
|
|
}
|
|
|
|
message DoneIbdRootUtxoSetChunksMessage {
|
|
}
|
|
|
|
message RequestIBDBlocksMessage{
|
|
repeated Hash hashes = 1;
|
|
}
|
|
|
|
message IBDRootNotFoundMessage{
|
|
}
|
|
|
|
message RequestIBDRootHashMessage{
|
|
}
|
|
|
|
message IBDRootHashMessage{
|
|
Hash hash = 1;
|
|
}
|
|
|
|
message IbdBlockLocatorMessage {
|
|
Hash targetHash = 1;
|
|
repeated Hash blockLocatorHashes = 2;
|
|
}
|
|
|
|
message IbdBlockLocatorHighestHashMessage {
|
|
Hash highestHash = 1;
|
|
}
|
|
|
|
message BlockHeadersMessage {
|
|
repeated BlockHeaderMessage blockHeaders = 1;
|
|
}
|