OLD | NEW |
(Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef COMPONENTS_PHYSICAL_WEB_DATA_SOURCE_PHYSICAL_WEB_DATA_SOURCE_H_ |
| 6 #define COMPONENTS_PHYSICAL_WEB_DATA_SOURCE_PHYSICAL_WEB_DATA_SOURCE_H_ |
| 7 |
| 8 #include <memory> |
| 9 |
| 10 namespace base { |
| 11 class ListValue; |
| 12 } |
| 13 |
| 14 // Helper class for accessing Physical Web metadata and controlling the scanner. |
| 15 class PhysicalWebDataSource { |
| 16 public: |
| 17 virtual ~PhysicalWebDataSource() {} |
| 18 |
| 19 // Starts scanning for Physical Web URLs. If |network_request_enabled| is |
| 20 // true, discovered URLs will be sent to a resolution service. |
| 21 virtual void StartDiscovery(bool network_request_enabled) = 0; |
| 22 |
| 23 // Stops scanning for Physical Web URLs and clears cached URL content. |
| 24 virtual void StopDiscovery() = 0; |
| 25 |
| 26 // Returns a list of resolved URLs and associated page metadata. If network |
| 27 // requests are disabled or if discovery is not active, the list will be |
| 28 // empty. The method can be called at any time to receive the current metadata |
| 29 // list. |
| 30 virtual std::unique_ptr<base::ListValue> GetMetadata() = 0; |
| 31 |
| 32 // Returns boolean |true| if network requests are disabled and there are one |
| 33 // or more discovered URLs that have not been sent to the resolution service. |
| 34 // The method can be called at any time to check for unresolved discoveries. |
| 35 // If discovery is inactive or network requests are enabled, it will always |
| 36 // return false. |
| 37 virtual bool HasUnresolvedDiscoveries() = 0; |
| 38 }; |
| 39 |
| 40 #endif // COMPONENTS_PHYSICAL_WEB_DATA_SOURCE_PHYSICAL_WEB_DATA_SOURCE_H_ |
OLD | NEW |