| Index: net/quic/crypto/quic_encrypter.h | 
| diff --git a/net/quic/crypto/quic_encrypter.h b/net/quic/crypto/quic_encrypter.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..32953634b993448bfb607a9bed16cb0c0d259b06 | 
| --- /dev/null | 
| +++ b/net/quic/crypto/quic_encrypter.h | 
| @@ -0,0 +1,37 @@ | 
| +// Copyright (c) 2012 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_QUIC_ENCRYPTER_H_ | 
| +#define NET_QUIC_CRYPTO_QUIC_ENCRYPTER_H_ | 
| + | 
| +#include "net/quic/crypto/crypto_protocol.h" | 
| +#include "net/quic/quic_protocol.h" | 
| + | 
| +namespace net { | 
| + | 
| +class QuicEncrypter { | 
| + public: | 
| +  virtual ~QuicEncrypter() {} | 
| + | 
| +  static QuicEncrypter* Create(CryptoTag algorithm); | 
| + | 
| +  // Returns a newly created QuicData object containing the encrypted | 
| +  // |plaintext| as well as a MAC over both |plaintext| and |associated_data|, | 
| +  // or NULL if there is an error. | 
| +  virtual QuicData* Encrypt(base::StringPiece associated_data, | 
| +                            base::StringPiece plaintext) = 0; | 
| + | 
| +  // Returns the maximum length of plaintext that can be encrypted | 
| +  // to ciphertext no larger than |ciphertext_size|. | 
| +  virtual size_t GetMaxPlaintextSize(size_t ciphertext_size) = 0; | 
| + | 
| +  // Returns the length of the ciphertext that would be generated by encrypting | 
| +  // to plaintext of size |plaintext_size|. | 
| +  virtual size_t GetCiphertextSize(size_t plaintext_size) = 0; | 
| + | 
| +}; | 
| + | 
| +}  // namespace net | 
| + | 
| +#endif  // NET_QUIC_CRYPTO_QUIC_ENCRYPTER_H_ | 
|  |