refa: logfile (#1764)

* refa: logfile

* opt: log page

* opt: raf log file

* remove old log

* update

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>

---------

Co-authored-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
My-Responsitories
2025-12-06 22:33:00 +08:00
committed by GitHub
parent 255e39b709
commit 0d273f6909
6 changed files with 539 additions and 156 deletions

View File

@@ -1,5 +1,9 @@
import 'dart:io';
import 'package:PiliPlus/utils/extension.dart';
import 'package:PiliPlus/utils/json_file_handler.dart';
import 'package:PiliPlus/utils/storage_pref.dart';
import 'package:catcher_2/catcher_2.dart';
import 'package:logger/logger.dart';
import 'package:path/path.dart' as p;
import 'package:path_provider/path_provider.dart';
@@ -10,44 +14,48 @@ class PiliLogger extends Logger {
PiliLogger() : super();
@override
Future<void> log(
void log(
Level level,
dynamic message, {
Object? error,
StackTrace? stackTrace,
DateTime? time,
}) async {
}) {
if (level == Level.error || level == Level.fatal) {
// 添加至文件末尾
File logFile = await LoggerUtils.getLogsPath();
logFile.writeAsString(
"**${DateTime.now()}** \n $message \n $stackTrace",
mode: FileMode.writeOnlyAppend,
);
Catcher2.reportCheckedError(error, stackTrace);
}
super.log(level, "$message", error: error, stackTrace: stackTrace);
super.log(level, message, error: error, stackTrace: stackTrace, time: time);
}
}
class LoggerUtils {
abstract final class LoggerUtils {
static File? _logFile;
static Future<File> getLogsPath() async {
if (_logFile != null) return _logFile!;
String dir = (await getApplicationDocumentsDirectory()).path;
final String filename = p.join(dir, ".pili_logs");
final String filename = p.join(dir, '.pili_logs.json');
final File file = File(filename);
if (!file.existsSync()) {
await file.create(recursive: true);
// TODO: remove after next two versions
final oldFile = File(p.join(dir, '.pili_logs'));
if (oldFile.existsSync()) oldFile.tryDel();
}
return _logFile = file;
}
static Future<bool> clearLogs() async {
final file = await getLogsPath();
try {
await file.writeAsBytes(const [], flush: true);
if (Pref.enableLog) {
await JsonFileHandler.add(
(raf) => raf.setPosition(0).then((raf) => raf.truncate(0)),
);
} else {
final file = await getLogsPath();
await file.writeAsBytes(const [], flush: true);
}
} catch (e) {
// if (kDebugMode) debugPrint('Error clearing file: $e');
return false;