| 1 | #![allow ( |
| 2 | clippy::missing_safety_doc, |
| 3 | dead_code, |
| 4 | non_camel_case_types, |
| 5 | non_snake_case, |
| 6 | non_upper_case_globals, |
| 7 | unused_imports |
| 8 | )] |
| 9 | #![doc (html_root_url = "https://docs.rs/openssl-sys/0.9" )] |
| 10 | #![recursion_limit = "128" ] // configure fixed limit across all rust versions |
| 11 | |
| 12 | extern crate libc; |
| 13 | pub use libc::c_int; |
| 14 | |
| 15 | #[cfg (feature = "unstable_boringssl" )] |
| 16 | extern crate bssl_sys; |
| 17 | |
| 18 | #[cfg (boringssl)] |
| 19 | #[path = "." ] |
| 20 | mod boringssl { |
| 21 | #[cfg (feature = "unstable_boringssl" )] |
| 22 | pub use bssl_sys::*; |
| 23 | #[cfg (not(feature = "unstable_boringssl" ))] |
| 24 | include!(concat!(env!("OUT_DIR" ), "/bindgen.rs" )); |
| 25 | |
| 26 | // BoringSSL does not require initialization. |
| 27 | pub fn init() {} |
| 28 | } |
| 29 | #[cfg (boringssl)] |
| 30 | pub use boringssl::*; |
| 31 | |
| 32 | #[cfg (feature = "aws-lc" )] |
| 33 | extern crate aws_lc_sys; |
| 34 | |
| 35 | #[cfg (awslc)] |
| 36 | #[path = "." ] |
| 37 | mod aws_lc { |
| 38 | #[cfg (feature = "aws-lc" )] |
| 39 | pub use aws_lc_sys::*; |
| 40 | |
| 41 | #[cfg (not(feature = "aws-lc" ))] |
| 42 | include!(concat!(env!("OUT_DIR" ), "/bindgen.rs" )); |
| 43 | |
| 44 | use libc::{c_char, c_long, c_void}; |
| 45 | |
| 46 | pub fn init() { |
| 47 | unsafe { CRYPTO_library_init() } |
| 48 | } |
| 49 | |
| 50 | // BIO_get_mem_data is a C preprocessor macro by definition |
| 51 | #[allow (non_snake_case, clippy::not_unsafe_ptr_arg_deref)] |
| 52 | pub fn BIO_get_mem_data(b: *mut BIO, pp: *mut *mut c_char) -> c_long { |
| 53 | unsafe { BIO_ctrl(b, BIO_CTRL_INFO, 0, pp.cast::<c_void>()) } |
| 54 | } |
| 55 | } |
| 56 | #[cfg (awslc)] |
| 57 | pub use aws_lc::*; |
| 58 | |
| 59 | #[cfg (openssl)] |
| 60 | #[path = "." ] |
| 61 | mod openssl { |
| 62 | use libc::*; |
| 63 | |
| 64 | #[cfg (feature = "bindgen" )] |
| 65 | include!(concat!(env!("OUT_DIR" ), "/bindgen.rs" )); |
| 66 | |
| 67 | pub use self::aes::*; |
| 68 | pub use self::asn1::*; |
| 69 | pub use self::bio::*; |
| 70 | pub use self::bn::*; |
| 71 | pub use self::cms::*; |
| 72 | pub use self::crypto::*; |
| 73 | pub use self::dtls1::*; |
| 74 | pub use self::ec::*; |
| 75 | pub use self::err::*; |
| 76 | pub use self::evp::*; |
| 77 | #[cfg (not(feature = "bindgen" ))] |
| 78 | pub use self::handwritten::*; |
| 79 | pub use self::obj_mac::*; |
| 80 | pub use self::ocsp::*; |
| 81 | pub use self::pem::*; |
| 82 | pub use self::pkcs7::*; |
| 83 | pub use self::rsa::*; |
| 84 | pub use self::sha::*; |
| 85 | pub use self::srtp::*; |
| 86 | pub use self::ssl::*; |
| 87 | pub use self::ssl3::*; |
| 88 | pub use self::tls1::*; |
| 89 | pub use self::types::*; |
| 90 | pub use self::x509::*; |
| 91 | pub use self::x509_vfy::*; |
| 92 | pub use self::x509v3::*; |
| 93 | |
| 94 | #[macro_use ] |
| 95 | mod macros; |
| 96 | |
| 97 | mod aes; |
| 98 | mod asn1; |
| 99 | mod bio; |
| 100 | mod bn; |
| 101 | mod cms; |
| 102 | mod crypto; |
| 103 | mod dtls1; |
| 104 | mod ec; |
| 105 | mod err; |
| 106 | mod evp; |
| 107 | #[cfg (not(feature = "bindgen" ))] |
| 108 | mod handwritten; |
| 109 | mod obj_mac; |
| 110 | mod ocsp; |
| 111 | mod pem; |
| 112 | mod pkcs7; |
| 113 | mod rsa; |
| 114 | mod sha; |
| 115 | mod srtp; |
| 116 | mod ssl; |
| 117 | mod ssl3; |
| 118 | mod tls1; |
| 119 | mod types; |
| 120 | mod x509; |
| 121 | mod x509_vfy; |
| 122 | mod x509v3; |
| 123 | |
| 124 | use std::sync::Once; |
| 125 | // explicitly initialize to work around https://github.com/openssl/openssl/issues/3505 |
| 126 | static INIT: Once = Once::new(); |
| 127 | |
| 128 | // FIXME remove |
| 129 | pub type PasswordCallback = unsafe extern "C" fn( |
| 130 | buf: *mut c_char, |
| 131 | size: c_int, |
| 132 | rwflag: c_int, |
| 133 | user_data: *mut c_void, |
| 134 | ) -> c_int; |
| 135 | |
| 136 | #[cfg (ossl110)] |
| 137 | pub fn init() { |
| 138 | use std::ptr; |
| 139 | |
| 140 | #[cfg (not(ossl111b))] |
| 141 | let init_options = OPENSSL_INIT_LOAD_SSL_STRINGS; |
| 142 | #[cfg (ossl111b)] |
| 143 | let init_options = OPENSSL_INIT_LOAD_SSL_STRINGS | OPENSSL_INIT_NO_ATEXIT; |
| 144 | |
| 145 | INIT.call_once(|| unsafe { |
| 146 | OPENSSL_init_ssl(init_options, ptr::null_mut()); |
| 147 | }) |
| 148 | } |
| 149 | |
| 150 | #[cfg (not(ossl110))] |
| 151 | pub fn init() { |
| 152 | use std::io::{self, Write}; |
| 153 | use std::mem; |
| 154 | use std::process; |
| 155 | use std::sync::{Mutex, MutexGuard}; |
| 156 | |
| 157 | static mut MUTEXES: *mut Vec<Mutex<()>> = 0 as *mut Vec<Mutex<()>>; |
| 158 | static mut GUARDS: *mut Vec<Option<MutexGuard<'static, ()>>> = |
| 159 | 0 as *mut Vec<Option<MutexGuard<'static, ()>>>; |
| 160 | |
| 161 | unsafe extern "C" fn locking_function( |
| 162 | mode: c_int, |
| 163 | n: c_int, |
| 164 | _file: *const c_char, |
| 165 | _line: c_int, |
| 166 | ) { |
| 167 | let mutex = &(*MUTEXES)[n as usize]; |
| 168 | |
| 169 | if mode & CRYPTO_LOCK != 0 { |
| 170 | (*GUARDS)[n as usize] = Some(mutex.lock().unwrap()); |
| 171 | } else { |
| 172 | if let None = (*GUARDS)[n as usize].take() { |
| 173 | let _ = writeln!( |
| 174 | io::stderr(), |
| 175 | "BUG: rust-openssl lock {} already unlocked, aborting" , |
| 176 | n |
| 177 | ); |
| 178 | process::abort(); |
| 179 | } |
| 180 | } |
| 181 | } |
| 182 | |
| 183 | cfg_if! { |
| 184 | if #[cfg(unix)] { |
| 185 | fn set_id_callback() { |
| 186 | unsafe extern "C" fn thread_id() -> c_ulong { |
| 187 | ::libc::pthread_self() as c_ulong |
| 188 | } |
| 189 | |
| 190 | unsafe { |
| 191 | CRYPTO_set_id_callback__fixed_rust(Some(thread_id)); |
| 192 | } |
| 193 | } |
| 194 | } else { |
| 195 | fn set_id_callback() {} |
| 196 | } |
| 197 | } |
| 198 | |
| 199 | INIT.call_once(|| unsafe { |
| 200 | SSL_library_init(); |
| 201 | SSL_load_error_strings(); |
| 202 | OPENSSL_add_all_algorithms_noconf(); |
| 203 | |
| 204 | let num_locks = CRYPTO_num_locks(); |
| 205 | let mut mutexes = Box::new(Vec::new()); |
| 206 | for _ in 0..num_locks { |
| 207 | mutexes.push(Mutex::new(())); |
| 208 | } |
| 209 | MUTEXES = mem::transmute(mutexes); |
| 210 | let guards: Box<Vec<Option<MutexGuard<()>>>> = |
| 211 | Box::new((0..num_locks).map(|_| None).collect()); |
| 212 | GUARDS = mem::transmute(guards); |
| 213 | |
| 214 | CRYPTO_set_locking_callback__fixed_rust(Some(locking_function)); |
| 215 | set_id_callback(); |
| 216 | }) |
| 217 | } |
| 218 | |
| 219 | /// Disable explicit initialization of the openssl libs. |
| 220 | /// |
| 221 | /// This is only appropriate to use if the openssl crate is being consumed by an application |
| 222 | /// that will be performing the initialization explicitly. |
| 223 | /// |
| 224 | /// # Safety |
| 225 | /// |
| 226 | /// In some versions of openssl, skipping initialization will fall back to the default procedure |
| 227 | /// while other will cause difficult to debug errors so care must be taken when calling this. |
| 228 | pub unsafe fn assume_init() { |
| 229 | INIT.call_once(|| {}); |
| 230 | } |
| 231 | } |
| 232 | #[cfg (openssl)] |
| 233 | pub use openssl::*; |
| 234 | |