From 49fe40bb38637c4c6e6c19ee94ffcc8d2bf9b481 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Wed, 7 Jun 2023 00:09:39 -0300 Subject: [PATCH] chore: Implement better Price abstraction for Hetzner server provider --- .../server_providers/hetzner/hetzner_api.dart | 20 +++++----- .../providers/server_providers/hetzner.dart | 37 +++++++++++++++++-- .../server_providers/server_provider.dart | 2 +- 3 files changed, 44 insertions(+), 15 deletions(-) diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index 6cddfa22..9b8fd30b 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -7,9 +7,7 @@ import 'package:selfprivacy/logic/api_maps/rest_maps/server_providers/server_pro import 'package:selfprivacy/logic/api_maps/staging_options.dart'; import 'package:selfprivacy/logic/models/disk_size.dart'; import 'package:selfprivacy/logic/models/json/hetzner_server_info.dart'; -import 'package:selfprivacy/logic/models/hive/server_details.dart'; import 'package:selfprivacy/logic/models/hive/user.dart'; -import 'package:selfprivacy/logic/models/price.dart'; import 'package:selfprivacy/utils/password_generator.dart'; class HetznerApi extends ServerProviderApi with VolumeProviderApi { @@ -106,7 +104,7 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi { length: 64, ); - Future getPricePerGb() async { + Future> getPricePerGb() async { double? price; final Response pricingResponse; @@ -119,16 +117,16 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi { price = double.parse(volumePrice); } catch (e) { print(e); + return GenericResult( + success: false, + data: price, + message: e.toString(), + ); } finally { client.close(); } - return price == null - ? null - : Price( - value: price, - currency: 'EUR', - ); + return GenericResult(success: true, data: price); } Future> createVolume() async { @@ -252,7 +250,7 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi { } Future> attachVolume( - final ServerVolume volume, + final HetznerVolume volume, final int serverId, ) async { bool success = false; @@ -312,7 +310,7 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi { } Future> resizeVolume( - final ServerVolume volume, + final HetznerVolume volume, final DiskSize size, ) async { bool success = false; diff --git a/lib/logic/providers/server_providers/hetzner.dart b/lib/logic/providers/server_providers/hetzner.dart index ceec065f..b9a3bbc8 100644 --- a/lib/logic/providers/server_providers/hetzner.dart +++ b/lib/logic/providers/server_providers/hetzner.dart @@ -756,7 +756,13 @@ class HetznerServerProvider extends ServerProvider { final int serverId, ) async => _adapter.api().attachVolume( - volume, + HetznerVolume( + volume.id, + volume.sizeByte, + volume.serverId, + volume.name, + volume.linuxDevice, + ), serverId, ); @@ -774,10 +780,35 @@ class HetznerServerProvider extends ServerProvider { final DiskSize size, ) async => _adapter.api().resizeVolume( - volume, + HetznerVolume( + volume.id, + volume.sizeByte, + volume.serverId, + volume.name, + volume.linuxDevice, + ), size, ); @override - Future getPricePerGb() async => _adapter.api().getPricePerGb(); + Future> getPricePerGb() async { + final result = await _adapter.api().getPricePerGb(); + + if (!result.success || result.data == null) { + return GenericResult( + data: null, + success: false, + message: result.message, + code: result.code, + ); + } + + return GenericResult( + success: true, + data: Price( + value: result.data!, + currency: 'EUR', + ), + ); + } } diff --git a/lib/logic/providers/server_providers/server_provider.dart b/lib/logic/providers/server_providers/server_provider.dart index f1004192..b48662bf 100644 --- a/lib/logic/providers/server_providers/server_provider.dart +++ b/lib/logic/providers/server_providers/server_provider.dart @@ -37,7 +37,7 @@ abstract class ServerProvider { final DateTime end, ); - Future getPricePerGb(); + Future> getPricePerGb(); Future>> getVolumes({final String? status}); Future> createVolume(); Future> deleteVolume(final ServerVolume volume);