-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathfindings.module.ts
64 lines (59 loc) · 2.45 KB
/
findings.module.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import { Logger, Module } from '@nestjs/common';
import { CqrsModule } from '@nestjs/cqrs';
import { Kafka } from 'kafkajs';
import { isConsumerMode, isTest } from '../app.constants';
import { ConfigModule } from '../database/admin/config/config.module';
import { CustomJobsModule } from '../database/custom-jobs/custom-jobs.module';
import { DatalayerModule } from '../database/datalayer.module';
import { JobExecutionsService } from '../database/jobs/job-executions.service';
import { JobsModule } from '../database/jobs/jobs.module';
import { DomainsModule } from '../database/reporting/domain/domain.module';
import { HostModule } from '../database/reporting/host/host.module';
import { PortModule } from '../database/reporting/port/port.module';
import { ProjectModule } from '../database/reporting/project.module';
import { WebsiteModule } from '../database/reporting/websites/website.module';
import { SecretsModule } from '../database/secrets/secrets.module';
import { EventSubscriptionsModule } from '../database/subscriptions/event-subscriptions/event-subscriptions.module';
import { SubscriptionTriggersModule } from '../database/subscriptions/subscription-triggers/subscription-triggers.module';
import { TagsModule } from '../database/tags/tag.module';
import { kafkaConfig } from '../queues/queue.module';
import { FindingsHandlers } from './commands/findings-commands';
import { FindingsConsumer } from './findings.consumer';
import { FindingsController } from './findings.controller';
import { FindingsService } from './findings.service';
import { JobLogsConsumer } from './job-logs.consumer';
@Module({
imports: [
CqrsModule,
JobsModule,
ProjectModule,
HostModule,
DomainsModule,
DatalayerModule,
EventSubscriptionsModule,
CustomJobsModule,
PortModule,
ConfigModule,
SubscriptionTriggersModule,
SecretsModule,
WebsiteModule,
TagsModule,
],
controllers: [FindingsController],
providers: [FindingsService, ...FindingsHandlers],
exports: [],
})
export class FindingsModule {
private logger: Logger = new Logger('FindingsModule');
public constructor(
private findingsService: FindingsService,
private jobService: JobExecutionsService,
) {}
public async onApplicationBootstrap() {
if (isTest()) return;
if (!isConsumerMode()) return;
const kafka = new Kafka(kafkaConfig);
await FindingsConsumer.create(kafka, this.findingsService);
await JobLogsConsumer.create(kafka, this.jobService);
}
}