forked from cryptonotefoundation/cryptonote
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBlockchainExplorerData.h
119 lines (99 loc) · 2.59 KB
/
BlockchainExplorerData.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// Copyright (c) 2011-2015 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 <array>
#include <string>
#include <vector>
#include "CryptoTypes.h"
#include <boost/variant.hpp>
namespace CryptoNote {
enum class TransactionRemoveReason : uint8_t
{
INCLUDED_IN_BLOCK = 0,
TIMEOUT = 1
};
struct TransactionOutputToKeyDetails {
Crypto::PublicKey txOutKey;
};
struct TransactionOutputMultisignatureDetails {
std::vector<Crypto::PublicKey> keys;
uint32_t requiredSignatures;
};
struct TransactionOutputDetails {
uint64_t amount;
uint32_t globalIndex;
boost::variant<
TransactionOutputToKeyDetails,
TransactionOutputMultisignatureDetails> output;
};
struct TransactionOutputReferenceDetails {
Crypto::Hash transactionHash;
size_t number;
};
struct TransactionInputGenerateDetails {
uint32_t height;
};
struct TransactionInputToKeyDetails {
std::vector<uint32_t> outputIndexes;
Crypto::KeyImage keyImage;
uint64_t mixin;
TransactionOutputReferenceDetails output;
};
struct TransactionInputMultisignatureDetails {
uint32_t signatures;
TransactionOutputReferenceDetails output;
};
struct TransactionInputDetails {
uint64_t amount;
boost::variant<
TransactionInputGenerateDetails,
TransactionInputToKeyDetails,
TransactionInputMultisignatureDetails> input;
};
struct TransactionExtraDetails {
std::vector<size_t> padding;
std::vector<Crypto::PublicKey> publicKey;
std::vector<std::string> nonce;
std::vector<uint8_t> raw;
};
struct TransactionDetails {
Crypto::Hash hash;
uint64_t size;
uint64_t fee;
uint64_t totalInputsAmount;
uint64_t totalOutputsAmount;
uint64_t mixin;
uint64_t unlockTime;
uint64_t timestamp;
Crypto::Hash paymentId;
bool inBlockchain;
Crypto::Hash blockHash;
uint32_t blockHeight;
TransactionExtraDetails extra;
std::vector<std::vector<Crypto::Signature>> signatures;
std::vector<TransactionInputDetails> inputs;
std::vector<TransactionOutputDetails> outputs;
};
struct BlockDetails {
uint8_t majorVersion;
uint8_t minorVersion;
uint64_t timestamp;
Crypto::Hash prevBlockHash;
uint32_t nonce;
bool isOrphaned;
uint32_t height;
Crypto::Hash hash;
uint64_t difficulty;
uint64_t reward;
uint64_t baseReward;
uint64_t blockSize;
uint64_t transactionsCumulativeSize;
uint64_t alreadyGeneratedCoins;
uint64_t alreadyGeneratedTransactions;
uint64_t sizeMedian;
double penalty;
uint64_t totalFeeAmount;
std::vector<TransactionDetails> transactions;
};
}