ext-cryptopp/emsa2.cpp

35 lines
1.2 KiB
C++
Raw Normal View History

2005-02-10 20:11:35 +00:00
// emsa2.cpp - written and placed in the public domain by Wei Dai
#include "pch.h"
#include "emsa2.h"
#ifndef CRYPTOPP_IMPORTS
NAMESPACE_BEGIN(CryptoPP)
void EMSA2Pad::ComputeMessageRepresentative(RandomNumberGenerator &rng,
2005-07-12 04:23:32 +00:00
const byte *recoverableMessage, size_t recoverableMessageLength,
2005-02-10 20:11:35 +00:00
HashTransformation &hash, HashIdentifier hashIdentifier, bool messageEmpty,
2005-07-12 04:23:32 +00:00
byte *representative, size_t representativeBitLength) const
2005-02-10 20:11:35 +00:00
{
assert(representativeBitLength >= MinRepresentativeBitLength(hashIdentifier.second, hash.DigestSize()));
if (representativeBitLength % 8 != 7)
throw PK_SignatureScheme::InvalidKeyLength("EMSA2: EMSA2 requires a key length that is a multiple of 8");
2005-07-12 04:23:32 +00:00
size_t digestSize = hash.DigestSize();
size_t representativeByteLength = BitsToBytes(representativeBitLength);
2005-02-10 20:11:35 +00:00
representative[0] = messageEmpty ? 0x4b : 0x6b;
memset(representative+1, 0xbb, representativeByteLength-digestSize-4); // pad with 0xbb
byte *afterP2 = representative+representativeByteLength-digestSize-3;
afterP2[0] = 0xba;
hash.Final(afterP2+1);
representative[representativeByteLength-2] = *hashIdentifier.first;
representative[representativeByteLength-1] = 0xcc;
}
NAMESPACE_END
#endif