Well, here is a patch that adds the Brainpool curves, but two of them  
fail validation.  These two have hex values of an odd length in [1]  
and [2].  My reading of Crypto++'s code to decode type 4  
(uncompressed) hex-encoded points says that each value should be of  
size MaxElementByteLength.  I tried prepending and appending a "0"  
char but that didn't make it pass validation.  So I'm stumped.  This  
will probably be easy in the morning -- it is past my bed-time!

Regards,

Zooko

[1] http://tools.ietf.org/html/draft-lochter-pkix-brainpool-ecc-03
[2] http://www.ecc-brainpool.org/download/Domain-parameters.pdf

diff -rN -u old-dw/c5/eccrypto.cpp new-dw/c5/eccrypto.cpp
--- old-dw/c5/eccrypto.cpp      2009-03-11 00:06:55.000000000 -0600
+++ new-dw/c5/eccrypto.cpp      2009-03-11 00:06:56.000000000 -0600
@@ -266,6 +266,55 @@
   
                        
"046B17D1F2E12C4247F8BCE6E563A440F277037D812DEB33A0F4A13945D898C2964F 
E342E2FE1A7F9B8EE7EB4A7C0F9E162BCE33576B315ECECBB6406837BF51F5",
                        
"FFFFFFFF00000000FFFFFFFFFFFFFFFFBCE6FAADA7179E84F3B9CAC2FC632551",
                        1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP160r1(),
+                       "E95E4A5F737059DC60DFC7AD95B3D8139515620F",
+                       "340E7BE2A280EB74E2BE61BADA745D97E8F7C300",
+                       "1E589A8595423412134FAA2DBDEC95C8D8675E58",
+                       
"04BED5AF16EA3F6A4F62938C4631EB5AF7BDBCDBC31667CB477A1A8EC338F947416 
69C976316DA6321",
+                       "E95E4A5F737059DC60DF5991D45029409E60FC09",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP192r1(),
+                       "C302F41D932A36CDA7A3463093D18DB78FCE476DE1A86297",
+                       "6A91174076B1E0E19C39C031FE8685C1CAE040E5C69A28EF",
+                       "469A28EF7C28CCA3DC721D044F4496BCCA7EF4146FBF25C9",
+                       
"04C0A0647EAAB6A48753B033C56CB0F0900A2F5C4853375FD614B690866ABD5BB88 
B5F4828C1490002E6773FA2FA299B8F",
+                       "C302F41D932A36CDA7A3462F9E9E916B5BE8F1029AC4ACC1",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP224r1(),
+                       
"D7C134AA264366862A18302575D1D787B09F075797DA89F57EC8C0FF",
+                       
"68A5E62CA9CE6C1C299803A6C1530B514E182AD8B0042A59CAD29F43",
+                       
"2580F63CCFE44138870713B1A92369E33E2135D266DBB372386C400B",
+                       
"04D9029AD2C7E5CF4340823B2A87DC68C9E4CE3174C1E6EFDEE12C07D58AA56F772 
C0726F24C6B89E4ECDAC24354B9E99CAA3F6D3761402CD",
+                       
"D7C134AA264366862A18302575D0FB98D116BC4B6DDEBCA3A5A7939F",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP256r1(),
+                       
"A9FB57DBA1EEA9BC3E660A909D838D726E3BF623D52620282013481D1F6E5377",
+                       
"7D5A0975FC2C3057EEF67530417AFFE7FB8055C126DC5C6CE94A4B44F330B5D9",
+                       
"26DC5C6CE94A4B44F330B5D9BBD77CBF958416295CF7E1CE6BCCDC18FF8C07B6",
+                       
"048BD2AEB9CB7E57CB2C4B482FFC81B7AFB9DE27E1E3BD23C23A4453BD9ACE32625 
47EF835C3DAC4FD97F8461A14611DC9C27745132DED8E545C1D54C72F046997",
+                       
"A9FB57DBA1EEA9BC3E660A909D838D718C397AA3B561A6F7901E0E82974856A7",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP320r1(),
+                       
"D35E472036BC4FB7E13C785ED201E065F98FCFA6F6F40DEF4F92B9EC7893EC28FCD 
412B1F1B32E27",
+                       
"3EE30B568FBAB0F883CCEBD46D3F3BB8A2A73513F5EB79DA66190EB085FFA9F492F 
375A97D860EB4",
+                       
"520883949DFDBC42D3AD198640688A6FE13F41349554B49ACC31DCCD884539816F5 
EB4AC8FB1F1A6",
+                       
"0443BD7E9AFB53D8B85289BCC48EE5BFE6F20137D10A087EB6E7871E2A10A599C71 
0AF8D0D39E2061114FDD05545EC1CC8AB4093247F77275E0743FFED117182EAA9C77877A 
AAC6AC7D35245D1692E8EE1",
+                       
"D35E472036BC4FB7E13C785ED201E065F98FCFA5B68F12A32D482EC7EE8658E9869 
1555B44C59311",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP384r1(),
+                       
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B412B1DA197FB71123ACD 
3A729901D1A71874700133107EC53",
+                       
"7BC382C63D8C150C3C72080ACE05AFA0C2BEA28E4FB22787139165EFBA91F90F8AA 
5814A503AD4EB04A8C7DD22CE2826",
+                       
"4A8C7DD22CE28268B39B55416F0447C2FB77DE107DCD2A62E880EA53EEB62D57CB4 
390295DBC9943AB78696FA504C11",
+                       
"041D1C64F068CF45FFA2A63A81B7C13F6B8847A3E77EF14FE3DB7FCAFE0CBD10E8E 
826E03436D646AAEF87B2E247D4AF1E8ABE1D7520F9C2A45CB1EB8E95CFD55262B70B29F 
EEC5864E19C054FF99129280E4646217791811142820341263C5315",
+                       
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B31F166E6CAC0425A7CF3 
AB6AF6B7FC3103B883202E9046565",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP512r1(),
+                       
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA703308717D4 
D9B009BC66842AECDA12AE6A380E62881FF2F2D82C68528AA6056583A48F3",
+                       
"7830A3318B603B89E2327145AC234CC594CBDD8D3DF91610A83441CAEA9863BC2DE 
D5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF2C7B9E7C1AC4D77FC94CA",
+                       
"3DF91610A83441CAEA9863BC2DED5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF 
2C7B9E7C1AC4D77FC94CADC083E67984050B75EBAE5DD2809BD638016F723",
+                       
"0481AEE4BDD82ED9645A21322E9C4C6A9385ED9F70B5D916C1B43B62EEF4D0098EF 
F3B1F78E2D0D48D50D1687B93B97D5F7C6D5047406A5E688B352209BCB9F8227DDE385D5 
66332ECC0EABFA9CF7822FDF209F70024A57B1AA000C55B881F8111B2DCDE494A5F485E5 
BCA4BD88A2763AED1CA2B2FA8F0540678CD1E0F3AD80892",
+                       
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA70330870553 
E5C414CA92619418661197FAC10471DB1D381085DDADDB58796829CA90069",
+                       1),
                EcRecommendedParameters<ECP>(ASN1::secp112r1(),
                        "DB7C2ABF62E35E668076BEAD208B",
                        "DB7C2ABF62E35E668076BEAD2088",
--- old-dw/c5/oids.h    2009-03-11 00:06:55.000000000 -0600
+++ new-dw/c5/oids.h    2009-03-11 00:06:56.000000000 -0600
@@ -42,8 +42,19 @@
                        DEFINE_OID(oiw()+14, oiw_secsig);
                                DEFINE_OID(oiw_secsig()+2, 
oiw_secsig_algorithms);
                                        DEFINE_OID(oiw_secsig_algorithms()+26, 
id_sha1);
+
                DEFINE_OID(identified_organization()+36, teletrust);
-                       DEFINE_OID(teletrust()+3+2+1, id_ripemd160)
+                       DEFINE_OID(teletrust()+3, teletrust_algorithm)
+                               DEFINE_OID(teletrust_algorithm()+2+1, 
id_ripemd160)
+                               DEFINE_OID(teletrust_algorithm()+3+2+8+1, 
teletrust_ellipticCurve)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+1, brainpoolP160r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+3, brainpoolP192r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+5, brainpoolP224r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+7, brainpoolP256r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+9, brainpoolP320r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+11, brainpoolP384r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+13, brainpoolP512r1)
+
                DEFINE_OID(identified_organization()+132, certicom);
                        DEFINE_OID(certicom()+0, certicom_ellipticCurve);
                                // these are sorted by curve type and then by 
OID


--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the "Crypto++ Users" 
Google Group.
To unsubscribe, send an email to [email protected].
More information about Crypto++ and this group is available at 
http://www.cryptopp.com.
-~----------~----~----~----~------~----~------~--~---

diff -rN -u old-dw/c5/eccrypto.cpp new-dw/c5/eccrypto.cpp
--- old-dw/c5/eccrypto.cpp      2009-03-11 00:06:55.000000000 -0600
+++ new-dw/c5/eccrypto.cpp      2009-03-11 00:06:56.000000000 -0600
@@ -266,6 +266,55 @@
                        
"046B17D1F2E12C4247F8BCE6E563A440F277037D812DEB33A0F4A13945D898C2964FE342E2FE1A7F9B8EE7EB4A7C0F9E162BCE33576B315ECECBB6406837BF51F5",
                        
"FFFFFFFF00000000FFFFFFFFFFFFFFFFBCE6FAADA7179E84F3B9CAC2FC632551",
                        1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP160r1(),
+                       "E95E4A5F737059DC60DFC7AD95B3D8139515620F",
+                       "340E7BE2A280EB74E2BE61BADA745D97E8F7C300",
+                       "1E589A8595423412134FAA2DBDEC95C8D8675E58",
+                       
"04BED5AF16EA3F6A4F62938C4631EB5AF7BDBCDBC31667CB477A1A8EC338F94741669C976316DA6321",
+                       "E95E4A5F737059DC60DF5991D45029409E60FC09",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP192r1(),
+                       "C302F41D932A36CDA7A3463093D18DB78FCE476DE1A86297",
+                       "6A91174076B1E0E19C39C031FE8685C1CAE040E5C69A28EF",
+                       "469A28EF7C28CCA3DC721D044F4496BCCA7EF4146FBF25C9",
+                       
"04C0A0647EAAB6A48753B033C56CB0F0900A2F5C4853375FD614B690866ABD5BB88B5F4828C1490002E6773FA2FA299B8F",
+                       "C302F41D932A36CDA7A3462F9E9E916B5BE8F1029AC4ACC1",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP224r1(),
+                       
"D7C134AA264366862A18302575D1D787B09F075797DA89F57EC8C0FF",
+                       
"68A5E62CA9CE6C1C299803A6C1530B514E182AD8B0042A59CAD29F43",
+                       
"2580F63CCFE44138870713B1A92369E33E2135D266DBB372386C400B",
+                       
"04D9029AD2C7E5CF4340823B2A87DC68C9E4CE3174C1E6EFDEE12C07D58AA56F772C0726F24C6B89E4ECDAC24354B9E99CAA3F6D3761402CD",
+                       
"D7C134AA264366862A18302575D0FB98D116BC4B6DDEBCA3A5A7939F",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP256r1(),
+                       
"A9FB57DBA1EEA9BC3E660A909D838D726E3BF623D52620282013481D1F6E5377",
+                       
"7D5A0975FC2C3057EEF67530417AFFE7FB8055C126DC5C6CE94A4B44F330B5D9",
+                       
"26DC5C6CE94A4B44F330B5D9BBD77CBF958416295CF7E1CE6BCCDC18FF8C07B6",
+                       
"048BD2AEB9CB7E57CB2C4B482FFC81B7AFB9DE27E1E3BD23C23A4453BD9ACE3262547EF835C3DAC4FD97F8461A14611DC9C27745132DED8E545C1D54C72F046997",
+                       
"A9FB57DBA1EEA9BC3E660A909D838D718C397AA3B561A6F7901E0E82974856A7",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP320r1(),
+                       
"D35E472036BC4FB7E13C785ED201E065F98FCFA6F6F40DEF4F92B9EC7893EC28FCD412B1F1B32E27",
+                       
"3EE30B568FBAB0F883CCEBD46D3F3BB8A2A73513F5EB79DA66190EB085FFA9F492F375A97D860EB4",
+                       
"520883949DFDBC42D3AD198640688A6FE13F41349554B49ACC31DCCD884539816F5EB4AC8FB1F1A6",
+                       
"0443BD7E9AFB53D8B85289BCC48EE5BFE6F20137D10A087EB6E7871E2A10A599C710AF8D0D39E2061114FDD05545EC1CC8AB4093247F77275E0743FFED117182EAA9C77877AAAC6AC7D35245D1692E8EE1",
+                       
"D35E472036BC4FB7E13C785ED201E065F98FCFA5B68F12A32D482EC7EE8658E98691555B44C59311",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP384r1(),
+                       
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B412B1DA197FB71123ACD3A729901D1A71874700133107EC53",
+                       
"7BC382C63D8C150C3C72080ACE05AFA0C2BEA28E4FB22787139165EFBA91F90F8AA5814A503AD4EB04A8C7DD22CE2826",
+                       
"4A8C7DD22CE28268B39B55416F0447C2FB77DE107DCD2A62E880EA53EEB62D57CB4390295DBC9943AB78696FA504C11",
+                       
"041D1C64F068CF45FFA2A63A81B7C13F6B8847A3E77EF14FE3DB7FCAFE0CBD10E8E826E03436D646AAEF87B2E247D4AF1E8ABE1D7520F9C2A45CB1EB8E95CFD55262B70B29FEEC5864E19C054FF99129280E4646217791811142820341263C5315",
+                       
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B31F166E6CAC0425A7CF3AB6AF6B7FC3103B883202E9046565",
+                       1),
+               EcRecommendedParameters<ECP>(ASN1::brainpoolP512r1(),
+                       
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA703308717D4D9B009BC66842AECDA12AE6A380E62881FF2F2D82C68528AA6056583A48F3",
+                       
"7830A3318B603B89E2327145AC234CC594CBDD8D3DF91610A83441CAEA9863BC2DED5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF2C7B9E7C1AC4D77FC94CA",
+                       
"3DF91610A83441CAEA9863BC2DED5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF2C7B9E7C1AC4D77FC94CADC083E67984050B75EBAE5DD2809BD638016F723",
+                       
"0481AEE4BDD82ED9645A21322E9C4C6A9385ED9F70B5D916C1B43B62EEF4D0098EFF3B1F78E2D0D48D50D1687B93B97D5F7C6D5047406A5E688B352209BCB9F8227DDE385D566332ECC0EABFA9CF7822FDF209F70024A57B1AA000C55B881F8111B2DCDE494A5F485E5BCA4BD88A2763AED1CA2B2FA8F0540678CD1E0F3AD80892",
+                       
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA70330870553E5C414CA92619418661197FAC10471DB1D381085DDADDB58796829CA90069",
+                       1),
                EcRecommendedParameters<ECP>(ASN1::secp112r1(),
                        "DB7C2ABF62E35E668076BEAD208B",
                        "DB7C2ABF62E35E668076BEAD2088",
--- old-dw/c5/oids.h    2009-03-11 00:06:55.000000000 -0600
+++ new-dw/c5/oids.h    2009-03-11 00:06:56.000000000 -0600
@@ -42,8 +42,19 @@
                        DEFINE_OID(oiw()+14, oiw_secsig);
                                DEFINE_OID(oiw_secsig()+2, 
oiw_secsig_algorithms);
                                        DEFINE_OID(oiw_secsig_algorithms()+26, 
id_sha1);
+
                DEFINE_OID(identified_organization()+36, teletrust);
-                       DEFINE_OID(teletrust()+3+2+1, id_ripemd160)
+                       DEFINE_OID(teletrust()+3, teletrust_algorithm)
+                               DEFINE_OID(teletrust_algorithm()+2+1, 
id_ripemd160)
+                               DEFINE_OID(teletrust_algorithm()+3+2+8+1, 
teletrust_ellipticCurve)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+1, brainpoolP160r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+3, brainpoolP192r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+5, brainpoolP224r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+7, brainpoolP256r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+9, brainpoolP320r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+11, brainpoolP384r1)
+                                       
DEFINE_OID(teletrust_ellipticCurve()+1+13, brainpoolP512r1)
+
                DEFINE_OID(identified_organization()+132, certicom);
                        DEFINE_OID(certicom()+0, certicom_ellipticCurve);
                                // these are sorted by curve type and then by 
OID

Reply via email to