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

Unified Diff: chrome/browser/chromeos/extensions/file_browser_resource_throttle.cc

Issue 12381035: Move Mime type handling to streamsPrivate API, so that it works on Desktop Chrome. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Initialize test variable Created 7 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/chromeos/extensions/file_browser_resource_throttle.cc
diff --git a/chrome/browser/chromeos/extensions/file_browser_resource_throttle.cc b/chrome/browser/chromeos/extensions/file_browser_resource_throttle.cc
deleted file mode 100644
index f7aecc779e892de5256bfbcdf07724856f635fa6..0000000000000000000000000000000000000000
--- a/chrome/browser/chromeos/extensions/file_browser_resource_throttle.cc
+++ /dev/null
@@ -1,208 +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.
-
-#include "chrome/browser/chromeos/extensions/file_browser_resource_throttle.h"
-
-#include <string>
-
-#include "base/bind.h"
-#include "base/values.h"
-#include "chrome/browser/chromeos/extensions/file_browser_handler.h"
-#include "chrome/browser/extensions/event_router.h"
-#include "chrome/browser/extensions/extension_info_map.h"
-#include "chrome/browser/extensions/extension_system.h"
-#include "chrome/browser/profiles/profile.h"
-#include "chrome/common/extensions/extension.h"
-#include "chrome/common/extensions/extension_constants.h"
-#include "chrome/common/extensions/extension_set.h"
-#include "content/public/browser/browser_context.h"
-#include "content/public/browser/browser_thread.h"
-#include "content/public/browser/render_view_host.h"
-#include "content/public/browser/resource_controller.h"
-#include "content/public/browser/web_contents.h"
-#include "net/url_request/url_request.h"
-
-using extensions::Event;
-using extensions::Extension;
-using extensions::ExtensionSystem;
-
-namespace {
-
-const char* const kOnExecuteContentHandlerEvent =
- "fileBrowserHandler.onExecuteContentHandler";
-
-// Goes through the extension's file browser handlers and checks it there is one
-// that can handle the |mime_type|.
-// |extension| must not be NULL.
-bool CanHandleMimeType(const Extension* extension,
- const std::string& mime_type) {
- FileBrowserHandler::List* handlers =
- FileBrowserHandler::GetHandlers(extension);
- if (!handlers)
- return false;
-
- for (FileBrowserHandler::List::const_iterator handler = handlers->begin();
- handler != handlers->end();
- ++handler) {
- if ((*handler)->CanHandleMIMEType(mime_type)) {
- return true;
- }
- }
-
- return false;
-}
-
-// Retrieves Profile for a render view host specified by |render_process_id| and
-// |render_view_id|.
-Profile* GetProfile(int render_process_id, int render_view_id) {
- content::RenderViewHost* render_view_host =
- content::RenderViewHost::FromID(render_process_id, render_view_id);
- if (!render_view_host)
- return NULL;
-
- content::WebContents* web_contents =
- content::WebContents::FromRenderViewHost(render_view_host);
- if (!web_contents)
- return NULL;
-
- content::BrowserContext* browser_context = web_contents->GetBrowserContext();
- if (!browser_context)
- return NULL;
-
- return Profile::FromBrowserContext(browser_context);
-}
-
-void DispatchEventOnUIThread(const std::string& mime_type,
- const GURL& request_url,
- int render_process_id,
- int render_view_id,
- const std::string& extension_id) {
- DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
-
- Profile* profile = GetProfile(render_process_id, render_view_id);
- if (!profile)
- return;
-
- // Create the event's arguments value.
- scoped_ptr<ListValue> event_args(new ListValue());
- event_args->Append(new base::StringValue(mime_type));
- event_args->Append(new base::StringValue(request_url.spec()));
-
- scoped_ptr<Event> event(new Event(kOnExecuteContentHandlerEvent,
- event_args.Pass()));
-
- ExtensionSystem::Get(profile)->event_router()->DispatchEventToExtension(
- extension_id, event.Pass());
-}
-
-// Default implementation of FileBrowserHandlerEventRouter.
-class FileBrowserHandlerEventRouterImpl
- : public FileBrowserResourceThrottle::FileBrowserHandlerEventRouter {
- public:
- FileBrowserHandlerEventRouterImpl() {}
- virtual ~FileBrowserHandlerEventRouterImpl() {}
-
- virtual void DispatchMimeTypeHandlerEvent(
- int render_process_id,
- int render_view_id,
- const std::string& mime_type,
- const GURL& request_url,
- const std::string& extension_id) OVERRIDE {
- // The event must be dispatched on the UI thread.
- content::BrowserThread::PostTask(
- content::BrowserThread::UI, FROM_HERE,
- base::Bind(&DispatchEventOnUIThread, mime_type, request_url,
- render_process_id, render_view_id, extension_id));
- }
-};
-
-} // namespace
-
-// static
-FileBrowserResourceThrottle* FileBrowserResourceThrottle::Create(
- int render_process_id,
- int render_view_id,
- net::URLRequest* request,
- bool profile_is_incognito,
- const ExtensionInfoMap* extension_info_map) {
- std::string mime_type;
- request->GetMimeType(&mime_type);
- scoped_ptr<FileBrowserHandlerEventRouter> event_router(
- new FileBrowserHandlerEventRouterImpl());
- return new FileBrowserResourceThrottle(render_process_id, render_view_id,
- mime_type, request->url(), profile_is_incognito, extension_info_map,
- event_router.Pass());
-}
-
-// static
-FileBrowserResourceThrottle* FileBrowserResourceThrottle::CreateForTest(
- int render_process_id,
- int render_view_id,
- const std::string& mime_type,
- const GURL& request_url,
- bool profile_is_incognito,
- const ExtensionInfoMap* extension_info_map,
- scoped_ptr<FileBrowserHandlerEventRouter> event_router_in) {
- scoped_ptr<FileBrowserHandlerEventRouter> event_router =
- event_router_in.Pass();
- if (!event_router)
- event_router.reset(new FileBrowserHandlerEventRouterImpl());
- return new FileBrowserResourceThrottle(render_process_id, render_view_id,
- mime_type, request_url, profile_is_incognito, extension_info_map,
- event_router.Pass());
-}
-
-FileBrowserResourceThrottle::FileBrowserResourceThrottle(
- int render_process_id,
- int render_view_id,
- const std::string& mime_type,
- const GURL& request_url,
- bool profile_is_incognito,
- const ExtensionInfoMap* extension_info_map,
- scoped_ptr<FileBrowserHandlerEventRouter> event_router)
- : render_process_id_(render_process_id),
- render_view_id_(render_view_id),
- mime_type_(mime_type),
- request_url_(request_url),
- profile_is_incognito_(profile_is_incognito),
- extension_info_map_(extension_info_map),
- event_router_(event_router.Pass()) {
-}
-
-FileBrowserResourceThrottle::~FileBrowserResourceThrottle() {}
-
-void FileBrowserResourceThrottle::WillProcessResponse(bool* defer) {
- std::vector<std::string> whitelist =
- FileBrowserHandler::GetMIMETypeWhitelist();
- // Go through the white-listed extensions and try to use them to intercept
- // the URL request.
- for (size_t i = 0; i < whitelist.size(); ++i) {
- if (MaybeInterceptWithExtension(whitelist[i]))
- return;
- }
-}
-
-bool FileBrowserResourceThrottle::MaybeInterceptWithExtension(
- const std::string& extension_id) {
- const Extension* extension =
- extension_info_map_->extensions().GetByID(extension_id);
- // The white-listed extension may not be installed, so we have to NULL check
- // |extension|.
- if (!extension)
- return false;
-
- // If in incognito mode, skip the extensions that are not incognito enabled.
- if (profile_is_incognito_ &&
- !extension_info_map_->IsIncognitoEnabled(extension_id)) {
- return false;
- }
-
- if (CanHandleMimeType(extension, mime_type_)) {
- event_router_->DispatchMimeTypeHandlerEvent(render_process_id_,
- render_view_id_, mime_type_, request_url_, extension->id());
- controller()->CancelAndIgnore();
- return true;
- }
- return false;
-}

Powered by Google App Engine
This is Rietveld 408576698