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