// Copyright 2013 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 NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ #define NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ #include #include #include "base/basictypes.h" #include "base/compiler_specific.h" #include "base/memory/scoped_ptr.h" #include "net/base/completion_callback.h" #include "net/base/net_export.h" #include "net/base/net_log.h" #include "net/cert/cert_verify_result.h" #include "net/cert/x509_certificate.h" #include "net/quic/crypto/proof_verifier.h" namespace net { class CertVerifier; class SingleRequestCertVerifier; // ProofVerifyDetailsChromium is the implementation-specific information that a // ProofVerifierChromium returns about a certificate verification. struct ProofVerifyDetailsChromium : public ProofVerifyDetails { public: CertVerifyResult cert_verify_result; }; // ProofVerifierChromium implements the QUIC ProofVerifier interface. // TODO(rtenneti): Add support for multiple requests for one ProofVerifier. class NET_EXPORT_PRIVATE ProofVerifierChromium : public ProofVerifier { public: ProofVerifierChromium(CertVerifier* cert_verifier, const BoundNetLog& net_log); virtual ~ProofVerifierChromium(); // ProofVerifier interface virtual Status VerifyProof(const std::string& hostname, const std::string& server_config, const std::vector& certs, const std::string& signature, std::string* error_details, scoped_ptr* details, ProofVerifierCallback* callback) OVERRIDE; private: enum State { STATE_NONE, STATE_VERIFY_CERT, STATE_VERIFY_CERT_COMPLETE, }; int DoLoop(int last_io_result); void OnIOComplete(int result); int DoVerifyCert(int result); int DoVerifyCertComplete(int result); bool VerifySignature(const std::string& signed_data, const std::string& signature, const std::string& cert); // |cert_verifier_| and |verifier_| are used for verifying certificates. CertVerifier* const cert_verifier_; scoped_ptr verifier_; // |hostname| specifies the hostname for which |certs| is a valid chain. std::string hostname_; scoped_ptr callback_; scoped_ptr verify_details_; std::string error_details_; // X509Certificate from a chain of DER encoded certificates. scoped_refptr cert_; State next_state_; BoundNetLog net_log_; DISALLOW_COPY_AND_ASSIGN(ProofVerifierChromium); }; } // namespace net #endif // NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_