Files
speckle-server/packages/server/modules/notifications/index.ts
T
Iain Sproat 4d01e13a84 feat(structured logging) (#1242)
* Revert "Revert structured logging 2 (#1240)"
This reverts commit 78ecaeffcb.
* Logging should not be bundled into core shared directory
* making sure observability stuff isnt bundled into frontend


Co-authored-by: Kristaps Fabians Geikins <fabis94@live.com>
2022-12-06 11:51:18 +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 '@/logging/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()
}