import 'dart:async'; import 'package:flutter/foundation.dart'; import 'package:sqflite/sqflite.dart'; import 'package:path_provider/path_provider.dart' show MissingPlatformDirectoryException, getApplicationDocumentsDirectory; import 'package:tetra_stats/services/crud_exceptions.dart'; import 'package:tetra_stats/services/tetrio_crud.dart'; import 'package:path/path.dart' show join; const String dbName = "TetraStats.db"; class DB { Database? _db; Future open() async { if (_db != null) { throw DatabaseAlreadyOpen(); } try { String dbPath; if (kIsWeb) { dbPath = dbName; } else { final docsPath = await getApplicationDocumentsDirectory(); dbPath = join(docsPath.path, dbName); } final db = await openDatabase(dbPath); _db = db; await db.execute(createTetrioUsersTable); await db.execute(createTetrioUsersToTrack); await db.execute(createTetrioTLRecordsTable); } on MissingPlatformDirectoryException { throw UnableToGetDocuments(); } } Future close() async { final db = _db; if (db == null) { throw DatabaseIsNotOpen(); } else { await db.close(); _db = null; } } Database getDatabaseOrThrow() { final db = _db; if (db == null) { throw DatabaseIsNotOpen(); } else { return db; } } Future ensureDbIsOpen() async { try { await open(); } on DatabaseAlreadyOpen { // empty } } }