| Index: net/quic/crypto/chacha20_poly1305_encrypter_nss.cc
|
| ===================================================================
|
| --- net/quic/crypto/chacha20_poly1305_encrypter_nss.cc (revision 0)
|
| +++ net/quic/crypto/chacha20_poly1305_encrypter_nss.cc (revision 0)
|
| @@ -0,0 +1,52 @@
|
| +// 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.
|
| +
|
| +#include "net/quic/crypto/chacha20_poly1305_encrypter.h"
|
| +
|
| +// This is a bodge to allow this code to be compiled against system NSS
|
| +// headers.
|
| +#if defined(USE_NSS)
|
| +#define CKM_NSS_CHACHA20_POLY1305 (CKM_NSS + 26)
|
| +#endif
|
| +
|
| +using base::StringPiece;
|
| +
|
| +namespace net {
|
| +
|
| +namespace {
|
| +
|
| +const size_t kKeySize = 32;
|
| +const size_t kNoncePrefixSize = 0;
|
| +
|
| +} // namespace
|
| +
|
| +ChaCha20Poly1305Encrypter::ChaCha20Poly1305Encrypter()
|
| + : AeadBaseEncrypter(CKM_NSS_CHACHA20_POLY1305, kKeySize, kAuthTagSize,
|
| + kNoncePrefixSize) {
|
| + COMPILE_ASSERT(kKeySize <= kMaxKeySize, key_size_too_big);
|
| + COMPILE_ASSERT(kNoncePrefixSize <= kMaxNoncePrefixSize,
|
| + nonce_prefix_size_too_big);
|
| +}
|
| +
|
| +ChaCha20Poly1305Encrypter::~ChaCha20Poly1305Encrypter() {}
|
| +
|
| +// static
|
| +bool ChaCha20Poly1305Encrypter::IsSupported() {
|
| +#if defined(USE_NSS)
|
| + // System NSS doesn't support ChaCha20+Poly1305 yet.
|
| + return false;
|
| +#else
|
| + // TODO(wtc): return true when FillAeadParams is implemented.
|
| + return false;
|
| +#endif
|
| +}
|
| +
|
| +void ChaCha20Poly1305Encrypter::FillAeadParams(StringPiece nonce,
|
| + StringPiece associated_data,
|
| + size_t auth_tag_size,
|
| + AeadParams* aead_params) const {
|
| + // TODO(wtc): implement this.
|
| +}
|
| +
|
| +} // namespace net
|
|
|
| Property changes on: net/quic/crypto/chacha20_poly1305_encrypter_nss.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|