1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
// Copyright 2024 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_ENTERPRISE_CLIENT_CERTIFICATES_CORE_CERTIFICATE_STORE_H_
#define COMPONENTS_ENTERPRISE_CLIENT_CERTIFICATES_CORE_CERTIFICATE_STORE_H_
#include <memory>
#include <optional>
#include <string>
#include "base/functional/callback_forward.h"
#include "base/memory/scoped_refptr.h"
#include "components/enterprise/client_certificates/core/client_identity.h"
#include "components/enterprise/client_certificates/core/store_error.h"
#include "components/keyed_service/core/keyed_service.h"
namespace client_certificates_pb {
class ClientIdentity;
}
namespace net {
class X509Certificate;
} // namespace net
namespace client_certificates {
class PrivateKey;
// Interface for classes that facilitate the creation and storage of private
// keys, and storage of certificates along with a private key.
class CertificateStore : public KeyedService {
public:
CertificateStore();
~CertificateStore() override;
// Will create a private key with the strongest protection available on the
// device and store it under `identity_name`. If successful,
// `callback` will be invoked with the key once it has been created and
// stored. If an error occurred, `callback` will be invoked with the error.
virtual void CreatePrivateKey(
const std::string& identity_name,
base::OnceCallback<void(StoreErrorOr<scoped_refptr<PrivateKey>>)>
callback) = 0;
// Will store the given `certificate` under `identity_name`.
// Will call `callback` with std::nullopt if successful, or an error if not.
// This API can be used to update an expired certificate without changing
// the existing private key.
virtual void CommitCertificate(
const std::string& identity_name,
scoped_refptr<net::X509Certificate> certificate,
base::OnceCallback<void(std::optional<StoreError>)> callback) = 0;
// Will move the private key with name `temporary_identity_name` and move
// it into `final_identity_name` alongside the given `certificate`.
// Will overwrite any pre-existing identity stored under
// `final_identity_name`. Will call `callback` with std::nullopt if
// successful, or an error if not. This API can be used as the last step in
// committing an updated identity when the private key needed to be rotated.
virtual void CommitIdentity(
const std::string& temporary_identity_name,
const std::string& final_identity_name,
scoped_refptr<net::X509Certificate> certificate,
base::OnceCallback<void(std::optional<StoreError>)> callback) = 0;
// Will attempt to retrieve an identity with name `identity_name` and load it
// into memory. Will return the loaded identity via `callback`. Will invoke
// `callback` with std::nullopt if the identity doesn't exist, or with an
// error if something went wrong.
virtual void GetIdentity(
const std::string& identity_name,
base::OnceCallback<void(StoreErrorOr<std::optional<ClientIdentity>>)>
callback) = 0;
};
} // namespace client_certificates
#endif // COMPONENTS_ENTERPRISE_CLIENT_CERTIFICATES_CORE_CERTIFICATE_STORE_H_
|