Merge pull request 'json-force' (#212) from json-force into master

Reviewed-on: https://git.selfprivacy.org/kherel/selfprivacy.org.app/pulls/212
Reviewed-by: Inex Code <inex.code@selfprivacy.org>
This commit is contained in:
Inex Code 2023-06-07 15:14:33 +03:00
commit 4a7f986ff4
8 changed files with 47 additions and 61 deletions

View file

@ -30,7 +30,11 @@ class BackblazeApi extends ApiMap {
@override
BaseOptions get options {
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
final BaseOptions options = BaseOptions(
baseUrl: rootAddress,
contentType: Headers.jsonContentType,
responseType: ResponseType.json,
);
if (isWithToken) {
final BackblazeCredential? backblazeCredential =
getIt<ApiConfigModel>().backblazeCredential;

View file

@ -26,7 +26,11 @@ class CloudflareApi extends DnsProviderApi {
@override
BaseOptions get options {
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
final BaseOptions options = BaseOptions(
baseUrl: rootAddress,
contentType: Headers.jsonContentType,
responseType: ResponseType.json,
);
if (isWithToken) {
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
assert(token != null);

View file

@ -26,7 +26,11 @@ class DesecApi extends DnsProviderApi {
@override
BaseOptions get options {
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
final BaseOptions options = BaseOptions(
baseUrl: rootAddress,
contentType: Headers.jsonContentType,
responseType: ResponseType.json,
);
if (isWithToken) {
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
assert(token != null);

View file

@ -36,7 +36,11 @@ class DigitalOceanApi extends ServerProviderApi with VolumeProviderApi {
@override
BaseOptions get options {
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
final BaseOptions options = BaseOptions(
baseUrl: rootAddress,
contentType: Headers.jsonContentType,
responseType: ResponseType.json,
);
if (isWithToken) {
final String? token = getIt<ApiConfigModel>().serverProviderKey;
assert(token != null);

View file

@ -37,7 +37,11 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi {
@override
BaseOptions get options {
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
final BaseOptions options = BaseOptions(
baseUrl: rootAddress,
contentType: Headers.jsonContentType,
responseType: ResponseType.json,
);
if (isWithToken) {
final String? token = getIt<ApiConfigModel>().serverProviderKey;
assert(token != null);

View file

@ -1,6 +1,5 @@
import 'dart:io';
import 'package:basic_utils/basic_utils.dart';
import 'package:device_info_plus/device_info_plus.dart';
import 'package:dio/dio.dart';
import 'package:easy_localization/easy_localization.dart';
@ -23,7 +22,6 @@ import 'package:selfprivacy/logic/models/hive/server_domain.dart';
import 'package:selfprivacy/logic/models/hive/user.dart';
import 'package:selfprivacy/logic/models/json/device_token.dart';
import 'package:selfprivacy/logic/models/json/dns_records.dart';
import 'package:selfprivacy/logic/models/message.dart';
import 'package:selfprivacy/logic/models/server_basic_info.dart';
import 'package:selfprivacy/logic/models/server_type.dart';
import 'package:selfprivacy/ui/helpers/modals.dart';
@ -208,46 +206,20 @@ class ServerInstallationRepository {
final String? ip4,
final Map<String, bool> skippedMatches,
) async {
final List<String> addresses = <String>[
'$domainName',
'api.$domainName',
'cloud.$domainName',
'meet.$domainName',
'password.$domainName'
];
final Map<String, bool> matches = <String, bool>{};
for (final String address in addresses) {
if (skippedMatches[address] ?? false) {
matches[address] = true;
continue;
}
final List<RRecord>? lookupRecordRes = await DnsUtils.lookupRecord(
address,
RRecordType.A,
provider: DnsApiProvider.CLOUDFLARE,
);
getIt.get<ConsoleModel>().addMessage(
Message(
text:
'DnsLookup: address: $address, $RRecordType, provider: CLOUDFLARE, ip4: $ip4',
),
);
getIt.get<ConsoleModel>().addMessage(
Message(
text:
'DnsLookup: ${lookupRecordRes == null ? 'empty' : (lookupRecordRes[0].data != ip4 ? 'wrong ip4' : 'right ip4')}',
),
);
if (lookupRecordRes == null ||
lookupRecordRes.isEmpty ||
lookupRecordRes[0].data != ip4) {
matches[address] = false;
} else {
matches[address] = true;
}
}
await InternetAddress.lookup(domainName!).then(
(final records) {
for (final record in records) {
if (skippedMatches[record.host] ?? false) {
matches[record.host] = true;
continue;
}
if (record.address == ip4!) {
matches[record.host] = true;
}
}
},
);
return matches;
}
@ -478,15 +450,18 @@ class ServerInstallationRepository {
}
Future<String> getServerIpFromDomain(final ServerDomain serverDomain) async {
final List<RRecord>? lookup = await DnsUtils.lookupRecord(
serverDomain.domainName,
RRecordType.A,
provider: DnsApiProvider.CLOUDFLARE,
String? domain;
await InternetAddress.lookup(serverDomain.domainName).then(
(final records) {
for (final record in records) {
domain = record.address;
}
},
);
if (lookup == null || lookup.isEmpty) {
if (domain == null || domain!.isEmpty) {
throw IpNotFoundException('No IP found for domain $serverDomain');
}
return lookup[0].data;
return domain!;
}
Future<String> getDeviceName() async {

View file

@ -73,14 +73,6 @@ packages:
url: "https://pub.dev"
source: hosted
version: "3.0.0"
basic_utils:
dependency: "direct main"
description:
name: basic_utils
sha256: "8815477fcf58499e42326bd858e391442425fa57db9a45e48e15224c62049262"
url: "https://pub.dev"
source: hosted
version: "5.5.4"
bloc:
dependency: transitive
description:

View file

@ -11,7 +11,6 @@ dependencies:
animations: ^2.0.7
auto_route: ^7.3.2
auto_size_text: ^3.0.0
basic_utils: ^5.5.4
crypt: ^4.3.0
cubit_form: ^2.0.1
device_info_plus: ^9.0.2