Allow add/edit domains for most providers
This commit is contained in:
@@ -14,6 +14,53 @@ function create(origin, accessToken) {
|
||||
if (error || result.status !== 200) return [error || result];
|
||||
return [null, result.body.domains];
|
||||
},
|
||||
async add(domain, zoneName, provider, config, fallbackCertificate, tlsConfig) {
|
||||
const data = { domain, provider, config, tlsConfig };
|
||||
if (zoneName) data.zoneName = zoneName;
|
||||
if (fallbackCertificate) data.fallbackCertificate = fallbackCertificate;
|
||||
|
||||
let error, result;
|
||||
try {
|
||||
result = await fetcher.post(`${origin}/api/v1/domains`, data, { access_token: accessToken });
|
||||
} catch (e) {
|
||||
error = e;
|
||||
}
|
||||
|
||||
if (error || result.status !== 201) return [error || result];
|
||||
return [null];
|
||||
},
|
||||
async update(domain, zoneName, provider, config, fallbackCertificate, tlsConfig) {
|
||||
const data = { provider, config, tlsConfig };
|
||||
if (zoneName) data.zoneName = zoneName;
|
||||
if (fallbackCertificate) data.fallbackCertificate = fallbackCertificate;
|
||||
|
||||
let error, result;
|
||||
try {
|
||||
result = await fetcher.post(`${origin}/api/v1/domains/${domain}/config`, data, { access_token: accessToken });
|
||||
} catch (e) {
|
||||
error = e;
|
||||
}
|
||||
|
||||
if (error || result.status !== 204) return [error || result];
|
||||
|
||||
// TODO is this still needed on update? a syncdns should also do this
|
||||
// this is done so that an out-of-sync dkim key can be synced
|
||||
// [error] = await domainsModel.setDnsRecords({ domain: domain, type: 'mail' });
|
||||
// if (error) console.error(error); // not fatal for now
|
||||
|
||||
return [null];
|
||||
},
|
||||
async remove(domain) {
|
||||
let error, result;
|
||||
try {
|
||||
result = await fetcher.del(`${origin}/api/v1/domains/${domain}`, { access_token: accessToken });
|
||||
} catch (e) {
|
||||
error = e;
|
||||
}
|
||||
|
||||
if (error || result.status !== 204) return [error || result];
|
||||
return [null];
|
||||
},
|
||||
async renewCerts(options) {
|
||||
let error, result;
|
||||
try {
|
||||
|
||||
Reference in New Issue
Block a user