pub struct QuantumSignature { /* private fields */ }Expand description
Quantum digital signature
Implementations§
Source§impl QuantumSignature
impl QuantumSignature
Sourcepub fn new(security_bits: usize, algorithm: &str) -> Result<Self>
pub fn new(security_bits: usize, algorithm: &str) -> Result<Self>
Creates a new quantum signature
Examples found in repository?
examples/quantum_crypto.rs (line 134)
122fn run_signature_example() -> Result<()> {
123 println!("\nQuantum Digital Signatures");
124 println!("-------------------------");
125
126 // Create quantum signature with 256 qubits
127 let num_qubits = 256;
128 println!("Creating quantum signature scheme with {num_qubits} qubits");
129
130 // Choose a quantum-resistant algorithm
131 let algorithm = "Dilithium";
132 println!("Using algorithm: {algorithm}");
133
134 let signature = QuantumSignature::new(num_qubits, algorithm)?;
135 println!("Quantum signature scheme created");
136
137 // Sign a message
138 let message = b"This message is quantum-signed";
139 println!(
140 "Signing message: '{}'",
141 std::str::from_utf8(message).unwrap()
142 );
143
144 let start = Instant::now();
145 let sig = signature.sign(message)?;
146 println!("Signature generated in {:.2?}", start.elapsed());
147 println!("Signature size: {} bytes", sig.len());
148
149 // Verify signature
150 println!("Verifying signature...");
151 let start = Instant::now();
152 let is_valid = signature.verify(message, &sig)?;
153 println!("Verification completed in {:.2?}", start.elapsed());
154
155 if is_valid {
156 println!("✓ Signature verification successful!");
157 } else {
158 println!("✗ Signature verification failed!");
159 }
160
161 // Try with tampered message
162 let tampered = b"This message has been modified";
163 println!("Verifying signature with tampered message...");
164 let is_valid = signature.verify(tampered, &sig)?;
165
166 if is_valid {
167 println!("✗ Signature incorrectly verified on tampered message!");
168 } else {
169 println!("✓ Signature correctly rejected tampered message!");
170 }
171
172 Ok(())
173}Sourcepub fn sign(&self, message: &[u8]) -> Result<Vec<u8>>
pub fn sign(&self, message: &[u8]) -> Result<Vec<u8>>
Signs a message
Examples found in repository?
examples/quantum_crypto.rs (line 145)
122fn run_signature_example() -> Result<()> {
123 println!("\nQuantum Digital Signatures");
124 println!("-------------------------");
125
126 // Create quantum signature with 256 qubits
127 let num_qubits = 256;
128 println!("Creating quantum signature scheme with {num_qubits} qubits");
129
130 // Choose a quantum-resistant algorithm
131 let algorithm = "Dilithium";
132 println!("Using algorithm: {algorithm}");
133
134 let signature = QuantumSignature::new(num_qubits, algorithm)?;
135 println!("Quantum signature scheme created");
136
137 // Sign a message
138 let message = b"This message is quantum-signed";
139 println!(
140 "Signing message: '{}'",
141 std::str::from_utf8(message).unwrap()
142 );
143
144 let start = Instant::now();
145 let sig = signature.sign(message)?;
146 println!("Signature generated in {:.2?}", start.elapsed());
147 println!("Signature size: {} bytes", sig.len());
148
149 // Verify signature
150 println!("Verifying signature...");
151 let start = Instant::now();
152 let is_valid = signature.verify(message, &sig)?;
153 println!("Verification completed in {:.2?}", start.elapsed());
154
155 if is_valid {
156 println!("✓ Signature verification successful!");
157 } else {
158 println!("✗ Signature verification failed!");
159 }
160
161 // Try with tampered message
162 let tampered = b"This message has been modified";
163 println!("Verifying signature with tampered message...");
164 let is_valid = signature.verify(tampered, &sig)?;
165
166 if is_valid {
167 println!("✗ Signature incorrectly verified on tampered message!");
168 } else {
169 println!("✓ Signature correctly rejected tampered message!");
170 }
171
172 Ok(())
173}Sourcepub fn verify(&self, message: &[u8], signature: &[u8]) -> Result<bool>
pub fn verify(&self, message: &[u8], signature: &[u8]) -> Result<bool>
Verifies a signature
Examples found in repository?
examples/quantum_crypto.rs (line 152)
122fn run_signature_example() -> Result<()> {
123 println!("\nQuantum Digital Signatures");
124 println!("-------------------------");
125
126 // Create quantum signature with 256 qubits
127 let num_qubits = 256;
128 println!("Creating quantum signature scheme with {num_qubits} qubits");
129
130 // Choose a quantum-resistant algorithm
131 let algorithm = "Dilithium";
132 println!("Using algorithm: {algorithm}");
133
134 let signature = QuantumSignature::new(num_qubits, algorithm)?;
135 println!("Quantum signature scheme created");
136
137 // Sign a message
138 let message = b"This message is quantum-signed";
139 println!(
140 "Signing message: '{}'",
141 std::str::from_utf8(message).unwrap()
142 );
143
144 let start = Instant::now();
145 let sig = signature.sign(message)?;
146 println!("Signature generated in {:.2?}", start.elapsed());
147 println!("Signature size: {} bytes", sig.len());
148
149 // Verify signature
150 println!("Verifying signature...");
151 let start = Instant::now();
152 let is_valid = signature.verify(message, &sig)?;
153 println!("Verification completed in {:.2?}", start.elapsed());
154
155 if is_valid {
156 println!("✓ Signature verification successful!");
157 } else {
158 println!("✗ Signature verification failed!");
159 }
160
161 // Try with tampered message
162 let tampered = b"This message has been modified";
163 println!("Verifying signature with tampered message...");
164 let is_valid = signature.verify(tampered, &sig)?;
165
166 if is_valid {
167 println!("✗ Signature incorrectly verified on tampered message!");
168 } else {
169 println!("✓ Signature correctly rejected tampered message!");
170 }
171
172 Ok(())
173}Trait Implementations§
Source§impl Clone for QuantumSignature
impl Clone for QuantumSignature
Source§fn clone(&self) -> QuantumSignature
fn clone(&self) -> QuantumSignature
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 moreAuto Trait Implementations§
impl Freeze for QuantumSignature
impl RefUnwindSafe for QuantumSignature
impl Send for QuantumSignature
impl Sync for QuantumSignature
impl Unpin for QuantumSignature
impl UnwindSafe for QuantumSignature
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> 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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.