mirror of
https://github.com/foss42/apidash.git
synced 2025-05-30 13:27:09 +08:00
Revert "fixed curl code gen error for empty url"
This reverts commit 7e1ca33a28921789f0720542e63b2c520e553fcf.
This commit is contained in:
@ -1,7 +1,6 @@
|
|||||||
import 'package:apidash/models/models.dart' show RequestModel;
|
|
||||||
import 'package:jinja/jinja.dart' as jj;
|
import 'package:jinja/jinja.dart' as jj;
|
||||||
|
import 'package:apidash/utils/utils.dart' show requestModelToHARJsonRequest;
|
||||||
import '../../consts.dart';
|
import 'package:apidash/models/models.dart' show RequestModel;
|
||||||
|
|
||||||
// ignore: camel_case_types
|
// ignore: camel_case_types
|
||||||
class cURLCodeGen {
|
class cURLCodeGen {
|
||||||
@ -30,48 +29,30 @@ class cURLCodeGen {
|
|||||||
if (!url.contains("://") && url.isNotEmpty) {
|
if (!url.contains("://") && url.isNotEmpty) {
|
||||||
url = "$defaultUriScheme://$url";
|
url = "$defaultUriScheme://$url";
|
||||||
}
|
}
|
||||||
if (requestModel.enabledParamsMap.isNotEmpty) {
|
|
||||||
if (!url.contains('?')) {
|
|
||||||
url += "?";
|
|
||||||
} else {
|
|
||||||
url += "&";
|
|
||||||
}
|
|
||||||
for (MapEntry<String, String> entry
|
|
||||||
in requestModel.enabledParamsMap.entries) {
|
|
||||||
url += "${Uri.encodeFull(entry.key)}=${Uri.encodeFull(entry.value)}&";
|
|
||||||
}
|
|
||||||
url = url.substring(0, url.length - 1);
|
|
||||||
}
|
|
||||||
var rM = requestModel.copyWith(url: url);
|
var rM = requestModel.copyWith(url: url);
|
||||||
|
|
||||||
|
var harJson = requestModelToHARJsonRequest(rM, useEnabled: true);
|
||||||
|
|
||||||
var templateStart = jj.Template(kTemplateStart);
|
var templateStart = jj.Template(kTemplateStart);
|
||||||
result += templateStart.render({
|
result += templateStart.render({
|
||||||
"method": switch (rM.method.name.toUpperCase()) {
|
"method": switch (harJson["method"]) {
|
||||||
"GET" => "",
|
"GET" => "",
|
||||||
"HEAD" => " --head",
|
"HEAD" => " --head",
|
||||||
_ => " --request ${rM.method.name.toUpperCase()} \\\n"
|
_ => " --request ${harJson["method"]} \\\n"
|
||||||
},
|
},
|
||||||
"url": rM.url,
|
"url": harJson["url"],
|
||||||
});
|
});
|
||||||
|
|
||||||
Map<String, String> headers = rM.enabledHeadersMap;
|
var headers = harJson["headers"];
|
||||||
if (rM.requestBody != null &&
|
if (headers.isNotEmpty) {
|
||||||
rM.requestBody!.isNotEmpty &&
|
for (var item in headers) {
|
||||||
rM.method != HTTPVerb.get &&
|
var templateHeader = jj.Template(kTemplateHeader);
|
||||||
rM.requestBodyContentType != ContentType.formdata) {
|
result += templateHeader
|
||||||
var templateHeader = jj.Template(kTemplateHeader);
|
.render({"name": item["name"], "value": item["value"]});
|
||||||
result += templateHeader.render({
|
}
|
||||||
"name": "Content-Type",
|
|
||||||
"value": rM.requestBodyContentType.header
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
for (MapEntry<String, String> header in headers.entries) {
|
if (harJson['formData'] != null) {
|
||||||
var templateHeader = jj.Template(kTemplateHeader);
|
var formDataList = harJson['formData'] as List<Map<String, dynamic>>;
|
||||||
result +=
|
|
||||||
templateHeader.render({"name": header.key, "value": header.value});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (rM.requestBodyContentType == ContentType.formdata) {
|
|
||||||
List<Map<String, dynamic>> formDataList = rM.formDataMapList;
|
|
||||||
for (var formData in formDataList) {
|
for (var formData in formDataList) {
|
||||||
var templateFormData = jj.Template(kTemplateFormData);
|
var templateFormData = jj.Template(kTemplateFormData);
|
||||||
if (formData['type'] != null &&
|
if (formData['type'] != null &&
|
||||||
@ -86,13 +67,11 @@ class cURLCodeGen {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
if (rM.requestBody != null &&
|
|
||||||
rM.requestBody!.isNotEmpty &&
|
if (harJson["postData"]?["text"] != null) {
|
||||||
rM.method != HTTPVerb.get) {
|
var templateBody = jj.Template(kTemplateBody);
|
||||||
var templateBody = jj.Template(kTemplateBody);
|
result += templateBody.render({"body": harJson["postData"]["text"]});
|
||||||
result += templateBody.render({"body": rM.requestBody});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
40
pubspec.lock
40
pubspec.lock
@ -625,30 +625,6 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.2.0"
|
version: "0.2.0"
|
||||||
leak_tracker:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: leak_tracker
|
|
||||||
sha256: "78eb209deea09858f5269f5a5b02be4049535f568c07b275096836f01ea323fa"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "10.0.0"
|
|
||||||
leak_tracker_flutter_testing:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: leak_tracker_flutter_testing
|
|
||||||
sha256: b46c5e37c19120a8a01918cfaf293547f47269f7cb4b0058f21531c2465d6ef0
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "2.0.1"
|
|
||||||
leak_tracker_testing:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: leak_tracker_testing
|
|
||||||
sha256: a597f72a664dbd293f3bfc51f9ba69816f84dcd403cdac7066cb3f6003f3ab47
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "2.0.1"
|
|
||||||
lints:
|
lints:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@ -685,26 +661,26 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: matcher
|
name: matcher
|
||||||
sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb
|
sha256: "1803e76e6653768d64ed8ff2e1e67bea3ad4b923eb5c56a295c3e634bad5960e"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.12.16+1"
|
version: "0.12.16"
|
||||||
material_color_utilities:
|
material_color_utilities:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: material_color_utilities
|
name: material_color_utilities
|
||||||
sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a"
|
sha256: "9528f2f296073ff54cb9fee677df673ace1218163c3bc7628093e7eed5203d41"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.8.0"
|
version: "0.5.0"
|
||||||
meta:
|
meta:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: meta
|
name: meta
|
||||||
sha256: d584fa6707a52763a52446f02cc621b077888fb63b93bbcb1143a7be5a0c0c04
|
sha256: a6e590c838b18133bb482a2745ad77c5bb7715fb0451209e1a7567d416678b8e
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.11.0"
|
version: "1.10.0"
|
||||||
mime:
|
mime:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@ -781,10 +757,10 @@ packages:
|
|||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
name: path
|
name: path
|
||||||
sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af"
|
sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.9.0"
|
version: "1.8.3"
|
||||||
path_parsing:
|
path_parsing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import 'package:apidash/codegen/others/curl.dart';
|
import 'package:apidash/codegen/others/curl.dart';
|
||||||
import 'package:test/test.dart';
|
|
||||||
|
|
||||||
import '../request_models.dart';
|
import '../request_models.dart';
|
||||||
|
import 'package:test/test.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
final curlCodeGen = cURLCodeGen();
|
final curlCodeGen = cURLCodeGen();
|
||||||
@ -20,7 +19,7 @@ void main() {
|
|||||||
|
|
||||||
test('GET 3', () {
|
test('GET 3', () {
|
||||||
const expectedCode =
|
const expectedCode =
|
||||||
r"""curl --url 'https://api.foss42.com/country/data?code=US&code=IND'""";
|
r"""curl --url 'https://api.foss42.com/country/data?code=IND'""";
|
||||||
expect(curlCodeGen.getCode(requestModelGet3, "https"), expectedCode);
|
expect(curlCodeGen.getCode(requestModelGet3, "https"), expectedCode);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user