mirror of
https://github.com/immich-app/immich.git
synced 2025-06-03 21:54:21 -04:00
* Deprecate login scenarios that support pre-web era * refactor and simplify setup * Added user info to change password form * change isFistLogin column to shouldChangePassword * Implemented change user password * Implement the change password page for mobile * Change label * Added changes log and up minor version * Fixed typo in the release note * Up server version
111 lines
3.3 KiB
Dart
111 lines
3.3 KiB
Dart
import 'dart:convert';
|
|
|
|
class LogInReponse {
|
|
final String accessToken;
|
|
final String userId;
|
|
final String userEmail;
|
|
final String firstName;
|
|
final String lastName;
|
|
final String profileImagePath;
|
|
final bool isAdmin;
|
|
final bool shouldChangePassword;
|
|
|
|
LogInReponse({
|
|
required this.accessToken,
|
|
required this.userId,
|
|
required this.userEmail,
|
|
required this.firstName,
|
|
required this.lastName,
|
|
required this.profileImagePath,
|
|
required this.isAdmin,
|
|
required this.shouldChangePassword,
|
|
});
|
|
|
|
LogInReponse copyWith({
|
|
String? accessToken,
|
|
String? userId,
|
|
String? userEmail,
|
|
String? firstName,
|
|
String? lastName,
|
|
String? profileImagePath,
|
|
bool? isAdmin,
|
|
bool? shouldChangePassword,
|
|
}) {
|
|
return LogInReponse(
|
|
accessToken: accessToken ?? this.accessToken,
|
|
userId: userId ?? this.userId,
|
|
userEmail: userEmail ?? this.userEmail,
|
|
firstName: firstName ?? this.firstName,
|
|
lastName: lastName ?? this.lastName,
|
|
profileImagePath: profileImagePath ?? this.profileImagePath,
|
|
isAdmin: isAdmin ?? this.isAdmin,
|
|
shouldChangePassword: shouldChangePassword ?? this.shouldChangePassword,
|
|
);
|
|
}
|
|
|
|
Map<String, dynamic> toMap() {
|
|
final result = <String, dynamic>{};
|
|
|
|
result.addAll({'accessToken': accessToken});
|
|
result.addAll({'userId': userId});
|
|
result.addAll({'userEmail': userEmail});
|
|
result.addAll({'firstName': firstName});
|
|
result.addAll({'lastName': lastName});
|
|
result.addAll({'profileImagePath': profileImagePath});
|
|
result.addAll({'isAdmin': isAdmin});
|
|
result.addAll({'shouldChangePassword': shouldChangePassword});
|
|
|
|
return result;
|
|
}
|
|
|
|
factory LogInReponse.fromMap(Map<String, dynamic> map) {
|
|
return LogInReponse(
|
|
accessToken: map['accessToken'] ?? '',
|
|
userId: map['userId'] ?? '',
|
|
userEmail: map['userEmail'] ?? '',
|
|
firstName: map['firstName'] ?? '',
|
|
lastName: map['lastName'] ?? '',
|
|
profileImagePath: map['profileImagePath'] ?? '',
|
|
isAdmin: map['isAdmin'] ?? false,
|
|
shouldChangePassword: map['shouldChangePassword'] ?? false,
|
|
);
|
|
}
|
|
|
|
String toJson() => json.encode(toMap());
|
|
|
|
factory LogInReponse.fromJson(String source) =>
|
|
LogInReponse.fromMap(json.decode(source));
|
|
|
|
@override
|
|
String toString() {
|
|
return 'LogInReponse(accessToken: $accessToken, userId: $userId, userEmail: $userEmail, firstName: $firstName, lastName: $lastName, profileImagePath: $profileImagePath, isAdmin: $isAdmin, shouldChangePassword: $shouldChangePassword)';
|
|
}
|
|
|
|
@override
|
|
bool operator ==(Object other) {
|
|
if (identical(this, other)) return true;
|
|
|
|
return other is LogInReponse &&
|
|
other.accessToken == accessToken &&
|
|
other.userId == userId &&
|
|
other.userEmail == userEmail &&
|
|
other.firstName == firstName &&
|
|
other.lastName == lastName &&
|
|
other.profileImagePath == profileImagePath &&
|
|
other.isAdmin == isAdmin &&
|
|
other.shouldChangePassword == shouldChangePassword;
|
|
}
|
|
|
|
@override
|
|
int get hashCode {
|
|
return accessToken.hashCode ^
|
|
userId.hashCode ^
|
|
userEmail.hashCode ^
|
|
firstName.hashCode ^
|
|
lastName.hashCode ^
|
|
profileImagePath.hashCode ^
|
|
isAdmin.hashCode ^
|
|
shouldChangePassword.hashCode;
|
|
}
|
|
}
|