Skip to content

Commit

Permalink
Add macos-system-configuration feature flag
Browse files Browse the repository at this point in the history
  • Loading branch information
littledivy committed Jan 2, 2024
1 parent 4f54ba7 commit 8bb1d65
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 7 deletions.
7 changes: 5 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ features = [
]

[features]
default = ["default-tls"]
default = ["default-tls", "macos-system-configuration"]

# Note: this doesn't enable the 'native-tls' feature, which adds specific
# functionality for it.
Expand Down Expand Up @@ -63,6 +63,9 @@ stream = ["tokio/fs", "tokio-util", "wasm-streams"]

socks = ["tokio-socks"]

# Use the system's proxy configuration.
macos-system-configuration = ["system-configuration"]

# Experimental HTTP/3 client.
http3 = ["rustls-tls-manual-roots", "h3", "h3-quinn", "quinn", "futures-channel"]

Expand Down Expand Up @@ -159,7 +162,7 @@ tokio = { version = "1.0", default-features = false, features = ["macros", "rt-m
winreg = "0.50.0"

[target.'cfg(target_os = "macos")'.dependencies]
system-configuration = "0.5.1"
system-configuration = { version = "0.5.1", optional = true }

# wasm

Expand Down
10 changes: 5 additions & 5 deletions src/proxy.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ use std::collections::HashMap;
use std::env;
use std::error::Error;
use std::net::IpAddr;
#[cfg(target_os = "macos")]
#[cfg(all(target_os = "macos", feature = "macos-system-configuration"))]
use system_configuration::{
core_foundation::{
base::CFType,
Expand Down Expand Up @@ -947,7 +947,7 @@ fn get_from_platform_impl() -> Result<Option<String>, Box<dyn Error>> {
Ok((proxy_enable == 1).then_some(proxy_server))
}

#[cfg(target_os = "macos")]
#[cfg(all(target_os = "macos", feature = "macos-system-configuration"))]
fn parse_setting_from_dynamic_store(
proxies_map: &CFDictionary<CFString, CFType>,
enabled_key: CFStringRef,
Expand Down Expand Up @@ -985,7 +985,7 @@ fn parse_setting_from_dynamic_store(
None
}

#[cfg(target_os = "macos")]
#[cfg(all(target_os = "macos", feature = "macos-system-configuration"))]
fn get_from_platform_impl() -> Result<Option<String>, Box<dyn Error>> {
let store = SCDynamicStoreBuilder::new("reqwest").build();

Expand Down Expand Up @@ -1016,12 +1016,12 @@ fn get_from_platform_impl() -> Result<Option<String>, Box<dyn Error>> {
}
}

#[cfg(any(target_os = "windows", target_os = "macos"))]
#[cfg(any(target_os = "windows", all(target_os = "macos", feature = "macos-system-configuration")))]
fn get_from_platform() -> Option<String> {
get_from_platform_impl().ok().flatten()
}

#[cfg(not(any(target_os = "windows", target_os = "macos")))]
#[cfg(not(any(target_os = "windows", all(target_os = "macos", feature = "macos-system-configuration"))))]
fn get_from_platform() -> Option<String> {
None
}
Expand Down

0 comments on commit 8bb1d65

Please sign in to comment.