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