matcher/src/modules/ad/adapters/primaries/ad-messager.controller.ts

71 lines
2.4 KiB
TypeScript
Raw Normal View History

2023-04-24 14:44:52 +00:00
import { RabbitSubscribe } from '@golevelup/nestjs-rabbitmq';
import { Controller } from '@nestjs/common';
import { Ad } from '../../domain/entities/ad';
import { InjectMapper } from '@automapper/nestjs';
import { Mapper } from '@automapper/core';
import { CommandBus } from '@nestjs/cqrs';
import { CreateAdCommand } from '../../commands/create-ad.command';
import { CreateAdRequest } from '../../domain/dtos/create-ad.request';
2023-04-28 13:53:57 +00:00
import { validateOrReject } from 'class-validator';
import { Messager } from '../secondaries/messager';
2023-05-11 15:47:55 +00:00
import { GeoTimezoneFinder } from '../../../geography/adapters/secondaries/geo-timezone-finder';
import { plainToInstance } from 'class-transformer';
import { DefaultParamsProvider } from '../secondaries/default-params.provider';
import { GeorouterCreator } from '../../../geography/adapters/secondaries/georouter-creator';
2023-04-24 14:44:52 +00:00
@Controller()
export class AdMessagerController {
constructor(
2023-04-28 13:53:57 +00:00
private readonly messager: Messager,
2023-04-26 10:10:22 +00:00
private readonly commandBus: CommandBus,
@InjectMapper() private readonly mapper: Mapper,
2023-05-11 15:47:55 +00:00
private readonly defaultParamsProvider: DefaultParamsProvider,
private readonly georouterCreator: GeorouterCreator,
2023-04-28 13:53:57 +00:00
private readonly timezoneFinder: GeoTimezoneFinder,
) {}
2023-04-24 14:44:52 +00:00
@RabbitSubscribe({
name: 'adCreated',
})
2023-04-26 10:10:22 +00:00
async adCreatedHandler(message: string): Promise<void> {
try {
2023-05-11 15:47:55 +00:00
const createAdRequest: CreateAdRequest = plainToInstance(
2023-04-28 13:53:57 +00:00
CreateAdRequest,
2023-05-11 15:47:55 +00:00
JSON.parse(message),
2023-04-28 13:53:57 +00:00
);
2023-04-26 10:10:22 +00:00
// validate instance
2023-04-28 13:53:57 +00:00
await validateOrReject(createAdRequest);
// validate nested objects (fixes direct nested validation bug)
for (const waypoint of createAdRequest.waypoints) {
try {
await validateOrReject(waypoint);
} catch (e) {
throw e;
}
}
createAdRequest.timezone = this.timezoneFinder.timezones(
createAdRequest.waypoints[0].lon,
createAdRequest.waypoints[0].lat,
)[0];
2023-04-26 10:10:22 +00:00
const ad: Ad = await this.commandBus.execute(
2023-05-11 15:47:55 +00:00
new CreateAdCommand(
createAdRequest,
this.defaultParamsProvider.getParams(),
this.georouterCreator,
this.timezoneFinder,
),
);
2023-04-26 10:10:22 +00:00
console.log(ad);
} catch (e) {
2023-05-11 15:47:55 +00:00
console.log(e);
2023-04-28 13:53:57 +00:00
this.messager.publish(
'logging.matcher.ad.crit',
JSON.stringify({
2023-05-11 15:47:55 +00:00
message,
2023-04-28 13:53:57 +00:00
error: e,
}),
);
}
2023-04-24 14:44:52 +00:00
}
}