OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/chromeos/launcher_search_provider/launcher_search_provi
der_service.h" | 5 #include "chrome/browser/chromeos/launcher_search_provider/launcher_search_provi
der_service.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 |
8 #include <utility> | 9 #include <utility> |
9 | 10 |
| 11 #include "base/memory/ptr_util.h" |
10 #include "base/memory/scoped_vector.h" | 12 #include "base/memory/scoped_vector.h" |
11 #include "base/strings/utf_string_conversions.h" | 13 #include "base/strings/utf_string_conversions.h" |
12 #include "chrome/browser/chromeos/launcher_search_provider/launcher_search_provi
der_service_factory.h" | 14 #include "chrome/browser/chromeos/launcher_search_provider/launcher_search_provi
der_service_factory.h" |
13 #include "chrome/browser/ui/app_list/search/launcher_search/launcher_search_prov
ider.h" | 15 #include "chrome/browser/ui/app_list/search/launcher_search/launcher_search_prov
ider.h" |
14 #include "chrome/browser/ui/app_list/search/launcher_search/launcher_search_resu
lt.h" | 16 #include "chrome/browser/ui/app_list/search/launcher_search/launcher_search_resu
lt.h" |
15 #include "extensions/browser/extension_registry.h" | 17 #include "extensions/browser/extension_registry.h" |
16 #include "extensions/common/extension_set.h" | 18 #include "extensions/common/extension_set.h" |
17 #include "extensions/common/permissions/permissions_data.h" | 19 #include "extensions/common/permissions/permissions_data.h" |
18 | 20 |
19 namespace api_launcher_search_provider = | 21 namespace api_launcher_search_provider = |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
54 | 56 |
55 extensions::EventRouter* event_router = | 57 extensions::EventRouter* event_router = |
56 extensions::EventRouter::Get(profile_); | 58 extensions::EventRouter::Get(profile_); |
57 | 59 |
58 CacheListenerExtensionIds(); | 60 CacheListenerExtensionIds(); |
59 for (const ExtensionId extension_id : *cached_listener_extension_ids_.get()) { | 61 for (const ExtensionId extension_id : *cached_listener_extension_ids_.get()) { |
60 // Convert query_id_ to string here since queryId is defined as string in | 62 // Convert query_id_ to string here since queryId is defined as string in |
61 // javascript side API while we use uint32_t internally to generate it. | 63 // javascript side API while we use uint32_t internally to generate it. |
62 event_router->DispatchEventToExtension( | 64 event_router->DispatchEventToExtension( |
63 extension_id, | 65 extension_id, |
64 make_scoped_ptr(new extensions::Event( | 66 base::WrapUnique(new extensions::Event( |
65 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_QUERY_STARTED, | 67 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_QUERY_STARTED, |
66 api_launcher_search_provider::OnQueryStarted::kEventName, | 68 api_launcher_search_provider::OnQueryStarted::kEventName, |
67 api_launcher_search_provider::OnQueryStarted::Create( | 69 api_launcher_search_provider::OnQueryStarted::Create( |
68 query_id_, query, max_result)))); | 70 query_id_, query, max_result)))); |
69 } | 71 } |
70 } | 72 } |
71 | 73 |
72 void Service::OnQueryEnded() { | 74 void Service::OnQueryEnded() { |
73 DCHECK(is_query_running_); | 75 DCHECK(is_query_running_); |
74 provider_ = nullptr; | 76 provider_ = nullptr; |
75 | 77 |
76 extensions::EventRouter* event_router = | 78 extensions::EventRouter* event_router = |
77 extensions::EventRouter::Get(profile_); | 79 extensions::EventRouter::Get(profile_); |
78 | 80 |
79 CacheListenerExtensionIds(); | 81 CacheListenerExtensionIds(); |
80 for (const ExtensionId extension_id : *cached_listener_extension_ids_.get()) { | 82 for (const ExtensionId extension_id : *cached_listener_extension_ids_.get()) { |
81 event_router->DispatchEventToExtension( | 83 event_router->DispatchEventToExtension( |
82 extension_id, | 84 extension_id, |
83 make_scoped_ptr(new extensions::Event( | 85 base::WrapUnique(new extensions::Event( |
84 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_QUERY_ENDED, | 86 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_QUERY_ENDED, |
85 api_launcher_search_provider::OnQueryEnded::kEventName, | 87 api_launcher_search_provider::OnQueryEnded::kEventName, |
86 api_launcher_search_provider::OnQueryEnded::Create(query_id_)))); | 88 api_launcher_search_provider::OnQueryEnded::Create(query_id_)))); |
87 } | 89 } |
88 | 90 |
89 is_query_running_ = false; | 91 is_query_running_ = false; |
90 } | 92 } |
91 | 93 |
92 void Service::OnOpenResult(const ExtensionId& extension_id, | 94 void Service::OnOpenResult(const ExtensionId& extension_id, |
93 const std::string& item_id) { | 95 const std::string& item_id) { |
94 CacheListenerExtensionIds(); | 96 CacheListenerExtensionIds(); |
95 CHECK(ContainsValue(*cached_listener_extension_ids_.get(), extension_id)); | 97 CHECK(ContainsValue(*cached_listener_extension_ids_.get(), extension_id)); |
96 | 98 |
97 extensions::EventRouter* event_router = | 99 extensions::EventRouter* event_router = |
98 extensions::EventRouter::Get(profile_); | 100 extensions::EventRouter::Get(profile_); |
99 event_router->DispatchEventToExtension( | 101 event_router->DispatchEventToExtension( |
100 extension_id, | 102 extension_id, |
101 make_scoped_ptr(new extensions::Event( | 103 base::WrapUnique(new extensions::Event( |
102 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_OPEN_RESULT, | 104 extensions::events::LAUNCHER_SEARCH_PROVIDER_ON_OPEN_RESULT, |
103 api_launcher_search_provider::OnOpenResult::kEventName, | 105 api_launcher_search_provider::OnOpenResult::kEventName, |
104 api_launcher_search_provider::OnOpenResult::Create(item_id)))); | 106 api_launcher_search_provider::OnOpenResult::Create(item_id)))); |
105 } | 107 } |
106 | 108 |
107 void Service::SetSearchResults( | 109 void Service::SetSearchResults( |
108 const extensions::Extension* extension, | 110 const extensions::Extension* extension, |
109 scoped_ptr<ErrorReporter> error_reporter, | 111 std::unique_ptr<ErrorReporter> error_reporter, |
110 const int query_id, | 112 const int query_id, |
111 const std::vector<extensions::api::launcher_search_provider::SearchResult>& | 113 const std::vector<extensions::api::launcher_search_provider::SearchResult>& |
112 results) { | 114 results) { |
113 // If query is not running or query_id is different from current query id, | 115 // If query is not running or query_id is different from current query id, |
114 // discard the results. | 116 // discard the results. |
115 if (!is_query_running_ || query_id != query_id_) | 117 if (!is_query_running_ || query_id != query_id_) |
116 return; | 118 return; |
117 | 119 |
118 // If |extension| is not in the listener extensions list, ignore it. | 120 // If |extension| is not in the listener extensions list, ignore it. |
119 CacheListenerExtensionIds(); | 121 CacheListenerExtensionIds(); |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
170 extension->permissions_data(); | 172 extension->permissions_data(); |
171 const bool has_permission = permission_data->HasAPIPermission( | 173 const bool has_permission = permission_data->HasAPIPermission( |
172 extensions::APIPermission::kLauncherSearchProvider); | 174 extensions::APIPermission::kLauncherSearchProvider); |
173 if (has_permission) | 175 if (has_permission) |
174 cached_listener_extension_ids_->insert(extension->id()); | 176 cached_listener_extension_ids_->insert(extension->id()); |
175 } | 177 } |
176 } | 178 } |
177 | 179 |
178 } // namespace launcher_search_provider | 180 } // namespace launcher_search_provider |
179 } // namespace chromeos | 181 } // namespace chromeos |
OLD | NEW |