Я хочу реализовать распространяемую библиотеку аутентификации, чтобы использовать ее в нескольких моих проектах.Библиотека должна реализовывать метод аутентификации JWT.Код выглядит следующим образом:
jwt.strategy.ts:
import {ExtractJwt, Strategy} from 'passport-jwt';
import {PassportStrategy} from '@nestjs/passport';
import {Injectable} from '@nestjs/common';
import {JwtPayload, User} from './interfaces';
import {ConfigService} from "./config.service";
@Injectable()
export class JwtStrategy extends PassportStrategy(Strategy, 'jwt') {
constructor(private readonly configService: ConfigService) {
super({
jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
secretOrKey: configService.get('secretOrPrivateKey'),
});
}
async validate(payload: JwtPayload): Promise<User> {
return {
uuid: payload.uuid,
email: payload.email,
}
}
}
jwt.auth.module.ts:
import {Module, DynamicModule} from '@nestjs/common';
import {JwtModule} from '@nestjs/jwt';
import {JwtStrategy} from './jwt.strategy';
import {PassportModule} from '@nestjs/passport';
import {ConfigService} from "./config.service";
import {JwtOptions} from "./interfaces/jwt.options";
@Module({
})
export class JwtAuthModule {
static forRoot(jwtOptions): DynamicModule {
return {
module: JwtAuthModule,
imports: [
// JwtModule.register(jwtOptions),
// PassportModule.register({defaultStrategy: 'jwt'}),
],
providers: [
JwtStrategy,
{
provide: ConfigService,
useValue: new ConfigService(jwtOptions),
}
],
exports: [ConfigService, JwtStrategy]
};
}
}
, и я импортировал это вмой app.module.ts:
import { Module, NestModule, HttpModule } from '@nestjs/common';
import { MongooseModule } from '@nestjs/mongoose';
import { environment } from './environments';
import { AuthModule } from './auth/auth.module';
import { PermissionModule } from './permission/permission.module';
import {JwtAuthModule} from '@pe/nest-kit';
import {JwtModule} from '@nestjs/jwt';
import {PassportModule} from '@nestjs/passport';
@Module({
imports: [
JwtModule.register(environment.jwtOptions),
PassportModule.register({defaultStrategy: 'jwt'}),
JwtAuthModule.forRoot(environment.jwtOptions),
HttpModule,
AuthModule,
PermissionModule,
MongooseModule.forRoot(environment.mongodb),
],
})
export class ApplicationModule implements NestModule {
configure() {
}
}
однако, каждый раз, когда я пытаюсь открыть URL проекта, я получаю сообщение об ошибке:
[Nest] 27645 - 24.10.2018, 15:23:26 [ExceptionsHandler] Неизвестная стратегия аутентификации "jwt" + 4119ms Ошибка: неизвестная стратегия аутентификации "jwt" при попытке (/home/user/workspace/permissions/node_modules/passport/lib/middleware/authenticate.js:187: 37) при аутентификации (/home/user/workspace/permissions/node_modules/passport/lib/middleware/authenticate.js:363:7) в Promise (/ home / user / workspace / permissions / node_modules / @ nestjs / passport/dist/auth.guard.js:83:3) в новом Promise () по адресу /home/user/workspace/permissions/node_modules/@nestjs/passport/dist/auth.guard.js:75:83 в MixinAuthGuard.(/home/user/workspace/permissions/node_modules/@nestjs/passport/dist/auth.guard.js:47:36) в Generator.next () в / home / user / workspace / permissions / node_modules / @ nestjs /passport / dist / auth.guard.js: 19: 71 в новом Promise () в __awaiter (/home/user/workspace/permissions/node_modules/@nestjs/passport/dist/auth.guard.js:15:12) вMixinAuthGuard.canActivate (/home/user/workspace/permissions/node_modules/@nestjs/passport/dist/auth.guard.js:40:20) в GuardsConsumer.tryActivate (/ home / user / workspace / permissions / node_modules / @ nestjs)/core/guards/guards-consumer.js:13:34) в canActivateFn (/home/user/workspace/permissions/node_modules/@nestjs/core/router/router-execution-context.js:97:59) в /home/user/workspace/permissions/node_modules/@nestjs/core/router/router-execution-context.js: 47: 37 в / home / user / workspace / permissions / node_modules / @ nestjs / core / router / router-proxy.js: 8: 23 в Layer.handle [как handle_request] (/home/user/workspace/permissions/node_modules/express/lib/router/layer.js:95:5)
что я делаю не так?