pub struct SealedSeed {
pub id: SealedSeedId,
pub ciphertext: Vec<u8>,
}Expand description
The user node’s provisioned seed that is sealed and persisted using its platform enclave keys that are software and version specific.
This struct is returned directly from the DB so it should be considered as untrusted and not-yet-validated.
- To validate and convert a
SealedSeedinto aRootSeed, useunseal_and_validate. The returnedRootSeedis bound to the returnedDeployEnvandNetwork, which can be used to validate e.g. theNetworksupplied by the Lexe operators via CLI args. - To encrypt an existing
RootSeed(andDeployEnvandNetwork) into aSealedSeed, useseal_from_root_seed.
See lexe_enclave::enclave::seal for more implementation details.
Fields§
§id: SealedSeedId§ciphertext: Vec<u8>The root seed, fully sealed + serialized.
Implementations§
Source§impl SealedSeed
impl SealedSeed
pub fn new( user_pk: UserPk, measurement: Measurement, machine_id: MachineId, ciphertext: Vec<u8>, ) -> SealedSeed
pub fn seal_from_root_seed<R>(
rng: &mut R,
root_seed: &RootSeed,
deploy_env: DeployEnv,
network: Network,
measurement: Measurement,
machine_id: MachineId,
) -> Result<SealedSeed, Error>where
R: Crng,
pub fn unseal_and_validate( self, expected_measurement: &Measurement, expected_machine_id: &MachineId, ) -> Result<(RootSeed, DeployEnv, Network), Error>
Trait Implementations§
Source§impl Clone for SealedSeed
impl Clone for SealedSeed
Source§fn clone(&self) -> SealedSeed
fn clone(&self) -> SealedSeed
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 SealedSeed
impl Debug for SealedSeed
Source§impl<'de> Deserialize<'de> for SealedSeed
impl<'de> Deserialize<'de> for SealedSeed
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<SealedSeed, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<SealedSeed, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for SealedSeed
impl PartialEq for SealedSeed
Source§impl Serialize for SealedSeed
impl Serialize for SealedSeed
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
Source§impl Signable for SealedSeed
impl Signable for SealedSeed
Source§const DOMAIN_SEPARATOR: [u8; 32]
const DOMAIN_SEPARATOR: [u8; 32]
Implementors will only need to fill in this value. An example is
array::pad(*b"LEXE-REALM::RootSeed"), used in the RootSeed.impl StructuralPartialEq for SealedSeed
Auto Trait Implementations§
impl Freeze for SealedSeed
impl RefUnwindSafe for SealedSeed
impl Send for SealedSeed
impl Sync for SealedSeed
impl Unpin for SealedSeed
impl UnsafeUnpin for SealedSeed
impl UnwindSafe for SealedSeed
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