refactor: Refactor ServerDetailsCubit to use ApiConnectionRepository

This commit is contained in:
Inex Code 2024-02-20 20:09:14 +03:00
parent 9459191c09
commit 92cf2cde6d
5 changed files with 130 additions and 86 deletions

View file

@ -1,34 +1,75 @@
import 'dart:async';
import 'package:selfprivacy/config/get_it_config.dart'; import 'package:selfprivacy/config/get_it_config.dart';
import 'package:selfprivacy/logic/cubit/server_connection_dependent/server_connection_dependent_cubit.dart'; import 'package:selfprivacy/logic/cubit/server_connection_dependent/server_connection_dependent_cubit.dart';
import 'package:selfprivacy/logic/cubit/server_detailed_info/server_detailed_info_repository.dart';
import 'package:selfprivacy/logic/models/auto_upgrade_settings.dart'; import 'package:selfprivacy/logic/models/auto_upgrade_settings.dart';
import 'package:selfprivacy/logic/models/server_metadata.dart'; import 'package:selfprivacy/logic/models/server_metadata.dart';
import 'package:selfprivacy/logic/models/system_settings.dart';
import 'package:selfprivacy/logic/models/timezone_settings.dart'; import 'package:selfprivacy/logic/models/timezone_settings.dart';
import 'package:selfprivacy/logic/providers/providers_controller.dart';
part 'server_detailed_info_state.dart'; part 'server_detailed_info_state.dart';
class ServerDetailsCubit class ServerDetailsCubit
extends ServerConnectionDependentCubit<ServerDetailsState> { extends ServerConnectionDependentCubit<ServerDetailsState> {
ServerDetailsCubit() : super(ServerDetailsInitial()); ServerDetailsCubit() : super(const ServerDetailsInitial()) {
final apiConnectionRepository = getIt<ApiConnectionRepository>();
_apiDataSubscription = apiConnectionRepository.dataStream.listen(
(final ApiData apiData) {
if (apiData.settings.data != null) {
_handleServerSettings(apiData.settings.data!);
}
},
);
}
ServerDetailsRepository repository = ServerDetailsRepository(); StreamSubscription? _apiDataSubscription;
void _handleServerSettings(final SystemSettings settings) {
emit(
Loaded(
metadata: state.metadata,
serverTimezone: TimeZoneSettings.fromString(settings.timezone),
autoUpgradeSettings: settings.autoUpgradeSettings,
),
);
}
Future<List<ServerMetadataEntity>> get _metadata async {
List<ServerMetadataEntity> data = [];
final serverProviderApi = ProvidersController.currentServerProvider;
final dnsProviderApi = ProvidersController.currentDnsProvider;
if (serverProviderApi != null && dnsProviderApi != null) {
final serverId = getIt<ApiConfigModel>().serverDetails?.id ?? 0;
final metadataResult = await serverProviderApi.getMetadata(serverId);
metadataResult.data.add(
ServerMetadataEntity(
trId: 'server.dns_provider',
value: dnsProviderApi.type.displayName,
type: MetadataType.other,
),
);
data = metadataResult.data;
}
return data;
}
void check() async { void check() async {
final bool isReadyToCheck = getIt<ApiConfigModel>().serverDetails != null; final bool isReadyToCheck = getIt<ApiConfigModel>().serverDetails != null;
try { try {
if (isReadyToCheck) { if (isReadyToCheck) {
emit(ServerDetailsLoading()); emit(const ServerDetailsLoading());
final ServerDetailsRepositoryDto data = await repository.load(); final List<ServerMetadataEntity> metadata = await _metadata;
emit( emit(
Loaded( state.copyWith(
metadata: data.metadata, metadata: metadata,
autoUpgradeSettings: data.autoUpgradeSettings,
serverTimezone: data.serverTimezone,
checkTime: DateTime.now(),
), ),
); );
} else { } else {
emit(ServerDetailsNotReady()); emit(const ServerDetailsNotReady());
} }
} on StateError { } on StateError {
print('Tried to emit server info state when cubit is closed'); print('Tried to emit server info state when cubit is closed');
@ -37,11 +78,17 @@ class ServerDetailsCubit
@override @override
void clear() { void clear() {
emit(ServerDetailsNotReady()); emit(const ServerDetailsNotReady());
} }
@override @override
void load() async { void load() async {
check(); check();
} }
@override
Future<void> close() {
_apiDataSubscription?.cancel();
return super.close();
}
} }

View file

@ -1,54 +0,0 @@
import 'package:selfprivacy/config/get_it_config.dart';
import 'package:selfprivacy/logic/api_maps/graphql_maps/server_api/server_api.dart';
import 'package:selfprivacy/logic/models/auto_upgrade_settings.dart';
import 'package:selfprivacy/logic/models/server_metadata.dart';
import 'package:selfprivacy/logic/models/timezone_settings.dart';
import 'package:selfprivacy/logic/providers/providers_controller.dart';
class ServerDetailsRepository {
ServerApi server = ServerApi();
Future<ServerDetailsRepositoryDto> load() async {
final settings = await server.getSystemSettings();
return ServerDetailsRepositoryDto(
autoUpgradeSettings: settings.autoUpgradeSettings,
metadata: await metadata,
serverTimezone: TimeZoneSettings.fromString(
settings.timezone,
),
);
}
Future<List<ServerMetadataEntity>> get metadata async {
List<ServerMetadataEntity> data = [];
final serverProviderApi = ProvidersController.currentServerProvider;
final dnsProviderApi = ProvidersController.currentDnsProvider;
if (serverProviderApi != null && dnsProviderApi != null) {
final serverId = getIt<ApiConfigModel>().serverDetails?.id ?? 0;
final metadataResult = await serverProviderApi.getMetadata(serverId);
metadataResult.data.add(
ServerMetadataEntity(
trId: 'server.dns_provider',
value: dnsProviderApi.type.displayName,
type: MetadataType.other,
),
);
data = metadataResult.data;
}
return data;
}
}
class ServerDetailsRepositoryDto {
ServerDetailsRepositoryDto({
required this.metadata,
required this.serverTimezone,
required this.autoUpgradeSettings,
});
final List<ServerMetadataEntity> metadata;
final TimeZoneSettings serverTimezone;
final AutoUpgradeSettings autoUpgradeSettings;
}

View file

@ -1,37 +1,78 @@
part of 'server_detailed_info_cubit.dart'; part of 'server_detailed_info_cubit.dart';
abstract class ServerDetailsState extends ServerInstallationDependendState { abstract class ServerDetailsState extends ServerInstallationDependendState {
const ServerDetailsState(); const ServerDetailsState({
required this.metadata,
});
final List<ServerMetadataEntity> metadata;
@override @override
List<Object> get props => []; List<Object> get props => [metadata];
ServerDetailsState copyWith({
final List<ServerMetadataEntity>? metadata,
});
} }
class ServerDetailsInitial extends ServerDetailsState {} class ServerDetailsInitial extends ServerDetailsState {
const ServerDetailsInitial({super.metadata = const []});
class ServerDetailsLoading extends ServerDetailsState {} @override
ServerDetailsInitial copyWith({final List<ServerMetadataEntity>? metadata}) =>
ServerDetailsInitial(
metadata: metadata ?? this.metadata,
);
}
class ServerDetailsNotReady extends ServerDetailsState {} class ServerDetailsLoading extends ServerDetailsState {
const ServerDetailsLoading({super.metadata = const []});
class Loading extends ServerDetailsState {} @override
ServerDetailsLoading copyWith({final List<ServerMetadataEntity>? metadata}) =>
ServerDetailsLoading(
metadata: metadata ?? this.metadata,
);
}
class ServerDetailsNotReady extends ServerDetailsState {
const ServerDetailsNotReady({super.metadata = const []});
@override
ServerDetailsNotReady copyWith({
final List<ServerMetadataEntity>? metadata,
}) =>
ServerDetailsNotReady(
metadata: metadata ?? this.metadata,
);
}
class Loaded extends ServerDetailsState { class Loaded extends ServerDetailsState {
const Loaded({ const Loaded({
required this.metadata, required super.metadata,
required this.serverTimezone, required this.serverTimezone,
required this.autoUpgradeSettings, required this.autoUpgradeSettings,
required this.checkTime,
}); });
final List<ServerMetadataEntity> metadata;
final TimeZoneSettings serverTimezone; final TimeZoneSettings serverTimezone;
final AutoUpgradeSettings autoUpgradeSettings; final AutoUpgradeSettings autoUpgradeSettings;
final DateTime checkTime;
@override @override
List<Object> get props => [ List<Object> get props => [
metadata, metadata,
serverTimezone, serverTimezone,
autoUpgradeSettings, autoUpgradeSettings,
checkTime,
]; ];
@override
Loaded copyWith({
final List<ServerMetadataEntity>? metadata,
final TimeZoneSettings? serverTimezone,
final AutoUpgradeSettings? autoUpgradeSettings,
final DateTime? checkTime,
}) =>
Loaded(
metadata: metadata ?? this.metadata,
serverTimezone: serverTimezone ?? this.serverTimezone,
autoUpgradeSettings: autoUpgradeSettings ?? this.autoUpgradeSettings,
);
} }

View file

@ -15,6 +15,7 @@ import 'package:selfprivacy/logic/models/json/recovery_token_status.dart';
import 'package:selfprivacy/logic/models/json/server_disk_volume.dart'; import 'package:selfprivacy/logic/models/json/server_disk_volume.dart';
import 'package:selfprivacy/logic/models/json/server_job.dart'; import 'package:selfprivacy/logic/models/json/server_job.dart';
import 'package:selfprivacy/logic/models/service.dart'; import 'package:selfprivacy/logic/models/service.dart';
import 'package:selfprivacy/logic/models/system_settings.dart';
/// Repository for all API calls /// Repository for all API calls
/// Stores the current state of all data from API and exposes it to Blocs. /// Stores the current state of all data from API and exposes it to Blocs.
@ -226,6 +227,7 @@ class ApiConnectionRepository {
await _apiData.recoveryKeyStatus.fetchData(); await _apiData.recoveryKeyStatus.fetchData();
_apiData.devices.data = await _apiData.devices.fetchData(); _apiData.devices.data = await _apiData.devices.fetchData();
_apiData.users.data = await _apiData.users.fetchData(); _apiData.users.data = await _apiData.users.fetchData();
_apiData.settings.data = await _apiData.settings.fetchData();
_dataStream.add(_apiData); _dataStream.add(_apiData);
connectionStatus = ConnectionStatus.connected; connectionStatus = ConnectionStatus.connected;
@ -270,6 +272,8 @@ class ApiConnectionRepository {
await _apiData.devices await _apiData.devices
.refetchData(version, () => _dataStream.add(_apiData)); .refetchData(version, () => _dataStream.add(_apiData));
await _apiData.users.refetchData(version, () => _dataStream.add(_apiData)); await _apiData.users.refetchData(version, () => _dataStream.add(_apiData));
await _apiData.settings
.refetchData(version, () => _dataStream.add(_apiData));
} }
void emitData() { void emitData() {
@ -312,6 +316,10 @@ class ApiData {
), ),
users = ApiDataElement<List<User>>( users = ApiDataElement<List<User>>(
fetchData: () async => api.getAllUsers(), fetchData: () async => api.getAllUsers(),
),
settings = ApiDataElement<SystemSettings>(
fetchData: () async => api.getSystemSettings(),
ttl: 600,
); );
ApiDataElement<List<ServerJob>> serverJobs; ApiDataElement<List<ServerJob>> serverJobs;
@ -323,6 +331,7 @@ class ApiData {
ApiDataElement<RecoveryKeyStatus> recoveryKeyStatus; ApiDataElement<RecoveryKeyStatus> recoveryKeyStatus;
ApiDataElement<List<ApiToken>> devices; ApiDataElement<List<ApiToken>> devices;
ApiDataElement<List<User>> users; ApiDataElement<List<User>> users;
ApiDataElement<SystemSettings> settings;
} }
enum ConnectionStatus { enum ConnectionStatus {

View file

@ -49,8 +49,7 @@ class RebuildServerJob extends ClientJob {
!jobs.any((final job) => job is RebuildServerJob); !jobs.any((final job) => job is RebuildServerJob);
@override @override
Future<(bool, String)> execute() async => Future<(bool, String)> execute() async => (false, 'unimplemented');
(false, 'unimplemented');
@override @override
RebuildServerJob copyWithNewStatus({ RebuildServerJob copyWithNewStatus({
@ -73,8 +72,7 @@ class UpgradeServerJob extends ClientJob {
!jobs.any((final job) => job is UpgradeServerJob); !jobs.any((final job) => job is UpgradeServerJob);
@override @override
Future<(bool, String)> execute() async => Future<(bool, String)> execute() async => (false, 'unimplemented');
(false, 'unimplemented');
@override @override
UpgradeServerJob copyWithNewStatus({ UpgradeServerJob copyWithNewStatus({
@ -100,8 +98,7 @@ class RebootServerJob extends ClientJob {
!jobs.any((final job) => job is RebootServerJob); !jobs.any((final job) => job is RebootServerJob);
@override @override
Future<(bool, String)> execute() async => Future<(bool, String)> execute() async => (false, 'unimplemented');
(false, 'unimplemented');
@override @override
RebootServerJob copyWithNewStatus({ RebootServerJob copyWithNewStatus({
@ -232,7 +229,9 @@ class ServiceToggleJob extends ClientJob {
@override @override
Future<(bool, String)> execute() async { Future<(bool, String)> execute() async {
await getIt<ApiConnectionRepository>().api.switchService(service.id, needToTurnOn); await getIt<ApiConnectionRepository>()
.api
.switchService(service.id, needToTurnOn);
return (true, 'Check not implemented'); return (true, 'Check not implemented');
} }
@ -353,8 +352,9 @@ class ChangeAutoUpgradeSettingsJob extends ReplaceableJob {
@override @override
Future<(bool, String)> execute() async { Future<(bool, String)> execute() async {
await getIt<ApiConnectionRepository>().api.setAutoUpgradeSettings( await getIt<ApiConnectionRepository>().api.setAutoUpgradeSettings(
AutoUpgradeSettings(enable: enable, allowReboot: allowReboot), AutoUpgradeSettings(enable: enable, allowReboot: allowReboot),
); );
getIt<ApiConnectionRepository>().apiData.settings.invalidate();
return (true, 'Check not implemented'); return (true, 'Check not implemented');
} }
@ -394,6 +394,7 @@ class ChangeServerTimezoneJob extends ReplaceableJob {
@override @override
Future<(bool, String)> execute() async { Future<(bool, String)> execute() async {
await getIt<ApiConnectionRepository>().api.setTimezone(timezone); await getIt<ApiConnectionRepository>().api.setTimezone(timezone);
getIt<ApiConnectionRepository>().apiData.settings.invalidate();
return (true, 'Check not implemented'); return (true, 'Check not implemented');
} }