added missing comma in intl_es, same thing for chat.dart as it was missing trailing comma, for my_analytics i added some error catches for that minified:tm

bug
pull/1384/head
bluearevalo 1 year ago
parent 150eb9533a
commit fbbbf5e740

@ -4721,7 +4721,7 @@
"versionNotFound": "Versión no encontrada", "versionNotFound": "Versión no encontrada",
"fetchingVersion": "Obteniendo versión...", "fetchingVersion": "Obteniendo versión...",
"versionFetchError": "Error al obtener la versión", "versionFetchError": "Error al obtener la versión",
"connectedToStaging": "Conectado al entorno de pruebas" "connectedToStaging": "Conectado al entorno de pruebas",
"connectedToStaging": "Conectado al entorno de pruebas", "connectedToStaging": "Conectado al entorno de pruebas",
"versionText": "Versión: {version}+{buildNumber}", "versionText": "Versión: {version}+{buildNumber}",
"@versionText": { "@versionText": {

@ -523,7 +523,7 @@ class ChatController extends State<ChatPageWithRoom>
ErrorHandler.logError( ErrorHandler.logError(
e: PangeaWarningError("Failed to set read marker: $e"), e: PangeaWarningError("Failed to set read marker: $e"),
s: s, s: s,
m: 'Failed to set read marker for eventId: $eventId' m: 'Failed to set read marker for eventId: $eventId',
); );
Sentry.captureException( Sentry.captureException(
e, e,
@ -531,7 +531,7 @@ class ChatController extends State<ChatPageWithRoom>
withScope: (scope) { withScope: (scope) {
scope.setExtra('extra_info', 'Failed during setReadMarker with eventId: $eventId'); scope.setExtra('extra_info', 'Failed during setReadMarker with eventId: $eventId');
scope.setTag('where', 'setReadMarker'); scope.setTag('where', 'setReadMarker');
} },
); );
}); });

@ -11,6 +11,7 @@ import 'package:fluffychat/pangea/models/analytics/summary_analytics_model.dart'
import 'package:fluffychat/pangea/utils/error_handler.dart'; import 'package:fluffychat/pangea/utils/error_handler.dart';
import 'package:flutter/foundation.dart'; import 'package:flutter/foundation.dart';
import 'package:matrix/matrix.dart'; import 'package:matrix/matrix.dart';
import 'package:sentry_flutter/sentry_flutter.dart';
import '../extensions/client_extension/client_extension.dart'; import '../extensions/client_extension/client_extension.dart';
import '../extensions/pangea_room_extension/pangea_room_extension.dart'; import '../extensions/pangea_room_extension/pangea_room_extension.dart';
@ -113,20 +114,36 @@ class MyAnalyticsController {
// adds an event ID to the cache of un-added event IDs // adds an event ID to the cache of un-added event IDs
// if the event IDs isn't already added // if the event IDs isn't already added
void addMessageSinceUpdate(String eventId) { void addMessageSinceUpdate(String eventId) {
final List<String> currentCache = messagesSinceUpdate; try{
if (!currentCache.contains(eventId)) { final List<String> currentCache = messagesSinceUpdate;
currentCache.add(eventId); if (!currentCache.contains(eventId)) {
_pangeaController.pStoreService.save( currentCache.add(eventId);
PLocalKey.messagesSinceUpdate, _pangeaController.pStoreService.save(
currentCache, PLocalKey.messagesSinceUpdate,
local: true, currentCache,
); local: true,
} );
}
// if the cached has reached if max-length, update analytics // if the cached has reached if max-length, update analytics
if (messagesSinceUpdate.length > _maxMessagesCached) { if (messagesSinceUpdate.length > _maxMessagesCached) {
debugPrint("reached max messages, updating"); debugPrint("reached max messages, updating");
updateAnalytics(); updateAnalytics();
}
} catch (exception, stackTrace) {
ErrorHandler.logError(
e: PangeaWarningError("Failed to add message since update: $exception"),
s: stackTrace,
m: 'Failed to add message since update for eventId: $eventId'
);
Sentry.captureException(
exception,
stackTrace: stackTrace,
withScope: (scope) {
scope.setExtra('extra_info', 'Failed during addMessageSinceUpdate with eventId: $eventId');
scope.setTag('where', 'addMessageSinceUpdate');
}
);
} }
} }
@ -143,30 +160,45 @@ class MyAnalyticsController {
// it's possible for this cache to be invalid or deleted // it's possible for this cache to be invalid or deleted
// It's a proxy measure for messages sent since last update // It's a proxy measure for messages sent since last update
List<String> get messagesSinceUpdate { List<String> get messagesSinceUpdate {
final dynamic locallySaved = _pangeaController.pStoreService.read(
PLocalKey.messagesSinceUpdate,
local: true,
);
if (locallySaved == null) {
_pangeaController.pStoreService.save(
PLocalKey.messagesSinceUpdate,
[],
local: true,
);
return [];
}
try { try {
return locallySaved as List<String>; Logs().d('Reading messages since update from local storage');
} catch (err) { final dynamic locallySaved = _pangeaController.pStoreService.read(
_pangeaController.pStoreService.save( PLocalKey.messagesSinceUpdate,
PLocalKey.messagesSinceUpdate, local: true,
[], );
local: true, if (locallySaved == null) {
); Logs().d('No locally saved messages found, initializing empty list.');
return []; _pangeaController.pStoreService.save(
PLocalKey.messagesSinceUpdate,
[],
local: true,
);
return [];
}
return locallySaved as List<String>;
} catch (exception, stackTrace) {
ErrorHandler.logError(
e: PangeaWarningError("Failed to get messages since update: $exception"),
s: stackTrace,
m: 'Failed to retrieve messages since update'
);
Sentry.captureException(
exception,
stackTrace: stackTrace,
withScope: (scope) {
scope.setExtra('extra_info', 'Error during messagesSinceUpdate getter');
scope.setTag('where', 'messagesSinceUpdate');
}
);
_pangeaController.pStoreService.save(
PLocalKey.messagesSinceUpdate,
[],
local: true,
);
return [];
} }
} }
Completer<void>? _updateCompleter; Completer<void>? _updateCompleter;
Future<void> updateAnalytics() async { Future<void> updateAnalytics() async {

Loading…
Cancel
Save