api-console-assets
Version:
This repo only exists to publish api console components to npm
522 lines (426 loc) • 26.9 kB
HTML
<html>
<head>
<meta charset="utf-8">
<title>QUnit for ASN1 Encoder Class 'asn1x509.js'</title>
<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="qunit.js"></script>
<link rel="stylesheet" href="qunit.css" type="text/css" media="screen" />
<script src="../ext/cj/cryptojs-312-core-fix.js"></script>
<script src="../ext/cj/x64-core.js"></script>
<script src="../ext/cj/cipher-core_min.js"></script>
<script src="../ext/cj/aes_min.js"></script>
<script src="../ext/cj/tripledes_min.js"></script>
<script src="../ext/cj/enc-base64_min.js"></script>
<script src="../ext/cj/md5_min.js"></script>
<script src="../ext/cj/sha1_min.js"></script>
<script src="../ext/cj/sha256_min.js"></script>
<script src="../ext/cj/sha224_min.js"></script>
<script src="../ext/cj/sha512_min.js"></script>
<script src="../ext/cj/sha384_min.js"></script>
<script src="../ext/cj/ripemd160_min.js"></script>
<script src="../ext/cj/hmac_min.js"></script>
<script src="../ext/cj/pbkdf2_min.js"></script>
<script src="../ext/yahoo.js"></script>
<script src="../ext/jsbn.js"></script>
<script src="../ext/jsbn2.js"></script>
<script src="../ext/prng4.js"></script>
<script src="../ext/rng.js"></script>
<script src="../ext/base64.js"></script>
<script src="../ext/rsa.js"></script>
<script src="../ext/rsa2.js"></script>
<script src="../src/base64x-1.1.js"></script>
<script src="../src/asn1hex-1.1.js"></script>
<script src="../src/rsapem-1.1.js"></script>
<script src="../src/rsasign-1.2.js"></script>
<script src="../src/crypto-1.1.js"></script>
<script src="../src/asn1-1.0.js"></script>
<script src="../src/asn1x509-1.0.js"></script>
<script src="../src/x509-1.1.js"></script>
<script src="../src/keyutil-1.0.js"></script>
<script type="text/javascript">
<!--
$(document).ready(function(){
// ======= TEST ===============================================================
// _test/z4.tsa.cer
var z4TSACERT =
"-----BEGIN CERTIFICATE-----\n" +
"MIIDETCCAfmgAwIBAgIBTTANBgkqhkiG9w0BAQUFADAbMQswCQYDVQQGEwJVUzEM\n" +
"MAoGA1UECgwDQ0ExMB4XDTEzMDUwMTIzNTk1OVoXDTIzMDUwMTIzNTk1OVowHDEL\n" +
"MAkGA1UEBhMCVVMxDTALBgNVBAMMBFRTQTEwggEiMA0GCSqGSIb3DQEBAQUAA4IB\n" +
"DwAwggEKAoIBAQDfdOqotHd55SYO0dLz2oXengw/tZ+q3ZmOPeVmMuOMIYO/Cv1w\n" +
"k2U0OK4pug4OBSJPhl09Zs6IwB8NwPOU7EDTgMOcQUYB/6QNCI1J7Zm2oLtuchzz\n" +
"4pIb+o4ZAhVprLhRyvqi8OTKQ7kfGfs5Tuwmn1M/0fQkfzMxADpjOKNgf0uy6lN6\n" +
"utjdTrPKKFUQNdc6/Ty8EeTnQEwUlsT2LAXCfEKxTn5RlRljDztS7Sfgs8VL0FPy\n" +
"1Qi8B+dFcgRYKFrcpsVaZ1lBmXKsXDRu5QR/Rg3f9DRq4GR1sNH8RLY9uApMl2SN\n" +
"z+sR4zRPG85R/se5Q06Gu0BUQ3UPm67ETVZLAgMBAAGjXzBdMAwGA1UdEwEB/wQC\n" +
"MAAwCwYDVR0PBAQDAgbAMBYGA1UdJQEB/wQMMAoGCCsGAQUFBwMIMCgGA1UdHwQh\n" +
"MB8wHaAboBmGF2h0dHA6Ly90ZXN0LmNvbS9jYTEuY3JsMA0GCSqGSIb3DQEBBQUA\n" +
"A4IBAQBNkm5GniFi3PKqbafCVN8mpHWJjF2stCRTVxeTCIXUC63YD5XKABGzPH+Y\n" +
"2R8fCrOa8cGlHmFXOlJye/lnXeZodPyxJUvAKohTp6sG+rJVId8ISI2Io2i5BF8a\n" +
"CHdm8qd8E0fJvBudqkEc26Ia6tFSA/gEW0ffhsCkN/lXUAjuvDLqtTtU7zBU6dIl\n" +
"h12Pwyf+x6AsYSciA9zWC6OE590K8Jr2z4u85biM7viWvPeZPNHSNM1fe+8wKbP8\n" +
"64JtLj/VrglcsXALaUalyh2Hs7gPQzjyus1fyhEWPO3T6KMcBMXjb6anxL5q9YO5\n" +
"qx1hJTY3L1hahBcMTALQyTEiFv1S\n" +
"-----END CERTIFICATE-----\n";
test("Certificate class test", function() {
var pubKey = new RSAKey();
pubKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o = new KJUR.asn1.x509.TBSCertificate();
o.setSerialNumberByParam({'int': 4});
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setNotBeforeByParam({'str': '130504235959Z'});
o.setNotAfterByParam({'str': '140504235959Z'});
o.setSubjectByParam({'str': '/C=US/CN=b'});
o.setSubjectPublicKey(pubKey);
o.appendExtension(new KJUR.asn1.x509.BasicConstraints({'cA':true}));
o.appendExtension(new KJUR.asn1.x509.KeyUsage({'bin':'11'}));
var prvKey = new RSAKey();
prvKey.readPKCS5PrvKeyHex("3082013a020100024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001024078bbc54c646795e9a623cb0f912c7f9f6861711560e57bade21ded2f7d9579f86272fab9e71ab27282c2760c404dae6ac8a3ab852cf6bcd562f9aff8247a264d022100fe9bd450866b3255614fde976a76ac0b1d5830dda64f5359b946d8512bc1239f022100e9ab680f5f05dbb0f4311b0e6f4368f4874a1238979d8bc600c35c6f20707c07022100d549cb698dc17d4fe30e5a84f3ade860033c1eeb7f67d286465c9fd817d45b3702201849b4bb44493b989d092da2c675df46eb790b83ce5e95d4b2e79b88017b2fa902207d261a96256d49b020cb1d587ecde127e093a4d2b34cdbff171f34125b5857a9");
var crt1 = new KJUR.asn1.x509.Certificate({tbscertobj: o,
prvkeyobj: prvKey});
crt1.sign();
expect(3);
// test3
equal(crt1.asn1TBSCert.getEncodedHex(), "3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0", "constructor,sign,asn1TBSCert.getEncodedHex");
// test1
hCrt1 = crt1.getEncodedHex()
equal(hCrt1, "3082013a3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0300d06092a864886f70d010105050003410088dca030a5dcae7b85f0bfcb1fcbac18065d9f5bfd717c78075449a8447e87d0c7cb0cfd2b2ad7140c4075fd44b741502b89a7f7a9967e21c8aea330ac124be0", "constructor,sign,getEncodedHex");
// test2
equal(crt1.getPEMString(), "-----BEGIN CERTIFICATE-----\r\nMIIBOjCB5aADAgECAgEEMA0GCSqGSIb3DQEBBQUAMBkxCzAJBgNVBAYTAlVTMQow\r\nCAYDVQQKDAFhMB4XDTEzMDUwNDIzNTk1OVoXDTE0MDUwNDIzNTk1OVowGTELMAkG\r\nA1UEBhMCVVMxCjAIBgNVBAMMAWIwVzANBgkqhkiG9w0BAQEFAANGADBDAjwA6GZN\r\n0rQFKRIVaPOzm8l6Yue6PAm6vcTw3NjfkOt5C5u2RaK3DjESdHtNPEG1FCSJURX+\r\n+I951D6uWxoCAwEAAaMdMBswDAYDVR0TBAUwAwEB/zALBgNVHQ8EBAMCBsAwDQYJ\r\nKoZIhvcNAQEFBQADQQCI3KAwpdyue4Xwv8sfy6wYBl2fW/1xfHgHVEmoRH6H0MfL\r\nDP0rKtcUDEB1/US3QVAriaf3qZZ+IciuozCsEkvg\r\n-----END CERTIFICATE-----\r\n", "getPEMString");
});
test("TBSCertificate class test", function() {
expect(1);
var rsaKey = new RSAKey();
rsaKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o = new KJUR.asn1.x509.TBSCertificate();
o.setSerialNumberByParam({'int': 4});
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setNotBeforeByParam({'str': '130504235959Z'});
o.setNotAfterByParam({'str': '140504235959Z'});
o.setSubjectByParam({'str': '/C=US/CN=b'});
o.setSubjectPublicKey(rsaKey);
o.appendExtension(new KJUR.asn1.x509.BasicConstraints({'cA':true}));
o.appendExtension(new KJUR.asn1.x509.KeyUsage({'bin':'11'}));
equal(o.getEncodedHex(), "3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0", "set/append test1");
});
test("X500Name class test", function() {
var o = null;
o = new KJUR.asn1.x509.X500Name();
o.setByString("/C=US/O=aaa");
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"setByString(/C=US/O=aaa)");
o = new KJUR.asn1.x509.X500Name();
o.setByString("/C=US/O=あ");
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03e38182",
"setByString(/C=US/O=あ)");
o = new KJUR.asn1.x509.X500Name();
o.setByObject({C: "US", O: "aaa"});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"setByObject({C: 'US', O: 'aaa'})");
o = new KJUR.asn1.x509.X500Name({'str':'/C=US/O=aaa'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"constructor str /C=US/O=aaa");
o = new KJUR.asn1.x509.X500Name({'C': 'US', 'O': 'aaa'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"constructor obj C:US, O:aaa");
o = new KJUR.asn1.x509.X500Name({'C': 'US', 'O': 'aa/'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c0361612f",
"constructor obj C:US, O:aa/");
o = new KJUR.asn1.x509.X500Name({'str': '/O=a/O=b/b/O=c/c/c'});
equal(o.getEncodedHex(),
"302a310a3008060355040a0c0161310c300a060355040a0c03622f62310e300c060355040a0c05632f632f63",
"constructor str /O=a/O=b/b/O=c/c/c");
});
test("RDN class test", function() {
expect(2);
var o2 = new KJUR.asn1.x509.RDN();
o2.addByString("O=aaa");
equal(o2.getEncodedHex(), "310c300a060355040a0c03616161", "addByString(O=aaa)");
var o3 = new KJUR.asn1.x509.RDN({'str':'O=aaa'});
equal(o3.getEncodedHex(), "310c300a060355040a0c03616161", "constructor str O=aaa");
});
test("AttributeTypeAndValue class test", function() {
var o1 = new KJUR.asn1.x509.AttributeTypeAndValue();
o1.setByAttrTypeAndValueStr("O", "aaa");
equal(o1.getEncodedHex(), "300a060355040a0c03616161", "setByAttrTypeAndValueStr O aaa");
var o2 = new KJUR.asn1.x509.AttributeTypeAndValue();
o2.setByString("O=aaa");
equal(o2.getEncodedHex(), "300a060355040a0c03616161", "setByString(O=aaa)");
var o3 = new KJUR.asn1.x509.AttributeTypeAndValue({'str':'O=aaa'});
equal(o3.getEncodedHex(), "300a060355040a0c03616161", "constructor str O=aaa");
var o4 = new KJUR.asn1.x509.AttributeTypeAndValue({'str':'O=あ'});
equal(o4.getEncodedHex(), "300a060355040a0c03e38182", "constructor str O=あ");
});
// === BEGIN Other ASN1 structure class ======================================
test("SubjectPublicKeyInfo class test", function() {
var rsaKey = new RSAKey();
rsaKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o1 = new KJUR.asn1.x509.SubjectPublicKeyInfo(rsaKey);
equal(o1.getEncodedHex(), "3057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001", "constructor default rsaKey");
var pubpem2 =
"-----BEGIN PUBLIC KEY-----\n" +
"MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOtpGHibL8Ue+MXPPufkcrNES40rCT5L\n" +
"RIU9MjTZ8/7owG5bAsiFA9Xxh3uZK1T5QA64jNJVbp2ojHAtNyWPuwsCAwEAAQ==" +
"-----END PUBLIC KEY-----\n"
var pubobj2 = KEYUTIL.getKey(pubpem2);
var o2 = new KJUR.asn1.x509.SubjectPublicKeyInfo();
o2.setPubKey(pubobj2);
equal(o2.getEncodedHex(), "305c300d06092a864886f70d0101010500034b003048024100eb6918789b2fc51ef8c5cf3ee7e472b3444b8d2b093e4b44853d3234d9f3fee8c06e5b02c88503d5f1877b992b54f9400eb88cd2556e9da88c702d37258fbb0b0203010001", "pubpem2");
});
test("Time class test", function() {
expect(4);
var o1 = new KJUR.asn1.x509.Time({'str':'130430235959Z'}); // UTC
equal(o1.getEncodedHex(), "170d3133303433303233353935395a", "constructor default timestr");
var o2 = new KJUR.asn1.x509.Time({'str':'20130430235959Z', 'type': 'gen'}); // Gen
equal(o2.getEncodedHex(), "180f32303133303433303233353935395a", "constructor default timestr");
var o3 = new KJUR.asn1.x509.Time({'str':'20130430235959Z'}); // Gen
equal(o3.getEncodedHex(), "180f32303133303433303233353935395a", "constructor default timestr (auto gen)");
var o4 = new KJUR.asn1.x509.Time(); // auto UTC
equal(o4.getEncodedHex().substr(0, 4), "170d", "constructor default timestr (empty)=170d...");
});
test("AlgorithmIdentifier class test", function() {
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA1withRSA'}).getEncodedHex(),
"300d06092a864886f70d0101050500", "constructor name SHA1withRSA");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA256withRSA'}).getEncodedHex(),
"300d06092a864886f70d01010b0500", "constructor name SHA256withRSA");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA256withRSA', paramempty: true}).getEncodedHex(),
"300b06092a864886f70d01010b", "constructor name SHA256withRSA, paramempty");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA1withDSA'}).getEncodedHex(),
"300906072a8648ce380403", "constructor name SHA1withDSA");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA512withECDSA'}).getEncodedHex(),
"300a06082a8648ce3d040304", "constructor name SHA512withECDSA");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'rsaEncryption'}).getEncodedHex(),
"300d06092a864886f70d0101010500", "constructor name rsaEncryption");
equal(new KJUR.asn1.x509.AlgorithmIdentifier({'name':'sha1'}).getEncodedHex(),
"300906052b0e03021a0500", "constructor name sha1");
});
test("AlgorithmIdentifier SHA1withECDSA", function() {
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA1withECDSA', paramempty: true});
equal(o.getEncodedHex(), "300906072a8648ce3d0401", "aaa");
});
test("AlgorithmIdentifier SHA256withECDSA", function() {
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA256withECDSA', paramempty: true});
equal(o.getEncodedHex(), "300a06082a8648ce3d040302", "aaa");
});
test("AlgorithmIdentifier SHA1withDSA", function() {
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA1withDSA', paramempty: true});
equal(o.getEncodedHex(), "300906072a8648ce380403", "aaa");
});
test("AlgorithmIdentifier SHA256withDSA", function() {
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA256withDSA', paramempty: true});
equal(o.getEncodedHex(), "300b0609608648016503040302", "aaa");
});
test("GeneralName class test", function() {
var o;
o = new KJUR.asn1.x509.GeneralName({'rfc822':'u1@foo.com'});
equal(o.getEncodedHex(), "810a753140666f6f2e636f6d", "constructor rfc822 u1@foo.com");
o = new KJUR.asn1.x509.GeneralName({'dns':'foo.com'});
equal(o.getEncodedHex(), "8207666f6f2e636f6d", "constructor dns foo.com");
o = new KJUR.asn1.x509.GeneralName({'uri':'http://aaa.com/'});
equal(o.getEncodedHex(), "860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
o = new KJUR.asn1.x509.GeneralName({certissuer: z4TSACERT});
equal(o.getEncodedHex(), "a41d301b310b3009060355040613025553310c300a060355040a0c03434131", "constructor certissuer cert1");
o = new KJUR.asn1.x509.GeneralName({certsubj: z4TSACERT});
equal(o.getEncodedHex(), "a41e301c310b3009060355040613025553310d300b06035504030c0454534131", "constructor certsubj cert1");
o = new KJUR.asn1.x509.GeneralName({dn: '/C=US/O=Test'});
equal(o.getEncodedHex(), "a41e301c310b3009060355040613025553310d300b060355040a0c0454657374", "dn /C=US/O=Test");
o = new KJUR.asn1.x509.GeneralName({ldapdn: 'O=Test,C=US'});
equal(o.getEncodedHex(), "a41e301c310b3009060355040613025553310d300b060355040a0c0454657374", "ldapdn O=Test,C=US");
o = new KJUR.asn1.x509.GeneralName({ip: '192.168.1.1'});
equal(o.getEncodedHex(), "8704c0a80101", "ip: 192.168.1.1");
o = new KJUR.asn1.x509.GeneralName({ip: '2001:db8::4'});
equal(o.getEncodedHex(), "871020010db8000000000000000000000004", "ip: 2001:db8::4");
o = new KJUR.asn1.x509.GeneralName({ip: '2606:4700:4700::1111'});
equal(o.getEncodedHex(), "871026064700470000000000000000001111", "ip: 2606:4700:4700::1111");
o = new KJUR.asn1.x509.GeneralName({ip: 'c0a80101'});
equal(o.getEncodedHex(), "8704c0a80101", "ip: c0a80101");
});
test("GeneralNames class test", function() {
expect(1);
var o1 = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
equal(o1.getEncodedHex(), "3011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
test("DistributionPointName class test", function() {
expect(1);
var o1a = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var o1 = new KJUR.asn1.x509.DistributionPointName(o1a);
equal(o1.getEncodedHex(), "a011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
test("DistributionPoint class test", function() {
expect(1);
var o1aa = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var o1a = new KJUR.asn1.x509.DistributionPointName(o1aa);
var o1 = new KJUR.asn1.x509.DistributionPoint({'dpobj': o1a});
equal(o1.getEncodedHex(), "3015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor dpobj http://aaa.com/");
});
test("OID class test", function() {
var o = KJUR.asn1.x509.OID;
equal(o.atype2obj('C').getEncodedHex(), "0603550406", "C");
equal(o.name2obj('SHA1withRSA').getEncodedHex(),
"06092a864886f70d010105", "name2obj SHA1withRSA");
equal(o.name2oid('basicConstraints'), '2.5.29.19', "name2oid basicConstraints");
equal(o.name2oid('UNKNOWNOIDNAME'), '', "name2oid unknown name");
equal(o.oid2name('2.5.29.19'), 'basicConstraints', "oid2name basicConstraints");
equal(o.oid2name('0.0.0.0'), '', "oid2name unknown oid");
});
// BasicConstraints
test("BasicConstraints class test", function() {
expect(6);
var o1 = new KJUR.asn1.x509.BasicConstraints({});
equal(o1.getExtnValueHex(), "3000", "constructor cA=f getExtnValueHex");
equal(o1.getEncodedHex(), "30090603551d1304023000", "constructor cA=f getEncodedHex");
var o2 = new KJUR.asn1.x509.BasicConstraints({'cA':true});
equal(o2.getExtnValueHex(), "30030101ff", "constructor cA=t getExtnValueHex");
equal(o2.getEncodedHex(), "300c0603551d13040530030101ff", "constructor cA=t getEncodedHex");
var o3 = new KJUR.asn1.x509.BasicConstraints({'cA':true, 'pathLen': 7});
equal(o3.getExtnValueHex(), "30060101ff020107", "constructor cA=t pl=7 getExtnValueHex");
equal(o3.getEncodedHex(), "300f0603551d13040830060101ff020107", "constructor cA=t pl=7 getEncodedHex");
});
// KeyUsage
test("KeyUsage class test", function() {
var o;
o = new KJUR.asn1.x509.KeyUsage({'bin':'11'});
equal(o.getExtnValueHex(), "030206c0", "constructor bin 11 getExtnValueHex");
equal(o.getEncodedHex(), "300b0603551d0f0404030206c0", "constructor bin 11 getEncodedHex");
o = new KJUR.asn1.x509.KeyUsage({'bin':'11', 'critical': true});
equal(o.getEncodedHex(), "300e0603551d0f0101ff0404030206c0", "constructor bin 11 critical getEncodedHex");
o = new KJUR.asn1.x509.KeyUsage({'names': ['digitalSignature', 'nonRepudiation']});
equal(o.getEncodedHex(), "300b0603551d0f0404030206c0", "constructor names [digitalSignature, nonRepudiation]");
o = new KJUR.asn1.x509.KeyUsage({'bin':'000000011'});
equal(o.getEncodedHex(), "300c0603551d0f04050303070180", "constructor bin 000000011");
o = new KJUR.asn1.x509.KeyUsage({'names': ['encipherOnly', 'decipherOnly']});
equal(o.getEncodedHex(), "300c0603551d0f04050303070180", "constructor names [encipherOnly, decipherOnly]");
});
// CRLDP
test("CRLDistributionPoints class test", function() {
expect(2);
var gn1 = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var dpn1 = new KJUR.asn1.x509.DistributionPointName(gn1);
var dp1 = new KJUR.asn1.x509.DistributionPoint({'dpobj': dpn1});
var cdp1 = new KJUR.asn1.x509.CRLDistributionPoints({'array': [dp1]});
equal(cdp1.getEncodedHex(), "30200603551d1f041930173015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor array http://aaa.com/");
var cdp2 = new KJUR.asn1.x509.CRLDistributionPoints({'uri': 'http://aaa.com/'});
equal(cdp2.getEncodedHex(), "30200603551d1f041930173015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
// ExtKeyUsage
test("ExtKeyUsage class test", function() {
expect(1);
var eku1 =
new KJUR.asn1.x509.ExtKeyUsage({'array':
[{'oid': '2.5.29.37.0'}, // anyExtendedKeyUsage
{'name': 'clientAuth'}]});
equal(eku1.getEncodedHex(), "30190603551d25041230100604551d250006082b06010505070302", "constructor array");
});
// AuthorityKeyIdentifier
test("AuthorityKeyIdentifier class test (KID)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'}});
equal(o1.getExtnValueHex(), "3004800289ab", "kid value");
equal(o1.getEncodedHex(), "300d0603551d2304063004800289ab", "ext hex");
});
test("AuthorityKeyIdentifier class test (CertIssuer)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'issuer': {'str': '/C=US/CN=a'}});
equal(o1.getExtnValueHex(), "301ba119310b3009060355040613025553310a300806035504030c0161", "issuer name");
equal(o1.getEncodedHex(), "30240603551d23041d301ba119310b3009060355040613025553310a300806035504030c0161", "ext hex");
});
test("AuthorityKeyIdentifier class test (CertSN)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'sn': {'hex': '1234'}});
equal(o1.getExtnValueHex(), "300482021234", "cert SN");
equal(o1.getEncodedHex(), "300d0603551d230406300482021234", "ext hex");
});
test("AuthorityKeyIdentifier class test (All)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'},
'issuer': {'str': '/C=US/CN=a'},
'sn': {'hex': '1234'}});
equal(o1.getExtnValueHex(), "3023800289aba119310b3009060355040613025553310a300806035504030c016182021234", "all");
equal(o1.getEncodedHex(), "302c0603551d2304253023800289aba119310b3009060355040613025553310a300806035504030c016182021234", "ext hex");
});
test("AuthorityKeyIdentifier class test (KID critical)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'}, 'critical': true});
equal(o1.getExtnValueHex(), "3004800289ab", "kid critical");
equal(o1.getEncodedHex(), "30100603551d230101ff04063004800289ab", "ext hex");
});
test("SubjectAltName", function() {
var o1 = new KJUR.asn1.x509.SubjectAltName({
critical: true,
array: [{uri: 'http://a.com'}, {uri: 'http://b.com'}]
});
equal(o1.getExtnValueHex(), "301c860c687474703a2f2f612e636f6d860c687474703a2f2f622e636f6d", "URIs critical");
equal(o1.getEncodedHex(), "30280603551d110101ff041e301c860c687474703a2f2f612e636f6d860c687474703a2f2f622e636f6d", "ext hex");
});
test("IssuerAltName", function() {
var o1 = new KJUR.asn1.x509.IssuerAltName({
critical: true,
array: [{uri: 'http://a.com'}, {uri: 'http://b.com'}]
});
equal(o1.getExtnValueHex(), "301c860c687474703a2f2f612e636f6d860c687474703a2f2f622e636f6d", "URIs critical");
equal(o1.getEncodedHex(), "30280603551d120101ff041e301c860c687474703a2f2f612e636f6d860c687474703a2f2f622e636f6d", "ext hex");
});
// ==== END OF X.509V3 EXTENSION TEST ===================
test("CRL class test", function() {
expect(1);
// TBS
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
var prvKey = new RSAKey();
prvKey.readPKCS5PrvKeyHex("3082013a020100024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001024078bbc54c646795e9a623cb0f912c7f9f6861711560e57bade21ded2f7d9579f86272fab9e71ab27282c2760c404dae6ac8a3ab852cf6bcd562f9aff8247a264d022100fe9bd450866b3255614fde976a76ac0b1d5830dda64f5359b946d8512bc1239f022100e9ab680f5f05dbb0f4311b0e6f4368f4874a1238979d8bc600c35c6f20707c07022100d549cb698dc17d4fe30e5a84f3ade860033c1eeb7f67d286465c9fd817d45b3702201849b4bb44493b989d092da2c675df46eb790b83ce5e95d4b2e79b88017b2fa902207d261a96256d49b020cb1d587ecde127e093a4d2b34cdbff171f34125b5857a9");
var crl1 = new KJUR.asn1.x509.CRL({'tbsobj': o,'prvkeyobj': prvKey});
crl1.sign();
equal(crl1.getEncodedHex(), "30819c3048300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a300d06092a864886f70d0101050500034100161f6e8b3cbe992aa4eece8894516a65d530543c6f23e83860cc391ae8289504cbe91f118fd20e2b96966182f695f9dce27b3e76f7d84beeab293cc3c9649740", "crl sign");
});
test("TBSCertList class test", function() {
expect(1);
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
equal(o.getEncodedHex(), "3048300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a", "constructor");
});
test("TBSCertList 2 class test", function() {
expect(1);
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
o.addRevokedCert({'int': 4}, {'str':'130514235959Z'});
equal(o.getEncodedHex(), "305e300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a30143012020104170d3133303531343233353935395a", "constructor with revoked cert");
});
test("CRLEntry class test", function() {
expect(1);
var e = new KJUR.asn1.x509.CRLEntry({'time':{'str':'130514235959Z'}, 'sn':{'int':3}});
equal(e.getEncodedHex(), "3012020103170d3133303531343233353935395a", "constructor/1");
});
});
-->
</script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">test markup</div>
<a href="index.html">TEST INDEX</a> |
<a href="qunit-do-x509-hex2dn.html">x509-hex2dn</a> |
<a href="qunit-do-asn1x509.html">asn1x509</a> |
<a href="qunit-do-asn1x509-newcrt.html">asn1x509-newcrt</a> |
<a href="qunit-do-asn1x509-multirdn.html">asn1x509-multirdn</a> |
<a href="qunit-do-asn1csr.html">asn1csr</a> |
</body>
</html>