cat_gateway/db/index/block/cip36/
insert_cip36_invalid.rsuse std::{fmt::Debug, sync::Arc};
use cardano_chain_follower::Metadata::cip36::{Cip36, VotingPubKey};
use scylla::{frame::value::MaybeUnset, SerializeRow, Session};
use tracing::error;
use crate::{
db::index::queries::{PreparedQueries, SizedBatch},
settings::cassandra_db,
};
const INSERT_CIP36_REGISTRATION_INVALID_QUERY: &str =
include_str!("./cql/insert_cip36_invalid.cql");
#[derive(SerializeRow, Clone)]
pub(super) struct Params {
stake_address: Vec<u8>,
slot_no: num_bigint::BigInt,
txn: i16,
vote_key: Vec<u8>,
payment_address: Vec<u8>,
is_payable: bool,
raw_nonce: num_bigint::BigInt,
nonce: num_bigint::BigInt,
cip36: MaybeUnset<bool>,
signed: bool,
error_report: Vec<String>,
}
impl Debug for Params {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
let cip36 = match self.cip36 {
MaybeUnset::Unset => "UNSET",
MaybeUnset::Set(v) => &format!("{v:?}"),
};
f.debug_struct("Params")
.field("stake_address", &self.stake_address)
.field("slot_no", &self.slot_no)
.field("txn", &self.txn)
.field("vote_key", &self.vote_key)
.field("payment_address", &self.payment_address)
.field("is_payable", &self.is_payable)
.field("raw_nonce", &self.raw_nonce)
.field("nonce", &self.nonce)
.field("cip36", &cip36)
.field("signed", &self.signed)
.field("error_report", &self.error_report)
.finish()
}
}
impl Params {
pub fn new(
vote_key: Option<&VotingPubKey>, slot_no: u64, txn: i16, cip36: &Cip36,
error_report: Vec<String>,
) -> Self {
let vote_key = if let Some(vote_key) = vote_key {
vote_key.voting_pk.to_bytes().to_vec()
} else {
Vec::new()
};
Params {
stake_address: cip36
.stake_pk
.map(|s| s.to_bytes().to_vec())
.unwrap_or_default(),
slot_no: slot_no.into(),
txn,
vote_key,
payment_address: cip36.payment_addr.clone(),
is_payable: cip36.payable,
raw_nonce: cip36.raw_nonce.into(),
nonce: cip36.nonce.into(),
cip36: if let Some(cip36) = cip36.cip36 {
MaybeUnset::Set(cip36)
} else {
MaybeUnset::Unset
},
signed: cip36.signed,
error_report,
}
}
pub(super) async fn prepare_batch(
session: &Arc<Session>, cfg: &cassandra_db::EnvVars,
) -> anyhow::Result<SizedBatch> {
let insert_queries = PreparedQueries::prepare_batch(
session.clone(),
INSERT_CIP36_REGISTRATION_INVALID_QUERY,
cfg,
scylla::statement::Consistency::Any,
true,
false,
)
.await;
if let Err(ref error) = insert_queries {
error!(error=%error,"Failed to prepare Insert CIP-36 Registration Invalid Query.");
};
insert_queries
}
}