From 64106c4d3d4ddba8c7bc2af75376e6d3d3d75601 Mon Sep 17 00:00:00 2001
From:
Date: Mon, 29 Jun 2015 20:16:15 +0000
Subject: Update documentation
---
src/openssl_sys/probe.rs.html | 243 ++++++++++++++++++++++++++++++++++++++++++
1 file changed, 243 insertions(+)
create mode 100644 src/openssl_sys/probe.rs.html
(limited to 'src/openssl_sys/probe.rs.html')
diff --git a/src/openssl_sys/probe.rs.html b/src/openssl_sys/probe.rs.html
new file mode 100644
index 0000000..402d897
--- /dev/null
+++ b/src/openssl_sys/probe.rs.html
@@ -0,0 +1,243 @@
+
+
+
+ 1
+ 2
+ 3
+ 4
+ 5
+ 6
+ 7
+ 8
+ 9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66
+67
+68
+69
+70
+71
+72
+73
+
+use std::env;
+use std::fs;
+use std::path::PathBuf;
+
+pub struct ProbeResult {
+ pub cert_file: Option<PathBuf>,
+ pub cert_dir: Option<PathBuf>,
+}
+
+
+
+
+
+pub fn find_certs_dirs() -> Vec<PathBuf> {
+
+ [
+ "/var/ssl",
+ "/usr/share/ssl",
+ "/usr/local/ssl",
+ "/usr/local/openssl",
+ "/usr/local/share",
+ "/usr/lib/ssl",
+ "/usr/ssl",
+ "/etc/openssl",
+ "/etc/pki/tls",
+ "/etc/ssl",
+ ].iter().map(|s| PathBuf::from(*s)).filter(|p| {
+ fs::metadata(p).is_ok()
+ }).collect()
+}
+
+pub fn init_ssl_cert_env_vars() {
+ let ProbeResult { cert_file, cert_dir } = probe();
+ match cert_file {
+ Some(path) => put("SSL_CERT_FILE", path),
+ None => {}
+ }
+ match cert_dir {
+ Some(path) => put("SSL_CERT_DIR", path),
+ None => {}
+ }
+
+ fn put(var: &str, path: PathBuf) {
+
+ match env::var(var) {
+ Ok(..) => {}
+ Err(..) => env::set_var(var, &path),
+ }
+ }
+}
+
+pub fn probe() -> ProbeResult {
+ let mut result = ProbeResult {
+ cert_file: env::var_os("SSL_CERT_FILE").map(PathBuf::from),
+ cert_dir: env::var_os("SSL_CERT_DIR").map(PathBuf::from),
+ };
+ for certs_dir in find_certs_dirs().iter() {
+
+
+ try(&mut result.cert_file, certs_dir.join("cert.pem"));
+ try(&mut result.cert_file, certs_dir.join("certs/ca-certificates.crt"));
+ try(&mut result.cert_file, certs_dir.join("certs/ca-root-nss.crt"));
+
+ try(&mut result.cert_dir, certs_dir.join("certs"));
+ }
+ result
+}
+
+fn try(dst: &mut Option<PathBuf>, val: PathBuf) {
+ if dst.is_none() && fs::metadata(&val).is_ok() {
+ *dst = Some(val);
+ }
+}
+
+
+