fix email spams

This commit is contained in:
OxSaitama 2023-10-20 12:18:04 +02:00
parent a20f17dc0b
commit 974d1225ee

View File

@ -1,4 +1,3 @@
import DocumentsService from "@Services/super-admin/DocumentsService/DocumentsService"; import DocumentsService from "@Services/super-admin/DocumentsService/DocumentsService";
import { Documents } from "@prisma/client"; import { Documents } from "@prisma/client";
import User, { Document } from "le-coffre-resources/dist/SuperAdmin"; import User, { Document } from "le-coffre-resources/dist/SuperAdmin";
@ -10,7 +9,12 @@ import UsersService from "@Services/super-admin/UsersService/UsersService";
@Service() @Service()
export default class EmailBuilder { export default class EmailBuilder {
public constructor(private mailchimpService: MailchimpService ,private documentsService: DocumentsService, protected variables: BackendVariables, private usersService: UsersService){} public constructor(
private mailchimpService: MailchimpService,
private documentsService: DocumentsService,
protected variables: BackendVariables,
private usersService: UsersService,
) {}
public async sendDocumentEmails(documentEntity: Documents) { public async sendDocumentEmails(documentEntity: Documents) {
if (documentEntity.document_status !== "ASKED" && documentEntity.document_status !== "REFUSED") return; if (documentEntity.document_status !== "ASKED" && documentEntity.document_status !== "REFUSED") return;
@ -22,12 +26,21 @@ export default class EmailBuilder{
subject = "Un ou plusieurs documents ne sont pas validés. Vous avez une nouvelle action à réaliser."; subject = "Un ou plusieurs documents ne sont pas validés. Vous avez une nouvelle action à réaliser.";
} }
const documentPrisma = await this.documentsService.getByUid(documentEntity.uid, { depositor: {include: {contact: true}}, folder:{include:{ office: true}} }); const documentPrisma = await this.documentsService.getByUid(documentEntity.uid, {
depositor: { include: { contact: true } },
folder: { include: { office: true } },
});
if (!documentPrisma) throw new Error("Document not found"); if (!documentPrisma) throw new Error("Document not found");
const document = Document.hydrate<Document>(documentPrisma); const document = Document.hydrate<Document>(documentPrisma);
//Use mailchimpService.get get if an email was sent to the user in the lst hour //Use mailchimpService.get get if an email was sent to the user in the lst hour
const lastEmail = await this.mailchimpService.get({ where: { to: document.depositor!.contact!.email, sentAt: { gte: new Date(Date.now() - 3600000) }, templateName: templateName} }); const lastEmail = await this.mailchimpService.get({
where: {
to: document.depositor!.contact!.email,
OR: [{ sentAt: { gte: new Date(Date.now() - 3600000) } }, { sentAt: null }],
templateName: templateName,
},
});
if (lastEmail.length > 0) return; if (lastEmail.length > 0) return;
const to = document.depositor!.contact!.email; const to = document.depositor!.contact!.email;
@ -35,7 +48,7 @@ export default class EmailBuilder{
first_name: document.depositor!.contact!.first_name, first_name: document.depositor!.contact!.first_name,
last_name: document.depositor!.contact!.last_name, last_name: document.depositor!.contact!.last_name,
office_name: document.folder!.office!.name, office_name: document.folder!.office!.name,
link: `${this.variables.APP_HOST}/customer-login` link: `${this.variables.APP_HOST}/customer-login`,
}; };
this.mailchimpService.create({ this.mailchimpService.create({
@ -54,16 +67,20 @@ export default class EmailBuilder{
} }
public async sendRecapEmails() { public async sendRecapEmails() {
const usersToEmail : User[] = await this.usersService.get({ where: { office_folders: { some:{ documents: { some: { document_status: "DEPOSITED" } } }} }, distinct: ["uid"], include: { contact: true } }); const usersToEmail: User[] = await this.usersService.get({
where: { office_folders: { some: { documents: { some: { document_status: "DEPOSITED" } } } } },
distinct: ["uid"],
include: { contact: true },
});
usersToEmail.forEach(user => { usersToEmail.forEach((user) => {
const to = user.contact!.email; const to = user.contact!.email;
const civility = this.getCivility(user.contact!.civility); const civility = this.getCivility(user.contact!.civility);
const templateVariables = { const templateVariables = {
civility: civility, civility: civility,
last_name: user.contact!.last_name, last_name: user.contact!.last_name,
link: this.variables.APP_HOST link: this.variables.APP_HOST,
}; };
const templateName = ETemplates.DOCUMENT_RECAP; const templateName = ETemplates.DOCUMENT_RECAP;
@ -86,7 +103,7 @@ export default class EmailBuilder{
} }
public getCivility(civility: string) { public getCivility(civility: string) {
if(civility === "MALE") return "Mr" if (civility === "MALE") return "Mr";
else return "Mme" else return "Mme";
} }
} }