mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-24 01:36:38 +00:00
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:
commit
4a7f986ff4
|
@ -30,7 +30,11 @@ class BackblazeApi extends ApiMap {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
BaseOptions get options {
|
BaseOptions get options {
|
||||||
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
|
final BaseOptions options = BaseOptions(
|
||||||
|
baseUrl: rootAddress,
|
||||||
|
contentType: Headers.jsonContentType,
|
||||||
|
responseType: ResponseType.json,
|
||||||
|
);
|
||||||
if (isWithToken) {
|
if (isWithToken) {
|
||||||
final BackblazeCredential? backblazeCredential =
|
final BackblazeCredential? backblazeCredential =
|
||||||
getIt<ApiConfigModel>().backblazeCredential;
|
getIt<ApiConfigModel>().backblazeCredential;
|
||||||
|
|
|
@ -26,7 +26,11 @@ class CloudflareApi extends DnsProviderApi {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
BaseOptions get options {
|
BaseOptions get options {
|
||||||
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
|
final BaseOptions options = BaseOptions(
|
||||||
|
baseUrl: rootAddress,
|
||||||
|
contentType: Headers.jsonContentType,
|
||||||
|
responseType: ResponseType.json,
|
||||||
|
);
|
||||||
if (isWithToken) {
|
if (isWithToken) {
|
||||||
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
|
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
|
||||||
assert(token != null);
|
assert(token != null);
|
||||||
|
|
|
@ -26,7 +26,11 @@ class DesecApi extends DnsProviderApi {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
BaseOptions get options {
|
BaseOptions get options {
|
||||||
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
|
final BaseOptions options = BaseOptions(
|
||||||
|
baseUrl: rootAddress,
|
||||||
|
contentType: Headers.jsonContentType,
|
||||||
|
responseType: ResponseType.json,
|
||||||
|
);
|
||||||
if (isWithToken) {
|
if (isWithToken) {
|
||||||
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
|
final String? token = getIt<ApiConfigModel>().dnsProviderKey;
|
||||||
assert(token != null);
|
assert(token != null);
|
||||||
|
|
|
@ -36,7 +36,11 @@ class DigitalOceanApi extends ServerProviderApi with VolumeProviderApi {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
BaseOptions get options {
|
BaseOptions get options {
|
||||||
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
|
final BaseOptions options = BaseOptions(
|
||||||
|
baseUrl: rootAddress,
|
||||||
|
contentType: Headers.jsonContentType,
|
||||||
|
responseType: ResponseType.json,
|
||||||
|
);
|
||||||
if (isWithToken) {
|
if (isWithToken) {
|
||||||
final String? token = getIt<ApiConfigModel>().serverProviderKey;
|
final String? token = getIt<ApiConfigModel>().serverProviderKey;
|
||||||
assert(token != null);
|
assert(token != null);
|
||||||
|
|
|
@ -37,7 +37,11 @@ class HetznerApi extends ServerProviderApi with VolumeProviderApi {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
BaseOptions get options {
|
BaseOptions get options {
|
||||||
final BaseOptions options = BaseOptions(baseUrl: rootAddress);
|
final BaseOptions options = BaseOptions(
|
||||||
|
baseUrl: rootAddress,
|
||||||
|
contentType: Headers.jsonContentType,
|
||||||
|
responseType: ResponseType.json,
|
||||||
|
);
|
||||||
if (isWithToken) {
|
if (isWithToken) {
|
||||||
final String? token = getIt<ApiConfigModel>().serverProviderKey;
|
final String? token = getIt<ApiConfigModel>().serverProviderKey;
|
||||||
assert(token != null);
|
assert(token != null);
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
|
|
||||||
import 'package:basic_utils/basic_utils.dart';
|
|
||||||
import 'package:device_info_plus/device_info_plus.dart';
|
import 'package:device_info_plus/device_info_plus.dart';
|
||||||
import 'package:dio/dio.dart';
|
import 'package:dio/dio.dart';
|
||||||
import 'package:easy_localization/easy_localization.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/hive/user.dart';
|
||||||
import 'package:selfprivacy/logic/models/json/device_token.dart';
|
import 'package:selfprivacy/logic/models/json/device_token.dart';
|
||||||
import 'package:selfprivacy/logic/models/json/dns_records.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_basic_info.dart';
|
||||||
import 'package:selfprivacy/logic/models/server_type.dart';
|
import 'package:selfprivacy/logic/models/server_type.dart';
|
||||||
import 'package:selfprivacy/ui/helpers/modals.dart';
|
import 'package:selfprivacy/ui/helpers/modals.dart';
|
||||||
|
@ -208,46 +206,20 @@ class ServerInstallationRepository {
|
||||||
final String? ip4,
|
final String? ip4,
|
||||||
final Map<String, bool> skippedMatches,
|
final Map<String, bool> skippedMatches,
|
||||||
) async {
|
) async {
|
||||||
final List<String> addresses = <String>[
|
|
||||||
'$domainName',
|
|
||||||
'api.$domainName',
|
|
||||||
'cloud.$domainName',
|
|
||||||
'meet.$domainName',
|
|
||||||
'password.$domainName'
|
|
||||||
];
|
|
||||||
|
|
||||||
final Map<String, bool> matches = <String, bool>{};
|
final Map<String, bool> matches = <String, bool>{};
|
||||||
|
await InternetAddress.lookup(domainName!).then(
|
||||||
for (final String address in addresses) {
|
(final records) {
|
||||||
if (skippedMatches[address] ?? false) {
|
for (final record in records) {
|
||||||
matches[address] = true;
|
if (skippedMatches[record.host] ?? false) {
|
||||||
continue;
|
matches[record.host] = true;
|
||||||
}
|
continue;
|
||||||
final List<RRecord>? lookupRecordRes = await DnsUtils.lookupRecord(
|
}
|
||||||
address,
|
if (record.address == ip4!) {
|
||||||
RRecordType.A,
|
matches[record.host] = true;
|
||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return matches;
|
return matches;
|
||||||
}
|
}
|
||||||
|
@ -478,15 +450,18 @@ class ServerInstallationRepository {
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<String> getServerIpFromDomain(final ServerDomain serverDomain) async {
|
Future<String> getServerIpFromDomain(final ServerDomain serverDomain) async {
|
||||||
final List<RRecord>? lookup = await DnsUtils.lookupRecord(
|
String? domain;
|
||||||
serverDomain.domainName,
|
await InternetAddress.lookup(serverDomain.domainName).then(
|
||||||
RRecordType.A,
|
(final records) {
|
||||||
provider: DnsApiProvider.CLOUDFLARE,
|
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');
|
throw IpNotFoundException('No IP found for domain $serverDomain');
|
||||||
}
|
}
|
||||||
return lookup[0].data;
|
return domain!;
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<String> getDeviceName() async {
|
Future<String> getDeviceName() async {
|
||||||
|
|
|
@ -73,14 +73,6 @@ packages:
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.0"
|
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:
|
bloc:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
|
|
@ -11,7 +11,6 @@ dependencies:
|
||||||
animations: ^2.0.7
|
animations: ^2.0.7
|
||||||
auto_route: ^7.3.2
|
auto_route: ^7.3.2
|
||||||
auto_size_text: ^3.0.0
|
auto_size_text: ^3.0.0
|
||||||
basic_utils: ^5.5.4
|
|
||||||
crypt: ^4.3.0
|
crypt: ^4.3.0
|
||||||
cubit_form: ^2.0.1
|
cubit_form: ^2.0.1
|
||||||
device_info_plus: ^9.0.2
|
device_info_plus: ^9.0.2
|
||||||
|
|
Loading…
Reference in a new issue