pub struct ProvenanceSigner { /* private fields */ }Expand description
In-process HMAC-SHA256 signer for the recall hot path.
Caller-side responsibility: rotate (key_id, key) on whatever
cadence your security posture demands and keep the historical
pairs accessible to the verifier. The struct holds a single key;
to handle multiple keys (active + historical) wrap several
ProvenanceSigners in a Keystore (see
crate::encryption::ContentEncryption for the equivalent
pattern on the at-rest side).
Implementations§
Source§impl ProvenanceSigner
impl ProvenanceSigner
Sourcepub fn new(key_id: impl Into<String>, key: &[u8]) -> Self
pub fn new(key_id: impl Into<String>, key: &[u8]) -> Self
Construct from a 32-byte key + a stable identifier.
Operators should set the key from secure storage (Vault,
AWS KMS, etc.) and choose an id like "mnemo-prov-2026-04"
that survives logging.
pub fn key_id(&self) -> &str
Sourcepub fn sign(
&self,
agent_id: impl Into<String>,
query: &str,
records: &[MemoryRecord],
) -> Result<ReadProvenance, ProvenanceError>
pub fn sign( &self, agent_id: impl Into<String>, query: &str, records: &[MemoryRecord], ) -> Result<ReadProvenance, ProvenanceError>
Build a signed ReadProvenance for one recall.
Trait Implementations§
Source§impl Clone for ProvenanceSigner
impl Clone for ProvenanceSigner
Source§fn clone(&self) -> ProvenanceSigner
fn clone(&self) -> ProvenanceSigner
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for ProvenanceSigner
impl Debug for ProvenanceSigner
Source§impl ProvenanceKeystore for ProvenanceSigner
Single-key implementation for the common case.
impl ProvenanceKeystore for ProvenanceSigner
Single-key implementation for the common case.
Auto Trait Implementations§
impl Freeze for ProvenanceSigner
impl RefUnwindSafe for ProvenanceSigner
impl Send for ProvenanceSigner
impl Sync for ProvenanceSigner
impl Unpin for ProvenanceSigner
impl UnsafeUnpin for ProvenanceSigner
impl UnwindSafe for ProvenanceSigner
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more