Overworking prints
This commit is contained in:
@@ -7,14 +7,10 @@ import 'package:file_picker/file_picker.dart';
|
|||||||
import 'package:file_saver/file_saver.dart';
|
import 'package:file_saver/file_saver.dart';
|
||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:json_schema/json_schema.dart';
|
import 'package:json_schema/json_schema.dart';
|
||||||
import 'package:logger/logger.dart';
|
|
||||||
import 'package:path_provider/path_provider.dart';
|
import 'package:path_provider/path_provider.dart';
|
||||||
|
|
||||||
class LocalStorageService {
|
class LocalStorageService {
|
||||||
static const String _fileName = 'game_data.json';
|
static const String _fileName = 'game_data.json';
|
||||||
static var logger = Logger(
|
|
||||||
printer: PrettyPrinter(),
|
|
||||||
);
|
|
||||||
|
|
||||||
/// Writes the game session list to a JSON file and returns it as string.
|
/// Writes the game session list to a JSON file and returns it as string.
|
||||||
static String getJsonFile() {
|
static String getJsonFile() {
|
||||||
@@ -36,38 +32,44 @@ class LocalStorageService {
|
|||||||
final file = await _getFilePath();
|
final file = await _getFilePath();
|
||||||
final jsonFile = getJsonFile();
|
final jsonFile = getJsonFile();
|
||||||
await file.writeAsString(jsonFile);
|
await file.writeAsString(jsonFile);
|
||||||
logger.i('Die Spieldaten wurden zwischengespeichert.');
|
print(
|
||||||
|
'[local_storage_service.dart] Die Spieldaten wurden zwischengespeichert.');
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
logger.w('Fehler beim Speichern der Spieldaten. Exception: $e');
|
print(
|
||||||
|
'[local_storage_service.dart] Fehler beim Speichern der Spieldaten. Exception: $e');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Loads the game data from a local JSON file.
|
/// Loads the game data from a local JSON file.
|
||||||
static Future<bool> loadGameSessions() async {
|
static Future<bool> loadGameSessions() async {
|
||||||
logger.d('Versuche, Daten zu laden...');
|
print('[local_storage_service.dart] Versuche, Daten zu laden...');
|
||||||
try {
|
try {
|
||||||
final file = await _getFilePath();
|
final file = await _getFilePath();
|
||||||
|
|
||||||
if (!await file.exists()) {
|
if (!await file.exists()) {
|
||||||
logger.w('Es existiert noch keine Datei mit Spieldaten');
|
print(
|
||||||
|
'[local_storage_service.dart] Es existiert noch keine Datei mit Spieldaten');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.d('Es existiert bereits eine Datei mit Spieldaten');
|
print(
|
||||||
|
'[local_storage_service.dart] Es existiert bereits eine Datei mit Spieldaten');
|
||||||
final jsonString = await file.readAsString();
|
final jsonString = await file.readAsString();
|
||||||
|
|
||||||
if (jsonString.isEmpty) {
|
if (jsonString.isEmpty) {
|
||||||
logger.w('Die gefundene Datei ist leer');
|
print('[local_storage_service.dart] Die gefundene Datei ist leer');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!await validateJsonSchema(jsonString)) {
|
if (!await validateJsonSchema(jsonString)) {
|
||||||
logger.w('Die Datei konnte nicht validiert werden');
|
print(
|
||||||
|
'[local_storage_service.dart] Die Datei konnte nicht validiert werden');
|
||||||
gameManager.gameList = [];
|
gameManager.gameList = [];
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
logger.d('Die gefundene Datei hat Inhalt');
|
print('[local_storage_service.dart] Die gefundene Datei hat Inhalt');
|
||||||
logger.d('Die gefundene Datei wurde erfolgreich validiert');
|
print(
|
||||||
|
'[local_storage_service.dart] Die gefundene Datei wurde erfolgreich validiert');
|
||||||
final jsonList = json.decode(jsonString) as List<dynamic>;
|
final jsonList = json.decode(jsonString) as List<dynamic>;
|
||||||
|
|
||||||
gameManager.gameList = jsonList
|
gameManager.gameList = jsonList
|
||||||
@@ -75,11 +77,12 @@ class LocalStorageService {
|
|||||||
GameSession.fromJson(jsonItem as Map<String, dynamic>))
|
GameSession.fromJson(jsonItem as Map<String, dynamic>))
|
||||||
.toList();
|
.toList();
|
||||||
|
|
||||||
logger.i('Die Spieldaten wurden erfolgreich geladen und verarbeitet');
|
print(
|
||||||
|
'[local_storage_service.dart] Die Spieldaten wurden erfolgreich geladen und verarbeitet');
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
logger.e('Fehler beim Laden der Spieldaten:\n$e',
|
print(
|
||||||
error: 'JSON nicht geladen');
|
'[local_storage_service.dart] Fehler beim Laden der Spieldaten:\n$e');
|
||||||
gameManager.gameList = [];
|
gameManager.gameList = [];
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -96,11 +99,12 @@ class LocalStorageService {
|
|||||||
ext: 'json',
|
ext: 'json',
|
||||||
mimeType: MimeType.json,
|
mimeType: MimeType.json,
|
||||||
);
|
);
|
||||||
logger.i('Die Spieldaten wurden exportiert. Dateipfad: $result');
|
print(
|
||||||
|
'[local_storage_service.dart] Die Spieldaten wurden exportiert. Dateipfad: $result');
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
logger.w('Fehler beim Exportieren der Spieldaten. Exception: $e',
|
print(
|
||||||
error: 'JSON nicht exportiert');
|
'[local_storage_service.dart] Fehler beim Exportieren der Spieldaten. Exception: $e');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -114,7 +118,8 @@ class LocalStorageService {
|
|||||||
);
|
);
|
||||||
|
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
logger.d('Der Filepicker-Dialog wurde abgebrochen');
|
print(
|
||||||
|
'[local_storage_service.dart] Der Filepicker-Dialog wurde abgebrochen');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -129,14 +134,16 @@ class LocalStorageService {
|
|||||||
.map((jsonItem) =>
|
.map((jsonItem) =>
|
||||||
GameSession.fromJson(jsonItem as Map<String, dynamic>))
|
GameSession.fromJson(jsonItem as Map<String, dynamic>))
|
||||||
.toList();
|
.toList();
|
||||||
logger.i('Die Datei wurde erfolgreich Importiertn');
|
print(
|
||||||
|
'[local_storage_service.dart] Die Datei wurde erfolgreich Importiertn');
|
||||||
return true;
|
return true;
|
||||||
} on FormatException catch (e) {
|
} on FormatException catch (e) {
|
||||||
logger.e('Ungültiges JSON-Format. Exception: $e', error: 'Formatfehler');
|
print(
|
||||||
|
'[local_storage_service.dart] Ungültiges JSON-Format. Exception: $e');
|
||||||
return false;
|
return false;
|
||||||
} on Exception catch (e) {
|
} on Exception catch (e) {
|
||||||
logger.e('Fehler beim Dateizugriff. Exception: $e',
|
print(
|
||||||
error: 'Dateizugriffsfehler');
|
'[local_storage_service.dart] Fehler beim Dateizugriff. Exception: $e');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -158,14 +165,15 @@ class LocalStorageService {
|
|||||||
final result = schema.validate(jsonData);
|
final result = schema.validate(jsonData);
|
||||||
|
|
||||||
if (result.isValid) {
|
if (result.isValid) {
|
||||||
logger.d('JSON ist erfolgreich validiert.');
|
print('[local_storage_service.dart] JSON ist erfolgreich validiert.');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
logger.w('JSON ist nicht gültig.\nFehler: ${result.errors}');
|
print(
|
||||||
|
'[local_storage_service.dart] JSON ist nicht gültig.\nFehler: ${result.errors}');
|
||||||
return false;
|
return false;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
logger.e('Fehler beim Validieren des JSON-Schemas: $e',
|
print(
|
||||||
error: 'Validierung fehlgeschlagen');
|
'[local_storage_service.dart] Fehler beim Validieren des JSON-Schemas: $e');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -174,11 +182,12 @@ class LocalStorageService {
|
|||||||
try {
|
try {
|
||||||
gameManager.gameList.clear();
|
gameManager.gameList.clear();
|
||||||
await saveGameSessions();
|
await saveGameSessions();
|
||||||
logger.i('Alle Runden wurden erfolgreich gelöscht.');
|
print(
|
||||||
|
'[local_storage_service.dart] Alle Runden wurden erfolgreich gelöscht.');
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
logger.e('Fehler beim Löschen aller Runden: $e',
|
print(
|
||||||
error: 'Löschen fehlgeschlagen');
|
'[local_storage_service.dart] Fehler beim Löschen aller Runden: $e');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user