add profile page, privacy options
All checks were successful
Release / meta (push) Successful in 11s
Release / linux-build (push) Successful in 1m0s
Release / web-build (push) Successful in 2m29s
Release / android-build (push) Successful in 10m26s
Release / release-master (push) Successful in 37s
Release / release-dev (push) Successful in 49s
All checks were successful
Release / meta (push) Successful in 11s
Release / linux-build (push) Successful in 1m0s
Release / web-build (push) Successful in 2m29s
Release / android-build (push) Successful in 10m26s
Release / release-master (push) Successful in 37s
Release / release-dev (push) Successful in 49s
This commit is contained in:
@@ -21,6 +21,8 @@ class AuthService extends ChangeNotifier {
|
||||
String? get userId => _user?.userId;
|
||||
String? get username => _user?.username;
|
||||
String? get fullName => _user?.fullName;
|
||||
String get entriesVisibility => _user?.entriesVisibility ?? 'private';
|
||||
String get mileageVisibility => _user?.mileageVisibility ?? 'private';
|
||||
bool get isElevated => _user?.isElevated ?? false;
|
||||
bool get isAdmin => isElevated; // alias for old name
|
||||
bool get isDisabled => _user?.disabled ?? false;
|
||||
@@ -31,6 +33,8 @@ class AuthService extends ChangeNotifier {
|
||||
required String fullName,
|
||||
required String accessToken,
|
||||
required String email,
|
||||
String entriesVisibility = 'private',
|
||||
String mileageVisibility = 'private',
|
||||
bool isElevated = false,
|
||||
bool isDisabled = false,
|
||||
}) {
|
||||
@@ -40,6 +44,8 @@ class AuthService extends ChangeNotifier {
|
||||
fullName: fullName,
|
||||
accessToken: accessToken,
|
||||
email: email,
|
||||
entriesVisibility: entriesVisibility,
|
||||
mileageVisibility: mileageVisibility,
|
||||
isElevated: isElevated,
|
||||
disabled: isDisabled,
|
||||
);
|
||||
@@ -77,6 +83,14 @@ class AuthService extends ChangeNotifier {
|
||||
fullName: userResponse['full_name'],
|
||||
accessToken: accessToken,
|
||||
email: userResponse['email'],
|
||||
entriesVisibility: _parseVisibility(
|
||||
userResponse['user_entries_visibility'] ?? userResponse['entries_visibility'],
|
||||
'private',
|
||||
),
|
||||
mileageVisibility: _parseVisibility(
|
||||
userResponse['user_mileage_visibility'] ?? userResponse['mileage_visibility'],
|
||||
'private',
|
||||
),
|
||||
isElevated: _parseIsElevated(userResponse),
|
||||
isDisabled: _parseIsDisabled(userResponse),
|
||||
);
|
||||
@@ -98,16 +112,24 @@ class AuthService extends ChangeNotifier {
|
||||
},
|
||||
);
|
||||
|
||||
setLoginData(
|
||||
userId: userResponse['user_id'],
|
||||
username: userResponse['username'],
|
||||
fullName: userResponse['full_name'],
|
||||
accessToken: token,
|
||||
email: userResponse['email'],
|
||||
isElevated: _parseIsElevated(userResponse),
|
||||
isDisabled: _parseIsDisabled(userResponse),
|
||||
);
|
||||
} catch (_) {
|
||||
setLoginData(
|
||||
userId: userResponse['user_id'],
|
||||
username: userResponse['username'],
|
||||
fullName: userResponse['full_name'],
|
||||
accessToken: token,
|
||||
email: userResponse['email'],
|
||||
entriesVisibility: _parseVisibility(
|
||||
userResponse['user_entries_visibility'] ?? userResponse['entries_visibility'],
|
||||
'private',
|
||||
),
|
||||
mileageVisibility: _parseVisibility(
|
||||
userResponse['user_mileage_visibility'] ?? userResponse['mileage_visibility'],
|
||||
'private',
|
||||
),
|
||||
isElevated: _parseIsElevated(userResponse),
|
||||
isDisabled: _parseIsDisabled(userResponse),
|
||||
);
|
||||
} catch (_) {
|
||||
await _clearToken();
|
||||
} finally {
|
||||
_restoring = false;
|
||||
@@ -224,4 +246,11 @@ class AuthService extends ChangeNotifier {
|
||||
if (str == null || str.isEmpty) return false;
|
||||
return ['1', 'true', 'yes', 'y', 'disabled'].contains(str);
|
||||
}
|
||||
|
||||
String _parseVisibility(dynamic value, String fallback) {
|
||||
const allowed = ['private', 'friends', 'public'];
|
||||
final str = value?.toString().toLowerCase().trim();
|
||||
if (str != null && allowed.contains(str)) return str;
|
||||
return fallback;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user