use bamboo_rs_core_ed25519_yasmf::entry::is_lipmaa_required;
use crate::entry::SIGNATURE_SIZE;
use crate::entry::{LogId, SeqNum, Signature};
use crate::hash::Hash;
use crate::identity::PublicKey;
pub trait AsEntry {
fn public_key(&self) -> &PublicKey;
fn log_id(&self) -> &LogId;
fn seq_num(&self) -> &SeqNum;
fn skiplink(&self) -> Option<&Hash>;
fn backlink(&self) -> Option<&Hash>;
fn payload_size(&self) -> u64;
fn payload_hash(&self) -> &Hash;
fn signature(&self) -> &Signature;
fn seq_num_backlink(&self) -> Option<SeqNum> {
self.seq_num().backlink_seq_num()
}
fn seq_num_skiplink(&self) -> Option<SeqNum> {
self.seq_num().skiplink_seq_num()
}
fn is_skiplink_required(&self) -> bool {
is_lipmaa_required(self.seq_num().as_u64())
}
}
pub trait AsEncodedEntry {
fn hash(&self) -> Hash;
#[allow(clippy::wrong_self_convention)]
fn into_bytes(&self) -> Vec<u8>;
fn size(&self) -> u64;
fn unsigned_bytes(&self) -> Vec<u8> {
let bytes = self.into_bytes();
let signature_offset = bytes.len() - SIGNATURE_SIZE;
bytes[..signature_offset].into()
}
#[allow(clippy::wrong_self_convention)]
fn into_hex(&self) -> String {
hex::encode(self.into_bytes())
}
}