Path: blob/main/crypto/krb5/src/plugins/preauth/pkinit/pkinit_constants.c
34923 views
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */1/* plugins/preauth/pkinit/pkinit_constants.c */2/*3* Copyright (C) 2011,2021 by the Massachusetts Institute of Technology.4* All rights reserved.5*6* Redistribution and use in source and binary forms, with or without7* modification, are permitted provided that the following conditions8* are met:9*10* * Redistributions of source code must retain the above copyright11* notice, this list of conditions and the following disclaimer.12*13* * Redistributions in binary form must reproduce the above copyright14* notice, this list of conditions and the following disclaimer in15* the documentation and/or other materials provided with the16* distribution.17*18* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS19* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT20* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS21* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE22* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,23* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES24* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR25* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)26* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,27* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)28* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED29* OF THE POSSIBILITY OF SUCH DAMAGE.30*/3132#include "pkinit.h"3334/* RFC 8636 id-pkinit-kdf-ah-sha1: iso(1) identified-organization(3) dod(6)35* internet(1) security(5) kerberosv5(2) pkinit(3) kdf(6) sha1(1) */36static char kdf_sha1[8] = { 0x2B, 0x06, 0x01, 0x05, 0x02, 0x03, 0x06, 0x01 };37/* RFC 8636 id-pkinit-kdf-ah-sha256: iso(1) identified-organization(3) dod(6)38* internet(1) security(5) kerberosv5(2) pkinit(3) kdf(6) sha256(2) */39static char kdf_sha256[8] = { 0x2B, 0x06, 0x01, 0x05, 0x02, 0x03, 0x06, 0x02 };40/* RFC 8636 id-pkinit-kdf-ah-sha512: iso(1) identified-organization(3) dod(6)41* internet(1) security(5) kerberosv5(2) pkinit(3) kdf(6) sha512(3) */42static char kdf_sha512[8] = { 0x2B, 0x06, 0x01, 0x05, 0x02, 0x03, 0x06, 0x03 };4344const krb5_data kdf_sha1_id = { KV5M_DATA, sizeof(kdf_sha1), kdf_sha1 };45const krb5_data kdf_sha256_id = { KV5M_DATA, sizeof(kdf_sha256), kdf_sha256 };46const krb5_data kdf_sha512_id = { KV5M_DATA, sizeof(kdf_sha512), kdf_sha512 };4748krb5_data const * const supported_kdf_alg_ids[] = {49&kdf_sha256_id,50&kdf_sha1_id,51&kdf_sha512_id,52NULL53};5455/* RFC 3370 sha-1: iso(1) identified-organization(3) oiw(14) secsig(3)56* algorithm(2) 26 */57static char cms_sha1[] = { 0x2b, 0x0e, 0x03, 0x02, 0x1a };58/* RFC 5754 id-sha256: joint-iso-itu-t(2) country(16) us(840) organization(1)59* gov(101) csor(3) nistalgorithm(4) hashalgs(2) 1 */60static char cms_sha256[] = {610x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x0162};63/* RFC 5754 id-sha384: joint-iso-itu-t(2) country(16) us(840) organization(1)64* gov(101) csor(3) nistalgorithm(4) hashalgs(2) 2 */65static char cms_sha384[] = {660x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x0267};68/* RFC 5754 id-sha512: joint-iso-itu-t(2) country(16) us(840) organization(1)69* gov(101) csor(3) nistalgorithm(4) hashalgs(2) 3 */70static char cms_sha512[] = {710x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x0372};7374const krb5_data cms_sha1_id = { KV5M_DATA, sizeof(cms_sha1), cms_sha1 };75const krb5_data cms_sha256_id = { KV5M_DATA, sizeof(cms_sha256), cms_sha256 };76const krb5_data cms_sha384_id = { KV5M_DATA, sizeof(cms_sha384), cms_sha384 };77const krb5_data cms_sha512_id = { KV5M_DATA, sizeof(cms_sha512), cms_sha512 };7879/* RFC 4055 sha256WithRSAEncryption: iso(1) member-body(2) us(840)80* rsadsi(113549) pkcs(1) 1 11 */81static char sha256WithRSAEncr_oid[9] = {820x2a, 0x86, 0x48, 0x86, 0xf7, 0x0d, 0x01, 0x01, 0x0b83};84/* RFC 4055 sha256WithRSAEncryption: iso(1) member-body(2) us(840)85* rsadsi(113549) pkcs(1) 1 13 */86static char sha512WithRSAEncr_oid[9] = {870x2a, 0x86, 0x48, 0x86, 0xf7, 0x0d, 0x01, 0x01, 0x0d88};8990/* RFC 3279 ecdsa-with-SHA1: iso(1) member-body(2) us(840) ansi-X9-62(10045)91* signatures(4) 1 */92static char ecdsaWithSha1_oid[] = {930x2a, 0x86, 0x48, 0xce, 0x3d, 0x04, 0x0194};9596/* RFC 5758 ecdsa-with-SHA256: iso(1) member-body(2) us(840) ansi-X9-62(10045)97* signatures(4) ecdsa-with-SHA2(3) 2 */98static char ecdsaWithSha256_oid[] = {990x2a, 0x86, 0x48, 0xce, 0x3d, 0x04, 0x03, 0x02100};101102/* RFC 5758 ecdsa-with-SHA384: iso(1) member-body(2) us(840) ansi-X9-62(10045)103* signatures(4) ecdsa-with-SHA2(3) 3 */104static char ecdsaWithSha384_oid[] = {1050x2a, 0x86, 0x48, 0xce, 0x3d, 0x04, 0x03, 0x03106};107108/* RFC 5758 ecdsa-with-SHA512: iso(1) member-body(2) us(840) ansi-X9-62(10045)109* signatures(4) ecdsa-with-SHA2(3) 4 */110static char ecdsaWithSha512_oid[] = {1110x2a, 0x86, 0x48, 0xce, 0x3d, 0x04, 0x03, 0x04112};113114const krb5_data sha256WithRSAEncr_id = {115KV5M_DATA, sizeof(sha256WithRSAEncr_oid), sha256WithRSAEncr_oid116};117const krb5_data sha512WithRSAEncr_id = {118KV5M_DATA, sizeof(sha512WithRSAEncr_oid), sha512WithRSAEncr_oid119};120const krb5_data ecdsaWithSha1_id = {121KV5M_DATA, sizeof(ecdsaWithSha1_oid), ecdsaWithSha1_oid122};123const krb5_data ecdsaWithSha256_id = {124KV5M_DATA, sizeof(ecdsaWithSha256_oid), ecdsaWithSha256_oid125};126const krb5_data ecdsaWithSha384_id = {127KV5M_DATA, sizeof(ecdsaWithSha384_oid), ecdsaWithSha384_oid128};129const krb5_data ecdsaWithSha512_id = {130KV5M_DATA, sizeof(ecdsaWithSha512_oid), ecdsaWithSha512_oid131};132133krb5_data const * const supported_cms_algs[] = {134&ecdsaWithSha512_id,135&ecdsaWithSha256_id,136&sha512WithRSAEncr_id,137&sha256WithRSAEncr_id,138NULL139};140141/* RFC 2412 section E.2 (well-known group 2) parameters, DER-encoded as142* DomainParameters (RFC 3279 section 2.3.3). */143static const uint8_t o1024[] = {1440x30, 0x82, 0x01, 0x0A, 0x02, 0x81, 0x81, 0x00,1450xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,1460xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2, 0x34,1470xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C, 0xD1,1480x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC, 0x74,1490x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B, 0x22,1500x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04, 0xDD,1510xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43, 0x1B,1520x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14, 0x37,1530x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2, 0x45,1540xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E, 0xC6,1550xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED, 0x6B,1560x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7, 0xED,1570xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F, 0xA5,1580xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F, 0xE6,1590x49, 0x28, 0x66, 0x51, 0xEC, 0xE6, 0x53, 0x81,1600xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,1610x02, 0x01, 0x02, 0x02, 0x81, 0x80, 0x7F, 0xFF,1620xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xE4, 0x87,1630xED, 0x51, 0x10, 0xB4, 0x61, 0x1A, 0x62, 0x63,1640x31, 0x45, 0xC0, 0x6E, 0x0E, 0x68, 0x94, 0x81,1650x27, 0x04, 0x45, 0x33, 0xE6, 0x3A, 0x01, 0x05,1660xDF, 0x53, 0x1D, 0x89, 0xCD, 0x91, 0x28, 0xA5,1670x04, 0x3C, 0xC7, 0x1A, 0x02, 0x6E, 0xF7, 0xCA,1680x8C, 0xD9, 0xE6, 0x9D, 0x21, 0x8D, 0x98, 0x15,1690x85, 0x36, 0xF9, 0x2F, 0x8A, 0x1B, 0xA7, 0xF0,1700x9A, 0xB6, 0xB6, 0xA8, 0xE1, 0x22, 0xF2, 0x42,1710xDA, 0xBB, 0x31, 0x2F, 0x3F, 0x63, 0x7A, 0x26,1720x21, 0x74, 0xD3, 0x1B, 0xF6, 0xB5, 0x85, 0xFF,1730xAE, 0x5B, 0x7A, 0x03, 0x5B, 0xF6, 0xF7, 0x1C,1740x35, 0xFD, 0xAD, 0x44, 0xCF, 0xD2, 0xD7, 0x4F,1750x92, 0x08, 0xBE, 0x25, 0x8F, 0xF3, 0x24, 0x94,1760x33, 0x28, 0xF6, 0x73, 0x29, 0xC0, 0xFF, 0xFF,1770xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF178};179180/* RFC 3526 section 3 (2048-bit MODP Group), RFC 3279 encoding */181static const uint8_t o2048[] = {1820x30, 0x82, 0x02, 0x0C, 0x02, 0x82, 0x01, 0x01,1830x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,1840xFF, 0xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2,1850x34, 0xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C,1860xD1, 0x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC,1870x74, 0x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B,1880x22, 0x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04,1890xDD, 0xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43,1900x1B, 0x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14,1910x37, 0x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2,1920x45, 0xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E,1930xC6, 0xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED,1940x6B, 0x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7,1950xED, 0xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F,1960xA5, 0xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F,1970xE6, 0x49, 0x28, 0x66, 0x51, 0xEC, 0xE4, 0x5B,1980x3D, 0xC2, 0x00, 0x7C, 0xB8, 0xA1, 0x63, 0xBF,1990x05, 0x98, 0xDA, 0x48, 0x36, 0x1C, 0x55, 0xD3,2000x9A, 0x69, 0x16, 0x3F, 0xA8, 0xFD, 0x24, 0xCF,2010x5F, 0x83, 0x65, 0x5D, 0x23, 0xDC, 0xA3, 0xAD,2020x96, 0x1C, 0x62, 0xF3, 0x56, 0x20, 0x85, 0x52,2030xBB, 0x9E, 0xD5, 0x29, 0x07, 0x70, 0x96, 0x96,2040x6D, 0x67, 0x0C, 0x35, 0x4E, 0x4A, 0xBC, 0x98,2050x04, 0xF1, 0x74, 0x6C, 0x08, 0xCA, 0x18, 0x21,2060x7C, 0x32, 0x90, 0x5E, 0x46, 0x2E, 0x36, 0xCE,2070x3B, 0xE3, 0x9E, 0x77, 0x2C, 0x18, 0x0E, 0x86,2080x03, 0x9B, 0x27, 0x83, 0xA2, 0xEC, 0x07, 0xA2,2090x8F, 0xB5, 0xC5, 0x5D, 0xF0, 0x6F, 0x4C, 0x52,2100xC9, 0xDE, 0x2B, 0xCB, 0xF6, 0x95, 0x58, 0x17,2110x18, 0x39, 0x95, 0x49, 0x7C, 0xEA, 0x95, 0x6A,2120xE5, 0x15, 0xD2, 0x26, 0x18, 0x98, 0xFA, 0x05,2130x10, 0x15, 0x72, 0x8E, 0x5A, 0x8A, 0xAC, 0xAA,2140x68, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,2150xFF, 0x02, 0x01, 0x02, 0x02, 0x82, 0x01, 0x00,2160x7F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,2170xE4, 0x87, 0xED, 0x51, 0x10, 0xB4, 0x61, 0x1A,2180x62, 0x63, 0x31, 0x45, 0xC0, 0x6E, 0x0E, 0x68,2190x94, 0x81, 0x27, 0x04, 0x45, 0x33, 0xE6, 0x3A,2200x01, 0x05, 0xDF, 0x53, 0x1D, 0x89, 0xCD, 0x91,2210x28, 0xA5, 0x04, 0x3C, 0xC7, 0x1A, 0x02, 0x6E,2220xF7, 0xCA, 0x8C, 0xD9, 0xE6, 0x9D, 0x21, 0x8D,2230x98, 0x15, 0x85, 0x36, 0xF9, 0x2F, 0x8A, 0x1B,2240xA7, 0xF0, 0x9A, 0xB6, 0xB6, 0xA8, 0xE1, 0x22,2250xF2, 0x42, 0xDA, 0xBB, 0x31, 0x2F, 0x3F, 0x63,2260x7A, 0x26, 0x21, 0x74, 0xD3, 0x1B, 0xF6, 0xB5,2270x85, 0xFF, 0xAE, 0x5B, 0x7A, 0x03, 0x5B, 0xF6,2280xF7, 0x1C, 0x35, 0xFD, 0xAD, 0x44, 0xCF, 0xD2,2290xD7, 0x4F, 0x92, 0x08, 0xBE, 0x25, 0x8F, 0xF3,2300x24, 0x94, 0x33, 0x28, 0xF6, 0x72, 0x2D, 0x9E,2310xE1, 0x00, 0x3E, 0x5C, 0x50, 0xB1, 0xDF, 0x82,2320xCC, 0x6D, 0x24, 0x1B, 0x0E, 0x2A, 0xE9, 0xCD,2330x34, 0x8B, 0x1F, 0xD4, 0x7E, 0x92, 0x67, 0xAF,2340xC1, 0xB2, 0xAE, 0x91, 0xEE, 0x51, 0xD6, 0xCB,2350x0E, 0x31, 0x79, 0xAB, 0x10, 0x42, 0xA9, 0x5D,2360xCF, 0x6A, 0x94, 0x83, 0xB8, 0x4B, 0x4B, 0x36,2370xB3, 0x86, 0x1A, 0xA7, 0x25, 0x5E, 0x4C, 0x02,2380x78, 0xBA, 0x36, 0x04, 0x65, 0x0C, 0x10, 0xBE,2390x19, 0x48, 0x2F, 0x23, 0x17, 0x1B, 0x67, 0x1D,2400xF1, 0xCF, 0x3B, 0x96, 0x0C, 0x07, 0x43, 0x01,2410xCD, 0x93, 0xC1, 0xD1, 0x76, 0x03, 0xD1, 0x47,2420xDA, 0xE2, 0xAE, 0xF8, 0x37, 0xA6, 0x29, 0x64,2430xEF, 0x15, 0xE5, 0xFB, 0x4A, 0xAC, 0x0B, 0x8C,2440x1C, 0xCA, 0xA4, 0xBE, 0x75, 0x4A, 0xB5, 0x72,2450x8A, 0xE9, 0x13, 0x0C, 0x4C, 0x7D, 0x02, 0x88,2460x0A, 0xB9, 0x47, 0x2D, 0x45, 0x56, 0x55, 0x34,2470x7F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF248};249250/* RFC 3526 section 5 (4096-bit MODP Group), RFC 3279 encoding */251static const uint8_t o4096[] = {2520x30, 0x82, 0x04, 0x0C, 0x02, 0x82, 0x02, 0x01,2530x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,2540xFF, 0xC9, 0x0F, 0xDA, 0xA2, 0x21, 0x68, 0xC2,2550x34, 0xC4, 0xC6, 0x62, 0x8B, 0x80, 0xDC, 0x1C,2560xD1, 0x29, 0x02, 0x4E, 0x08, 0x8A, 0x67, 0xCC,2570x74, 0x02, 0x0B, 0xBE, 0xA6, 0x3B, 0x13, 0x9B,2580x22, 0x51, 0x4A, 0x08, 0x79, 0x8E, 0x34, 0x04,2590xDD, 0xEF, 0x95, 0x19, 0xB3, 0xCD, 0x3A, 0x43,2600x1B, 0x30, 0x2B, 0x0A, 0x6D, 0xF2, 0x5F, 0x14,2610x37, 0x4F, 0xE1, 0x35, 0x6D, 0x6D, 0x51, 0xC2,2620x45, 0xE4, 0x85, 0xB5, 0x76, 0x62, 0x5E, 0x7E,2630xC6, 0xF4, 0x4C, 0x42, 0xE9, 0xA6, 0x37, 0xED,2640x6B, 0x0B, 0xFF, 0x5C, 0xB6, 0xF4, 0x06, 0xB7,2650xED, 0xEE, 0x38, 0x6B, 0xFB, 0x5A, 0x89, 0x9F,2660xA5, 0xAE, 0x9F, 0x24, 0x11, 0x7C, 0x4B, 0x1F,2670xE6, 0x49, 0x28, 0x66, 0x51, 0xEC, 0xE4, 0x5B,2680x3D, 0xC2, 0x00, 0x7C, 0xB8, 0xA1, 0x63, 0xBF,2690x05, 0x98, 0xDA, 0x48, 0x36, 0x1C, 0x55, 0xD3,2700x9A, 0x69, 0x16, 0x3F, 0xA8, 0xFD, 0x24, 0xCF,2710x5F, 0x83, 0x65, 0x5D, 0x23, 0xDC, 0xA3, 0xAD,2720x96, 0x1C, 0x62, 0xF3, 0x56, 0x20, 0x85, 0x52,2730xBB, 0x9E, 0xD5, 0x29, 0x07, 0x70, 0x96, 0x96,2740x6D, 0x67, 0x0C, 0x35, 0x4E, 0x4A, 0xBC, 0x98,2750x04, 0xF1, 0x74, 0x6C, 0x08, 0xCA, 0x18, 0x21,2760x7C, 0x32, 0x90, 0x5E, 0x46, 0x2E, 0x36, 0xCE,2770x3B, 0xE3, 0x9E, 0x77, 0x2C, 0x18, 0x0E, 0x86,2780x03, 0x9B, 0x27, 0x83, 0xA2, 0xEC, 0x07, 0xA2,2790x8F, 0xB5, 0xC5, 0x5D, 0xF0, 0x6F, 0x4C, 0x52,2800xC9, 0xDE, 0x2B, 0xCB, 0xF6, 0x95, 0x58, 0x17,2810x18, 0x39, 0x95, 0x49, 0x7C, 0xEA, 0x95, 0x6A,2820xE5, 0x15, 0xD2, 0x26, 0x18, 0x98, 0xFA, 0x05,2830x10, 0x15, 0x72, 0x8E, 0x5A, 0x8A, 0xAA, 0xC4,2840x2D, 0xAD, 0x33, 0x17, 0x0D, 0x04, 0x50, 0x7A,2850x33, 0xA8, 0x55, 0x21, 0xAB, 0xDF, 0x1C, 0xBA,2860x64, 0xEC, 0xFB, 0x85, 0x04, 0x58, 0xDB, 0xEF,2870x0A, 0x8A, 0xEA, 0x71, 0x57, 0x5D, 0x06, 0x0C,2880x7D, 0xB3, 0x97, 0x0F, 0x85, 0xA6, 0xE1, 0xE4,2890xC7, 0xAB, 0xF5, 0xAE, 0x8C, 0xDB, 0x09, 0x33,2900xD7, 0x1E, 0x8C, 0x94, 0xE0, 0x4A, 0x25, 0x61,2910x9D, 0xCE, 0xE3, 0xD2, 0x26, 0x1A, 0xD2, 0xEE,2920x6B, 0xF1, 0x2F, 0xFA, 0x06, 0xD9, 0x8A, 0x08,2930x64, 0xD8, 0x76, 0x02, 0x73, 0x3E, 0xC8, 0x6A,2940x64, 0x52, 0x1F, 0x2B, 0x18, 0x17, 0x7B, 0x20,2950x0C, 0xBB, 0xE1, 0x17, 0x57, 0x7A, 0x61, 0x5D,2960x6C, 0x77, 0x09, 0x88, 0xC0, 0xBA, 0xD9, 0x46,2970xE2, 0x08, 0xE2, 0x4F, 0xA0, 0x74, 0xE5, 0xAB,2980x31, 0x43, 0xDB, 0x5B, 0xFC, 0xE0, 0xFD, 0x10,2990x8E, 0x4B, 0x82, 0xD1, 0x20, 0xA9, 0x21, 0x08,3000x01, 0x1A, 0x72, 0x3C, 0x12, 0xA7, 0x87, 0xE6,3010xD7, 0x88, 0x71, 0x9A, 0x10, 0xBD, 0xBA, 0x5B,3020x26, 0x99, 0xC3, 0x27, 0x18, 0x6A, 0xF4, 0xE2,3030x3C, 0x1A, 0x94, 0x68, 0x34, 0xB6, 0x15, 0x0B,3040xDA, 0x25, 0x83, 0xE9, 0xCA, 0x2A, 0xD4, 0x4C,3050xE8, 0xDB, 0xBB, 0xC2, 0xDB, 0x04, 0xDE, 0x8E,3060xF9, 0x2E, 0x8E, 0xFC, 0x14, 0x1F, 0xBE, 0xCA,3070xA6, 0x28, 0x7C, 0x59, 0x47, 0x4E, 0x6B, 0xC0,3080x5D, 0x99, 0xB2, 0x96, 0x4F, 0xA0, 0x90, 0xC3,3090xA2, 0x23, 0x3B, 0xA1, 0x86, 0x51, 0x5B, 0xE7,3100xED, 0x1F, 0x61, 0x29, 0x70, 0xCE, 0xE2, 0xD7,3110xAF, 0xB8, 0x1B, 0xDD, 0x76, 0x21, 0x70, 0x48,3120x1C, 0xD0, 0x06, 0x91, 0x27, 0xD5, 0xB0, 0x5A,3130xA9, 0x93, 0xB4, 0xEA, 0x98, 0x8D, 0x8F, 0xDD,3140xC1, 0x86, 0xFF, 0xB7, 0xDC, 0x90, 0xA6, 0xC0,3150x8F, 0x4D, 0xF4, 0x35, 0xC9, 0x34, 0x06, 0x31,3160x99, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,3170xFF, 0x02, 0x01, 0x02, 0x02, 0x82, 0x02, 0x00,3180x7F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,3190xE4, 0x87, 0xED, 0x51, 0x10, 0xB4, 0x61, 0x1A,3200x62, 0x63, 0x31, 0x45, 0xC0, 0x6E, 0x0E, 0x68,3210x94, 0x81, 0x27, 0x04, 0x45, 0x33, 0xE6, 0x3A,3220x01, 0x05, 0xDF, 0x53, 0x1D, 0x89, 0xCD, 0x91,3230x28, 0xA5, 0x04, 0x3C, 0xC7, 0x1A, 0x02, 0x6E,3240xF7, 0xCA, 0x8C, 0xD9, 0xE6, 0x9D, 0x21, 0x8D,3250x98, 0x15, 0x85, 0x36, 0xF9, 0x2F, 0x8A, 0x1B,3260xA7, 0xF0, 0x9A, 0xB6, 0xB6, 0xA8, 0xE1, 0x22,3270xF2, 0x42, 0xDA, 0xBB, 0x31, 0x2F, 0x3F, 0x63,3280x7A, 0x26, 0x21, 0x74, 0xD3, 0x1B, 0xF6, 0xB5,3290x85, 0xFF, 0xAE, 0x5B, 0x7A, 0x03, 0x5B, 0xF6,3300xF7, 0x1C, 0x35, 0xFD, 0xAD, 0x44, 0xCF, 0xD2,3310xD7, 0x4F, 0x92, 0x08, 0xBE, 0x25, 0x8F, 0xF3,3320x24, 0x94, 0x33, 0x28, 0xF6, 0x72, 0x2D, 0x9E,3330xE1, 0x00, 0x3E, 0x5C, 0x50, 0xB1, 0xDF, 0x82,3340xCC, 0x6D, 0x24, 0x1B, 0x0E, 0x2A, 0xE9, 0xCD,3350x34, 0x8B, 0x1F, 0xD4, 0x7E, 0x92, 0x67, 0xAF,3360xC1, 0xB2, 0xAE, 0x91, 0xEE, 0x51, 0xD6, 0xCB,3370x0E, 0x31, 0x79, 0xAB, 0x10, 0x42, 0xA9, 0x5D,3380xCF, 0x6A, 0x94, 0x83, 0xB8, 0x4B, 0x4B, 0x36,3390xB3, 0x86, 0x1A, 0xA7, 0x25, 0x5E, 0x4C, 0x02,3400x78, 0xBA, 0x36, 0x04, 0x65, 0x0C, 0x10, 0xBE,3410x19, 0x48, 0x2F, 0x23, 0x17, 0x1B, 0x67, 0x1D,3420xF1, 0xCF, 0x3B, 0x96, 0x0C, 0x07, 0x43, 0x01,3430xCD, 0x93, 0xC1, 0xD1, 0x76, 0x03, 0xD1, 0x47,3440xDA, 0xE2, 0xAE, 0xF8, 0x37, 0xA6, 0x29, 0x64,3450xEF, 0x15, 0xE5, 0xFB, 0x4A, 0xAC, 0x0B, 0x8C,3460x1C, 0xCA, 0xA4, 0xBE, 0x75, 0x4A, 0xB5, 0x72,3470x8A, 0xE9, 0x13, 0x0C, 0x4C, 0x7D, 0x02, 0x88,3480x0A, 0xB9, 0x47, 0x2D, 0x45, 0x55, 0x62, 0x16,3490xD6, 0x99, 0x8B, 0x86, 0x82, 0x28, 0x3D, 0x19,3500xD4, 0x2A, 0x90, 0xD5, 0xEF, 0x8E, 0x5D, 0x32,3510x76, 0x7D, 0xC2, 0x82, 0x2C, 0x6D, 0xF7, 0x85,3520x45, 0x75, 0x38, 0xAB, 0xAE, 0x83, 0x06, 0x3E,3530xD9, 0xCB, 0x87, 0xC2, 0xD3, 0x70, 0xF2, 0x63,3540xD5, 0xFA, 0xD7, 0x46, 0x6D, 0x84, 0x99, 0xEB,3550x8F, 0x46, 0x4A, 0x70, 0x25, 0x12, 0xB0, 0xCE,3560xE7, 0x71, 0xE9, 0x13, 0x0D, 0x69, 0x77, 0x35,3570xF8, 0x97, 0xFD, 0x03, 0x6C, 0xC5, 0x04, 0x32,3580x6C, 0x3B, 0x01, 0x39, 0x9F, 0x64, 0x35, 0x32,3590x29, 0x0F, 0x95, 0x8C, 0x0B, 0xBD, 0x90, 0x06,3600x5D, 0xF0, 0x8B, 0xAB, 0xBD, 0x30, 0xAE, 0xB6,3610x3B, 0x84, 0xC4, 0x60, 0x5D, 0x6C, 0xA3, 0x71,3620x04, 0x71, 0x27, 0xD0, 0x3A, 0x72, 0xD5, 0x98,3630xA1, 0xED, 0xAD, 0xFE, 0x70, 0x7E, 0x88, 0x47,3640x25, 0xC1, 0x68, 0x90, 0x54, 0x90, 0x84, 0x00,3650x8D, 0x39, 0x1E, 0x09, 0x53, 0xC3, 0xF3, 0x6B,3660xC4, 0x38, 0xCD, 0x08, 0x5E, 0xDD, 0x2D, 0x93,3670x4C, 0xE1, 0x93, 0x8C, 0x35, 0x7A, 0x71, 0x1E,3680x0D, 0x4A, 0x34, 0x1A, 0x5B, 0x0A, 0x85, 0xED,3690x12, 0xC1, 0xF4, 0xE5, 0x15, 0x6A, 0x26, 0x74,3700x6D, 0xDD, 0xE1, 0x6D, 0x82, 0x6F, 0x47, 0x7C,3710x97, 0x47, 0x7E, 0x0A, 0x0F, 0xDF, 0x65, 0x53,3720x14, 0x3E, 0x2C, 0xA3, 0xA7, 0x35, 0xE0, 0x2E,3730xCC, 0xD9, 0x4B, 0x27, 0xD0, 0x48, 0x61, 0xD1,3740x11, 0x9D, 0xD0, 0xC3, 0x28, 0xAD, 0xF3, 0xF6,3750x8F, 0xB0, 0x94, 0xB8, 0x67, 0x71, 0x6B, 0xD7,3760xDC, 0x0D, 0xEE, 0xBB, 0x10, 0xB8, 0x24, 0x0E,3770x68, 0x03, 0x48, 0x93, 0xEA, 0xD8, 0x2D, 0x54,3780xC9, 0xDA, 0x75, 0x4C, 0x46, 0xC7, 0xEE, 0xE0,3790xC3, 0x7F, 0xDB, 0xEE, 0x48, 0x53, 0x60, 0x47,3800xA6, 0xFA, 0x1A, 0xE4, 0x9A, 0x03, 0x18, 0xCC,3810xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF382};383384/* Named curve prime256v1 (1.2.840.10045.3.1.7) as parameters for RFC 3279385* section 2.3.5 id-ecPublicKey */386static const uint8_t p256[] = {3870x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x07388};389390/* Named curve secp384r1 (1.3.132.0.34, from RFC 5480 section 2.1.1.1) as391* parameters for RFC 3279 section 2.3.5 id-ecPublicKey */392static const uint8_t p384[] = {3930x06, 0x05, 0x2B, 0x81, 0x04, 0x00, 0x22394};395396/* Named curve secp521r1 (1.3.132.0.35, from RFC 5480 section 2.1.1.1) as397* parameters for RFC 3279 section 2.3.5 id-ecPublicKey */398static const uint8_t p521[] = {3990x06, 0x05, 0x2B, 0x81, 0x04, 0x00, 0x23400};401402const krb5_data oakley_1024 = { KV5M_DATA, sizeof(o1024), (char *)o1024 };403const krb5_data oakley_2048 = { KV5M_DATA, sizeof(o2048), (char *)o2048 };404const krb5_data oakley_4096 = { KV5M_DATA, sizeof(o4096), (char *)o4096 };405const krb5_data ec_p256 = { KV5M_DATA, sizeof(p256), (char *)p256 };406const krb5_data ec_p384 = { KV5M_DATA, sizeof(p384), (char *)p384 };407const krb5_data ec_p521 = { KV5M_DATA, sizeof(p521), (char *)p521 };408409/* RFC 3279 section 2.3.3 dhpublicnumber (1.2.840.10046.2.1) */410const krb5_data dh_oid = { 0, 7, "\x2A\x86\x48\xce\x3e\x02\x01" };411412/* RFC 3279 section 2.3.5 id-ecPublicKey (1.2.840.10045.2.1) */413const krb5_data ec_oid = { 0, 7, "\x2A\x86\x48\xCE\x3D\x02\x01" };414415416