use tp_inherents::{InherentIdentifier, InherentData, Error};
#[cfg(feature = "std")]
use tp_inherents::{InherentDataProviders, ProvideInherentData};
pub const INHERENT_IDENTIFIER: InherentIdentifier = *b"auraslot";
pub type InherentType = tp_consensus_slots::Slot;
pub trait AuraInherentData {
fn aura_inherent_data(&self) ->Result<InherentType, Error>;
fn aura_replace_inherent_data(&mut self, new: InherentType);
}
impl AuraInherentData for InherentData {
fn aura_inherent_data(&self) ->Result<InherentType, Error> {
self.get_data(&INHERENT_IDENTIFIER)
.and_then(|r| r.ok_or_else(|| "Aura inherent data not found".into()))
}
fn aura_replace_inherent_data(&mut self, new: InherentType) {
self.replace_data(INHERENT_IDENTIFIER, &new);
}
}
#[cfg(feature = "std")]
pub struct InherentDataProvider {
slot_duration: u64,
}
#[cfg(feature = "std")]
impl InherentDataProvider {
pub fn new(slot_duration: u64) -> Self {
Self {
slot_duration
}
}
}
#[cfg(feature = "std")]
impl ProvideInherentData for InherentDataProvider {
fn on_register(
&self,
providers: &InherentDataProviders,
) ->Result<(), Error> {
if !providers.has_provider(&tp_timestamp::INHERENT_IDENTIFIER) {
providers.register_provider(tp_timestamp::InherentDataProvider)
} else {
Ok(())
}
}
fn inherent_identifier(&self) -> &'static InherentIdentifier {
&INHERENT_IDENTIFIER
}
fn provide_inherent_data(
&self,
inherent_data: &mut InherentData,
) ->Result<(), Error> {
use tp_timestamp::TimestampInherentData;
let timestamp = inherent_data.timestamp_inherent_data()?;
let slot = timestamp / self.slot_duration;
inherent_data.put_data(INHERENT_IDENTIFIER, &slot)
}
fn error_to_string(&self, error: &[u8]) -> Option<String> {
use codec::Decode;
tp_inherents::Error::decode(&mut &error[..]).map(|e| e.into_string()).ok()
}
}