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

Angular v17 SSR - InjectionToken for REQUEST/RESPONSE not working? #292

Closed
Shamshiel opened this issue Nov 11, 2023 · 24 comments
Closed

Angular v17 SSR - InjectionToken for REQUEST/RESPONSE not working? #292

Shamshiel opened this issue Nov 11, 2023 · 24 comments
Assignees

Comments

@Shamshiel
Copy link

Shamshiel commented Nov 11, 2023

See comment for resolution

Either I'm doing something wrong or cookies can't be retrieved from request headers via the SsrCookieService. It seems that SsrCookieService is not able to retrieve the request from the providers.

I have the server.ts and my guard like described below but the bearer token can't be retrieved. I checked the incoming request in the server and the cookie is available in the header. So I assume the request is for some reason not correctly provided to the SsrCookieService.

Is that a bug or am I doing something wrong?

server.ts

server.get('*', (req, res, next) => {
    const { protocol, originalUrl, baseUrl, headers } = req;

    commonEngine
      .render({
        bootstrap,
        documentFilePath: indexHtml,
        url: `${protocol}://${headers.host}${originalUrl}`,
        publicPath: browserDistFolder,
        providers: [
          { provide: APP_BASE_HREF, useValue: baseUrl },
          { provide: 'REQUEST', useValue: req },
          { provide: 'RESPONSE', useValue: res },
        ],
      })
      .then((html) => res.send(html))
      .catch((err) => next(err));
  });

Guard

export function authenticationGuard(): CanActivateFn {
    return () => {
        const authService: AuthService = inject(AuthService);
        const router: Router = inject(Router);
        const cookieService: SsrCookieService = inject(SsrCookieService);

        return authService.getUser().pipe(
            map((x) => {
                const bearerToken = cookieService.get('access_token');
                console.log('Bearer Token: ' + bearerToken);
                if (x.role !== 'admin') {
                    router.navigate(['/home']);
                    return false;
                }
                return true;
            })
        );
    };
}

Specifications

  • Version: Angular 17.0.0 and ngx-cookie-service-ssr 17.0.0
Copy link

Hello 👋 @Shamshiel
Thank you for raising an issue. We will investigate into the issue and get back to you as soon as possible. Please make sure you have given us as much context as possible.
Feel free to raise a PR if you can fix the issue

@jnizet
Copy link

jnizet commented Nov 11, 2023

I think the issue is that the code uses a non-exported REQUEST InjectionToken, so providing the request under the string token 'REQUEST' won't work to populate it.

@pavankjadda
Copy link
Collaborator

@Shamshiel Can you share stackblitz reproduction?

@pavankjadda
Copy link
Collaborator

@Shamshiel create new issue by following issue template and stackblitz reproduction

@pavankjadda pavankjadda closed this as not planned Won't fix, can't repro, duplicate, stale Nov 11, 2023
@oriollpz
Copy link

Any news in this problem? I can't access my cookies in the SSR of Angular 17.

@pavankjadda
Copy link
Collaborator

Any news in this problem? I can't access my cookies in the SSR of Angular 17.

No. I am able to access them in my code. Can you share an example where you can't access them?

@oriollpz
Copy link

When you use a Guard and try to access the cookie when does SSR, it returns null the "req" Injection.

@malzoubi96
Copy link

Any news in this problem

@pavankjadda
Copy link
Collaborator

@oriollpz @zozjo Can anyone of you try share a StackBlitz example of tis problem?

@pavankjadda pavankjadda reopened this Dec 7, 2023
@pavankjadda
Copy link
Collaborator

pavankjadda commented Dec 7, 2023

@oriollpz @zozjo @Shamshiel @jnizet Can you try version 17.0.1-rc.1 and see if it fixes the issue?

@Shamshiel
Copy link
Author

I haven't tried your RC but I fixed the issue by just copying your SsrCookieService in my project and exporting the REQUEST like this:

export const REQUEST = new InjectionToken<Request>('REQUEST');

and then importing it in the server.ts like this:

import { REQUEST } from './src/app/services/ssr-cookie.service';


So the issue is that in v17.0.0 of this library the InjectionToken is not exported. Just using the token 'REQUEST' does not work. I guess the RC would work if SSR_REQUEST is the actual exported InjectionToken for REQUEST.

@pavankjadda
Copy link
Collaborator

Fixed in version 17.0.1

@xalidevxx
Copy link

xalidevxx commented Dec 24, 2023

Fixed in version 17.0.1

Hi! I am facing the same error.

I am using:
"@angular/ssr":"~17.0.0", "ngx-cookie-service-ssr": "^17.0.1"

I did
console.log(this.cookieService.get('lang'))
and got:

  • server side: "undefined"
  • client side: "ru"

Can you help me please. I have attached the screenshots.

Screenshot from 2023-12-25 00-39-54

Screenshot from 2023-12-25 00-37-55

Screenshot from 2023-12-25 00-37-14

Screenshot from 2023-12-25 00-43-17

@pavankjadda
Copy link
Collaborator

@xalidevxx
Copy link

xalidevxx commented Dec 25, 2023

@xalidevxx See updated docs https://github.com/stevermeister/ngx-cookie-service?tab=readme-ov-file#server-side-rendering. You need to import REQUEST

I added the request as in the documentation. Then I built the project and run the production version locally. I output cookieService.get('lang') in app.component.html.

As a result:

  • there is no cookie on the server side
  • on the client side there is a cookie.

I expect the server version and browser version to should be the same.

Is this how it should work?

Screenshot from 2023-12-25 12-59-18

Screenshot from 2023-12-25 13-01-16

Screenshot from 2023-12-25 13-05-15

@xalidevxx
Copy link

@xalidevxx See updated docs https://github.com/stevermeister/ngx-cookie-service?tab=readme-ov-file#server-side-rendering. You need to import REQUEST

Hi! Can you help me please?

@davpirelli
Copy link

News about this issue? Still got same behaviour on latest release

@xalidevxx
Copy link

News about this issue? Still got same behaviour on latest release

Hi! I didn't find a solution and left it like that.

@pavankjadda
Copy link
Collaborator

All, I am looking at this. Stay tuned.

@pavankjadda pavankjadda self-assigned this Jul 5, 2024
@pavankjadda pavankjadda linked a pull request Jul 5, 2024 that will close this issue
@rhutchison
Copy link

Might be related angular/angular-cli#26323

@ydang204
Copy link

is there any news guys? I'm facing the same issue

@cskiwi
Copy link

cskiwi commented Jul 27, 2024

Stumbled upon this issue as well. would be amazing to have it fixed :)

@humanely
Copy link

humanely commented Aug 3, 2024

Any fixes yet?

@BenasPal
Copy link

BenasPal commented Nov 21, 2024

Guys issue is related to angular/angular-cli#26323, while running ng serve it wont work unless in angular v19. You need to npm run build:ssr and then npm run serve:ssr. Also make sure you provide request { provide: REQUEST, useValue: req }, with import { REQUEST } from 'ngx-cookie-service-ssr';

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.