Files
speckle-server/packages/server/modules/emails/services/sending.ts
T
2025-04-28 15:23:32 +01:00

55 lines
1.5 KiB
TypeScript

import { emailLogger } from '@/observability/logging'
import { SendEmail, SendEmailParams } from '@/modules/emails/domain/operations'
import { getTransporter } from '@/modules/emails/utils/transporter'
import { getEmailFromAddress } from '@/modules/shared/helpers/envHelper'
import { resolveMixpanelUserId } from '@speckle/shared'
import {
getRequestLogger,
loggerWithMaybeContext
} from '@/observability/utils/requestContext'
export type { SendEmailParams } from '@/modules/emails/domain/operations'
/**
* Send out an e-mail
*/
export const sendEmail: SendEmail = async ({
from,
to,
subject,
text,
html
}: SendEmailParams): Promise<boolean> => {
const logger = getRequestLogger() || loggerWithMaybeContext({ logger: emailLogger })
const transporter = getTransporter()
if (!transporter) {
logger.warn('No email transport present. Cannot send emails. Skipping send...')
return false
}
try {
const emailFrom = getEmailFromAddress()
await transporter.sendMail({
from: from || `"Speckle" <${emailFrom}>`,
to,
subject,
text,
html
})
const emails = typeof to === 'string' ? [to] : to
const distinctIds = await Promise.all(
emails.map((email) => resolveMixpanelUserId(email))
)
logger.info(
{
subject,
distinctIds
},
'Email "{subject}" sent out to distinctIds {distinctIds}'
)
return true
} catch (error) {
logger.error(error)
}
return false
}