Skip to content

Commit 610e45c

Browse files
authored
Merge pull request #342 from apoorvdwi/add-rust-curl-codegen
Add Curl Rust Code Generator
2 parents a620c64 + adfbc2b commit 610e45c

File tree

4 files changed

+1143
-0
lines changed

4 files changed

+1143
-0
lines changed

lib/codegen/codegen.dart

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ import 'php/guzzle.dart';
99
import 'python/http_client.dart';
1010
import 'python/requests.dart';
1111
import 'rust/actix.dart';
12+
import 'rust/curl_rust.dart';
1213
import 'rust/reqwest.dart';
1314
import 'rust/ureq.dart';
1415
import 'js/axios.dart';
@@ -73,6 +74,8 @@ class Codegen {
7374
return PythonRequestsCodeGen().getCode(rM, boundary: boundary);
7475
case CodegenLanguage.rustActix:
7576
return RustActixCodeGen().getCode(rM, boundary: boundary);
77+
case CodegenLanguage.rustCurl:
78+
return RustCurlCodeGen().getCode(rM);
7679
case CodegenLanguage.rustReqwest:
7780
return RustReqwestCodeGen().getCode(rM);
7881
case CodegenLanguage.rustUreq:

lib/codegen/rust/curl_rust.dart

Lines changed: 147 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,147 @@
1+
import 'package:jinja/jinja.dart' as jj;
2+
import 'package:apidash/utils/utils.dart'
3+
show getValidRequestUri, requestModelToHARJsonRequest;
4+
import 'package:apidash/models/models.dart' show RequestModel;
5+
import 'package:apidash/consts.dart';
6+
7+
class RustCurlCodeGen {
8+
final String kTemplateStart = """use curl::easy::Easy;
9+
{% if hasJsonBody %}use serde_json::json;
10+
{% endif %}{% if hasHeaders %}use curl::easy::List;
11+
{% endif %}
12+
fn main() {
13+
let mut easy = Easy::new();
14+
let mut data = Vec::new();
15+
16+
""";
17+
18+
String kTemplateUrl = """
19+
easy.url("{{url}}").unwrap();
20+
""";
21+
22+
String kTemplateMethod = """
23+
{% if method == 'get' or method == 'post' or method == 'put' %}
24+
easy.{{ method }}(true).unwrap();
25+
{% elif method == 'delete' %}
26+
easy.custom_request("DELETE").unwrap();
27+
{% elif method == 'patch' %}
28+
easy.custom_request("PATCH").unwrap();
29+
{% elif method == 'head' %}
30+
easy.nobody(true).unwrap();
31+
{% endif %}
32+
33+
""";
34+
35+
String kTemplateRawBody = """
36+
easy.post_fields_copy(r#"{{body}}"#.as_bytes()).unwrap();
37+
38+
39+
""";
40+
41+
String kTemplateJsonBody = """
42+
easy.post_fields_copy(json!({{body}}).to_string().as_bytes()).unwrap();
43+
44+
45+
""";
46+
47+
String kTemplateFormData = """
48+
let mut form = curl::easy::Form::new();
49+
{% for field in fields %}
50+
form.part("{{field.name}}")
51+
{% if field.type == "file" %}.file("{{field.value}}"){% else %}.contents(b"{{field.value}}"){% endif %}
52+
.add().unwrap();
53+
{% endfor %}
54+
easy.httppost(form).unwrap();
55+
""";
56+
57+
String kTemplateHeader = """
58+
{% if headers %}let mut list = List::new();{% for header, value in headers %}
59+
list.append("{{header}}: {{value}}").unwrap();{% endfor %}
60+
easy.http_headers(list).unwrap();
61+
{% endif %}
62+
63+
""";
64+
65+
final String kTemplateEnd = """
66+
{
67+
let mut transfer = easy.transfer();
68+
transfer.write_function(|new_data| {
69+
data.extend_from_slice(new_data);
70+
Ok(new_data.len())
71+
}).unwrap();
72+
transfer.perform().unwrap();
73+
}
74+
75+
let response_body = String::from_utf8_lossy(&data);
76+
77+
println!("Response body: {}", response_body);
78+
println!("Response code: {}", easy.response_code().unwrap());
79+
}""";
80+
81+
String? getCode(RequestModel requestModel) {
82+
try {
83+
String result = "";
84+
var requestBody = requestModel.requestBody;
85+
86+
String url = requestModel.url;
87+
88+
result += jj.Template(kTemplateStart).render({
89+
"hasJsonBody": requestModel.hasJsonData,
90+
"hasHeaders": (requestModel.enabledRequestHeaders != null &&
91+
requestModel.enabledRequestHeaders!.isNotEmpty) ||
92+
(requestModel.hasJsonData || requestModel.hasTextData)
93+
});
94+
95+
var rec = getValidRequestUri(
96+
url,
97+
requestModel.enabledRequestParams,
98+
);
99+
100+
Uri? uri = rec.$1;
101+
var harJson =
102+
requestModelToHARJsonRequest(requestModel, useEnabled: true);
103+
104+
var templateUrl = jj.Template(kTemplateUrl);
105+
result += templateUrl.render({"url": harJson["url"]});
106+
107+
var methodTemplate = jj.Template(kTemplateMethod);
108+
result += methodTemplate.render({"method": requestModel.method.name});
109+
110+
if (uri != null) {
111+
if (requestModel.hasTextData) {
112+
var templateBody = jj.Template(kTemplateRawBody);
113+
result += templateBody.render({"body": requestBody});
114+
} else if (requestModel.hasJsonData) {
115+
var templateBody = jj.Template(kTemplateJsonBody);
116+
result += templateBody.render({"body": requestBody});
117+
} else if (requestModel.hasFormData) {
118+
var templateFormData = jj.Template(kTemplateFormData);
119+
result += templateFormData.render({
120+
"fields": requestModel.formDataMapList,
121+
});
122+
}
123+
124+
var headersList = requestModel.enabledRequestHeaders;
125+
if (headersList != null || requestModel.hasBody) {
126+
var headers = requestModel.enabledHeadersMap;
127+
if (requestModel.hasJsonData || requestModel.hasTextData) {
128+
headers.putIfAbsent(kHeaderContentType,
129+
() => requestModel.requestBodyContentType.header);
130+
}
131+
if (headers.isNotEmpty) {
132+
var templateHeader = jj.Template(kTemplateHeader);
133+
result += templateHeader.render({
134+
"headers": headers,
135+
});
136+
}
137+
}
138+
139+
result += kTemplateEnd;
140+
}
141+
142+
return result;
143+
} catch (e) {
144+
return null;
145+
}
146+
}
147+
}

lib/consts.dart

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -284,6 +284,7 @@ enum CodegenLanguage {
284284
pythonHttpClient("Python (http.client)", "python", "py"),
285285
rustActix("Rust (Actix Client)", "rust", "rs"),
286286
rustReqwest("Rust (reqwest)", "rust", "rs"),
287+
rustCurl("Rust (curl-rust)", "rust", "rs"),
287288
rustUreq("Rust (ureq)", "rust", "rs"),
288289
javaOkHttp("Java (okhttp3)", "java", 'java'),
289290
javaAsyncHttpClient("Java (asynchttpclient)", "java", "java"),

0 commit comments

Comments
 (0)