Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't get setGlobalPrefix value in adapter #14362

Open
3 of 15 tasks
Mittcio opened this issue Jan 4, 2025 · 7 comments
Open
3 of 15 tasks

Can't get setGlobalPrefix value in adapter #14362

Mittcio opened this issue Jan 4, 2025 · 7 comments
Labels
needs triage This issue has not been looked into

Comments

@Mittcio
Copy link
Contributor

Mittcio commented Jan 4, 2025

Is there an existing issue for this?

  • I have searched the existing issues

Current behavior

In nest-application await this.httpAdapter?.init(); no options is passed from nest app to adapter

async init() {
        await this.httpAdapter?.init();

Minimum reproduction code

https://github.com/nestjs/nest

Steps to reproduce

No response

Expected behavior

To pass to adapter this.config

async init() {
        await this.httpAdapter?.init(this.config);

and in adapter will be able to call this.config.getGlobalPrefix();

Package

  • I don't know. Or some 3rd-party package
  • @nestjs/common
  • @nestjs/core
  • @nestjs/microservices
  • @nestjs/platform-express
  • @nestjs/platform-fastify
  • @nestjs/platform-socket.io
  • @nestjs/platform-ws
  • @nestjs/testing
  • @nestjs/websockets
  • Other (see below)

Other package

No response

NestJS version

latest

Packages versions

latest

Node.js version

20

In which operating systems have you tested?

  • macOS
  • Windows
  • Linux

Other

No response

@Mittcio Mittcio added the needs triage This issue has not been looked into label Jan 4, 2025
@micalevisk
Copy link
Member

I didn't get if this is a bug report or a feature request

@kamilmysliwiec
Copy link
Member

Why do you need that?

@Mittcio
Copy link
Contributor Author

Mittcio commented Jan 5, 2025

The middleware in express way not work well, it has other aproach. And for that, I need to make some custom createMiddlewareFactory, because the path of middlewares already contains here the setGlobalPrefix and i need it to compare path

    createMiddlewareFactory(requestMethod) {
      retrun (...args) => {
         // some magic but path is /api/test and not /test
         this.middlewares.push(args)
      } 
   }

@Mittcio
Copy link
Contributor Author

Mittcio commented Jan 5, 2025

And here

get(...args) {
        // magic with middleware, filter middleware by path
       const m = this.middlewares.filter()
        return this.injectRouteOptions(common_1.RequestMethod.GET, ...args, m);
    }

Now all work well but i hardcode that prefix api that is not nice.

@Mittcio
Copy link
Contributor Author

Mittcio commented Jan 22, 2025

Not only I need, you also need it for example you pass extra param in public setErrorHandler(handler: Function, prefix?: string) :)

@Mittcio
Copy link
Contributor Author

Mittcio commented Jan 22, 2025

Here you (are forced to) pass prefix but it is not needed (may be because other adapter need it, fastyfy I don't see it)

public registerParserMiddleware(prefix?: string, rawBody?: boolean) {

public registerParserMiddleware(prefix?: string, rawBody?: boolean) {
    const bodyParserJsonOptions = getBodyParserOptions(rawBody!);
    const bodyParserUrlencodedOptions = getBodyParserOptions(rawBody!, {
      extended: true,
    });

    const parserMiddleware = {
      jsonParser: express.json(bodyParserJsonOptions),
      urlencodedParser: express.urlencoded(bodyParserUrlencodedOptions),
    };
    Object.keys(parserMiddleware)
      .filter(parser => !this.isMiddlewareApplied(parser))
      .forEach(parserKey => this.use(parserMiddleware[parserKey]));
  }

@Mittcio
Copy link
Contributor Author

Mittcio commented Jan 22, 2025

a ha ha ha, nice in adapter i can do

public registerParserMiddleware(prefix?: string, rawBody?: boolean) {
  this.prefix = prefix;
  // other code
}

or in setErrorHandler

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
needs triage This issue has not been looked into
Projects
None yet
Development

No branches or pull requests

3 participants