2016-04-06 00:19:16 +00:00
|
|
|
// Copyright 2016 Google Inc. All rights reserved.
|
|
|
|
//
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file or at
|
|
|
|
// https://developers.google.com/open-source/licenses/bsd
|
|
|
|
|
|
|
|
#include "packager/media/base/aes_cryptor.h"
|
|
|
|
|
|
|
|
#include <openssl/aes.h>
|
2016-04-08 18:41:17 +00:00
|
|
|
#include <openssl/err.h>
|
|
|
|
#include <openssl/rand.h>
|
2016-04-06 00:19:16 +00:00
|
|
|
|
|
|
|
#include "packager/base/logging.h"
|
|
|
|
#include "packager/base/stl_util.h"
|
|
|
|
|
|
|
|
namespace edash_packager {
|
|
|
|
namespace media {
|
|
|
|
|
|
|
|
AesCryptor::AesCryptor() : aes_key_(new AES_KEY) {}
|
|
|
|
AesCryptor::~AesCryptor() {}
|
|
|
|
|
|
|
|
bool AesCryptor::Crypt(const std::vector<uint8_t>& text,
|
|
|
|
std::vector<uint8_t>* crypt_text) {
|
|
|
|
// Save text size to make it work for in-place conversion, since the
|
|
|
|
// next statement will update the text size.
|
|
|
|
const size_t text_size = text.size();
|
|
|
|
crypt_text->resize(text_size + NumPaddingBytes(text_size));
|
|
|
|
size_t crypt_text_size = crypt_text->size();
|
|
|
|
if (!CryptInternal(text.data(), text_size, crypt_text->data(),
|
|
|
|
&crypt_text_size)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
DCHECK_LE(crypt_text_size, crypt_text->size());
|
|
|
|
crypt_text->resize(crypt_text_size);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool AesCryptor::Crypt(const std::string& text, std::string* crypt_text) {
|
|
|
|
// Save text size to make it work for in-place conversion, since the
|
|
|
|
// next statement will update the text size.
|
|
|
|
const size_t text_size = text.size();
|
|
|
|
crypt_text->resize(text_size + NumPaddingBytes(text_size));
|
|
|
|
size_t crypt_text_size = crypt_text->size();
|
|
|
|
if (!CryptInternal(reinterpret_cast<const uint8_t*>(text.data()), text_size,
|
|
|
|
reinterpret_cast<uint8_t*>(string_as_array(crypt_text)),
|
|
|
|
&crypt_text_size))
|
|
|
|
return false;
|
|
|
|
DCHECK_LE(crypt_text_size, crypt_text->size());
|
|
|
|
crypt_text->resize(crypt_text_size);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t AesCryptor::NumPaddingBytes(size_t size) const {
|
|
|
|
// No padding by default.
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-04-08 18:41:17 +00:00
|
|
|
bool AesCryptor::GenerateRandomIv(FourCC protection_scheme,
|
|
|
|
std::vector<uint8_t>* iv) {
|
|
|
|
// ISO/IEC 23001-7:2016 10.1 and 10.3 For 'cenc' and 'cens'
|
|
|
|
// default_Per_Sample_IV_Size and Per_Sample_IV_Size SHOULD be 8-bytes.
|
|
|
|
// There is no official guideline on the iv size for 'cbc1' and 'cbcs',
|
|
|
|
// but 16-byte provides better security.
|
|
|
|
const size_t iv_size =
|
|
|
|
(protection_scheme == FOURCC_cenc || protection_scheme == FOURCC_cens)
|
|
|
|
? 8
|
|
|
|
: 16;
|
|
|
|
iv->resize(iv_size);
|
|
|
|
if (RAND_bytes(iv->data(), iv_size) != 1) {
|
|
|
|
LOG(ERROR) << "RAND_bytes failed with error: "
|
|
|
|
<< ERR_error_string(ERR_get_error(), NULL);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-04-06 00:19:16 +00:00
|
|
|
} // namespace media
|
|
|
|
} // namespace edash_packager
|
|
|
|
|
|
|
|
|