Files
speckle-server/packages/server/modules/auth/services/postAuth.ts
T

66 lines
2.1 KiB
TypeScript

import { authLogger, type Logger } from '@/observability/logging'
import { maybeLoggerWithContext } from '@/observability/components/express/requestContext'
import {
addToMailchimpAudience,
triggerMailchimpCustomerJourney
} from '@/modules/auth/services/mailchimp'
import { UserEvents } from '@/modules/core/domain/users/events'
import {
enableMixpanel,
getMailchimpNewsletterIds,
getMailchimpOnboardingIds,
getMailchimpStatus
} from '@/modules/shared/helpers/envHelper'
import { EventBus, EventPayload } from '@/modules/shared/services/eventBus'
import { mixpanel } from '@/modules/shared/utils/mixpanel'
const onUserCreatedFactory =
() => async (payload: EventPayload<typeof UserEvents.Created>) => {
const logger = maybeLoggerWithContext({ logger: authLogger })!
const { user, signUpCtx } = payload.payload
try {
// Send event to MP
const userEmail = user.email
const newsletterConsent = signUpCtx?.newsletterConsent
if (userEmail && enableMixpanel()) {
const isInvite = !!signUpCtx?.isInvite
await mixpanel({ userEmail, req: signUpCtx?.req }).track('Sign Up', {
isInvite
})
}
// Set up mailchimp
if (getMailchimpStatus()) {
try {
const onboardingIds = getMailchimpOnboardingIds()
await triggerMailchimpCustomerJourney(user, onboardingIds)
if (newsletterConsent) {
const { listId } = getMailchimpNewsletterIds()
await addToMailchimpAudience(user, listId)
}
} catch (error) {
logger.warn({ err: error }, 'Failed to sign up user to mailchimp lists')
}
}
} catch (e) {
logger.error(
{
err: e,
userId: user.id
},
'Post sign up tracking failed'
)
}
}
export const initializeEventListenerFactory =
(deps: { eventBus: EventBus; logger: Logger }) => () => {
const onUserCreated = onUserCreatedFactory()
const cbs = [deps.eventBus.listen(UserEvents.Created, onUserCreated)]
return () => cbs.forEach((cb) => cb())
}