mirror of
https://github.com/kodjodevf/mangayomi.git
synced 2026-04-19 09:52:03 +00:00
77 lines
1.9 KiB
Dart
77 lines
1.9 KiB
Dart
import 'dart:async';
|
|
import 'dart:io';
|
|
|
|
import 'package:mangayomi/providers/storage_provider.dart';
|
|
import 'package:path/path.dart' as path;
|
|
|
|
class AppLogger {
|
|
static final _logQueue = StreamController<String>();
|
|
static late File _logFile;
|
|
static late IOSink _sink;
|
|
static bool _initialized = false;
|
|
|
|
/// Initialize the logger
|
|
static Future<void> init() async {
|
|
final storage = StorageProvider();
|
|
final directory = await storage.getDefaultDirectory();
|
|
_logFile = File(path.join(directory!.path, 'logs.txt'));
|
|
|
|
if (await _logFile.exists() && await _logFile.length() > 100 * 1024) {
|
|
await _logFile.delete();
|
|
}
|
|
|
|
if (!await _logFile.exists()) {
|
|
await _logFile.create(recursive: true);
|
|
}
|
|
|
|
_sink = _logFile.openWrite(mode: FileMode.append);
|
|
_initialized = true;
|
|
|
|
_logQueue.stream.listen((log) {
|
|
_sink.writeln(log);
|
|
});
|
|
|
|
log('\n\nLogger initialized\n\n');
|
|
}
|
|
|
|
static void log(String message, {LogLevel logLevel = LogLevel.info}) {
|
|
if (!_initialized) return;
|
|
|
|
final now = DateTime.now();
|
|
final timestamp =
|
|
'${now.day.toString().padLeft(2, '0')}/${now.month.toString().padLeft(2, '0')}/${now.year.toString().padLeft(4, '0')} '
|
|
'${now.hour.toString().padLeft(2, '0')}:${now.minute.toString().padLeft(2, '0')}:${now.second.toString().padLeft(2, '0')}';
|
|
|
|
final logMessage = '[$timestamp][${logLevel.toString()}] $message';
|
|
_logQueue.add(logMessage);
|
|
}
|
|
|
|
static Future<void> dispose() async {
|
|
if (!_initialized) return;
|
|
await _logQueue.close();
|
|
await _sink.flush();
|
|
await _sink.close();
|
|
_initialized = false;
|
|
}
|
|
}
|
|
|
|
enum LogLevel {
|
|
debug,
|
|
info,
|
|
warning,
|
|
error;
|
|
|
|
@override
|
|
String toString() {
|
|
switch (this) {
|
|
case LogLevel.debug:
|
|
return 'DEBUG';
|
|
case LogLevel.info:
|
|
return 'INFO';
|
|
case LogLevel.warning:
|
|
return 'WARNING';
|
|
case LogLevel.error:
|
|
return 'ERROR';
|
|
}
|
|
}
|
|
}
|