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 141)
129fn run_signature_example() -> Result<()> {
130 println!("\nQuantum Digital Signatures");
131 println!("-------------------------");
132
133 // Create quantum signature with 256 qubits
134 let num_qubits = 256;
135 println!("Creating quantum signature scheme with {num_qubits} qubits");
136
137 // Choose a quantum-resistant algorithm
138 let algorithm = "Dilithium";
139 println!("Using algorithm: {algorithm}");
140
141 let signature = QuantumSignature::new(num_qubits, algorithm)?;
142 println!("Quantum signature scheme created");
143
144 // Sign a message
145 let message = b"This message is quantum-signed";
146 println!(
147 "Signing message: '{}'",
148 std::str::from_utf8(message).unwrap()
149 );
150
151 let start = Instant::now();
152 let sig = signature.sign(message)?;
153 println!("Signature generated in {:.2?}", start.elapsed());
154 println!("Signature size: {} bytes", sig.len());
155
156 // Verify signature
157 println!("Verifying signature...");
158 let start = Instant::now();
159 let is_valid = signature.verify(message, &sig)?;
160 println!("Verification completed in {:.2?}", start.elapsed());
161
162 if is_valid {
163 println!("✓ Signature verification successful!");
164 } else {
165 println!("✗ Signature verification failed!");
166 }
167
168 // Try with tampered message
169 let tampered = b"This message has been modified";
170 println!("Verifying signature with tampered message...");
171 let is_valid = signature.verify(tampered, &sig)?;
172
173 if is_valid {
174 println!("✗ Signature incorrectly verified on tampered message!");
175 } else {
176 println!("✓ Signature correctly rejected tampered message!");
177 }
178
179 Ok(())
180}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 152)
129fn run_signature_example() -> Result<()> {
130 println!("\nQuantum Digital Signatures");
131 println!("-------------------------");
132
133 // Create quantum signature with 256 qubits
134 let num_qubits = 256;
135 println!("Creating quantum signature scheme with {num_qubits} qubits");
136
137 // Choose a quantum-resistant algorithm
138 let algorithm = "Dilithium";
139 println!("Using algorithm: {algorithm}");
140
141 let signature = QuantumSignature::new(num_qubits, algorithm)?;
142 println!("Quantum signature scheme created");
143
144 // Sign a message
145 let message = b"This message is quantum-signed";
146 println!(
147 "Signing message: '{}'",
148 std::str::from_utf8(message).unwrap()
149 );
150
151 let start = Instant::now();
152 let sig = signature.sign(message)?;
153 println!("Signature generated in {:.2?}", start.elapsed());
154 println!("Signature size: {} bytes", sig.len());
155
156 // Verify signature
157 println!("Verifying signature...");
158 let start = Instant::now();
159 let is_valid = signature.verify(message, &sig)?;
160 println!("Verification completed in {:.2?}", start.elapsed());
161
162 if is_valid {
163 println!("✓ Signature verification successful!");
164 } else {
165 println!("✗ Signature verification failed!");
166 }
167
168 // Try with tampered message
169 let tampered = b"This message has been modified";
170 println!("Verifying signature with tampered message...");
171 let is_valid = signature.verify(tampered, &sig)?;
172
173 if is_valid {
174 println!("✗ Signature incorrectly verified on tampered message!");
175 } else {
176 println!("✓ Signature correctly rejected tampered message!");
177 }
178
179 Ok(())
180}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 159)
129fn run_signature_example() -> Result<()> {
130 println!("\nQuantum Digital Signatures");
131 println!("-------------------------");
132
133 // Create quantum signature with 256 qubits
134 let num_qubits = 256;
135 println!("Creating quantum signature scheme with {num_qubits} qubits");
136
137 // Choose a quantum-resistant algorithm
138 let algorithm = "Dilithium";
139 println!("Using algorithm: {algorithm}");
140
141 let signature = QuantumSignature::new(num_qubits, algorithm)?;
142 println!("Quantum signature scheme created");
143
144 // Sign a message
145 let message = b"This message is quantum-signed";
146 println!(
147 "Signing message: '{}'",
148 std::str::from_utf8(message).unwrap()
149 );
150
151 let start = Instant::now();
152 let sig = signature.sign(message)?;
153 println!("Signature generated in {:.2?}", start.elapsed());
154 println!("Signature size: {} bytes", sig.len());
155
156 // Verify signature
157 println!("Verifying signature...");
158 let start = Instant::now();
159 let is_valid = signature.verify(message, &sig)?;
160 println!("Verification completed in {:.2?}", start.elapsed());
161
162 if is_valid {
163 println!("✓ Signature verification successful!");
164 } else {
165 println!("✗ Signature verification failed!");
166 }
167
168 // Try with tampered message
169 let tampered = b"This message has been modified";
170 println!("Verifying signature with tampered message...");
171 let is_valid = signature.verify(tampered, &sig)?;
172
173 if is_valid {
174 println!("✗ Signature incorrectly verified on tampered message!");
175 } else {
176 println!("✓ Signature correctly rejected tampered message!");
177 }
178
179 Ok(())
180}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.