2022-11-28 20:51:37 +02:00
|
|
|
import 'package:selfprivacy/logic/api_maps/api_generic_result.dart';
|
2022-07-12 15:54:16 +03:00
|
|
|
import 'package:selfprivacy/logic/api_maps/rest_maps/api_map.dart';
|
|
|
|
import 'package:selfprivacy/logic/models/hive/server_details.dart';
|
|
|
|
import 'package:selfprivacy/logic/models/hive/server_domain.dart';
|
|
|
|
import 'package:selfprivacy/logic/models/hive/user.dart';
|
2022-11-12 19:29:06 +02:00
|
|
|
import 'package:selfprivacy/logic/models/metrics.dart';
|
2022-07-13 14:58:23 +03:00
|
|
|
import 'package:selfprivacy/logic/models/server_basic_info.dart';
|
2022-11-11 05:32:01 +02:00
|
|
|
import 'package:selfprivacy/logic/models/server_metadata.dart';
|
2022-10-14 02:13:56 +03:00
|
|
|
import 'package:selfprivacy/logic/models/server_provider_location.dart';
|
2022-10-14 22:00:44 +03:00
|
|
|
import 'package:selfprivacy/logic/models/server_type.dart';
|
2022-07-12 15:54:16 +03:00
|
|
|
|
2022-11-28 20:51:37 +02:00
|
|
|
export 'package:selfprivacy/logic/api_maps/api_generic_result.dart';
|
|
|
|
|
2022-10-26 19:07:35 +03:00
|
|
|
class ProviderApiTokenValidation {
|
|
|
|
ProviderApiTokenValidation({
|
|
|
|
required this.length,
|
|
|
|
required this.regexp,
|
|
|
|
});
|
|
|
|
final int length;
|
|
|
|
final RegExp regexp;
|
|
|
|
}
|
|
|
|
|
2022-07-13 14:58:23 +03:00
|
|
|
abstract class ServerProviderApi extends ApiMap {
|
|
|
|
Future<List<ServerBasicInfo>> getServers();
|
2022-11-28 21:11:08 +02:00
|
|
|
Future<APIGenericResult<List<ServerProviderLocation>>>
|
|
|
|
getAvailableLocations();
|
|
|
|
Future<APIGenericResult<List<ServerType>>> getServerTypesByLocation({
|
2022-10-14 22:00:44 +03:00
|
|
|
required final ServerProviderLocation location,
|
|
|
|
});
|
2022-07-12 15:54:16 +03:00
|
|
|
|
|
|
|
Future<ServerHostingDetails> restart();
|
|
|
|
Future<ServerHostingDetails> powerOn();
|
|
|
|
|
|
|
|
Future<void> deleteServer({required final String domainName});
|
|
|
|
Future<ServerHostingDetails?> createServer({
|
|
|
|
required final String dnsApiToken,
|
|
|
|
required final User rootUser,
|
|
|
|
required final String domainName,
|
2022-10-16 04:15:48 +03:00
|
|
|
required final String serverType,
|
2022-07-12 15:54:16 +03:00
|
|
|
});
|
|
|
|
Future<void> createReverseDns({
|
|
|
|
required final ServerHostingDetails serverDetails,
|
|
|
|
required final ServerDomain domain,
|
|
|
|
});
|
|
|
|
|
2022-11-28 20:51:37 +02:00
|
|
|
Future<APIGenericResult<bool>> isApiTokenValid(final String token);
|
2022-10-26 19:07:35 +03:00
|
|
|
ProviderApiTokenValidation getApiTokenValidation();
|
2022-11-11 05:32:01 +02:00
|
|
|
Future<List<ServerMetadataEntity>> getMetadata(final int serverId);
|
2022-11-12 19:29:06 +02:00
|
|
|
Future<ServerMetrics?> getMetrics(
|
|
|
|
final int serverId,
|
|
|
|
final DateTime start,
|
|
|
|
final DateTime end,
|
|
|
|
);
|
2022-10-29 11:03:43 +03:00
|
|
|
|
2022-11-14 07:48:36 +02:00
|
|
|
/// Provider name key which lets infect understand what kind of installation
|
|
|
|
/// it requires, for example 'digitaloceal' for Digital Ocean
|
|
|
|
String get infectProviderName;
|
|
|
|
|
|
|
|
/// Actual provider name to render on information page for user,
|
|
|
|
/// for example 'Digital Ocean' for Digital Ocean
|
2022-11-23 09:55:28 +02:00
|
|
|
String get displayProviderName;
|
2022-07-12 15:54:16 +03:00
|
|
|
}
|