use crate::*;
impl<'info> Validate<'info> for SetRole<'info> {
fn validate(&self) -> Result<()> {
assert_keys_eq!(self.operator.admin, self.admin, Unauthorized);
Ok(())
}
}
impl<'info> Validate<'info> for DelegateSetAnnualRewards<'info> {
fn validate(&self) -> Result<()> {
assert_keys_eq!(
self.with_delegate.operator.rate_setter,
self.with_delegate.delegate,
Unauthorized
);
self.with_delegate.validate()?;
Ok(())
}
}
impl<'info> Validate<'info> for DelegateSetRewardsShare<'info> {
fn validate(&self) -> Result<()> {
assert_keys_eq!(
self.quarry.rewarder,
self.with_delegate.rewarder,
Unauthorized
);
assert_keys_eq!(
self.with_delegate.operator.share_allocator,
self.with_delegate.delegate,
Unauthorized
);
self.with_delegate.validate()?;
Ok(())
}
}
impl<'info> Validate<'info> for DelegateSetFamine<'info> {
fn validate(&self) -> Result<()> {
assert_keys_eq!(
self.quarry.rewarder,
self.with_delegate.rewarder,
Unauthorized
);
assert_keys_eq!(
self.with_delegate.operator.share_allocator,
self.with_delegate.delegate,
Unauthorized
);
self.with_delegate.validate()?;
Ok(())
}
}
impl<'info> Validate<'info> for WithDelegate<'info> {
fn validate(&self) -> Result<()> {
assert_keys_eq!(self.operator.rewarder, self.rewarder);
assert_keys_eq!(self.operator, self.rewarder.authority);
Ok(())
}
}