FIX: Include HTML content for authenticated users with crawler UA (#26757)

e05628c0 introduced an optimization to remove basic-HTML content for authenticated users. The assumption is that, if they were able to log in, they must have a JS capable browser and do not need the basic HTML.

However, there are use-cases where an API-key is used to crawl a private site, or private categories of a public site. This commit re-enables those use cases by keeping the basic-html in place for crawler/bot user agents.
This commit is contained in:
David Taylor 2024-04-25 22:41:57 +01:00 committed by GitHub
parent e0e0e0506f
commit 594026d65f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 9 additions and 1 deletions

View File

@ -431,7 +431,7 @@ module ApplicationHelper
end end
def include_crawler_content? def include_crawler_content?
if current_user if current_user && !crawler_layout?
params.key?(:print) params.key?(:print)
else else
crawler_layout? || !mobile_view? || !modern_mobile_device? crawler_layout? || !mobile_view? || !modern_mobile_device?

View File

@ -19,11 +19,19 @@ RSpec.describe ApplicationHelper do
it "sends crawler content to logged on users who wants to print" do it "sends crawler content to logged on users who wants to print" do
helper.stubs(:current_user).returns(Fabricate(:user)) helper.stubs(:current_user).returns(Fabricate(:user))
controller.stubs(:use_crawler_layout?).returns(false)
helper.stubs(:params).returns(print: true) helper.stubs(:params).returns(print: true)
expect(helper.include_crawler_content?).to eq(true) expect(helper.include_crawler_content?).to eq(true)
end end
it "sends crawler content to logged on users with a crawler user agent" do
helper.stubs(:current_user).returns(Fabricate(:user))
controller.stubs(:use_crawler_layout?).returns(true)
expect(helper.include_crawler_content?).to eq(true)
end
it "sends crawler content to old mobiles" do it "sends crawler content to old mobiles" do
controller.stubs(:use_crawler_layout?).returns(false) controller.stubs(:use_crawler_layout?).returns(false)