Update http.dart

This commit is contained in:
Ankit Mahato
2024-03-31 17:34:32 +05:30
parent bc89374d14
commit e863b35ada

View File

@ -1,6 +1,7 @@
import 'dart:io'; import 'dart:io';
import 'package:jinja/jinja.dart' as jj; import 'package:jinja/jinja.dart' as jj;
import 'package:apidash/utils/utils.dart' show getNewUuid, getValidRequestUri, stripUriParams; import 'package:apidash/utils/utils.dart'
show getValidRequestUri, stripUriParams;
import 'package:apidash/models/models.dart' show RequestModel; import 'package:apidash/models/models.dart' show RequestModel;
class JuliaHttpClientCodeGen { class JuliaHttpClientCodeGen {
@ -12,10 +13,6 @@ using HTTP{% if hasJson %}, JSON{% endif %}
final String kTemplateUrl = """ final String kTemplateUrl = """
url = "{{url}}" url = "{{url}}"
\n \n
""";
final String kTemplateBoundary = """
boundary = "{{boundary}}"
\n
"""; """;
String kTemplateParams = """ String kTemplateParams = """
@ -37,7 +34,7 @@ headers = Dict(
"""; """;
final String kTemplateFormDataBody = ''' final String kTemplateFormDataBody = '''
{{ 'data' if hasFile else 'payload' }} = Dict( data = Dict(
{%- for data in formdata %} {%- for data in formdata %}
{%- if data.type == "text" %} {%- if data.type == "text" %}
"{{ data.name }}" => "{{ data.value }}", "{{ data.name }}" => "{{ data.value }}",
@ -46,17 +43,15 @@ headers = Dict(
{%- endif %} {%- endif %}
{%- endfor %} {%- endfor %}
) )
{%- if hasFile %}
payload = HTTP.Form(data{% if boundary is defined %}, boundary=boundary{% endif %}) payload = HTTP.Form(data)
{%- endif %}
\n \n
'''; ''';
String kTemplateBody = """ String kTemplateBody = '''
payload = \"\"\"{{ body }}\"\"\" payload = """{{ body }}"""
\n \n
"""; ''';
String kTemplateRequest = """ String kTemplateRequest = """
response = HTTP.request("{{ method | upper }}", url response = HTTP.request("{{ method | upper }}", url
@ -72,15 +67,15 @@ response = HTTP.request("{{ method | upper }}", url
, status_exception=false) , status_exception=false)
println("Status Code: $(response.status) $(HTTP.StatusCodes.statustext(response.status))") println("Status Code: $(response.status) $(HTTP.StatusCodes.statustext(response.status))")
println("Response Body: \n\n$(String(response.body))") println("Response Body: \n$(String(response.body))")
"""; """;
String? getCode(RequestModel requestModel, {String? boundary}) { String? getCode(RequestModel requestModel) {
try { try {
String result = ""; String result = "";
bool hasQuery = false; bool hasQuery = false;
bool hasHeaders = false; bool hasHeaders = false;
bool hasBody = false; bool addHeaderForBody = false;
var rec = getValidRequestUri( var rec = getValidRequestUri(
requestModel.url, requestModel.url,
@ -91,18 +86,13 @@ println("Response Body: \n\n$(String(response.body))")
final templateStart = jj.Template(kTemplateStart); final templateStart = jj.Template(kTemplateStart);
result += templateStart.render({ result += templateStart.render({
// "hasJson": requestModel.hasBody && requestModel.hasJsonContentType && requestModel.hasJsonData, // "hasJson": requestModel.hasBody && requestModel.hasJsonContentType && requestModel.hasJsonData,
"hasJson": false, // we manually send false because we do not require JSON package "hasJson":
false, // we manually send false because we do not require JSON package
}); });
final templateUrl = jj.Template(kTemplateUrl); final templateUrl = jj.Template(kTemplateUrl);
result += templateUrl.render({"url": stripUriParams(uri)}); result += templateUrl.render({"url": stripUriParams(uri)});
if (requestModel.hasFormData && requestModel.hasFileInFormData) {
boundary ??= getNewUuid();
final templateParams = jj.Template(kTemplateBoundary);
result += templateParams.render({"boundary": boundary});
}
if (uri.hasQuery) { if (uri.hasQuery) {
var params = uri.queryParameters; var params = uri.queryParameters;
if (params.isNotEmpty) { if (params.isNotEmpty) {
@ -113,41 +103,34 @@ println("Response Body: \n\n$(String(response.body))")
} }
if (requestModel.hasJsonData || requestModel.hasTextData) { if (requestModel.hasJsonData || requestModel.hasTextData) {
hasBody = true; addHeaderForBody = true;
final templateBody = jj.Template(kTemplateBody); final templateBody = jj.Template(kTemplateBody);
var bodyStr = requestModel.requestBody; var bodyStr = requestModel.requestBody;
result += templateBody.render({"body": bodyStr}); result += templateBody.render({"body": bodyStr});
} }
if (requestModel.hasFormData) { if (requestModel.hasFormData) {
hasBody = true;
final formDataBodyData = jj.Template(kTemplateFormDataBody); final formDataBodyData = jj.Template(kTemplateFormDataBody);
result += formDataBodyData.render( result += formDataBodyData.render(
{ {
"hasFile": requestModel.hasFileInFormData, "hasFile": requestModel.hasFileInFormData,
"formdata": requestModel.formDataMapList, "formdata": requestModel.formDataMapList,
"boundary": boundary,
}, },
); );
} }
var headersList = requestModel.enabledRequestHeaders; var headersList = requestModel.enabledRequestHeaders;
if (headersList != null || hasBody) { if (headersList != null || addHeaderForBody) {
var headers = requestModel.enabledHeadersMap; var headers = requestModel.enabledHeadersMap;
if (!requestModel.hasContentTypeHeader) { if (!requestModel.hasContentTypeHeader) {
if (hasBody) { if (addHeaderForBody) {
headers[HttpHeaders.contentTypeHeader] = requestModel.requestBodyContentType.header; headers[HttpHeaders.contentTypeHeader] =
} requestModel.requestBodyContentType.header;
if (requestModel.hasFormData) {
headers[HttpHeaders.contentTypeHeader] = requestModel.hasFileInFormData
? "multipart/form-data; boundary=\$(boundary)"
: "application/x-www-form-urlencoded";
} }
} }
if (headers.isNotEmpty || hasBody) { if (headers.isNotEmpty) {
hasHeaders = true; hasHeaders = true;
var templateHeaders = jj.Template(kTemplateHeaders); var templateHeaders = jj.Template(kTemplateHeaders);
result += templateHeaders.render({"headers": headers}); result += templateHeaders.render({"headers": headers});
@ -159,11 +142,11 @@ println("Response Body: \n\n$(String(response.body))")
"method": requestModel.method.name, "method": requestModel.method.name,
}); });
if (hasHeaders || requestModel.hasFormData) { if (hasHeaders) {
result += kStringRequestHeaders; result += kStringRequestHeaders;
} }
if (hasBody || requestModel.hasFormData) { if (requestModel.hasBody) {
result += kStringRequestBody; result += kStringRequestBody;
} }