Асинхронная конфигурация
Если вам нужно передать параметры модуля асинхронно, а не статически, используйте метод .forRootAsync()
. Как и большинство динамических модулей, Nest предоставляет несколько техник для работы с асинхронной конфигурацией.
Одна из техник - использование фабричной функции:
import { NecordModule } from 'necord';
import { Module } from '@nestjs/common';
import { IntentsBitField } from 'discord.js';
@Module({
imports: [
NecordModule.forRootAsync({
useFactory: () => ({
token: 'DISCORD_BOT_TOKEN',
intents: [
IntentsBitField.Guilds,
IntentsBitField.GuildMessages,
IntentsBitField.DirectMessages
]
})
})
]
})
export class AppModule {}
Как и другие фабричные провайдеры, наша фабричная функция может быть асинхронной и может внедрять зависимости через inject.
import { NecordModule } from 'necord';
import { Module } from '@nestjs/common';
import { IntentsBitField } from 'discord.js';
@Module({
imports: [
NecordModule.forRootAsync({
imports: [ConfigModule.forFeature(necordModuleConfig)],
useFactory: async (configService: ConfigService) => ({
token: configService.get<string>('DISCORD_BOT_TOKEN'),
intents: [
IntentsBitField.Guilds,
IntentsBitField.GuildMessages,
IntentsBitField.DirectMessages
]
}),
inject: [ConfigService]
})
]
})
export class AppModule {}
В качестве альтернативы вы можете настроить NecordModule, используя класс вместо фабрики, как показано ниже:
import { NecordModule } from 'necord';
import { Module } from '@nestjs/common';
import { IntentsBitField } from 'discord.js';
@Module({
imports: [
NecordModule.forRootAsync({
useClass: NecordConfigService
})
]
})
export class AppModule {}
Приведенная выше конструкция создает экземпляр класса NecordConfigService
внутри NecordModule
, используя его для создания требуемого объекта опций. Обратите внимание, что в этом примере NecordConfigService
должен реализовать интерфейс NecordOptionsFactory
, как показано ниже. NecordModule
вызовет метод .createNecordOptions()
на объекте экземпляра поставленного класса.
import { Injectable } from '@nestjs/common';
import { NecordModuleOptions } from 'necord';
import { IntentsBitField } from 'discord.js';
@Injectable()
export class NecordConfigService {
createNecordOptions(): NecordModuleOptions {
return {
token: 'DISCORD_BOT_TOKEN',
intents: [
IntentsBitField.Guilds,
IntentsBitField.GuildMessages,
IntentsBitField.DirectMessages
]
};
}
}
Если вы хотите использовать существующий провайдер вместо того, чтобы создавать его внутри NecordModule
, используйте useExisting
.