mirror of
https://github.com/immich-app/immich.git
synced 2025-05-24 01:12:58 -04:00
* refactor: user entity * chore: rebase fixes * refactor: remove int user Id * refactor: migrate store userId from int to string * refactor: rename uid to id * feat: drift * pr feedback * refactor: move common overrides to mixin * refactor: remove int user Id * refactor: migrate store userId from int to string * refactor: rename uid to id * feat: user & partner sync stream * pr changes * refactor: sync service and add tests * chore: remove generated change * chore: move sync model * rebase: convert string ids to byte uuids * rebase * add processing logs * batch db calls * rewrite isolate manager * rewrite with worker_manager * misc fixes * add sync order test --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: Alex <alex.tran1502@gmail.com>
105 lines
3.1 KiB
Dart
105 lines
3.1 KiB
Dart
import 'package:drift/drift.dart';
|
|
import 'package:immich_mobile/domain/interfaces/sync_stream.interface.dart';
|
|
import 'package:immich_mobile/extensions/string_extensions.dart';
|
|
import 'package:immich_mobile/infrastructure/entities/partner.entity.drift.dart';
|
|
import 'package:immich_mobile/infrastructure/entities/user.entity.drift.dart';
|
|
import 'package:immich_mobile/infrastructure/repositories/db.repository.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:openapi/api.dart';
|
|
|
|
class DriftSyncStreamRepository extends DriftDatabaseRepository
|
|
implements ISyncStreamRepository {
|
|
final Logger _logger = Logger('DriftSyncStreamRepository');
|
|
final Drift _db;
|
|
|
|
DriftSyncStreamRepository(super.db) : _db = db;
|
|
|
|
@override
|
|
Future<bool> deleteUsersV1(Iterable<SyncUserDeleteV1> data) async {
|
|
try {
|
|
await _db.batch((batch) {
|
|
for (final user in data) {
|
|
batch.delete(
|
|
_db.userEntity,
|
|
UserEntityCompanion(id: Value(user.userId.toUuidByte())),
|
|
);
|
|
}
|
|
});
|
|
return true;
|
|
} catch (e, s) {
|
|
_logger.severe('Error while processing SyncUserDeleteV1', e, s);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
@override
|
|
Future<bool> updateUsersV1(Iterable<SyncUserV1> data) async {
|
|
try {
|
|
await _db.batch((batch) {
|
|
for (final user in data) {
|
|
final companion = UserEntityCompanion(
|
|
name: Value(user.name),
|
|
email: Value(user.email),
|
|
);
|
|
|
|
batch.insert(
|
|
_db.userEntity,
|
|
companion.copyWith(id: Value(user.id.toUuidByte())),
|
|
onConflict: DoUpdate((_) => companion),
|
|
);
|
|
}
|
|
});
|
|
return true;
|
|
} catch (e, s) {
|
|
_logger.severe('Error while processing SyncUserV1', e, s);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
@override
|
|
Future<bool> deletePartnerV1(Iterable<SyncPartnerDeleteV1> data) async {
|
|
try {
|
|
await _db.batch((batch) {
|
|
for (final partner in data) {
|
|
batch.delete(
|
|
_db.partnerEntity,
|
|
PartnerEntityCompanion(
|
|
sharedById: Value(partner.sharedById.toUuidByte()),
|
|
sharedWithId: Value(partner.sharedWithId.toUuidByte()),
|
|
),
|
|
);
|
|
}
|
|
});
|
|
return true;
|
|
} catch (e, s) {
|
|
_logger.severe('Error while processing SyncPartnerDeleteV1', e, s);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
@override
|
|
Future<bool> updatePartnerV1(Iterable<SyncPartnerV1> data) async {
|
|
try {
|
|
await _db.batch((batch) {
|
|
for (final partner in data) {
|
|
final companion =
|
|
PartnerEntityCompanion(inTimeline: Value(partner.inTimeline));
|
|
|
|
batch.insert(
|
|
_db.partnerEntity,
|
|
companion.copyWith(
|
|
sharedById: Value(partner.sharedById.toUuidByte()),
|
|
sharedWithId: Value(partner.sharedWithId.toUuidByte()),
|
|
),
|
|
onConflict: DoUpdate((_) => companion),
|
|
);
|
|
}
|
|
});
|
|
return true;
|
|
} catch (e, s) {
|
|
_logger.severe('Error while processing SyncPartnerV1', e, s);
|
|
return false;
|
|
}
|
|
}
|
|
}
|