Compare commits
No commits in common. "2f977dc7dd4f65c56544c99188c271b7cf5f1213" and "96e7e0936e52b4fa8f2115264a1b96e935349ca1" have entirely different histories.
2f977dc7dd
...
96e7e0936e
|
@ -1,16 +1,8 @@
|
||||||
#![doc = include_str!("../README.md")]
|
|
||||||
#![no_std]
|
#![no_std]
|
||||||
#![allow(clippy::missing_safety_doc, non_camel_case_types, non_snake_case, non_upper_case_globals)]
|
#![allow(non_camel_case_types)]
|
||||||
#![deny(
|
#![allow(non_snake_case)]
|
||||||
clippy::expect_used,
|
#![allow(non_upper_case_globals)]
|
||||||
clippy::panic,
|
#![allow(clippy::missing_safety_doc)]
|
||||||
clippy::panic_in_result_fn,
|
|
||||||
clippy::unwrap_in_result,
|
|
||||||
clippy::unwrap_used,
|
|
||||||
clippy::zero_ptr,
|
|
||||||
unused_lifetimes,
|
|
||||||
unused_qualifications
|
|
||||||
)]
|
|
||||||
|
|
||||||
#[cfg(feature = "dont-assume-size_t-equals-uintptr_t")]
|
#[cfg(feature = "dont-assume-size_t-equals-uintptr_t")]
|
||||||
use libc::size_t;
|
use libc::size_t;
|
||||||
|
|
|
@ -25,36 +25,3 @@ ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
||||||
THIS SOFTWARE.
|
THIS SOFTWARE.
|
||||||
Footer
|
Footer
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
## RustCrypto Projects
|
|
||||||
|
|
||||||
* General layout and `lib.rs` is inspired from how RustCrypto people do it.
|
|
||||||
|
|
||||||
```
|
|
||||||
Copyright (c) 2021 The RustCrypto Project Developers
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
|
||||||
person obtaining a copy of this software and associated
|
|
||||||
documentation files (the "Software"), to deal in the
|
|
||||||
Software without restriction, including without
|
|
||||||
limitation the rights to use, copy, modify, merge,
|
|
||||||
publish, distribute, sublicense, and/or sell copies of
|
|
||||||
the Software, and to permit persons to whom the Software
|
|
||||||
is furnished to do so, subject to the following
|
|
||||||
conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
|
||||||
shall be included in all copies or substantial portions
|
|
||||||
of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF
|
|
||||||
ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
|
|
||||||
TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
|
||||||
PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
|
||||||
SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
||||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
|
|
||||||
IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
DEALINGS IN THE SOFTWARE.
|
|
||||||
```
|
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
mod private;
|
|
||||||
mod public;
|
|
||||||
|
|
||||||
pub use private::PrivateKey;
|
|
||||||
pub use public::PublicKey;
|
|
|
@ -1,31 +0,0 @@
|
||||||
use core::ops::Drop;
|
|
||||||
use core::slice;
|
|
||||||
|
|
||||||
use bearssl_sys::br_ec_private_key;
|
|
||||||
|
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct PrivateKey(pub(crate) br_ec_private_key);
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl Drop for PrivateKey {
|
|
||||||
fn drop(&mut self) {
|
|
||||||
use zeroize::Zeroize;
|
|
||||||
|
|
||||||
self.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::ZeroizeOnDrop for PrivateKey {}
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::Zeroize for PrivateKey {
|
|
||||||
fn zeroize(&mut self) {
|
|
||||||
// Safety: Slice constructions should be safe as long as lengths have not been modified
|
|
||||||
// outside what BearSSL set.
|
|
||||||
unsafe {
|
|
||||||
let x = slice::from_raw_parts_mut(self.0.x, self.0.xlen);
|
|
||||||
x.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,17 +0,0 @@
|
||||||
use core::ops::Drop;
|
|
||||||
use core::slice;
|
|
||||||
|
|
||||||
use bearssl_sys::br_ec_public_key;
|
|
||||||
|
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct PublicKey(pub(crate) br_ec_public_key);
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::Zeroize for PublicKey {
|
|
||||||
fn zeroize(&mut self) {
|
|
||||||
unsafe {
|
|
||||||
let q = slice::from_raw_parts_mut(self.0.q, self.0.qlen);
|
|
||||||
q.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,20 +1,8 @@
|
||||||
#![doc = include_str!("../README.md")]
|
|
||||||
#![no_std]
|
#![no_std]
|
||||||
#![deny(
|
|
||||||
clippy::expect_used,
|
|
||||||
clippy::panic,
|
|
||||||
clippy::panic_in_result_fn,
|
|
||||||
clippy::unwrap_in_result,
|
|
||||||
clippy::unwrap_used,
|
|
||||||
clippy::zero_ptr,
|
|
||||||
unused_lifetimes,
|
|
||||||
unused_qualifications
|
|
||||||
)]
|
|
||||||
|
|
||||||
#[cfg(feature = "std")]
|
#[cfg(feature = "std")]
|
||||||
extern crate std;
|
extern crate std;
|
||||||
|
|
||||||
pub mod ec;
|
|
||||||
pub mod engine;
|
pub mod engine;
|
||||||
pub mod profile;
|
pub mod profile;
|
||||||
pub mod rsa;
|
pub mod rsa;
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
mod private;
|
use bearssl_sys::*;
|
||||||
mod public;
|
|
||||||
|
|
||||||
pub use private::PrivateKey;
|
pub struct PublicKey(pub(crate) br_rsa_public_key);
|
||||||
pub use public::PublicKey;
|
pub struct PrivateKey(pub(crate) br_rsa_private_key);
|
||||||
|
|
|
@ -1,43 +0,0 @@
|
||||||
use core::ops::Drop;
|
|
||||||
use core::slice;
|
|
||||||
|
|
||||||
use bearssl_sys::br_rsa_private_key;
|
|
||||||
|
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct PrivateKey(pub(crate) br_rsa_private_key);
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl Drop for PrivateKey {
|
|
||||||
fn drop(&mut self) {
|
|
||||||
use zeroize::Zeroize;
|
|
||||||
|
|
||||||
self.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::ZeroizeOnDrop for PrivateKey {}
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::Zeroize for PrivateKey {
|
|
||||||
fn zeroize(&mut self) {
|
|
||||||
// Safety: Slice constructions should be safe as long as lengths have not been modified
|
|
||||||
// outside what BearSSL set.
|
|
||||||
unsafe {
|
|
||||||
let p = slice::from_raw_parts_mut(self.0.p, self.0.plen);
|
|
||||||
p.zeroize();
|
|
||||||
|
|
||||||
let q = slice::from_raw_parts_mut(self.0.q, self.0.qlen);
|
|
||||||
q.zeroize();
|
|
||||||
|
|
||||||
let dp = slice::from_raw_parts_mut(self.0.dp, self.0.dplen);
|
|
||||||
dp.zeroize();
|
|
||||||
|
|
||||||
let dq = slice::from_raw_parts_mut(self.0.dq, self.0.dqlen);
|
|
||||||
dq.zeroize();
|
|
||||||
|
|
||||||
let iq = slice::from_raw_parts_mut(self.0.iq, self.0.iqlen);
|
|
||||||
iq.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,20 +0,0 @@
|
||||||
use core::ops::Drop;
|
|
||||||
use core::slice;
|
|
||||||
|
|
||||||
use bearssl_sys::br_rsa_public_key;
|
|
||||||
|
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct PublicKey(pub(crate) br_rsa_public_key);
|
|
||||||
|
|
||||||
#[cfg(feature = "zeroize")]
|
|
||||||
impl zeroize::Zeroize for PublicKey {
|
|
||||||
fn zeroize(&mut self) {
|
|
||||||
unsafe {
|
|
||||||
let n = slice::from_raw_parts_mut(self.0.n, self.0.nlen);
|
|
||||||
n.zeroize();
|
|
||||||
|
|
||||||
let e = slice::from_raw_parts_mut(self.0.e, self.0.elen);
|
|
||||||
e.zeroize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue