Index: net/quic/crypto/chacha20_poly1305_encrypter.h |
=================================================================== |
--- net/quic/crypto/chacha20_poly1305_encrypter.h (revision 0) |
+++ net/quic/crypto/chacha20_poly1305_encrypter.h (revision 0) |
@@ -0,0 +1,43 @@ |
+// Copyright (c) 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_CHACHA20_POLY1305_ENCRYPTER_H_ |
+#define NET_QUIC_CRYPTO_CHACHA20_POLY1305_ENCRYPTER_H_ |
+ |
+#include "net/quic/crypto/aead_base_encrypter.h" |
+ |
+namespace net { |
+ |
+// A ChaCha20Poly1305Encrypter is a QuicEncrypter that implements the |
+// AEAD_CHACHA20_POLY1305 algorithm specified in |
+// draft-agl-tls-chacha20poly1305-04. Create an instance by calling |
+// QuicEncrypter::Create(kCC12). |
+// |
+// It uses an authentication tag of 16 bytes (128 bits). There is no |
+// fixed nonce prefix. |
+class NET_EXPORT_PRIVATE ChaCha20Poly1305Encrypter : public AeadBaseEncrypter { |
+ public: |
+ enum { |
+ kAuthTagSize = 16, |
+ }; |
+ |
+ ChaCha20Poly1305Encrypter(); |
+ virtual ~ChaCha20Poly1305Encrypter(); |
+ |
+ // Returns true if the underlying crypto library supports ChaCha20+Poly1305. |
+ static bool IsSupported(); |
+ |
+#if !defined(USE_OPENSSL) |
+ protected: |
+ // AeadBaseEncrypter methods: |
+ virtual void FillAeadParams(base::StringPiece nonce, |
+ base::StringPiece associated_data, |
+ size_t auth_tag_size, |
+ AeadParams* aead_params) const OVERRIDE; |
+#endif |
+}; |
+ |
+} // namespace net |
+ |
+#endif // NET_QUIC_CRYPTO_CHACHA20_POLY1305_ENCRYPTER_H_ |
Property changes on: net/quic/crypto/chacha20_poly1305_encrypter.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |