Skip to content

Commit

Permalink
Address hidden renderer feedback
Browse files Browse the repository at this point in the history
  • Loading branch information
DJAndries committed Jan 24, 2025
1 parent 7b6566b commit b3df12b
Show file tree
Hide file tree
Showing 12 changed files with 121 additions and 23 deletions.
2 changes: 2 additions & 0 deletions browser/brave_search/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,9 @@ source_set("brave_search") {
deps = [
"//brave/components/brave_search/browser",
"//brave/components/brave_search/common",
"//brave/components/brave_shields/content/browser",
"//chrome/browser/content_extraction",
"//chrome/browser/content_settings:content_settings_factory",
"//chrome/browser/profiles",
"//components/keyed_service/core",
"//content/public/browser",
Expand Down
55 changes: 40 additions & 15 deletions browser/brave_search/backup_results_service_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,9 @@
#include "brave/components/brave_search/browser/backup_results_allowed_urls.h"
#include "brave/components/brave_search/browser/backup_results_service.h"
#include "brave/components/brave_search/common/features.h"
#include "brave/components/brave_shields/content/browser/brave_shields_util.h"
#include "chrome/browser/content_extraction/inner_html.h"
#include "chrome/browser/content_settings/host_content_settings_map_factory.h"
#include "chrome/browser/profiles/profile.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/navigation_handle.h"
Expand Down Expand Up @@ -63,15 +65,17 @@ class BackupResultsWebContentsObserver
public:
void DidFinishNavigation(content::NavigationHandle* controller) override {
const auto* response_headers = controller->GetResponseHeaders();
if (response_headers) {
backup_results_service_->HandleWebContentsDidFinishNavigation(
web_contents(), response_headers->response_code());
if (!response_headers || !backup_results_service_) {
return;
}
backup_results_service_->HandleWebContentsDidFinishNavigation(
web_contents(), response_headers->response_code());
}

void DidFinishLoad(content::RenderFrameHost* render_frame_host,
const GURL& validated_url) override {
if (!validated_url.SchemeIs(url::kHttpsScheme)) {
if (!validated_url.SchemeIs(url::kHttpsScheme) ||
!backup_results_service_) {
return;
}
backup_results_service_->HandleWebContentsDidFinishLoad(web_contents());
Expand Down Expand Up @@ -107,15 +111,28 @@ void BackupResultsServiceImpl::FetchBackupResults(
std::optional<net::HttpRequestHeaders> headers,
BackupResultsCallback callback) {
if (!profile_) {
std::move(callback).Run(std::nullopt);
return;
}
auto otr_profile_id =
Profile::OTRProfileID::CreateUniqueForSearchBackupResults();
auto* otr_profile = profile_->GetOffTheRecordProfile(otr_profile_id, true);

bool should_render =
!headers || !headers->HasHeader(net::HttpRequestHeaders::kCookie);

if (should_render) {
auto* host_content_settings_map =
HostContentSettingsMapFactory::GetForProfile(profile_);
if (host_content_settings_map &&
brave_shields::GetNoScriptControlType(host_content_settings_map, url) ==
brave_shields::ControlType::BLOCK) {
std::move(callback).Run(std::nullopt);
return;
}
}

auto otr_profile_id =
Profile::OTRProfileID::CreateUniqueForSearchBackupResults();
auto* otr_profile = profile_->GetOffTheRecordProfile(otr_profile_id, true);

std::unique_ptr<content::WebContents> web_contents;

if (should_render) {
Expand Down Expand Up @@ -318,15 +335,23 @@ void BackupResultsServiceImpl::CleanupAndDispatchResult(
}

void BackupResultsServiceImpl::OnProfileWillBeDestroyed(Profile* profile) {
profile_->RemoveObserver(this);
for (auto& request : pending_requests_) {
request.web_contents = nullptr;
auto* otr_profile = request.otr_profile.get();
request.otr_profile = nullptr;
profile_->DestroyOffTheRecordProfile(otr_profile);
Shutdown();
}

void BackupResultsServiceImpl::Shutdown() {
if (profile_) {
profile_->RemoveObserver(this);
for (auto& request : pending_requests_) {
request.web_contents = nullptr;
auto* otr_profile = request.otr_profile.get();
request.otr_profile = nullptr;
profile_->DestroyOffTheRecordProfile(otr_profile);
}
pending_requests_.clear();
profile_ = nullptr;
}
pending_requests_.clear();
profile_ = nullptr;

weak_ptr_factory_.InvalidateWeakPtrs();
}

} // namespace brave_search
3 changes: 3 additions & 0 deletions browser/brave_search/backup_results_service_impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,9 @@ class BackupResultsServiceImpl : public BackupResultsService,
// ProfileObserver:
void OnProfileWillBeDestroyed(Profile* profile) override;

// KeyedService:
void Shutdown() override;

private:
struct PendingRequest {
PendingRequest(std::unique_ptr<content::WebContents> web_contents,
Expand Down
2 changes: 1 addition & 1 deletion browser/brave_search/brave_search_browsertest.cc
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ class BraveSearchTest : public InProcessBrowserTest {
https_server_->ServeFilesFromDirectory(test_data_dir);

ASSERT_TRUE(https_server_->Start());
GURL url = https_server()->GetURL("a.com", "/search");
GURL url = https_server()->GetURL("google.com", "/search");
brave_search::BraveSearchFallbackHost::SetBackupProviderForTest(url);

// Force default search engine to Google
Expand Down
12 changes: 12 additions & 0 deletions components/brave_search/browser/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -33,3 +33,15 @@ static_library("browser") {
"//url",
]
}

source_set("unit_tests") {
testonly = true
sources = [ "backup_results_allowed_urls_unittest.cc" ]

deps = [
":browser",
"//base/test:test_support",
"//testing/gtest:gtest",
"//url",
]
}
16 changes: 13 additions & 3 deletions components/brave_search/browser/backup_results_allowed_urls.cc
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,14 @@

#include "brave/components/brave_search/browser/backup_results_allowed_urls.h"

#include <string>
#include <string_view>
#include <vector>

#include "base/containers/fixed_flat_set.h"
#include "base/logging.h"
#include "base/strings/string_split.h"
#include "base/strings/string_util.h"
#include "url/url_constants.h"

namespace brave_search {
Expand Down Expand Up @@ -59,6 +62,7 @@ bool IsBackupResultURLAllowed(const GURL& url) {
if (!url.SchemeIs(url::kHttpsScheme)) {
return false;
}

// Extract the hostname from the URL
auto hostname = url.host_piece();

Expand All @@ -70,10 +74,16 @@ bool IsBackupResultURLAllowed(const GURL& url) {
return false;
}

std::string_view tld = host_parts.back();
std::string_view sld = host_parts[host_parts.size() - 2];
// Look for "google" in the parts
auto google_it = std::find(host_parts.begin(), host_parts.end(), kGoogleSLD);
if (google_it == host_parts.end()) {
return false;
}

std::string potential_tld = base::JoinString(
std::vector<std::string>(google_it + 1, host_parts.end()), ".");

return sld == kGoogleSLD && kAllowedGoogleTLDs.contains(tld);
return !potential_tld.empty() && kAllowedGoogleTLDs.contains(potential_tld);
}

} // namespace brave_search
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
/* Copyright (c) 2025 The Brave Authors. All rights reserved.
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at https://mozilla.org/MPL/2.0/. */

#include "brave/components/brave_search/browser/backup_results_allowed_urls.h"

#include "testing/gtest/include/gtest/gtest.h"
#include "url/gurl.h"

namespace brave_search {

TEST(BackupResultsAllowedURLsTest, ValidGoogleDomains) {
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://google.com")));
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://google.co.uk")));
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://google.com.au")));
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://google.fr")));
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://google.de")));
EXPECT_TRUE(IsBackupResultURLAllowed(GURL("https://www.google.de")));
EXPECT_TRUE(
IsBackupResultURLAllowed(GURL("https://www.google.co.uk/search")));
}

TEST(BackupResultsAllowedURLsTest, InvalidDomains) {
EXPECT_FALSE(
IsBackupResultURLAllowed(GURL("http://google.com"))); // Not HTTPS
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("https://fake-google.com")));
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("https://google.invalid")));
EXPECT_FALSE(
IsBackupResultURLAllowed(GURL("https://google"))); // Missing TLD
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("https://googles.com")));
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("https://googles.com/search")));
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("about:blank")));
EXPECT_FALSE(IsBackupResultURLAllowed(GURL("https://brave.com")));
}

} // namespace brave_search
4 changes: 3 additions & 1 deletion components/brave_search/browser/backup_results_service.cc
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,13 @@

#include "brave/components/brave_search/browser/backup_results_service.h"

#include <utility>

namespace brave_search {

BackupResultsService::BackupResults::BackupResults(int final_status_code,
std::string html)
: final_status_code(final_status_code), html(html) {}
: final_status_code(final_status_code), html(std::move(html)) {}

BackupResultsService::BackupResults::~BackupResults() = default;

Expand Down
5 changes: 3 additions & 2 deletions components/brave_search/browser/backup_results_service.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,15 @@ namespace brave_search {

// Fetches search results from a backup search provider,
// for use in Brave Search fallback mixing (GMix) and Web Discovery Project.
// This class does not interact with Brave Search.
//
// Each request will use an OTR profile for temporarily storing cookies, etc.
//
// There are three modes of operation for this service:
// i) If `features::kBackupResultsFullRender` is disabled, the initial search
// i) If `features::kBackupResultsFullRender` is disabled, the bootstrap
// page will be rendered, and the actual search engine results page will be
// fetched.
// ii) If `features::kBackupResultsFullRender` is enabled, the initial search
// ii) If `features::kBackupResultsFullRender` is enabled, the bootstrap
// page and the actual search engine results page will be rendered.
// iii) If a cookie header value is provided in `FetchBackupResults`, the actual
// search engine result page will be directly fetched, with no rendering.
Expand Down
5 changes: 5 additions & 0 deletions components/brave_search/browser/brave_search_fallback_host.cc
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,11 @@ void BraveSearchFallbackHost::FetchBackupResults(
headers.SetHeader(net::HttpRequestHeaders::kCookie, *cookie_header_value);
}

if (!backup_results_service_) {
OnResultsAvailable(std::move(callback), std::nullopt);
return;
}

backup_results_service_->FetchBackupResults(
url, headers,
base::BindOnce(&BraveSearchFallbackHost::OnResultsAvailable,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ class BraveSearchFallbackHost final
void OnResultsAvailable(
BraveSearchFallbackHost::FetchBackupResultsCallback callback,
const std::optional<BackupResultsService::BackupResults> backup_results);
base::WeakPtr<brave_search::BackupResultsService> backup_results_service_;
base::WeakPtr<BackupResultsService> backup_results_service_;
base::WeakPtrFactory<BraveSearchFallbackHost> weak_factory_;
};

Expand Down
1 change: 1 addition & 0 deletions test/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -203,6 +203,7 @@ test("brave_unit_tests") {
"//brave/components/brave_rewards/core/test",
"//brave/components/brave_rewards/test:brave_rewards_unit_tests",
"//brave/components/brave_search/browser",
"//brave/components/brave_search/browser:unit_tests",
"//brave/components/brave_search/common",
"//brave/components/brave_search_conversion",
"//brave/components/brave_search_conversion:unit_tests",
Expand Down

0 comments on commit b3df12b

Please sign in to comment.