blob: 9d5522e7f93712a64489a05a9eea165eef7ed2ae [file] [log] [blame]
// Copyright (c) 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef QUICHE_COMMON_PLATFORM_API_QUICHE_DEFAULT_PROOF_PROVIDERS_H_
#define QUICHE_COMMON_PLATFORM_API_QUICHE_DEFAULT_PROOF_PROVIDERS_H_
#include <memory>
#include "quiche_platform_impl/quiche_default_proof_providers_impl.h"
#include "quiche/quic/core/crypto/proof_source.h"
#include "quiche/quic/core/crypto/proof_verifier.h"
namespace quiche {
// Provides a default proof verifier that can verify a cert chain for |host|.
// The verifier has to do a good faith attempt at verifying the certificate
// against a reasonable root store, and not just always return success.
inline std::unique_ptr<quic::ProofVerifier> CreateDefaultProofVerifier(
const std::string& host) {
return CreateDefaultProofVerifierImpl(host);
}
// Provides a default proof source for CLI-based tools. The actual certificates
// used in the proof source should be confifgurable via command-line flags.
inline std::unique_ptr<quic::ProofSource> CreateDefaultProofSource() {
return CreateDefaultProofSourceImpl();
}
} // namespace quiche
#endif // QUICHE_COMMON_PLATFORM_API_QUICHE_DEFAULT_PROOF_PROVIDERS_H_