feat: Implement deSEC API support

This commit is contained in:
NaiJi 2023-05-12 03:07:43 -03:00
parent 234064ed72
commit af90ddd78a

View file

@ -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)