OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "chrome/browser/extensions/extension_function_dispatcher.h" | 5 #include "chrome/browser/extensions/extension_function_dispatcher.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/json/json_string_value_serializer.h" | 8 #include "base/json/json_string_value_serializer.h" |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 30 matching lines...) Expand all Loading... |
41 | 41 |
42 using extensions::Extension; | 42 using extensions::Extension; |
43 using extensions::ExtensionAPI; | 43 using extensions::ExtensionAPI; |
44 using content::RenderViewHost; | 44 using content::RenderViewHost; |
45 using WebKit::WebSecurityOrigin; | 45 using WebKit::WebSecurityOrigin; |
46 | 46 |
47 namespace { | 47 namespace { |
48 | 48 |
49 void LogSuccess(const std::string& extension_id, | 49 void LogSuccess(const std::string& extension_id, |
50 const std::string& api_name, | 50 const std::string& api_name, |
51 scoped_ptr<ListValue> args, | 51 scoped_ptr<base::ListValue> args, |
52 Profile* profile) { | 52 Profile* profile) { |
53 // The ActivityLog can only be accessed from the main (UI) thread. If we're | 53 // The ActivityLog can only be accessed from the main (UI) thread. If we're |
54 // running on the wrong thread, re-dispatch from the main thread. | 54 // running on the wrong thread, re-dispatch from the main thread. |
55 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { | 55 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
56 BrowserThread::PostTask(BrowserThread::UI, | 56 BrowserThread::PostTask(BrowserThread::UI, |
57 FROM_HERE, | 57 FROM_HERE, |
58 base::Bind(&LogSuccess, | 58 base::Bind(&LogSuccess, |
59 extension_id, | 59 extension_id, |
60 api_name, | 60 api_name, |
61 base::Passed(&args), | 61 base::Passed(&args), |
62 profile)); | 62 profile)); |
63 } else { | 63 } else { |
64 extensions::ActivityLog* activity_log = | 64 extensions::ActivityLog* activity_log = |
65 extensions::ActivityLog::GetInstance(profile); | 65 extensions::ActivityLog::GetInstance(profile); |
66 activity_log->LogAPIAction( | 66 activity_log->LogAPIAction( |
67 extension_id, api_name, args.get(), std::string()); | 67 extension_id, api_name, args.get(), std::string()); |
68 } | 68 } |
69 } | 69 } |
70 | 70 |
71 void LogFailure(const std::string& extension_id, | 71 void LogFailure(const std::string& extension_id, |
72 const std::string& api_name, | 72 const std::string& api_name, |
73 scoped_ptr<ListValue> args, | 73 scoped_ptr<base::ListValue> args, |
74 extensions::BlockedAction::Reason reason, | 74 extensions::BlockedAction::Reason reason, |
75 Profile* profile) { | 75 Profile* profile) { |
76 // The ActivityLog can only be accessed from the main (UI) thread. If we're | 76 // The ActivityLog can only be accessed from the main (UI) thread. If we're |
77 // running on the wrong thread, re-dispatch from the main thread. | 77 // running on the wrong thread, re-dispatch from the main thread. |
78 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { | 78 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
79 BrowserThread::PostTask(BrowserThread::UI, | 79 BrowserThread::PostTask(BrowserThread::UI, |
80 FROM_HERE, | 80 FROM_HERE, |
81 base::Bind(&LogFailure, | 81 base::Bind(&LogFailure, |
82 extension_id, | 82 extension_id, |
83 api_name, | 83 api_name, |
(...skipping 448 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
532 return function; | 532 return function; |
533 } | 533 } |
534 | 534 |
535 // static | 535 // static |
536 void ExtensionFunctionDispatcher::SendAccessDenied( | 536 void ExtensionFunctionDispatcher::SendAccessDenied( |
537 const ExtensionFunction::ResponseCallback& callback) { | 537 const ExtensionFunction::ResponseCallback& callback) { |
538 ListValue empty_list; | 538 ListValue empty_list; |
539 callback.Run(ExtensionFunction::FAILED, empty_list, | 539 callback.Run(ExtensionFunction::FAILED, empty_list, |
540 "Access to extension API denied."); | 540 "Access to extension API denied."); |
541 } | 541 } |
OLD | NEW |