1 | use super::*; |
2 | use libc::*; |
3 | use std::ptr; |
4 | |
5 | #[cfg (not(osslconf = "OPENSSL_NO_DEPRECATED_3_0" ))] |
6 | pub const SHA_LBLOCK: c_int = 16; |
7 | |
8 | #[cfg (not(osslconf = "OPENSSL_NO_DEPRECATED_3_0" ))] |
9 | pub type SHA_LONG = c_uint; |
10 | |
11 | cfg_if! { |
12 | if #[cfg(ossl300)] { |
13 | #[cfg (ossl300)] |
14 | // Ideally we'd macro define these, but that crashes ctest :( |
15 | pub unsafe fn SHA1(d: *const c_uchar, n: size_t, md: *mut c_uchar) -> *mut c_uchar { |
16 | if EVP_Q_digest( |
17 | ptr::null_mut(), |
18 | "SHA1 \0" .as_ptr() as *const c_char, |
19 | ptr::null(), |
20 | d as *const c_void, |
21 | n, |
22 | md, |
23 | ptr::null_mut(), |
24 | ) != 0 |
25 | { |
26 | md |
27 | } else { |
28 | ptr::null_mut() |
29 | } |
30 | } |
31 | |
32 | pub unsafe fn SHA224(d: *const c_uchar, n: size_t, md: *mut c_uchar) -> *mut c_uchar { |
33 | if EVP_Q_digest( |
34 | ptr::null_mut(), |
35 | "SHA224 \0" .as_ptr() as *const c_char, |
36 | ptr::null(), |
37 | d as *const c_void, |
38 | n, |
39 | md, |
40 | ptr::null_mut(), |
41 | ) != 0 { |
42 | md |
43 | } else { |
44 | ptr::null_mut() |
45 | } |
46 | } |
47 | |
48 | pub unsafe fn SHA256(d: *const c_uchar, n: size_t, md: *mut c_uchar) -> *mut c_uchar { |
49 | if EVP_Q_digest( |
50 | ptr::null_mut(), |
51 | "SHA256 \0" .as_ptr() as *const c_char, |
52 | ptr::null(), |
53 | d as *const c_void, |
54 | n, |
55 | md, |
56 | ptr::null_mut(), |
57 | ) != 0 { |
58 | md |
59 | } else { |
60 | ptr::null_mut() |
61 | } |
62 | } |
63 | } |
64 | } |
65 | |
66 | #[cfg (not(osslconf = "OPENSSL_NO_DEPRECATED_3_0" ))] |
67 | pub type SHA_LONG64 = u64; |
68 | |
69 | cfg_if! { |
70 | if #[cfg(ossl300)] { |
71 | pub unsafe fn SHA384(d: *const c_uchar, n: size_t, md: *mut c_uchar) -> *mut c_uchar { |
72 | if EVP_Q_digest( |
73 | ptr::null_mut(), |
74 | "SHA384 \0" .as_ptr() as *const c_char, |
75 | ptr::null(), |
76 | d as *const c_void, |
77 | n, |
78 | md, |
79 | ptr::null_mut(), |
80 | ) != 0 { |
81 | md |
82 | } else { |
83 | ptr::null_mut() |
84 | } |
85 | } |
86 | |
87 | pub unsafe fn SHA512(d: *const c_uchar, n: size_t, md: *mut c_uchar) -> *mut c_uchar { |
88 | if EVP_Q_digest( |
89 | ptr::null_mut(), |
90 | "SHA512 \0" .as_ptr() as *const c_char, |
91 | ptr::null(), |
92 | d as *const c_void, |
93 | n, |
94 | md, |
95 | ptr::null_mut(), |
96 | ) != 0 { |
97 | md |
98 | } else { |
99 | ptr::null_mut() |
100 | } |
101 | } |
102 | } |
103 | } |
104 | |