Chromium Code Reviews| Index: crypto/aead_openssl.h |
| diff --git a/crypto/aead_openssl.h b/crypto/aead_openssl.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..773cce1428686b26be80ba7076d97214f3c90bcc |
| --- /dev/null |
| +++ b/crypto/aead_openssl.h |
| @@ -0,0 +1,48 @@ |
| +// Copyright 2015 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 CRYPTO_AEAD_H_ |
| +#define CRYPTO_AEAD_H_ |
| + |
| +#include "base/strings/string_piece.h" |
| +#include "crypto/crypto_export.h" |
| + |
| +struct evp_aead_st; |
|
estark
2015/04/22 03:55:31
This seems odd to me (forward-declaring the intern
|
| + |
| +namespace crypto { |
| + |
| +// This class exposes the AES-128-CTR-HMAC-SHA256 AEAD, currently only |
| +// for OpenSSL builds. |
| +class CRYPTO_EXPORT Aead { |
| + public: |
| + enum AeadAlgorithm { AES_128_CTR_HMAC_SHA256 }; |
| + |
| + explicit Aead(AeadAlgorithm algorithm); |
| + |
| + ~Aead(); |
| + |
| + void Init(const std::string* key); |
| + |
| + bool Seal(const base::StringPiece& plaintext, |
| + const base::StringPiece& nonce, |
| + const base::StringPiece& additional_data, |
| + std::string* ciphertext) const; |
| + |
| + bool Open(const base::StringPiece& ciphertext, |
| + const base::StringPiece& nonce, |
| + const base::StringPiece& additional_data, |
| + std::string* plaintext) const; |
| + |
| + size_t KeyLength() const; |
| + |
| + size_t NonceLength() const; |
| + |
| + private: |
| + const std::string* key_; |
| + const evp_aead_st* aead_; |
| +}; |
| + |
| +} // namespace crypto |
| + |
| +#endif // CRYPTO_ENCRYPTOR_H_ |