use codec::Codec;
use pezcumulus_primitives_aura::AuraUnincludedSegmentApi;
use pezsp_consensus_aura::AuraApi;
use pezsp_runtime::{
app_crypto::{AppCrypto, AppPair, AppSignature, Pair},
traits::Block as BlockT,
};
pub trait AuraIdT: AppCrypto<Pair = Self::BoundedPair> + Codec + Send {
type BoundedPair: AppPair + AppCrypto<Signature = Self::BoundedSignature>;
type BoundedSignature: AppSignature
+ TryFrom<Vec<u8>>
+ std::hash::Hash
+ pezsp_runtime::traits::Member
+ Codec;
}
impl<T> AuraIdT for T
where
T: AppCrypto + Codec + Send + Sync,
<<T as AppCrypto>::Pair as AppCrypto>::Signature:
TryFrom<Vec<u8>> + std::hash::Hash + pezsp_runtime::traits::Member + Codec,
{
type BoundedPair = <T as AppCrypto>::Pair;
type BoundedSignature = <<T as AppCrypto>::Pair as AppCrypto>::Signature;
}
pub trait AuraRuntimeApi<Block: BlockT, AuraId: AuraIdT>:
pezsp_api::ApiExt<Block>
+ AuraApi<Block, <AuraId::BoundedPair as Pair>::Public>
+ AuraUnincludedSegmentApi<Block>
+ Sized
{
fn has_aura_api(&self, at: Block::Hash) -> bool {
self.has_api::<dyn AuraApi<Block, <AuraId::BoundedPair as Pair>::Public>>(at)
.unwrap_or(false)
}
}
impl<T, Block: BlockT, AuraId: AuraIdT> AuraRuntimeApi<Block, AuraId> for T where
T: pezsp_api::ApiExt<Block>
+ AuraApi<Block, <AuraId::BoundedPair as Pair>::Public>
+ AuraUnincludedSegmentApi<Block>
{
}