Files
cloudron-box/dashboard/src/models/DomainsModel.js
T

130 lines
4.0 KiB
JavaScript
Raw Normal View History

2025-01-05 12:52:11 +01:00
import { fetcher } from 'pankow';
2025-03-03 11:22:56 +01:00
import { API_ORIGIN } from '../constants.js';
2025-01-05 12:52:11 +01:00
2025-01-31 21:02:48 +01:00
function create() {
const accessToken = localStorage.token;
2025-04-19 16:28:36 +02:00
const exposed = {
2025-01-05 12:52:11 +01:00
async list() {
let error, result;
try {
2025-03-03 11:22:56 +01:00
result = await fetcher.get(`${API_ORIGIN}/api/v1/domains`, { access_token: accessToken });
2025-01-05 12:52:11 +01:00
} catch (e) {
error = e;
}
2025-01-27 22:20:26 +01:00
if (error || result.status !== 200) return [error || result];
return [null, result.body.domains];
},
async get(domain) {
let error, result;
try {
result = await fetcher.get(`${API_ORIGIN}/api/v1/domains/${domain}`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
},
2025-01-29 16:29:21 +01:00
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 {
2025-03-03 11:22:56 +01:00
result = await fetcher.post(`${API_ORIGIN}/api/v1/domains`, data, { access_token: accessToken });
2025-01-29 16:29:21 +01:00
} 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 {
2025-03-03 11:22:56 +01:00
result = await fetcher.post(`${API_ORIGIN}/api/v1/domains/${domain}/config`, data, { access_token: accessToken });
2025-01-29 16:29:21 +01:00
} catch (e) {
error = e;
}
if (error || result.status !== 204) return [error || result];
// this is done so that an out-of-sync dkim key can be synced
2025-04-19 16:28:36 +02:00
[error] = await exposed.setDnsRecords({ domain: domain, type: 'mail' });
if (error) console.error(error); // not fatal for now
2025-01-29 16:29:21 +01:00
return [null];
},
async remove(domain) {
let error, result;
try {
2025-03-14 18:48:13 +01:00
result = await fetcher.del(`${API_ORIGIN}/api/v1/domains/${domain}`, null, { access_token: accessToken });
2025-01-29 16:29:21 +01:00
} catch (e) {
error = e;
}
if (error || result.status !== 204) return [error || result];
return [null];
},
2025-01-27 22:20:26 +01:00
async renewCerts(options) {
let error, result;
try {
2025-03-03 11:22:56 +01:00
result = await fetcher.post(`${API_ORIGIN}/api/v1/reverseproxy/renew_certs`, { rebuild: !!options.rebuild }, { access_token: accessToken });
2025-01-27 22:20:26 +01:00
} catch (e) {
error = e;
2025-01-05 12:52:11 +01:00
}
2025-01-27 22:20:26 +01:00
if (error || result.status !== 202) return [error || result];
return [null, result.body.taskId];
2025-01-05 12:52:11 +01:00
},
2025-01-27 22:20:26 +01:00
async setDnsRecords(options) {
let error, result;
try {
2025-03-03 11:22:56 +01:00
result = await fetcher.post(`${API_ORIGIN}/api/v1/domains/sync_dns`, options, { access_token: accessToken });
2025-01-27 22:20:26 +01:00
} catch (e) {
error = e;
}
if (error || result.status !== 201) return [error || result];
return [null, result.body.taskId];
2025-01-30 14:29:46 +01:00
},
async setWellKnown(domain, wellKnown) {
// see WellKnownDialog.vue for the slightly complex wellKnown object
let error, result;
try {
2025-03-03 11:22:56 +01:00
result = await fetcher.post(`${API_ORIGIN}/api/v1/domains/${domain}/wellknown`, { wellKnown }, { access_token: accessToken });
2025-01-30 14:29:46 +01:00
} catch (e) {
error = e;
}
if (error || result.status !== 204) return [error || result];
return [null];
},
2025-02-06 18:22:07 +01:00
async checkRecords(domain, subdomain) {
let error, result;
try {
2025-03-03 11:22:56 +01:00
result = await fetcher.get(`${API_ORIGIN}/api/v1/domains/${domain}/dns_check`, { subdomain, access_token: accessToken });
2025-02-06 18:22:07 +01:00
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
2025-02-06 18:22:07 +01:00
},
2025-01-05 12:52:11 +01:00
};
2025-04-19 16:28:36 +02:00
return exposed;
2025-01-05 12:52:11 +01:00
}
export default {
create,
};