mirror of
https://mirror.ghproxy.com/https://github.com/StarCitizenToolBox/app.git
synced 2025-02-05 22:44:30 +08:00
BinaryModule support
This commit is contained in:
parent
eafd249847
commit
02101db99d
BIN
assets/binary/aria2c.zip
Normal file
BIN
assets/binary/aria2c.zip
Normal file
Binary file not shown.
45
lib/common/conf/binary_conf.dart
Normal file
45
lib/common/conf/binary_conf.dart
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
import 'dart:io';
|
||||||
|
|
||||||
|
import 'package:archive/archive.dart';
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
import 'package:starcitizen_doctor/common/conf/app_conf.dart';
|
||||||
|
import 'package:starcitizen_doctor/common/utils/base_utils.dart';
|
||||||
|
|
||||||
|
class BinaryModuleConf {
|
||||||
|
static const _modules = {
|
||||||
|
"aria2c": "0",
|
||||||
|
};
|
||||||
|
|
||||||
|
static Future extractModel() async {
|
||||||
|
final workingDir = "${AppConf.applicationSupportDir}\\modules";
|
||||||
|
for (var m in _modules.entries) {
|
||||||
|
final name = m.key;
|
||||||
|
final version = m.value;
|
||||||
|
final dir = "$workingDir\\$name";
|
||||||
|
final versionFile = File("$dir\\version");
|
||||||
|
if (await versionFile.exists() &&
|
||||||
|
(await versionFile.readAsString()).trim() == version) {
|
||||||
|
dPrint(
|
||||||
|
"BinaryModuleConf.extractModule skip $name version == $version");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// write model file
|
||||||
|
final zipBuffer = await rootBundle.load("assets/binary/$name.zip");
|
||||||
|
final decoder = ZipDecoder().decodeBytes(zipBuffer.buffer.asUint8List());
|
||||||
|
for (var value in decoder.files) {
|
||||||
|
final filename = value.name;
|
||||||
|
if (value.isFile) {
|
||||||
|
final data = value.content as List<int>;
|
||||||
|
final file = File('$dir\\$filename');
|
||||||
|
await file.create(recursive: true);
|
||||||
|
await file.writeAsBytes(data);
|
||||||
|
} else {
|
||||||
|
await Directory('$dir\\$filename').create(recursive: true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// write version file
|
||||||
|
await versionFile.writeAsString(version);
|
||||||
|
dPrint("BinaryModuleConf.extractModule $name $dir");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,6 @@
|
|||||||
import 'package:starcitizen_doctor/api/analytics.dart';
|
import 'package:starcitizen_doctor/api/analytics.dart';
|
||||||
import 'package:starcitizen_doctor/base/ui_model.dart';
|
import 'package:starcitizen_doctor/base/ui_model.dart';
|
||||||
|
import 'package:starcitizen_doctor/common/conf/binary_conf.dart';
|
||||||
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
|
||||||
import 'package:starcitizen_doctor/ui/index_ui.dart';
|
import 'package:starcitizen_doctor/ui/index_ui.dart';
|
||||||
import 'package:starcitizen_doctor/ui/index_ui_model.dart';
|
import 'package:starcitizen_doctor/ui/index_ui_model.dart';
|
||||||
@ -27,6 +28,7 @@ class SplashUIModel extends BaseUIModel {
|
|||||||
await AppConf.checkUpdate();
|
await AppConf.checkUpdate();
|
||||||
step = 2;
|
step = 2;
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
|
await handleError(() => BinaryModuleConf.extractModel());
|
||||||
Future.delayed(const Duration(milliseconds: 300));
|
Future.delayed(const Duration(milliseconds: 300));
|
||||||
Navigator.pushAndRemoveUntil(
|
Navigator.pushAndRemoveUntil(
|
||||||
context!,
|
context!,
|
||||||
|
@ -102,6 +102,7 @@ flutter:
|
|||||||
uses-material-design: true
|
uses-material-design: true
|
||||||
assets:
|
assets:
|
||||||
- assets/
|
- assets/
|
||||||
|
- assets/binary/
|
||||||
- assets/countdown/
|
- assets/countdown/
|
||||||
|
|
||||||
# To add assets to your application, add an assets section, like this:
|
# To add assets to your application, add an assets section, like this:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user