@@ -7,6 +7,7 @@
#include < gtest/gtest.h>
#include " Common/Crypto/ec.h"
#include " Core/IOS/ES/Formats.h"
constexpr std::array<u8, 30 > PRIVATE_KEY{{0x0 , 0x1 , 0x2 , 0x3 , 0x4 , 0x5 , 0x6 , 0x7 , 0x8 , 0x9 ,
0x0 , 0x1 , 0x2 , 0x3 , 0x4 , 0x5 , 0x6 , 0x7 , 0x8 , 0x9 ,
@@ -43,3 +44,55 @@ TEST(ec, GenerateSharedSecret)
EXPECT_EQ (Common::ec::ComputeSharedSecret (PRIVATE_KEY.data (), PUBLIC_KEY.data ()), SECRET);
}
TEST (ec, SignAndVerify)
{
static constexpr std::array<u8, 20 > HASH = {{0x0 , 0x1 , 0x2 , 0x3 , 0x4 , 0x5 , 0x6 , 0x7 , 0x8 , 0x9 ,
0x0 , 0x1 , 0x2 , 0x3 , 0x4 , 0x5 , 0x6 , 0x7 , 0x8 , 0x9 }};
auto signature = Common::ec::Sign (PRIVATE_KEY.data (), HASH.data ());
EXPECT_TRUE (Common::ec::VerifySignature (PUBLIC_KEY.data (), signature.data (), HASH.data ()));
signature.fill (0xff );
EXPECT_FALSE (Common::ec::VerifySignature (PUBLIC_KEY.data (), signature.data (), HASH.data ()));
}
TEST (ec, VerifyRealWorldSignature)
{
static constexpr std::array<u8, 60 > MS_PUBKEY = {
{0x00 , 0xfd , 0x56 , 0x04 , 0x18 , 0x2c , 0xf1 , 0x75 , 0x09 , 0x21 , 0x00 , 0xc3 , 0x08 , 0xae , 0x48 ,
0x39 , 0x91 , 0x1b , 0x6f , 0x9f , 0xa1 , 0xd5 , 0x3a , 0x95 , 0xaf , 0x08 , 0x33 , 0x49 , 0x47 , 0x2b ,
0x00 , 0x01 , 0x71 , 0x31 , 0x69 , 0xb5 , 0x91 , 0xff , 0xd3 , 0x0c , 0xbf , 0x73 , 0xda , 0x76 , 0x64 ,
0xba , 0x8d , 0x0d , 0xf9 , 0x5b , 0x4d , 0x11 , 0x04 , 0x44 , 0x64 , 0x35 , 0xc0 , 0xed , 0xa4 , 0x2f }};
static constexpr std::array<u8, 0x180 > DEVICE_CERT = {
{0x00 , 0x01 , 0x00 , 0x02 , 0x00 , 0x54 , 0xe3 , 0x9a , 0x0f , 0xe6 , 0xe1 , 0x61 , 0xb6 , 0x2f , 0x9d ,
0x0c , 0xaa , 0x1e , 0xc5 , 0x58 , 0x85 , 0xa1 , 0xeb , 0x93 , 0xa5 , 0x1e , 0xf4 , 0x06 , 0x99 , 0x77 ,
0x9a , 0x46 , 0x76 , 0x01 , 0x00 , 0xb7 , 0xe4 , 0x72 , 0x10 , 0x6e , 0xa2 , 0x21 , 0x57 , 0xe0 , 0xe3 ,
0xbe , 0x48 , 0x9d , 0x7b , 0xa5 , 0x2d , 0x46 , 0x2f , 0x33 , 0x93 , 0xae , 0xb0 , 0x4b , 0x53 , 0xcb ,
0xb9 , 0xef , 0x16 , 0x70 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x52 , 0x6f , 0x6f , 0x74 , 0x2d , 0x43 , 0x41 ,
0x30 , 0x30 , 0x30 , 0x30 , 0x30 , 0x30 , 0x30 , 0x31 , 0x2d , 0x4d , 0x53 , 0x30 , 0x30 , 0x30 , 0x30 ,
0x30 , 0x30 , 0x30 , 0x32 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x02 , 0x4e , 0x47 , 0x30 , 0x34 , 0x65 , 0x35 , 0x34 , 0x32 , 0x31 , 0x64 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x6f , 0x1e , 0x5f , 0x58 , 0x01 , 0xa8 , 0x1a , 0x89 , 0x8d , 0x04 ,
0xe4 , 0x0e , 0x44 , 0x6c , 0x99 , 0x52 , 0xef , 0xe8 , 0xe9 , 0x8a , 0xec , 0x2b , 0x73 , 0xea , 0x13 ,
0x56 , 0x93 , 0xf5 , 0x1a , 0xd8 , 0x53 , 0xa8 , 0xc5 , 0xf2 , 0x00 , 0x41 , 0xe9 , 0x5e , 0x0a , 0x5d ,
0x0c , 0xdf , 0xf0 , 0xc6 , 0x96 , 0x2c , 0x98 , 0x96 , 0xa9 , 0x0f , 0xf0 , 0x2e , 0x1f , 0x0d , 0x1a ,
0xcf , 0xa8 , 0x35 , 0x52 , 0x74 , 0x36 , 0x13 , 0x88 , 0x02 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 ,
0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x00 }};
const auto device_cert = IOS::ES::CertReader{{std::cbegin (DEVICE_CERT), std::cend (DEVICE_CERT)}};
EXPECT_TRUE (Common::ec::VerifySignature (MS_PUBKEY.data (), device_cert.GetSignatureData ().data (),
device_cert.GetSha1 ().data ()));
}