2024-09-04 01:50:35 +00:00
|
|
|
import 'dart:collection';
|
|
|
|
|
|
|
|
import 'package:flutter/foundation.dart';
|
2024-12-02 00:51:36 +00:00
|
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
2024-09-04 01:50:35 +00:00
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
|
|
|
|
|
|
part 'log_service.g.dart';
|
|
|
|
|
|
|
|
const _defaultMaxItems = 1000;
|
2024-12-02 00:51:36 +00:00
|
|
|
const _maxItems = _defaultMaxItems;
|
|
|
|
final _events = Queue<LogRecord>();
|
2024-09-04 01:50:35 +00:00
|
|
|
|
|
|
|
@Riverpod(keepAlive: true)
|
2024-12-02 00:51:36 +00:00
|
|
|
List<LogRecord> logHistory(Ref ref) {
|
|
|
|
return UnmodifiableListView(_events);
|
|
|
|
}
|
2024-09-04 01:50:35 +00:00
|
|
|
|
2024-12-02 00:51:36 +00:00
|
|
|
@Riverpod(keepAlive: true)
|
|
|
|
class LogService extends _$LogService {
|
2024-09-04 01:50:35 +00:00
|
|
|
@override
|
|
|
|
UnmodifiableListView<LogRecord> build() {
|
2024-12-02 00:51:36 +00:00
|
|
|
Logger.root.clearListeners();
|
2024-09-04 19:01:40 +00:00
|
|
|
Logger.root.onRecord.listen((event) {
|
|
|
|
add(event);
|
|
|
|
});
|
2024-12-02 00:51:36 +00:00
|
|
|
ref.onDispose(Logger.root.clearListeners);
|
2024-09-04 01:50:35 +00:00
|
|
|
return UnmodifiableListView(_events);
|
|
|
|
}
|
|
|
|
|
|
|
|
void add(LogRecord event) {
|
|
|
|
final logName = event.loggerName.isEmpty ? 'ROOT' : event.loggerName;
|
|
|
|
final msg =
|
|
|
|
'${event.level.name} - $logName @ ${event.time}: ${event.message}';
|
|
|
|
debugPrint(msg);
|
|
|
|
_events.add(event);
|
|
|
|
if (_events.length > _maxItems) {
|
|
|
|
_events.removeFirst();
|
|
|
|
}
|
2024-12-02 00:51:36 +00:00
|
|
|
ref.invalidate(logHistoryProvider);
|
2024-09-04 01:50:35 +00:00
|
|
|
}
|
|
|
|
}
|