mirror of
https://github.com/denoland/deno.git
synced 2025-01-05 13:59:01 -05:00
feat(ext/fetch): support fallible request-builder hooks (#18116)
This tweaks the signature of `request_builder_hook` in order to support fallible hooks. The rationale for this is mostly on two sides: * it allows a hook to inspect and possibly drop an outgoing request (e.g. for policying purposes), bubbling up a detailed error message to the user. * it wires into newer `reqwest` API which allows to split and then reassemble a `RequestBuilder`, although only in a fallible way (https://github.com/seanmonstar/reqwest/pull/1770)
This commit is contained in:
parent
fd601d9999
commit
3325b8ec80
1 changed files with 4 additions and 2 deletions
|
@ -72,7 +72,8 @@ pub struct Options {
|
|||
pub user_agent: String,
|
||||
pub root_cert_store: Option<RootCertStore>,
|
||||
pub proxy: Option<Proxy>,
|
||||
pub request_builder_hook: Option<fn(RequestBuilder) -> RequestBuilder>,
|
||||
pub request_builder_hook:
|
||||
Option<fn(RequestBuilder) -> Result<RequestBuilder, AnyError>>,
|
||||
pub unsafely_ignore_certificate_errors: Option<Vec<String>>,
|
||||
pub client_cert_chain_and_key: Option<(String, String)>,
|
||||
pub file_fetch_handler: Rc<dyn FetchHandler>,
|
||||
|
@ -342,7 +343,8 @@ where
|
|||
|
||||
let options = state.borrow::<Options>();
|
||||
if let Some(request_builder_hook) = options.request_builder_hook {
|
||||
request = request_builder_hook(request);
|
||||
request = request_builder_hook(request)
|
||||
.map_err(|err| type_error(err.to_string()))?;
|
||||
}
|
||||
|
||||
let cancel_handle = CancelHandle::new_rc();
|
||||
|
|
Loading…
Reference in a new issue