use super::{ArcSealer, Seal, Signature};
use crate::{
common::crypto::{Sha256, SigningKey},
dkim::{Canonicalization, Done, NeedDomain, NeedHeaders, NeedSelector},
};
impl<T: SigningKey<Hasher = Sha256>> ArcSealer<T> {
pub fn from_key(key: T) -> ArcSealer<T, NeedDomain> {
ArcSealer {
_state: Default::default(),
signature: Signature {
a: key.algorithm(),
..Default::default()
},
seal: Seal {
a: key.algorithm(),
..Default::default()
},
key,
}
}
}
impl<T: SigningKey<Hasher = Sha256>> ArcSealer<T, NeedDomain> {
pub fn domain(mut self, domain: impl Into<String> + Clone) -> ArcSealer<T, NeedSelector> {
self.signature.d = domain.clone().into();
self.seal.d = domain.into();
ArcSealer {
_state: Default::default(),
key: self.key,
signature: self.signature,
seal: self.seal,
}
}
}
impl<T: SigningKey<Hasher = Sha256>> ArcSealer<T, NeedSelector> {
pub fn selector(mut self, selector: impl Into<String> + Clone) -> ArcSealer<T, NeedHeaders> {
self.signature.s = selector.clone().into();
self.seal.s = selector.into();
ArcSealer {
_state: Default::default(),
key: self.key,
signature: self.signature,
seal: self.seal,
}
}
}
impl<T: SigningKey<Hasher = Sha256>> ArcSealer<T, NeedHeaders> {
pub fn headers(
mut self,
headers: impl IntoIterator<Item = impl Into<String>>,
) -> ArcSealer<T, Done> {
self.signature.h = headers.into_iter().map(|h| h.into()).collect();
ArcSealer {
_state: Default::default(),
key: self.key,
signature: self.signature,
seal: self.seal,
}
}
}
impl<T: SigningKey<Hasher = Sha256>> ArcSealer<T, Done> {
pub fn expiration(mut self, expiration: u64) -> Self {
self.signature.x = expiration;
self
}
pub fn body_length(mut self, body_length: bool) -> Self {
self.signature.l = u64::from(body_length);
self
}
pub fn header_canonicalization(mut self, ch: Canonicalization) -> Self {
self.signature.ch = ch;
self
}
pub fn body_canonicalization(mut self, cb: Canonicalization) -> Self {
self.signature.cb = cb;
self
}
}