mirror of
https://github.com/OneUptime/oneuptime
synced 2024-11-22 23:30:10 +00:00
95 lines
3.1 KiB
TypeScript
95 lines
3.1 KiB
TypeScript
import PostgresDatabase from '../Infrastructure/PostgresDatabase';
|
|
import Model from 'Model/Models/Domain';
|
|
import DatabaseService from './DatabaseService';
|
|
import { OnCreate, OnUpdate } from '../Types/Database/Hooks';
|
|
import CreateBy from '../Types/Database/CreateBy';
|
|
import Text from 'Common/Types/Text';
|
|
import UpdateBy from '../Types/Database/UpdateBy';
|
|
import BadDataException from 'Common/Types/Exception/BadDataException';
|
|
import Domain from '../Types/Domain';
|
|
|
|
export class Service extends DatabaseService<Model> {
|
|
public constructor(postgresDatabase?: PostgresDatabase) {
|
|
super(Model, postgresDatabase);
|
|
}
|
|
|
|
protected override async onBeforeCreate(
|
|
createBy: CreateBy<Model>
|
|
): Promise<OnCreate<Model>> {
|
|
createBy.data.domainVerificationText =
|
|
'oneuptime-verification-' + Text.generateRandomText(20);
|
|
return Promise.resolve({ createBy, carryForward: null });
|
|
}
|
|
|
|
protected override async onBeforeUpdate(
|
|
updateBy: UpdateBy<Model>
|
|
): Promise<OnUpdate<Model>> {
|
|
if (
|
|
updateBy.data.isVerified &&
|
|
updateBy.query._id &&
|
|
!updateBy.props.isRoot
|
|
) {
|
|
// check the verification of the domain.
|
|
|
|
const items: Array<Model> = await this.findBy({
|
|
query: {
|
|
_id: updateBy.query._id as string,
|
|
projectId: updateBy.props.tenantId!,
|
|
},
|
|
select: {
|
|
domain: true,
|
|
domainVerificationText: true,
|
|
},
|
|
|
|
limit: 1,
|
|
skip: 0,
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
});
|
|
|
|
if (items.length === 0) {
|
|
throw new BadDataException(
|
|
'Domain with id ' + updateBy.query._id + ' not found.'
|
|
);
|
|
}
|
|
|
|
const domain: string | undefined = items[0]?.domain?.toString();
|
|
const verificationText: string | undefined =
|
|
items[0]?.domainVerificationText?.toString();
|
|
|
|
if (!domain) {
|
|
throw new BadDataException(
|
|
'Domain with id ' + updateBy.query._id + ' not found.'
|
|
);
|
|
}
|
|
|
|
if (!verificationText) {
|
|
throw new BadDataException(
|
|
'Domain verification text with id ' +
|
|
updateBy.query._id +
|
|
' not found.'
|
|
);
|
|
}
|
|
|
|
const isVerified: boolean = await Domain.verifyTxtRecord(
|
|
domain,
|
|
verificationText
|
|
);
|
|
|
|
if (!isVerified) {
|
|
throw new BadDataException(
|
|
'Verification TXT record ' +
|
|
verificationText +
|
|
' not found in domain ' +
|
|
domain +
|
|
'. Please add a TXT record to verify the domain.'
|
|
);
|
|
}
|
|
}
|
|
|
|
return { carryForward: null, updateBy };
|
|
}
|
|
}
|
|
export default new Service();
|