mirror of
https://github.com/bggRGjQaUbCoE/PiliPlus.git
synced 2026-04-27 13:55:54 +08:00
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:
committed by
GitHub
parent
255e39b709
commit
0d273f6909
@@ -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;
|
||||
|
||||
Reference in New Issue
Block a user