#ifndef DEVICE_FIDO_ATTESTED_CREDENTIAL_DATA_H_
#define DEVICE_FIDO_ATTESTED_CREDENTIAL_DATA_H_
#include <stddef.h>
#include <stdint.h>
#include <array>
#include <memory>
#include <optional>
#include <vector>
#include "base/component_export.h"
#include "base/containers/span.h"
#include "device/fido/fido_constants.h"
namespace device {
struct PublicKey;
class COMPONENT_EXPORT(DEVICE_FIDO) AttestedCredentialData {
public:
static std::optional<
std::pair<AttestedCredentialData, base::span<const uint8_t>>>
ConsumeFromCtapResponse(base::span<const uint8_t> buffer);
static std::optional<AttestedCredentialData> CreateFromU2fRegisterResponse(
base::span<const uint8_t> u2f_data,
std::unique_ptr<PublicKey> public_key);
AttestedCredentialData(AttestedCredentialData&& other);
AttestedCredentialData(
base::span<const uint8_t, kAaguidLength> aaguid,
base::span<const uint8_t, kCredentialIdLengthLength> credential_id_length,
std::vector<uint8_t> credential_id,
std::unique_ptr<PublicKey> public_key);
AttestedCredentialData(base::span<const uint8_t, kAaguidLength> aaguid,
base::span<const uint8_t> credential_id,
std::unique_ptr<PublicKey> public_key);
AttestedCredentialData(const AttestedCredentialData&) = delete;
AttestedCredentialData& operator=(const AttestedCredentialData&) = delete;
~AttestedCredentialData();
AttestedCredentialData& operator=(AttestedCredentialData&& other);
const std::vector<uint8_t>& credential_id() const { return credential_id_; }
const std::array<uint8_t, kAaguidLength>& aaguid() const { return aaguid_; }
bool IsAaguidZero() const;
bool DeleteAaguid();
std::vector<uint8_t> SerializeAsBytes() const;
const PublicKey* public_key() const;
private:
std::array<uint8_t, kAaguidLength> aaguid_;
std::array<uint8_t, kCredentialIdLengthLength> credential_id_length_;
std::vector<uint8_t> credential_id_;
std::unique_ptr<PublicKey> public_key_;
};
}
#endif