mirror of
https://github.com/logto-io/logto.git
synced 2024-12-16 20:26:19 -05:00
refactor(core): persist dns records to database (#3950)
This commit is contained in:
parent
64af2dc88e
commit
8178d61eca
3 changed files with 23 additions and 36 deletions
|
@ -99,16 +99,6 @@ describe('syncDomainStatus()', () => {
|
|||
getCustomHostname.mockResolvedValueOnce(mockCloudflareDataPendingSSL);
|
||||
const response = await syncDomainStatus(mockDomainWithCloudflareData);
|
||||
expect(response.status).toBe(DomainStatus.PendingSsl);
|
||||
expect(response.dnsRecords).not.toContainEqual({
|
||||
type: 'CNAME',
|
||||
name: mockDomainWithCloudflareData.domain,
|
||||
value: fallbackOrigin,
|
||||
});
|
||||
expect(response.dnsRecords).not.toContainEqual({
|
||||
type: 'TXT',
|
||||
name: mockTxtName,
|
||||
value: mockTxtValue,
|
||||
});
|
||||
expect(response.dnsRecords).toContainEqual({
|
||||
type: 'TXT',
|
||||
name: mockSslTxtName,
|
||||
|
@ -120,21 +110,6 @@ describe('syncDomainStatus()', () => {
|
|||
getCustomHostname.mockResolvedValueOnce(mockCloudflareDataActive);
|
||||
const response = await syncDomainStatus(mockDomainWithCloudflareData);
|
||||
expect(response.status).toBe(DomainStatus.Active);
|
||||
expect(response.dnsRecords).not.toContainEqual({
|
||||
type: 'CNAME',
|
||||
name: mockDomainWithCloudflareData.domain,
|
||||
value: fallbackOrigin,
|
||||
});
|
||||
expect(response.dnsRecords).not.toContainEqual({
|
||||
type: 'TXT',
|
||||
name: mockTxtName,
|
||||
value: mockTxtValue,
|
||||
});
|
||||
expect(response.dnsRecords).not.toContainEqual({
|
||||
type: 'TXT',
|
||||
name: mockSslTxtName,
|
||||
value: mockSslTxtValue,
|
||||
});
|
||||
});
|
||||
|
||||
it('should sync and get verification error', async () => {
|
||||
|
|
|
@ -5,12 +5,12 @@ import {
|
|||
DomainStatus,
|
||||
} from '@logto/schemas';
|
||||
import { generateStandardId } from '@logto/shared';
|
||||
import { conditional } from '@silverhand/essentials';
|
||||
|
||||
import type Queries from '#src/tenants/Queries.js';
|
||||
import SystemContext from '#src/tenants/SystemContext.js';
|
||||
import assertThat from '#src/utils/assert-that.js';
|
||||
import { getCustomHostname, createCustomHostname } from '#src/utils/cloudflare/index.js';
|
||||
import { findSslTxtRecord, findVerificationTxtRecord } from '#src/utils/cloudflare/utils.js';
|
||||
|
||||
export type DomainLibrary = ReturnType<typeof createDomainLibrary>;
|
||||
|
||||
|
@ -49,19 +49,20 @@ export const createDomainLibrary = (queries: Queries) => {
|
|||
.filter(Boolean)
|
||||
.join('\n');
|
||||
|
||||
const sslRecord = conditional(
|
||||
txtName && txtValue && { type: 'TXT', name: txtName, value: txtValue }
|
||||
);
|
||||
const cnameRecord = conditional(
|
||||
(status === DomainStatus.PendingVerification || status === DomainStatus.Error) && {
|
||||
const dnsRecords: DomainDnsRecords = [
|
||||
// Verification CNAME, fixed value, generated by us
|
||||
{
|
||||
type: 'CNAME',
|
||||
name: domain.domain,
|
||||
value: origin,
|
||||
}
|
||||
);
|
||||
const dnsRecords: DomainDnsRecords = [cnameRecord, ownershipVerification, sslRecord].filter(
|
||||
Boolean
|
||||
);
|
||||
},
|
||||
// SSL TXT, generated by Cloudflare
|
||||
txtName && txtValue
|
||||
? { type: 'TXT', name: txtName, value: txtValue }
|
||||
: findSslTxtRecord(domain.dnsRecords),
|
||||
// Ownership TXT, generated by Cloudflare
|
||||
ownershipVerification ?? findVerificationTxtRecord(domain.dnsRecords),
|
||||
].filter(Boolean);
|
||||
|
||||
return updateDomainById(
|
||||
domain.id,
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import { parseJson } from '@logto/connector-kit';
|
||||
import { type DomainDnsRecords } from '@logto/schemas';
|
||||
|
||||
import assertThat from '../assert-that.js';
|
||||
|
||||
|
@ -11,3 +12,13 @@ export const parseCloudflareResponse = (body: string) => {
|
|||
|
||||
return result.data.result;
|
||||
};
|
||||
|
||||
export const findVerificationTxtRecord = (records: DomainDnsRecords) =>
|
||||
records.find(
|
||||
({ type, name }) => type.toUpperCase() === 'TXT' && name.includes('_cf-custom-hostname')
|
||||
);
|
||||
|
||||
export const findSslTxtRecord = (records: DomainDnsRecords) =>
|
||||
records.find(
|
||||
({ type, name }) => type.toUpperCase() === 'TXT' && name.includes('_acme-challenge')
|
||||
);
|
||||
|
|
Loading…
Reference in a new issue