1 // Copyright (c) 2013 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 #ifndef NET_QUIC_CRYPTO_AEAD_BASE_DECRYPTER_H_
6 #define NET_QUIC_CRYPTO_AEAD_BASE_DECRYPTER_H_
8 #include "base/compiler_specific.h"
9 #include "net/quic/crypto/quic_decrypter.h"
11 #if defined(USE_OPENSSL)
12 #include "net/quic/crypto/scoped_evp_aead_ctx.h"
16 typedef struct PK11SymKeyStr PK11SymKey
;
17 typedef SECStatus (*PK11_DecryptFunction
)(
18 PK11SymKey
* symKey
, CK_MECHANISM_TYPE mechanism
, SECItem
* param
,
19 unsigned char* out
, unsigned int* outLen
, unsigned int maxLen
,
20 const unsigned char* enc
, unsigned encLen
);
25 // AeadBaseDecrypter is the base class of AEAD QuicDecrypter subclasses.
26 class NET_EXPORT_PRIVATE AeadBaseDecrypter
: public QuicDecrypter
{
28 #if defined(USE_OPENSSL)
29 AeadBaseDecrypter(const EVP_AEAD
* aead_alg
,
32 size_t nonce_prefix_size
);
34 AeadBaseDecrypter(CK_MECHANISM_TYPE aead_mechanism
,
35 PK11_DecryptFunction pk11_decrypt
,
38 size_t nonce_prefix_size
);
40 virtual ~AeadBaseDecrypter();
42 // QuicDecrypter implementation
43 virtual bool SetKey(base::StringPiece key
) OVERRIDE
;
44 virtual bool SetNoncePrefix(base::StringPiece nonce_prefix
) OVERRIDE
;
45 virtual bool Decrypt(base::StringPiece nonce
,
46 base::StringPiece associated_data
,
47 base::StringPiece ciphertext
,
48 unsigned char* output
,
49 size_t* output_length
) OVERRIDE
;
50 virtual QuicData
* DecryptPacket(QuicPacketSequenceNumber sequence_number
,
51 base::StringPiece associated_data
,
52 base::StringPiece ciphertext
) OVERRIDE
;
53 virtual base::StringPiece
GetKey() const OVERRIDE
;
54 virtual base::StringPiece
GetNoncePrefix() const OVERRIDE
;
57 // Make these constants available to the subclasses so that the subclasses
58 // can assert at compile time their key_size_ and nonce_prefix_size_ do not
59 // exceed the maximum.
60 static const size_t kMaxKeySize
= 32;
61 static const size_t kMaxNoncePrefixSize
= 4;
63 #if !defined(USE_OPENSSL)
67 CK_GCM_PARAMS gcm_params
;
69 // USE_NSS means we are using system NSS rather than our copy of NSS.
70 // The system NSS <pkcs11n.h> header doesn't define this type yet.
71 CK_NSS_AEAD_PARAMS nss_aead_params
;
76 virtual void FillAeadParams(base::StringPiece nonce
,
77 base::StringPiece associated_data
,
79 AeadParams
* aead_params
) const = 0;
80 #endif // !defined(USE_OPENSSL)
83 #if defined(USE_OPENSSL)
84 const EVP_AEAD
* const aead_alg_
;
86 const CK_MECHANISM_TYPE aead_mechanism_
;
87 const PK11_DecryptFunction pk11_decrypt_
;
89 const size_t key_size_
;
90 const size_t auth_tag_size_
;
91 const size_t nonce_prefix_size_
;
94 unsigned char key_
[kMaxKeySize
];
96 unsigned char nonce_prefix_
[kMaxNoncePrefixSize
];
98 #if defined(USE_OPENSSL)
99 ScopedEVPAEADCtx ctx_
;
102 DISALLOW_COPY_AND_ASSIGN(AeadBaseDecrypter
);
107 #endif // NET_QUIC_CRYPTO_AEAD_BASE_DECRYPTER_H_