diff --git a/packages/celest_core/lib/src/storage/memory_storage.dart b/packages/celest_core/lib/src/storage/memory_storage.dart index ece77fb6..887b8771 100644 --- a/packages/celest_core/lib/src/storage/memory_storage.dart +++ b/packages/celest_core/lib/src/storage/memory_storage.dart @@ -4,12 +4,14 @@ import 'package:celest_core/src/storage/storage.dart'; /// An in-memory implementation of [Storage] and [SecureStorage]. final class MemoryStorage implements Storage, SecureStorage { MemoryStorage({ - required this.scope, - }); + String? scope, + }) : scope = scope ?? _defaultScope; final _storage = {}; final String scope; + static const _defaultScope = 'dev.celest.cli'; + @override void clear() => _storage.removeWhere((key, _) => key.startsWith('$scope/')); diff --git a/packages/celest_core/lib/src/storage/storage.dart b/packages/celest_core/lib/src/storage/storage.dart index 7bc64447..ff0d5de3 100644 --- a/packages/celest_core/lib/src/storage/storage.dart +++ b/packages/celest_core/lib/src/storage/storage.dart @@ -1,7 +1,9 @@ import 'package:celest_core/src/storage/local/local_storage.dart'; +import 'package:celest_core/src/storage/memory_storage.dart'; import 'package:celest_core/src/storage/secure/secure_storage.dart'; abstract interface class Storage { + factory Storage.memory({String? scope}) = MemoryStorage; factory Storage.local({String? scope}) = LocalStorage; factory Storage.secure({String? scope}) = SecureStorage;