mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-24 09:46:42 +00:00
feat: Implement deSEC API support
This commit is contained in:
parent
234064ed72
commit
af90ddd78a
|
@ -172,7 +172,18 @@ class DesecApi extends DnsProviderApi {
|
||||||
allCreateFutures.add(
|
allCreateFutures.add(
|
||||||
client.post(
|
client.post(
|
||||||
'/$domainName/rrsets/',
|
'/$domainName/rrsets/',
|
||||||
data: record.toJson(),
|
data: record.name == null
|
||||||
|
? {
|
||||||
|
'type': record.type,
|
||||||
|
'ttl': record.ttl,
|
||||||
|
'records': [record.content],
|
||||||
|
}
|
||||||
|
: {
|
||||||
|
'subname': record.name,
|
||||||
|
'type': record.type,
|
||||||
|
'ttl': record.ttl,
|
||||||
|
'records': [record.content],
|
||||||
|
},
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -198,10 +209,9 @@ class DesecApi extends DnsProviderApi {
|
||||||
final String? domainName,
|
final String? domainName,
|
||||||
final String? ip4,
|
final String? ip4,
|
||||||
) {
|
) {
|
||||||
final DnsRecord domainA =
|
final DnsRecord domainA = DnsRecord(type: 'A', name: null, content: ip4);
|
||||||
DnsRecord(type: 'A', name: domainName, content: ip4);
|
|
||||||
|
|
||||||
final DnsRecord mx = DnsRecord(type: 'MX', name: '@', content: domainName);
|
final DnsRecord mx = DnsRecord(type: 'MX', name: null, content: domainName);
|
||||||
final DnsRecord apiA = DnsRecord(type: 'A', name: 'api', content: ip4);
|
final DnsRecord apiA = DnsRecord(type: 'A', name: 'api', content: ip4);
|
||||||
final DnsRecord cloudA = DnsRecord(type: 'A', name: 'cloud', content: ip4);
|
final DnsRecord cloudA = DnsRecord(type: 'A', name: 'cloud', content: ip4);
|
||||||
final DnsRecord gitA = DnsRecord(type: 'A', name: 'git', content: ip4);
|
final DnsRecord gitA = DnsRecord(type: 'A', name: 'git', content: ip4);
|
||||||
|
@ -221,7 +231,7 @@ class DesecApi extends DnsProviderApi {
|
||||||
|
|
||||||
final DnsRecord txt2 = DnsRecord(
|
final DnsRecord txt2 = DnsRecord(
|
||||||
type: 'TXT',
|
type: 'TXT',
|
||||||
name: domainName,
|
name: null,
|
||||||
content: 'v=spf1 a mx ip4:$ip4 -all',
|
content: 'v=spf1 a mx ip4:$ip4 -all',
|
||||||
ttl: 18000,
|
ttl: 18000,
|
||||||
);
|
);
|
||||||
|
@ -246,14 +256,24 @@ class DesecApi extends DnsProviderApi {
|
||||||
final DnsRecord record,
|
final DnsRecord record,
|
||||||
final ServerDomain domain,
|
final ServerDomain domain,
|
||||||
) async {
|
) async {
|
||||||
final String domainZoneId = domain.zoneId;
|
final String url = '/${domain.domainName}/rrsets/';
|
||||||
final String url = '$rootAddress/zones/$domainZoneId/dns_records';
|
|
||||||
|
|
||||||
final Dio client = await getClient();
|
final Dio client = await getClient();
|
||||||
try {
|
try {
|
||||||
await client.post(
|
await client.post(
|
||||||
url,
|
url,
|
||||||
data: record.toJson(),
|
data: record.name == null
|
||||||
|
? {
|
||||||
|
'type': record.type,
|
||||||
|
'ttl': record.ttl,
|
||||||
|
'records': [record.content],
|
||||||
|
}
|
||||||
|
: {
|
||||||
|
'subname': record.name,
|
||||||
|
'type': record.type,
|
||||||
|
'ttl': record.ttl,
|
||||||
|
'records': [record.content],
|
||||||
|
},
|
||||||
);
|
);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print(e);
|
print(e);
|
||||||
|
@ -264,14 +284,12 @@ class DesecApi extends DnsProviderApi {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<List<String>> domainList() async {
|
Future<List<String>> domainList() async {
|
||||||
final String url = '$rootAddress/zones';
|
|
||||||
List<String> domains = [];
|
List<String> domains = [];
|
||||||
|
|
||||||
final Dio client = await getClient();
|
final Dio client = await getClient();
|
||||||
try {
|
try {
|
||||||
final Response response = await client.get(
|
final Response response = await client.get(
|
||||||
url,
|
'',
|
||||||
queryParameters: {'per_page': 50},
|
|
||||||
);
|
);
|
||||||
domains = response.data['result']
|
domains = response.data['result']
|
||||||
.map<String>((final el) => el['name'] as String)
|
.map<String>((final el) => el['name'] as String)
|
||||||
|
|
Loading…
Reference in a new issue