Files
speckle-server/packages/server/modules/notifications/index.ts
T
Iain Sproat 5655b3e758 fix(metrics): pass registry in to modules (#4113)
- ensure metrics are added to the correct registry
2025-03-06 08:37:05 +00:00

58 lines
1.8 KiB
TypeScript

import {
initializeQueue,
consumeIncomingNotifications,
registerNotificationHandlers,
shutdownQueue
} from '@/modules/notifications/services/queue'
import {
NotificationType,
NotificationTypeHandlers
} from '@/modules/notifications/helpers/types'
import { SpeckleModule } from '@/modules/shared/helpers/typeHelper'
import { shouldDisableNotificationsConsumption } from '@/modules/shared/helpers/envHelper'
import { moduleLogger } from '@/observability/logging'
export async function initializeConsumption(
customHandlers?: Partial<NotificationTypeHandlers>
) {
moduleLogger.info('📞 Initializing notification queue consumption...')
const allHandlers: Partial<NotificationTypeHandlers> = {
[NotificationType.MentionedInComment]: (
await import('@/modules/notifications/services/handlers/mentionedInComment')
).default,
[NotificationType.NewStreamAccessRequest]: (
await import('@/modules/notifications/services/handlers/newStreamAccessRequest')
).default,
[NotificationType.StreamAccessRequestApproved]: (
await import(
'@/modules/notifications/services/handlers/streamAccessRequestApproved'
)
).default,
[NotificationType.ActivityDigest]: (
await import('@/modules/notifications/services/handlers/activityDigest')
).default
}
registerNotificationHandlers(customHandlers || allHandlers)
initializeQueue()
if (shouldDisableNotificationsConsumption()) {
moduleLogger.info('Skipping notification consumption...')
} else {
await consumeIncomingNotifications()
}
}
export const init: SpeckleModule['init'] = async ({ isInitial }) => {
moduleLogger.info('📞 Init notifications module')
if (isInitial) {
await initializeConsumption()
}
}
export const shutdown: SpeckleModule['shutdown'] = async () => {
await shutdownQueue()
}