mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2024-11-14 12:43:16 +00:00
NaiJi
86b80156fd
- Replace raw DKIM String object with a general DnsRecord structure - Implement network utils for common operations with networking concepts and structures - Implement initializing page pop up to re-try server deployment in case of a random networking error
136 lines
3.2 KiB
Dart
136 lines
3.2 KiB
Dart
import 'package:selfprivacy/logic/models/json/dns_records.dart';
|
|
|
|
enum DnsRecordsCategory {
|
|
services,
|
|
email,
|
|
other,
|
|
}
|
|
|
|
class DesiredDnsRecord {
|
|
const DesiredDnsRecord({
|
|
required this.name,
|
|
required this.content,
|
|
this.type = 'A',
|
|
this.description = '',
|
|
this.category = DnsRecordsCategory.services,
|
|
this.isSatisfied = false,
|
|
});
|
|
|
|
final String name;
|
|
final String type;
|
|
final String content;
|
|
final String description;
|
|
final DnsRecordsCategory category;
|
|
final bool isSatisfied;
|
|
|
|
DesiredDnsRecord copyWith({
|
|
final String? name,
|
|
final String? type,
|
|
final String? content,
|
|
final String? description,
|
|
final DnsRecordsCategory? category,
|
|
final bool? isSatisfied,
|
|
}) =>
|
|
DesiredDnsRecord(
|
|
name: name ?? this.name,
|
|
type: type ?? this.type,
|
|
content: content ?? this.content,
|
|
description: description ?? this.description,
|
|
category: category ?? this.category,
|
|
isSatisfied: isSatisfied ?? this.isSatisfied,
|
|
);
|
|
}
|
|
|
|
List<DesiredDnsRecord> getDesiredDnsRecords(
|
|
final String? domainName,
|
|
final String? ipAddress,
|
|
final String? dkimPublicKey,
|
|
) {
|
|
if (domainName == null || ipAddress == null) {
|
|
return [];
|
|
}
|
|
return [
|
|
DesiredDnsRecord(
|
|
name: domainName,
|
|
content: ipAddress,
|
|
description: 'record.root',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'api.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.api',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'cloud.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.cloud',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'git.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.git',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'meet.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.meet',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'social.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.social',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'password.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.password',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: 'vpn.$domainName',
|
|
content: ipAddress,
|
|
description: 'record.vpn',
|
|
),
|
|
DesiredDnsRecord(
|
|
name: domainName,
|
|
content: domainName,
|
|
description: 'record.mx',
|
|
type: 'MX',
|
|
category: DnsRecordsCategory.email,
|
|
),
|
|
DesiredDnsRecord(
|
|
name: '_dmarc.$domainName',
|
|
content: 'v=DMARC1; p=none',
|
|
description: 'record.dmarc',
|
|
type: 'TXT',
|
|
category: DnsRecordsCategory.email,
|
|
),
|
|
DesiredDnsRecord(
|
|
name: domainName,
|
|
content: 'v=spf1 a mx ip4:$ipAddress -all',
|
|
description: 'record.spf',
|
|
type: 'TXT',
|
|
category: DnsRecordsCategory.email,
|
|
),
|
|
if (dkimPublicKey != null)
|
|
DesiredDnsRecord(
|
|
name: 'selector._domainkey.$domainName',
|
|
content: dkimPublicKey,
|
|
description: 'record.dkim',
|
|
type: 'TXT',
|
|
category: DnsRecordsCategory.email,
|
|
),
|
|
];
|
|
}
|
|
|
|
DnsRecord? extractDkimRecord(final List<DnsRecord> records) {
|
|
DnsRecord? dkimRecord;
|
|
|
|
for (final DnsRecord record in records) {
|
|
if (record.type == 'TXT' && record.name == 'selector._domainkey') {
|
|
dkimRecord = record;
|
|
}
|
|
}
|
|
|
|
return dkimRecord;
|
|
}
|