Chromium Code Reviews| 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/api/app_runtime/app_runtime_api.h" | 5 #include "chrome/browser/extensions/api/app_runtime/app_runtime_api.h" |
| 6 | 6 |
| 7 #include "base/json/json_writer.h" | 7 #include "base/json/json_writer.h" |
| 8 #include "base/string16.h" | 8 #include "base/string16.h" |
| 9 #include "base/string_number_conversions.h" | 9 #include "base/string_number_conversions.h" |
| 10 #include "base/utf_string_conversions.h" | 10 #include "base/utf_string_conversions.h" |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 30 const char kCallbackNotFoundError[] = | 30 const char kCallbackNotFoundError[] = |
| 31 "WebIntent callback not found; perhaps already responded to"; | 31 "WebIntent callback not found; perhaps already responded to"; |
| 32 | 32 |
| 33 } // anonymous namespace | 33 } // anonymous namespace |
| 34 | 34 |
| 35 namespace extensions { | 35 namespace extensions { |
| 36 | 36 |
| 37 // static. | 37 // static. |
| 38 void AppEventRouter::DispatchOnLaunchedEvent( | 38 void AppEventRouter::DispatchOnLaunchedEvent( |
| 39 Profile* profile, const Extension* extension) { | 39 Profile* profile, const Extension* extension) { |
| 40 ExtensionSystem* system = ExtensionSystem::Get(profile); | |
| 40 scoped_ptr<ListValue> arguments(new ListValue()); | 41 scoped_ptr<ListValue> arguments(new ListValue()); |
| 41 extensions::ExtensionSystem::Get(profile)->event_router()-> | 42 system->event_router()->AddLazyEventListener(kOnLaunchedEvent, |
| 42 DispatchEventToExtension(extension->id(), kOnLaunchedEvent, | 43 extension->id()); |
| 43 arguments.Pass(), profile, GURL()); | 44 system->event_router()->DispatchEventToExtension( |
| 45 extension->id(), kOnLaunchedEvent, arguments.Pass(), profile, GURL()); | |
| 46 system->event_router()->RemoveLazyEventListener(kOnLaunchedEvent, | |
| 47 extension->id()); | |
|
Matt Perry
2012/11/29 20:24:46
If you go this route, can you move this chunk to a
Marijn Kruisselbrink
2012/11/29 21:07:19
Done.
| |
| 44 } | 48 } |
| 45 | 49 |
| 46 // static. | 50 // static. |
| 47 void AppEventRouter::DispatchOnRestartedEvent( | 51 void AppEventRouter::DispatchOnRestartedEvent( |
| 48 Profile* profile, const Extension* extension) { | 52 Profile* profile, const Extension* extension) { |
| 49 scoped_ptr<ListValue> arguments(new ListValue()); | 53 scoped_ptr<ListValue> arguments(new ListValue()); |
| 50 extensions::ExtensionSystem::Get(profile)->event_router()-> | 54 extensions::ExtensionSystem::Get(profile)->event_router()-> |
| 51 DispatchEventToExtension(extension->id(), kOnRestartedEvent, | 55 DispatchEventToExtension(extension->id(), kOnRestartedEvent, |
| 52 arguments.Pass(), profile, GURL()); | 56 arguments.Pass(), profile, GURL()); |
| 53 } | 57 } |
| 54 | 58 |
| 55 // static. | 59 // static. |
| 56 void AppEventRouter::DispatchOnLaunchedEventWithFileEntry( | 60 void AppEventRouter::DispatchOnLaunchedEventWithFileEntry( |
| 57 Profile* profile, const Extension* extension, const string16& action, | 61 Profile* profile, const Extension* extension, const string16& action, |
| 58 const std::string& handler_id, const std::string& mime_type, | 62 const std::string& handler_id, const std::string& mime_type, |
| 59 const std::string& file_system_id, const std::string& base_name) { | 63 const std::string& file_system_id, const std::string& base_name) { |
| 60 scoped_ptr<ListValue> args(new ListValue()); | 64 scoped_ptr<ListValue> args(new ListValue()); |
| 61 DictionaryValue* launch_data = new DictionaryValue(); | 65 DictionaryValue* launch_data = new DictionaryValue(); |
| 62 launch_data->SetString("id", handler_id); | 66 launch_data->SetString("id", handler_id); |
| 63 DictionaryValue* launch_item = new DictionaryValue; | 67 DictionaryValue* launch_item = new DictionaryValue; |
| 64 launch_item->SetString("fileSystemId", file_system_id); | 68 launch_item->SetString("fileSystemId", file_system_id); |
| 65 launch_item->SetString("baseName", base_name); | 69 launch_item->SetString("baseName", base_name); |
| 66 launch_item->SetString("mimeType", mime_type); | 70 launch_item->SetString("mimeType", mime_type); |
| 67 ListValue* items = new ListValue; | 71 ListValue* items = new ListValue; |
| 68 items->Append(launch_item); | 72 items->Append(launch_item); |
| 69 launch_data->Set("items", items); | 73 launch_data->Set("items", items); |
| 70 args->Append(launch_data); | 74 args->Append(launch_data); |
| 71 extensions::ExtensionSystem::Get(profile)->event_router()-> | 75 ExtensionSystem* system = ExtensionSystem::Get(profile); |
| 72 DispatchEventToExtension(extension->id(), kOnLaunchedEvent, args.Pass(), | 76 system->event_router()->AddLazyEventListener(kOnLaunchedEvent, |
| 73 profile, GURL()); | 77 extension->id()); |
| 78 system->event_router()->DispatchEventToExtension( | |
| 79 extension->id(), kOnLaunchedEvent, args.Pass(), profile, GURL()); | |
| 80 system->event_router()->RemoveLazyEventListener(kOnLaunchedEvent, | |
| 81 extension->id()); | |
| 74 } | 82 } |
| 75 | 83 |
| 76 // static. | 84 // static. |
| 77 void AppEventRouter::DispatchOnLaunchedEventWithWebIntent( | 85 void AppEventRouter::DispatchOnLaunchedEventWithWebIntent( |
| 78 Profile* profile, const Extension* extension, | 86 Profile* profile, const Extension* extension, |
| 79 content::WebIntentsDispatcher* intents_dispatcher, | 87 content::WebIntentsDispatcher* intents_dispatcher, |
| 80 content::WebContents* source) { | 88 content::WebContents* source) { |
| 81 webkit_glue::WebIntentData web_intent_data = intents_dispatcher->GetIntent(); | 89 webkit_glue::WebIntentData web_intent_data = intents_dispatcher->GetIntent(); |
| 82 scoped_ptr<ListValue> args(new ListValue()); | 90 scoped_ptr<ListValue> args(new ListValue()); |
| 83 DictionaryValue* launch_data = new DictionaryValue(); | 91 DictionaryValue* launch_data = new DictionaryValue(); |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 119 break; | 127 break; |
| 120 default: | 128 default: |
| 121 NOTREACHED(); | 129 NOTREACHED(); |
| 122 break; | 130 break; |
| 123 } | 131 } |
| 124 DCHECK(args->GetSize() == 2); // intent_id must be our third argument. | 132 DCHECK(args->GetSize() == 2); // intent_id must be our third argument. |
| 125 WebIntentCallbacks* callbacks = WebIntentCallbacks::Get(profile); | 133 WebIntentCallbacks* callbacks = WebIntentCallbacks::Get(profile); |
| 126 int intent_id = | 134 int intent_id = |
| 127 callbacks->RegisterCallback(extension, intents_dispatcher, source); | 135 callbacks->RegisterCallback(extension, intents_dispatcher, source); |
| 128 args->Append(base::Value::CreateIntegerValue(intent_id)); | 136 args->Append(base::Value::CreateIntegerValue(intent_id)); |
| 129 extensions::ExtensionSystem::Get(profile)->event_router()-> | 137 ExtensionSystem* system = ExtensionSystem::Get(profile); |
| 130 DispatchEventToExtension(extension->id(), kOnLaunchedEvent, args.Pass(), | 138 system->event_router()->AddLazyEventListener(kOnLaunchedEvent, |
| 131 profile, GURL()); | 139 extension->id()); |
| 140 system->event_router()->DispatchEventToExtension( | |
| 141 extension->id(), kOnLaunchedEvent, args.Pass(), profile, GURL()); | |
| 142 system->event_router()->RemoveLazyEventListener(kOnLaunchedEvent, | |
| 143 extension->id()); | |
| 132 } | 144 } |
| 133 | 145 |
| 134 bool AppRuntimePostIntentResponseFunction::RunImpl() { | 146 bool AppRuntimePostIntentResponseFunction::RunImpl() { |
| 135 DictionaryValue* details = NULL; | 147 DictionaryValue* details = NULL; |
| 136 EXTENSION_FUNCTION_VALIDATE(args_->GetDictionary(0, &details)); | 148 EXTENSION_FUNCTION_VALIDATE(args_->GetDictionary(0, &details)); |
| 137 | 149 |
| 138 int intent_id = 0; | 150 int intent_id = 0; |
| 139 EXTENSION_FUNCTION_VALIDATE(details->GetInteger(kIntentIdKey, &intent_id)); | 151 EXTENSION_FUNCTION_VALIDATE(details->GetInteger(kIntentIdKey, &intent_id)); |
| 140 | 152 |
| 141 WebIntentCallbacks* callbacks = WebIntentCallbacks::Get(profile()); | 153 WebIntentCallbacks* callbacks = WebIntentCallbacks::Get(profile()); |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 154 reply_type = webkit_glue::WEB_INTENT_REPLY_SUCCESS; | 166 reply_type = webkit_glue::WEB_INTENT_REPLY_SUCCESS; |
| 155 | 167 |
| 156 std::string data; | 168 std::string data; |
| 157 EXTENSION_FUNCTION_VALIDATE(details->GetString(kIntentDataKey, &data)); | 169 EXTENSION_FUNCTION_VALIDATE(details->GetString(kIntentDataKey, &data)); |
| 158 | 170 |
| 159 intents_dispatcher->SendReplyMessage(reply_type, UTF8ToUTF16(data)); | 171 intents_dispatcher->SendReplyMessage(reply_type, UTF8ToUTF16(data)); |
| 160 return true; | 172 return true; |
| 161 } | 173 } |
| 162 | 174 |
| 163 } // namespace extensions | 175 } // namespace extensions |
| OLD | NEW |