Ori Newman 4736213ba4
[NOD-1528] Make data stores copy data on stage (#1020)
* [NOD-1528] Make data stores copy data on stage

* [NOD-1528] Add proto objects to serialize consensus state objects

* [NOD-1528] Fix receiver names

* [NOD-1528] Add copy to block store and utxo diff staging

* [NOD-1528] Return errors where needed
2020-11-10 18:32:42 +02:00

153 lines
2.8 KiB
Protocol Buffer

syntax = "proto3";
package serialization;
option go_package = "github.com/kaspanet/kaspad/serialization";
message DbBlock {
DbBlockHeader header = 1;
repeated DbTransaction transactions = 2;
}
message DbBlockHeader {
int32 version = 1;
repeated DbHash parentHashes = 2;
DbHash hashMerkleRoot = 3;
DbHash acceptedIDMerkleRoot = 4;
DbHash utxoCommitment = 5;
int64 timeInMilliseconds = 6;
uint32 bits = 7;
uint64 nonce = 8;
}
message DbHash {
bytes hash = 1;
}
message DbTransaction {
int32 version = 1;
repeated DbTransactionInput inputs = 2;
repeated DbTransactionOutput outputs = 3;
uint64 lockTime = 4;
DbSubnetworkId subnetworkID = 5;
uint64 gas = 6;
DbHash payloadHash = 7;
bytes payload = 8;
}
message DbTransactionInput {
DbOutpoint previousOutpoint = 1;
bytes signatureScript = 2;
uint64 sequence = 3;
}
message DbOutpoint {
DbTransactionId transactionID = 1;
uint32 index = 2;
}
message DbTransactionId {
bytes transactionId = 1;
}
message DbTransactionOutput {
uint64 value = 1;
bytes scriptPublicKey = 2;
}
message DbSubnetworkId {
bytes subnetworkId = 1;
}
message DbAcceptanceData {
repeated DbBlockAcceptanceData blockAcceptanceData = 1;
}
message DbBlockAcceptanceData {
repeated DbTransactionAcceptanceData transactionAcceptanceData = 1;
}
message DbTransactionAcceptanceData {
DbTransaction transaction = 1;
uint64 fee = 2;
bool isAccepted = 3;
}
message DbBlockRelations {
repeated DbHash parents = 1;
repeated DbHash children = 2;
}
message DbBlockStatus {
uint32 status = 1;
}
message DbBlockGhostdagData {
uint64 blueScore = 1;
DbHash selectedParent = 2;
repeated DbHash mergeSetBlues = 3;
repeated DbHash mergeSetReds = 4;
repeated DbBluesAnticoneSizes bluesAnticoneSizes = 5;
}
message DbBluesAnticoneSizes {
DbHash blueHash = 1;
uint32 anticoneSize = 2;
}
message DbMultiset {
bytes multiset = 1;
}
message DbUtxoSet {
repeated DbUtxoCollectionItem items = 1;
}
message DbUtxoCollectionItem {
DbOutpoint outpoint = 1;
DbUtxoEntry utxoEntry = 2;
}
message DbUtxoEntry {
uint64 amount = 1;
bytes scriptPublicKey = 2;
uint64 blockBlueScore = 3;
bool isCoinbase = 4;
}
message DbReachabilityData {
DbReachabilityTreeNode treeNode = 1;
repeated DbHash futureCoveringSet = 2;
}
message DbReachabilityTreeNode {
repeated DbHash children = 1;
DbHash parent = 2;
DbReachabilityInterval interval = 3;
}
message DbReachabilityInterval {
uint64 start = 1;
uint64 end = 2;
}
message DbUtxoDiff {
repeated DbUtxoCollectionItem toAdd = 1;
repeated DbUtxoCollectionItem toRemove = 2;
}
message DbPruningPointUTXOSetBytes {
bytes bytes = 1;
}
message DbHeaderTips {
repeated DbHash tips = 1;
}
message DbTips {
repeated DbHash tips = 1;
}
message DbVirtualDiffParents {
repeated DbHash virtualDiffParents = 1;
}