Index: net/quic/quic_crypto_client_stream.h |
diff --git a/net/quic/quic_crypto_client_stream.h b/net/quic/quic_crypto_client_stream.h |
index 3be89abca1887db0e6241e6b77ae11860ba3a168..5a7c7f08911bf0de75d12e355ff684a34d8b6daa 100644 |
--- a/net/quic/quic_crypto_client_stream.h |
+++ b/net/quic/quic_crypto_client_stream.h |
@@ -106,6 +106,10 @@ class NET_EXPORT_PRIVATE QuicCryptoClientStream : public QuicCryptoStream { |
STATE_GET_CHANNEL_ID, |
STATE_GET_CHANNEL_ID_COMPLETE, |
STATE_RECV_SHLO, |
+ STATE_INITIALIZE_SCUP, |
+ STATE_VERIFY_PROOF_SCUP, |
+ STATE_VERIFY_PROOF_COMPLETE_SCUP, |
+ STATE_VERIFY_PROOF_DONE, |
}; |
// Handles new server config and optional source-address token provided by the |
@@ -117,6 +121,16 @@ class NET_EXPORT_PRIVATE QuicCryptoClientStream : public QuicCryptoStream { |
// |in| may be NULL if the call did not result from a received message. |
void DoHandshakeLoop(const CryptoHandshakeMessage* in); |
+ // Starts the proof verification. Returns the QuicAsyncStatus returned by the |
+ // ProofVerifier's VerifyProof. |
+ QuicAsyncStatus DoVerifyProof(QuicCryptoClientConfig::CachedState* cached); |
+ |
+ // If proof is valid then it sets the proof as valid (which persists the |
+ // server config) and returns QUIC_NO_ERROR. If not, it closes the connection |
+ // and returns QUIC_PROOF_INVALID. |
+ QuicErrorCode DoVerifyProofComplete( |
+ QuicCryptoClientConfig::CachedState* cached); |
+ |
// Called to set the proof of |cached| valid. Also invokes the session's |
// OnProofValid() method. |
void SetCachedProofValid(QuicCryptoClientConfig::CachedState* cached); |