2024-09-16 22:26:14 +02:00
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
|
|
import 'package:immich_mobile/entities/album.entity.dart';
|
|
|
|
import 'package:immich_mobile/entities/asset.entity.dart';
|
|
|
|
import 'package:immich_mobile/entities/user.entity.dart';
|
|
|
|
import 'package:immich_mobile/interfaces/asset.interface.dart';
|
|
|
|
import 'package:immich_mobile/providers/db.provider.dart';
|
|
|
|
import 'package:isar/isar.dart';
|
|
|
|
|
|
|
|
final assetRepositoryProvider =
|
|
|
|
Provider((ref) => AssetRepository(ref.watch(dbProvider)));
|
|
|
|
|
|
|
|
class AssetRepository implements IAssetRepository {
|
|
|
|
final Isar _db;
|
|
|
|
|
|
|
|
AssetRepository(
|
|
|
|
this._db,
|
|
|
|
);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Future<List<Asset>> getByAlbum(Album album, {User? notOwnedBy}) {
|
|
|
|
var query = album.assets.filter();
|
|
|
|
if (notOwnedBy != null) {
|
|
|
|
query = query.not().ownerIdEqualTo(notOwnedBy.isarId);
|
|
|
|
}
|
|
|
|
return query.findAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Future<void> deleteById(List<int> ids) =>
|
|
|
|
_db.writeTxn(() => _db.assets.deleteAll(ids));
|
2024-09-20 15:32:37 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
Future<Asset?> getByRemoteId(String id) => _db.assets.getByRemoteId(id);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Future<List<Asset>> getAllByRemoteId(Iterable<String> ids) =>
|
|
|
|
_db.assets.getAllByRemoteId(ids);
|
2024-09-24 08:24:48 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
Future<List<Asset>> getAll({
|
|
|
|
required int ownerId,
|
|
|
|
bool? remote,
|
|
|
|
int limit = 100,
|
|
|
|
}) {
|
|
|
|
if (remote == null) {
|
|
|
|
return _db.assets
|
|
|
|
.where()
|
|
|
|
.ownerIdEqualToAnyChecksum(ownerId)
|
|
|
|
.limit(limit)
|
|
|
|
.findAll();
|
|
|
|
}
|
|
|
|
final QueryBuilder<Asset, Asset, QAfterFilterCondition> query;
|
|
|
|
if (remote) {
|
|
|
|
query = _db.assets
|
|
|
|
.where()
|
|
|
|
.localIdIsNull()
|
|
|
|
.filter()
|
|
|
|
.remoteIdIsNotNull()
|
|
|
|
.ownerIdEqualTo(ownerId);
|
|
|
|
} else {
|
|
|
|
query = _db.assets
|
|
|
|
.where()
|
|
|
|
.remoteIdIsNull()
|
|
|
|
.filter()
|
|
|
|
.localIdIsNotNull()
|
|
|
|
.ownerIdEqualTo(ownerId);
|
|
|
|
}
|
|
|
|
|
|
|
|
return query.limit(limit).findAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Future<List<Asset>> getMatches({
|
|
|
|
required List<Asset> assets,
|
|
|
|
required int ownerId,
|
|
|
|
bool? remote,
|
|
|
|
int limit = 100,
|
|
|
|
}) {
|
|
|
|
final QueryBuilder<Asset, Asset, QAfterFilterCondition> query;
|
|
|
|
if (remote == null) {
|
|
|
|
query = _db.assets.filter().remoteIdIsNotNull().or().localIdIsNotNull();
|
|
|
|
} else if (remote) {
|
|
|
|
query = _db.assets.where().localIdIsNull().filter().remoteIdIsNotNull();
|
|
|
|
} else {
|
|
|
|
query = _db.assets.where().remoteIdIsNull().filter().localIdIsNotNull();
|
|
|
|
}
|
|
|
|
return _getMatchesImpl(query, ownerId, assets, limit);
|
|
|
|
}
|
2024-09-16 22:26:14 +02:00
|
|
|
}
|
2024-09-24 08:24:48 +02:00
|
|
|
|
|
|
|
Future<List<Asset>> _getMatchesImpl(
|
|
|
|
QueryBuilder<Asset, Asset, QAfterFilterCondition> query,
|
|
|
|
int ownerId,
|
|
|
|
List<Asset> assets,
|
|
|
|
int limit,
|
|
|
|
) =>
|
|
|
|
query
|
|
|
|
.ownerIdEqualTo(ownerId)
|
|
|
|
.anyOf(
|
|
|
|
assets,
|
|
|
|
(q, Asset a) => q
|
|
|
|
.fileNameEqualTo(a.fileName)
|
|
|
|
.and()
|
|
|
|
.durationInSecondsEqualTo(a.durationInSeconds)
|
|
|
|
.and()
|
|
|
|
.fileCreatedAtBetween(
|
|
|
|
a.fileCreatedAt.subtract(const Duration(hours: 12)),
|
|
|
|
a.fileCreatedAt.add(const Duration(hours: 12)),
|
|
|
|
)
|
|
|
|
.and()
|
|
|
|
.not()
|
|
|
|
.checksumEqualTo(a.checksum),
|
|
|
|
)
|
|
|
|
.sortByFileName()
|
|
|
|
.thenByFileCreatedAt()
|
|
|
|
.thenByFileModifiedAt()
|
|
|
|
.limit(limit)
|
|
|
|
.findAll();
|