remove configuration and rabbit modules, add corresponding packages
This commit is contained in:
parent
b4fdadda37
commit
e72ecefd0a
File diff suppressed because it is too large
Load Diff
|
@ -34,10 +34,12 @@
|
||||||
"@automapper/classes": "^8.7.7",
|
"@automapper/classes": "^8.7.7",
|
||||||
"@automapper/core": "^8.7.7",
|
"@automapper/core": "^8.7.7",
|
||||||
"@automapper/nestjs": "^8.7.7",
|
"@automapper/nestjs": "^8.7.7",
|
||||||
"@golevelup/nestjs-rabbitmq": "^3.4.0",
|
|
||||||
"@grpc/grpc-js": "^1.8.0",
|
"@grpc/grpc-js": "^1.8.0",
|
||||||
"@grpc/proto-loader": "^0.7.4",
|
"@grpc/proto-loader": "^0.7.4",
|
||||||
"@liaoliaots/nestjs-redis": "^9.0.5",
|
"@liaoliaots/nestjs-redis": "^9.0.5",
|
||||||
|
"@mobicoop/configuration-module": "^1.1.0",
|
||||||
|
"@mobicoop/message-broker-module": "^1.0.5",
|
||||||
|
"@nestjs/cache-manager": "^1.0.0",
|
||||||
"@nestjs/common": "^9.0.0",
|
"@nestjs/common": "^9.0.0",
|
||||||
"@nestjs/config": "^2.2.0",
|
"@nestjs/config": "^2.2.0",
|
||||||
"@nestjs/core": "^9.0.0",
|
"@nestjs/core": "^9.0.0",
|
||||||
|
@ -49,7 +51,7 @@
|
||||||
"@types/supertest": "^2.0.11",
|
"@types/supertest": "^2.0.11",
|
||||||
"@typescript-eslint/eslint-plugin": "^5.0.0",
|
"@typescript-eslint/eslint-plugin": "^5.0.0",
|
||||||
"@typescript-eslint/parser": "^5.0.0",
|
"@typescript-eslint/parser": "^5.0.0",
|
||||||
"cache-manager": "^5.1.4",
|
"cache-manager": "^5.2.1",
|
||||||
"cache-manager-ioredis-yet": "^1.1.0",
|
"cache-manager-ioredis-yet": "^1.1.0",
|
||||||
"class-transformer": "^0.5.1",
|
"class-transformer": "^0.5.1",
|
||||||
"dotenv-cli": "^6.0.0",
|
"dotenv-cli": "^6.0.0",
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
export const MESSAGE_BROKER_PUBLISHER = Symbol();
|
||||||
|
export const MESSAGE_PUBLISHER = Symbol();
|
|
@ -1,17 +1,67 @@
|
||||||
import { classes } from '@automapper/classes';
|
import { classes } from '@automapper/classes';
|
||||||
import { AutomapperModule } from '@automapper/nestjs';
|
import { AutomapperModule } from '@automapper/nestjs';
|
||||||
import { Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
import { ConfigModule } from '@nestjs/config';
|
import { ConfigModule, ConfigService } from '@nestjs/config';
|
||||||
import { ConfigurationModule } from './modules/configuration/configuration.module';
|
|
||||||
import { HealthModule } from './modules/health/health.module';
|
import { HealthModule } from './modules/health/health.module';
|
||||||
import { UserModule } from './modules/user/user.module';
|
import { UserModule } from './modules/user/user.module';
|
||||||
|
import {
|
||||||
|
ConfigurationModule,
|
||||||
|
ConfigurationModuleOptions,
|
||||||
|
} from '@mobicoop/configuration-module';
|
||||||
|
import {
|
||||||
|
MessageBrokerModule,
|
||||||
|
MessageBrokerModuleOptions,
|
||||||
|
} from '@mobicoop/message-broker-module';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ConfigModule.forRoot({ isGlobal: true }),
|
ConfigModule.forRoot({ isGlobal: true }),
|
||||||
AutomapperModule.forRoot({ strategyInitializer: classes() }),
|
AutomapperModule.forRoot({ strategyInitializer: classes() }),
|
||||||
UserModule,
|
UserModule,
|
||||||
ConfigurationModule,
|
MessageBrokerModule.forRootAsync(
|
||||||
|
{
|
||||||
|
imports: [ConfigModule],
|
||||||
|
inject: [ConfigService],
|
||||||
|
useFactory: async (
|
||||||
|
configService: ConfigService,
|
||||||
|
): Promise<MessageBrokerModuleOptions> => ({
|
||||||
|
uri: configService.get<string>('MESSAGE_BROKER_URI'),
|
||||||
|
exchange: configService.get<string>('MESSAGE_BROKER_EXCHANGE'),
|
||||||
|
handlers: {},
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
false,
|
||||||
|
),
|
||||||
|
ConfigurationModule.forRootAsync(
|
||||||
|
{
|
||||||
|
imports: [ConfigModule],
|
||||||
|
inject: [ConfigService],
|
||||||
|
useFactory: async (
|
||||||
|
configService: ConfigService,
|
||||||
|
): Promise<ConfigurationModuleOptions> => ({
|
||||||
|
domain: configService.get<string>('SERVICE_CONFIGURATION_DOMAIN'),
|
||||||
|
messageBroker: {
|
||||||
|
uri: configService.get<string>('MESSAGE_BROKER_URI'),
|
||||||
|
exchange: configService.get<string>('MESSAGE_BROKER_EXCHANGE'),
|
||||||
|
},
|
||||||
|
redis: {
|
||||||
|
host: configService.get<string>('REDIS_HOST'),
|
||||||
|
password: configService.get<string>('REDIS_PASSWORD'),
|
||||||
|
port: configService.get<number>('REDIS_PORT'),
|
||||||
|
},
|
||||||
|
setConfigurationBrokerRoutingKeys: [
|
||||||
|
'configuration.create',
|
||||||
|
'configuration.update',
|
||||||
|
],
|
||||||
|
deleteConfigurationRoutingKey: 'configuration.delete',
|
||||||
|
propagateConfigurationRoutingKey: 'configuration.propagate',
|
||||||
|
setConfigurationBrokerQueue: 'user-configuration-create-update',
|
||||||
|
deleteConfigurationQueue: 'user-configuration-delete',
|
||||||
|
propagateConfigurationQueue: 'user-configuration-propagate',
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
true,
|
||||||
|
),
|
||||||
HealthModule,
|
HealthModule,
|
||||||
],
|
],
|
||||||
controllers: [],
|
controllers: [],
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
export interface IPublishMessage {
|
||||||
|
publish(routingKey: string, message: string): void;
|
||||||
|
}
|
|
@ -1,77 +0,0 @@
|
||||||
import { RabbitSubscribe } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { Controller } from '@nestjs/common';
|
|
||||||
import { ConfigService } from '@nestjs/config';
|
|
||||||
import { CommandBus } from '@nestjs/cqrs';
|
|
||||||
import { DeleteConfigurationCommand } from '../../commands/delete-configuration.command';
|
|
||||||
import { SetConfigurationCommand } from '../../commands/set-configuration.command';
|
|
||||||
import { DeleteConfigurationRequest } from '../../domain/dtos/delete-configuration.request';
|
|
||||||
import { SetConfigurationRequest } from '../../domain/dtos/set-configuration.request';
|
|
||||||
import { Configuration } from '../../domain/entities/configuration';
|
|
||||||
|
|
||||||
@Controller()
|
|
||||||
export class ConfigurationMessagerController {
|
|
||||||
constructor(
|
|
||||||
private readonly commandBus: CommandBus,
|
|
||||||
private readonly configService: ConfigService,
|
|
||||||
) {}
|
|
||||||
|
|
||||||
@RabbitSubscribe({
|
|
||||||
name: 'setConfiguration',
|
|
||||||
})
|
|
||||||
public async setConfigurationHandler(message: string) {
|
|
||||||
const configuration: Configuration = JSON.parse(message);
|
|
||||||
if (
|
|
||||||
configuration.domain ==
|
|
||||||
this.configService.get<string>('SERVICE_CONFIGURATION_DOMAIN')
|
|
||||||
) {
|
|
||||||
const setConfigurationRequest: SetConfigurationRequest =
|
|
||||||
new SetConfigurationRequest();
|
|
||||||
setConfigurationRequest.domain = configuration.domain;
|
|
||||||
setConfigurationRequest.key = configuration.key;
|
|
||||||
setConfigurationRequest.value = configuration.value;
|
|
||||||
await this.commandBus.execute(
|
|
||||||
new SetConfigurationCommand(setConfigurationRequest),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@RabbitSubscribe({
|
|
||||||
name: 'deleteConfiguration',
|
|
||||||
})
|
|
||||||
public async configurationDeletedHandler(message: string) {
|
|
||||||
const deletedConfiguration: Configuration = JSON.parse(message);
|
|
||||||
if (
|
|
||||||
deletedConfiguration.domain ==
|
|
||||||
this.configService.get<string>('SERVICE_CONFIGURATION_DOMAIN')
|
|
||||||
) {
|
|
||||||
const deleteConfigurationRequest = new DeleteConfigurationRequest();
|
|
||||||
deleteConfigurationRequest.domain = deletedConfiguration.domain;
|
|
||||||
deleteConfigurationRequest.key = deletedConfiguration.key;
|
|
||||||
await this.commandBus.execute(
|
|
||||||
new DeleteConfigurationCommand(deleteConfigurationRequest),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@RabbitSubscribe({
|
|
||||||
name: 'propagateConfiguration',
|
|
||||||
})
|
|
||||||
public async propagateConfigurationsHandler(message: string) {
|
|
||||||
const configurations: Array<Configuration> = JSON.parse(message);
|
|
||||||
configurations.forEach(async (configuration) => {
|
|
||||||
if (
|
|
||||||
configuration.domain ==
|
|
||||||
this.configService.get<string>('SERVICE_CONFIGURATION_DOMAIN')
|
|
||||||
) {
|
|
||||||
const setConfigurationRequest: SetConfigurationRequest =
|
|
||||||
new SetConfigurationRequest();
|
|
||||||
setConfigurationRequest.domain = configuration.domain;
|
|
||||||
setConfigurationRequest.key = configuration.key;
|
|
||||||
setConfigurationRequest.value = configuration.value;
|
|
||||||
await this.commandBus.execute(
|
|
||||||
new SetConfigurationCommand(setConfigurationRequest),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import { InjectRedis } from '@liaoliaots/nestjs-redis';
|
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
import { Redis } from 'ioredis';
|
|
||||||
import { IConfigurationRepository } from '../../domain/interfaces/configuration.repository';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export class RedisConfigurationRepository extends IConfigurationRepository {
|
|
||||||
constructor(@InjectRedis() private readonly redis: Redis) {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
get = async (key: string): Promise<string> => await this.redis.get(key);
|
|
||||||
|
|
||||||
set = async (key: string, value: string): Promise<'OK'> =>
|
|
||||||
this.redis.set(key, value);
|
|
||||||
|
|
||||||
del = async (key: string): Promise<number> => this.redis.del(key);
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
import { DeleteConfigurationRequest } from '../domain/dtos/delete-configuration.request';
|
|
||||||
|
|
||||||
export class DeleteConfigurationCommand {
|
|
||||||
readonly deleteConfigurationRequest: DeleteConfigurationRequest;
|
|
||||||
|
|
||||||
constructor(deleteConfigurationRequest: DeleteConfigurationRequest) {
|
|
||||||
this.deleteConfigurationRequest = deleteConfigurationRequest;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
import { SetConfigurationRequest } from '../domain/dtos/set-configuration.request';
|
|
||||||
|
|
||||||
export class SetConfigurationCommand {
|
|
||||||
readonly setConfigurationRequest: SetConfigurationRequest;
|
|
||||||
|
|
||||||
constructor(setConfigurationRequest: SetConfigurationRequest) {
|
|
||||||
this.setConfigurationRequest = setConfigurationRequest;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,68 +0,0 @@
|
||||||
import { RabbitMQConfig, RabbitMQModule } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { RedisModule, RedisModuleOptions } from '@liaoliaots/nestjs-redis';
|
|
||||||
import { Module } from '@nestjs/common';
|
|
||||||
import { ConfigModule, ConfigService } from '@nestjs/config';
|
|
||||||
import { CqrsModule } from '@nestjs/cqrs';
|
|
||||||
import { ConfigurationMessagerController } from './adapters/primaries/configuration-messager.controller';
|
|
||||||
import { RedisConfigurationRepository } from './adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { DeleteConfigurationUseCase } from './domain/usecases/delete-configuration.usecase';
|
|
||||||
import { GetConfigurationUseCase } from './domain/usecases/get-configuration.usecase';
|
|
||||||
import { SetConfigurationUseCase } from './domain/usecases/set-configuration.usecase';
|
|
||||||
|
|
||||||
@Module({
|
|
||||||
imports: [
|
|
||||||
CqrsModule,
|
|
||||||
RedisModule.forRootAsync({
|
|
||||||
imports: [ConfigModule],
|
|
||||||
inject: [ConfigService],
|
|
||||||
useFactory: async (
|
|
||||||
configService: ConfigService,
|
|
||||||
): Promise<RedisModuleOptions> => ({
|
|
||||||
config: {
|
|
||||||
host: configService.get<string>('REDIS_HOST'),
|
|
||||||
port: configService.get<number>('REDIS_PORT'),
|
|
||||||
password: configService.get<string>('REDIS_PASSWORD'),
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
}),
|
|
||||||
RabbitMQModule.forRootAsync(RabbitMQModule, {
|
|
||||||
imports: [ConfigModule],
|
|
||||||
inject: [ConfigService],
|
|
||||||
useFactory: async (
|
|
||||||
configService: ConfigService,
|
|
||||||
): Promise<RabbitMQConfig> => ({
|
|
||||||
exchanges: [
|
|
||||||
{
|
|
||||||
name: configService.get<string>('RMQ_EXCHANGE'),
|
|
||||||
type: 'topic',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
handlers: {
|
|
||||||
setConfiguration: {
|
|
||||||
exchange: configService.get<string>('RMQ_EXCHANGE'),
|
|
||||||
routingKey: ['configuration.create', 'configuration.update'],
|
|
||||||
},
|
|
||||||
deleteConfiguration: {
|
|
||||||
exchange: configService.get<string>('RMQ_EXCHANGE'),
|
|
||||||
routingKey: 'configuration.delete',
|
|
||||||
},
|
|
||||||
propagateConfiguration: {
|
|
||||||
exchange: configService.get<string>('RMQ_EXCHANGE'),
|
|
||||||
routingKey: 'configuration.propagate',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
uri: configService.get<string>('RMQ_URI'),
|
|
||||||
connectionInitOptions: { wait: false },
|
|
||||||
enableControllerDiscovery: true,
|
|
||||||
}),
|
|
||||||
}),
|
|
||||||
],
|
|
||||||
controllers: [ConfigurationMessagerController],
|
|
||||||
providers: [
|
|
||||||
GetConfigurationUseCase,
|
|
||||||
SetConfigurationUseCase,
|
|
||||||
DeleteConfigurationUseCase,
|
|
||||||
RedisConfigurationRepository,
|
|
||||||
],
|
|
||||||
})
|
|
||||||
export class ConfigurationModule {}
|
|
|
@ -1,11 +0,0 @@
|
||||||
import { IsNotEmpty, IsString } from 'class-validator';
|
|
||||||
|
|
||||||
export class DeleteConfigurationRequest {
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
domain: string;
|
|
||||||
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
key: string;
|
|
||||||
}
|
|
|
@ -1,15 +0,0 @@
|
||||||
import { IsNotEmpty, IsString } from 'class-validator';
|
|
||||||
|
|
||||||
export class SetConfigurationRequest {
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
domain: string;
|
|
||||||
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
key: string;
|
|
||||||
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
value: string;
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
import { AutoMap } from '@automapper/classes';
|
|
||||||
|
|
||||||
export class Configuration {
|
|
||||||
@AutoMap()
|
|
||||||
domain: string;
|
|
||||||
|
|
||||||
@AutoMap()
|
|
||||||
key: string;
|
|
||||||
|
|
||||||
@AutoMap()
|
|
||||||
value: string;
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export abstract class IConfigurationRepository {
|
|
||||||
abstract get(key: string): Promise<string>;
|
|
||||||
abstract set(key: string, value: string): void;
|
|
||||||
abstract del(key: string): void;
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import { CommandHandler } from '@nestjs/cqrs';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { DeleteConfigurationCommand } from '../../commands/delete-configuration.command';
|
|
||||||
|
|
||||||
@CommandHandler(DeleteConfigurationCommand)
|
|
||||||
export class DeleteConfigurationUseCase {
|
|
||||||
constructor(private configurationRepository: RedisConfigurationRepository) {}
|
|
||||||
|
|
||||||
execute = async (
|
|
||||||
deleteConfigurationCommand: DeleteConfigurationCommand,
|
|
||||||
): Promise<void> => {
|
|
||||||
await this.configurationRepository.del(
|
|
||||||
deleteConfigurationCommand.deleteConfigurationRequest.domain +
|
|
||||||
':' +
|
|
||||||
deleteConfigurationCommand.deleteConfigurationRequest.key,
|
|
||||||
);
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,15 +0,0 @@
|
||||||
import { QueryHandler } from '@nestjs/cqrs';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { GetConfigurationQuery } from '../../queries/get-configuration.query';
|
|
||||||
|
|
||||||
@QueryHandler(GetConfigurationQuery)
|
|
||||||
export class GetConfigurationUseCase {
|
|
||||||
constructor(private configurationRepository: RedisConfigurationRepository) {}
|
|
||||||
|
|
||||||
execute = async (
|
|
||||||
getConfigurationQuery: GetConfigurationQuery,
|
|
||||||
): Promise<string> =>
|
|
||||||
this.configurationRepository.get(
|
|
||||||
getConfigurationQuery.domain + ':' + getConfigurationQuery.key,
|
|
||||||
);
|
|
||||||
}
|
|
|
@ -1,19 +0,0 @@
|
||||||
import { CommandHandler } from '@nestjs/cqrs';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { SetConfigurationCommand } from '../../commands/set-configuration.command';
|
|
||||||
|
|
||||||
@CommandHandler(SetConfigurationCommand)
|
|
||||||
export class SetConfigurationUseCase {
|
|
||||||
constructor(private _configurationRepository: RedisConfigurationRepository) {}
|
|
||||||
|
|
||||||
execute = async (
|
|
||||||
setConfigurationCommand: SetConfigurationCommand,
|
|
||||||
): Promise<void> => {
|
|
||||||
await this._configurationRepository.set(
|
|
||||||
setConfigurationCommand.setConfigurationRequest.domain +
|
|
||||||
':' +
|
|
||||||
setConfigurationCommand.setConfigurationRequest.key,
|
|
||||||
setConfigurationCommand.setConfigurationRequest.value,
|
|
||||||
);
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
export class GetConfigurationQuery {
|
|
||||||
readonly domain: string;
|
|
||||||
readonly key: string;
|
|
||||||
|
|
||||||
constructor(domain: string, key: string) {
|
|
||||||
this.domain = domain;
|
|
||||||
this.key = key;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,49 +0,0 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { DeleteConfigurationCommand } from '../../commands/delete-configuration.command';
|
|
||||||
import { DeleteConfigurationRequest } from '../../domain/dtos/delete-configuration.request';
|
|
||||||
import { DeleteConfigurationUseCase } from '../../domain/usecases/delete-configuration.usecase';
|
|
||||||
|
|
||||||
const mockRedisConfigurationRepository = {
|
|
||||||
del: jest.fn().mockResolvedValue(undefined),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('DeleteConfigurationUseCase', () => {
|
|
||||||
let deleteConfigurationUseCase: DeleteConfigurationUseCase;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
providers: [
|
|
||||||
{
|
|
||||||
provide: RedisConfigurationRepository,
|
|
||||||
useValue: mockRedisConfigurationRepository,
|
|
||||||
},
|
|
||||||
|
|
||||||
DeleteConfigurationUseCase,
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
deleteConfigurationUseCase = module.get<DeleteConfigurationUseCase>(
|
|
||||||
DeleteConfigurationUseCase,
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(deleteConfigurationUseCase).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('execute', () => {
|
|
||||||
it('should delete a key', async () => {
|
|
||||||
jest.spyOn(mockRedisConfigurationRepository, 'del');
|
|
||||||
const deleteConfigurationRequest: DeleteConfigurationRequest = {
|
|
||||||
domain: 'my-domain',
|
|
||||||
key: 'my-key',
|
|
||||||
};
|
|
||||||
await deleteConfigurationUseCase.execute(
|
|
||||||
new DeleteConfigurationCommand(deleteConfigurationRequest),
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(mockRedisConfigurationRepository.del).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,43 +0,0 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { GetConfigurationUseCase } from '../../domain/usecases/get-configuration.usecase';
|
|
||||||
import { GetConfigurationQuery } from '../../queries/get-configuration.query';
|
|
||||||
|
|
||||||
const mockRedisConfigurationRepository = {
|
|
||||||
get: jest.fn().mockResolvedValue('my-value'),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('GetConfigurationUseCase', () => {
|
|
||||||
let getConfigurationUseCase: GetConfigurationUseCase;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
providers: [
|
|
||||||
{
|
|
||||||
provide: RedisConfigurationRepository,
|
|
||||||
useValue: mockRedisConfigurationRepository,
|
|
||||||
},
|
|
||||||
|
|
||||||
GetConfigurationUseCase,
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
getConfigurationUseCase = module.get<GetConfigurationUseCase>(
|
|
||||||
GetConfigurationUseCase,
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(getConfigurationUseCase).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('execute', () => {
|
|
||||||
it('should get a value for a key', async () => {
|
|
||||||
const value: string = await getConfigurationUseCase.execute(
|
|
||||||
new GetConfigurationQuery('my-domain', 'my-key'),
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(value).toBe('my-value');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,47 +0,0 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { getRedisToken } from '@liaoliaots/nestjs-redis';
|
|
||||||
|
|
||||||
const mockRedis = {
|
|
||||||
get: jest.fn().mockResolvedValue('myValue'),
|
|
||||||
set: jest.fn().mockImplementation(),
|
|
||||||
del: jest.fn().mockImplementation(),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('RedisConfigurationRepository', () => {
|
|
||||||
let redisConfigurationRepository: RedisConfigurationRepository;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
providers: [
|
|
||||||
{
|
|
||||||
provide: getRedisToken('default'),
|
|
||||||
useValue: mockRedis,
|
|
||||||
},
|
|
||||||
RedisConfigurationRepository,
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
redisConfigurationRepository = module.get<RedisConfigurationRepository>(
|
|
||||||
RedisConfigurationRepository,
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(redisConfigurationRepository).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('interact', () => {
|
|
||||||
it('should get a value', async () => {
|
|
||||||
expect(await redisConfigurationRepository.get('myKey')).toBe('myValue');
|
|
||||||
});
|
|
||||||
it('should set a value', async () => {
|
|
||||||
expect(
|
|
||||||
await redisConfigurationRepository.set('myKey', 'myValue'),
|
|
||||||
).toBeUndefined();
|
|
||||||
});
|
|
||||||
it('should delete a value', async () => {
|
|
||||||
expect(await redisConfigurationRepository.del('myKey')).toBeUndefined();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,50 +0,0 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { RedisConfigurationRepository } from '../../adapters/secondaries/redis-configuration.repository';
|
|
||||||
import { SetConfigurationCommand } from '../../commands/set-configuration.command';
|
|
||||||
import { SetConfigurationRequest } from '../../domain/dtos/set-configuration.request';
|
|
||||||
import { SetConfigurationUseCase } from '../../domain/usecases/set-configuration.usecase';
|
|
||||||
|
|
||||||
const mockRedisConfigurationRepository = {
|
|
||||||
set: jest.fn().mockResolvedValue(undefined),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('SetConfigurationUseCase', () => {
|
|
||||||
let setConfigurationUseCase: SetConfigurationUseCase;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
providers: [
|
|
||||||
{
|
|
||||||
provide: RedisConfigurationRepository,
|
|
||||||
useValue: mockRedisConfigurationRepository,
|
|
||||||
},
|
|
||||||
|
|
||||||
SetConfigurationUseCase,
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
setConfigurationUseCase = module.get<SetConfigurationUseCase>(
|
|
||||||
SetConfigurationUseCase,
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(setConfigurationUseCase).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('execute', () => {
|
|
||||||
it('should set a value for a key', async () => {
|
|
||||||
jest.spyOn(mockRedisConfigurationRepository, 'set');
|
|
||||||
const setConfigurationRequest: SetConfigurationRequest = {
|
|
||||||
domain: 'my-domain',
|
|
||||||
key: 'my-key',
|
|
||||||
value: 'my-value',
|
|
||||||
};
|
|
||||||
await setConfigurationUseCase.execute(
|
|
||||||
new SetConfigurationCommand(setConfigurationRequest),
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(mockRedisConfigurationRepository.set).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,18 +1,20 @@
|
||||||
import { Controller, Get } from '@nestjs/common';
|
import { Controller, Get, Inject } from '@nestjs/common';
|
||||||
import {
|
import {
|
||||||
HealthCheckService,
|
HealthCheckService,
|
||||||
HealthCheck,
|
HealthCheck,
|
||||||
HealthCheckResult,
|
HealthCheckResult,
|
||||||
} from '@nestjs/terminus';
|
} from '@nestjs/terminus';
|
||||||
import { Messager } from '../secondaries/messager';
|
|
||||||
import { PrismaHealthIndicatorUseCase } from '../../domain/usecases/prisma.health-indicator.usecase';
|
import { PrismaHealthIndicatorUseCase } from '../../domain/usecases/prisma.health-indicator.usecase';
|
||||||
|
import { MESSAGE_PUBLISHER } from 'src/app.constants';
|
||||||
|
import { IPublishMessage } from 'src/interfaces/message-publisher';
|
||||||
|
|
||||||
@Controller('health')
|
@Controller('health')
|
||||||
export class HealthController {
|
export class HealthController {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly prismaHealthIndicatorUseCase: PrismaHealthIndicatorUseCase,
|
private readonly prismaHealthIndicatorUseCase: PrismaHealthIndicatorUseCase,
|
||||||
private readonly healthCheckService: HealthCheckService,
|
private readonly healthCheckService: HealthCheckService,
|
||||||
private readonly messager: Messager,
|
@Inject(MESSAGE_PUBLISHER)
|
||||||
|
private readonly messagePublisher: IPublishMessage,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@Get()
|
@Get()
|
||||||
|
@ -24,7 +26,7 @@ export class HealthController {
|
||||||
]);
|
]);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
const healthCheckResult: HealthCheckResult = error.response;
|
const healthCheckResult: HealthCheckResult = error.response;
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'logging.user.health.crit',
|
'logging.user.health.crit',
|
||||||
JSON.stringify(healthCheckResult.error),
|
JSON.stringify(healthCheckResult.error),
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,12 +0,0 @@
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export abstract class IMessageBroker {
|
|
||||||
exchange: string;
|
|
||||||
|
|
||||||
constructor(exchange: string) {
|
|
||||||
this.exchange = exchange;
|
|
||||||
}
|
|
||||||
|
|
||||||
abstract publish(routingKey: string, message: string): void;
|
|
||||||
}
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
import { Inject, Injectable } from '@nestjs/common';
|
||||||
|
import { MESSAGE_BROKER_PUBLISHER } from '../../../../app.constants';
|
||||||
|
import { MessageBrokerPublisher } from '@mobicoop/message-broker-module';
|
||||||
|
import { IPublishMessage } from 'src/interfaces/message-publisher';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MessagePublisher implements IPublishMessage {
|
||||||
|
constructor(
|
||||||
|
@Inject(MESSAGE_BROKER_PUBLISHER)
|
||||||
|
private readonly messageBrokerPublisher: MessageBrokerPublisher,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
publish = (routingKey: string, message: string): void => {
|
||||||
|
this.messageBrokerPublisher.publish(routingKey, message);
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,18 +0,0 @@
|
||||||
import { AmqpConnection } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
import { ConfigService } from '@nestjs/config';
|
|
||||||
import { IMessageBroker } from './message-broker';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export class Messager extends IMessageBroker {
|
|
||||||
constructor(
|
|
||||||
private readonly amqpConnection: AmqpConnection,
|
|
||||||
private readonly configService: ConfigService,
|
|
||||||
) {
|
|
||||||
super(configService.get<string>('RMQ_EXCHANGE'));
|
|
||||||
}
|
|
||||||
|
|
||||||
publish = (routingKey: string, message: string): void => {
|
|
||||||
this.amqpConnection.publish(this.exchange, routingKey, message);
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -5,30 +5,24 @@ import { UsersRepository } from '../user/adapters/secondaries/users.repository';
|
||||||
import { DatabaseModule } from '../database/database.module';
|
import { DatabaseModule } from '../database/database.module';
|
||||||
import { HealthController } from './adapters/primaries/health.controller';
|
import { HealthController } from './adapters/primaries/health.controller';
|
||||||
import { TerminusModule } from '@nestjs/terminus';
|
import { TerminusModule } from '@nestjs/terminus';
|
||||||
import { RabbitMQModule } from '@golevelup/nestjs-rabbitmq';
|
import { MESSAGE_BROKER_PUBLISHER, MESSAGE_PUBLISHER } from 'src/app.constants';
|
||||||
import { ConfigModule, ConfigService } from '@nestjs/config';
|
import { MessageBrokerPublisher } from '@mobicoop/message-broker-module';
|
||||||
import { Messager } from './adapters/secondaries/messager';
|
import { MessagePublisher } from './adapters/secondaries/message-publisher';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [TerminusModule, DatabaseModule],
|
||||||
TerminusModule,
|
controllers: [HealthServerController, HealthController],
|
||||||
RabbitMQModule.forRootAsync(RabbitMQModule, {
|
providers: [
|
||||||
imports: [ConfigModule],
|
PrismaHealthIndicatorUseCase,
|
||||||
useFactory: async (configService: ConfigService) => ({
|
UsersRepository,
|
||||||
exchanges: [
|
|
||||||
{
|
{
|
||||||
name: configService.get<string>('RMQ_EXCHANGE'),
|
provide: MESSAGE_BROKER_PUBLISHER,
|
||||||
type: 'topic',
|
useClass: MessageBrokerPublisher,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: MESSAGE_PUBLISHER,
|
||||||
|
useClass: MessagePublisher,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
uri: configService.get<string>('RMQ_URI'),
|
|
||||||
connectionInitOptions: { wait: false },
|
|
||||||
}),
|
|
||||||
inject: [ConfigService],
|
|
||||||
}),
|
|
||||||
DatabaseModule,
|
|
||||||
],
|
|
||||||
controllers: [HealthServerController, HealthController],
|
|
||||||
providers: [PrismaHealthIndicatorUseCase, UsersRepository, Messager],
|
|
||||||
})
|
})
|
||||||
export class HealthModule {}
|
export class HealthModule {}
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { MessagePublisher } from '../../adapters/secondaries/message-publisher';
|
||||||
|
import { MESSAGE_BROKER_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
|
const mockMessageBrokerPublisher = {
|
||||||
|
publish: jest.fn().mockImplementation(),
|
||||||
|
};
|
||||||
|
|
||||||
|
describe('Messager', () => {
|
||||||
|
let messagePublisher: MessagePublisher;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
imports: [],
|
||||||
|
providers: [
|
||||||
|
MessagePublisher,
|
||||||
|
{
|
||||||
|
provide: MESSAGE_BROKER_PUBLISHER,
|
||||||
|
useValue: mockMessageBrokerPublisher,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
messagePublisher = module.get<MessagePublisher>(MessagePublisher);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(messagePublisher).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should publish a message', async () => {
|
||||||
|
jest.spyOn(mockMessageBrokerPublisher, 'publish');
|
||||||
|
messagePublisher.publish('health.info', 'my-test');
|
||||||
|
expect(mockMessageBrokerPublisher.publish).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
});
|
|
@ -1,47 +0,0 @@
|
||||||
import { AmqpConnection } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { ConfigService } from '@nestjs/config';
|
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
|
|
||||||
const mockAmqpConnection = {
|
|
||||||
publish: jest.fn().mockImplementation(),
|
|
||||||
};
|
|
||||||
|
|
||||||
const mockConfigService = {
|
|
||||||
get: jest.fn().mockResolvedValue({
|
|
||||||
RMQ_EXCHANGE: 'mobicoop',
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('Messager', () => {
|
|
||||||
let messager: Messager;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
imports: [],
|
|
||||||
providers: [
|
|
||||||
Messager,
|
|
||||||
{
|
|
||||||
provide: AmqpConnection,
|
|
||||||
useValue: mockAmqpConnection,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
provide: ConfigService,
|
|
||||||
useValue: mockConfigService,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
messager = module.get<Messager>(Messager);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(messager).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should publish a message', async () => {
|
|
||||||
jest.spyOn(mockAmqpConnection, 'publish');
|
|
||||||
messager.publish('test.create.info', 'my-test');
|
|
||||||
expect(mockAmqpConnection.publish).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,8 +1,8 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
import { PrismaHealthIndicatorUseCase } from '../../domain/usecases/prisma.health-indicator.usecase';
|
import { PrismaHealthIndicatorUseCase } from '../../domain/usecases/prisma.health-indicator.usecase';
|
||||||
import { UsersRepository } from '../../../user/adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../../user/adapters/secondaries/users.repository';
|
||||||
import { PrismaClientKnownRequestError } from '@prisma/client/runtime';
|
|
||||||
import { HealthCheckError, HealthIndicatorResult } from '@nestjs/terminus';
|
import { HealthCheckError, HealthIndicatorResult } from '@nestjs/terminus';
|
||||||
|
import { Prisma } from '@prisma/client';
|
||||||
|
|
||||||
const mockUsersRepository = {
|
const mockUsersRepository = {
|
||||||
healthCheck: jest
|
healthCheck: jest
|
||||||
|
@ -11,7 +11,7 @@ const mockUsersRepository = {
|
||||||
return Promise.resolve(true);
|
return Promise.resolve(true);
|
||||||
})
|
})
|
||||||
.mockImplementation(() => {
|
.mockImplementation(() => {
|
||||||
throw new PrismaClientKnownRequestError('Service unavailable', {
|
throw new Prisma.PrismaClientKnownRequestError('Service unavailable', {
|
||||||
code: 'code',
|
code: 'code',
|
||||||
clientVersion: 'version',
|
clientVersion: 'version',
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,12 +1,6 @@
|
||||||
import { Mapper } from '@automapper/core';
|
import { Mapper } from '@automapper/core';
|
||||||
import { InjectMapper } from '@automapper/nestjs';
|
import { InjectMapper } from '@automapper/nestjs';
|
||||||
import {
|
import { Controller, UseInterceptors, UsePipes } from '@nestjs/common';
|
||||||
CacheInterceptor,
|
|
||||||
CacheKey,
|
|
||||||
Controller,
|
|
||||||
UseInterceptors,
|
|
||||||
UsePipes,
|
|
||||||
} from '@nestjs/common';
|
|
||||||
import { CommandBus, QueryBus } from '@nestjs/cqrs';
|
import { CommandBus, QueryBus } from '@nestjs/cqrs';
|
||||||
import { GrpcMethod, RpcException } from '@nestjs/microservices';
|
import { GrpcMethod, RpcException } from '@nestjs/microservices';
|
||||||
import { DatabaseException } from '../../../database/exceptions/database.exception';
|
import { DatabaseException } from '../../../database/exceptions/database.exception';
|
||||||
|
@ -23,6 +17,7 @@ import { FindUserByUuidQuery } from '../../queries/find-user-by-uuid.query';
|
||||||
import { UserPresenter } from './user.presenter';
|
import { UserPresenter } from './user.presenter';
|
||||||
import { ICollection } from '../../../database/interfaces/collection.interface';
|
import { ICollection } from '../../../database/interfaces/collection.interface';
|
||||||
import { RpcValidationPipe } from '../../../../utils/pipes/rpc.validation-pipe';
|
import { RpcValidationPipe } from '../../../../utils/pipes/rpc.validation-pipe';
|
||||||
|
import { CacheInterceptor, CacheKey } from '@nestjs/cache-manager';
|
||||||
|
|
||||||
@UsePipes(
|
@UsePipes(
|
||||||
new RpcValidationPipe({
|
new RpcValidationPipe({
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
import { Inject, Injectable } from '@nestjs/common';
|
||||||
|
import { IPublishMessage } from '../../../../interfaces/message-publisher';
|
||||||
|
import { MESSAGE_BROKER_PUBLISHER } from '../../../../app.constants';
|
||||||
|
import { MessageBrokerPublisher } from '@mobicoop/message-broker-module';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MessagePublisher implements IPublishMessage {
|
||||||
|
constructor(
|
||||||
|
@Inject(MESSAGE_BROKER_PUBLISHER)
|
||||||
|
private readonly messageBrokerPublisher: MessageBrokerPublisher,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
publish = (routingKey: string, message: string): void => {
|
||||||
|
this.messageBrokerPublisher.publish(routingKey, message);
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,18 +0,0 @@
|
||||||
import { AmqpConnection } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
import { ConfigService } from '@nestjs/config';
|
|
||||||
import { IMessageBroker } from '../../domain/interfaces/message-broker';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export class Messager extends IMessageBroker {
|
|
||||||
constructor(
|
|
||||||
private readonly amqpConnection: AmqpConnection,
|
|
||||||
private readonly configService: ConfigService,
|
|
||||||
) {
|
|
||||||
super(configService.get<string>('RMQ_EXCHANGE'));
|
|
||||||
}
|
|
||||||
|
|
||||||
publish = (routingKey: string, message: string): void => {
|
|
||||||
this.amqpConnection.publish(this.exchange, routingKey, message);
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
import { Injectable } from '@nestjs/common';
|
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export abstract class IMessageBroker {
|
|
||||||
exchange: string;
|
|
||||||
|
|
||||||
constructor(exchange: string) {
|
|
||||||
this.exchange = exchange;
|
|
||||||
}
|
|
||||||
|
|
||||||
abstract publish(routingKey: string, message: string): void;
|
|
||||||
}
|
|
|
@ -1,17 +1,20 @@
|
||||||
import { Mapper } from '@automapper/core';
|
import { Mapper } from '@automapper/core';
|
||||||
import { InjectMapper } from '@automapper/nestjs';
|
import { InjectMapper } from '@automapper/nestjs';
|
||||||
import { CommandHandler } from '@nestjs/cqrs';
|
import { CommandHandler } from '@nestjs/cqrs';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { CreateUserCommand } from '../../commands/create-user.command';
|
import { CreateUserCommand } from '../../commands/create-user.command';
|
||||||
import { CreateUserRequest } from '../dtos/create-user.request';
|
import { CreateUserRequest } from '../dtos/create-user.request';
|
||||||
import { User } from '../entities/user';
|
import { User } from '../entities/user';
|
||||||
|
import { Inject } from '@nestjs/common';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
import { IPublishMessage } from '../../../../interfaces/message-publisher';
|
||||||
|
|
||||||
@CommandHandler(CreateUserCommand)
|
@CommandHandler(CreateUserCommand)
|
||||||
export class CreateUserUseCase {
|
export class CreateUserUseCase {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly repository: UsersRepository,
|
private readonly repository: UsersRepository,
|
||||||
private readonly messager: Messager,
|
@Inject(MESSAGE_PUBLISHER)
|
||||||
|
private readonly messagePublisher: IPublishMessage,
|
||||||
@InjectMapper() private readonly mapper: Mapper,
|
@InjectMapper() private readonly mapper: Mapper,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
@ -24,15 +27,18 @@ export class CreateUserUseCase {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const user = await this.repository.create(entity);
|
const user = await this.repository.create(entity);
|
||||||
this.messager.publish('user.create', JSON.stringify(user));
|
this.messagePublisher.publish('user.create', JSON.stringify(user));
|
||||||
this.messager.publish('logging.user.create.info', JSON.stringify(user));
|
this.messagePublisher.publish(
|
||||||
|
'logging.user.create.info',
|
||||||
|
JSON.stringify(user),
|
||||||
|
);
|
||||||
return user;
|
return user;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
let key = 'logging.user.create.crit';
|
let key = 'logging.user.create.crit';
|
||||||
if (error.message.includes('Already exists')) {
|
if (error.message.includes('Already exists')) {
|
||||||
key = 'logging.user.create.warning';
|
key = 'logging.user.create.warning';
|
||||||
}
|
}
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
key,
|
key,
|
||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
command,
|
command,
|
||||||
|
|
|
@ -1,27 +1,33 @@
|
||||||
import { CommandHandler } from '@nestjs/cqrs';
|
import { CommandHandler } from '@nestjs/cqrs';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { DeleteUserCommand } from '../../commands/delete-user.command';
|
import { DeleteUserCommand } from '../../commands/delete-user.command';
|
||||||
import { User } from '../entities/user';
|
import { User } from '../entities/user';
|
||||||
|
import { IPublishMessage } from '../../../../interfaces/message-publisher';
|
||||||
|
import { Inject } from '@nestjs/common';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
@CommandHandler(DeleteUserCommand)
|
@CommandHandler(DeleteUserCommand)
|
||||||
export class DeleteUserUseCase {
|
export class DeleteUserUseCase {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly repository: UsersRepository,
|
private readonly repository: UsersRepository,
|
||||||
private readonly messager: Messager,
|
@Inject(MESSAGE_PUBLISHER)
|
||||||
|
private readonly messagePublisher: IPublishMessage,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
execute = async (command: DeleteUserCommand): Promise<User> => {
|
execute = async (command: DeleteUserCommand): Promise<User> => {
|
||||||
try {
|
try {
|
||||||
const user = await this.repository.delete(command.uuid);
|
const user = await this.repository.delete(command.uuid);
|
||||||
this.messager.publish('user.delete', JSON.stringify({ uuid: user.uuid }));
|
this.messagePublisher.publish(
|
||||||
this.messager.publish(
|
'user.delete',
|
||||||
|
JSON.stringify({ uuid: user.uuid }),
|
||||||
|
);
|
||||||
|
this.messagePublisher.publish(
|
||||||
'logging.user.delete.info',
|
'logging.user.delete.info',
|
||||||
JSON.stringify({ uuid: user.uuid }),
|
JSON.stringify({ uuid: user.uuid }),
|
||||||
);
|
);
|
||||||
return user;
|
return user;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'logging.user.delete.crit',
|
'logging.user.delete.crit',
|
||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
command,
|
command,
|
||||||
|
|
|
@ -1,15 +1,17 @@
|
||||||
import { NotFoundException } from '@nestjs/common';
|
import { Inject, NotFoundException } from '@nestjs/common';
|
||||||
import { QueryHandler } from '@nestjs/cqrs';
|
import { QueryHandler } from '@nestjs/cqrs';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { FindUserByUuidQuery } from '../../queries/find-user-by-uuid.query';
|
import { FindUserByUuidQuery } from '../../queries/find-user-by-uuid.query';
|
||||||
import { User } from '../entities/user';
|
import { User } from '../entities/user';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
import { IPublishMessage } from '../../../../interfaces/message-publisher';
|
||||||
|
|
||||||
@QueryHandler(FindUserByUuidQuery)
|
@QueryHandler(FindUserByUuidQuery)
|
||||||
export class FindUserByUuidUseCase {
|
export class FindUserByUuidUseCase {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly repository: UsersRepository,
|
private readonly repository: UsersRepository,
|
||||||
private readonly messager: Messager,
|
@Inject(MESSAGE_PUBLISHER)
|
||||||
|
private readonly messagePublisher: IPublishMessage,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
execute = async (findUserByUuid: FindUserByUuidQuery): Promise<User> => {
|
execute = async (findUserByUuid: FindUserByUuidQuery): Promise<User> => {
|
||||||
|
@ -18,7 +20,7 @@ export class FindUserByUuidUseCase {
|
||||||
if (!user) throw new NotFoundException();
|
if (!user) throw new NotFoundException();
|
||||||
return user;
|
return user;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'logging.user.read.warning',
|
'logging.user.read.warning',
|
||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
query: findUserByUuid,
|
query: findUserByUuid,
|
||||||
|
|
|
@ -1,17 +1,20 @@
|
||||||
import { Mapper } from '@automapper/core';
|
import { Mapper } from '@automapper/core';
|
||||||
import { InjectMapper } from '@automapper/nestjs';
|
import { InjectMapper } from '@automapper/nestjs';
|
||||||
import { CommandHandler } from '@nestjs/cqrs';
|
import { CommandHandler } from '@nestjs/cqrs';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { UpdateUserCommand } from '../../commands/update-user.command';
|
import { UpdateUserCommand } from '../../commands/update-user.command';
|
||||||
import { UpdateUserRequest } from '../dtos/update-user.request';
|
import { UpdateUserRequest } from '../dtos/update-user.request';
|
||||||
import { User } from '../entities/user';
|
import { User } from '../entities/user';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
import { Inject } from '@nestjs/common';
|
||||||
|
import { IPublishMessage } from '../../../../interfaces/message-publisher';
|
||||||
|
|
||||||
@CommandHandler(UpdateUserCommand)
|
@CommandHandler(UpdateUserCommand)
|
||||||
export class UpdateUserUseCase {
|
export class UpdateUserUseCase {
|
||||||
constructor(
|
constructor(
|
||||||
private readonly repository: UsersRepository,
|
private readonly repository: UsersRepository,
|
||||||
private readonly messager: Messager,
|
@Inject(MESSAGE_PUBLISHER)
|
||||||
|
private readonly messagePublisher: IPublishMessage,
|
||||||
@InjectMapper() private readonly mapper: Mapper,
|
@InjectMapper() private readonly mapper: Mapper,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
@ -27,17 +30,17 @@ export class UpdateUserUseCase {
|
||||||
command.updateUserRequest.uuid,
|
command.updateUserRequest.uuid,
|
||||||
entity,
|
entity,
|
||||||
);
|
);
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'user.update',
|
'user.update',
|
||||||
JSON.stringify(command.updateUserRequest),
|
JSON.stringify(command.updateUserRequest),
|
||||||
);
|
);
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'logging.user.update.info',
|
'logging.user.update.info',
|
||||||
JSON.stringify(command.updateUserRequest),
|
JSON.stringify(command.updateUserRequest),
|
||||||
);
|
);
|
||||||
return user;
|
return user;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
this.messager.publish(
|
this.messagePublisher.publish(
|
||||||
'logging.user.update.crit',
|
'logging.user.update.crit',
|
||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
command,
|
command,
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
import { classes } from '@automapper/classes';
|
import { classes } from '@automapper/classes';
|
||||||
import { AutomapperModule } from '@automapper/nestjs';
|
import { AutomapperModule } from '@automapper/nestjs';
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { CreateUserCommand } from '../../commands/create-user.command';
|
import { CreateUserCommand } from '../../commands/create-user.command';
|
||||||
import { CreateUserRequest } from '../../domain/dtos/create-user.request';
|
import { CreateUserRequest } from '../../domain/dtos/create-user.request';
|
||||||
import { User } from '../../domain/entities/user';
|
import { User } from '../../domain/entities/user';
|
||||||
import { CreateUserUseCase } from '../../domain/usecases/create-user.usecase';
|
import { CreateUserUseCase } from '../../domain/usecases/create-user.usecase';
|
||||||
import { UserProfile } from '../../mappers/user.profile';
|
import { UserProfile } from '../../mappers/user.profile';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
const newUserRequest: CreateUserRequest = {
|
const newUserRequest: CreateUserRequest = {
|
||||||
firstName: 'John',
|
firstName: 'John',
|
||||||
|
@ -31,7 +31,7 @@ const mockUsersRepository = {
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
const mockMessager = {
|
const mockMessagePublisher = {
|
||||||
publish: jest.fn().mockImplementation(),
|
publish: jest.fn().mockImplementation(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -49,8 +49,8 @@ describe('CreateUserUseCase', () => {
|
||||||
CreateUserUseCase,
|
CreateUserUseCase,
|
||||||
UserProfile,
|
UserProfile,
|
||||||
{
|
{
|
||||||
provide: Messager,
|
provide: MESSAGE_PUBLISHER,
|
||||||
useValue: mockMessager,
|
useValue: mockMessagePublisher,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
}).compile();
|
}).compile();
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { DeleteUserCommand } from '../../commands/delete-user.command';
|
import { DeleteUserCommand } from '../../commands/delete-user.command';
|
||||||
import { DeleteUserUseCase } from '../../domain/usecases/delete-user.usecase';
|
import { DeleteUserUseCase } from '../../domain/usecases/delete-user.usecase';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
const mockUsers = [
|
const mockUsers = [
|
||||||
{
|
{
|
||||||
|
@ -46,7 +46,7 @@ const mockUsersRepository = {
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
const mockMessager = {
|
const mockMessagePublisher = {
|
||||||
publish: jest.fn().mockImplementation(),
|
publish: jest.fn().mockImplementation(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -62,8 +62,8 @@ describe('DeleteUserUseCase', () => {
|
||||||
},
|
},
|
||||||
DeleteUserUseCase,
|
DeleteUserUseCase,
|
||||||
{
|
{
|
||||||
provide: Messager,
|
provide: MESSAGE_PUBLISHER,
|
||||||
useValue: mockMessager,
|
useValue: mockMessagePublisher,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
}).compile();
|
}).compile();
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
import { NotFoundException } from '@nestjs/common';
|
import { NotFoundException } from '@nestjs/common';
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { FindUserByUuidRequest } from '../../domain/dtos/find-user-by-uuid.request';
|
import { FindUserByUuidRequest } from '../../domain/dtos/find-user-by-uuid.request';
|
||||||
import { FindUserByUuidUseCase } from '../../domain/usecases/find-user-by-uuid.usecase';
|
import { FindUserByUuidUseCase } from '../../domain/usecases/find-user-by-uuid.usecase';
|
||||||
import { FindUserByUuidQuery } from '../../queries/find-user-by-uuid.query';
|
import { FindUserByUuidQuery } from '../../queries/find-user-by-uuid.query';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
const mockUser = {
|
const mockUser = {
|
||||||
uuid: 'bb281075-1b98-4456-89d6-c643d3044a91',
|
uuid: 'bb281075-1b98-4456-89d6-c643d3044a91',
|
||||||
|
@ -26,7 +26,7 @@ const mockUserRepository = {
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
const mockMessager = {
|
const mockMessagePublisher = {
|
||||||
publish: jest.fn().mockImplementation(),
|
publish: jest.fn().mockImplementation(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -42,8 +42,8 @@ describe('FindUserByUuidUseCase', () => {
|
||||||
useValue: mockUserRepository,
|
useValue: mockUserRepository,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
provide: Messager,
|
provide: MESSAGE_PUBLISHER,
|
||||||
useValue: mockMessager,
|
useValue: mockMessagePublisher,
|
||||||
},
|
},
|
||||||
FindUserByUuidUseCase,
|
FindUserByUuidUseCase,
|
||||||
],
|
],
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { MessagePublisher } from '../../adapters/secondaries/message-publisher';
|
||||||
|
import { MESSAGE_BROKER_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
|
const mockMessageBrokerPublisher = {
|
||||||
|
publish: jest.fn().mockImplementation(),
|
||||||
|
};
|
||||||
|
|
||||||
|
describe('Messager', () => {
|
||||||
|
let messagePublisher: MessagePublisher;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
imports: [],
|
||||||
|
providers: [
|
||||||
|
MessagePublisher,
|
||||||
|
{
|
||||||
|
provide: MESSAGE_BROKER_PUBLISHER,
|
||||||
|
useValue: mockMessageBrokerPublisher,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
messagePublisher = module.get<MessagePublisher>(MessagePublisher);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(messagePublisher).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should publish a message', async () => {
|
||||||
|
jest.spyOn(mockMessageBrokerPublisher, 'publish');
|
||||||
|
messagePublisher.publish('user.create.info', 'my-test');
|
||||||
|
expect(mockMessageBrokerPublisher.publish).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
});
|
|
@ -1,47 +0,0 @@
|
||||||
import { AmqpConnection } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { ConfigService } from '@nestjs/config';
|
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
|
|
||||||
const mockAmqpConnection = {
|
|
||||||
publish: jest.fn().mockImplementation(),
|
|
||||||
};
|
|
||||||
|
|
||||||
const mockConfigService = {
|
|
||||||
get: jest.fn().mockResolvedValue({
|
|
||||||
RMQ_EXCHANGE: 'mobicoop',
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('Messager', () => {
|
|
||||||
let messager: Messager;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const module: TestingModule = await Test.createTestingModule({
|
|
||||||
imports: [],
|
|
||||||
providers: [
|
|
||||||
Messager,
|
|
||||||
{
|
|
||||||
provide: AmqpConnection,
|
|
||||||
useValue: mockAmqpConnection,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
provide: ConfigService,
|
|
||||||
useValue: mockConfigService,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
}).compile();
|
|
||||||
|
|
||||||
messager = module.get<Messager>(Messager);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should be defined', () => {
|
|
||||||
expect(messager).toBeDefined();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should publish a message', async () => {
|
|
||||||
jest.spyOn(mockAmqpConnection, 'publish');
|
|
||||||
messager.publish('user.create.info', 'my-test');
|
|
||||||
expect(mockAmqpConnection.publish).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,13 +1,13 @@
|
||||||
import { classes } from '@automapper/classes';
|
import { classes } from '@automapper/classes';
|
||||||
import { AutomapperModule } from '@automapper/nestjs';
|
import { AutomapperModule } from '@automapper/nestjs';
|
||||||
import { Test, TestingModule } from '@nestjs/testing';
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
import { Messager } from '../../adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
import { UsersRepository } from '../../adapters/secondaries/users.repository';
|
||||||
import { UpdateUserCommand } from '../../commands/update-user.command';
|
import { UpdateUserCommand } from '../../commands/update-user.command';
|
||||||
import { UpdateUserRequest } from '../../domain/dtos/update-user.request';
|
import { UpdateUserRequest } from '../../domain/dtos/update-user.request';
|
||||||
import { User } from '../../domain/entities/user';
|
import { User } from '../../domain/entities/user';
|
||||||
import { UpdateUserUseCase } from '../../domain/usecases/update-user.usecase';
|
import { UpdateUserUseCase } from '../../domain/usecases/update-user.usecase';
|
||||||
import { UserProfile } from '../../mappers/user.profile';
|
import { UserProfile } from '../../mappers/user.profile';
|
||||||
|
import { MESSAGE_PUBLISHER } from '../../../../app.constants';
|
||||||
|
|
||||||
const originalUser: User = new User();
|
const originalUser: User = new User();
|
||||||
originalUser.uuid = 'bb281075-1b98-4456-89d6-c643d3044a91';
|
originalUser.uuid = 'bb281075-1b98-4456-89d6-c643d3044a91';
|
||||||
|
@ -54,7 +54,7 @@ describe('UpdateUserUseCase', () => {
|
||||||
UpdateUserUseCase,
|
UpdateUserUseCase,
|
||||||
UserProfile,
|
UserProfile,
|
||||||
{
|
{
|
||||||
provide: Messager,
|
provide: MESSAGE_PUBLISHER,
|
||||||
useValue: mockMessager,
|
useValue: mockMessager,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|
|
@ -1,12 +1,10 @@
|
||||||
import { RabbitMQModule } from '@golevelup/nestjs-rabbitmq';
|
|
||||||
import { RedisClientOptions } from '@liaoliaots/nestjs-redis';
|
import { RedisClientOptions } from '@liaoliaots/nestjs-redis';
|
||||||
import { CacheModule, Module } from '@nestjs/common';
|
import { Module } from '@nestjs/common';
|
||||||
import { ConfigModule, ConfigService } from '@nestjs/config';
|
import { ConfigModule, ConfigService } from '@nestjs/config';
|
||||||
import { CqrsModule } from '@nestjs/cqrs';
|
import { CqrsModule } from '@nestjs/cqrs';
|
||||||
import { redisStore } from 'cache-manager-ioredis-yet';
|
import { redisStore } from 'cache-manager-ioredis-yet';
|
||||||
import { DatabaseModule } from '../database/database.module';
|
import { DatabaseModule } from '../database/database.module';
|
||||||
import { UserController } from './adapters/primaries/user.controller';
|
import { UserController } from './adapters/primaries/user.controller';
|
||||||
import { Messager } from './adapters/secondaries/messager';
|
|
||||||
import { UsersRepository } from './adapters/secondaries/users.repository';
|
import { UsersRepository } from './adapters/secondaries/users.repository';
|
||||||
import { CreateUserUseCase } from './domain/usecases/create-user.usecase';
|
import { CreateUserUseCase } from './domain/usecases/create-user.usecase';
|
||||||
import { DeleteUserUseCase } from './domain/usecases/delete-user.usecase';
|
import { DeleteUserUseCase } from './domain/usecases/delete-user.usecase';
|
||||||
|
@ -14,25 +12,18 @@ import { FindAllUsersUseCase } from './domain/usecases/find-all-users.usecase';
|
||||||
import { FindUserByUuidUseCase } from './domain/usecases/find-user-by-uuid.usecase';
|
import { FindUserByUuidUseCase } from './domain/usecases/find-user-by-uuid.usecase';
|
||||||
import { UpdateUserUseCase } from './domain/usecases/update-user.usecase';
|
import { UpdateUserUseCase } from './domain/usecases/update-user.usecase';
|
||||||
import { UserProfile } from './mappers/user.profile';
|
import { UserProfile } from './mappers/user.profile';
|
||||||
|
import { CacheModule } from '@nestjs/cache-manager';
|
||||||
|
import { MessageBrokerPublisher } from '@mobicoop/message-broker-module';
|
||||||
|
import {
|
||||||
|
MESSAGE_BROKER_PUBLISHER,
|
||||||
|
MESSAGE_PUBLISHER,
|
||||||
|
} from '../../app.constants';
|
||||||
|
import { MessagePublisher } from './adapters/secondaries/message-publisher';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
DatabaseModule,
|
DatabaseModule,
|
||||||
CqrsModule,
|
CqrsModule,
|
||||||
RabbitMQModule.forRootAsync(RabbitMQModule, {
|
|
||||||
imports: [ConfigModule],
|
|
||||||
useFactory: async (configService: ConfigService) => ({
|
|
||||||
exchanges: [
|
|
||||||
{
|
|
||||||
name: configService.get<string>('RMQ_EXCHANGE'),
|
|
||||||
type: 'topic',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
uri: configService.get<string>('RMQ_URI'),
|
|
||||||
connectionInitOptions: { wait: false },
|
|
||||||
}),
|
|
||||||
inject: [ConfigService],
|
|
||||||
}),
|
|
||||||
CacheModule.registerAsync<RedisClientOptions>({
|
CacheModule.registerAsync<RedisClientOptions>({
|
||||||
imports: [ConfigModule],
|
imports: [ConfigModule],
|
||||||
useFactory: async (configService: ConfigService) => ({
|
useFactory: async (configService: ConfigService) => ({
|
||||||
|
@ -50,12 +41,19 @@ import { UserProfile } from './mappers/user.profile';
|
||||||
providers: [
|
providers: [
|
||||||
UserProfile,
|
UserProfile,
|
||||||
UsersRepository,
|
UsersRepository,
|
||||||
Messager,
|
|
||||||
FindAllUsersUseCase,
|
FindAllUsersUseCase,
|
||||||
FindUserByUuidUseCase,
|
FindUserByUuidUseCase,
|
||||||
CreateUserUseCase,
|
CreateUserUseCase,
|
||||||
UpdateUserUseCase,
|
UpdateUserUseCase,
|
||||||
DeleteUserUseCase,
|
DeleteUserUseCase,
|
||||||
|
{
|
||||||
|
provide: MESSAGE_BROKER_PUBLISHER,
|
||||||
|
useClass: MessageBrokerPublisher,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: MESSAGE_PUBLISHER,
|
||||||
|
useClass: MessagePublisher,
|
||||||
|
},
|
||||||
],
|
],
|
||||||
exports: [],
|
exports: [],
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue