import { Module } from '@nestjs/common'; import { PassportModule } from '@nestjs/passport'; import { JwtModule, JwtModuleOptions } from '@nestjs/jwt'; import { ConfigModule, ConfigService } from '@nestjs/config'; import { TypeOrmModule } from '@nestjs/typeorm'; import { AuthController } from './auth.controller'; import { AuthService } from './auth.service'; import { GoogleStrategy } from './google.strategy'; import { JwtStrategy } from './jwt.strategy'; import { User } from '../../entities/user.entity'; import { RefreshToken } from '../../entities/refresh-token.entity'; @Module({ imports: [ PassportModule.register({ defaultStrategy: 'jwt' }), JwtModule.registerAsync({ imports: [ConfigModule], useFactory: (configService: ConfigService): JwtModuleOptions => { return { secret: configService.get('JWT_SECRET'), signOptions: { expiresIn: '15m', }, }; }, inject: [ConfigService], }), TypeOrmModule.forFeature([User, RefreshToken]), ], controllers: [AuthController], providers: [AuthService, GoogleStrategy, JwtStrategy], exports: [AuthService], }) export class AuthModule {}