import { Module } from '@nestjs/common';
import { ConfigModule, ConfigService } from '@nestjs/config';
import { JwtModule } from '@nestjs/jwt';
import { PassportModule } from '@nestjs/passport';
import { TypeOrmModule } from '@nestjs/typeorm';
import { UserRoles } from '../users/user-role.entity';
import { User } from '../users/user.entity';
import { UsersService } from '../users/users.service';
import { AuthController } from './auth.controller';
import { AuthService } from './auth.service';
import { JwtStrategy } from './jwt.strategy';
@Module({
imports: [
ConfigModule,
TypeOrmModule.forFeature([User, UserRoles]),
PassportModule.register({ defaultStrategy: 'jwt' }),
JwtModule.registerAsync({
imports: [ConfigModule],
useFactory: async (configService: ConfigService) => {
return {
secret: configService.get('WEBTOKEN_ENCRYPTION_KEY'),
signOptions: {
...(configService.get('WEBTOKEN_EXPIRATION_TIME')
? {
expiresIn: Number(
configService.get('WEBTOKEN_EXPIRATION_TIME'),
),
}
: {}),
},
};
},
inject: [ConfigService],
}),
],
providers: [AuthService, JwtStrategy, UsersService],
exports: [AuthService, JwtStrategy],
controllers: [AuthController],
})
export class AuthModule {}