iota_types/
executable_transaction.rs1use serde::{Deserialize, Serialize};
6
7use crate::{
8 committee::EpochId,
9 crypto::AuthorityStrongQuorumSignInfo,
10 message_envelope::{Envelope, TrustedEnvelope, VerifiedEnvelope},
11 messages_checkpoint::CheckpointSequenceNumber,
12 transaction::{SenderSignedData, TransactionDataAPI},
13};
14
15#[derive(Clone, Debug, Serialize, Deserialize)]
20pub enum CertificateProof {
21 Checkpoint(EpochId, CheckpointSequenceNumber),
23 Certified(AuthorityStrongQuorumSignInfo),
25 QuorumExecuted(EpochId),
29 SystemTransaction(EpochId),
32}
33
34impl CertificateProof {
35 pub fn new_from_cert_sig(sig: AuthorityStrongQuorumSignInfo) -> Self {
36 Self::Certified(sig)
37 }
38
39 pub fn new_from_checkpoint(epoch: EpochId, checkpoint: CheckpointSequenceNumber) -> Self {
40 Self::Checkpoint(epoch, checkpoint)
41 }
42
43 pub fn new_system(epoch: EpochId) -> Self {
44 Self::SystemTransaction(epoch)
45 }
46
47 pub fn epoch(&self) -> EpochId {
48 match self {
49 Self::Checkpoint(epoch, _)
50 | Self::QuorumExecuted(epoch)
51 | Self::SystemTransaction(epoch) => *epoch,
52 Self::Certified(sig) => sig.epoch,
53 }
54 }
55}
56
57pub type ExecutableTransaction = Envelope<SenderSignedData, CertificateProof>;
63pub type VerifiedExecutableTransaction = VerifiedEnvelope<SenderSignedData, CertificateProof>;
64pub type TrustedExecutableTransaction = TrustedEnvelope<SenderSignedData, CertificateProof>;
65
66impl VerifiedExecutableTransaction {
67 pub fn certificate_sig(&self) -> Option<&AuthorityStrongQuorumSignInfo> {
68 match self.auth_sig() {
69 CertificateProof::Certified(sig) => Some(sig),
70 _ => None,
71 }
72 }
73
74 pub fn gas_budget(&self) -> u64 {
75 self.data().transaction_data().gas_budget()
76 }
77}