2023-05-25 05:52:43 +02:00
|
|
|
import 'package:collection/collection.dart';
|
2022-06-25 20:46:51 +02:00
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2022-07-13 14:23:48 +02:00
|
|
|
import 'package:http/http.dart';
|
2022-05-29 05:35:45 +02:00
|
|
|
import 'package:image_picker/image_picker.dart';
|
2023-05-25 05:52:43 +02:00
|
|
|
import 'package:immich_mobile/modules/partner/services/partner.service.dart';
|
2023-03-03 23:38:30 +01:00
|
|
|
import 'package:immich_mobile/shared/models/store.dart';
|
2023-02-06 08:13:32 +01:00
|
|
|
import 'package:immich_mobile/shared/models/user.dart';
|
2022-08-03 07:04:34 +02:00
|
|
|
import 'package:immich_mobile/shared/providers/api.provider.dart';
|
2023-03-03 23:38:30 +01:00
|
|
|
import 'package:immich_mobile/shared/providers/db.provider.dart';
|
2022-07-13 14:23:48 +02:00
|
|
|
import 'package:immich_mobile/shared/services/api.service.dart';
|
2023-03-03 23:38:30 +01:00
|
|
|
import 'package:immich_mobile/shared/services/sync.service.dart';
|
2023-05-25 05:52:43 +02:00
|
|
|
import 'package:immich_mobile/utils/diff.dart';
|
2023-03-03 23:38:30 +01:00
|
|
|
import 'package:isar/isar.dart';
|
2023-05-25 05:52:43 +02:00
|
|
|
import 'package:logging/logging.dart';
|
2022-07-13 14:23:48 +02:00
|
|
|
import 'package:openapi/api.dart';
|
2022-04-24 04:08:45 +02:00
|
|
|
|
2022-07-13 14:23:48 +02:00
|
|
|
final userServiceProvider = Provider(
|
|
|
|
(ref) => UserService(
|
|
|
|
ref.watch(apiServiceProvider),
|
2023-03-03 23:38:30 +01:00
|
|
|
ref.watch(dbProvider),
|
|
|
|
ref.watch(syncServiceProvider),
|
2023-05-25 05:52:43 +02:00
|
|
|
ref.watch(partnerServiceProvider),
|
2022-07-13 14:23:48 +02:00
|
|
|
),
|
|
|
|
);
|
2022-06-25 20:46:51 +02:00
|
|
|
|
2022-04-24 04:08:45 +02:00
|
|
|
class UserService {
|
2022-07-13 14:23:48 +02:00
|
|
|
final ApiService _apiService;
|
2023-03-03 23:38:30 +01:00
|
|
|
final Isar _db;
|
|
|
|
final SyncService _syncService;
|
2023-05-25 05:52:43 +02:00
|
|
|
final PartnerService _partnerService;
|
|
|
|
final Logger _log = Logger("UserService");
|
2022-04-24 04:08:45 +02:00
|
|
|
|
2023-05-25 05:52:43 +02:00
|
|
|
UserService(
|
|
|
|
this._apiService,
|
|
|
|
this._db,
|
|
|
|
this._syncService,
|
|
|
|
this._partnerService,
|
|
|
|
);
|
2022-04-24 04:08:45 +02:00
|
|
|
|
2023-03-03 23:38:30 +01:00
|
|
|
Future<List<User>?> _getAllUsers({required bool isAll}) async {
|
2022-07-13 14:23:48 +02:00
|
|
|
try {
|
2023-02-06 08:13:32 +01:00
|
|
|
final dto = await _apiService.userApi.getAllUsers(isAll);
|
2023-11-11 22:06:19 +01:00
|
|
|
return dto?.map(User.fromUserDto).toList();
|
2022-04-24 04:08:45 +02:00
|
|
|
} catch (e) {
|
2023-05-25 05:52:43 +02:00
|
|
|
_log.warning("Failed get all users:\n$e");
|
2022-07-13 14:23:48 +02:00
|
|
|
return null;
|
2022-04-24 04:08:45 +02:00
|
|
|
}
|
|
|
|
}
|
2022-05-29 05:35:45 +02:00
|
|
|
|
2023-03-03 23:38:30 +01:00
|
|
|
Future<List<User>> getUsersInDb({bool self = false}) async {
|
|
|
|
if (self) {
|
|
|
|
return _db.users.where().findAll();
|
|
|
|
}
|
2023-03-23 02:36:44 +01:00
|
|
|
final int userId = Store.get(StoreKey.currentUser).isarId;
|
2023-03-03 23:38:30 +01:00
|
|
|
return _db.users.where().isarIdNotEqualTo(userId).findAll();
|
|
|
|
}
|
|
|
|
|
2022-07-13 14:23:48 +02:00
|
|
|
Future<CreateProfileImageResponseDto?> uploadProfileImage(XFile image) async {
|
2022-05-29 05:35:45 +02:00
|
|
|
try {
|
2022-07-13 14:23:48 +02:00
|
|
|
return await _apiService.userApi.createProfileImage(
|
|
|
|
MultipartFile.fromBytes(
|
|
|
|
'file',
|
|
|
|
await image.readAsBytes(),
|
|
|
|
filename: image.name,
|
|
|
|
),
|
2022-05-29 05:35:45 +02:00
|
|
|
);
|
|
|
|
} catch (e) {
|
2023-05-25 05:52:43 +02:00
|
|
|
_log.warning("Failed to upload profile image:\n$e");
|
2022-05-29 05:35:45 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2023-03-03 23:38:30 +01:00
|
|
|
|
|
|
|
Future<bool> refreshUsers() async {
|
|
|
|
final List<User>? users = await _getAllUsers(isAll: true);
|
2023-05-25 05:52:43 +02:00
|
|
|
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");
|
2023-03-03 23:38:30 +01:00
|
|
|
return false;
|
|
|
|
}
|
2023-05-25 05:52:43 +02:00
|
|
|
|
|
|
|
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),
|
2023-11-13 16:54:41 +01:00
|
|
|
both: (User a, User b) {
|
|
|
|
a.isPartnerSharedWith = true;
|
|
|
|
a.inTimeline = b.inTimeline;
|
|
|
|
return true;
|
|
|
|
},
|
2023-05-25 05:52:43 +02:00
|
|
|
onlyFirst: (_) {},
|
|
|
|
onlySecond: (_) {},
|
|
|
|
);
|
|
|
|
|
2023-03-03 23:38:30 +01:00
|
|
|
return _syncService.syncUsersFromServer(users);
|
|
|
|
}
|
2022-04-24 04:08:45 +02:00
|
|
|
}
|