From cf58060fccb68088b1a9f82f484f1f8b635fa61e Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Tue, 26 Feb 2019 17:55:00 +0100 Subject: feat: Add `Request::with_handle` method This method acts as an "escape-hatch" which lets the user configure whatever they want on the cURL easy handle. No warranty! --- src/lib.rs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/src/lib.rs b/src/lib.rs index ea3a7f8ba2b5..978f21c6ad24 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -228,6 +228,27 @@ impl <'a> Request<'a> { Ok(self) } + /// Set custom configuration on the cURL `Easy` handle. + /// + /// This function can be considered an "escape-hatch" from the + /// high-level API which lets users access the internal + /// `curl::easy::Easy` handle and configure options on it + /// directly. + /// + /// ``` + /// # use crimp::{Request, Method}; + /// let response = Request::new(Method::Get, "https://httpbin.org/get") + /// .with_handle(|mut handle| handle.referer("Example-Referer")).unwrap() + /// .send().unwrap(); + /// # + /// # assert!(response.is_success()); + /// ``` + pub fn with_handle(mut self, function: F) -> Result + where F: FnOnce(&mut Easy) -> Result<(), curl::Error> { + function(&mut self.handle)?; + Ok(self) + } + /// Add a byte-array body to a request using the specified /// `Content-Type`. pub fn body(mut self, content_type: &'a str, data: &'a [u8]) -> Self { -- cgit 1.4.1