// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_PUBLIC_BROWSER_SMART_CARD_DELEGATE_H_
#define CONTENT_PUBLIC_BROWSER_SMART_CARD_DELEGATE_H_
#include "content/common/content_export.h"
#include "mojo/public/cpp/bindings/pending_receiver.h"
#include "services/device/public/mojom/smart_card.mojom-forward.h"
namespace content {
class BrowserContext;
class RenderFrameHost;
// Interface provided by the content embedder to support the Web Smart Card
// API.
class CONTENT_EXPORT SmartCardDelegate {
public:
// Callback type to report whether the user allowed the connection request.
using RequestReaderPermissionCallback = base::OnceCallback<void(bool)>;
SmartCardDelegate() = default;
SmartCardDelegate(SmartCardDelegate&) = delete;
SmartCardDelegate& operator=(SmartCardDelegate&) = delete;
virtual ~SmartCardDelegate() = default;
virtual mojo::PendingRemote<device::mojom::SmartCardContextFactory>
GetSmartCardContextFactory(BrowserContext& browser_context) = 0;
// Returns whether the origin is blocked from connecting to smart card
// readers.
virtual bool IsPermissionBlocked(RenderFrameHost& render_frame_host) = 0;
// Returns whether `origin` has permission to connect to the smart card reader
// names `reader_name`.
//
// Will always return false if the frame's origin IsPermissionBlocked().
virtual bool HasReaderPermission(RenderFrameHost& render_frame_host,
const std::string& reader_name) = 0;
// Shows a prompt to the user requesting permission to connect to the smart
// card reader named `reader_name`.
//
// If the frame's origin IsPermissionBlocked(), `callback` will immediately
// receive false.
virtual void RequestReaderPermission(
RenderFrameHost& render_frame_host,
const std::string& reader_name,
RequestReaderPermissionCallback callback) = 0;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_SMART_CARD_DELEGATE_H_