gpt4 book ai didi

typescript - 如何在 NestJS 中设置类似 Angular 的配置环境文件?

转载 作者:行者123 更新时间:2023-12-05 07:04:54 25 4
gpt4 key购买 nike

NestJS 是否允许以类似于 Angular 的方式拥有环境文件?

在 Angular 中,您有单独的环境文件,这些文件会根据应用程序环境(开发、生产等)自动映射:

  • src/environments/environment.ts
  • src/environments/environment.prod.ts

@nestjs/config是否提供了类似的优雅简单的方法来分离和管理环境变量?不幸的是,我在官方文档中找不到关于 NestJS 的这种模式的详细解释或可用示例:https://docs.nestjs.com/techniques/configuration

最佳答案

不熟悉 Angular,所以我不知道它是否直观,但您应该考虑使用 Dynamic Modules用于注入(inject)您的配置。

NestJS 文档中的示例已经非常接近您想要的,除了它们在不同的 .env 文件上工作,这些文件直接加载到 ConfigService 中。

您的案例需要一些编码,但您只需执行一次,然后就可以在任何其他 NestJS 项目中重复使用。查看文档,您可以派生一个由 ConfigModule.register() 服务的 Injectable() 提供程序,它基于 process.env.NODE_ENV 是一个适当环境类的实例。

或者您当然可以使用直接加载 .env 的现成示例。但这不是强类型的。


我个人使用基于 Joi 的 Schema ValidationConfiguration Namespaces并为配置设置定义一个接口(interface)。就像下面的示例代码:

env.schema.ts:

export const envSchema = Joi.object({

NODE_ENV: Joi.string()
.valid('development', 'production')
.default('development'),

EMAIL_VERIFICATION_SECRET: Joi.string().when('NODE_ENV', {
is: 'production',
then: Joi.required(),
otherwise: Joi.optional().default('the_email_verification_secret'),
}),
});

电子邮件.config.ts:

interface EmailConfig {
verificationSecret: string;
}

export default registerAs('email', (): EmailConfig => ({
verificationSecret: process.env.EMAIL_VERIFICATION_SECRET,
}));

notification.module.ts:

@Module({
imports: [
ConfigModule.forFeature(emailConfig),
],
})
export class NotificationModule {}

电子邮件通知.service.ts:

@Injectable()
export class EmailNotificationService {
private secret: string;

constructor(
@Inject(emailConfig.KEY)
private mailConfig: ConfigType<typeof emailConfig>,
) {
this.secret = this.mailConfig.verificationSecret;
}
}

当然,您不必使用配置命名空间,但它会将配置分解为您在特定模块中需要的 block 。通过接口(interface)进行强类型化,并使用 Joi您的架构已经过验证并适应了适当的环境。

关于typescript - 如何在 NestJS 中设置类似 Angular 的配置环境文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62845917/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com