faloker/purify

View on GitHub
api/src/auth/auth.module.ts

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
import { Module, forwardRef } from '@nestjs/common';
import { AuthService } from './auth.service';
import { UsersModule } from '../users/users.module';
import { ProjectsModule } from '../projects/projects.module';
import { PassportModule } from '@nestjs/passport';
import { APIKeyStrategy } from './apikey.strategy';
import { LocalStrategy } from './local.strategy';
import { JwtStrategy } from './jwt.strategy';
import { JwtModule } from '@nestjs/jwt';
import { AuthController } from './auth.controller';
import { ConfigModule, ConfigService } from '@nestjs/config';
import { LdapStrategy } from './ldap.strategy';
import { SamlStrategy } from './saml.strategy';

@Module({
  imports: [
    ConfigModule,
    forwardRef(() => UsersModule),
    forwardRef(() => ProjectsModule),
    PassportModule.register({ failureFlash: true }),
    JwtModule.registerAsync({
      imports: [ConfigModule],
      useFactory: async (configService: ConfigService) => ({
        secret: configService.get<string>('JWT_SECRET'),
        signOptions: { expiresIn: '15m' },
      }),
      inject: [ConfigService],
    }),
  ],
  controllers: [AuthController],
  providers: [
    AuthService,
    LocalStrategy,
    JwtStrategy,
    APIKeyStrategy,
    LdapStrategy,
    SamlStrategy,
  ],
  exports: [AuthService],
})
export class AuthModule {}