/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This code is made available to you under your choice of the following sets
* of licensing terms:
*/
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
/* Copyright 2015 Mozilla Contributors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "pkixgtest.h"
#include "mozpkix/pkixder.h"
#include "mozpkix/pkixnss.h"
using namespace mozilla::pkix;
using namespace mozilla::pkix::der;
using namespace mozilla::pkix::test;
struct VerifySignedDataNSSTestParams
{
ByteString data;
DigestAlgorithm digestAlgorithm;
ByteString signature;
PublicKeyAlgorithm publicKeyAlgorithm;
ByteString subjectPublicKeyInfo;
Result expectedResult;
};
::std::ostream&
operator <<(::std::ostream& os,
const VerifySignedDataNSSTestParams&)
{
return os <<
"TODO (bug 1318770)" ;
}
#define BS(s) ByteString(s, MOZILLA_PKIX_ARRAY_LENGTH(s))
static const uint8_t kData[] = {
0 x53,
0 x70,
0 x68,
0 x79,
0 x6e,
0 x78,
0 x20,
0 x6f,
0 x66,
0 x20,
0 x62,
0 x6c,
0 x61,
0 x63,
0 x6b,
0 x20,
0 x71,
0 x75,
0 x61,
0 x72,
0 x74,
0 x7a,
0 x2c,
0 x20,
0 x6a,
0 x75,
0 x64,
0 x67,
0 x65,
0 x20,
0 x6d,
0 x79,
0 x20,
0 x76,
0 x6f,
0 x77,
0 x2e
};
static const uint8_t kRsaSubjectPublicKeyInfo[] = {
0 x30,
0 x82,
0 x01,
0 x22,
0 x30,
0 x0d,
0 x06,
0 x09,
0 x2a,
0 x86,
0 x48,
0 x86,
0 xf7,
0 x0d,
0 x01,
0 x01,
0 x01,
0 x05,
0 x00,
0 x03,
0 x82,
0 x01,
0 x0f,
0 x00,
0 x30,
0 x82,
0 x01,
0 x0a,
0 x02,
0 x82,
0 x01,
0 x01,
0 x00,
0 xdb,
0 x75,
0 x02,
0 x7b,
0 xeb,
0 xf7,
0 x3b,
0 x31,
0 x03,
0 x71,
0 x77,
0 x34,
0 x88,
0 x8f,
0 xb2,
0 x0d,
0 xa6,
0 xbe,
0 x7d,
0 xa7,
0 xdd,
0 xac,
0 x0e,
0 x99,
0 x50,
0 x46,
0 x69,
0 x90,
0 xe6,
0 x7c,
0 x3a,
0 xa6,
0 xf9,
0 x3e,
0 x02,
0 x15,
0 x3c,
0 xf7,
0 xb9,
0 xf4,
0 xab,
0 x3d,
0 x54,
0 x2c,
0 x0d,
0 x84,
0 x94,
0 x37,
0 x95,
0 xbc,
0 x2b,
0 x56,
0 x05,
0 x00,
0 xfa,
0 xa2,
0 x08,
0 xf9,
0 xcd,
0 xc3,
0 x2b,
0 x9a,
0 x58,
0 x80,
0 x11,
0 x49,
0 xe0,
0 x69,
0 xf9,
0 x81,
0 x08,
0 x52,
0 x75,
0 xb4,
0 xc1,
0 x94,
0 xa2,
0 x67,
0 x22,
0 x5b,
0 xfb,
0 xe4,
0 x74,
0 xaa,
0 x24,
0 xb7,
0 xa3,
0 x5e,
0 x2c,
0 x6b,
0 xda,
0 x20,
0 x09,
0 x5a,
0 x5e,
0 x4f,
0 x95,
0 xe8,
0 x24,
0 x71,
0 x64,
0 x65,
0 x29,
0 x2c,
0 x44,
0 xb5,
0 x17,
0 xec,
0 xe4,
0 x68,
0 xc3,
0 x69,
0 x6b,
0 x53,
0 x6d,
0 xa1,
0 xa0,
0 xb1,
0 x74,
0 xe2,
0 x28,
0 x03,
0 xda,
0 x20,
0 xca,
0 xa4,
0 x45,
0 x1e,
0 xf6,
0 xab,
0 xc7,
0 xe9,
0 xcb,
0 xe3,
0 x9a,
0 x16,
0 x34,
0 x8f,
0 xd7,
0 xf3,
0 x66,
0 x74,
0 xea,
0 xe7,
0 x32,
0 xf3,
0 xd2,
0 x55,
0 x6c,
0 x8f,
0 x38,
0 xb8,
0 x1b,
0 x38,
0 x08,
0 x4c,
0 x1f,
0 x41,
0 x74,
0 x35,
0 x9e,
0 x2d,
0 x29,
0 xed,
0 x72,
0 xe3,
0 xda,
0 x18,
0 x01,
0 xf4,
0 x5f,
0 x8d,
0 x9d,
0 x72,
0 x13,
0 x18,
0 x09,
0 x1f,
0 xbe,
0 xb0,
0 x20,
0 x90,
0 xc4,
0 x3d,
0 x2c,
0 x4f,
0 xf2,
0 xdc,
0 x99,
0 x8a,
0 xae,
0 x02,
0 xd6,
0 xef,
0 x5a,
0 x88,
0 x08,
0 x15,
0 x85,
0 xdd,
0 xaa,
0 xce,
0 xe4,
0 x4b,
0 x3f,
0 xe9,
0 xf4,
0 xfa,
0 x54,
0 xde,
0 xb0,
0 x30,
0 xdf,
0 x8f,
0 x14,
0 x2c,
0 x49,
0 x69,
0 x24,
0 xe4,
0 xa9,
0 xeb,
0 x62,
0 x15,
0 xf8,
0 x8a,
0 xd8,
0 xe4,
0 x8a,
0 x99,
0 x2b,
0 xdb,
0 x68,
0 x8b,
0 x2a,
0 x61,
0 xbd,
0 xc0,
0 x57,
0 xff,
0 x5f,
0 xee,
0 xe9,
0 xac,
0 x06,
0 x77,
0 x13,
0 x7b,
0 x2e,
0 xd1,
0 x76,
0 x6c,
0 xe8,
0 x6c,
0 x73,
0 x1f,
0 x02,
0 x03,
0 x01,
0 x00,
0 x01
};
// Use `openssl dgst -binary -sha1` to obtain the hash of the data, and then
// `openssl pkeyutl` with `-pkeyopt rsa_padding_mode:pkcs1` and `-pkeyopt
// digest:sha1` to create the signature.
static const uint8_t kRsaPkcs1Sha1Signature[] = {
0 x6c,
0 x11,
0 x88,
0 xc9,
0 x6b,
0 x06,
0 xf2,
0 x55,
0 x67,
0 xa1,
0 x30,
0 x3b,
0 x0a,
0 xf5,
0 x20,
0 x84,
0 xd7,
0 x3c,
0 x44,
0 xc8,
0 x25,
0 x67,
0 x58,
0 x2a,
0 x9d,
0 x7b,
0 xbc,
0 x92,
0 x01,
0 xbd,
0 x4c,
0 x11,
0 x51,
0 x2f,
0 x18,
0 x85,
0 xd5,
0 xef,
0 xd5,
0 x35,
0 x1e,
0 x12,
0 x89,
0 x0e,
0 x36,
0 xaa,
0 x86,
0 xb8,
0 xaf,
0 x81,
0 x5b,
0 xf2,
0 x65,
0 xde,
0 x07,
0 xb9,
0 xbc,
0 x1a,
0 x22,
0 xf1,
0 xac,
0 x8e,
0 x95,
0 x5d,
0 x3d,
0 x5b,
0 x15,
0 x92,
0 x12,
0 x07,
0 x24,
0 x14,
0 x89,
0 x5a,
0 x00,
0 xfe,
0 x0c,
0 xf3,
0 x99,
0 x0b,
0 x83,
0 x3f,
0 x09,
0 x2c,
0 x82,
0 x06,
0 x84,
0 x21,
0 xd3,
0 x79,
0 xc7,
0 xac,
0 x16,
0 x89,
0 x2e,
0 x81,
0 xb4,
0 x29,
0 x88,
0 x08,
0 x26,
0 x30,
0 x79,
0 x40,
0 x96,
0 xa7,
0 xd9,
0 x5c,
0 x67,
0 xdb,
0 x94,
0 x77,
0 x20,
0 xcb,
0 x07,
0 x55,
0 xa7,
0 x37,
0 xb4,
0 xf9,
0 xcc,
0 x9a,
0 x9a,
0 x22,
0 x42,
0 xb5,
0 xce,
0 xcc,
0 x0f,
0 x13,
0 x54,
0 x2f,
0 x1d,
0 x7f,
0 xa9,
0 xb7,
0 x7a,
0 x06,
0 x6f,
0 x15,
0 x16,
0 xe2,
0 x30,
0 x5b,
0 xe0,
0 x84,
0 xe6,
0 x28,
0 x65,
0 x53,
0 x6a,
0 xab,
0 x67,
0 x85,
0 x53,
0 x1b,
0 xaf,
0 x9f,
0 x9b,
0 x60,
0 x18,
0 xb8,
0 xf1,
0 xd5,
0 x53,
0 xc9,
0 x48,
0 x21,
0 xd9,
0 x81,
0 xbd,
0 xeb,
0 x44,
0 x82,
0 x3c,
0 x66,
0 x91,
0 x63,
0 xa0,
0 x00,
0 x9b,
0 x23,
0 x0a,
0 xef,
0 xfe,
0 x2d,
0 x17,
0 xd5,
0 x99,
0 x64,
0 x43,
0 x32,
0 x58,
0 xae,
0 x96,
0 x36,
0 x5e,
0 x80,
0 x7c,
0 xb7,
0 x01,
0 x44,
0 x06,
0 x19,
0 xba,
0 x52,
0 x30,
0 xc9,
0 x66,
0 xb4,
0 x4e,
0 x7e,
0 xeb,
0 xe2,
0 x97,
0 x37,
0 x0c,
0 xbd,
0 xa6,
0 xe6,
0 x20,
0 x05,
0 x47,
0 x79,
0 x36,
0 x56,
0 x48,
0 x9d,
0 x91,
0 x7e,
0 x61,
0 x67,
0 xbd,
0 xc3,
0 x12,
0 xa8,
0 x2a,
0 xf0,
0 xfc,
0 xee,
0 x78,
0 x18,
0 x59,
0 x7e,
0 xd6,
0 xd1,
0 x55,
0 xee,
0 xf5,
0 xaf,
0 xb8,
0 xbd,
0 x16,
0 xd8,
0 x01,
0 xca
};
// Similarly as above, but with sha256.
static const uint8_t kRsaPkcs1Sha256Signature[] = {
0 x9c,
0 xbd,
0 x2d,
0 x6c,
0 x4a,
0 xe2,
0 x47,
0 xc9,
0 xe2,
0 xd9,
0 x48,
0 xa6,
0 x3a,
0 x3d,
0 x43,
0 xf5,
0 x5e,
0 xd0,
0 x11,
0 x9a,
0 xab,
0 x79,
0 x71,
0 xb6,
0 x97,
0 x7c,
0 x6a,
0 xc7,
0 x96,
0 x29,
0 x21,
0 xbd,
0 xe2,
0 xe7,
0 xee,
0 x01,
0 x1b,
0 x0f,
0 xd1,
0 x31,
0 xeb,
0 xa6,
0 xbe,
0 xec,
0 xc0,
0 x64,
0 x63,
0 xf4,
0 x71,
0 xd4,
0 x7b,
0 x1b,
0 x02,
0 xba,
0 xae,
0 xf3,
0 x7a,
0 x81,
0 x5c,
0 x78,
0 xd5,
0 x75,
0 xee,
0 x9a,
0 x4a,
0 x97,
0 x64,
0 x6a,
0 x75,
0 x12,
0 xa3,
0 xca,
0 xe5,
0 x2f,
0 x40,
0 x43,
0 x1e,
0 xe0,
0 x5c,
0 xa2,
0 x2f,
0 x3e,
0 xf0,
0 xdd,
0 x5e,
0 xdc,
0 x57,
0 x3a,
0 xfc,
0 x35,
0 x84,
0 x1d,
0 x79,
0 x2e,
0 x82,
0 xeb,
0 x0d,
0 xef,
0 xdf,
0 x12,
0 x96,
0 xe0,
0 x1f,
0 xe8,
0 x16,
0 xe0,
0 x6c,
0 xf9,
0 xf4,
0 x06,
0 x6c,
0 x51,
0 x40,
0 x3d,
0 x23,
0 xac,
0 x24,
0 x9c,
0 x6c,
0 xe6,
0 x1a,
0 x84,
0 x89,
0 x8c,
0 x6d,
0 xbe,
0 xc0,
0 x42,
0 x70,
0 x9c,
0 xdf,
0 xcb,
0 x70,
0 x7e,
0 x4f,
0 xbc,
0 x87,
0 x2b,
0 xc0,
0 xb7,
0 xcf,
0 x21,
0 xfe,
0 x1d,
0 x2e,
0 x38,
0 x00,
0 xe4,
0 xaf,
0 x88,
0 x44,
0 x16,
0 x28,
0 x38,
0 xf7,
0 x4e,
0 x07,
0 xf6,
0 x82,
0 x20,
0 x96,
0 x4c,
0 x33,
0 x15,
0 xb6,
0 xb1,
0 x4b,
0 x08,
0 x4e,
0 x18,
0 x3a,
0 xaa,
0 x2f,
0 x69,
0 xbe,
0 x5c,
0 x62,
0 x1e,
0 xf1,
0 x02,
0 xa8,
0 xa3,
0 x54,
0 x85,
0 x72,
0 xd0,
0 x39,
0 x4d,
0 xa8,
0 xec,
0 xe2,
0 x2e,
0 xb8,
0 x4d,
0 x93,
0 xd6,
0 x91,
0 x84,
0 x26,
0 x09,
0 xf0,
0 x95,
0 x37,
0 x9f,
0 x28,
0 x0e,
0 x93,
0 xbe,
0 x71,
0 x4c,
0 xb7,
0 xf8,
0 xc6,
0 xa7,
0 x40,
0 x9e,
0 xf4,
0 xe2,
0 x6a,
0 x1c,
0 xd7,
0 x87,
0 xa5,
0 x0a,
0 xf1,
0 xc4,
0 x1b,
0 x85,
0 x75,
0 x3b,
0 x23,
0 x69,
0 xca,
0 x20,
0 x14,
0 x8f,
0 x56,
0 x28,
0 xa3,
0 x9f,
0 xd8,
0 xda,
0 xd8,
0 xff,
0 x54,
0 x1b,
0 x2b,
0 x40,
0 xa1,
0 x04,
0 x63,
0 xd9,
0 x36,
0 x64,
0 x98,
0 x78
};
// As above.
static const uint8_t kRsaPkcs1Sha384Signature[] = {
0 xc4,
0 x63,
0 x51,
0 x52,
0 x13,
0 x87,
0 x56,
0 x43,
0 x57,
0 x76,
0 xf9,
0 x19,
0 x0b,
0 x12,
0 xbc,
0 xe3,
0 x67,
0 x4b,
0 x7e,
0 xed,
0 xb4,
0 xb3,
0 xc9,
0 xe5,
0 xa7,
0 xa7,
0 x00,
0 x73,
0 x1a,
0 x58,
0 x1a,
0 xf0,
0 x5b,
0 xe2,
0 xe3,
0 x9b,
0 xe4,
0 xb1,
0 x0a,
0 x7b,
0 xaf,
0 x1d,
0 x5a,
0 x58,
0 x99,
0 xa2,
0 xa4,
0 x61,
0 x92,
0 x13,
0 x6c,
0 xb7,
0 x2a,
0 xdb,
0 xdd,
0 x3e,
0 xc9,
0 xe5,
0 x2a,
0 x60,
0 x5d,
0 xf2,
0 x0a,
0 x57,
0 x5a,
0 x65,
0 x3d,
0 xd1,
0 x5e,
0 xc1,
0 x5b,
0 x47,
0 xa9,
0 x86,
0 x56,
0 x08,
0 x05,
0 xee,
0 x08,
0 xf9,
0 x35,
0 x4a,
0 x46,
0 xa5,
0 x6a,
0 x23,
0 x01,
0 x6d,
0 xc3,
0 x89,
0 x1f,
0 x26,
0 x2e,
0 x44,
0 xa8,
0 x50,
0 x84,
0 x9b,
0 x5d,
0 x33,
0 x5f,
0 xf2,
0 x6b,
0 xc5,
0 xdb,
0 x5a,
0 xcd,
0 xec,
0 xd4,
0 xd2,
0 x16,
0 x79,
0 x8c,
0 x4c,
0 x78,
0 x9a,
0 xf0,
0 x66,
0 x19,
0 xc7,
0 x45,
0 x97,
0 x15,
0 x22,
0 x9b,
0 xad,
0 xe1,
0 xda,
0 x1a,
0 x68,
0 x8f,
0 xde,
0 x9c,
0 x11,
0 xb9,
0 x63,
0 xeb,
0 x48,
0 x0d,
0 xd6,
0 xb7,
0 x47,
0 x61,
0 xd4,
0 x19,
0 x12,
0 x12,
0 x23,
0 x5c,
0 x86,
0 x15,
0 x87,
0 x83,
0 x32,
0 x11,
0 xb3,
0 x8e,
0 xdb,
0 x64,
0 x54,
0 x4e,
0 xf5,
0 x17,
0 xf9,
0 x2c,
0 xa2,
0 xb8,
0 x85,
0 x3b,
0 x60,
0 x75,
0 xb5,
0 x80,
0 xb5,
0 x75,
0 x5a,
0 xf3,
0 xf2,
0 xdd,
0 xef,
0 xf0,
0 x62,
0 x14,
0 x7e,
0 xba,
0 x7b,
0 x9b,
0 xf6,
0 x4a,
0 x67,
0 x71,
0 xa1,
0 x38,
0 x05,
0 xfb,
0 x1d,
0 xeb,
0 xd7,
0 x7c,
0 x51,
0 xdd,
0 xf2,
0 x06,
0 x1b,
0 x8f,
0 xfe,
0 x31,
0 x9f,
0 xe7,
0 xf9,
0 xf4,
0 xd7,
0 x73,
0 x26,
0 x4f,
0 xc3,
0 x8e,
0 x33,
0 x3c,
0 x08,
0 x5b,
0 xfa,
0 x40,
0 xc5,
0 xe6,
0 xe9,
0 x9c,
0 x57,
0 x8b,
0 x6f,
0 x30,
0 xd3,
0 x09,
0 x5f,
0 xe9,
0 x87,
0 xd6,
0 xb6,
0 xa1,
0 xd6,
0 x36,
0 xf1,
0 xda,
0 x45,
0 x8c,
0 xc0,
0 x4a,
0 x7f,
0 xb4,
0 xe5,
0 x74,
0 xab,
0 x69,
0 x82,
0 x19,
0 x5f
};
static const uint8_t kRsaPkcs1Sha512Signature[] = {
0 x91,
0 x68,
0 x2a,
0 x91,
0 xce,
0 xab,
0 x57,
0 xd2,
0 x60,
0 x2d,
0 x2f,
0 xee,
0 x2b,
0 x28,
0 xc8,
0 xa7,
0 xe8,
0 x2e,
0 x41,
0 xf8,
0 x48,
0 x92,
0 xb4,
0 x1b,
0 xbb,
0 x89,
0 x54,
0 x5d,
0 xea,
0 x9f,
0 xa1,
0 x58,
0 x23,
0 x4d,
0 x73,
0 xe6,
0 x4f,
0 x88,
0 x45,
0 x7c,
0 xa0,
0 x06,
0 x3e,
0 x8e,
0 x29,
0 xca,
0 xdd,
0 xc4,
0 x9a,
0 x8a,
0 x45,
0 xbb,
0 xad,
0 x61,
0 x4c,
0 x4c,
0 x1f,
0 xd2,
0 x67,
0 xb0,
0 x8d,
0 x1f,
0 x11,
0 x3f,
0 x74,
0 x67,
0 x66,
0 x3c,
0 x65,
0 xf5,
0 xd8,
0 xd8,
0 xcc,
0 x2e,
0 x66,
0 x1f,
0 xa9,
0 x6f,
0 x2e,
0 x60,
0 x28,
0 x74,
0 x92,
0 xb7,
0 x50,
0 x16,
0 x8c,
0 x96,
0 xb2,
0 xf4,
0 x20,
0 xfb,
0 xa9,
0 x14,
0 xd3,
0 x12,
0 xcf,
0 x35,
0 xef,
0 x7c,
0 x80,
0 xf8,
0 x70,
0 x9f,
0 x8d,
0 x7f,
0 x66,
0 x5f,
0 x94,
0 xeb,
0 xd9,
0 xbb,
0 xc3,
0 x54,
0 x3d,
0 x9d,
0 x54,
0 xef,
0 xb1,
0 x23,
0 xe0,
0 x6d,
0 x02,
0 x96,
0 xa9,
0 x2b,
0 x76,
0 xd0,
0 x88,
0 x6b,
0 x64,
0 x39,
0 x15,
0 x11,
0 xba,
0 x9a,
0 x61,
0 x72,
0 x16,
0 xba,
0 x6e,
0 x17,
0 xf7,
0 xc8,
0 xe8,
0 xb2,
0 x47,
0 x31,
0 xc5,
0 x48,
0 x1d,
0 x58,
0 x80,
0 x34,
0 x07,
0 x30,
0 x8f,
0 x05,
0 xc4,
0 x26,
0 x7e,
0 x70,
0 x78,
0 x43,
0 xc1,
0 x13,
0 xe5,
0 x09,
0 x4e,
0 x68,
0 xc1,
0 x8d,
0 x34,
0 xa1,
0 xd5,
0 x68,
0 xa2,
0 xfe,
0 x73,
0 x4a,
0 x54,
0 x05,
0 x1b,
0 xc0,
0 xb3,
0 x72,
0 xe2,
0 xab,
0 x51,
0 x71,
0 xa7,
0 xaf,
0 x5c,
0 x95,
0 xfb,
0 x65,
0 xe0,
0 xb0,
0 x60,
0 x0c,
0 xd3,
0 x23,
0 xa2,
0 x0f,
0 x0d,
0 xed,
0 xd9,
0 x87,
0 xb4,
0 x96,
0 x03,
0 xd8,
0 xfd,
0 x80,
0 xa2,
0 xa1,
0 xc1,
0 x36,
0 xb3,
0 x47,
0 x05,
0 xd1,
0 x6e,
0 xd2,
0 x81,
0 x16,
0 xe4,
0 x63,
0 x26,
0 xf9,
0 x96,
0 x55,
0 x37,
0 x18,
0 x4f,
0 x2b,
0 x7e,
0 x1c,
0 xd9,
0 xba,
0 x4f,
0 xde,
0 x4d,
0 x61,
0 xc4,
0 xd5,
0 x7c,
0 xe3,
0 xa3,
0 x21,
0 xe8,
0 xae,
0 xc2,
0 xe9,
0 x62,
0 x07
};
static const uint8_t kRsaPssSubjectPublicKeyInfo[] = {
0 x30,
0 x82,
0 x01,
0 x22,
0 x30,
0 x0d,
0 x06,
0 x09,
0 x2a,
0 x86,
0 x48,
0 x86,
0 xf7,
0 x0d,
0 x01,
0 x01,
0 x0a,
0 x05,
0 x00,
0 x03,
0 x82,
0 x01,
0 x0f,
0 x00,
0 x30,
0 x82,
0 x01,
0 x0a,
0 x02,
0 x82,
0 x01,
0 x01,
0 x00,
0 xdb,
0 x75,
0 x02,
0 x7b,
0 xeb,
0 xf7,
0 x3b,
0 x31,
0 x03,
0 x71,
0 x77,
0 x34,
0 x88,
0 x8f,
0 xb2,
0 x0d,
0 xa6,
0 xbe,
0 x7d,
0 xa7,
0 xdd,
0 xac,
0 x0e,
0 x99,
0 x50,
0 x46,
0 x69,
0 x90,
0 xe6,
0 x7c,
0 x3a,
0 xa6,
0 xf9,
0 x3e,
0 x02,
0 x15,
0 x3c,
0 xf7,
0 xb9,
0 xf4,
0 xab,
0 x3d,
0 x54,
0 x2c,
0 x0d,
0 x84,
0 x94,
0 x37,
0 x95,
0 xbc,
0 x2b,
0 x56,
0 x05,
0 x00,
0 xfa,
0 xa2,
0 x08,
0 xf9,
0 xcd,
0 xc3,
0 x2b,
0 x9a,
0 x58,
0 x80,
0 x11,
0 x49,
0 xe0,
0 x69,
0 xf9,
0 x81,
0 x08,
0 x52,
0 x75,
0 xb4,
0 xc1,
0 x94,
0 xa2,
0 x67,
0 x22,
0 x5b,
0 xfb,
0 xe4,
0 x74,
0 xaa,
0 x24,
0 xb7,
0 xa3,
0 x5e,
0 x2c,
0 x6b,
0 xda,
0 x20,
0 x09,
0 x5a,
0 x5e,
0 x4f,
0 x95,
0 xe8,
0 x24,
0 x71,
0 x64,
0 x65,
0 x29,
0 x2c,
0 x44,
0 xb5,
0 x17,
0 xec,
0 xe4,
0 x68,
0 xc3,
0 x69,
0 x6b,
0 x53,
0 x6d,
0 xa1,
0 xa0,
0 xb1,
0 x74,
0 xe2,
0 x28,
0 x03,
0 xda,
0 x20,
0 xca,
0 xa4,
0 x45,
0 x1e,
0 xf6,
0 xab,
0 xc7,
0 xe9,
0 xcb,
0 xe3,
0 x9a,
0 x16,
0 x34,
0 x8f,
0 xd7,
0 xf3,
0 x66,
0 x74,
0 xea,
0 xe7,
0 x32,
0 xf3,
0 xd2,
0 x55,
0 x6c,
0 x8f,
0 x38,
0 xb8,
0 x1b,
0 x38,
0 x08,
0 x4c,
0 x1f,
0 x41,
0 x74,
0 x35,
0 x9e,
0 x2d,
0 x29,
0 xed,
0 x72,
0 xe3,
0 xda,
0 x18,
0 x01,
0 xf4,
0 x5f,
0 x8d,
0 x9d,
0 x72,
0 x13,
0 x18,
0 x09,
0 x1f,
0 xbe,
0 xb0,
0 x20,
0 x90,
0 xc4,
0 x3d,
0 x2c,
0 x4f,
0 xf2,
0 xdc,
0 x99,
0 x8a,
0 xae,
0 x02,
0 xd6,
0 xef,
0 x5a,
0 x88,
0 x08,
0 x15,
0 x85,
0 xdd,
0 xaa,
0 xce,
0 xe4,
0 x4b,
0 x3f,
0 xe9,
0 xf4,
0 xfa,
0 x54,
0 xde,
0 xb0,
0 x30,
0 xdf,
0 x8f,
0 x14,
0 x2c,
0 x49,
0 x69,
0 x24,
0 xe4,
0 xa9,
0 xeb,
0 x62,
0 x15,
0 xf8,
0 x8a,
0 xd8,
0 xe4,
0 x8a,
0 x99,
0 x2b,
0 xdb,
0 x68,
0 x8b,
0 x2a,
0 x61,
0 xbd,
0 xc0,
0 x57,
0 xff,
0 x5f,
0 xee,
0 xe9,
0 xac,
0 x06,
0 x77,
0 x13,
0 x7b,
0 x2e,
0 xd1,
0 x76,
0 x6c,
0 xe8,
0 x6c,
0 x73,
0 x1f,
0 x02,
0 x03,
0 x01,
0 x00,
0 x01
};
// Use `openssl dgst -binary -sha1` to obtain the hash of the data, and then
// `openssl pkeyutl` with `-pkeyopt rsa_padding_mode:pss`, `-pkeyopt
// digest:sha1`, and `-pkeyopt rsa_pss_saltlen:-1` to create the signature.
static const uint8_t kRsaPssSha1Signature[] = {
0 xa9,
0 xd9,
0 x36,
0 x19,
0 x90,
0 x3d,
0 x58,
0 xa6,
0 x66,
0 xae,
0 x8e,
0 xab,
0 xb5,
0 x7d,
0 xe7,
0 x8c,
0 xcf,
0 x3c,
0 x69,
0 xd8,
0 xba,
0 x22,
0 xe1,
0 x35,
0 x9a,
0 x88,
0 xfd,
0 xf1,
0 x01,
0 x75,
0 x71,
0 x05,
0 x60,
0 xcf,
0 x05,
0 x76,
0 x18,
0 x38,
0 xa6,
0 x74,
0 xaf,
0 x36,
0 x90,
0 xb5,
0 xad,
0 x3c,
0 xde,
0 xe3,
0 x5f,
0 x86,
0 x3b,
0 x38,
0 x05,
0 xa0,
0 xae,
0 xa2,
0 x5c,
0 xa9,
0 xc8,
0 x35,
0 xa1,
0 x86,
0 x95,
0 xcb,
0 xb0,
0 xd8,
0 x91,
0 x27,
0 x7f,
0 x9b,
0 x5f,
0 xbe,
0 xd7,
0 x99,
0 x39,
0 x88,
0 x9a,
0 xe8,
0 xeb,
0 x8a,
0 x8b,
0 xf2,
0 xd3,
0 x39,
0 xca,
0 xbc,
0 x29,
0 x9c,
0 xf4,
0 x8d,
0 x2d,
0 x86,
0 xbc,
0 x13,
0 xfc,
0 xc4,
0 x9f,
0 x1f,
0 x65,
0 x7c,
0 x86,
0 x10,
0 x36,
0 x8d,
0 x43,
0 xf5,
0 x55,
0 xa4,
0 xd2,
0 x5e,
0 x0a,
0 x8f,
0 x6a,
0 x2e,
0 x9e,
0 x2f,
0 xe2,
0 xb9,
0 x32,
0 x4a,
0 x00,
0 x5a,
0 xc6,
0 x1a,
0 x75,
0 x44,
0 x59,
0 x5f,
0 xfc,
0 xe3,
0 xf6,
0 xfb,
0 xc1,
0 x95,
0 x10,
0 x18,
0 x2c,
0 xed,
0 xfd,
0 x23,
0 x0c,
0 x48,
0 x14,
0 xf9,
0 x5c,
0 x04,
0 x9b,
0 xb7,
0 x7a,
0 x23,
0 xf6,
0 x82,
0 x78,
0 x92,
0 xe9,
0 xa8,
0 xc6,
0 x1b,
0 xa9,
0 xad,
0 xcc,
0 x4a,
0 xac,
0 x56,
0 x01,
0 x02,
0 x81,
0 xa9,
0 xa4,
0 x34,
0 xb2,
0 xdd,
0 xd3,
0 xc4,
0 x01,
0 x97,
0 x84,
0 x3f,
0 x85,
0 x2c,
0 x7e,
0 x66,
0 x4a,
0 x98,
0 x1f,
0 xf5,
0 x1e,
0 x2e,
0 x62,
0 x09,
0 x4e,
0 x47,
0 xd1,
0 x39,
0 x93,
0 x13,
0 x53,
0 x48,
0 x90,
0 xb4,
0 xb8,
0 x3f,
0 x3c,
0 x6b,
0 x87,
0 x36,
0 x24,
0 x8f,
0 xf5,
0 xb8,
0 x9d,
0 xb2,
0 x58,
0 x8f,
0 x55,
0 xbd,
0 x2f,
0 xf6,
0 xce,
0 x05,
0 xd3,
0 xc5,
0 x6b,
0 x84,
0 x6c,
0 x1b,
0 x77,
0 x00,
0 x7e,
0 xfb,
0 xa4,
0 x01,
0 x0f,
0 xf5,
0 x9d,
0 x9a,
0 xc7,
0 xe3,
0 xa4,
0 xdb,
0 xac,
0 x87,
0 x3b,
0 x50,
0 x66,
0 xd2,
0 xf5,
0 xaf,
0 x51,
0 x28,
0 xb4,
0 x5e,
0 x6e,
0 xca,
0 x74,
0 xaa
};
// As above, but with sha256.
static const uint8_t kRsaPssSha256Signature[] = {
0 x34,
0 x01,
0 x2e,
0 x0b,
0 xba,
0 x00,
0 x2a,
0 x66,
0 x50,
0 x5a,
0 x6c,
0 xf8,
0 x3b,
0 x7f,
0 xda,
0 x43,
0 xd1,
0 x56,
0 x75,
0 xc8,
0 xa9,
0 x7a,
0 xa9,
0 x53,
0 xc8,
0 xb3,
0 xca,
0 x92,
0 x68,
0 x8d,
0 x68,
0 x90,
0 x93,
0 xf3,
0 xfd,
0 xb3,
0 x66,
0 x3d,
0 x81,
0 xe4,
0 x6e,
0 x7d,
0 x46,
0 x57,
0 x86,
0 x0d,
0 xd5,
0 x58,
0 x46,
0 x27,
0 x4f,
0 xae,
0 xab,
0 x55,
0 x1f,
0 x25,
0 xdd,
0 x43,
0 xac,
0 x72,
0 x50,
0 x0c,
0 x24,
0 x87,
0 xbb,
0 xf9,
0 x08,
0 x4a,
0 x47,
0 x43,
0 xff,
0 x7a,
0 x40,
0 x8a,
0 xd6,
0 x69,
0 x99,
0 xe8,
0 x65,
0 x66,
0 x4d,
0 x73,
0 x9f,
0 xc5,
0 x43,
0 x60,
0 x44,
0 xc6,
0 xf8,
0 x8a,
0 xbd,
0 xf2,
0 x8a,
0 xfc,
0 x9f,
0 x22,
0 xa6,
0 x10,
0 x4a,
0 xa4,
0 x8b,
0 x70,
0 x5b,
0 xa1,
0 x7c,
0 x8c,
0 x1a,
0 xc3,
0 xf2,
0 x84,
0 xde,
0 x03,
0 x41,
0 x7d,
0 xe1,
0 x38,
0 x09,
0 xa2,
0 x78,
0 x14,
0 xf4,
0 x2c,
0 xa6,
0 xf6,
0 x8a,
0 x1e,
0 xcc,
0 x91,
0 xbf,
0 x6c,
0 x14,
0 xe4,
0 xc1,
0 x65,
0 xc7,
0 x74,
0 x89,
0 x49,
0 x24,
0 x5c,
0 xc6,
0 x85,
0 x58,
0 x35,
0 x76,
0 x9b,
0 x9c,
0 xa1,
0 x3e,
0 xef,
0 xf7,
0 x57,
0 xc7,
0 x18,
0 x70,
0 x98,
0 x1b,
0 xa1,
0 x12,
0 xae,
0 x69,
0 x85,
0 x1d,
0 x0d,
0 xa6,
0 xec,
0 x94,
0 x7f,
0 xab,
0 x77,
0 x08,
0 xfc,
0 x89,
0 x69,
0 x9c,
0 x51,
0 xa1,
0 x01,
0 xd6,
0 xc8,
0 xc2,
0 xbf,
0 xc7,
0 x63,
0 xa3,
0 xce,
0 xca,
0 xc9,
0 x11,
0 xfd,
0 x78,
0 x62,
0 x5d,
0 x80,
0 x15,
0 x10,
0 x75,
0 xcd,
0 xd8,
0 xc9,
0 x7f,
0 xd2,
0 xcb,
0 x32,
0 x35,
0 x0d,
0 xc0,
0 x56,
0 x0e,
0 xa4,
0 xa5,
0 x2d,
0 xe3,
0 xeb,
0 x1e,
0 x30,
0 x60,
0 x35,
0 x1d,
0 xe8,
0 xb5,
0 x27,
0 xa1,
0 x46,
0 x61,
0 x74,
0 xb7,
0 xf6,
0 x2c,
0 x50,
0 x4f,
0 x23,
0 xb3,
0 xb0,
0 x6b,
0 xaf,
0 x8d,
0 x1a,
0 x74,
0 x27,
0 x58,
0 x58,
0 x25,
0 xc9,
0 x45,
0 x84,
0 xd8,
0 x5d,
0 xe8,
0 x7e,
0 xc6,
0 x3e,
0 xd4,
0 xf2,
0 xb1,
0 x3f
};
// As above, but with sha384.
static const uint8_t kRsaPssSha384Signature[] = {
0 x42,
0 xd1,
0 x90,
0 xb2,
0 x78,
0 x76,
0 x97,
0 x5f,
0 xf1,
0 x4c,
0 xab,
0 x1b,
0 xe0,
0 x80,
0 xd6,
0 x32,
0 xac,
0 x57,
0 x93,
0 x2e,
0 x03,
0 xb7,
0 xec,
0 x9f,
0 x48,
0 x72,
0 x91,
0 x12,
0 xb7,
0 x2b,
0 xaf,
0 x69,
0 xc6,
0 x2d,
0 xde,
0 x6a,
0 xdc,
0 xcb,
0 xaf,
0 xf8,
0 x84,
0 x2b,
0 x13,
0 xf9,
0 xb9,
0 x60,
0 x76,
0 x36,
0 x13,
0 x63,
0 xcb,
0 xdd,
0 x22,
0 xed,
0 xa2,
0 x07,
0 xac,
0 x44,
0 xee,
0 x40,
0 x01,
0 x19,
0 x0e,
0 xdd,
0 x1d,
0 xeb,
0 x0a,
0 xe7,
0 xd2,
0 x71,
0 x1d,
0 xea,
0 x66,
0 x9f,
0 x61,
0 x76,
0 xee,
0 xbf,
0 x50,
0 xa1,
0 x47,
0 x17,
0 x32,
0 x58,
0 x03,
0 x32,
0 xd5,
0 x39,
0 x37,
0 xee,
0 x30,
0 x9c,
0 x87,
0 xed,
0 xc3,
0 x07,
0 xde,
0 x36,
0 xc6,
0 x65,
0 x55,
0 xd4,
0 xd3,
0 xbc,
0 x4a,
0 x83,
0 x70,
0 xd3,
0 x8d,
0 xd2,
0 xe0,
0 x65,
0 x8c,
0 xe1,
0 xd8,
0 x40,
0 xe2,
0 x83,
0 x52,
0 x4f,
0 xf2,
0 xe5,
0 x16,
0 x9a,
0 x9b,
0 x9b,
0 xf2,
0 x51,
0 x97,
0 xb0,
0 x64,
0 xf9,
0 x78,
0 x07,
0 xcc,
0 x48,
0 xe4,
0 xe5,
0 xeb,
0 x69,
0 x31,
0 xe7,
0 x10,
0 xb9,
0 xa9,
0 xdd,
0 x06,
0 xb0,
0 x9e,
0 x06,
0 xed,
0 xe1,
0 x21,
0 x3d,
0 xcb,
0 xfb,
0 x0b,
0 x84,
0 x78,
0 xbb,
0 x1c,
0 x3c,
0 x5e,
0 x56,
0 x29,
0 xd8,
0 x85,
0 xe1,
0 x6b,
0 x14,
0 xee,
0 xad,
0 xf8,
0 x8c,
0 xb7,
0 xfb,
0 xdb,
0 x48,
0 x89,
0 xa2,
0 x2f,
0 x98,
0 x4c,
0 xcc,
0 x62,
0 xbe,
0 x1d,
0 x5e,
0 xe2,
0 x59,
0 x11,
0 x4b,
0 xfd,
0 x93,
0 xd0,
0 xe2,
0 x93,
0 x9a,
0 x8e,
0 xc6,
0 x97,
0 x99,
0 x6b,
0 x9f,
0 x81,
0 x96,
0 x76,
0 x78,
0 x6f,
0 xe9,
0 xf3,
0 x3d,
0 xe2,
0 xe2,
0 xd6,
0 x8a,
0 x3e,
0 xb3,
0 xff,
0 x33,
0 xfb,
0 x1d,
0 x54,
0 xa9,
0 xcd,
0 xe8,
0 x58,
0 x34,
0 xd7,
0 x9e,
0 x5f,
0 x0a,
0 xcd,
0 x38,
0 xbd,
0 x67,
0 x2c,
0 x4e,
0 xbd,
0 x11,
0 xed,
0 x4a,
0 xfd,
0 x15,
0 x35,
0 x14,
0 x0d,
0 xfa,
0 xd9,
0 xa4,
0 xf7,
0 x6c,
0 x5f,
0 x19,
0 xbd,
0 x1c
};
// As above, but with sha512.
static const uint8_t kRsaPssSha512Signature[] = {
0 xbf,
0 xbc,
0 xa6,
0 x9d,
0 x9b,
0 x25,
0 xd0,
0 x0f,
0 x13,
0 x2c,
0 xa4,
0 x36,
0 x5d,
0 xab,
0 x06,
0 xba,
0 x7e,
0 x0e,
0 xc8,
0 x30,
0 x6e,
0 x8b,
0 x36,
0 x19,
0 x28,
0 xdd,
0 x41,
0 xc7,
0 xba,
0 x94,
0 x0c,
0 x0a,
0 x46,
0 x83,
0 xdd,
0 xdf,
0 xf0,
0 x99,
0 xd6,
0 x07,
0 xa9,
0 xc4,
0 x93,
0 xd9,
0 x1e,
0 x98,
0 xac,
0 xa0,
0 xb2,
0 x35,
0 x95,
0 x98,
0 x89,
0 x4f,
0 x6b,
0 x81,
0 x0e,
0 x4d,
0 xc1,
0 x94,
0 xb8,
0 xc2,
0 x4c,
0 x33,
0 xd2,
0 x2b,
0 xd6,
0 xbd,
0 xb8,
0 x2f,
0 x04,
0 x24,
0 x64,
0 x94,
0 xfe,
0 x02,
0 x36,
0 x83,
0 xce,
0 xe1,
0 x47,
0 xf3,
0 xb3,
0 x4a,
0 xc0,
0 x7e,
0 xe4,
0 x6b,
0 x3b,
0 x0d,
0 xcd,
0 x83,
0 x6e,
0 x93,
0 xd2,
0 x5e,
0 x40,
0 xdb,
0 xe1,
0 xe2,
0 x08,
0 xd1,
0 xc3,
0 x7a,
0 xfb,
0 xdf,
0 xe5,
0 x91,
0 x01,
0 xb2,
0 xd9,
0 xcd,
0 x15,
0 xeb,
0 x15,
0 xcc,
0 xf4,
0 xa6,
0 xdd,
0 x87,
0 x31,
0 x9b,
0 xcb,
0 x19,
0 x38,
0 x00,
0 x99,
0 xfe,
0 xcb,
0 xfb,
0 x41,
0 xda,
0 xce,
0 x45,
0 xf2,
0 x65,
0 x5b,
0 x3b,
0 x9d,
0 x34,
0 x7e,
0 x48,
0 x40,
0 x63,
0 x67,
0 xfa,
0 xbe,
0 x34,
0 xaf,
0 xf5,
0 x69,
0 xa3,
0 x40,
0 x8d,
0 x1b,
0 xae,
0 x84,
0 x0f,
0 x3b,
0 x1f,
0 xc4,
0 x00,
0 x8b,
0 x8a,
0 x64,
0 x9f,
0 xca,
0 xfc,
0 x0c,
0 x58,
0 x6e,
0 xfd,
0 x8a,
0 xb5,
0 x11,
0 x3d,
0 x2b,
0 x7d,
0 xf1,
0 xdd,
0 x08,
0 xe9,
0 x1d,
0 x27,
0 x18,
0 x1e,
0 x31,
0 xc1,
0 xec,
0 x10,
0 xe6,
0 x5b,
0 x39,
0 xcc,
0 x9f,
0 x2e,
0 x9c,
0 x41,
0 x4c,
0 x47,
0 x77,
0 x36,
0 x5f,
0 x2c,
0 x5b,
0 x8c,
0 x16,
0 x96,
0 x7f,
0 x1f,
0 xa8,
0 x30,
0 x3b,
0 x34,
0 x2f,
0 xa2,
0 x44,
0 x41,
0 x49,
0 x68,
0 x3a,
0 x75,
0 xa5,
0 xb4,
0 xde,
0 xd2,
0 x89,
0 x72,
0 x7c,
0 x6e,
0 x83,
0 x54,
0 x30,
0 x9c,
0 x1e,
0 x9b,
0 x58,
0 xb0,
0 xa3,
0 x2c,
0 xdf,
0 x3d,
0 x69,
0 xff,
0 xe1,
0 x4c,
0 x28,
0 x4a,
0 x19,
0 xec,
0 x0b,
0 x4c,
0 x0a,
0 x7e,
0 xb7,
0 xd4
};
static const uint8_t kEC256SubjectPublicKeyInfo[] = {
0 x30,
0 x59,
0 x30,
0 x13,
0 x06,
0 x07,
0 x2a,
0 x86,
0 x48,
0 xce,
0 x3d,
0 x02,
0 x01,
0 x06,
0 x08,
0 x2a,
0 x86,
0 x48,
0 xce,
0 x3d,
0 x03,
0 x01,
0 x07,
0 x03,
0 x42,
0 x00,
0 x04,
0 x6d,
0 xd3,
0 xc0,
0 x54,
0 xc6,
0 x33,
0 xd3,
0 xff,
0 x4a,
0 x43,
0 x0c,
0 x3a,
0 x70,
0 xdb,
0 x97,
0 xf6,
0 xc9,
0 x68,
0 xa0,
0 xb1,
0 xb9,
0 x6e,
0 x15,
0 x20,
0 x80,
0 x50,
0 x6f,
0 x37,
0 x8f,
0 xcc,
0 xe3,
0 x47,
0 x96,
0 x2c,
0 x5d,
0 xb8,
0 x76,
0 x8e,
0 x67,
0 x19,
0 x1c,
0 xc7,
0 x64,
0 xb4,
0 xd5,
0 xda,
0 xa6,
0 x4d,
0 xc5,
0 x3d,
0 xe6,
0 xa7,
0 xb3,
0 xb0,
0 x41,
0 xfb,
0 x29,
0 xb4,
0 x2f,
0 xe8,
0 x72,
0 xeb,
0 xfb,
0 xfe
};
// Similar to above, but without the RSA padding mode option.
static const uint8_t kEC256Sha1Signature[] = {
0 x30,
0 x46,
0 x02,
0 x21,
0 x00,
0 xa7,
0 x66,
0 xd0,
0 x2c,
0 x3e,
0 x2c,
0 x06,
0 x28,
0 x84,
0 x3f,
0 x59,
0 xe7,
0 x21,
0 x44,
0 x7d,
0 x5a,
0 xca,
0 xd6,
0 xd5,
0 xe8,
0 x7d,
0 x0a,
0 xc5,
0 x26,
0 x99,
0 x93,
0 x43,
0 xf1,
0 x7d,
0 x07,
0 x08,
0 xdb,
0 x02,
0 x21,
0 x00,
0 xfc,
0 x02,
0 xea,
0 xcb,
0 x3b,
0 x7e,
0 xd3,
0 x2e,
0 x86,
0 x09,
0 x18,
0 x1a,
0 x46,
0 x4b,
0 x98,
0 xfa,
0 x7c,
0 x4c,
0 x2f,
0 xf8,
0 x6e,
0 xf7,
0 x42,
0 x1e,
0 x5d,
0 x73,
0 x0b,
0 x27,
0 xbf,
0 xd7,
0 x43,
0 xeb
};
static const uint8_t kEC256Signature[] = {
0 x30,
0 x45,
0 x02,
0 x21,
0 x00,
0 xfa,
0 x47,
0 x24,
0 x2e,
0 xc0,
0 x01,
0 x6c,
0 x31,
0 xca,
0 x75,
0 x12,
0 xa4,
0 x02,
0 x78,
0 x0d,
0 xc6,
0 x75,
0 x30,
0 x1f,
0 x31,
0 xec,
0 xc1,
0 xa1,
0 x1c,
0 xc9,
0 x3e,
0 xcd,
0 xa5,
0 x69,
0 xe2,
0 x06,
0 x61,
0 x02,
0 x20,
0 x7f,
0 x94,
0 x6e,
0 x60,
0 x2e,
0 xdd,
0 x06,
0 xa6,
0 xd6,
0 x90,
0 x74,
0 x36,
0 x4f,
0 xf4,
0 xc5,
0 x80,
0 x8f,
0 xf6,
0 xf9,
0 x3b,
0 x6c,
0 xee,
0 x28,
0 x94,
0 x93,
0 xce,
0 xff,
0 x1e,
0 xfc,
0 x84,
0 x10,
0 x65
};
static const uint8_t kEC384SubjectPublicKeyInfo[] = {
0 x30,
0 x76,
0 x30,
0 x10,
0 x06,
0 x07,
0 x2a,
0 x86,
0 x48,
0 xce,
0 x3d,
0 x02,
0 x01,
0 x06,
0 x05,
0 x2b,
0 x81,
0 x04,
0 x00,
0 x22,
0 x03,
0 x62,
0 x00,
0 x04,
0 x6c,
0 x7a,
0 x7b,
0 x3f,
0 x85,
0 x0d,
0 x04,
0 x8d,
0 x8c,
0 x90,
0 x0a,
0 x9e,
0 x42,
0 x54,
0 xfa,
0 x64,
0 x78,
0 xd3,
0 x08,
0 x91,
0 xe0,
0 xaa,
0 xc1,
0 x03,
0 x0c,
0 x6c,
0 xf1,
0 x8c,
0 xa6,
0 x32,
0 x9d,
0 x57,
0 x10,
0 x38,
0 xf2,
0 xee,
0 x27,
0 x1c,
0 xa8,
0 x11,
0 xd0,
0 x1c,
0 x50,
0 x24,
0 xd9,
0 x15,
0 x17,
0 x3c,
0 xe8,
0 x29,
0 x67,
0 x4b,
0 x06,
0 xe3,
0 x89,
0 x52,
0 x62,
0 x0f,
0 xd6,
0 x12,
0 x95,
0 x52,
0 x21,
0 x3e,
0 x5d,
0 x7b,
0 x5b,
0 x04,
0 xdc,
0 xa1,
0 x49,
0 x51,
0 xf0,
0 xed,
0 x35,
0 x6b,
0 x1c,
0 xdd,
0 x09,
0 x8f,
0 xdf,
0 x1e,
0 x0a,
0 x39,
0 xd4,
0 x92,
0 x38,
0 x1b,
0 x0a,
0 xce,
0 xea,
0 xf9,
0 x6a,
0 x0e,
0 x37,
0 x4d
};
static const uint8_t kEC384Signature[] = {
0 x30,
0 x65,
0 x02,
0 x31,
0 x00,
0 x8c,
0 xdf,
0 x30,
0 xa4,
0 x06,
0 x2b,
0 x15,
0 x2f,
0 x2e,
0 x46,
0 xbb,
0 x3e,
0 xd1,
0 xa7,
0 x87,
0 x29,
0 x2a,
0 x30,
0 x74,
0 x29,
0 x31,
0 x38,
0 x2a,
0 x05,
0 x74,
0 x1c,
0 xbd,
0 xe6,
0 xf4,
0 x4b,
0 x8d,
0 x8e,
0 xa9,
0 x42,
0 xad,
0 xea,
0 x62,
0 x0d,
0 x36,
0 xa2,
0 xde,
0 x6e,
0 x99,
0 x7f,
0 xa5,
0 x51,
0 x42,
0 x1e,
0 x02,
0 x30,
0 x35,
0 xad,
0 x08,
0 x88,
0 x52,
0 x40,
0 x2e,
0 x91,
0 x44,
0 xf2,
0 x07,
0 x0a,
0 x92,
0 x39,
0 x35,
0 x1d,
0 x15,
0 xeb,
0 x90,
0 xc4,
0 xd9,
0 xfb,
0 x83,
0 xae,
0 x99,
0 xaa,
0 x50,
0 x4e,
0 xc9,
0 x35,
0 x1d,
0 x3a,
0 x8d,
0 x40,
0 x9a,
0 x91,
0 x14,
0 x6c,
0 x0d,
0 x02,
0 x25,
0 x7e,
0 x48,
0 x8b,
0 x98,
0 x9d,
0 x3f,
0 x14
};
static const uint8_t kEC521SubjectPublicKeyInfo[] = {
0 x30,
0 x81,
0 x9b,
0 x30,
0 x10,
0 x06,
0 x07,
0 x2a,
0 x86,
0 x48,
0 xce,
0 x3d,
0 x02,
0 x01,
0 x06,
0 x05,
0 x2b,
0 x81,
0 x04,
0 x00,
0 x23,
0 x03,
0 x81,
0 x86,
0 x00,
0 x04,
0 x01,
0 x59,
0 x3c,
0 x05,
0 xb1,
0 x74,
0 x49,
0 x54,
0 x72,
0 xea,
0 xf5,
0 xb0,
0 x43,
0 x98,
0 x39,
0 xfe,
0 xc6,
0 x4e,
0 x8a,
0 x58,
0 x62,
0 x83,
0 xe7,
0 x61,
0 xeb,
0 xf6,
0 x50,
0 x32,
0 xa6,
0 x1e,
0 x7c,
0 x6a,
0 x7c,
0 xa5,
0 x4e,
0 x5b,
0 x96,
0 x77,
0 xfd,
0 xf5,
0 x5c,
0 xe8,
0 x61,
0 x32,
0 xc2,
0 xd2,
0 xcf,
0 x06,
0 xef,
0 x46,
0 xf1,
0 x51,
0 x50,
0 x35,
0 xf7,
0 xac,
0 x97,
0 x7a,
0 xfb,
0 xe8,
0 x9f,
0 xa5,
0 xc6,
0 x32,
0 x8a,
0 xdf,
0 x00,
0 x9d,
0 x6f,
0 xd7,
0 x34,
0 xa7,
0 xe5,
0 x1d,
0 x85,
0 x4b,
0 xc2,
0 x26,
0 x38,
0 x8c,
0 x6f,
0 x8f,
0 x75,
0 xd8,
0 x47,
0 x08,
0 xe7,
0 xcb,
0 x78,
0 x9f,
0 x3d,
0 xe8,
0 x5a,
0 xe5,
0 xa1,
0 x74,
0 x56,
0 x80,
0 x62,
0 x7e,
0 x95,
0 x2a,
0 x2d,
0 x6e,
0 x27,
0 x71,
0 x02,
0 xf1,
0 xbf,
0 x5d,
0 xe4,
0 x7e,
0 xab,
0 x94,
0 x92,
0 x24,
0 x0f,
0 x31,
0 x51,
0 x33,
0 x67,
0 x6a,
0 xfb,
0 x29,
0 xae,
0 xa9,
0 xaf,
0 xdd,
0 x09,
0 x77,
0 x08,
0 xf8
};
static const uint8_t kEC521Signature[] = {
0 x30,
0 x81,
0 x87,
0 x02,
0 x41,
0 x56,
0 xa2,
0 x7e,
0 xff,
0 x54,
0 xe2,
0 xb4,
0 x23,
0 x08,
0 xf8,
0 xde,
0 x28,
0 x63,
0 x77,
0 x3b,
0 x0f,
0 x18,
0 x7b,
0 x5d,
0 xac,
0 x2f,
0 x57,
0 x04,
0 xbe,
0 x15,
0 x7b,
0 x04,
0 xb1,
0 xd2,
0 x7f,
0 x21,
0 x14,
0 x40,
0 x18,
0 xb2,
0 x27,
0 xe4,
0 xef,
0 x14,
0 x54,
0 x9c,
0 xca,
0 x90,
0 xd8,
0 x95,
0 x3a,
0 xfe,
0 xf8,
0 xe4,
0 x60,
0 x98,
0 x45,
0 x31,
0 x5e,
0 x3b,
0 xac,
0 x89,
0 x48,
0 x0b,
0 xad,
0 xe2,
0 xeb,
0 xa5,
0 xec,
0 xae,
0 x02,
0 x42,
0 x01,
0 xc9,
0 x16,
0 x18,
0 x30,
0 x1b,
0 xdb,
0 xbb,
0 x99,
0 x47,
0 x32,
0 xa0,
0 x17,
0 x02,
0 xef,
0 x30,
0 x72,
0 x77,
0 x27,
0 x06,
0 x0c,
0 x6d,
0 x4a,
0 x01,
0 xba,
0 xb0,
0 x30,
0 xec,
0 x8b,
0 x35,
0 x44,
0 x9a,
0 xe5,
0 xd2,
0 x15,
0 x74,
0 x69,
0 x67,
0 x2a,
0 xe8,
0 x5a,
0 xd3,
0 xa4,
0 x91,
0 x39,
0 x49,
0 x60,
0 x4f,
0 x90,
0 x78,
0 xeb,
0 xb4,
0 xc0,
0 x77,
0 x53,
0 xf7,
0 xf5,
0 x44,
0 xfc,
0 x29,
0 x86,
0 xaf,
0 x95,
0 x6f,
0 x56,
0 xcd
};
static const VerifySignedDataNSSTestParams
VERIFYSIGNEDDIGESTNSS_TEST_PARAMS[] =
{
{
BS(kData),
DigestAlgorithm::sha1,
BS(kRsaPkcs1Sha1Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPkcs1Sha256Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha384,
BS(kRsaPkcs1Sha384Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha512,
BS(kRsaPkcs1Sha512Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Success,
},
// SHA-1 is not allowed for RSA-PSS
{
BS(kData),
DigestAlgorithm::sha1,
BS(kRsaPssSha1Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Result::ERROR_CERT_SIGNATURE_ALGORITHM_DISABLED,
},
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPssSha256Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha384,
BS(kRsaPssSha384Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha512,
BS(kRsaPssSha512Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha1,
BS(kEC256Sha1Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC256SubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha256,
BS(kEC256Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC256SubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha384,
BS(kEC384Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC384SubjectPublicKeyInfo),
Success,
},
{
BS(kData),
DigestAlgorithm::sha512,
BS(kEC521Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC521SubjectPublicKeyInfo),
Success,
},
// Wrong digest algorithm - RSA PKCS#1
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPkcs1Sha384Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// Wrong digest algorithm - RSA PSS
{
BS(kData),
DigestAlgorithm::sha512,
BS(kRsaPssSha384Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// Wrong digest algorithm - ECDSA
{
BS(kData),
DigestAlgorithm::sha1,
BS(kEC256Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC256SubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// ECDSA key for RSA PKCS#1 signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPkcs1Sha256Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC256SubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// RSA PKCS#1 key for ECDSA signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kEC256Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// RSA PKCS#1 key for RSA PSS signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPssSha256Signature),
PublicKeyAlgorithm::RSA_PKCS1,
BS(kRsaSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// RSA PSS key for RSA PKCS#1 signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPkcs1Sha256Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// ECDSA key for RSA PSS signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kRsaPssSha256Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC256SubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// RSA PSS key for ECDSA signature
{
BS(kData),
DigestAlgorithm::sha256,
BS(kEC256Signature),
PublicKeyAlgorithm::RSA_PSS,
BS(kRsaPssSubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
// Wrong data.
{
BS(kRsaSubjectPublicKeyInfo),
DigestAlgorithm::sha384,
BS(kEC384Signature),
PublicKeyAlgorithm::ECDSA,
BS(kEC384SubjectPublicKeyInfo),
Result::ERROR_BAD_SIGNATURE,
},
};
class pkixnss_VerifySignedDataNSS
:
public ::testing::Test
,
public ::testing::WithParamInterface<VerifySignedDataNSSTestParams>
{
};
void CheckVerifySignedData(PublicKeyAlgorithm publicKeyAlgorithm, Input data,
DigestAlgorithm digestAlgorithm, Input signature, Input subjectPublicKeyInfo,
Result expectedResult)
{
switch (publicKeyAlgorithm) {
case PublicKeyAlgorithm::RSA_PKCS1:
ASSERT_EQ(expectedResult,
VerifyRSAPKCS1SignedDataNSS(data, digestAlgorithm, signature,
subjectPublicKeyInfo, nullptr));
break ;
case PublicKeyAlgorithm::RSA_PSS:
ASSERT_EQ(expectedResult,
VerifyRSAPSSSignedDataNSS(data, digestAlgorithm, signature,
subjectPublicKeyInfo, nullptr));
break ;
case PublicKeyAlgorithm::ECDSA:
ASSERT_EQ(expectedResult,
VerifyECDSASignedDataNSS(data, digestAlgorithm, signature,
subjectPublicKeyInfo, nullptr));
break ;
default :
ASSERT_FALSE(
true );
}
}
TEST_P(pkixnss_VerifySignedDataNSS, VerifySignedDataNSS)
{
const VerifySignedDataNSSTestParams& params(GetParam());
ByteString data(params.data);
Input dataInput;
ASSERT_EQ(Success, dataInput.Init(data.data(), data.length()));
ByteString signature(params.signature);
Input signatureInput;
ASSERT_EQ(Success, signatureInput.Init(signature.data(), signature.length()));
Input subjectPublicKeyInfo;
ASSERT_EQ(Success,
subjectPublicKeyInfo.Init(params.subjectPublicKeyInfo.data(),
params.subjectPublicKeyInfo.length()));
CheckVerifySignedData(params.publicKeyAlgorithm, dataInput,
params.digestAlgorithm, signatureInput, subjectPublicKeyInfo,
params.expectedResult);
if (params.expectedResult == Success) {
signature[signature.length() -
4 ] = ~signature[signature.length() -
4 ];
CheckVerifySignedData(params.publicKeyAlgorithm, dataInput,
params.digestAlgorithm, signatureInput, subjectPublicKeyInfo,
Result::ERROR_BAD_SIGNATURE);
signature[signature.length() -
4 ] = ~signature[signature.length() -
4 ];
data[data.length() -
10 ] = ~data[data.length() -
10 ];
CheckVerifySignedData(params.publicKeyAlgorithm, dataInput,
params.digestAlgorithm, signatureInput, subjectPublicKeyInfo,
Result::ERROR_BAD_SIGNATURE);
}
}
INSTANTIATE_TEST_SUITE_P(
pkixnss_VerifySignedDataNSS, pkixnss_VerifySignedDataNSS,
testing::ValuesIn(VERIFYSIGNEDDIGESTNSS_TEST_PARAMS));
Messung V0.5 in Prozent C=93 H=91 G=91
¤ Dauer der Verarbeitung: 0.15 Sekunden
(vorverarbeitet am 2026-06-05)
¤
*© Formatika GbR, Deutschland