|  | // Copyright (c) 2020 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_QUIC_TEST_TOOLS_TEST_TICKET_CRYPTER_H_ | 
|  | #define QUICHE_QUIC_TEST_TOOLS_TEST_TICKET_CRYPTER_H_ | 
|  |  | 
|  | #include "net/third_party/quiche/src/quic/core/crypto/proof_source.h" | 
|  |  | 
|  | namespace quic { | 
|  | namespace test { | 
|  |  | 
|  | // Provides a simple implementation of ProofSource::TicketCrypter for testing. | 
|  | // THIS IMPLEMENTATION IS NOT SECURE. It is only intended for testing purposes. | 
|  | class TestTicketCrypter : public ProofSource::TicketCrypter { | 
|  | public: | 
|  | ~TestTicketCrypter() override = default; | 
|  |  | 
|  | // TicketCrypter interface | 
|  | size_t MaxOverhead() override; | 
|  | std::vector<uint8_t> Encrypt(quiche::QuicheStringPiece in) override; | 
|  | void Decrypt(quiche::QuicheStringPiece in, | 
|  | std::unique_ptr<ProofSource::DecryptCallback> callback) override; | 
|  |  | 
|  | void SetRunCallbacksAsync(bool run_async); | 
|  | size_t NumPendingCallbacks(); | 
|  | void RunPendingCallback(size_t n); | 
|  |  | 
|  | // Allows configuring this TestTicketCrypter to fail decryption. | 
|  | void set_fail_decrypt(bool fail_decrypt) { fail_decrypt_ = fail_decrypt; } | 
|  |  | 
|  | private: | 
|  | // Performs the Decrypt operation synchronously. | 
|  | std::vector<uint8_t> Decrypt(quiche::QuicheStringPiece in); | 
|  |  | 
|  | struct PendingCallback { | 
|  | std::unique_ptr<ProofSource::DecryptCallback> callback; | 
|  | std::vector<uint8_t> decrypted_ticket; | 
|  | }; | 
|  |  | 
|  | bool fail_decrypt_ = false; | 
|  | bool run_async_ = false; | 
|  | std::vector<PendingCallback> pending_callbacks_; | 
|  | }; | 
|  |  | 
|  | }  // namespace test | 
|  | }  // namespace quic | 
|  |  | 
|  | #endif  // QUICHE_QUIC_TEST_TOOLS_TEST_TICKET_CRYPTER_H_ |