mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +01:00
75830a4878
* refactor(server): user endpoints * fix repos * fix unit tests --------- Co-authored-by: Daniel Dietzler <mail@ddietzler.dev> Co-authored-by: Alex <alex.tran1502@gmail.com>
119 lines
3.4 KiB
Dart
119 lines
3.4 KiB
Dart
import 'package:collection/collection.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:http/http.dart';
|
|
import 'package:image_picker/image_picker.dart';
|
|
import 'package:immich_mobile/services/partner.service.dart';
|
|
import 'package:immich_mobile/entities/store.entity.dart';
|
|
import 'package:immich_mobile/entities/user.entity.dart';
|
|
import 'package:immich_mobile/providers/api.provider.dart';
|
|
import 'package:immich_mobile/providers/db.provider.dart';
|
|
import 'package:immich_mobile/services/api.service.dart';
|
|
import 'package:immich_mobile/services/sync.service.dart';
|
|
import 'package:immich_mobile/utils/diff.dart';
|
|
import 'package:isar/isar.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:openapi/api.dart';
|
|
|
|
final userServiceProvider = Provider(
|
|
(ref) => UserService(
|
|
ref.watch(apiServiceProvider),
|
|
ref.watch(dbProvider),
|
|
ref.watch(syncServiceProvider),
|
|
ref.watch(partnerServiceProvider),
|
|
),
|
|
);
|
|
|
|
class UserService {
|
|
final ApiService _apiService;
|
|
final Isar _db;
|
|
final SyncService _syncService;
|
|
final PartnerService _partnerService;
|
|
final Logger _log = Logger("UserService");
|
|
|
|
UserService(
|
|
this._apiService,
|
|
this._db,
|
|
this._syncService,
|
|
this._partnerService,
|
|
);
|
|
|
|
Future<List<User>?> _getAllUsers() async {
|
|
try {
|
|
final dto = await _apiService.userApi.searchUsers();
|
|
return dto?.map(User.fromSimpleUserDto).toList();
|
|
} catch (e) {
|
|
_log.warning("Failed get all users", e);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
Future<List<User>> getUsersInDb({bool self = false}) async {
|
|
if (self) {
|
|
return _db.users.where().findAll();
|
|
}
|
|
final int userId = Store.get(StoreKey.currentUser).isarId;
|
|
return _db.users.where().isarIdNotEqualTo(userId).findAll();
|
|
}
|
|
|
|
Future<CreateProfileImageResponseDto?> uploadProfileImage(XFile image) async {
|
|
try {
|
|
return await _apiService.userApi.createProfileImage(
|
|
MultipartFile.fromBytes(
|
|
'file',
|
|
await image.readAsBytes(),
|
|
filename: image.name,
|
|
),
|
|
);
|
|
} catch (e) {
|
|
_log.warning("Failed to upload profile image", e);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
Future<List<User>?> getUsersFromServer() async {
|
|
final List<User>? users = await _getAllUsers();
|
|
final List<User>? sharedBy =
|
|
await _partnerService.getPartners(PartnerDirection.sharedBy);
|
|
final List<User>? sharedWith =
|
|
await _partnerService.getPartners(PartnerDirection.sharedWith);
|
|
|
|
if (users == null || sharedBy == null || sharedWith == null) {
|
|
_log.warning("Failed to refresh users");
|
|
return null;
|
|
}
|
|
|
|
users.sortBy((u) => u.id);
|
|
sharedBy.sortBy((u) => u.id);
|
|
sharedWith.sortBy((u) => u.id);
|
|
|
|
diffSortedListsSync(
|
|
users,
|
|
sharedBy,
|
|
compare: (User a, User b) => a.id.compareTo(b.id),
|
|
both: (User a, User b) => a.isPartnerSharedBy = true,
|
|
onlyFirst: (_) {},
|
|
onlySecond: (_) {},
|
|
);
|
|
|
|
diffSortedListsSync(
|
|
users,
|
|
sharedWith,
|
|
compare: (User a, User b) => a.id.compareTo(b.id),
|
|
both: (User a, User b) {
|
|
a.isPartnerSharedWith = true;
|
|
a.inTimeline = b.inTimeline;
|
|
return true;
|
|
},
|
|
onlyFirst: (_) {},
|
|
onlySecond: (_) {},
|
|
);
|
|
|
|
return users;
|
|
}
|
|
|
|
Future<bool> refreshUsers() async {
|
|
final users = await getUsersFromServer();
|
|
if (users == null) return false;
|
|
return _syncService.syncUsersFromServer(users);
|
|
}
|
|
}
|