#curl #reqwest #command #convert #request-builder #further #parser

curl-parser

Convert curl command to a ParsedRequest (could be further converted to reqwest::RequestBuilder)

4 releases (2 breaking)

0.3.1 Dec 18, 2023
0.2.1 Feb 9, 2023
0.2.0 Feb 9, 2023
0.1.1 Feb 9, 2023

#3 in #further

Download history 34/week @ 2024-07-22 24/week @ 2024-07-29 95/week @ 2024-08-05 200/week @ 2024-08-12 116/week @ 2024-08-19 98/week @ 2024-08-26 38/week @ 2024-09-02 37/week @ 2024-09-09 23/week @ 2024-09-16 59/week @ 2024-09-23 29/week @ 2024-09-30 28/week @ 2024-10-07 38/week @ 2024-10-14 62/week @ 2024-10-21 61/week @ 2024-10-28 44/week @ 2024-11-04

209 downloads per month
Used in atac

MIT license

22KB
329 lines

CURL Parser

Nowadays, most of the APIs provide CURL examples to allow users to try out the APIs without any entry barriers, but it takes time to digest the examples and convert them into Rust code. This crate could convert CURL commands into Rust code.

At the moment, it supports -X, -H, -d and -u options since these are the most widely used ones.

Usage

let input = r#"curl \
    -X PATCH \
    -d '{"visibility":"private"}' \
    -H "Accept: application/vnd.github+json" \
    -H "Authorization: Bearer <YOUR-TOKEN>"\
    -H "X-GitHub-Api-Version: 2022-11-28" \
    https://api.github.com/user/email/visibility "#;
let parsed = curl_parser::ParsedRequest::try_from(input)?;
println!("{:#?}", parsed);
let req: reqwest::RequestBuilder = parsed.into();
let res = req.send().await?;
assert_eq!(res.status(), 200);

By default, reqwest is enabled so that you can convert ParsedRequest into a reqwest::RequestBuilder. If you don't want to use reqwest, you can disable the default features.

Dependencies

~7–19MB
~274K SLoC