Fix application failure on cloudflare 403 response

Check error response and show modal dialogue if domain couldn't be registered
This commit is contained in:
NaiJi 2022-05-17 01:15:16 +03:00
parent 129c1bb4c6
commit 10488d6832
6 changed files with 60 additions and 24 deletions

View file

@ -299,6 +299,7 @@
"7": "Yes", "7": "Yes",
"8": "Remove task", "8": "Remove task",
"9": "Reboot", "9": "Reboot",
"10": "You cannot use this API for domains with such TLD.",
"yes": "Yes" "yes": "Yes"
}, },
"timer": { "timer": {

View file

@ -295,6 +295,7 @@
"7": "Да, удалить", "7": "Да, удалить",
"8": "Удалить задачу", "8": "Удалить задачу",
"9": "Перезагрузить", "9": "Перезагрузить",
"10": "API не поддерживает домены с таким TLD.",
"yes": "Да" "yes": "Да"
}, },
"timer": { "timer": {

View file

@ -125,24 +125,26 @@ class CloudflareApi extends ApiMap {
var domainName = cloudFlareDomain.domainName; var domainName = cloudFlareDomain.domainName;
var domainZoneId = cloudFlareDomain.zoneId; var domainZoneId = cloudFlareDomain.zoneId;
var listDnsRecords = projectDnsRecords(domainName, ip4); var listDnsRecords = projectDnsRecords(domainName, ip4);
var url = '$rootAddress/zones/$domainZoneId/dns_records';
var allCreateFutures = <Future>[]; var allCreateFutures = <Future>[];
var client = await getClient();
var client = await getClient();
try {
for (var record in listDnsRecords) { for (var record in listDnsRecords) {
allCreateFutures.add( allCreateFutures.add(
client.post( client.post(
url, '/zones/$domainZoneId/dns_records',
data: record.toJson(), data: record.toJson(),
), ),
); );
} }
await Future.wait(allCreateFutures); await Future.wait(allCreateFutures);
} on DioError catch (e) {
print(e.message);
throw e;
} finally {
close(client); close(client);
} }
}
List<DnsRecord> projectDnsRecords(String? domainName, String? ip4) { List<DnsRecord> projectDnsRecords(String? domainName, String? ip4) {
var domainA = DnsRecord(type: 'A', name: domainName, content: ip4); var domainA = DnsRecord(type: 'A', name: domainName, content: ip4);

View file

@ -13,7 +13,6 @@ import 'package:selfprivacy/logic/models/json/recovery_token_status.dart';
import 'package:selfprivacy/logic/models/json/device_token.dart'; import 'package:selfprivacy/logic/models/json/device_token.dart';
import 'package:selfprivacy/logic/models/timezone_settings.dart'; import 'package:selfprivacy/logic/models/timezone_settings.dart';
import 'package:selfprivacy/logic/models/hive/user.dart'; import 'package:selfprivacy/logic/models/hive/user.dart';
import 'package:timezone/browser.dart';
import 'api_map.dart'; import 'api_map.dart';

View file

@ -80,10 +80,14 @@ class AppConfigCubit extends Cubit<AppConfigState> {
void createServerAndSetDnsRecords() async { void createServerAndSetDnsRecords() async {
AppConfigNotFinished _stateCopy = state as AppConfigNotFinished; AppConfigNotFinished _stateCopy = state as AppConfigNotFinished;
var onCancel =
() => emit((state as AppConfigNotFinished).copyWith(isLoading: false));
var onSuccess = (ServerHostingDetails serverDetails) async { var onSuccess = (ServerHostingDetails serverDetails) async {
await repository.createDnsRecords( await repository.createDnsRecords(
serverDetails.ip4, serverDetails.ip4,
state.serverDomain!, state.serverDomain!,
onCancel: onCancel,
); );
emit((state as AppConfigNotFinished).copyWith( emit((state as AppConfigNotFinished).copyWith(
@ -93,9 +97,6 @@ class AppConfigCubit extends Cubit<AppConfigState> {
runDelayed(startServerIfDnsIsOkay, Duration(seconds: 30), null); runDelayed(startServerIfDnsIsOkay, Duration(seconds: 30), null);
}; };
var onCancel =
() => emit((state as AppConfigNotFinished).copyWith(isLoading: false));
try { try {
emit((state as AppConfigNotFinished).copyWith(isLoading: true)); emit((state as AppConfigNotFinished).copyWith(isLoading: true));
await repository.createServer( await repository.createServer(

View file

@ -214,8 +214,9 @@ class AppConfigRepository {
Future<void> createDnsRecords( Future<void> createDnsRecords(
String ip4, String ip4,
ServerDomain cloudFlareDomain, ServerDomain cloudFlareDomain, {
) async { required void Function() onCancel,
}) async {
var cloudflareApi = CloudflareApi(); var cloudflareApi = CloudflareApi();
await cloudflareApi.removeSimilarRecords( await cloudflareApi.removeSimilarRecords(
@ -223,10 +224,41 @@ class AppConfigRepository {
cloudFlareDomain: cloudFlareDomain, cloudFlareDomain: cloudFlareDomain,
); );
try {
await cloudflareApi.createMultipleDnsRecords( await cloudflareApi.createMultipleDnsRecords(
ip4: ip4, ip4: ip4,
cloudFlareDomain: cloudFlareDomain, cloudFlareDomain: cloudFlareDomain,
); );
} on DioError catch (e) {
var hetznerApi = HetznerApi();
var nav = getIt.get<NavigationService>();
nav.showPopUpDialog(
BrandAlert(
title: e.response!.data["errors"][0]["code"] == 1038
? 'modals.10'.tr()
: 'providers.domain.states.error'.tr(),
contentText: 'modals.6'.tr(),
actions: [
ActionButton(
text: 'basis.delete'.tr(),
isRed: true,
onPressed: () async {
await hetznerApi.deleteSelfprivacyServerAndAllVolumes(
domainName: cloudFlareDomain.domainName);
onCancel();
},
),
ActionButton(
text: 'basis.cancel'.tr(),
onPressed: () {
onCancel();
},
),
],
),
);
}
await HetznerApi().createReverseDns( await HetznerApi().createReverseDns(
ip4: ip4, ip4: ip4,