| Index: chrome_frame/delete_chrome_history.cc
|
| diff --git a/chrome_frame/delete_chrome_history.cc b/chrome_frame/delete_chrome_history.cc
|
| deleted file mode 100644
|
| index fcd4fd626043dcdfaa441cb6900591662f5b4c45..0000000000000000000000000000000000000000
|
| --- a/chrome_frame/delete_chrome_history.cc
|
| +++ /dev/null
|
| @@ -1,97 +0,0 @@
|
| -// Copyright (c) 2012 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.
|
| -
|
| -// Implementation of DeleteChromeHistory
|
| -#include "chrome_frame/delete_chrome_history.h"
|
| -
|
| -#include "chrome/browser/browsing_data/browsing_data_remover.h"
|
| -
|
| -#include "base/win/windows_version.h"
|
| -#include "chrome_frame/chrome_frame_activex.h"
|
| -#include "chrome_frame/utils.h"
|
| -
|
| -// Below other header to avoid symbol pollution.
|
| -#define INITGUID
|
| -#include <deletebrowsinghistory.h>
|
| -
|
| -DeleteChromeHistory::DeleteChromeHistory()
|
| - : remove_mask_(0) {
|
| - DVLOG(1) << __FUNCTION__;
|
| -}
|
| -
|
| -DeleteChromeHistory::~DeleteChromeHistory() {
|
| -}
|
| -
|
| -
|
| -HRESULT DeleteChromeHistory::FinalConstruct() {
|
| - DVLOG(1) << __FUNCTION__;
|
| - Initialize();
|
| - return S_OK;
|
| -}
|
| -
|
| -void DeleteChromeHistory::OnAutomationServerReady() {
|
| -}
|
| -
|
| -void DeleteChromeHistory::OnAutomationServerLaunchFailed(
|
| - AutomationLaunchResult reason, const std::string& server_version) {
|
| - DLOG(WARNING) << __FUNCTION__;
|
| - loop_.Quit();
|
| -}
|
| -
|
| -void DeleteChromeHistory::GetProfilePath(const std::wstring& profile_name,
|
| - base::FilePath* profile_path) {
|
| - ChromeFramePlugin::GetProfilePath(kIexploreProfileName, profile_path);
|
| -}
|
| -
|
| -STDMETHODIMP DeleteChromeHistory::DeleteBrowsingHistory(DWORD flags) {
|
| - DVLOG(1) << __FUNCTION__;
|
| - // Usually called inside a quick startup/tear-down routine by RunDLL32. You
|
| - // can simulate the process by calling:
|
| - // RunDll32.exe InetCpl.cpl,ClearMyTracksByProcess 255
|
| - // Since automation setup isn't synchronous, we can be tearing down while
|
| - // being only partially set-up, causing even synchronous IPCs to be dropped.
|
| - // Since the *Chrome* startup/tear-down occurs synchronously from the
|
| - // perspective of automation, we can add a flag to the chrome.exe invocation
|
| - // in lieu of sending an IPC when it seems appropriate. Since we assume this
|
| - // happens in one-off fashion, don't attempt to pack REMOVE_* arguments.
|
| - // Instead, have the browser process clobber all history.
|
| - //
|
| - // IE8 on Vista launches us twice when the user asks to delete browsing data -
|
| - // once in low integrity and once in medium integrity. The low integrity
|
| - // instance will fail to connect to the automation server and restart it in an
|
| - // effort to connect. Thus, we detect if we are in that circumstance and exit
|
| - // silently.
|
| - base::IntegrityLevel integrity_level;
|
| - if (base::win::GetVersion() >= base::win::VERSION_VISTA &&
|
| - !base::GetProcessIntegrityLevel(base::GetCurrentProcessHandle(),
|
| - &integrity_level)) {
|
| - return E_UNEXPECTED;
|
| - }
|
| - if (integrity_level == base::LOW_INTEGRITY) {
|
| - return S_OK;
|
| - }
|
| - if (!InitializeAutomation(GetHostProcessName(false), false, false,
|
| - GURL(), GURL(), true)) {
|
| - return E_UNEXPECTED;
|
| - }
|
| -
|
| - if (flags & DELETE_BROWSING_HISTORY_COOKIES)
|
| - remove_mask_ |= BrowsingDataRemover::REMOVE_SITE_DATA;
|
| - if (flags & DELETE_BROWSING_HISTORY_TIF)
|
| - remove_mask_ |= BrowsingDataRemover::REMOVE_CACHE;
|
| - if (flags & DELETE_BROWSING_HISTORY_FORMDATA)
|
| - remove_mask_ |= BrowsingDataRemover::REMOVE_FORM_DATA;
|
| - if (flags & DELETE_BROWSING_HISTORY_PASSWORDS)
|
| - remove_mask_ |= BrowsingDataRemover::REMOVE_PASSWORDS;
|
| - if (flags & DELETE_BROWSING_HISTORY_HISTORY)
|
| - remove_mask_ |= BrowsingDataRemover::REMOVE_HISTORY;
|
| -
|
| - loop_.PostDelayedTask(FROM_HERE,
|
| - base::MessageLoop::QuitClosure(), base::TimeDelta::FromMinutes(10));
|
| - loop_.base::MessageLoop::Run();
|
| -
|
| - return S_OK;
|
| -}
|
| -
|
| -
|
|
|