mirror of
https://github.com/foss42/apidash.git
synced 2025-05-23 01:06:46 +08:00
wip: working on fetch api for js
This commit is contained in:
@ -1,15 +1,22 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:apidash/consts.dart';
|
import 'package:apidash/consts.dart';
|
||||||
|
import 'package:apidash/utils/convert_utils.dart';
|
||||||
|
import 'package:apidash/utils/extensions/request_model_extension.dart';
|
||||||
import 'package:jinja/jinja.dart' as jj;
|
import 'package:jinja/jinja.dart' as jj;
|
||||||
import 'package:apidash/utils/utils.dart'
|
import 'package:apidash/utils/utils.dart'
|
||||||
show requestModelToHARJsonRequest, padMultilineString;
|
show getNewUuid, padMultilineString, requestModelToHARJsonRequest;
|
||||||
import 'package:apidash/models/models.dart' show RequestModel;
|
import 'package:apidash/models/models.dart' show FormDataModel, RequestModel;
|
||||||
|
|
||||||
class FetchCodeGen {
|
class FetchCodeGen {
|
||||||
FetchCodeGen({this.isNodeJs = false});
|
FetchCodeGen({this.isNodeJs = false});
|
||||||
|
|
||||||
final bool isNodeJs;
|
final bool isNodeJs;
|
||||||
|
|
||||||
String kStringImportNode = """import fetch from 'node-fetch';
|
String kStringImportNode = """
|
||||||
|
import fetch from 'node-fetch';
|
||||||
|
{% if isFormDataRequest %}const fs = require('fs');{% endif %}
|
||||||
|
|
||||||
|
|
||||||
""";
|
""";
|
||||||
|
|
||||||
@ -24,10 +31,55 @@ let options = {
|
|||||||
""";
|
""";
|
||||||
|
|
||||||
String kTemplateBody = """,
|
String kTemplateBody = """,
|
||||||
body:
|
body: {{body}}
|
||||||
{{body}}
|
|
||||||
""";
|
""";
|
||||||
|
String kMultiPartFileReader = '''
|
||||||
|
function readFile(file) {
|
||||||
|
{% if isNodeJs %} return fs.readFile(file, 'binary'); {% else %} return new Promise((resolve, reject) => {
|
||||||
|
const reader = new FileReader();
|
||||||
|
reader.onload = () => resolve(reader.result);
|
||||||
|
reader.onerror = reject;
|
||||||
|
reader.readAsArrayBuffer(file);
|
||||||
|
});
|
||||||
|
{% endif %}
|
||||||
|
}
|
||||||
|
|
||||||
|
''';
|
||||||
|
String kMultiPartBodyTemplate = r'''
|
||||||
|
async function buildDataList(fields) {
|
||||||
|
const dataList = [];
|
||||||
|
for (const field of fields) {
|
||||||
|
const name = field.name || '';
|
||||||
|
const value = field.value || '';
|
||||||
|
const type = field.type || 'text';
|
||||||
|
|
||||||
|
dataList.push(`--{{boundary}}`);
|
||||||
|
if (type === 'text') {
|
||||||
|
dataList.push(`Content-Disposition: form-data; name="${name}"`);
|
||||||
|
dataList.push('Content-Type: text/plain');
|
||||||
|
dataList.push('');
|
||||||
|
dataList.push(value);
|
||||||
|
} else if (type === 'file') {
|
||||||
|
const fileContent = await readFile(value);
|
||||||
|
dataList.push(`Content-Disposition: form-data; name="$name"; filename="${value.name}"`);
|
||||||
|
dataList.push(`Content-Type: ${value.type}`);
|
||||||
|
dataList.push('');
|
||||||
|
{% if isNodeJs %}dataList.push(fileContent);
|
||||||
|
{% else %}
|
||||||
|
dataList.push(fileContent.content);{% endif %}}
|
||||||
|
}
|
||||||
|
|
||||||
|
dataList.push(`--{{boundary}}--`);
|
||||||
|
dataList.push('');
|
||||||
|
return dataList.join('\r\n');
|
||||||
|
}
|
||||||
|
var dataList = [];
|
||||||
|
buildDataList({{fields_list}})
|
||||||
|
.then(data => dataList = data)
|
||||||
|
.catch(err => console.error(err));
|
||||||
|
const payload = dataList.join('\r\n');
|
||||||
|
|
||||||
|
''';
|
||||||
String kStringRequest = """
|
String kStringRequest = """
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -53,8 +105,28 @@ fetch(url, options)
|
|||||||
String defaultUriScheme,
|
String defaultUriScheme,
|
||||||
) {
|
) {
|
||||||
try {
|
try {
|
||||||
String result = isNodeJs ? kStringImportNode : "";
|
List<FormDataModel> formDataList = requestModel.formDataList ?? [];
|
||||||
|
String uuid = getNewUuid();
|
||||||
|
jj.Template kNodejsImportTemplate = jj.Template(kStringImportNode);
|
||||||
|
String importsData = kNodejsImportTemplate.render({
|
||||||
|
"isFormDataRequest": requestModel.isFormDataRequest,
|
||||||
|
});
|
||||||
|
|
||||||
|
String result = isNodeJs ? importsData : "";
|
||||||
|
if (requestModel.isFormDataRequest) {
|
||||||
|
jj.Template kMultiPartFileReaderTemplate =
|
||||||
|
jj.Template(kMultiPartFileReader);
|
||||||
|
result += kMultiPartFileReaderTemplate.render({
|
||||||
|
"isNodeJs": isNodeJs,
|
||||||
|
});
|
||||||
|
var boundary = uuid;
|
||||||
|
var templateMultiPartBody = jj.Template(kMultiPartBodyTemplate);
|
||||||
|
result += templateMultiPartBody.render({
|
||||||
|
"boundary": boundary,
|
||||||
|
"isNodeJs": isNodeJs,
|
||||||
|
"fields_list": json.encode(rowsToFormDataMap(formDataList)),
|
||||||
|
});
|
||||||
|
}
|
||||||
String url = requestModel.url;
|
String url = requestModel.url;
|
||||||
if (!url.contains("://") && url.isNotEmpty) {
|
if (!url.contains("://") && url.isNotEmpty) {
|
||||||
url = "$defaultUriScheme://$url";
|
url = "$defaultUriScheme://$url";
|
||||||
@ -70,21 +142,33 @@ fetch(url, options)
|
|||||||
});
|
});
|
||||||
|
|
||||||
var headers = harJson["headers"];
|
var headers = harJson["headers"];
|
||||||
|
|
||||||
if (headers.isNotEmpty) {
|
if (headers.isNotEmpty) {
|
||||||
var templateHeader = jj.Template(kTemplateHeader);
|
var templateHeader = jj.Template(kTemplateHeader);
|
||||||
var m = {};
|
var m = {};
|
||||||
|
if (requestModel.isFormDataRequest) {
|
||||||
|
m["Content-Type"] = "multipart/form-data; boundary=$uuid";
|
||||||
|
}
|
||||||
for (var i in headers) {
|
for (var i in headers) {
|
||||||
m[i["name"]] = i["value"];
|
m[i["name"]] = i["value"];
|
||||||
}
|
}
|
||||||
result += templateHeader
|
result += templateHeader.render({
|
||||||
.render({"headers": padMultilineString(kEncoder.convert(m), 2)});
|
"headers": padMultilineString(kEncoder.convert(m), 2),
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (harJson["postData"]?["text"] != null) {
|
if (harJson["postData"]?["text"] != null) {
|
||||||
var templateBody = jj.Template(kTemplateBody);
|
var templateBody = jj.Template(kTemplateBody);
|
||||||
result += templateBody
|
result += templateBody.render({
|
||||||
.render({"body": kEncoder.convert(harJson["postData"]["text"])});
|
"body": kEncoder.convert(harJson["postData"]["text"]),
|
||||||
|
});
|
||||||
|
} else if (requestModel.isFormDataRequest) {
|
||||||
|
var templateBody = jj.Template(kTemplateBody);
|
||||||
|
result += templateBody.render({
|
||||||
|
"body": 'payload',
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
result += kStringRequest;
|
result += kStringRequest;
|
||||||
return result;
|
return result;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
Reference in New Issue
Block a user