chromium/components/permissions/android/nfc/nfc_system_level_setting.h

// 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_