OLD | NEW |
| (Empty) |
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. | |
4 | |
5 #include "net/quic/crypto/null_decrypter.h" | |
6 #include "net/quic/quic_utils.h" | |
7 #include "net/quic/quic_data_reader.h" | |
8 | |
9 using base::StringPiece; | |
10 using std::string; | |
11 | |
12 namespace net { | |
13 | |
14 QuicData* NullDecrypter::Decrypt(StringPiece associated_data, | |
15 StringPiece ciphertext) { | |
16 QuicDataReader reader(ciphertext.data(), ciphertext.length()); | |
17 | |
18 uint128 hash; | |
19 if (!reader.ReadUInt128(&hash)) { | |
20 return NULL; | |
21 } | |
22 | |
23 StringPiece plaintext = reader.ReadRemainingPayload(); | |
24 | |
25 // TODO(rch): avoid buffer copy here | |
26 string buffer = associated_data.as_string(); | |
27 plaintext.AppendToString(&buffer); | |
28 | |
29 if (hash != QuicUtils::FNV1a_128_Hash(buffer.data(), buffer.length())) { | |
30 return NULL; | |
31 } | |
32 return new QuicData(plaintext.data(), plaintext.length()); | |
33 } | |
34 | |
35 } // namespace net | |
OLD | NEW |