2022-07-13 22:23:41 +02:00
|
|
|
import 'package:drift/drift.dart' as sql;
|
2022-01-01 21:34:40 +01:00
|
|
|
import 'package:nc_photos/account.dart';
|
|
|
|
import 'package:nc_photos/di_container.dart';
|
|
|
|
import 'package:nc_photos/entity/file.dart';
|
2022-07-05 22:20:24 +02:00
|
|
|
import 'package:nc_photos/entity/sqlite_table_converter.dart';
|
|
|
|
import 'package:nc_photos/entity/sqlite_table_extension.dart' as sql;
|
|
|
|
import 'package:nc_photos/object_extension.dart';
|
2022-01-01 21:34:40 +01:00
|
|
|
|
|
|
|
class ScanDirOffline {
|
|
|
|
ScanDirOffline(this._c) : assert(require(_c));
|
|
|
|
|
2022-07-05 22:20:24 +02:00
|
|
|
static bool require(DiContainer c) => DiContainer.has(c, DiType.sqliteDb);
|
2022-01-01 21:34:40 +01:00
|
|
|
|
2022-07-05 22:20:24 +02:00
|
|
|
Future<List<File>> call(
|
2022-05-28 08:33:04 +02:00
|
|
|
Account account,
|
|
|
|
File root, {
|
|
|
|
bool isOnlySupportedFormat = true,
|
|
|
|
}) async {
|
2022-07-05 22:20:24 +02:00
|
|
|
return await _c.sqliteDb.isolate({
|
|
|
|
"account": account,
|
|
|
|
"root": root,
|
|
|
|
"isOnlySupportedFormat": isOnlySupportedFormat,
|
|
|
|
}, (db, Map args) async {
|
|
|
|
final Account account = args["account"];
|
|
|
|
final File root = args["root"];
|
|
|
|
final bool isOnlySupportedFormat = args["isOnlySupportedFormat"];
|
|
|
|
final dbFiles = await db.useInIsolate((db) async {
|
|
|
|
final query = db.queryFiles().run((q) {
|
|
|
|
q
|
|
|
|
..setQueryMode(sql.FilesQueryMode.completeFile)
|
|
|
|
..setAppAccount(account);
|
|
|
|
root.strippedPathWithEmpty.run((p) {
|
|
|
|
if (p.isNotEmpty) {
|
|
|
|
q.byRelativePathPattern("$p/%");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
if (isOnlySupportedFormat) {
|
|
|
|
q
|
|
|
|
..byMimePattern("image/%")
|
|
|
|
..byMimePattern("video/%");
|
|
|
|
}
|
|
|
|
return q.build();
|
|
|
|
});
|
|
|
|
return await query
|
|
|
|
.map((r) => sql.CompleteFile(
|
|
|
|
r.readTable(db.files),
|
|
|
|
r.readTable(db.accountFiles),
|
|
|
|
r.readTableOrNull(db.images),
|
|
|
|
r.readTableOrNull(db.trashes),
|
|
|
|
))
|
|
|
|
.get();
|
|
|
|
});
|
|
|
|
return dbFiles
|
2022-07-11 20:14:42 +02:00
|
|
|
.map((f) => SqliteFileConverter.fromSql(account.userId.toString(), f))
|
2022-07-05 22:20:24 +02:00
|
|
|
.toList();
|
|
|
|
});
|
2022-01-01 21:34:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
final DiContainer _c;
|
|
|
|
}
|
2022-07-13 22:23:41 +02:00
|
|
|
|
|
|
|
class ScanDirOfflineMini {
|
|
|
|
ScanDirOfflineMini(this._c) : assert(require(_c));
|
|
|
|
|
|
|
|
static bool require(DiContainer c) => DiContainer.has(c, DiType.sqliteDb);
|
|
|
|
|
|
|
|
Future<List<File>> call(
|
|
|
|
Account account,
|
|
|
|
Iterable<File> roots,
|
|
|
|
int limit, {
|
|
|
|
bool isOnlySupportedFormat = true,
|
|
|
|
}) async {
|
|
|
|
final dbFiles = await _c.sqliteDb.use((db) async {
|
|
|
|
final query = db.queryFiles().run((q) {
|
|
|
|
q
|
|
|
|
..setQueryMode(sql.FilesQueryMode.completeFile)
|
|
|
|
..setAppAccount(account);
|
|
|
|
for (final r in roots) {
|
|
|
|
final path = r.strippedPathWithEmpty;
|
|
|
|
if (path.isEmpty) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
q.byRelativePathPattern("$path/%");
|
|
|
|
}
|
|
|
|
if (isOnlySupportedFormat) {
|
|
|
|
q
|
|
|
|
..byMimePattern("image/%")
|
|
|
|
..byMimePattern("video/%");
|
|
|
|
}
|
|
|
|
return q.build();
|
|
|
|
});
|
|
|
|
query
|
|
|
|
..orderBy([sql.OrderingTerm.desc(db.accountFiles.bestDateTime)])
|
|
|
|
..limit(limit);
|
|
|
|
return await query
|
|
|
|
.map((r) => sql.CompleteFile(
|
|
|
|
r.readTable(db.files),
|
|
|
|
r.readTable(db.accountFiles),
|
|
|
|
r.readTableOrNull(db.images),
|
|
|
|
r.readTableOrNull(db.trashes),
|
|
|
|
))
|
|
|
|
.get();
|
|
|
|
});
|
|
|
|
return dbFiles
|
|
|
|
.map((f) => SqliteFileConverter.fromSql(account.userId.toString(), f))
|
|
|
|
.toList();
|
|
|
|
}
|
|
|
|
|
|
|
|
final DiContainer _c;
|
|
|
|
}
|