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

Side by Side Diff: chrome/browser/guest_view/web_view/chrome_web_view_guest_delegate.cc

Issue 1021073002: <webview> Implement clear http cache API. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Sync after http://crrev.com/1033013003 Created 5 years, 8 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 5
6 #include "chrome/browser/guest_view/web_view/chrome_web_view_guest_delegate.h" 6 #include "chrome/browser/guest_view/web_view/chrome_web_view_guest_delegate.h"
7 7
8 #include "chrome/browser/browsing_data/storage_partition_http_cache_data_remover .h"
8 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h" 9 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h"
9 #include "chrome/browser/favicon/favicon_tab_helper.h" 10 #include "chrome/browser/favicon/favicon_tab_helper.h"
10 #include "chrome/browser/profiles/profile.h" 11 #include "chrome/browser/profiles/profile.h"
11 #include "chrome/browser/renderer_context_menu/render_view_context_menu.h" 12 #include "chrome/browser/renderer_context_menu/render_view_context_menu.h"
12 #include "chrome/browser/ui/pdf/chrome_pdf_web_contents_helper_client.h" 13 #include "chrome/browser/ui/pdf/chrome_pdf_web_contents_helper_client.h"
13 #include "chrome/common/chrome_version_info.h" 14 #include "chrome/common/chrome_version_info.h"
14 #include "components/pdf/browser/pdf_web_contents_helper.h" 15 #include "components/pdf/browser/pdf_web_contents_helper.h"
15 #include "components/renderer_context_menu/context_menu_delegate.h" 16 #include "components/renderer_context_menu/context_menu_delegate.h"
17 #include "components/web_cache/browser/web_cache_manager.h"
18 #include "content/public/browser/render_process_host.h"
16 #include "extensions/browser/api/web_request/web_request_api.h" 19 #include "extensions/browser/api/web_request/web_request_api.h"
17 #include "extensions/browser/guest_view/web_view/web_view_constants.h" 20 #include "extensions/browser/guest_view/web_view/web_view_constants.h"
18 21
19 #if defined(ENABLE_PRINTING) 22 #if defined(ENABLE_PRINTING)
20 #if defined(ENABLE_PRINT_PREVIEW) 23 #if defined(ENABLE_PRINT_PREVIEW)
21 #include "chrome/browser/printing/print_preview_message_handler.h" 24 #include "chrome/browser/printing/print_preview_message_handler.h"
22 #include "chrome/browser/printing/print_view_manager.h" 25 #include "chrome/browser/printing/print_view_manager.h"
23 #else 26 #else
24 #include "chrome/browser/printing/print_view_manager_basic.h" 27 #include "chrome/browser/printing/print_view_manager_basic.h"
25 #endif // defined(ENABLE_PRINT_PREVIEW) 28 #endif // defined(ENABLE_PRINT_PREVIEW)
26 #endif // defined(ENABLE_PRINTING) 29 #endif // defined(ENABLE_PRINTING)
27 30
28 namespace extensions { 31 namespace extensions {
29 32
30 ChromeWebViewGuestDelegate::ChromeWebViewGuestDelegate( 33 ChromeWebViewGuestDelegate::ChromeWebViewGuestDelegate(
31 WebViewGuest* web_view_guest) 34 WebViewGuest* web_view_guest)
32 : pending_context_menu_request_id_(0), 35 : pending_context_menu_request_id_(0),
33 chromevox_injected_(false), 36 chromevox_injected_(false),
34 web_view_guest_(web_view_guest), 37 web_view_guest_(web_view_guest),
35 weak_ptr_factory_(this) { 38 weak_ptr_factory_(this) {
36 } 39 }
37 40
38 ChromeWebViewGuestDelegate::~ChromeWebViewGuestDelegate() { 41 ChromeWebViewGuestDelegate::~ChromeWebViewGuestDelegate() {
39 } 42 }
40 43
44 void ChromeWebViewGuestDelegate::ClearCache(
45 base::Time remove_since,
46 const base::Closure& done_callback) {
47 int render_process_id = guest_web_contents()->GetRenderProcessHost()->GetID();
48 // We need to clear renderer cache separately for our process because
49 // StoragePartitionHttpCacheDataRemover::ClearData() does not clear that.
Fady Samuel 2015/03/27 14:47:38 Can StoragePartitionHttpCacheDataRemover move to c
lazyboy 2015/03/27 17:34:05 Yes, I've filed http://crbug.com/471287 to do that
50 web_cache::WebCacheManager::GetInstance()->Remove(render_process_id);
51 web_cache::WebCacheManager::GetInstance()->ClearCacheForProcess(
52 render_process_id);
53
54 content::StoragePartition* partition =
55 content::BrowserContext::GetStoragePartition(
56 guest_web_contents()->GetBrowserContext(),
57 guest_web_contents()->GetSiteInstance());
58
59 // StoragePartitionHttpCacheDataRemover removes itself when it is done.
60 StoragePartitionHttpCacheDataRemover::CreateForRange(
61 partition, remove_since, base::Time::Now())->Remove(done_callback);
62 }
63
41 bool ChromeWebViewGuestDelegate::HandleContextMenu( 64 bool ChromeWebViewGuestDelegate::HandleContextMenu(
42 const content::ContextMenuParams& params) { 65 const content::ContextMenuParams& params) {
43 ContextMenuDelegate* menu_delegate = 66 ContextMenuDelegate* menu_delegate =
44 ContextMenuDelegate::FromWebContents(guest_web_contents()); 67 ContextMenuDelegate::FromWebContents(guest_web_contents());
45 DCHECK(menu_delegate); 68 DCHECK(menu_delegate);
46 69
47 pending_menu_ = menu_delegate->BuildMenu(guest_web_contents(), params); 70 pending_menu_ = menu_delegate->BuildMenu(guest_web_contents(), params);
48 71
49 // Pass it to embedder. 72 // Pass it to embedder.
50 int request_id = ++pending_context_menu_request_id_; 73 int request_id = ++pending_context_menu_request_id_;
(...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after
167 chromeos::ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK) { 190 chromeos::ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK) {
168 if (details.enabled) 191 if (details.enabled)
169 InjectChromeVoxIfNeeded(guest_web_contents()->GetRenderViewHost()); 192 InjectChromeVoxIfNeeded(guest_web_contents()->GetRenderViewHost());
170 else 193 else
171 chromevox_injected_ = false; 194 chromevox_injected_ = false;
172 } 195 }
173 } 196 }
174 #endif 197 #endif
175 198
176 } // namespace extensions 199 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698