2025-02-27 23:31:36 +05:30
|
|
|
import 'dart:io';
|
|
|
|
|
|
2025-08-28 19:41:54 +05:30
|
|
|
import 'package:background_downloader/background_downloader.dart';
|
2025-02-27 23:31:36 +05:30
|
|
|
import 'package:flutter/foundation.dart';
|
2025-08-28 19:41:54 +05:30
|
|
|
import 'package:immich_mobile/constants/constants.dart';
|
2025-08-22 01:28:50 +05:30
|
|
|
import 'package:immich_mobile/domain/models/store.model.dart';
|
2025-02-28 01:48:49 +05:30
|
|
|
import 'package:immich_mobile/domain/services/log.service.dart';
|
2025-02-27 23:31:36 +05:30
|
|
|
import 'package:immich_mobile/domain/services/store.service.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/album.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/android_device_asset.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/asset.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/backup_album.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/duplicated_asset.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/etag.entity.dart';
|
|
|
|
|
import 'package:immich_mobile/entities/ios_device_asset.entity.dart';
|
2025-08-28 19:41:54 +05:30
|
|
|
import 'package:immich_mobile/extensions/translate_extensions.dart';
|
2025-04-04 01:12:35 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/entities/device_asset.entity.dart';
|
2025-03-06 23:28:24 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/entities/exif.entity.dart';
|
2025-02-27 23:31:36 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/entities/store.entity.dart';
|
2025-03-12 19:26:56 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/entities/user.entity.dart';
|
2025-08-22 01:28:50 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/repositories/db.repository.dart';
|
2025-02-28 01:48:49 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/repositories/log.repository.dart';
|
2025-08-06 10:49:29 -05:00
|
|
|
import 'package:immich_mobile/infrastructure/repositories/logger_db.repository.dart';
|
2025-02-27 23:31:36 +05:30
|
|
|
import 'package:immich_mobile/infrastructure/repositories/store.repository.dart';
|
|
|
|
|
import 'package:isar/isar.dart';
|
|
|
|
|
import 'package:path_provider/path_provider.dart';
|
|
|
|
|
|
2025-08-28 19:41:54 +05:30
|
|
|
void configureFileDownloaderNotifications() {
|
|
|
|
|
FileDownloader().configureNotificationForGroup(
|
|
|
|
|
kDownloadGroupImage,
|
|
|
|
|
running: TaskNotification('downloading_media'.t(), '${'file_name'.t()}: {filename}'),
|
|
|
|
|
complete: TaskNotification('download_finished'.t(), '${'file_name'.t()}: {filename}'),
|
|
|
|
|
progressBar: true,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
FileDownloader().configureNotificationForGroup(
|
|
|
|
|
kDownloadGroupVideo,
|
|
|
|
|
running: TaskNotification('downloading_media'.t(), '${'file_name'.t()}: {filename}'),
|
|
|
|
|
complete: TaskNotification('download_finished'.t(), '${'file_name'.t()}: {filename}'),
|
|
|
|
|
progressBar: true,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
FileDownloader().configureNotificationForGroup(
|
|
|
|
|
kManualUploadGroup,
|
|
|
|
|
running: TaskNotification('uploading_media'.t(), 'backup_background_service_in_progress_notification'.t()),
|
|
|
|
|
complete: TaskNotification('upload_finished'.t(), 'backup_background_service_in_progress_notification'.t()),
|
|
|
|
|
groupNotificationId: kManualUploadGroup,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
FileDownloader().configureNotificationForGroup(
|
|
|
|
|
kBackupGroup,
|
|
|
|
|
running: TaskNotification('uploading_media'.t(), 'backup_background_service_in_progress_notification'.t()),
|
|
|
|
|
complete: TaskNotification('upload_finished'.t(), 'backup_background_service_in_progress_notification'.t()),
|
|
|
|
|
groupNotificationId: kBackupGroup,
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-27 23:31:36 +05:30
|
|
|
abstract final class Bootstrap {
|
2025-08-22 01:28:50 +05:30
|
|
|
static Future<(Isar isar, Drift drift, DriftLogger logDb)> initDB() async {
|
|
|
|
|
final drift = Drift();
|
|
|
|
|
final logDb = DriftLogger();
|
|
|
|
|
|
|
|
|
|
Isar? isar = Isar.getInstance();
|
|
|
|
|
|
|
|
|
|
if (isar != null) {
|
|
|
|
|
return (isar, drift, logDb);
|
2025-02-27 23:31:36 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
|
|
final dir = await getApplicationDocumentsDirectory();
|
2025-08-22 01:28:50 +05:30
|
|
|
isar = await Isar.open(
|
2025-02-27 23:31:36 +05:30
|
|
|
[
|
|
|
|
|
StoreValueSchema,
|
|
|
|
|
AssetSchema,
|
|
|
|
|
AlbumSchema,
|
2025-08-22 01:28:50 +05:30
|
|
|
ExifInfoSchema,
|
2025-02-27 23:31:36 +05:30
|
|
|
UserSchema,
|
|
|
|
|
BackupAlbumSchema,
|
|
|
|
|
DuplicatedAssetSchema,
|
|
|
|
|
ETagSchema,
|
|
|
|
|
if (Platform.isAndroid) AndroidDeviceAssetSchema,
|
|
|
|
|
if (Platform.isIOS) IOSDeviceAssetSchema,
|
2025-04-04 01:12:35 +05:30
|
|
|
DeviceAssetEntitySchema,
|
2025-02-27 23:31:36 +05:30
|
|
|
],
|
|
|
|
|
directory: dir.path,
|
2025-04-04 08:19:50 +05:30
|
|
|
maxSizeMiB: 2048,
|
2025-02-27 23:31:36 +05:30
|
|
|
inspector: kDebugMode,
|
|
|
|
|
);
|
2025-08-22 01:28:50 +05:30
|
|
|
|
|
|
|
|
return (isar, drift, logDb);
|
2025-02-27 23:31:36 +05:30
|
|
|
}
|
|
|
|
|
|
2025-08-22 01:28:50 +05:30
|
|
|
static Future<void> initDomain(Isar db, Drift drift, DriftLogger logDb, {bool shouldBufferLogs = true}) async {
|
|
|
|
|
final isBeta = await IsarStoreRepository(db).tryGet(StoreKey.betaTimeline) ?? false;
|
|
|
|
|
final IStoreRepository storeRepo = isBeta ? DriftStoreRepository(drift) : IsarStoreRepository(db);
|
|
|
|
|
|
|
|
|
|
await StoreService.init(storeRepository: storeRepo);
|
2025-08-06 10:49:29 -05:00
|
|
|
|
2025-02-28 01:48:49 +05:30
|
|
|
await LogService.init(
|
2025-08-07 03:27:17 +05:30
|
|
|
logRepository: LogRepository(logDb),
|
2025-08-22 01:28:50 +05:30
|
|
|
storeRepository: storeRepo,
|
2025-04-17 20:55:27 +05:30
|
|
|
shouldBuffer: shouldBufferLogs,
|
2025-02-28 01:48:49 +05:30
|
|
|
);
|
2025-02-27 23:31:36 +05:30
|
|
|
}
|
|
|
|
|
}
|