Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(901)

Unified Diff: chrome/browser/ui/webui/collected_cookies_ui_delegate.cc

Issue 6644002: [ChromeOS] Implement collected cookies in webui. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address comments in patch set 4 and 5 Created 9 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/webui/collected_cookies_ui_delegate.cc
diff --git a/chrome/browser/ui/webui/collected_cookies_ui_delegate.cc b/chrome/browser/ui/webui/collected_cookies_ui_delegate.cc
new file mode 100644
index 0000000000000000000000000000000000000000..a484a309743c6be121d080b91a73826e3b3bfea1
--- /dev/null
+++ b/chrome/browser/ui/webui/collected_cookies_ui_delegate.cc
@@ -0,0 +1,288 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/ui/webui/collected_cookies_ui_delegate.h"
+
+#include "base/message_loop.h"
+#include "base/string_util.h"
+#include "base/values.h"
+#include "chrome/browser/cookies_tree_model.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/ui/webui/chrome_url_data_manager.h"
+#include "chrome/browser/ui/webui/constrained_html_ui.h"
+#include "chrome/browser/ui/webui/cookies_tree_model_util.h"
+#include "chrome/common/jstemplate_builder.h"
+#include "chrome/common/notification_service.h"
+#include "chrome/common/url_constants.h"
+#include "content/browser/tab_contents/tab_contents.h"
+#include "grit/browser_resources.h"
+#include "grit/generated_resources.h"
+#include "ui/base/l10n/l10n_util.h"
+#include "ui/base/resource/resource_bundle.h"
+
+namespace {
+
+// TODO(xiyuan): Localize this.
+const int kDialogWidth = 480;
+const int kDialogHeight = 470;
+
+CookieTreeOriginNode* GetOriginNode(CookiesTreeModel* model,
+ const std::string& node_path) {
+ CookieTreeNode* node = cookies_tree_model_util::GetTreeNodeFromPath(
+ model->GetRoot(), node_path);
+
+ while (node && node->GetDetailedInfo().node_type !=
+ CookieTreeNode::DetailedInfo::TYPE_ORIGIN) {
+ node = node->parent();
+ }
+
+ return static_cast<CookieTreeOriginNode*>(node);
+}
+
+std::string GetInfobarLabel(ContentSetting setting,
+ const string16& domain_name) {
+ switch (setting) {
+ case CONTENT_SETTING_BLOCK:
+ return l10n_util::GetStringFUTF8(
+ IDS_COLLECTED_COOKIES_BLOCK_RULE_CREATED, domain_name);
+
+ case CONTENT_SETTING_ALLOW:
+ return l10n_util::GetStringFUTF8(
+ IDS_COLLECTED_COOKIES_ALLOW_RULE_CREATED, domain_name);
+
+ case CONTENT_SETTING_SESSION_ONLY:
+ return l10n_util::GetStringFUTF8(
+ IDS_COLLECTED_COOKIES_SESSION_RULE_CREATED, domain_name);
+
+ default:
+ NOTREACHED() << "Unknown ContentSetting, " << setting;
+ return std::string();
+ }
+}
+
+class CollectedCookiesSource : public ChromeURLDataManager::DataSource {
+ public:
+ explicit CollectedCookiesSource(bool block_third_party_cookies)
+ : DataSource(chrome::kChromeUICollectedCookiesHost,
+ MessageLoop::current()),
+ block_third_party_cookies_(block_third_party_cookies) {
+ }
+
+ virtual void StartDataRequest(const std::string& path,
+ bool is_off_the_record,
+ int request_id);
+
+ virtual std::string GetMimeType(const std::string& path) const {
+ return "text/html";
+ }
+
+ private:
+ virtual ~CollectedCookiesSource() {}
+
+ bool block_third_party_cookies_;
+
+ DISALLOW_COPY_AND_ASSIGN(CollectedCookiesSource);
+};
+
+void CollectedCookiesSource::StartDataRequest(const std::string& path,
+ bool is_off_the_record,
+ int request_id) {
+ DictionaryValue localized_strings;
+ localized_strings.SetString("title",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_DIALOG_TITLE));
+
+ localized_strings.SetString("title",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_DIALOG_TITLE));
+ localized_strings.SetString("allowedCookies",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_ALLOWED_COOKIES_LABEL));
+ localized_strings.SetString("blockButton",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_BLOCK_BUTTON));
+
+ localized_strings.SetString("blockedCookies",
+ l10n_util::GetStringUTF16(block_third_party_cookies_ ?
+ IDS_COLLECTED_COOKIES_BLOCKED_THIRD_PARTY_BLOCKING_ENABLED :
+ IDS_COLLECTED_COOKIES_BLOCKED_COOKIES_LABEL));
+
+ localized_strings.SetString("allowButton",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_ALLOW_BUTTON));
+ localized_strings.SetString("allowThisSessionButton",
+ l10n_util::GetStringUTF16(IDS_COLLECTED_COOKIES_SESSION_ONLY_BUTTON));
+ localized_strings.SetString("closeButton",
+ l10n_util::GetStringUTF16(IDS_CLOSE));
+
+ SetFontAndTextDirection(&localized_strings);
+
+ static const base::StringPiece html(
+ ResourceBundle::GetSharedInstance().GetRawDataResource(
+ IDR_COLLECTED_COOKIES_HTML));
+ const std::string response = jstemplate_builder::GetI18nTemplateHtml(
+ html, &localized_strings);
+
+ scoped_refptr<RefCountedBytes> html_bytes(new RefCountedBytes);
+ html_bytes->data.resize(response.size());
+ std::copy(response.begin(), response.end(), html_bytes->data.begin());
+
+ SendResponse(request_id, html_bytes);
+}
+
+} // namespace
+
+// static
+void CollectedCookiesUIDelegate::Show(TabContents* tab_contents) {
+ CollectedCookiesUIDelegate* delegate =
+ new CollectedCookiesUIDelegate(tab_contents);
+ ConstrainedHtmlUI::CreateConstrainedHtmlDialog(tab_contents->profile(),
+ delegate,
+ tab_contents);
+}
+
+CollectedCookiesUIDelegate::CollectedCookiesUIDelegate(
+ TabContents* tab_contents)
+ : tab_contents_(tab_contents),
+ closed_(false) {
+ TabSpecificContentSettings* content_settings =
+ tab_contents->GetTabSpecificContentSettings();
+ HostContentSettingsMap* host_content_settings_map =
+ tab_contents_->profile()->GetHostContentSettingsMap();
+
+ registrar_.Add(this, NotificationType::COLLECTED_COOKIES_SHOWN,
+ Source<TabSpecificContentSettings>(content_settings));
+
+ allowed_cookies_tree_model_.reset(
+ content_settings->GetAllowedCookiesTreeModel());
+ blocked_cookies_tree_model_.reset(
+ content_settings->GetBlockedCookiesTreeModel());
+
+ CollectedCookiesSource* source = new CollectedCookiesSource(
+ host_content_settings_map->BlockThirdPartyCookies());
+ tab_contents->profile()->GetChromeURLDataManager()->AddDataSource(source);
+}
+
+CollectedCookiesUIDelegate::~CollectedCookiesUIDelegate() {
+}
+
+bool CollectedCookiesUIDelegate::IsDialogModal() const {
+ return false;
+}
+
+std::wstring CollectedCookiesUIDelegate::GetDialogTitle() const {
+ return L"";
oshima 2011/03/11 01:10:22 std::wstring()
xiyuan 2011/03/11 16:46:03 Done.
+}
+
+GURL CollectedCookiesUIDelegate::GetDialogContentURL() const {
+ return GURL(chrome::kChromeUICollectedCookiesURL);
+}
+
+void CollectedCookiesUIDelegate::GetWebUIMessageHandlers(
+ std::vector<WebUIMessageHandler*>* handlers) const {
+ const WebUIMessageHandler* handler = this;
+ handlers->push_back(const_cast<WebUIMessageHandler*>(handler));
+}
+
+void CollectedCookiesUIDelegate::GetDialogSize(gfx::Size* size) const {
+ size->set_width(kDialogWidth);
+ size->set_height(kDialogHeight);
+}
+
+std::string CollectedCookiesUIDelegate::GetDialogArgs() const {
+ return "";
oshima 2011/03/11 01:10:22 std::string()
xiyuan 2011/03/11 16:46:03 Done.
+}
+
+void CollectedCookiesUIDelegate::OnDialogClosed(
+ const std::string& json_retval) {
+ closed_ = true;
+}
+
+bool CollectedCookiesUIDelegate::ShouldShowDialogTitle() const {
+ return true;
+}
+
+void CollectedCookiesUIDelegate::RegisterMessages() {
+ web_ui_->RegisterMessageCallback("BindCookiesTreeModel",
+ NewCallback(this, &CollectedCookiesUIDelegate::BindCookiesTreeModel));
+ web_ui_->RegisterMessageCallback("Block",
+ NewCallback(this, &CollectedCookiesUIDelegate::Block));
+ web_ui_->RegisterMessageCallback("Allow",
+ NewCallback(this, &CollectedCookiesUIDelegate::Allow));
+ web_ui_->RegisterMessageCallback("AllowThisSession",
+ NewCallback(this, &CollectedCookiesUIDelegate::AllowThisSession));
+
+ allowed_cookies_adapter_.Init(web_ui_);
+ blocked_cookies_adapter_.Init(web_ui_);
+}
+
+void CollectedCookiesUIDelegate::CloseDialog() {
+ if (!closed_ && web_ui_)
+ web_ui_->CallJavascriptFunction("closeDialog");
+}
+
+void CollectedCookiesUIDelegate::SetInfobarLabel(const std::string& text) {
+ StringValue string(text);
+ web_ui_->CallJavascriptFunction("setInfobarLabel", string);
+}
+
+void CollectedCookiesUIDelegate::AddContentException(
+ CookieTreeOriginNode* origin_node, ContentSetting setting) {
+ if (origin_node->CanCreateContentException()) {
+ origin_node->CreateContentException(
+ tab_contents_->profile()->GetHostContentSettingsMap(), setting);
+
+ SetInfobarLabel(GetInfobarLabel(setting, origin_node->GetTitle()));
+ }
+}
+
+void CollectedCookiesUIDelegate::Observe(NotificationType type,
+ const NotificationSource& source,
+ const NotificationDetails& details) {
+ DCHECK_EQ(type.value, NotificationType::COLLECTED_COOKIES_SHOWN);
+ DCHECK_EQ(Source<TabSpecificContentSettings>(source).ptr(),
+ tab_contents_->GetTabSpecificContentSettings());
+ CloseDialog();
+}
+
+void CollectedCookiesUIDelegate::BindCookiesTreeModel(const ListValue* args) {
+ allowed_cookies_adapter_.Bind("allowed-cookies",
+ allowed_cookies_tree_model_.get());
+ blocked_cookies_adapter_.Bind("blocked-cookies",
+ blocked_cookies_tree_model_.get());
+}
+
+void CollectedCookiesUIDelegate::Block(const ListValue* args) {
+ std::string node_path;
+ if (!args->GetString(0, &node_path))
+ return;
+
+ CookieTreeOriginNode* origin_node = GetOriginNode(
+ allowed_cookies_tree_model_.get(), node_path);
+ if (!origin_node)
+ return;
+
+ AddContentException(origin_node, CONTENT_SETTING_BLOCK);
+}
+
+void CollectedCookiesUIDelegate::Allow(const ListValue* args) {
+ std::string node_path;
+ if (!args->GetString(0, &node_path))
+ return;
+
+ CookieTreeOriginNode* origin_node = GetOriginNode(
+ blocked_cookies_tree_model_.get(), node_path);
+ if (!origin_node)
+ return;
+
+ AddContentException(origin_node, CONTENT_SETTING_ALLOW);
+}
+
+void CollectedCookiesUIDelegate::AllowThisSession(const ListValue* args) {
+ std::string node_path;
+ if (!args->GetString(0, &node_path))
+ return;
+
+ CookieTreeOriginNode* origin_node = GetOriginNode(
+ blocked_cookies_tree_model_.get(), node_path);
+ if (!origin_node)
+ return;
+
+ AddContentException(origin_node, CONTENT_SETTING_SESSION_ONLY);
+}

Powered by Google App Engine
This is Rietveld 408576698