blob: 320e1841d8259c63404a80de3b898af9af318188 [file] [log] [blame]
Yingdi Yu87516612015-07-10 18:03:52 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Davide Pesavento794f6872017-05-15 23:33:38 -04003 * Copyright (c) 2013-2017 Regents of the University of California.
Yingdi Yu87516612015-07-10 18:03:52 -07004 *
5 * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6 *
7 * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8 * terms of the GNU Lesser General Public License as published by the Free Software
9 * Foundation, either version 3 of the License, or (at your option) any later version.
10 *
11 * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License and GNU Lesser
16 * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17 * <http://www.gnu.org/licenses/>.
18 *
19 * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20 */
21
22#ifndef NDN_CXX_SECURITY_TRANSFORM_BLOCK_CIPHER_HPP
23#define NDN_CXX_SECURITY_TRANSFORM_BLOCK_CIPHER_HPP
24
25#include "transform-base.hpp"
26#include "../security-common.hpp"
27
28namespace ndn {
29namespace security {
30namespace transform {
31
32/**
33 * @brief The module to encrypt data using block cipher.
34 *
35 * The padding scheme of the block cipher is set to the default padding scheme of OpenSSl,
36 * which is PKCS padding.
37 */
38class BlockCipher : public Transform
39{
40public:
41 /**
42 * @brief Create a block cipher
43 *
44 * @param algo The block cipher algorithm (e.g., EncryptMode::AES_CBC).
45 * @param op The operation that the cipher needs to perform, e.g., CipherOperator::ENCRYPT or CipherOperator::DECRYPT
46 * @param key The pointer to the key.
47 * @param keyLen The size of the key.
48 * @param iv The pointer to the initial vector.
49 * @param ivLen The length of the initial vector.
50 */
51 BlockCipher(BlockCipherAlgorithm algo, CipherOperator op,
52 const uint8_t* key, size_t keyLen,
53 const uint8_t* iv, size_t ivLen);
54
55private:
56 /**
57 * @brief Read partial transformation result (if exists) from BIO
58 */
Davide Pesavento57c07df2016-12-11 18:41:45 -050059 void
Yingdi Yu87516612015-07-10 18:03:52 -070060 preTransform() final;
61
62 /**
63 * @brief Write @p data into the cipher
64 *
65 * @return number of bytes that are actually accepted
66 */
Davide Pesavento57c07df2016-12-11 18:41:45 -050067 size_t
Yingdi Yu87516612015-07-10 18:03:52 -070068 convert(const uint8_t* data, size_t dataLen) final;
69
70 /**
71 * @brief Finalize the encryption
72 */
Davide Pesavento57c07df2016-12-11 18:41:45 -050073 void
Yingdi Yu87516612015-07-10 18:03:52 -070074 finalize() final;
75
76 /**
77 * @brief Fill output buffer with the encryption result from BIO.
78 */
79 void
80 fillOutputBuffer();
81
82 /**
83 * @return true if the cipher does not have partial result.
84 */
85 bool
86 isConverterEmpty() const;
87
88private:
Yingdi Yu87516612015-07-10 18:03:52 -070089 void
90 initializeAesCbc(const uint8_t* key, size_t keyLen,
91 const uint8_t* iv, size_t ivLen,
92 CipherOperator op);
93
94private:
95 class Impl;
Davide Pesavento794f6872017-05-15 23:33:38 -040096 const unique_ptr<Impl> m_impl;
Yingdi Yu87516612015-07-10 18:03:52 -070097};
98
99unique_ptr<Transform>
100blockCipher(BlockCipherAlgorithm algo, CipherOperator op,
101 const uint8_t* key, size_t keyLen,
102 const uint8_t* iv, size_t ivLen);
103
104} // namespace transform
105} // namespace security
106} // namespace ndn
107
108#endif // NDN_CXX_SECURITY_TRANSFORM_BLOCK_CIPHER_HPP