| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "components/arc/intent_helper/link_handler_model_impl.h" | 5 #include "components/arc/intent_helper/link_handler_model_impl.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <utility> | 8 #include <utility> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 49 | 49 |
| 50 } // namespace | 50 } // namespace |
| 51 | 51 |
| 52 LinkHandlerModelImpl::LinkHandlerModelImpl( | 52 LinkHandlerModelImpl::LinkHandlerModelImpl( |
| 53 scoped_refptr<ActivityIconLoader> icon_loader) | 53 scoped_refptr<ActivityIconLoader> icon_loader) |
| 54 : icon_loader_(icon_loader), weak_ptr_factory_(this) {} | 54 : icon_loader_(icon_loader), weak_ptr_factory_(this) {} |
| 55 | 55 |
| 56 LinkHandlerModelImpl::~LinkHandlerModelImpl() {} | 56 LinkHandlerModelImpl::~LinkHandlerModelImpl() {} |
| 57 | 57 |
| 58 bool LinkHandlerModelImpl::Init(const GURL& url) { | 58 bool LinkHandlerModelImpl::Init(const GURL& url) { |
| 59 mojom::IntentHelperInstance* intent_helper_instance = | 59 auto* instance = ArcIntentHelperBridge::GetIntentHelperInstance( |
| 60 ArcIntentHelperBridge::GetIntentHelperInstance(kMinInstanceVersion); | 60 "RequestUrlHandlerList", kMinInstanceVersion); |
| 61 if (!intent_helper_instance) | 61 if (!instance) |
| 62 return false; | 62 return false; |
| 63 | 63 |
| 64 // Check if ARC apps can handle the |url|. Since the information is held in | 64 // Check if ARC apps can handle the |url|. Since the information is held in |
| 65 // a different (ARC) process, issue a mojo IPC request. Usually, the | 65 // a different (ARC) process, issue a mojo IPC request. Usually, the |
| 66 // callback function, OnUrlHandlerList, is called within a few milliseconds | 66 // callback function, OnUrlHandlerList, is called within a few milliseconds |
| 67 // even on the slowest Chromebook we support. | 67 // even on the slowest Chromebook we support. |
| 68 const GURL rewritten(RewriteUrlFromQueryIfAvailable(url)); | 68 const GURL rewritten(RewriteUrlFromQueryIfAvailable(url)); |
| 69 intent_helper_instance->RequestUrlHandlerList( | 69 instance->RequestUrlHandlerList( |
| 70 rewritten.spec(), base::Bind(&LinkHandlerModelImpl::OnUrlHandlerList, | 70 rewritten.spec(), base::Bind(&LinkHandlerModelImpl::OnUrlHandlerList, |
| 71 weak_ptr_factory_.GetWeakPtr())); | 71 weak_ptr_factory_.GetWeakPtr())); |
| 72 return true; | 72 return true; |
| 73 } | 73 } |
| 74 | 74 |
| 75 void LinkHandlerModelImpl::AddObserver(Observer* observer) { | 75 void LinkHandlerModelImpl::AddObserver(Observer* observer) { |
| 76 observer_list_.AddObserver(observer); | 76 observer_list_.AddObserver(observer); |
| 77 } | 77 } |
| 78 | 78 |
| 79 void LinkHandlerModelImpl::OpenLinkWithHandler(const GURL& url, | 79 void LinkHandlerModelImpl::OpenLinkWithHandler(const GURL& url, |
| 80 uint32_t handler_id) { | 80 uint32_t handler_id) { |
| 81 mojom::IntentHelperInstance* intent_helper_instance = | 81 auto* instance = ArcIntentHelperBridge::GetIntentHelperInstance( |
| 82 ArcIntentHelperBridge::GetIntentHelperInstance(kMinInstanceVersion); | 82 "HandleUrl", kMinInstanceVersion); |
| 83 if (!intent_helper_instance) | 83 if (!instance) |
| 84 return; | 84 return; |
| 85 if (handler_id >= handlers_.size()) | 85 if (handler_id >= handlers_.size()) |
| 86 return; | 86 return; |
| 87 const GURL rewritten(RewriteUrlFromQueryIfAvailable(url)); | 87 const GURL rewritten(RewriteUrlFromQueryIfAvailable(url)); |
| 88 intent_helper_instance->HandleUrl(rewritten.spec(), | 88 instance->HandleUrl(rewritten.spec(), handlers_[handler_id]->package_name); |
| 89 handlers_[handler_id]->package_name); | |
| 90 } | 89 } |
| 91 | 90 |
| 92 void LinkHandlerModelImpl::OnUrlHandlerList( | 91 void LinkHandlerModelImpl::OnUrlHandlerList( |
| 93 mojo::Array<mojom::UrlHandlerInfoPtr> handlers) { | 92 mojo::Array<mojom::UrlHandlerInfoPtr> handlers) { |
| 94 handlers_ = ArcIntentHelperBridge::FilterOutIntentHelper(std::move(handlers)); | 93 handlers_ = ArcIntentHelperBridge::FilterOutIntentHelper(std::move(handlers)); |
| 95 | 94 |
| 96 bool icon_info_notified = false; | 95 bool icon_info_notified = false; |
| 97 if (icon_loader_) { | 96 if (icon_loader_) { |
| 98 std::vector<ActivityIconLoader::ActivityName> activities; | 97 std::vector<ActivityIconLoader::ActivityName> activities; |
| 99 for (size_t i = 0; i < handlers_.size(); ++i) { | 98 for (size_t i = 0; i < handlers_.size(); ++i) { |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 if (!GetQueryValue(url, kKeyToFind, &value)) | 157 if (!GetQueryValue(url, kKeyToFind, &value)) |
| 159 return url; | 158 return url; |
| 160 | 159 |
| 161 const GURL new_url(value); | 160 const GURL new_url(value); |
| 162 if (!new_url.is_valid()) | 161 if (!new_url.is_valid()) |
| 163 return url; | 162 return url; |
| 164 return new_url; | 163 return new_url; |
| 165 } | 164 } |
| 166 | 165 |
| 167 } // namespace arc | 166 } // namespace arc |
| OLD | NEW |