1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "net/quic/crypto/null_encrypter.h"
6 #include "net/quic/quic_data_writer.h"
7 #include "net/quic/quic_utils.h"
9 using base::StringPiece
;
14 const size_t kHashSizeShort
= 12; // size of uint128 serialized short
16 NullEncrypter::NullEncrypter() {}
18 bool NullEncrypter::SetKey(StringPiece key
) { return key
.empty(); }
20 bool NullEncrypter::SetNoncePrefix(StringPiece nonce_prefix
) {
21 return nonce_prefix
.empty();
24 bool NullEncrypter::Encrypt(
25 StringPiece
/*nonce*/,
26 StringPiece associated_data
,
27 StringPiece plaintext
,
28 unsigned char* output
) {
29 string buffer
= associated_data
.as_string();
30 plaintext
.AppendToString(&buffer
);
31 uint128 hash
= QuicUtils::FNV1a_128_Hash(buffer
.data(), buffer
.length());
32 QuicUtils::SerializeUint128Short(hash
, output
);
33 memcpy(output
+ GetHashLength(), plaintext
.data(), plaintext
.size());
37 QuicData
* NullEncrypter::EncryptPacket(
38 QuicPacketSequenceNumber
/*sequence_number*/,
39 StringPiece associated_data
,
40 StringPiece plaintext
) {
41 const size_t len
= plaintext
.size() + GetHashLength();
42 uint8
* buffer
= new uint8
[len
];
43 Encrypt(StringPiece(), associated_data
, plaintext
, buffer
);
44 return new QuicData(reinterpret_cast<char*>(buffer
), len
, true);
47 size_t NullEncrypter::GetKeySize() const { return 0; }
49 size_t NullEncrypter::GetNoncePrefixSize() const { return 0; }
51 size_t NullEncrypter::GetMaxPlaintextSize(size_t ciphertext_size
) const {
52 return ciphertext_size
- GetHashLength();
55 size_t NullEncrypter::GetCiphertextSize(size_t plaintext_size
) const {
56 return plaintext_size
+ GetHashLength();
59 StringPiece
NullEncrypter::GetKey() const { return StringPiece(); }
61 StringPiece
NullEncrypter::GetNoncePrefix() const { return StringPiece(); }
63 size_t NullEncrypter::GetHashLength() const {
64 return kHashSizeShort
;