-
Notifications
You must be signed in to change notification settings - Fork 551
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
Issues with cookies when using latest Passenger and Rack 3 (w/ Ruby on Rails 7.1) #2503
Comments
For this specific issue, the correct solution is for Passenger to correctly handle response headers which can be an Array of values. In addition, using newline characters is no longer supported in Rack 3. |
I know that we can force to use BTW, currently when you install passenger gem, it will automatically install Rack 3. Which I believe renders it impossible to run any Rails application without issues with cookies. |
I will try to fix this, but am currently swamped trying to fix our CI, you may have noticed the 6.0.19 release is quite late at this point. A PR would be much faster than waiting for me to fix it, but I'll get to it eventually, it just likely won't be in the next release. |
To add to the equation: even if you don't use Passenger gem, Ruby on Rails 7.1 now uses Rack 3 by default. So, upgrading an app to Rails 7.1 will break the app if it relies on cookies for authentication of their users. And it doesn't fire any log message, many think it's a Rails issue and it's not. So the devs are blind about this and the root of the problem. |
Just got bitten by this! In our test pipeline we use puma because installing a full apache there is a hassle, and trying out the site on a staging server appeared to work fine because the browsers we tried with apparently still had a cookie from Rails 7.0.8 / rack 2. After 10 minutes in production our help desk started to light up with "can't log in" messages... ouch. More people are going to get bitten by this, you may want to send an email to your users to warn them. @FooBarWidget |
If someone feels like helping, I pushed 7353892 to hopefully fix this, so you could test it and report back. |
@CamJN this is but one of several changes required to support Rack 3. I think a better short term option would be to detect You should also consider adding a PR to test Rack 3 with Passenger to https://github.com/socketry/rack-conform - this will bring attention to Rack 3 specific issues. You should also consider running your own test suite with |
@ioquatix according to https://github.com/rack/rack/blob/main/UPGRADE-GUIDE.md
|
That's "the one changed feature which is not backwards compatible" but there are other new features which you must support and handle correctly at the server level, most notably streaming. |
Well, that's good enough to fix this bug, if you want to request other features, perhaps open a separate feature request. |
Puma 5.x is not compatible with Rack 3 cookies. The current default new Gemfile uses puma ">= 5.0". Puma ~> 5.6 will error on start when used with Rack 3, but earlier versions will not. puma/puma#3164: Support Rack 3 cookies puma/puma#3166: Prevent loading with rack 3 phusion/passenger#2503: Related passenger ex
Thanks for passenger and appreciate the quick fix! Is there anything I can do to help get the change released? |
@mitchellhenke no. The release is done, just sadly being held up by some CI issues we're sorting out. |
Hello @CamJN any update regarding the release? |
@rmatovu987 see the comment immediately before yours. |
This is blocking a critical bug fix with another gem for us :( |
@benkruger why can't you just stick with Rack 2.2 for now? Even once @CamJN gets CI working and lands this fix 🙏, it's our choice to jump into Rack 3 or wait for things to smooth out. They'll get there in time. With my apps, we're going to stay a bit cautious given #2503 (comment) is authored by someone who has some authority on Rack conformance, and his nice suggestion would help Passenger find and fix any other Rack 3 compat issues that could be lurking, and demonstrate that Passenger is ready for production use with Rack 3. |
Playing around a bit with my Rails config, I can get Rails 7.1 working with Rack 3 if I change the config.force_ssl = true # this is already the default for production apps
config.ssl_options = {secure_cookies: false} # added this config option otherwise cookies break if secure cookies is true Not saying you should make this change to get your apps working in production, but it appears as though this is only a secure cookies issue. |
@akaspick SSL or not should not matter to the way cookies are set. What you may be seeing (what tricked me at some point) is that cookies set by rack 2 will work fine on rack 3. So I would be interested if you can reproduce this after clearing your cookies. |
@Fjan I tested this with all my cookies deleted first so it could create new ones. In my web console, I could see the secure cookie being set with my original config and things didn't work. Cleared cookies, changed to unsecure cookies, and the unsecure cookie was set and worked. Anyway, this change in the secure setting seems to make a difference for some reason. |
So secure cookies do seem to work just fine after more testing. The issue appears when using The commit to make the middleware compatible with Rack 3 rails/rails@9d840a1 changed to the array format at https://github.com/rails/rails/blob/9d840a17197ffa5dec8cb2d4171450dfa12c156f/actionpack/lib/action_dispatch/middleware/ssl.rb#L116 which breaks passenger. That's why using |
If anyone like me is stuck on an old version of Linux that went outside the Passenger support window just before this patch, here’s a workaround you can add to your Rails app. Put this in # Workaround for https://github.com/phusion/passenger/issues/2503
# (which is fixed in the latest Passenger, but it no longer supports the server’s ancient Ubuntu)
class PassengerCookieWorkaround
def initialize(app)
@app = app
end
def call(env)
if env["SERVER_SOFTWARE"] =~ %r{Phusion_Passenger/(\d+\.\d+\.(\d+)?)}
if Gem::Version.new($1) < Gem::Version.new('6.0.19')
workaround_enabled = true
puts "Passenger SSL cookie workaround enabled; upgrade Passenger to 6.0.19 or later when possible"
end
end
@app.call(env).tap do |status, headers, body|
if workaround_enabled
headers.each do |k,v|
headers[k] = v.join("\n") if v.is_a?(Array)
end
end
end
end
end
Rails.application.config.middleware.unshift PassengerCookieWorkaround |
Just wanted to mention we were running into the same issue stuck on an older Ubuntu box and your fix worked great! 🙏 |
Issue report
Fill in as much as possible so that we can understand, find and fix the problem.
Are you sure this is a bug in Passenger?
Me and the Ruby on Rails maintainers point that this could be a Rack 3 + Passenger compatibility issue, as forcing the application manifest to use Rack
~> 2.2
makes everything work well.Please try with the newest version of Passenger to avoid issues that have already been fixed
I'm already using Passenger 6.0.18.
Question 1: What is the problem?
This issue is descibed in details in rails/rails#49422. Cookies names, like
user_id
are being prepended with["
, turning it into["user_id
, so, important authentication scripts likejust doesn't work.
This happens after upgrading a Ruby on Rails project from Rails 7.0.8 (using Rack 2.2) to Rails 7.1 (which uses Rack 3.0). This is not a Rails issue, as downgrading from Rack 3 to Rack 2 solves it.
There is no error when using Rack 3 without Passenger (for example, Nginx with Puma), so this is not a Rack issue either.
It's important to note that Rack 3 is the default for Ruby on Rails 7.1, so, new apps and upgraded apps could break!
Question 2: Passenger version and integration mode:
open source 6.0.18/nginx 1.18.0
Question 3: OS or Linux distro, platform (including version):
Ubuntu 22.04.3 LTS x86-64
Question 4: Passenger installation method:
Your answer:
[ ] RubyGems + Gemfile
[ ] RubyGems, no Gemfile
[x] Phusion APT repo
[ ] Phusion YUM repo
[ ] OS X Homebrew
[ ] source tarball
[ ] Other, please specify:
Question 5: Your app's programming language (including any version managers) and framework (including versions):
Ruby 3.2.2 with YJIT, RVM, Rails 7.1 RC2
Question 6: Are you using a PaaS and/or containerization? If so which one?
No.
Question 7: Anything else about your setup that we should know?
No.
We strive for quality and appreciate you taking the time to submit a report! Please note that if you want guaranteed response times and priority issue support we encourage you to join our enterprise customer base. They also provide us with the means to continue our high level of open source support!
The text was updated successfully, but these errors were encountered: