mangayomi-mirror/lib/utils/log/logger.dart
2025-08-26 22:07:49 +02:00

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';
}
}
}