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

Strange behaviour when using client key and unleash session cookie #5086

Closed
erilor opened this issue Oct 18, 2023 · 6 comments
Closed

Strange behaviour when using client key and unleash session cookie #5086

erilor opened this issue Oct 18, 2023 · 6 comments
Labels

Comments

@erilor
Copy link

erilor commented Oct 18, 2023

Describe the bug

I was testing your product out and found something strange, perhaps a bug?

I was running the unleash docker container (5.5.6) and also served a web-app (from the same machine) using your JS-SDK and a client API-key. Everything works nicely and the front end app fetches toggles. But if I log in to the admin web from the same browser (so I get a unleash-session cookie), my front end app starts failing with status 401 ("Token was not valid"). If I remove the cookie the front end app starts working again.

It seems like the session cookie is used even when an client-key i sent in the Authorization header.

Steps to reproduce the bug

No response

Expected behavior

No response

Logs, error output, etc.

No response

Screenshots

No response

Additional context

No response

Unleash version

5.5.6

Subscription type

Open source

Hosting type

Self-hosted

SDK information (language and version)

JS-SDK

@sjaanus
Copy link
Contributor

sjaanus commented Oct 19, 2023

Hey @erilor,

From the information you've provided, I've attempted to reproduce the issue on my end. I set everything up similarly to your configuration. As shown in the screenshot I've attached, everything is running on the same host, just on different ports.

After logging into the admin UI, I did observe that the unleash-session cookie is set. However, in my testing, this didn't affect my web app. The web app is consistently sending its Authorization header and, importantly, no cookies are included in the request header. This behavior is consistent with what's expected, as the web app should not be sending cookies with its requests in this context.

Could you provide additional details regarding your setup to help us understand why cookies might be sent along with the request in your scenario?

Looking forward to hearing from you!

@erilor
Copy link
Author

erilor commented Oct 19, 2023

Hi @sjaanus !

That is weird, for me the cookie is passed with every request from JS. My cookie is set as
HostOnly:true
HttpOnly:true
Secure:false
SameSite:Lax
path:"/"

Is it the same for you? With those settings it seems like it should be passed, right?

I believe the attachment might have been missed? Or am I failing to see it somehow?

Thanks for looking into this!

@sjaanus
Copy link
Contributor

sjaanus commented Oct 23, 2023

Hey @erilor , this is how my setup looks like.

Running JS app on the left. Frontend requests are being sent without coookie. On the bottom right you can see unleash-session set in cookie store.

Image

@sjaanus sjaanus moved this from New to Todo in Issues and PRs Oct 23, 2023
@erilor
Copy link
Author

erilor commented Oct 23, 2023

Hi @sjaanus,

Interesting, I realise now that I forgot to mention that we use a reverse proxy between the frontend and the backend(s). I tried it your way and in that case the cookie isn't sent for me either.

I guess that makes this kind of an edge case, but it would be nice if the cookie was ignored if an API-key was in the request.

@sjaanus
Copy link
Contributor

sjaanus commented Oct 26, 2023

Yes, I concur that this appears to be a corner case. Typically, one wouldn't run a reverse proxy and operate everything on localhost.

I'll bring this to the team's attention, but I'll be closing this issue for now.

@sjaanus sjaanus closed this as completed Oct 26, 2023
@github-project-automation github-project-automation bot moved this from Todo to Done in Issues and PRs Oct 26, 2023
@erilor
Copy link
Author

erilor commented Oct 26, 2023

That seems reasonable.

But just to be clear: I wasn't running on localhost. Anyone will probably run in to this if they want to expose the unleash UI on the same domain as the the site that uses the toggles, if the site also uses a reverse proxy. I would imagine reverse proxies aren't that uncommon.

So while not as general as I first thought I don't think it's THAT exotic =)

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

No branches or pull requests

2 participants