1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
|
// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/content_settings/android/cookie_controls_bridge.h"
#include <memory>
#include "components/content_settings/core/browser/cookie_settings.h"
#include "components/content_settings/core/common/cookie_controls_state.h"
#include "components/permissions/permissions_client.h"
#include "content/public/browser/android/browser_context_handle.h"
#include "content/public/browser/browser_context.h"
#include "content/public/browser/web_contents.h"
// Must come after all headers that specialize FromJniType() / ToJniType().
#include "components/content_settings/android/content_settings_jni_headers/CookieControlsBridge_jni.h"
namespace content_settings {
using base::android::JavaParamRef;
using base::android::ScopedJavaLocalRef;
CookieControlsBridge::CookieControlsBridge(
JNIEnv* env,
const JavaParamRef<jobject>& obj,
const JavaParamRef<jobject>& jweb_contents_android,
const JavaParamRef<jobject>& joriginal_browser_context_handle,
bool is_incognito_branded)
: jobject_(obj) {
UpdateWebContents(env, jweb_contents_android,
joriginal_browser_context_handle, is_incognito_branded);
}
void CookieControlsBridge::UpdateWebContents(
JNIEnv* env,
const JavaParamRef<jobject>& jweb_contents_android,
const JavaParamRef<jobject>& joriginal_browser_context_handle,
bool is_incognito_branded) {
content::WebContents* web_contents =
content::WebContents::FromJavaWebContents(jweb_contents_android);
content::BrowserContext* original_context =
content::BrowserContextFromJavaHandle(joriginal_browser_context_handle);
content::BrowserContext* context = web_contents->GetBrowserContext();
auto* permissions_client = permissions::PermissionsClient::Get();
observation_.Reset();
controller_ = std::make_unique<CookieControlsController>(
permissions_client->GetCookieSettings(context),
original_context ? permissions_client->GetCookieSettings(original_context)
: nullptr,
permissions_client->GetSettingsMap(context),
permissions_client->GetTrackingProtectionSettings(context),
is_incognito_branded);
observation_.Observe(controller_.get());
controller_->Update(web_contents);
}
void CookieControlsBridge::OnStatusChanged(
CookieControlsState controls_state,
CookieControlsEnforcement enforcement,
CookieBlocking3pcdStatus blocking_status,
base::Time expiration) {
// Only invoke the callback when there is a change.
if (controls_state_ == controls_state && enforcement_ == enforcement &&
expiration_ == expiration) {
return;
}
controls_state_ = controls_state;
enforcement_ = enforcement;
expiration_ = expiration;
JNIEnv* env = base::android::AttachCurrentThread();
Java_CookieControlsBridge_onStatusChanged(
env, jobject_, static_cast<int>(controls_state_),
static_cast<int>(enforcement_), static_cast<int>(blocking_status),
expiration.InMillisecondsSinceUnixEpoch());
}
void CookieControlsBridge::OnCookieControlsIconStatusChanged(
bool icon_visible,
CookieControlsState controls_state,
CookieBlocking3pcdStatus blocking_status,
bool should_highlight) {
// This function's main use is for web's User Bypass icon, which
// does not observe `OnStatusChanged`. Since the Clank icon does
// observe `OnStatusChanged`, the only variable we need to pass
// on from this function is `should_highlight`.
JNIEnv* env = base::android::AttachCurrentThread();
Java_CookieControlsBridge_onHighlightCookieControl(
env, jobject_, static_cast<bool>(should_highlight));
}
void CookieControlsBridge::OnReloadThresholdExceeded() {
JNIEnv* env = base::android::AttachCurrentThread();
Java_CookieControlsBridge_onHighlightPwaCookieControl(env, jobject_);
}
void CookieControlsBridge::SetThirdPartyCookieBlockingEnabledForSite(
JNIEnv* env,
bool block_cookies) {
controller_->OnCookieBlockingEnabledForSite(block_cookies);
}
void CookieControlsBridge::OnUiClosing(JNIEnv* env) {
controller_->OnUiClosing();
}
void CookieControlsBridge::OnEntryPointAnimated(JNIEnv* env) {
controller_->OnEntryPointAnimated();
}
CookieControlsBridge::~CookieControlsBridge() = default;
void CookieControlsBridge::Destroy(JNIEnv* env,
const JavaParamRef<jobject>& obj) {
delete this;
}
jboolean JNI_CookieControlsBridge_IsCookieControlsEnabled(
JNIEnv* env,
const JavaParamRef<jobject>& jbrowser_context_handle) {
content::BrowserContext* context =
content::BrowserContextFromJavaHandle(jbrowser_context_handle);
return permissions::PermissionsClient::Get()
->GetCookieSettings(context)
->ShouldBlockThirdPartyCookies();
}
static jlong JNI_CookieControlsBridge_Init(
JNIEnv* env,
const JavaParamRef<jobject>& obj,
const JavaParamRef<jobject>& jweb_contents_android,
const JavaParamRef<jobject>& joriginal_browser_context_handle,
jboolean is_incognito_branded) {
return reinterpret_cast<intptr_t>(new CookieControlsBridge(
env, obj, jweb_contents_android, joriginal_browser_context_handle,
is_incognito_branded));
}
} // namespace content_settings
|