chromium/chromeos/crosapi/cpp/keystore_service_util.h

// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROMEOS_CROSAPI_CPP_KEYSTORE_SERVICE_UTIL_H_
#define CHROMEOS_CROSAPI_CPP_KEYSTORE_SERVICE_UTIL_H_

#include <optional>

#include "base/component_export.h"
#include "base/values.h"
#include "chromeos/crosapi/mojom/keystore_service.mojom.h"

namespace crosapi {
namespace keystore_service_util {

// The WebCrypto string for ECDSA.
COMPONENT_EXPORT(CROSAPI)
extern const char kWebCryptoEcdsa[];

// The WebCrypto string for PKCS1.
COMPONENT_EXPORT(CROSAPI)
extern const char kWebCryptoRsassaPkcs1v15[];

// The WebCrypto string for the P-256 named curve.
COMPONENT_EXPORT(CROSAPI)
extern const char kWebCryptoNamedCurveP256[];

// Converts a crosapi signing algorithm into a WebCrypto dictionary. Returns
// std::nullopt on error.
COMPONENT_EXPORT(CROSAPI)
std::optional<base::Value::Dict> DictionaryFromSigningAlgorithm(
    const mojom::KeystoreSigningAlgorithmPtr& algorithm);

// Converts a WebCrypto dictionary into a crosapi signing algorithm. Returns
// std::nullopt on error.
COMPONENT_EXPORT(CROSAPI)
std::optional<mojom::KeystoreSigningAlgorithmPtr>
SigningAlgorithmFromDictionary(const base::Value::Dict& dictionary);

// Creates the KeystorePKCS115Params variant of the KeystoreSigningAlgorithm
// union and populates the modulus_length field with |modulus_length|.
COMPONENT_EXPORT(CROSAPI)
mojom::KeystoreSigningAlgorithmPtr MakeRsaKeystoreSigningAlgorithm(
    unsigned int modulus_length,
    bool sw_backed);

// Creates the KeystoreECDSAParams variant of the KeystoreSigningAlgorithm
// union and populates the named_curve field with |modulus_length|.
COMPONENT_EXPORT(CROSAPI)
mojom::KeystoreSigningAlgorithmPtr MakeEcKeystoreSigningAlgorithm(
    const std::string& named_curve);

}  // namespace keystore_service_util
}  // namespace crosapi

#endif  // CHROMEOS_CROSAPI_CPP_KEYSTORE_SERVICE_UTIL_H_