| // Copyright 2019 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef COMPONENTS_PERMISSIONS_ANDROID_NFC_NFC_SYSTEM_LEVEL_SETTING_H_ |
| #define COMPONENTS_PERMISSIONS_ANDROID_NFC_NFC_SYSTEM_LEVEL_SETTING_H_ |
| |
| #include "base/functional/callback.h" |
| |
| namespace content { |
| class WebContents; |
| } |
| |
| namespace permissions { |
| |
| // This class determines whether NFC is enabled system-wide on the device. |
| class NfcSystemLevelSetting { |
| public: |
| virtual ~NfcSystemLevelSetting() {} |
| |
| // Returns true if the NFC system level setting can be enabled. |
| virtual bool IsNfcAccessPossible() = 0; |
| |
| // Returns true if the NFC system level setting is enabled. |
| virtual bool IsNfcSystemLevelSettingEnabled() = 0; |
| |
| // Triggers a prompt to ask the user to turn on the system NFC setting on |
| // their device, and invokes callback when prompt is completed. |
| // |
| // The prompt will be triggered in the activity of the web contents. |
| // |
| // The callback is guaranteed to be called unless the user never replies to |
| // the prompt dialog, which in practice happens very infrequently since the |
| // dialog is modal. |
| // |
| // The callback may be invoked a long time after this method has returned. |
| // If you need to access in the callback an object that is not owned by the |
| // callback, you should ensure that the object has not been destroyed before |
| // accessing it to prevent crashes, e.g. by using weak pointer semantics. |
| virtual void PromptToEnableNfcSystemLevelSetting( |
| content::WebContents* web_contents, |
| base::OnceClosure prompt_completed_callback) = 0; |
| }; |
| |
| } // namespace permissions |
| |
| #endif // COMPONENTS_PERMISSIONS_ANDROID_NFC_NFC_SYSTEM_LEVEL_SETTING_H_ |