| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 // Implementation of the Chrome Extensions Proxy Settings API. | 5 // Implementation of the Chrome Extensions Proxy Settings API. |
| 6 | 6 |
| 7 #include "chrome/browser/extensions/extension_proxy_api.h" | 7 #include "chrome/browser/extensions/extension_proxy_api.h" |
| 8 | 8 |
| 9 #include "base/json/json_writer.h" | 9 #include "base/json/json_writer.h" |
| 10 #include "base/stringprintf.h" | 10 #include "base/stringprintf.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 } | 26 } |
| 27 | 27 |
| 28 ExtensionProxyEventRouter::ExtensionProxyEventRouter() { | 28 ExtensionProxyEventRouter::ExtensionProxyEventRouter() { |
| 29 } | 29 } |
| 30 | 30 |
| 31 ExtensionProxyEventRouter::~ExtensionProxyEventRouter() { | 31 ExtensionProxyEventRouter::~ExtensionProxyEventRouter() { |
| 32 } | 32 } |
| 33 | 33 |
| 34 void ExtensionProxyEventRouter::OnProxyError( | 34 void ExtensionProxyEventRouter::OnProxyError( |
| 35 ExtensionEventRouterForwarder* event_router, | 35 ExtensionEventRouterForwarder* event_router, |
| 36 ProfileId profile_id, | 36 void* profile, |
| 37 int error_code) { | 37 int error_code) { |
| 38 ListValue args; | 38 ListValue args; |
| 39 DictionaryValue* dict = new DictionaryValue(); | 39 DictionaryValue* dict = new DictionaryValue(); |
| 40 dict->SetBoolean(keys::kProxyEventFatal, true); | 40 dict->SetBoolean(keys::kProxyEventFatal, true); |
| 41 dict->SetString(keys::kProxyEventError, net::ErrorToString(error_code)); | 41 dict->SetString(keys::kProxyEventError, net::ErrorToString(error_code)); |
| 42 dict->SetString(keys::kProxyEventDetails, ""); | 42 dict->SetString(keys::kProxyEventDetails, ""); |
| 43 args.Append(dict); | 43 args.Append(dict); |
| 44 | 44 |
| 45 std::string json_args; | 45 std::string json_args; |
| 46 base::JSONWriter::Write(&args, false, &json_args); | 46 base::JSONWriter::Write(&args, false, &json_args); |
| 47 | 47 |
| 48 if (profile_id != Profile::kInvalidProfileId) { | 48 if (profile) { |
| 49 event_router->DispatchEventToRenderers( | 49 event_router->DispatchEventToRenderers( |
| 50 keys::kProxyEventOnProxyError, json_args, profile_id, true, GURL()); | 50 keys::kProxyEventOnProxyError, json_args, profile, true, GURL()); |
| 51 } else { | 51 } else { |
| 52 event_router->BroadcastEventToRenderers( | 52 event_router->BroadcastEventToRenderers( |
| 53 keys::kProxyEventOnProxyError, json_args, GURL()); | 53 keys::kProxyEventOnProxyError, json_args, GURL()); |
| 54 } | 54 } |
| 55 } | 55 } |
| 56 | 56 |
| 57 void ExtensionProxyEventRouter::OnPACScriptError( | 57 void ExtensionProxyEventRouter::OnPACScriptError( |
| 58 ExtensionEventRouterForwarder* event_router, | 58 ExtensionEventRouterForwarder* event_router, |
| 59 ProfileId profile_id, | 59 void* profile, |
| 60 int line_number, | 60 int line_number, |
| 61 const string16& error) { | 61 const string16& error) { |
| 62 ListValue args; | 62 ListValue args; |
| 63 DictionaryValue* dict = new DictionaryValue(); | 63 DictionaryValue* dict = new DictionaryValue(); |
| 64 dict->SetBoolean(keys::kProxyEventFatal, false); | 64 dict->SetBoolean(keys::kProxyEventFatal, false); |
| 65 dict->SetString(keys::kProxyEventError, | 65 dict->SetString(keys::kProxyEventError, |
| 66 net::ErrorToString(net::ERR_PAC_SCRIPT_FAILED)); | 66 net::ErrorToString(net::ERR_PAC_SCRIPT_FAILED)); |
| 67 std::string error_msg; | 67 std::string error_msg; |
| 68 if (line_number != -1) { | 68 if (line_number != -1) { |
| 69 base::SStringPrintf( | 69 base::SStringPrintf( |
| 70 &error_msg, "line: %d: %s", line_number, UTF16ToUTF8(error).c_str()); | 70 &error_msg, "line: %d: %s", line_number, UTF16ToUTF8(error).c_str()); |
| 71 } else { | 71 } else { |
| 72 error_msg = UTF16ToUTF8(error); | 72 error_msg = UTF16ToUTF8(error); |
| 73 } | 73 } |
| 74 dict->SetString(keys::kProxyEventDetails, error_msg); | 74 dict->SetString(keys::kProxyEventDetails, error_msg); |
| 75 args.Append(dict); | 75 args.Append(dict); |
| 76 | 76 |
| 77 std::string json_args; | 77 std::string json_args; |
| 78 base::JSONWriter::Write(&args, false, &json_args); | 78 base::JSONWriter::Write(&args, false, &json_args); |
| 79 | 79 |
| 80 if (profile_id != Profile::kInvalidProfileId) { | 80 if (profile) { |
| 81 event_router->DispatchEventToRenderers( | 81 event_router->DispatchEventToRenderers( |
| 82 keys::kProxyEventOnProxyError, json_args, profile_id, true, GURL()); | 82 keys::kProxyEventOnProxyError, json_args, profile, true, GURL()); |
| 83 } else { | 83 } else { |
| 84 event_router->BroadcastEventToRenderers( | 84 event_router->BroadcastEventToRenderers( |
| 85 keys::kProxyEventOnProxyError, json_args, GURL()); | 85 keys::kProxyEventOnProxyError, json_args, GURL()); |
| 86 } | 86 } |
| 87 } | 87 } |
| 88 | 88 |
| 89 ProxyPrefTransformer::ProxyPrefTransformer() { | 89 ProxyPrefTransformer::ProxyPrefTransformer() { |
| 90 } | 90 } |
| 91 | 91 |
| 92 ProxyPrefTransformer::~ProxyPrefTransformer() { | 92 ProxyPrefTransformer::~ProxyPrefTransformer() { |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 175 if (!proxy_rules_dict) | 175 if (!proxy_rules_dict) |
| 176 return NULL; | 176 return NULL; |
| 177 extension_pref->Set(keys::kProxyConfigRules, proxy_rules_dict); | 177 extension_pref->Set(keys::kProxyConfigRules, proxy_rules_dict); |
| 178 break; | 178 break; |
| 179 } | 179 } |
| 180 case ProxyPrefs::kModeCount: | 180 case ProxyPrefs::kModeCount: |
| 181 NOTREACHED(); | 181 NOTREACHED(); |
| 182 } | 182 } |
| 183 return extension_pref.release(); | 183 return extension_pref.release(); |
| 184 } | 184 } |
| OLD | NEW |