Index: ios/chrome/common/physical_web/physical_web_data_source_ios.h |
diff --git a/ios/chrome/common/physical_web/physical_web_data_source_ios.h b/ios/chrome/common/physical_web/physical_web_data_source_ios.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1e8da086da7015b2b9bb15d8583557f41866054f |
--- /dev/null |
+++ b/ios/chrome/common/physical_web/physical_web_data_source_ios.h |
@@ -0,0 +1,43 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef IOS_CHROME_COMMON_PHYSICAL_WEB_PHYSICAL_WEB_DATA_SOURCE_IOS_H_ |
+#define IOS_CHROME_COMMON_PHYSICAL_WEB_PHYSICAL_WEB_DATA_SOURCE_IOS_H_ |
+ |
+#include "components/physical_web_data_source/physical_web_data_source.h" |
+ |
+#include "base/macros.h" |
+#include "base/values.h" |
+#import "base/mac/scoped_nsobject.h" |
+#import "ios/chrome/common/physical_web/physical_web_scanner.h" |
+ |
+// IOS implementation of PhysicalWebDataSource |
+class PhysicalWebDataSourceIOS : public PhysicalWebDataSource { |
+ public: |
+ PhysicalWebDataSourceIOS(); |
+ ~PhysicalWebDataSourceIOS() override; |
+ |
+ // Starts scanning for Physical Web URLs. If |network_request_enabled| is |
+ // true, discovered URLs will be sent to a resolution service. |
+ void StartDiscovery(bool network_request_enabled) override; |
+ |
+ // Stops scanning for Physical Web URLs and clears cached URL content. |
+ void StopDiscovery() override; |
+ |
+ // Returns a list of resolved URLs and associated page metadata. If network |
+ // requests are disabled, the list will be empty. |
+ std::unique_ptr<base::ListValue> GetMetadata() override; |
+ |
+ // Returns boolean |true| if network requests are disabled and there are one |
+ // or more discovered URLs that have not been sent to the resolution service. |
+ bool HasUnresolvedDiscoveries() override; |
+ |
+ private: |
+ // Scanner for nearby Physical Web URL devices. |
+ base::scoped_nsobject<PhysicalWebScanner> scanner_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PhysicalWebDataSourceIOS); |
+}; |
+ |
+#endif // IOS_CHROME_COMMON_PHYSICAL_WEB_PHYSICAL_WEB_DATA_SOURCE_IOS_H_ |