mirror of
https://mirror.ghproxy.com/https://github.com/StarCitizenToolBox/app.git
synced 2025-01-09 08:03:43 +08:00
update RSHttp
This commit is contained in:
parent
7e1352c0be
commit
5fa62351f2
@ -2,8 +2,8 @@ import 'dart:convert';
|
|||||||
|
|
||||||
import 'package:flutter/foundation.dart';
|
import 'package:flutter/foundation.dart';
|
||||||
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
||||||
|
import 'package:starcitizen_doctor/common/io/rs_http.dart';
|
||||||
import 'package:starcitizen_doctor/common/utils/base_utils.dart';
|
import 'package:starcitizen_doctor/common/utils/base_utils.dart';
|
||||||
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
|
||||||
|
|
||||||
class AnalyticsApi {
|
class AnalyticsApi {
|
||||||
static touch(String key) async {
|
static touch(String key) async {
|
||||||
@ -11,9 +11,8 @@ class AnalyticsApi {
|
|||||||
if (kDebugMode) return;
|
if (kDebugMode) return;
|
||||||
dPrint("AnalyticsApi.touch === $key start");
|
dPrint("AnalyticsApi.touch === $key start");
|
||||||
try {
|
try {
|
||||||
await rust_http.postJsonString(
|
await RSHttp.postData("${URLConf.xkeycApiHome}/analytics/$key",
|
||||||
url: "${URLConf.xkeycApiHome}/analytics/$key",
|
data: utf8.encode(json.encode({"test": "a"})), contentType: "application/json");
|
||||||
jsonData: json.encode({"test": "a"}));
|
|
||||||
dPrint("AnalyticsApi.touch === $key over");
|
dPrint("AnalyticsApi.touch === $key over");
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
dPrint("AnalyticsApi.touch === $key Error:$e");
|
dPrint("AnalyticsApi.touch === $key Error:$e");
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
||||||
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
import 'package:starcitizen_doctor/common/io/rs_http.dart';
|
||||||
import 'package:starcitizen_doctor/data/app_placard_data.dart';
|
import 'package:starcitizen_doctor/data/app_placard_data.dart';
|
||||||
import 'package:starcitizen_doctor/data/app_version_data.dart';
|
import 'package:starcitizen_doctor/data/app_version_data.dart';
|
||||||
import 'package:starcitizen_doctor/data/countdown_festival_item_data.dart';
|
import 'package:starcitizen_doctor/data/countdown_festival_item_data.dart';
|
||||||
@ -33,8 +33,7 @@ class Api {
|
|||||||
|
|
||||||
static Future<Map<String, dynamic>> getAppReleaseDataByVersionName(
|
static Future<Map<String, dynamic>> getAppReleaseDataByVersionName(
|
||||||
String version) async {
|
String version) async {
|
||||||
final r = await rust_http.getString(
|
final r = await RSHttp.getText(
|
||||||
url:
|
|
||||||
"${URLConf.gitlabApiPath}/repos/SCToolBox/Release/releases/tags/$version");
|
"${URLConf.gitlabApiPath}/repos/SCToolBox/Release/releases/tags/$version");
|
||||||
return json.decode(r);
|
return json.decode(r);
|
||||||
}
|
}
|
||||||
@ -52,8 +51,8 @@ class Api {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Future<List> getScServerStatus() async {
|
static Future<List> getScServerStatus() async {
|
||||||
final r = await rust_http.getString(
|
final r = await RSHttp.getText(
|
||||||
url: "https://status.robertsspaceindustries.com/index.json");
|
"https://status.robertsspaceindustries.com/index.json");
|
||||||
final map = json.decode(r);
|
final map = json.decode(r);
|
||||||
return map["systems"];
|
return map["systems"];
|
||||||
}
|
}
|
||||||
@ -65,8 +64,7 @@ class Api {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Future<String> getRepoData(String dir, String name) async {
|
static Future<String> getRepoData(String dir, String name) async {
|
||||||
final r =
|
final r = await RSHttp.getText("${URLConf.apiRepoPath}/$dir/$name");
|
||||||
await rust_http.getString(url: "${URLConf.apiRepoPath}/$dir/$name");
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
|
|
||||||
import 'package:dart_rss/dart_rss.dart';
|
import 'package:dart_rss/dart_rss.dart';
|
||||||
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
import 'package:starcitizen_doctor/common/io/rs_http.dart';
|
||||||
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
||||||
|
|
||||||
class RSSApi {
|
class RSSApi {
|
||||||
static Future<List<RssItem>> getRssVideo() async {
|
static Future<List<RssItem>> getRssVideo() async {
|
||||||
final r = await rust_http.getString(url: URLConf.rssVideoUrl);
|
final r = await RSHttp.getText(URLConf.rssVideoUrl);
|
||||||
final f = RssFeed.parse(r);
|
final f = RssFeed.parse(r);
|
||||||
return f.items.sublist(0, 8);
|
return f.items.sublist(0, 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Future<List<RssItem>> getRssText() async {
|
static Future<List<RssItem>> getRssText() async {
|
||||||
final r1 = await rust_http.getString(url: URLConf.rssTextUrl1);
|
final r1 = await RSHttp.getText(URLConf.rssTextUrl1);
|
||||||
final r1f = RssFeed.parse(r1);
|
final r1f = RssFeed.parse(r1);
|
||||||
final r2 = await rust_http.getString(url: URLConf.rssTextUrl2);
|
final r2 = await RSHttp.getText(URLConf.rssTextUrl2);
|
||||||
final r2f = RssFeed.parse(r2);
|
final r2f = RssFeed.parse(r2);
|
||||||
final items = r1f.items..addAll(r2f.items);
|
final items = r1f.items..addAll(r2f.items);
|
||||||
items.sort((a, b) {
|
items.sort((a, b) {
|
||||||
|
29
lib/common/io/rs_http.dart
Normal file
29
lib/common/io/rs_http.dart
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
import 'dart:typed_data';
|
||||||
|
|
||||||
|
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
||||||
|
import 'package:starcitizen_doctor/common/rust/api/http_api.dart';
|
||||||
|
|
||||||
|
class RSHttp {
|
||||||
|
static Future<String> getText(String url,
|
||||||
|
{Map<String, String>? headers}) async {
|
||||||
|
final r = await rust_http.fetch(
|
||||||
|
method: MyMethod.gets, url: url, headers: headers);
|
||||||
|
if (r.data == null) return "";
|
||||||
|
final str = utf8.decode(r.data!);
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Future postData(String url,
|
||||||
|
{Map<String, String>? headers,
|
||||||
|
String? contentType,
|
||||||
|
Uint8List? data}) async {
|
||||||
|
if (contentType != null) {
|
||||||
|
headers ??= {};
|
||||||
|
headers["Content-Type"] = contentType;
|
||||||
|
}
|
||||||
|
final r = await rust_http.fetch(
|
||||||
|
method: MyMethod.post, url: url, headers: headers, inputData: data);
|
||||||
|
return r.statusCode == 200;
|
||||||
|
}
|
||||||
|
}
|
@ -4,16 +4,53 @@
|
|||||||
// ignore_for_file: invalid_use_of_internal_member, unused_import, unnecessary_import
|
// ignore_for_file: invalid_use_of_internal_member, unused_import, unnecessary_import
|
||||||
|
|
||||||
import '../frb_generated.dart';
|
import '../frb_generated.dart';
|
||||||
|
import '../http_package.dart';
|
||||||
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated.dart';
|
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated.dart';
|
||||||
|
|
||||||
Future<String> getString(
|
Future<void> setDefaultHeader(
|
||||||
{required String url, Map<String, String>? headers, dynamic hint}) =>
|
{required Map<String, String> headers, dynamic hint}) =>
|
||||||
RustLib.instance.api.getString(url: url, headers: headers, hint: hint);
|
RustLib.instance.api.setDefaultHeader(headers: headers, hint: hint);
|
||||||
|
|
||||||
Future<String> postJsonString(
|
Future<RustHttpResponse> fetch(
|
||||||
{required String url,
|
{required MyMethod method,
|
||||||
|
required String url,
|
||||||
Map<String, String>? headers,
|
Map<String, String>? headers,
|
||||||
String? jsonData,
|
Uint8List? inputData,
|
||||||
dynamic hint}) =>
|
dynamic hint}) =>
|
||||||
RustLib.instance.api.postJsonString(
|
RustLib.instance.api.fetch(
|
||||||
url: url, headers: headers, jsonData: jsonData, hint: hint);
|
method: method,
|
||||||
|
url: url,
|
||||||
|
headers: headers,
|
||||||
|
inputData: inputData,
|
||||||
|
hint: hint);
|
||||||
|
|
||||||
|
// Rust type: RustOpaqueMoi<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>
|
||||||
|
@sealed
|
||||||
|
class ReqwestVersion extends RustOpaque {
|
||||||
|
ReqwestVersion.dcoDecode(List<dynamic> wire)
|
||||||
|
: super.dcoDecode(wire, _kStaticData);
|
||||||
|
|
||||||
|
ReqwestVersion.sseDecode(int ptr, int externalSizeOnNative)
|
||||||
|
: super.sseDecode(ptr, externalSizeOnNative, _kStaticData);
|
||||||
|
|
||||||
|
static final _kStaticData = RustArcStaticData(
|
||||||
|
rustArcIncrementStrongCount:
|
||||||
|
RustLib.instance.api.rust_arc_increment_strong_count_ReqwestVersion,
|
||||||
|
rustArcDecrementStrongCount:
|
||||||
|
RustLib.instance.api.rust_arc_decrement_strong_count_ReqwestVersion,
|
||||||
|
rustArcDecrementStrongCountPtr:
|
||||||
|
RustLib.instance.api.rust_arc_decrement_strong_count_ReqwestVersionPtr,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
enum MyMethod {
|
||||||
|
options,
|
||||||
|
gets,
|
||||||
|
post,
|
||||||
|
put,
|
||||||
|
delete,
|
||||||
|
head,
|
||||||
|
trace,
|
||||||
|
connect,
|
||||||
|
patch,
|
||||||
|
}
|
||||||
|
@ -9,6 +9,7 @@ import 'dart:async';
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'downloader.dart';
|
import 'downloader.dart';
|
||||||
import 'frb_generated.io.dart' if (dart.library.html) 'frb_generated.web.dart';
|
import 'frb_generated.io.dart' if (dart.library.html) 'frb_generated.web.dart';
|
||||||
|
import 'http_package.dart';
|
||||||
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated.dart';
|
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated.dart';
|
||||||
|
|
||||||
/// Main entrypoint of the Rust API
|
/// Main entrypoint of the Rust API
|
||||||
@ -73,14 +74,24 @@ abstract class RustLibApi extends BaseApi {
|
|||||||
required int connectionCount,
|
required int connectionCount,
|
||||||
dynamic hint});
|
dynamic hint});
|
||||||
|
|
||||||
Future<String> getString(
|
Future<RustHttpResponse> fetch(
|
||||||
{required String url, Map<String, String>? headers, dynamic hint});
|
{required MyMethod method,
|
||||||
|
required String url,
|
||||||
Future<String> postJsonString(
|
|
||||||
{required String url,
|
|
||||||
Map<String, String>? headers,
|
Map<String, String>? headers,
|
||||||
String? jsonData,
|
Uint8List? inputData,
|
||||||
dynamic hint});
|
dynamic hint});
|
||||||
|
|
||||||
|
Future<void> setDefaultHeader(
|
||||||
|
{required Map<String, String> headers, dynamic hint});
|
||||||
|
|
||||||
|
RustArcIncrementStrongCountFnType
|
||||||
|
get rust_arc_increment_strong_count_ReqwestVersion;
|
||||||
|
|
||||||
|
RustArcDecrementStrongCountFnType
|
||||||
|
get rust_arc_decrement_strong_count_ReqwestVersion;
|
||||||
|
|
||||||
|
CrossPlatformFinalizerArg
|
||||||
|
get rust_arc_decrement_strong_count_ReqwestVersionPtr;
|
||||||
}
|
}
|
||||||
|
|
||||||
class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
||||||
@ -150,63 +161,80 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
);
|
);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<String> getString(
|
Future<RustHttpResponse> fetch(
|
||||||
{required String url, Map<String, String>? headers, dynamic hint}) {
|
{required MyMethod method,
|
||||||
return handler.executeNormal(NormalTask(
|
required String url,
|
||||||
callFfi: (port_) {
|
|
||||||
final serializer = SseSerializer(generalizedFrbRustBinding);
|
|
||||||
sse_encode_String(url, serializer);
|
|
||||||
sse_encode_opt_Map_String_String(headers, serializer);
|
|
||||||
pdeCallFfi(generalizedFrbRustBinding, serializer,
|
|
||||||
funcId: 3, port: port_);
|
|
||||||
},
|
|
||||||
codec: SseCodec(
|
|
||||||
decodeSuccessData: sse_decode_String,
|
|
||||||
decodeErrorData: null,
|
|
||||||
),
|
|
||||||
constMeta: kGetStringConstMeta,
|
|
||||||
argValues: [url, headers],
|
|
||||||
apiImpl: this,
|
|
||||||
hint: hint,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
TaskConstMeta get kGetStringConstMeta => const TaskConstMeta(
|
|
||||||
debugName: "get_string",
|
|
||||||
argNames: ["url", "headers"],
|
|
||||||
);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Future<String> postJsonString(
|
|
||||||
{required String url,
|
|
||||||
Map<String, String>? headers,
|
Map<String, String>? headers,
|
||||||
String? jsonData,
|
Uint8List? inputData,
|
||||||
dynamic hint}) {
|
dynamic hint}) {
|
||||||
return handler.executeNormal(NormalTask(
|
return handler.executeNormal(NormalTask(
|
||||||
callFfi: (port_) {
|
callFfi: (port_) {
|
||||||
final serializer = SseSerializer(generalizedFrbRustBinding);
|
final serializer = SseSerializer(generalizedFrbRustBinding);
|
||||||
|
sse_encode_my_method(method, serializer);
|
||||||
sse_encode_String(url, serializer);
|
sse_encode_String(url, serializer);
|
||||||
sse_encode_opt_Map_String_String(headers, serializer);
|
sse_encode_opt_Map_String_String(headers, serializer);
|
||||||
sse_encode_opt_String(jsonData, serializer);
|
sse_encode_opt_list_prim_u_8_strict(inputData, serializer);
|
||||||
pdeCallFfi(generalizedFrbRustBinding, serializer,
|
pdeCallFfi(generalizedFrbRustBinding, serializer,
|
||||||
funcId: 4, port: port_);
|
funcId: 4, port: port_);
|
||||||
},
|
},
|
||||||
codec: SseCodec(
|
codec: SseCodec(
|
||||||
decodeSuccessData: sse_decode_String,
|
decodeSuccessData: sse_decode_rust_http_response,
|
||||||
decodeErrorData: null,
|
decodeErrorData: null,
|
||||||
),
|
),
|
||||||
constMeta: kPostJsonStringConstMeta,
|
constMeta: kFetchConstMeta,
|
||||||
argValues: [url, headers, jsonData],
|
argValues: [method, url, headers, inputData],
|
||||||
apiImpl: this,
|
apiImpl: this,
|
||||||
hint: hint,
|
hint: hint,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
TaskConstMeta get kPostJsonStringConstMeta => const TaskConstMeta(
|
TaskConstMeta get kFetchConstMeta => const TaskConstMeta(
|
||||||
debugName: "post_json_string",
|
debugName: "fetch",
|
||||||
argNames: ["url", "headers", "jsonData"],
|
argNames: ["method", "url", "headers", "inputData"],
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<void> setDefaultHeader(
|
||||||
|
{required Map<String, String> headers, dynamic hint}) {
|
||||||
|
return handler.executeNormal(NormalTask(
|
||||||
|
callFfi: (port_) {
|
||||||
|
final serializer = SseSerializer(generalizedFrbRustBinding);
|
||||||
|
sse_encode_Map_String_String(headers, serializer);
|
||||||
|
pdeCallFfi(generalizedFrbRustBinding, serializer,
|
||||||
|
funcId: 3, port: port_);
|
||||||
|
},
|
||||||
|
codec: SseCodec(
|
||||||
|
decodeSuccessData: sse_decode_unit,
|
||||||
|
decodeErrorData: null,
|
||||||
|
),
|
||||||
|
constMeta: kSetDefaultHeaderConstMeta,
|
||||||
|
argValues: [headers],
|
||||||
|
apiImpl: this,
|
||||||
|
hint: hint,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
TaskConstMeta get kSetDefaultHeaderConstMeta => const TaskConstMeta(
|
||||||
|
debugName: "set_default_header",
|
||||||
|
argNames: ["headers"],
|
||||||
|
);
|
||||||
|
|
||||||
|
RustArcIncrementStrongCountFnType
|
||||||
|
get rust_arc_increment_strong_count_ReqwestVersion => wire
|
||||||
|
.rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion;
|
||||||
|
|
||||||
|
RustArcDecrementStrongCountFnType
|
||||||
|
get rust_arc_decrement_strong_count_ReqwestVersion => wire
|
||||||
|
.rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion;
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return ReqwestVersion.dcoDecode(raw as List<dynamic>);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> dco_decode_Map_String_String(dynamic raw) {
|
Map<String, String> dco_decode_Map_String_String(dynamic raw) {
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
@ -214,12 +242,26 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
.map((e) => MapEntry(e.$1, e.$2)));
|
.map((e) => MapEntry(e.$1, e.$2)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return ReqwestVersion.dcoDecode(raw as List<dynamic>);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String dco_decode_String(dynamic raw) {
|
String dco_decode_String(dynamic raw) {
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
return raw as String;
|
return raw as String;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_box_autoadd_u_64(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return dco_decode_u_64(raw);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData dco_decode_download_callback_data(dynamic raw) {
|
DownloadCallbackData dco_decode_download_callback_data(dynamic raw) {
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
@ -258,9 +300,9 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
switch (raw[0]) {
|
switch (raw[0]) {
|
||||||
case 0:
|
case 0:
|
||||||
return MyDownloaderStatus_NoStart();
|
return const MyDownloaderStatus_NoStart();
|
||||||
case 1:
|
case 1:
|
||||||
return MyDownloaderStatus_Running();
|
return const MyDownloaderStatus_Running();
|
||||||
case 2:
|
case 2:
|
||||||
return MyDownloaderStatus_Pending(
|
return MyDownloaderStatus_Pending(
|
||||||
dco_decode_my_network_item_pending_type(raw[1]),
|
dco_decode_my_network_item_pending_type(raw[1]),
|
||||||
@ -270,12 +312,18 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
dco_decode_String(raw[1]),
|
dco_decode_String(raw[1]),
|
||||||
);
|
);
|
||||||
case 4:
|
case 4:
|
||||||
return MyDownloaderStatus_Finished();
|
return const MyDownloaderStatus_Finished();
|
||||||
default:
|
default:
|
||||||
throw Exception("unreachable");
|
throw Exception("unreachable");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod dco_decode_my_method(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return MyMethod.values[raw as int];
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(
|
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(
|
||||||
dynamic raw) {
|
dynamic raw) {
|
||||||
@ -290,9 +338,15 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? dco_decode_opt_String(dynamic raw) {
|
int? dco_decode_opt_box_autoadd_u_64(dynamic raw) {
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
return raw == null ? null : dco_decode_String(raw);
|
return raw == null ? null : dco_decode_box_autoadd_u_64(raw);
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? dco_decode_opt_list_prim_u_8_strict(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return raw == null ? null : dco_decode_list_prim_u_8_strict(raw);
|
||||||
}
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
@ -308,6 +362,31 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse dco_decode_rust_http_response(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
final arr = raw as List<dynamic>;
|
||||||
|
if (arr.length != 7)
|
||||||
|
throw Exception('unexpected arr length: expect 7 but see ${arr.length}');
|
||||||
|
return RustHttpResponse(
|
||||||
|
statusCode: dco_decode_u_16(arr[0]),
|
||||||
|
headers: dco_decode_Map_String_String(arr[1]),
|
||||||
|
url: dco_decode_String(arr[2]),
|
||||||
|
contentLength: dco_decode_opt_box_autoadd_u_64(arr[3]),
|
||||||
|
version:
|
||||||
|
dco_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
arr[4]),
|
||||||
|
remoteAddr: dco_decode_String(arr[5]),
|
||||||
|
data: dco_decode_opt_list_prim_u_8_strict(arr[6]),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_u_16(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return raw as int;
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int dco_decode_u_64(dynamic raw) {
|
int dco_decode_u_64(dynamic raw) {
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
@ -326,6 +405,21 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_usize(dynamic raw) {
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
return dcoDecodeI64OrU64(raw);
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
return ReqwestVersion.sseDecode(
|
||||||
|
sse_decode_usize(deserializer), sse_decode_i_32(deserializer));
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> sse_decode_Map_String_String(
|
Map<String, String> sse_decode_Map_String_String(
|
||||||
SseDeserializer deserializer) {
|
SseDeserializer deserializer) {
|
||||||
@ -334,6 +428,15 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
return Map.fromEntries(inner.map((e) => MapEntry(e.$1, e.$2)));
|
return Map.fromEntries(inner.map((e) => MapEntry(e.$1, e.$2)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
return ReqwestVersion.sseDecode(
|
||||||
|
sse_decode_usize(deserializer), sse_decode_i_32(deserializer));
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String sse_decode_String(SseDeserializer deserializer) {
|
String sse_decode_String(SseDeserializer deserializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
@ -341,6 +444,12 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
return utf8.decoder.convert(inner);
|
return utf8.decoder.convert(inner);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_box_autoadd_u_64(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
return (sse_decode_u_64(deserializer));
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData sse_decode_download_callback_data(
|
DownloadCallbackData sse_decode_download_callback_data(
|
||||||
SseDeserializer deserializer) {
|
SseDeserializer deserializer) {
|
||||||
@ -392,9 +501,9 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
var tag_ = sse_decode_i_32(deserializer);
|
var tag_ = sse_decode_i_32(deserializer);
|
||||||
switch (tag_) {
|
switch (tag_) {
|
||||||
case 0:
|
case 0:
|
||||||
return MyDownloaderStatus_NoStart();
|
return const MyDownloaderStatus_NoStart();
|
||||||
case 1:
|
case 1:
|
||||||
return MyDownloaderStatus_Running();
|
return const MyDownloaderStatus_Running();
|
||||||
case 2:
|
case 2:
|
||||||
var var_field0 = sse_decode_my_network_item_pending_type(deserializer);
|
var var_field0 = sse_decode_my_network_item_pending_type(deserializer);
|
||||||
return MyDownloaderStatus_Pending(var_field0);
|
return MyDownloaderStatus_Pending(var_field0);
|
||||||
@ -402,12 +511,19 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
var var_field0 = sse_decode_String(deserializer);
|
var var_field0 = sse_decode_String(deserializer);
|
||||||
return MyDownloaderStatus_Error(var_field0);
|
return MyDownloaderStatus_Error(var_field0);
|
||||||
case 4:
|
case 4:
|
||||||
return MyDownloaderStatus_Finished();
|
return const MyDownloaderStatus_Finished();
|
||||||
default:
|
default:
|
||||||
throw UnimplementedError('');
|
throw UnimplementedError('');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod sse_decode_my_method(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
var inner = sse_decode_i_32(deserializer);
|
||||||
|
return MyMethod.values[inner];
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
||||||
SseDeserializer deserializer) {
|
SseDeserializer deserializer) {
|
||||||
@ -429,11 +545,22 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? sse_decode_opt_String(SseDeserializer deserializer) {
|
int? sse_decode_opt_box_autoadd_u_64(SseDeserializer deserializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
|
||||||
if (sse_decode_bool(deserializer)) {
|
if (sse_decode_bool(deserializer)) {
|
||||||
return (sse_decode_String(deserializer));
|
return (sse_decode_box_autoadd_u_64(deserializer));
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? sse_decode_opt_list_prim_u_8_strict(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
|
||||||
|
if (sse_decode_bool(deserializer)) {
|
||||||
|
return (sse_decode_list_prim_u_8_strict(deserializer));
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -448,6 +575,34 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
return (var_field0, var_field1);
|
return (var_field0, var_field1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse sse_decode_rust_http_response(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
var var_statusCode = sse_decode_u_16(deserializer);
|
||||||
|
var var_headers = sse_decode_Map_String_String(deserializer);
|
||||||
|
var var_url = sse_decode_String(deserializer);
|
||||||
|
var var_contentLength = sse_decode_opt_box_autoadd_u_64(deserializer);
|
||||||
|
var var_version =
|
||||||
|
sse_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
deserializer);
|
||||||
|
var var_remoteAddr = sse_decode_String(deserializer);
|
||||||
|
var var_data = sse_decode_opt_list_prim_u_8_strict(deserializer);
|
||||||
|
return RustHttpResponse(
|
||||||
|
statusCode: var_statusCode,
|
||||||
|
headers: var_headers,
|
||||||
|
url: var_url,
|
||||||
|
contentLength: var_contentLength,
|
||||||
|
version: var_version,
|
||||||
|
remoteAddr: var_remoteAddr,
|
||||||
|
data: var_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_u_16(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
return deserializer.buffer.getUint16();
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int sse_decode_u_64(SseDeserializer deserializer) {
|
int sse_decode_u_64(SseDeserializer deserializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
@ -465,12 +620,26 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_usize(SseDeserializer deserializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
return deserializer.buffer.getUint64();
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
bool sse_decode_bool(SseDeserializer deserializer) {
|
bool sse_decode_bool(SseDeserializer deserializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
return deserializer.buffer.getUint8() != 0;
|
return deserializer.buffer.getUint8() != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
sse_encode_usize(self.sseEncode(move: true), serializer);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_Map_String_String(
|
void sse_encode_Map_String_String(
|
||||||
Map<String, String> self, SseSerializer serializer) {
|
Map<String, String> self, SseSerializer serializer) {
|
||||||
@ -479,12 +648,26 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
self.entries.map((e) => (e.key, e.value)).toList(), serializer);
|
self.entries.map((e) => (e.key, e.value)).toList(), serializer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
sse_encode_usize(self.sseEncode(move: null), serializer);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_String(String self, SseSerializer serializer) {
|
void sse_encode_String(String self, SseSerializer serializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
sse_encode_list_prim_u_8_strict(utf8.encoder.convert(self), serializer);
|
sse_encode_list_prim_u_8_strict(utf8.encoder.convert(self), serializer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_box_autoadd_u_64(int self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
sse_encode_u_64(self, serializer);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_download_callback_data(
|
void sse_encode_download_callback_data(
|
||||||
DownloadCallbackData self, SseSerializer serializer) {
|
DownloadCallbackData self, SseSerializer serializer) {
|
||||||
@ -540,6 +723,12 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_my_method(MyMethod self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
sse_encode_i_32(self.index, serializer);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_my_network_item_pending_type(
|
void sse_encode_my_network_item_pending_type(
|
||||||
MyNetworkItemPendingType self, SseSerializer serializer) {
|
MyNetworkItemPendingType self, SseSerializer serializer) {
|
||||||
@ -559,12 +748,23 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_opt_String(String? self, SseSerializer serializer) {
|
void sse_encode_opt_box_autoadd_u_64(int? self, SseSerializer serializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
|
||||||
sse_encode_bool(self != null, serializer);
|
sse_encode_bool(self != null, serializer);
|
||||||
if (self != null) {
|
if (self != null) {
|
||||||
sse_encode_String(self, serializer);
|
sse_encode_box_autoadd_u_64(self, serializer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_opt_list_prim_u_8_strict(
|
||||||
|
Uint8List? self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
|
||||||
|
sse_encode_bool(self != null, serializer);
|
||||||
|
if (self != null) {
|
||||||
|
sse_encode_list_prim_u_8_strict(self, serializer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -576,6 +776,26 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
sse_encode_String(self.$2, serializer);
|
sse_encode_String(self.$2, serializer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_rust_http_response(
|
||||||
|
RustHttpResponse self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
sse_encode_u_16(self.statusCode, serializer);
|
||||||
|
sse_encode_Map_String_String(self.headers, serializer);
|
||||||
|
sse_encode_String(self.url, serializer);
|
||||||
|
sse_encode_opt_box_autoadd_u_64(self.contentLength, serializer);
|
||||||
|
sse_encode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
self.version, serializer);
|
||||||
|
sse_encode_String(self.remoteAddr, serializer);
|
||||||
|
sse_encode_opt_list_prim_u_8_strict(self.data, serializer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_u_16(int self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
serializer.buffer.putUint16(self);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_u_64(int self, SseSerializer serializer) {
|
void sse_encode_u_64(int self, SseSerializer serializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
@ -593,6 +813,12 @@ class RustLibApiImpl extends RustLibApiImplPlatform implements RustLibApi {
|
|||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_usize(int self, SseSerializer serializer) {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
serializer.buffer.putUint64(self);
|
||||||
|
}
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_bool(bool self, SseSerializer serializer) {
|
void sse_encode_bool(bool self, SseSerializer serializer) {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
@ -10,6 +10,7 @@ import 'dart:convert';
|
|||||||
import 'dart:ffi' as ffi;
|
import 'dart:ffi' as ffi;
|
||||||
import 'downloader.dart';
|
import 'downloader.dart';
|
||||||
import 'frb_generated.dart';
|
import 'frb_generated.dart';
|
||||||
|
import 'http_package.dart';
|
||||||
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated_io.dart';
|
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated_io.dart';
|
||||||
|
|
||||||
abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
||||||
@ -20,12 +21,29 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
required super.portManager,
|
required super.portManager,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
CrossPlatformFinalizerArg
|
||||||
|
get rust_arc_decrement_strong_count_ReqwestVersionPtr => wire
|
||||||
|
._rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersionPtr;
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> dco_decode_Map_String_String(dynamic raw);
|
Map<String, String> dco_decode_Map_String_String(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String dco_decode_String(dynamic raw);
|
String dco_decode_String(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_box_autoadd_u_64(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData dco_decode_download_callback_data(dynamic raw);
|
DownloadCallbackData dco_decode_download_callback_data(dynamic raw);
|
||||||
|
|
||||||
@ -41,6 +59,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
MyDownloaderStatus dco_decode_my_downloader_status(dynamic raw);
|
MyDownloaderStatus dco_decode_my_downloader_status(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod dco_decode_my_method(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(dynamic raw);
|
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(dynamic raw);
|
||||||
|
|
||||||
@ -48,11 +69,20 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
Map<String, String>? dco_decode_opt_Map_String_String(dynamic raw);
|
Map<String, String>? dco_decode_opt_Map_String_String(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? dco_decode_opt_String(dynamic raw);
|
int? dco_decode_opt_box_autoadd_u_64(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? dco_decode_opt_list_prim_u_8_strict(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
(String, String) dco_decode_record_string_string(dynamic raw);
|
(String, String) dco_decode_record_string_string(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse dco_decode_rust_http_response(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_u_16(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int dco_decode_u_64(dynamic raw);
|
int dco_decode_u_64(dynamic raw);
|
||||||
|
|
||||||
@ -62,13 +92,29 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void dco_decode_unit(dynamic raw);
|
void dco_decode_unit(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_usize(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> sse_decode_Map_String_String(
|
Map<String, String> sse_decode_Map_String_String(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String sse_decode_String(SseDeserializer deserializer);
|
String sse_decode_String(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_box_autoadd_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData sse_decode_download_callback_data(
|
DownloadCallbackData sse_decode_download_callback_data(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
@ -87,6 +133,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
MyDownloaderStatus sse_decode_my_downloader_status(
|
MyDownloaderStatus sse_decode_my_downloader_status(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod sse_decode_my_method(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
@ -96,12 +145,21 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? sse_decode_opt_String(SseDeserializer deserializer);
|
int? sse_decode_opt_box_autoadd_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? sse_decode_opt_list_prim_u_8_strict(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
(String, String) sse_decode_record_string_string(
|
(String, String) sse_decode_record_string_string(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse sse_decode_rust_http_response(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_u_16(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int sse_decode_u_64(SseDeserializer deserializer);
|
int sse_decode_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
@ -111,16 +169,32 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void sse_decode_unit(SseDeserializer deserializer);
|
void sse_decode_unit(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_usize(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
bool sse_decode_bool(SseDeserializer deserializer);
|
bool sse_decode_bool(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_Map_String_String(
|
void sse_encode_Map_String_String(
|
||||||
Map<String, String> self, SseSerializer serializer);
|
Map<String, String> self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_String(String self, SseSerializer serializer);
|
void sse_encode_String(String self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_box_autoadd_u_64(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_download_callback_data(
|
void sse_encode_download_callback_data(
|
||||||
DownloadCallbackData self, SseSerializer serializer);
|
DownloadCallbackData self, SseSerializer serializer);
|
||||||
@ -140,6 +214,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
void sse_encode_my_downloader_status(
|
void sse_encode_my_downloader_status(
|
||||||
MyDownloaderStatus self, SseSerializer serializer);
|
MyDownloaderStatus self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_my_method(MyMethod self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_my_network_item_pending_type(
|
void sse_encode_my_network_item_pending_type(
|
||||||
MyNetworkItemPendingType self, SseSerializer serializer);
|
MyNetworkItemPendingType self, SseSerializer serializer);
|
||||||
@ -149,12 +226,23 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
Map<String, String>? self, SseSerializer serializer);
|
Map<String, String>? self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_opt_String(String? self, SseSerializer serializer);
|
void sse_encode_opt_box_autoadd_u_64(int? self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_opt_list_prim_u_8_strict(
|
||||||
|
Uint8List? self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_record_string_string(
|
void sse_encode_record_string_string(
|
||||||
(String, String) self, SseSerializer serializer);
|
(String, String) self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_rust_http_response(
|
||||||
|
RustHttpResponse self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_u_16(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_u_64(int self, SseSerializer serializer);
|
void sse_encode_u_64(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@ -164,6 +252,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void sse_encode_unit(void self, SseSerializer serializer);
|
void sse_encode_unit(void self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_usize(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_bool(bool self, SseSerializer serializer);
|
void sse_encode_bool(bool self, SseSerializer serializer);
|
||||||
}
|
}
|
||||||
@ -181,4 +272,36 @@ class RustLibWire implements BaseWire {
|
|||||||
/// The symbols are looked up in [dynamicLibrary].
|
/// The symbols are looked up in [dynamicLibrary].
|
||||||
RustLibWire(ffi.DynamicLibrary dynamicLibrary)
|
RustLibWire(ffi.DynamicLibrary dynamicLibrary)
|
||||||
: _lookup = dynamicLibrary.lookup;
|
: _lookup = dynamicLibrary.lookup;
|
||||||
|
|
||||||
|
void
|
||||||
|
rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ffi.Pointer<ffi.Void> ptr,
|
||||||
|
) {
|
||||||
|
return _rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
late final _rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersionPtr =
|
||||||
|
_lookup<ffi.NativeFunction<ffi.Void Function(ffi.Pointer<ffi.Void>)>>(
|
||||||
|
'frbgen_starcitizen_doctor_rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion');
|
||||||
|
late final _rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion =
|
||||||
|
_rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersionPtr
|
||||||
|
.asFunction<void Function(ffi.Pointer<ffi.Void>)>();
|
||||||
|
|
||||||
|
void
|
||||||
|
rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ffi.Pointer<ffi.Void> ptr,
|
||||||
|
) {
|
||||||
|
return _rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
late final _rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersionPtr =
|
||||||
|
_lookup<ffi.NativeFunction<ffi.Void Function(ffi.Pointer<ffi.Void>)>>(
|
||||||
|
'frbgen_starcitizen_doctor_rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion');
|
||||||
|
late final _rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion =
|
||||||
|
_rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersionPtr
|
||||||
|
.asFunction<void Function(ffi.Pointer<ffi.Void>)>();
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ import 'dart:async';
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'downloader.dart';
|
import 'downloader.dart';
|
||||||
import 'frb_generated.dart';
|
import 'frb_generated.dart';
|
||||||
|
import 'http_package.dart';
|
||||||
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated_web.dart';
|
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated_web.dart';
|
||||||
|
|
||||||
abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
||||||
@ -19,12 +20,29 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
required super.portManager,
|
required super.portManager,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
CrossPlatformFinalizerArg
|
||||||
|
get rust_arc_decrement_strong_count_ReqwestVersionPtr => wire
|
||||||
|
.rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion;
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> dco_decode_Map_String_String(dynamic raw);
|
Map<String, String> dco_decode_Map_String_String(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
dco_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String dco_decode_String(dynamic raw);
|
String dco_decode_String(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_box_autoadd_u_64(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData dco_decode_download_callback_data(dynamic raw);
|
DownloadCallbackData dco_decode_download_callback_data(dynamic raw);
|
||||||
|
|
||||||
@ -40,6 +58,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
MyDownloaderStatus dco_decode_my_downloader_status(dynamic raw);
|
MyDownloaderStatus dco_decode_my_downloader_status(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod dco_decode_my_method(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(dynamic raw);
|
MyNetworkItemPendingType dco_decode_my_network_item_pending_type(dynamic raw);
|
||||||
|
|
||||||
@ -47,11 +68,20 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
Map<String, String>? dco_decode_opt_Map_String_String(dynamic raw);
|
Map<String, String>? dco_decode_opt_Map_String_String(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? dco_decode_opt_String(dynamic raw);
|
int? dco_decode_opt_box_autoadd_u_64(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? dco_decode_opt_list_prim_u_8_strict(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
(String, String) dco_decode_record_string_string(dynamic raw);
|
(String, String) dco_decode_record_string_string(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse dco_decode_rust_http_response(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_u_16(dynamic raw);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int dco_decode_u_64(dynamic raw);
|
int dco_decode_u_64(dynamic raw);
|
||||||
|
|
||||||
@ -61,13 +91,29 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void dco_decode_unit(dynamic raw);
|
void dco_decode_unit(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int dco_decode_usize(dynamic raw);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
Map<String, String> sse_decode_Map_String_String(
|
Map<String, String> sse_decode_Map_String_String(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
ReqwestVersion
|
||||||
|
sse_decode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String sse_decode_String(SseDeserializer deserializer);
|
String sse_decode_String(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_box_autoadd_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
DownloadCallbackData sse_decode_download_callback_data(
|
DownloadCallbackData sse_decode_download_callback_data(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
@ -86,6 +132,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
MyDownloaderStatus sse_decode_my_downloader_status(
|
MyDownloaderStatus sse_decode_my_downloader_status(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
MyMethod sse_decode_my_method(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
MyNetworkItemPendingType sse_decode_my_network_item_pending_type(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
@ -95,12 +144,21 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
String? sse_decode_opt_String(SseDeserializer deserializer);
|
int? sse_decode_opt_box_autoadd_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
Uint8List? sse_decode_opt_list_prim_u_8_strict(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
(String, String) sse_decode_record_string_string(
|
(String, String) sse_decode_record_string_string(
|
||||||
SseDeserializer deserializer);
|
SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
RustHttpResponse sse_decode_rust_http_response(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_u_16(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
int sse_decode_u_64(SseDeserializer deserializer);
|
int sse_decode_u_64(SseDeserializer deserializer);
|
||||||
|
|
||||||
@ -110,16 +168,32 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void sse_decode_unit(SseDeserializer deserializer);
|
void sse_decode_unit(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
int sse_decode_usize(SseDeserializer deserializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
bool sse_decode_bool(SseDeserializer deserializer);
|
bool sse_decode_bool(SseDeserializer deserializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_Map_String_String(
|
void sse_encode_Map_String_String(
|
||||||
Map<String, String> self, SseSerializer serializer);
|
Map<String, String> self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void
|
||||||
|
sse_encode_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ReqwestVersion self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_String(String self, SseSerializer serializer);
|
void sse_encode_String(String self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_box_autoadd_u_64(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_download_callback_data(
|
void sse_encode_download_callback_data(
|
||||||
DownloadCallbackData self, SseSerializer serializer);
|
DownloadCallbackData self, SseSerializer serializer);
|
||||||
@ -139,6 +213,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
void sse_encode_my_downloader_status(
|
void sse_encode_my_downloader_status(
|
||||||
MyDownloaderStatus self, SseSerializer serializer);
|
MyDownloaderStatus self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_my_method(MyMethod self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_my_network_item_pending_type(
|
void sse_encode_my_network_item_pending_type(
|
||||||
MyNetworkItemPendingType self, SseSerializer serializer);
|
MyNetworkItemPendingType self, SseSerializer serializer);
|
||||||
@ -148,12 +225,23 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
Map<String, String>? self, SseSerializer serializer);
|
Map<String, String>? self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_opt_String(String? self, SseSerializer serializer);
|
void sse_encode_opt_box_autoadd_u_64(int? self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_opt_list_prim_u_8_strict(
|
||||||
|
Uint8List? self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_record_string_string(
|
void sse_encode_record_string_string(
|
||||||
(String, String) self, SseSerializer serializer);
|
(String, String) self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_rust_http_response(
|
||||||
|
RustHttpResponse self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_u_16(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_u_64(int self, SseSerializer serializer);
|
void sse_encode_u_64(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@ -163,6 +251,9 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
@protected
|
@protected
|
||||||
void sse_encode_unit(void self, SseSerializer serializer);
|
void sse_encode_unit(void self, SseSerializer serializer);
|
||||||
|
|
||||||
|
@protected
|
||||||
|
void sse_encode_usize(int self, SseSerializer serializer);
|
||||||
|
|
||||||
@protected
|
@protected
|
||||||
void sse_encode_bool(bool self, SseSerializer serializer);
|
void sse_encode_bool(bool self, SseSerializer serializer);
|
||||||
}
|
}
|
||||||
@ -171,6 +262,18 @@ abstract class RustLibApiImplPlatform extends BaseApiImpl<RustLibWire> {
|
|||||||
|
|
||||||
class RustLibWire implements BaseWire {
|
class RustLibWire implements BaseWire {
|
||||||
RustLibWire.fromExternalLibrary(ExternalLibrary lib);
|
RustLibWire.fromExternalLibrary(ExternalLibrary lib);
|
||||||
|
|
||||||
|
void rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic ptr) =>
|
||||||
|
wasmModule
|
||||||
|
.rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr);
|
||||||
|
|
||||||
|
void rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic ptr) =>
|
||||||
|
wasmModule
|
||||||
|
.rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@JS('wasm_bindgen')
|
@JS('wasm_bindgen')
|
||||||
@ -184,4 +287,12 @@ class RustLibWasmModule implements WasmModule {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
external RustLibWasmModule bind(dynamic thisArg, String moduleName);
|
external RustLibWasmModule bind(dynamic thisArg, String moduleName);
|
||||||
|
|
||||||
|
external void
|
||||||
|
rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic ptr);
|
||||||
|
|
||||||
|
external void
|
||||||
|
rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
dynamic ptr);
|
||||||
}
|
}
|
||||||
|
51
lib/common/rust/http_package.dart
Normal file
51
lib/common/rust/http_package.dart
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
// This file is automatically generated, so please do not edit it.
|
||||||
|
// Generated by `flutter_rust_bridge`@ 2.0.0-dev.23.
|
||||||
|
|
||||||
|
// ignore_for_file: invalid_use_of_internal_member, unused_import, unnecessary_import
|
||||||
|
|
||||||
|
import 'api/http_api.dart';
|
||||||
|
import 'frb_generated.dart';
|
||||||
|
import 'package:flutter_rust_bridge/flutter_rust_bridge_for_generated.dart';
|
||||||
|
|
||||||
|
class RustHttpResponse {
|
||||||
|
final int statusCode;
|
||||||
|
final Map<String, String> headers;
|
||||||
|
final String url;
|
||||||
|
final int? contentLength;
|
||||||
|
final ReqwestVersion version;
|
||||||
|
final String remoteAddr;
|
||||||
|
final Uint8List? data;
|
||||||
|
|
||||||
|
const RustHttpResponse({
|
||||||
|
required this.statusCode,
|
||||||
|
required this.headers,
|
||||||
|
required this.url,
|
||||||
|
this.contentLength,
|
||||||
|
required this.version,
|
||||||
|
required this.remoteAddr,
|
||||||
|
this.data,
|
||||||
|
});
|
||||||
|
|
||||||
|
@override
|
||||||
|
int get hashCode =>
|
||||||
|
statusCode.hashCode ^
|
||||||
|
headers.hashCode ^
|
||||||
|
url.hashCode ^
|
||||||
|
contentLength.hashCode ^
|
||||||
|
version.hashCode ^
|
||||||
|
remoteAddr.hashCode ^
|
||||||
|
data.hashCode;
|
||||||
|
|
||||||
|
@override
|
||||||
|
bool operator ==(Object other) =>
|
||||||
|
identical(this, other) ||
|
||||||
|
other is RustHttpResponse &&
|
||||||
|
runtimeType == other.runtimeType &&
|
||||||
|
statusCode == other.statusCode &&
|
||||||
|
headers == other.headers &&
|
||||||
|
url == other.url &&
|
||||||
|
contentLength == other.contentLength &&
|
||||||
|
version == other.version &&
|
||||||
|
remoteAddr == other.remoteAddr &&
|
||||||
|
data == other.data;
|
||||||
|
}
|
@ -4,7 +4,7 @@ import 'dart:io';
|
|||||||
|
|
||||||
import 'package:dart_rss/dart_rss.dart';
|
import 'package:dart_rss/dart_rss.dart';
|
||||||
import 'package:desktop_webview_window/desktop_webview_window.dart';
|
import 'package:desktop_webview_window/desktop_webview_window.dart';
|
||||||
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
import 'package:starcitizen_doctor/common/io/rs_http.dart';
|
||||||
import 'package:hive/hive.dart';
|
import 'package:hive/hive.dart';
|
||||||
import 'package:starcitizen_doctor/api/analytics.dart';
|
import 'package:starcitizen_doctor/api/analytics.dart';
|
||||||
import 'package:starcitizen_doctor/api/api.dart';
|
import 'package:starcitizen_doctor/api/api.dart';
|
||||||
@ -107,8 +107,8 @@ class HomeUIModel extends BaseUIModel {
|
|||||||
updateSCServerStatus();
|
updateSCServerStatus();
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
appWebLocalizationVersionsData = AppWebLocalizationVersionsData.fromJson(
|
appWebLocalizationVersionsData = AppWebLocalizationVersionsData.fromJson(
|
||||||
json.decode((await rust_http.getString(
|
json.decode((await RSHttp.getText(
|
||||||
url: "${URLConf.webTranslateHomeUrl}/versions.json"))));
|
"${URLConf.webTranslateHomeUrl}/versions.json"))));
|
||||||
countdownFestivalListData = await Api.getFestivalCountdownList();
|
countdownFestivalListData = await Api.getFestivalCountdownList();
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
_loadRRS();
|
_loadRRS();
|
||||||
|
@ -10,9 +10,9 @@ import 'package:hive/hive.dart';
|
|||||||
import 'package:local_auth/local_auth.dart';
|
import 'package:local_auth/local_auth.dart';
|
||||||
import 'package:starcitizen_doctor/common/conf/app_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/app_conf.dart';
|
||||||
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
||||||
|
import 'package:starcitizen_doctor/common/io/rs_http.dart';
|
||||||
import 'package:starcitizen_doctor/common/win32/credentials.dart';
|
import 'package:starcitizen_doctor/common/win32/credentials.dart';
|
||||||
import 'package:starcitizen_doctor/data/app_web_localization_versions_data.dart';
|
import 'package:starcitizen_doctor/data/app_web_localization_versions_data.dart';
|
||||||
import 'package:starcitizen_doctor/common/rust/api/http_api.dart' as rust_http;
|
|
||||||
|
|
||||||
import '../../../base/ui.dart';
|
import '../../../base/ui.dart';
|
||||||
|
|
||||||
@ -256,7 +256,7 @@ class WebViewModel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
final startTime = DateTime.now();
|
final startTime = DateTime.now();
|
||||||
final r = await rust_http.getString(url: url);
|
final r = await RSHttp.getText(url);
|
||||||
final endTime = DateTime.now();
|
final endTime = DateTime.now();
|
||||||
final data = json.decode(r);
|
final data = json.decode(r);
|
||||||
if (cacheKey.isNotEmpty) {
|
if (cacheKey.isNotEmpty) {
|
||||||
|
@ -13,6 +13,7 @@ tokio = { version = "1", features = ["full"] }
|
|||||||
url = "2.5.0"
|
url = "2.5.0"
|
||||||
uuid = { version = "1.7.0", features = ["v4", "fast-rng", "macro-diagnostics"] }
|
uuid = { version = "1.7.0", features = ["v4", "fast-rng", "macro-diagnostics"] }
|
||||||
async-std = "1.12.0"
|
async-std = "1.12.0"
|
||||||
|
hyper = { version = "0.14.28"}
|
||||||
once_cell = "1.19.0"
|
once_cell = "1.19.0"
|
||||||
reqwest = { version = "0.11", features = ["rustls-tls-native-roots", "cookies", "gzip", "brotli", "deflate", "multipart", "trust-dns", "json"] }
|
reqwest = { version = "0.11", features = ["rustls-tls-native-roots", "cookies", "gzip", "brotli", "deflate", "multipart", "trust-dns", "json","stream"] }
|
||||||
serde_json = { version = "1.0.1", features = [] }
|
hickory-resolver = {version = "0.24.0", features = [ "dns-over-https-rustls","dns-over-rustls","native-certs"]}
|
||||||
|
@ -1,40 +1,42 @@
|
|||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::time::Duration;
|
use hyper::Method;
|
||||||
use once_cell::sync::Lazy;
|
use crate::http_package;
|
||||||
use reqwest;
|
use crate::http_package::RustHttpResponse;
|
||||||
use reqwest::header::{HeaderMap, HeaderValue};
|
|
||||||
use reqwest::RequestBuilder;
|
|
||||||
|
|
||||||
static HTTP_CLIENT: Lazy<reqwest::Client> = Lazy::new(|| {
|
|
||||||
let mut header_map = HeaderMap::new();
|
|
||||||
header_map.insert("User-Agent", HeaderValue::from_static("SCToolBox/2.10.x lib_rust_http"));
|
|
||||||
reqwest::Client::builder()
|
|
||||||
.use_rustls_tls()
|
|
||||||
.connect_timeout(Duration::from_secs(10))
|
|
||||||
.timeout(Duration::from_secs(10))
|
|
||||||
.default_headers(header_map).build().unwrap()
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
#[tokio::main]
|
pub enum MyMethod {
|
||||||
pub async fn get_string(url: String, headers: Option<HashMap<String, String>>) -> String {
|
Options,
|
||||||
let mut req = _append_header(HTTP_CLIENT.get(url), headers);
|
Gets,
|
||||||
req.send().await.unwrap().text().await.unwrap()
|
Post,
|
||||||
|
Put,
|
||||||
|
Delete,
|
||||||
|
Head,
|
||||||
|
Trace,
|
||||||
|
Connect,
|
||||||
|
Patch,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn post_json_string(url: String, headers: Option<HashMap<String, String>>, json_data: Option<String>) -> String {
|
fn _my_method_to_hyper_method(m: MyMethod) -> Method {
|
||||||
let mut req = _append_header(HTTP_CLIENT.post(url), headers);
|
return match m {
|
||||||
if json_data.is_some() {
|
MyMethod::Options => { Method::OPTIONS }
|
||||||
req = req.body(json_data.unwrap()).header(reqwest::header::CONTENT_TYPE, "application/json");
|
MyMethod::Gets => { Method::GET }
|
||||||
}
|
MyMethod::Post => { Method::POST }
|
||||||
req.send().await.unwrap().text().await.unwrap()
|
MyMethod::Put => { Method::PUT }
|
||||||
|
MyMethod::Delete => { Method::DELETE }
|
||||||
|
MyMethod::Head => { Method::HEAD }
|
||||||
|
MyMethod::Trace => { Method::TRACE }
|
||||||
|
MyMethod::Connect => { Method::CONNECT }
|
||||||
|
MyMethod::Patch => { Method::PATCH }
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
fn _append_header(mut req: RequestBuilder, headers: Option<HashMap<String, String>>) -> RequestBuilder {
|
pub fn set_default_header(headers: HashMap<String, String>) {
|
||||||
if headers.is_some() {
|
http_package::set_default_header(headers)
|
||||||
for x in headers.unwrap() {
|
|
||||||
req = req.header(x.0, x.1);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
req
|
pub async fn fetch(method: MyMethod,
|
||||||
|
url: String,
|
||||||
|
headers: Option<HashMap<String, String>>,
|
||||||
|
input_data: Option<Vec<u8>>) -> RustHttpResponse {
|
||||||
|
http_package::fetch(_my_method_to_hyper_method(method), url, headers, input_data).await.unwrap()
|
||||||
}
|
}
|
@ -4,6 +4,7 @@
|
|||||||
// Section: imports
|
// Section: imports
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
use crate::api::http_api::*;
|
||||||
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
||||||
use flutter_rust_bridge::for_generated::transform_result_dco;
|
use flutter_rust_bridge::for_generated::transform_result_dco;
|
||||||
use flutter_rust_bridge::{Handler, IntoIntoDart};
|
use flutter_rust_bridge::{Handler, IntoIntoDart};
|
||||||
@ -11,3 +12,17 @@ use flutter_rust_bridge::{Handler, IntoIntoDart};
|
|||||||
// Section: boilerplate
|
// Section: boilerplate
|
||||||
|
|
||||||
flutter_rust_bridge::frb_generated_boilerplate_io!();
|
flutter_rust_bridge::frb_generated_boilerplate_io!();
|
||||||
|
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern "C" fn frbgen_starcitizen_doctor_rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr: *const std::ffi::c_void,
|
||||||
|
) {
|
||||||
|
MoiArc::<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>::increment_strong_count(ptr as _);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern "C" fn frbgen_starcitizen_doctor_rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr: *const std::ffi::c_void,
|
||||||
|
) {
|
||||||
|
MoiArc::<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>::decrement_strong_count(ptr as _);
|
||||||
|
}
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
// Section: imports
|
// Section: imports
|
||||||
|
|
||||||
|
use crate::api::http_api::*;
|
||||||
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
||||||
use flutter_rust_bridge::for_generated::transform_result_dco;
|
use flutter_rust_bridge::for_generated::transform_result_dco;
|
||||||
use flutter_rust_bridge::{Handler, IntoIntoDart};
|
use flutter_rust_bridge::{Handler, IntoIntoDart};
|
||||||
@ -120,41 +121,7 @@ fn wire_start_download_impl(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
fn wire_get_string_impl(
|
fn wire_fetch_impl(
|
||||||
port_: flutter_rust_bridge::for_generated::MessagePort,
|
|
||||||
ptr_: flutter_rust_bridge::for_generated::PlatformGeneralizedUint8ListPtr,
|
|
||||||
rust_vec_len_: i32,
|
|
||||||
data_len_: i32,
|
|
||||||
) {
|
|
||||||
FLUTTER_RUST_BRIDGE_HANDLER.wrap_normal::<flutter_rust_bridge::for_generated::SseCodec, _, _>(
|
|
||||||
flutter_rust_bridge::for_generated::TaskInfo {
|
|
||||||
debug_name: "get_string",
|
|
||||||
port: Some(port_),
|
|
||||||
mode: flutter_rust_bridge::for_generated::FfiCallMode::Normal,
|
|
||||||
},
|
|
||||||
move || {
|
|
||||||
let message = unsafe {
|
|
||||||
flutter_rust_bridge::for_generated::Dart2RustMessageSse::from_wire(
|
|
||||||
ptr_,
|
|
||||||
rust_vec_len_,
|
|
||||||
data_len_,
|
|
||||||
)
|
|
||||||
};
|
|
||||||
let mut deserializer =
|
|
||||||
flutter_rust_bridge::for_generated::SseDeserializer::new(message);
|
|
||||||
let api_url = <String>::sse_decode(&mut deserializer);
|
|
||||||
let api_headers =
|
|
||||||
<Option<std::collections::HashMap<String, String>>>::sse_decode(&mut deserializer);
|
|
||||||
deserializer.end();
|
|
||||||
move |context| {
|
|
||||||
transform_result_sse((move || {
|
|
||||||
Result::<_, ()>::Ok(crate::api::http_api::get_string(api_url, api_headers))
|
|
||||||
})())
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
}
|
|
||||||
fn wire_post_json_string_impl(
|
|
||||||
port_: flutter_rust_bridge::for_generated::MessagePort,
|
port_: flutter_rust_bridge::for_generated::MessagePort,
|
||||||
ptr_: flutter_rust_bridge::for_generated::PlatformGeneralizedUint8ListPtr,
|
ptr_: flutter_rust_bridge::for_generated::PlatformGeneralizedUint8ListPtr,
|
||||||
rust_vec_len_: i32,
|
rust_vec_len_: i32,
|
||||||
@ -162,7 +129,7 @@ fn wire_post_json_string_impl(
|
|||||||
) {
|
) {
|
||||||
FLUTTER_RUST_BRIDGE_HANDLER.wrap_async::<flutter_rust_bridge::for_generated::SseCodec, _, _, _>(
|
FLUTTER_RUST_BRIDGE_HANDLER.wrap_async::<flutter_rust_bridge::for_generated::SseCodec, _, _, _>(
|
||||||
flutter_rust_bridge::for_generated::TaskInfo {
|
flutter_rust_bridge::for_generated::TaskInfo {
|
||||||
debug_name: "post_json_string",
|
debug_name: "fetch",
|
||||||
port: Some(port_),
|
port: Some(port_),
|
||||||
mode: flutter_rust_bridge::for_generated::FfiCallMode::Normal,
|
mode: flutter_rust_bridge::for_generated::FfiCallMode::Normal,
|
||||||
},
|
},
|
||||||
@ -176,19 +143,21 @@ fn wire_post_json_string_impl(
|
|||||||
};
|
};
|
||||||
let mut deserializer =
|
let mut deserializer =
|
||||||
flutter_rust_bridge::for_generated::SseDeserializer::new(message);
|
flutter_rust_bridge::for_generated::SseDeserializer::new(message);
|
||||||
|
let api_method = <crate::api::http_api::MyMethod>::sse_decode(&mut deserializer);
|
||||||
let api_url = <String>::sse_decode(&mut deserializer);
|
let api_url = <String>::sse_decode(&mut deserializer);
|
||||||
let api_headers =
|
let api_headers =
|
||||||
<Option<std::collections::HashMap<String, String>>>::sse_decode(&mut deserializer);
|
<Option<std::collections::HashMap<String, String>>>::sse_decode(&mut deserializer);
|
||||||
let api_json_data = <Option<String>>::sse_decode(&mut deserializer);
|
let api_input_data = <Option<Vec<u8>>>::sse_decode(&mut deserializer);
|
||||||
deserializer.end();
|
deserializer.end();
|
||||||
move |context| async move {
|
move |context| async move {
|
||||||
transform_result_sse(
|
transform_result_sse(
|
||||||
(move || async move {
|
(move || async move {
|
||||||
Result::<_, ()>::Ok(
|
Result::<_, ()>::Ok(
|
||||||
crate::api::http_api::post_json_string(
|
crate::api::http_api::fetch(
|
||||||
|
api_method,
|
||||||
api_url,
|
api_url,
|
||||||
api_headers,
|
api_headers,
|
||||||
api_json_data,
|
api_input_data,
|
||||||
)
|
)
|
||||||
.await,
|
.await,
|
||||||
)
|
)
|
||||||
@ -199,9 +168,58 @@ fn wire_post_json_string_impl(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
fn wire_set_default_header_impl(
|
||||||
|
port_: flutter_rust_bridge::for_generated::MessagePort,
|
||||||
|
ptr_: flutter_rust_bridge::for_generated::PlatformGeneralizedUint8ListPtr,
|
||||||
|
rust_vec_len_: i32,
|
||||||
|
data_len_: i32,
|
||||||
|
) {
|
||||||
|
FLUTTER_RUST_BRIDGE_HANDLER.wrap_normal::<flutter_rust_bridge::for_generated::SseCodec, _, _>(
|
||||||
|
flutter_rust_bridge::for_generated::TaskInfo {
|
||||||
|
debug_name: "set_default_header",
|
||||||
|
port: Some(port_),
|
||||||
|
mode: flutter_rust_bridge::for_generated::FfiCallMode::Normal,
|
||||||
|
},
|
||||||
|
move || {
|
||||||
|
let message = unsafe {
|
||||||
|
flutter_rust_bridge::for_generated::Dart2RustMessageSse::from_wire(
|
||||||
|
ptr_,
|
||||||
|
rust_vec_len_,
|
||||||
|
data_len_,
|
||||||
|
)
|
||||||
|
};
|
||||||
|
let mut deserializer =
|
||||||
|
flutter_rust_bridge::for_generated::SseDeserializer::new(message);
|
||||||
|
let api_headers =
|
||||||
|
<std::collections::HashMap<String, String>>::sse_decode(&mut deserializer);
|
||||||
|
deserializer.end();
|
||||||
|
move |context| {
|
||||||
|
transform_result_sse((move || {
|
||||||
|
Result::<_, ()>::Ok(crate::api::http_api::set_default_header(api_headers))
|
||||||
|
})())
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Section: related_funcs
|
||||||
|
|
||||||
|
flutter_rust_bridge::frb_generated_moi_arc_impl_value!(
|
||||||
|
flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest::Version>
|
||||||
|
);
|
||||||
|
|
||||||
// Section: dart2rust
|
// Section: dart2rust
|
||||||
|
|
||||||
|
impl SseDecode for reqwest::Version {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
let mut inner = <RustOpaqueMoi<
|
||||||
|
flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest::Version>,
|
||||||
|
>>::sse_decode(deserializer);
|
||||||
|
return inner.rust_auto_opaque_decode_owned();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseDecode for std::collections::HashMap<String, String> {
|
impl SseDecode for std::collections::HashMap<String, String> {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
@ -210,6 +228,16 @@ impl SseDecode for std::collections::HashMap<String, String> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseDecode
|
||||||
|
for RustOpaqueMoi<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest::Version>>
|
||||||
|
{
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
let mut inner = <usize>::sse_decode(deserializer);
|
||||||
|
return decode_rust_opaque_moi(inner);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseDecode for String {
|
impl SseDecode for String {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
@ -297,6 +325,25 @@ impl SseDecode for crate::downloader::MyDownloaderStatus {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseDecode for crate::api::http_api::MyMethod {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
let mut inner = <i32>::sse_decode(deserializer);
|
||||||
|
return match inner {
|
||||||
|
0 => crate::api::http_api::MyMethod::Options,
|
||||||
|
1 => crate::api::http_api::MyMethod::Gets,
|
||||||
|
2 => crate::api::http_api::MyMethod::Post,
|
||||||
|
3 => crate::api::http_api::MyMethod::Put,
|
||||||
|
4 => crate::api::http_api::MyMethod::Delete,
|
||||||
|
5 => crate::api::http_api::MyMethod::Head,
|
||||||
|
6 => crate::api::http_api::MyMethod::Trace,
|
||||||
|
7 => crate::api::http_api::MyMethod::Connect,
|
||||||
|
8 => crate::api::http_api::MyMethod::Patch,
|
||||||
|
_ => unreachable!("Invalid variant for MyMethod: {}", inner),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseDecode for crate::downloader::MyNetworkItemPendingType {
|
impl SseDecode for crate::downloader::MyNetworkItemPendingType {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
@ -324,11 +371,22 @@ impl SseDecode for Option<std::collections::HashMap<String, String>> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SseDecode for Option<String> {
|
impl SseDecode for Option<u64> {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
if (<bool>::sse_decode(deserializer)) {
|
if (<bool>::sse_decode(deserializer)) {
|
||||||
return Some(<String>::sse_decode(deserializer));
|
return Some(<u64>::sse_decode(deserializer));
|
||||||
|
} else {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SseDecode for Option<Vec<u8>> {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
if (<bool>::sse_decode(deserializer)) {
|
||||||
|
return Some(<Vec<u8>>::sse_decode(deserializer));
|
||||||
} else {
|
} else {
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
@ -344,6 +402,35 @@ impl SseDecode for (String, String) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseDecode for crate::http_package::RustHttpResponse {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
let mut var_statusCode = <u16>::sse_decode(deserializer);
|
||||||
|
let mut var_headers = <std::collections::HashMap<String, String>>::sse_decode(deserializer);
|
||||||
|
let mut var_url = <String>::sse_decode(deserializer);
|
||||||
|
let mut var_contentLength = <Option<u64>>::sse_decode(deserializer);
|
||||||
|
let mut var_version = <reqwest::Version>::sse_decode(deserializer);
|
||||||
|
let mut var_remoteAddr = <String>::sse_decode(deserializer);
|
||||||
|
let mut var_data = <Option<Vec<u8>>>::sse_decode(deserializer);
|
||||||
|
return crate::http_package::RustHttpResponse {
|
||||||
|
status_code: var_statusCode,
|
||||||
|
headers: var_headers,
|
||||||
|
url: var_url,
|
||||||
|
content_length: var_contentLength,
|
||||||
|
version: var_version,
|
||||||
|
remote_addr: var_remoteAddr,
|
||||||
|
data: var_data,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SseDecode for u16 {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
deserializer.cursor.read_u16::<NativeEndian>().unwrap()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseDecode for u64 {
|
impl SseDecode for u64 {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
@ -363,6 +450,13 @@ impl SseDecode for () {
|
|||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {}
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseDecode for usize {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
|
deserializer.cursor.read_u64::<NativeEndian>().unwrap() as _
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseDecode for bool {
|
impl SseDecode for bool {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
fn sse_decode(deserializer: &mut flutter_rust_bridge::for_generated::SseDeserializer) -> Self {
|
||||||
@ -381,8 +475,8 @@ fn pde_ffi_dispatcher_primary_impl(
|
|||||||
match func_id {
|
match func_id {
|
||||||
2 => wire_cancel_download_impl(port, ptr, rust_vec_len, data_len),
|
2 => wire_cancel_download_impl(port, ptr, rust_vec_len, data_len),
|
||||||
1 => wire_start_download_impl(port, ptr, rust_vec_len, data_len),
|
1 => wire_start_download_impl(port, ptr, rust_vec_len, data_len),
|
||||||
3 => wire_get_string_impl(port, ptr, rust_vec_len, data_len),
|
4 => wire_fetch_impl(port, ptr, rust_vec_len, data_len),
|
||||||
4 => wire_post_json_string_impl(port, ptr, rust_vec_len, data_len),
|
3 => wire_set_default_header_impl(port, ptr, rust_vec_len, data_len),
|
||||||
_ => unreachable!(),
|
_ => unreachable!(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -401,6 +495,36 @@ fn pde_ffi_dispatcher_sync_impl(
|
|||||||
|
|
||||||
// Section: rust2dart
|
// Section: rust2dart
|
||||||
|
|
||||||
|
pub struct Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
reqwest::Version,
|
||||||
|
);
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
impl flutter_rust_bridge::IntoDart
|
||||||
|
for Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion
|
||||||
|
{
|
||||||
|
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
||||||
|
flutter_rust_bridge::for_generated::rust_auto_opaque_encode::<_, MoiArc<_>>(self.0)
|
||||||
|
.into_dart()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl flutter_rust_bridge::for_generated::IntoDartExceptPrimitive
|
||||||
|
for Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion
|
||||||
|
{
|
||||||
|
}
|
||||||
|
impl
|
||||||
|
flutter_rust_bridge::IntoIntoDart<
|
||||||
|
Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion,
|
||||||
|
> for reqwest::Version
|
||||||
|
{
|
||||||
|
fn into_into_dart(
|
||||||
|
self,
|
||||||
|
) -> Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion
|
||||||
|
{
|
||||||
|
Local_Auto_Owned_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
self,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
impl flutter_rust_bridge::IntoDart for crate::downloader::DownloadCallbackData {
|
impl flutter_rust_bridge::IntoDart for crate::downloader::DownloadCallbackData {
|
||||||
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
||||||
@ -453,6 +577,33 @@ impl flutter_rust_bridge::IntoIntoDart<crate::downloader::MyDownloaderStatus>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Codec=Dco (DartCObject based), see doc to use other codecs
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
impl flutter_rust_bridge::IntoDart for crate::api::http_api::MyMethod {
|
||||||
|
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
||||||
|
match self {
|
||||||
|
Self::Options => 0.into_dart(),
|
||||||
|
Self::Gets => 1.into_dart(),
|
||||||
|
Self::Post => 2.into_dart(),
|
||||||
|
Self::Put => 3.into_dart(),
|
||||||
|
Self::Delete => 4.into_dart(),
|
||||||
|
Self::Head => 5.into_dart(),
|
||||||
|
Self::Trace => 6.into_dart(),
|
||||||
|
Self::Connect => 7.into_dart(),
|
||||||
|
Self::Patch => 8.into_dart(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl flutter_rust_bridge::for_generated::IntoDartExceptPrimitive
|
||||||
|
for crate::api::http_api::MyMethod
|
||||||
|
{
|
||||||
|
}
|
||||||
|
impl flutter_rust_bridge::IntoIntoDart<crate::api::http_api::MyMethod>
|
||||||
|
for crate::api::http_api::MyMethod
|
||||||
|
{
|
||||||
|
fn into_into_dart(self) -> crate::api::http_api::MyMethod {
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
impl flutter_rust_bridge::IntoDart for crate::downloader::MyNetworkItemPendingType {
|
impl flutter_rust_bridge::IntoDart for crate::downloader::MyNetworkItemPendingType {
|
||||||
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
||||||
match self {
|
match self {
|
||||||
@ -474,6 +625,39 @@ impl flutter_rust_bridge::IntoIntoDart<crate::downloader::MyNetworkItemPendingTy
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Codec=Dco (DartCObject based), see doc to use other codecs
|
||||||
|
impl flutter_rust_bridge::IntoDart for crate::http_package::RustHttpResponse {
|
||||||
|
fn into_dart(self) -> flutter_rust_bridge::for_generated::DartAbi {
|
||||||
|
[
|
||||||
|
self.status_code.into_into_dart().into_dart(),
|
||||||
|
self.headers.into_into_dart().into_dart(),
|
||||||
|
self.url.into_into_dart().into_dart(),
|
||||||
|
self.content_length.into_into_dart().into_dart(),
|
||||||
|
self.version.into_into_dart().into_dart(),
|
||||||
|
self.remote_addr.into_into_dart().into_dart(),
|
||||||
|
self.data.into_into_dart().into_dart(),
|
||||||
|
]
|
||||||
|
.into_dart()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl flutter_rust_bridge::for_generated::IntoDartExceptPrimitive
|
||||||
|
for crate::http_package::RustHttpResponse
|
||||||
|
{
|
||||||
|
}
|
||||||
|
impl flutter_rust_bridge::IntoIntoDart<crate::http_package::RustHttpResponse>
|
||||||
|
for crate::http_package::RustHttpResponse
|
||||||
|
{
|
||||||
|
fn into_into_dart(self) -> crate::http_package::RustHttpResponse {
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SseEncode for reqwest::Version {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
<RustOpaqueMoi<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>>::sse_encode(flutter_rust_bridge::for_generated::rust_auto_opaque_encode::<_, MoiArc<_>>(self), serializer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseEncode for std::collections::HashMap<String, String> {
|
impl SseEncode for std::collections::HashMap<String, String> {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
@ -482,6 +666,17 @@ impl SseEncode for std::collections::HashMap<String, String> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseEncode
|
||||||
|
for RustOpaqueMoi<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest::Version>>
|
||||||
|
{
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
let (ptr, size) = self.sse_encode_raw();
|
||||||
|
<usize>::sse_encode(ptr, serializer);
|
||||||
|
<i32>::sse_encode(size, serializer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseEncode for String {
|
impl SseEncode for String {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
@ -552,6 +747,29 @@ impl SseEncode for crate::downloader::MyDownloaderStatus {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseEncode for crate::api::http_api::MyMethod {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
<i32>::sse_encode(
|
||||||
|
match self {
|
||||||
|
crate::api::http_api::MyMethod::Options => 0,
|
||||||
|
crate::api::http_api::MyMethod::Gets => 1,
|
||||||
|
crate::api::http_api::MyMethod::Post => 2,
|
||||||
|
crate::api::http_api::MyMethod::Put => 3,
|
||||||
|
crate::api::http_api::MyMethod::Delete => 4,
|
||||||
|
crate::api::http_api::MyMethod::Head => 5,
|
||||||
|
crate::api::http_api::MyMethod::Trace => 6,
|
||||||
|
crate::api::http_api::MyMethod::Connect => 7,
|
||||||
|
crate::api::http_api::MyMethod::Patch => 8,
|
||||||
|
_ => {
|
||||||
|
unimplemented!("");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
serializer,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseEncode for crate::downloader::MyNetworkItemPendingType {
|
impl SseEncode for crate::downloader::MyNetworkItemPendingType {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
@ -580,12 +798,22 @@ impl SseEncode for Option<std::collections::HashMap<String, String>> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SseEncode for Option<String> {
|
impl SseEncode for Option<u64> {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
<bool>::sse_encode(self.is_some(), serializer);
|
<bool>::sse_encode(self.is_some(), serializer);
|
||||||
if let Some(value) = self {
|
if let Some(value) = self {
|
||||||
<String>::sse_encode(value, serializer);
|
<u64>::sse_encode(value, serializer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SseEncode for Option<Vec<u8>> {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
<bool>::sse_encode(self.is_some(), serializer);
|
||||||
|
if let Some(value) = self {
|
||||||
|
<Vec<u8>>::sse_encode(value, serializer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -598,6 +826,26 @@ impl SseEncode for (String, String) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseEncode for crate::http_package::RustHttpResponse {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
<u16>::sse_encode(self.status_code, serializer);
|
||||||
|
<std::collections::HashMap<String, String>>::sse_encode(self.headers, serializer);
|
||||||
|
<String>::sse_encode(self.url, serializer);
|
||||||
|
<Option<u64>>::sse_encode(self.content_length, serializer);
|
||||||
|
<reqwest::Version>::sse_encode(self.version, serializer);
|
||||||
|
<String>::sse_encode(self.remote_addr, serializer);
|
||||||
|
<Option<Vec<u8>>>::sse_encode(self.data, serializer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SseEncode for u16 {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
serializer.cursor.write_u16::<NativeEndian>(self).unwrap();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseEncode for u64 {
|
impl SseEncode for u64 {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
@ -617,6 +865,16 @@ impl SseEncode for () {
|
|||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {}
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl SseEncode for usize {
|
||||||
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
serializer
|
||||||
|
.cursor
|
||||||
|
.write_u64::<NativeEndian>(self as _)
|
||||||
|
.unwrap();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl SseEncode for bool {
|
impl SseEncode for bool {
|
||||||
// Codec=Sse (Serialization based), see doc to use other codecs
|
// Codec=Sse (Serialization based), see doc to use other codecs
|
||||||
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
fn sse_encode(self, serializer: &mut flutter_rust_bridge::for_generated::SseSerializer) {
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
// Section: imports
|
// Section: imports
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
use crate::api::http_api::*;
|
||||||
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
use flutter_rust_bridge::for_generated::byteorder::{NativeEndian, ReadBytesExt, WriteBytesExt};
|
||||||
use flutter_rust_bridge::for_generated::transform_result_dco;
|
use flutter_rust_bridge::for_generated::transform_result_dco;
|
||||||
use flutter_rust_bridge::for_generated::wasm_bindgen;
|
use flutter_rust_bridge::for_generated::wasm_bindgen;
|
||||||
@ -13,3 +14,17 @@ use flutter_rust_bridge::{Handler, IntoIntoDart};
|
|||||||
// Section: boilerplate
|
// Section: boilerplate
|
||||||
|
|
||||||
flutter_rust_bridge::frb_generated_boilerplate_web!();
|
flutter_rust_bridge::frb_generated_boilerplate_web!();
|
||||||
|
|
||||||
|
#[wasm_bindgen]
|
||||||
|
pub fn rust_arc_increment_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr: *const std::ffi::c_void,
|
||||||
|
) {
|
||||||
|
MoiArc::<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>::increment_strong_count(ptr as _);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[wasm_bindgen]
|
||||||
|
pub fn rust_arc_decrement_strong_count_RustOpaque_flutter_rust_bridgefor_generatedrust_asyncRwLockreqwestVersion(
|
||||||
|
ptr: *const std::ffi::c_void,
|
||||||
|
) {
|
||||||
|
MoiArc::<flutter_rust_bridge::for_generated::rust_async::RwLock<reqwest :: Version>>::decrement_strong_count(ptr as _);
|
||||||
|
}
|
||||||
|
58
rust/src/http_package/dns.rs
Normal file
58
rust/src/http_package/dns.rs
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
use hickory_resolver::config::{NameServerConfigGroup, ResolverConfig, ResolverOpts};
|
||||||
|
use hickory_resolver::{lookup_ip::LookupIpIntoIter, TokioAsyncResolver};
|
||||||
|
use hyper::client::connect::dns::Name;
|
||||||
|
use once_cell::sync::OnceCell;
|
||||||
|
use reqwest::dns::{Addrs, Resolve, Resolving};
|
||||||
|
|
||||||
|
use std::io;
|
||||||
|
use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};
|
||||||
|
use std::sync::Arc;
|
||||||
|
|
||||||
|
/// Wrapper around an `AsyncResolver`, which implements the `Resolve` trait.
|
||||||
|
#[derive(Debug, Default, Clone)]
|
||||||
|
pub(crate) struct MyHickoryDnsResolver {
|
||||||
|
/// Since we might not have been called in the context of a
|
||||||
|
/// Tokio Runtime in initialization, so we must delay the actual
|
||||||
|
/// construction of the resolver.
|
||||||
|
state: Arc<OnceCell<TokioAsyncResolver>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
struct SocketAddrs {
|
||||||
|
iter: LookupIpIntoIter,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Resolve for MyHickoryDnsResolver {
|
||||||
|
fn resolve(&self, name: Name) -> Resolving {
|
||||||
|
let resolver = self.clone();
|
||||||
|
Box::pin(async move {
|
||||||
|
let resolver = resolver.state.get_or_try_init(new_resolver)?;
|
||||||
|
let lookup = resolver.lookup_ip(name.as_str()).await?;
|
||||||
|
let addrs: Addrs = Box::new(SocketAddrs {
|
||||||
|
iter: lookup.into_iter(),
|
||||||
|
});
|
||||||
|
Ok(addrs)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Iterator for SocketAddrs {
|
||||||
|
type Item = SocketAddr;
|
||||||
|
|
||||||
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
|
self.iter.next().map(|ip_addr| SocketAddr::new(ip_addr, 0))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn new_resolver() -> io::Result<TokioAsyncResolver> {
|
||||||
|
let ali_ips: &[IpAddr] = &[
|
||||||
|
IpAddr::V4(Ipv4Addr::new(223, 5, 5, 5)),
|
||||||
|
IpAddr::V4(Ipv4Addr::new(223, 6, 6, 6)),
|
||||||
|
IpAddr::V6("2400:3200::1".parse::<Ipv6Addr>().unwrap()),
|
||||||
|
IpAddr::V6("2400:3200:baba::1".parse::<Ipv6Addr>().unwrap()),
|
||||||
|
];
|
||||||
|
|
||||||
|
let group =
|
||||||
|
NameServerConfigGroup::from_ips_https(ali_ips, 443, "dns.alidns.com".to_string(), true);
|
||||||
|
let cfg = ResolverConfig::from_parts(None, vec![], group);
|
||||||
|
Ok(TokioAsyncResolver::tokio(cfg, ResolverOpts::default()))
|
||||||
|
}
|
109
rust/src/http_package/mod.rs
Normal file
109
rust/src/http_package/mod.rs
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
pub mod dns;
|
||||||
|
|
||||||
|
use reqwest::header::{HeaderMap, HeaderName, HeaderValue};
|
||||||
|
use reqwest::{Method, RequestBuilder};
|
||||||
|
use std::collections::HashMap;
|
||||||
|
use std::str::FromStr;
|
||||||
|
use std::sync::{Arc, RwLock};
|
||||||
|
use std::time::Duration;
|
||||||
|
use flutter_rust_bridge::for_generated::lazy_static;
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct RustHttpResponse {
|
||||||
|
pub status_code: u16,
|
||||||
|
pub headers: HashMap<String, String>,
|
||||||
|
pub url: String,
|
||||||
|
pub content_length: Option<u64>,
|
||||||
|
pub version: reqwest::Version,
|
||||||
|
pub remote_addr: String,
|
||||||
|
pub data: Option<Vec<u8>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
lazy_static! {
|
||||||
|
static ref DEFAULT_HEADER: RwLock<HeaderMap> = RwLock::from(HeaderMap::new());
|
||||||
|
static ref HTTP_CLIENT: reqwest::Client = {
|
||||||
|
reqwest::Client::builder()
|
||||||
|
.use_rustls_tls()
|
||||||
|
.connect_timeout(Duration::from_secs(10))
|
||||||
|
.timeout(Duration::from_secs(10))
|
||||||
|
.dns_resolver(Arc::from(dns::MyHickoryDnsResolver::default()))
|
||||||
|
.build()
|
||||||
|
.unwrap()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_default_header(headers: HashMap<String, String>) {
|
||||||
|
let mut dh = DEFAULT_HEADER.write().unwrap();
|
||||||
|
dh.clear();
|
||||||
|
for ele in headers {
|
||||||
|
dh.append(
|
||||||
|
HeaderName::from_str(ele.0.as_str()).unwrap(),
|
||||||
|
HeaderValue::from_str(ele.1.as_str()).unwrap(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn fetch(
|
||||||
|
method: Method,
|
||||||
|
url: String,
|
||||||
|
headers: Option<HashMap<String, String>>,
|
||||||
|
input_data: Option<Vec<u8>>,
|
||||||
|
) -> reqwest::Result<RustHttpResponse> {
|
||||||
|
let mut req = _mix_header(HTTP_CLIENT.request(method, url), headers);
|
||||||
|
if input_data.is_some() {
|
||||||
|
req = req.body(input_data.unwrap());
|
||||||
|
}
|
||||||
|
let resp = req.send().await?;
|
||||||
|
|
||||||
|
let url = resp.url().to_string();
|
||||||
|
let status_code = resp.status().as_u16();
|
||||||
|
let resp_headers = _reade_resp_header(resp.headers());
|
||||||
|
let content_length = resp.content_length();
|
||||||
|
let version = resp.version();
|
||||||
|
let mut remote_addr = "".to_string();
|
||||||
|
if resp.remote_addr().is_some() {
|
||||||
|
remote_addr = resp.remote_addr().unwrap().to_string();
|
||||||
|
}
|
||||||
|
let mut data: Option<Vec<u8>> = None;
|
||||||
|
|
||||||
|
let bytes = resp.bytes().await;
|
||||||
|
if bytes.is_ok() {
|
||||||
|
data = Some(bytes.unwrap().to_vec());
|
||||||
|
}
|
||||||
|
|
||||||
|
let resp = RustHttpResponse {
|
||||||
|
status_code,
|
||||||
|
headers: resp_headers,
|
||||||
|
url,
|
||||||
|
content_length,
|
||||||
|
version,
|
||||||
|
remote_addr,
|
||||||
|
data,
|
||||||
|
};
|
||||||
|
Ok(resp)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn _reade_resp_header(r_header: &HeaderMap) -> HashMap<String, String> {
|
||||||
|
let mut resp_headers = HashMap::new();
|
||||||
|
for ele in r_header {
|
||||||
|
resp_headers.insert(
|
||||||
|
ele.0.as_str().to_string(),
|
||||||
|
ele.1.to_str().unwrap().to_string(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
resp_headers
|
||||||
|
}
|
||||||
|
|
||||||
|
fn _mix_header(
|
||||||
|
mut req: RequestBuilder,
|
||||||
|
headers: Option<HashMap<String, String>>,
|
||||||
|
) -> RequestBuilder {
|
||||||
|
if headers.is_some() {
|
||||||
|
for x in headers.unwrap() {
|
||||||
|
req = req.header(x.0, x.1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let dh = DEFAULT_HEADER.read().unwrap();
|
||||||
|
req = req.headers(dh.clone());
|
||||||
|
req
|
||||||
|
}
|
@ -1,3 +1,4 @@
|
|||||||
mod frb_generated;
|
mod frb_generated;
|
||||||
mod api;
|
mod api;
|
||||||
mod downloader;
|
mod downloader;
|
||||||
|
mod http_package;
|
||||||
|
Loading…
Reference in New Issue
Block a user