blob: ccc5d2bf493f3eafc9f829a315353f1dc2848ec4 [file] [log] [blame]
Yingdi Yu87516612015-07-10 18:03:52 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento6158f472017-08-11 18:55:09 -04002/*
3 * 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#include "security/transform/block-cipher.hpp"
Davide Pesavento6158f472017-08-11 18:55:09 -040023
24#include "encoding/buffer-stream.hpp"
Yingdi Yu87516612015-07-10 18:03:52 -070025#include "security/transform/buffer-source.hpp"
26#include "security/transform/stream-sink.hpp"
Yingdi Yu87516612015-07-10 18:03:52 -070027
28#include "boost-test.hpp"
29
30namespace ndn {
31namespace security {
32namespace transform {
33namespace tests {
34
35BOOST_AUTO_TEST_SUITE(Security)
36BOOST_AUTO_TEST_SUITE(Transform)
37BOOST_AUTO_TEST_SUITE(TestBlockCipher)
38
39BOOST_AUTO_TEST_CASE(AesCbc)
40{
Davide Pesavento6158f472017-08-11 18:55:09 -040041 const uint8_t key[] = {
Yingdi Yu87516612015-07-10 18:03:52 -070042 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
43 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f
44 };
Davide Pesavento6158f472017-08-11 18:55:09 -040045 const uint8_t iv[] = {
Yingdi Yu87516612015-07-10 18:03:52 -070046 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
47 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07
48 };
Davide Pesavento6158f472017-08-11 18:55:09 -040049 const uint8_t plainText[] = {
50 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
51 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
52 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
53 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f
54 };
55 //
56 // You can use the following shell one-liner to calculate the ciphertext:
57 // echo ${plaintext} | xxd -p -r | openssl enc -aes-128-cbc -K ${key} -iv ${iv} | xxd -i
58 //
59 const uint8_t cipherText[] = {
Yingdi Yu87516612015-07-10 18:03:52 -070060 0x07, 0x4d, 0x32, 0x68, 0xc3, 0x40, 0x64, 0x43,
61 0x1e, 0x66, 0x4c, 0x25, 0x66, 0x42, 0x0f, 0x59,
62 0x0a, 0x51, 0x19, 0x07, 0x67, 0x5c, 0x0e, 0xfa,
63 0xa6, 0x8c, 0xbb, 0xaf, 0xfd, 0xea, 0x47, 0xd4,
64 0xc7, 0x2c, 0x12, 0x34, 0x79, 0xde, 0xec, 0xc8,
65 0x75, 0x33, 0x8f, 0x6b, 0xd6, 0x55, 0xf3, 0xfa
66 };
67
68 // encrypt
69 OBufferStream os;
70 bufferSource(plainText, sizeof(plainText)) >>
Davide Pesavento6158f472017-08-11 18:55:09 -040071 blockCipher(BlockCipherAlgorithm::AES_CBC, CipherOperator::ENCRYPT,
Yingdi Yu87516612015-07-10 18:03:52 -070072 key, sizeof(key), iv, sizeof(iv)) >> streamSink(os);
73
Davide Pesavento6158f472017-08-11 18:55:09 -040074 auto buf = os.buf();
Yingdi Yu87516612015-07-10 18:03:52 -070075 BOOST_CHECK_EQUAL_COLLECTIONS(cipherText, cipherText + sizeof(cipherText),
76 buf->begin(), buf->end());
77
78 // decrypt
79 OBufferStream os2;
80 bufferSource(cipherText, sizeof(cipherText)) >>
Davide Pesavento6158f472017-08-11 18:55:09 -040081 blockCipher(BlockCipherAlgorithm::AES_CBC, CipherOperator::DECRYPT,
Yingdi Yu87516612015-07-10 18:03:52 -070082 key, sizeof(key), iv, sizeof(iv)) >> streamSink(os2);
83
Davide Pesavento6158f472017-08-11 18:55:09 -040084 auto buf2 = os2.buf();
Yingdi Yu87516612015-07-10 18:03:52 -070085 BOOST_CHECK_EQUAL_COLLECTIONS(plainText, plainText + sizeof(plainText),
86 buf2->begin(), buf2->end());
87}
88
89BOOST_AUTO_TEST_SUITE_END() // TestBlockCipher
90BOOST_AUTO_TEST_SUITE_END() // Transform
91BOOST_AUTO_TEST_SUITE_END() // Security
92
93} // namespace tests
94} // namespace transform
95} // namespace security
96} // namespace ndn