2022-11-28 18:51:37 +00:00
|
|
|
import 'package:selfprivacy/logic/api_maps/api_generic_result.dart';
|
2022-07-12 12:54:16 +00: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 17:29:06 +00:00
|
|
|
import 'package:selfprivacy/logic/models/metrics.dart';
|
2022-07-13 11:58:23 +00:00
|
|
|
import 'package:selfprivacy/logic/models/server_basic_info.dart';
|
2022-11-11 03:32:01 +00:00
|
|
|
import 'package:selfprivacy/logic/models/server_metadata.dart';
|
2022-10-13 23:13:56 +00:00
|
|
|
import 'package:selfprivacy/logic/models/server_provider_location.dart';
|
2022-10-14 19:00:44 +00:00
|
|
|
import 'package:selfprivacy/logic/models/server_type.dart';
|
2022-07-12 12:54:16 +00:00
|
|
|
|
2022-11-28 18:51:37 +00:00
|
|
|
export 'package:selfprivacy/logic/api_maps/api_generic_result.dart';
|
|
|
|
|
2022-10-26 16:07:35 +00:00
|
|
|
class ProviderApiTokenValidation {
|
|
|
|
ProviderApiTokenValidation({
|
|
|
|
required this.length,
|
|
|
|
required this.regexp,
|
|
|
|
});
|
|
|
|
final int length;
|
|
|
|
final RegExp regexp;
|
|
|
|
}
|
|
|
|
|
2022-07-13 11:58:23 +00:00
|
|
|
abstract class ServerProviderApi extends ApiMap {
|
|
|
|
Future<List<ServerBasicInfo>> getServers();
|
2022-11-28 19:11:08 +00:00
|
|
|
Future<APIGenericResult<List<ServerProviderLocation>>>
|
|
|
|
getAvailableLocations();
|
|
|
|
Future<APIGenericResult<List<ServerType>>> getServerTypesByLocation({
|
2022-10-14 19:00:44 +00:00
|
|
|
required final ServerProviderLocation location,
|
|
|
|
});
|
2022-07-12 12:54:16 +00: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 01:15:48 +00:00
|
|
|
required final String serverType,
|
2022-07-12 12:54:16 +00:00
|
|
|
});
|
|
|
|
Future<void> createReverseDns({
|
|
|
|
required final ServerHostingDetails serverDetails,
|
|
|
|
required final ServerDomain domain,
|
|
|
|
});
|
|
|
|
|
2022-11-28 18:51:37 +00:00
|
|
|
Future<APIGenericResult<bool>> isApiTokenValid(final String token);
|
2022-10-26 16:07:35 +00:00
|
|
|
ProviderApiTokenValidation getApiTokenValidation();
|
2022-11-11 03:32:01 +00:00
|
|
|
Future<List<ServerMetadataEntity>> getMetadata(final int serverId);
|
2022-11-12 17:29:06 +00:00
|
|
|
Future<ServerMetrics?> getMetrics(
|
|
|
|
final int serverId,
|
|
|
|
final DateTime start,
|
|
|
|
final DateTime end,
|
|
|
|
);
|
2022-10-29 08:03:43 +00:00
|
|
|
|
2022-11-14 05:48:36 +00: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 07:55:28 +00:00
|
|
|
String get displayProviderName;
|
2022-07-12 12:54:16 +00:00
|
|
|
}
|