api-console-assets
Version:
This repo only exists to publish api console components to npm
392 lines • 230 kB
HTML
<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"> <style>
.KEYW {color: #933;}
.COMM {color: #bbb; font-style: italic;}
.NUMB {color: #393;}
.STRN {color: #393;}
.REGX {color: #339;}
.line {border-right: 1px dotted #666; color: #666; font-style: normal;}
</style></head><body><pre><span class='line'> 1</span> <span class="COMM">/* x509-1.1.20.js (c) 2012-2018 Kenji Urushima | kjur.github.io/jsrsasign/license
<span class='line'> 2</span> */</span><span class="WHIT">
<span class='line'> 3</span> </span><span class="COMM">/*
<span class='line'> 4</span> * x509.js - X509 class to read subject public key from certificate.
<span class='line'> 5</span> *
<span class='line'> 6</span> * Copyright (c) 2010-2018 Kenji Urushima (kenji.urushima@gmail.com)
<span class='line'> 7</span> *
<span class='line'> 8</span> * This software is licensed under the terms of the MIT License.
<span class='line'> 9</span> * https://kjur.github.io/jsrsasign/license
<span class='line'> 10</span> *
<span class='line'> 11</span> * The above copyright and license notice shall be
<span class='line'> 12</span> * included in all copies or substantial portions of the Software.
<span class='line'> 13</span> */</span><span class="WHIT">
<span class='line'> 14</span>
<span class='line'> 15</span> </span><span class="COMM">/**
<span class='line'> 16</span> * @fileOverview
<span class='line'> 17</span> * @name x509-1.1.js
<span class='line'> 18</span> * @author Kenji Urushima kenji.urushima@gmail.com
<span class='line'> 19</span> * @version jsrsasign 8.0.10 x509 1.1.20 (2018-Apr-09)
<span class='line'> 20</span> * @since jsrsasign 1.x.x
<span class='line'> 21</span> * @license <a href="https://kjur.github.io/jsrsasign/license/">MIT License</a>
<span class='line'> 22</span> */</span><span class="WHIT">
<span class='line'> 23</span>
<span class='line'> 24</span> </span><span class="COMM">/**
<span class='line'> 25</span> * hexadecimal X.509 certificate ASN.1 parser class.<br/>
<span class='line'> 26</span> * @class hexadecimal X.509 certificate ASN.1 parser class
<span class='line'> 27</span> * @property {String} hex hexacedimal string for X.509 certificate.
<span class='line'> 28</span> * @property {Number} version format version (1: X509v1, 3: X509v3, otherwise: unknown) since jsrsasign 7.1.4
<span class='line'> 29</span> * @author Kenji Urushima
<span class='line'> 30</span> * @version 1.0.1 (08 May 2012)
<span class='line'> 31</span> * @see <a href="https://kjur.github.io/jsrsasigns/">'jsrsasign'(RSA Sign JavaScript Library) home page https://kjur.github.io/jsrsasign/</a>
<span class='line'> 32</span> * @description
<span class='line'> 33</span> * X509 class provides following functionality:
<span class='line'> 34</span> * <ul>
<span class='line'> 35</span> * <li>parse X.509 certificate ASN.1 structure</li>
<span class='line'> 36</span> * <li>get basic fields, extensions, signature algorithms and signature values</li>
<span class='line'> 37</span> * <li>read PEM certificate</li>
<span class='line'> 38</span> * </ul>
<span class='line'> 39</span> *
<span class='line'> 40</span> * <ul>
<span class='line'> 41</span> * <li><b>TO GET FIELDS</b>
<span class='line'> 42</span> * <ul>
<span class='line'> 43</span> * <li>serial - {@link X509#getSerialNumberHex}</li>
<span class='line'> 44</span> * <li>signature algorithm field - {@link X509#getSignatureAlgorithmField}</li>
<span class='line'> 45</span> * <li>issuer - {@link X509#getIssuerHex}</li>
<span class='line'> 46</span> * <li>issuer - {@link X509#getIssuerString}</li>
<span class='line'> 47</span> * <li>notBefore - {@link X509#getNotBefore}</li>
<span class='line'> 48</span> * <li>notAfter - {@link X509#getNotAfter}</li>
<span class='line'> 49</span> * <li>subject - {@link X509#getSubjectHex}</li>
<span class='line'> 50</span> * <li>subject - {@link X509#getSubjectString}</li>
<span class='line'> 51</span> * <li>subjectPublicKeyInfo - {@link X509#getPublicKey}</li>
<span class='line'> 52</span> * <li>subjectPublicKeyInfo - {@link X509#getPublicKeyHex}</li>
<span class='line'> 53</span> * <li>subjectPublicKeyInfo - {@link X509#getPublicKeyIdx}</li>
<span class='line'> 54</span> * <li>subjectPublicKeyInfo - {@link X509.getPublicKeyFromCertPEM}</li>
<span class='line'> 55</span> * <li>subjectPublicKeyInfo - {@link X509.getPublicKeyFromCertHex}</li>
<span class='line'> 56</span> * <li>subjectPublicKeyInfo - {@link X509#getPublicKeyContentIdx}</li>
<span class='line'> 57</span> * <li>signature algorithm - {@link X509#getSignatureAlgorithmName}</li>
<span class='line'> 58</span> * <li>signature value - {@link X509#getSignatureValueHex}</li>
<span class='line'> 59</span> * </ul>
<span class='line'> 60</span> * </li>
<span class='line'> 61</span> * <li><b>X509 METHODS TO GET EXTENSIONS</b>
<span class='line'> 62</span> * <ul>
<span class='line'> 63</span> * <li>basicConstraints - {@link X509#getExtBasicConstraints}</li>
<span class='line'> 64</span> * <li>keyUsage - {@link X509#getExtKeyUsageBin}</li>
<span class='line'> 65</span> * <li>keyUsage - {@link X509#getExtKeyUsageString}</li>
<span class='line'> 66</span> * <li>subjectKeyIdentifier - {@link X509#getExtSubjectKeyIdentifier}</li>
<span class='line'> 67</span> * <li>authorityKeyIdentifier - {@link X509#getExtAuthorityKeyIdentifier}</li>
<span class='line'> 68</span> * <li>extKeyUsage - {@link X509#getExtExtKeyUsageName}</li>
<span class='line'> 69</span> * <li>subjectAltName(DEPRECATED) - {@link X509#getExtSubjectAltName}</li>
<span class='line'> 70</span> * <li>subjectAltName2 - {@link X509#getExtSubjectAltName2}</li>
<span class='line'> 71</span> * <li>cRLDistributionPoints - {@link X509#getExtCRLDistributionPointsURI}</li>
<span class='line'> 72</span> * <li>authorityInfoAccess - {@link X509#getExtAIAInfo}</li>
<span class='line'> 73</span> * <li>certificatePolicies - {@link X509#getExtCertificatePolicies}</li>
<span class='line'> 74</span> * </ul>
<span class='line'> 75</span> * </li>
<span class='line'> 76</span> * <li><b>UTILITIES</b>
<span class='line'> 77</span> * <ul>
<span class='line'> 78</span> * <li>reading PEM X.509 certificate - {@link X509#readCertPEM}</li>
<span class='line'> 79</span> * <li>reading hexadecimal string of X.509 certificate - {@link X509#readCertHex}</li>
<span class='line'> 80</span> * <li>get all certificate information - {@link X509#getInfo}</li>
<span class='line'> 81</span> * <li>get specified extension information - {@link X509#getExtInfo}</li>
<span class='line'> 82</span> * <li>verify signature value - {@link X509#verifySignature}</li>
<span class='line'> 83</span> * </ul>
<span class='line'> 84</span> * </li>
<span class='line'> 85</span> * </ul>
<span class='line'> 86</span> */</span><span class="WHIT">
<span class='line'> 87</span> </span><span class="KEYW">function</span><span class="WHIT"> </span><span class="NAME">X509</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'> 88</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">ASN1HEX</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 89</span> </span><span class="WHIT"> </span><span class="NAME">_getChildIdx</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getChildIdx</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 90</span> </span><span class="WHIT"> </span><span class="NAME">_getV</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getV</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 91</span> </span><span class="WHIT"> </span><span class="NAME">_getTLV</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getTLV</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 92</span> </span><span class="WHIT"> </span><span class="NAME">_getVbyList</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getVbyList</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 93</span> </span><span class="WHIT"> </span><span class="NAME">_getTLVbyList</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getTLVbyList</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 94</span> </span><span class="WHIT"> </span><span class="NAME">_getIdxbyList</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getIdxbyList</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 95</span> </span><span class="WHIT"> </span><span class="NAME">_getVidx</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getVidx</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 96</span> </span><span class="WHIT"> </span><span class="NAME">_oidname</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.oidname</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 97</span> </span><span class="WHIT"> </span><span class="NAME">_X509</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">X509</span><span class="PUNC">,</span><span class="WHIT">
<span class='line'> 98</span> </span><span class="WHIT"> </span><span class="NAME">_pemtohex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">pemtohex</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'> 99</span>
<span class='line'>100</span> </span><span class="WHIT"> </span><span class="NAME">this.hex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">null</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>101</span> </span><span class="WHIT"> </span><span class="NAME">this.version</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">;</span><span class="WHIT"> </span><span class="COMM">// version (1: X509v1, 3: X509v3, others: unspecified)</span><span class="WHIT">
<span class='line'>102</span> </span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">;</span><span class="WHIT"> </span><span class="COMM">// field index offset (-1: for X509v1, 0: for X509v3)</span><span class="WHIT">
<span class='line'>103</span> </span><span class="WHIT"> </span><span class="NAME">this.aExtInfo</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">null</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>104</span>
<span class='line'>105</span> </span><span class="WHIT"> </span><span class="COMM">// ===== get basic fields from hex =====================================</span><span class="WHIT">
<span class='line'>106</span>
<span class='line'>107</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>108</span> * get format version (X.509v1 or v3 certificate)<br/>
<span class='line'>109</span> * @name getVersion
<span class='line'>110</span> * @memberOf X509#
<span class='line'>111</span> * @function
<span class='line'>112</span> * @return {Number} 1 for X509v1, 3 for X509v3, otherwise 0
<span class='line'>113</span> * @since jsrsasign 7.1.14 x509 1.1.13
<span class='line'>114</span> * @description
<span class='line'>115</span> * This method returns a format version of X.509 certificate.
<span class='line'>116</span> * It returns 1 for X.509v1 certificate and 3 for v3 certificate.
<span class='line'>117</span> * Otherwise returns 0.
<span class='line'>118</span> * This method will be automatically called in
<span class='line'>119</span> * {@link X509#readCertPEM}. After then, you can use
<span class='line'>120</span> * {@link X509.version} parameter.
<span class='line'>121</span> * @example
<span class='line'>122</span> * var x = new X509();
<span class='line'>123</span> * x.readCertPEM(sCertPEM);
<span class='line'>124</span> * version = x.getVersion(); // 1 or 3
<span class='line'>125</span> * sn = x.getSerialNumberHex(); // return string like "01ad..."
<span class='line'>126</span> */</span><span class="WHIT">
<span class='line'>127</span> </span><span class="WHIT"> </span><span class="NAME">this.getVersion</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>128</span> </span><span class="WHIT"> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="WHIT"> </span><span class="PUNC">===</span><span class="WHIT"> </span><span class="KEYW">null</span><span class="WHIT"> </span><span class="PUNC">||</span><span class="WHIT"> </span><span class="NAME">this.version</span><span class="WHIT"> </span><span class="PUNC">!==</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">this.version</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>129</span>
<span class='line'>130</span> </span><span class="WHIT"> </span><span class="COMM">// check if the first item of tbsCertificate "[0] { INTEGER 2 }"</span><span class="WHIT">
<span class='line'>131</span> </span><span class="WHIT"> </span><span class="KEYW">if</span><span class="WHIT"> </span><span class="PUNC">(</span><span class="NAME">_getTLVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">]</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">!==</span><span class="WHIT">
<span class='line'>132</span> </span><span class="WHIT"> </span><span class="STRN">"a003020102"</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>133</span> </span><span class="WHIT"> </span><span class="NAME">this.version</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">1</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>134</span> </span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="PUNC">-</span><span class="NUMB">1</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>135</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NUMB">1</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>136</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="WHIT">
<span class='line'>137</span>
<span class='line'>138</span> </span><span class="WHIT"> </span><span class="NAME">this.version</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NUMB">3</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>139</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NUMB">3</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>140</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>141</span>
<span class='line'>142</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>143</span> * get hexadecimal string of serialNumber field of certificate.<br/>
<span class='line'>144</span> * @name getSerialNumberHex
<span class='line'>145</span> * @memberOf X509#
<span class='line'>146</span> * @function
<span class='line'>147</span> * @return {String} hexadecimal string of certificate serial number
<span class='line'>148</span> * @example
<span class='line'>149</span> * var x = new X509();
<span class='line'>150</span> * x.readCertPEM(sCertPEM);
<span class='line'>151</span> * var sn = x.getSerialNumberHex(); // return string like "01ad..."
<span class='line'>152</span> */</span><span class="WHIT">
<span class='line'>153</span> </span><span class="WHIT"> </span><span class="NAME">this.getSerialNumberHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>154</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">1</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"02"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>155</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>156</span>
<span class='line'>157</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>158</span> * get signature algorithm name in basic field
<span class='line'>159</span> * @name getSignatureAlgorithmField
<span class='line'>160</span> * @memberOf X509#
<span class='line'>161</span> * @function
<span class='line'>162</span> * @return {String} signature algorithm name (ex. SHA1withRSA, SHA256withECDSA)
<span class='line'>163</span> * @since x509 1.1.8
<span class='line'>164</span> * @description
<span class='line'>165</span> * This method will get a name of signature algorithm field of certificate:
<span class='line'>166</span> * @example
<span class='line'>167</span> * var x = new X509();
<span class='line'>168</span> * x.readCertPEM(sCertPEM);
<span class='line'>169</span> * algName = x.getSignatureAlgorithmField();
<span class='line'>170</span> */</span><span class="WHIT">
<span class='line'>171</span> </span><span class="WHIT"> </span><span class="NAME">this.getSignatureAlgorithmField</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>172</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_oidname</span><span class="PUNC">(</span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">2</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"06"</span><span class="PUNC">)</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>173</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>174</span>
<span class='line'>175</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>176</span> * get hexadecimal string of issuer field TLV of certificate.<br/>
<span class='line'>177</span> * @name getIssuerHex
<span class='line'>178</span> * @memberOf X509#
<span class='line'>179</span> * @function
<span class='line'>180</span> * @return {String} hexadecial string of issuer DN ASN.1
<span class='line'>181</span> * @example
<span class='line'>182</span> * var x = new X509();
<span class='line'>183</span> * x.readCertPEM(sCertPEM);
<span class='line'>184</span> * var issuer = x.getIssuerHex(); // return string like "3013..."
<span class='line'>185</span> */</span><span class="WHIT">
<span class='line'>186</span> </span><span class="WHIT"> </span><span class="NAME">this.getIssuerHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>187</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getTLVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">3</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"30"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>188</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>189</span>
<span class='line'>190</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>191</span> * get string of issuer field of certificate.<br/>
<span class='line'>192</span> * @name getIssuerString
<span class='line'>193</span> * @memberOf X509#
<span class='line'>194</span> * @function
<span class='line'>195</span> * @return {String} issuer DN string
<span class='line'>196</span> * @example
<span class='line'>197</span> * var x = new X509();
<span class='line'>198</span> * x.readCertPEM(sCertPEM);
<span class='line'>199</span> * var issuer = x.getIssuerString(); // return string like "/C=US/O=TEST"
<span class='line'>200</span> */</span><span class="WHIT">
<span class='line'>201</span> </span><span class="WHIT"> </span><span class="NAME">this.getIssuerString</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>202</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_X509.hex2dn</span><span class="PUNC">(</span><span class="NAME">this.getIssuerHex</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>203</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>204</span>
<span class='line'>205</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>206</span> * get hexadecimal string of subject field of certificate.<br/>
<span class='line'>207</span> * @name getSubjectHex
<span class='line'>208</span> * @memberOf X509#
<span class='line'>209</span> * @function
<span class='line'>210</span> * @return {String} hexadecial string of subject DN ASN.1
<span class='line'>211</span> * @example
<span class='line'>212</span> * var x = new X509();
<span class='line'>213</span> * x.readCertPEM(sCertPEM);
<span class='line'>214</span> * var subject = x.getSubjectHex(); // return string like "3013..."
<span class='line'>215</span> */</span><span class="WHIT">
<span class='line'>216</span> </span><span class="WHIT"> </span><span class="NAME">this.getSubjectHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>217</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getTLVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">5</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"30"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>218</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>219</span>
<span class='line'>220</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>221</span> * get string of subject field of certificate.<br/>
<span class='line'>222</span> * @name getSubjectString
<span class='line'>223</span> * @memberOf X509#
<span class='line'>224</span> * @function
<span class='line'>225</span> * @return {String} subject DN string
<span class='line'>226</span> * @example
<span class='line'>227</span> * var x = new X509();
<span class='line'>228</span> * x.readCertPEM(sCertPEM);
<span class='line'>229</span> * var subject = x.getSubjectString(); // return string like "/C=US/O=TEST"
<span class='line'>230</span> */</span><span class="WHIT">
<span class='line'>231</span> </span><span class="WHIT"> </span><span class="NAME">this.getSubjectString</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>232</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_X509.hex2dn</span><span class="PUNC">(</span><span class="NAME">this.getSubjectHex</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>233</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>234</span>
<span class='line'>235</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>236</span> * get notBefore field string of certificate.<br/>
<span class='line'>237</span> * @name getNotBefore
<span class='line'>238</span> * @memberOf X509#
<span class='line'>239</span> * @function
<span class='line'>240</span> * @return {String} not before time value (ex. "151231235959Z")
<span class='line'>241</span> * @example
<span class='line'>242</span> * var x = new X509();
<span class='line'>243</span> * x.readCertPEM(sCertPEM);
<span class='line'>244</span> * var notBefore = x.getNotBefore(); // return string like "151231235959Z"
<span class='line'>245</span> */</span><span class="WHIT">
<span class='line'>246</span> </span><span class="WHIT"> </span><span class="NAME">this.getNotBefore</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>247</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">4</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">]</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>248</span> </span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">s.replace</span><span class="PUNC">(</span><span class="REGX">/(..)/g</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"%$1"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>249</span> </span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">decodeURIComponent</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>250</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">s</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>251</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>252</span>
<span class='line'>253</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>254</span> * get notAfter field string of certificate.<br/>
<span class='line'>255</span> * @name getNotAfter
<span class='line'>256</span> * @memberOf X509#
<span class='line'>257</span> * @function
<span class='line'>258</span> * @return {String} not after time value (ex. "151231235959Z")
<span class='line'>259</span> * @example
<span class='line'>260</span> * var x = new X509();
<span class='line'>261</span> * x.readCertPEM(sCertPEM);
<span class='line'>262</span> * var notAfter = x.getNotAfter(); // return string like "151231235959Z"
<span class='line'>263</span> */</span><span class="WHIT">
<span class='line'>264</span> </span><span class="WHIT"> </span><span class="NAME">this.getNotAfter</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>265</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">4</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">1</span><span class="PUNC">]</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>266</span> </span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">s.replace</span><span class="PUNC">(</span><span class="REGX">/(..)/g</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"%$1"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>267</span> </span><span class="WHIT"> </span><span class="NAME">s</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">decodeURIComponent</span><span class="PUNC">(</span><span class="NAME">s</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>268</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">s</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>269</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>270</span>
<span class='line'>271</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>272</span> * get a hexadecimal string of subjectPublicKeyInfo field.<br/>
<span class='line'>273</span> * @name getPublicKeyHex
<span class='line'>274</span> * @memberOf X509#
<span class='line'>275</span> * @function
<span class='line'>276</span> * @return {String} ASN.1 SEQUENCE hexadecimal string of subjectPublicKeyInfo field
<span class='line'>277</span> * @since jsrsasign 7.1.4 x509 1.1.13
<span class='line'>278</span> * @example
<span class='line'>279</span> * x = new X509();
<span class='line'>280</span> * x.readCertPEM(sCertPEM);
<span class='line'>281</span> * hSPKI = x.getPublicKeyHex(); // return string like "30820122..."
<span class='line'>282</span> */</span><span class="WHIT">
<span class='line'>283</span> </span><span class="WHIT"> </span><span class="NAME">this.getPublicKeyHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>284</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_ASN1HEX.getTLVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">6</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"30"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>285</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>286</span>
<span class='line'>287</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>288</span> * get a string index of subjectPublicKeyInfo field for hexadecimal string certificate.<br/>
<span class='line'>289</span> * @name getPublicKeyIdx
<span class='line'>290</span> * @memberOf X509#
<span class='line'>291</span> * @function
<span class='line'>292</span> * @return {Number} string index of subjectPublicKeyInfo field for hexadecimal string certificate.
<span class='line'>293</span> * @since jsrsasign 7.1.4 x509 1.1.13
<span class='line'>294</span> * @example
<span class='line'>295</span> * x = new X509();
<span class='line'>296</span> * x.readCertPEM(sCertPEM);
<span class='line'>297</span> * idx = x.getPublicKeyIdx(); // return string index in x.hex parameter
<span class='line'>298</span> */</span><span class="WHIT">
<span class='line'>299</span> </span><span class="WHIT"> </span><span class="NAME">this.getPublicKeyIdx</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>300</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getIdxbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">6</span><span class="WHIT"> </span><span class="PUNC">+</span><span class="WHIT"> </span><span class="NAME">this.foffset</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"30"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>301</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>302</span>
<span class='line'>303</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>304</span> * get a string index of contents of subjectPublicKeyInfo BITSTRING value from hexadecimal certificate<br/>
<span class='line'>305</span> * @name getPublicKeyContentIdx
<span class='line'>306</span> * @memberOf X509#
<span class='line'>307</span> * @function
<span class='line'>308</span> * @return {Integer} string index of key contents
<span class='line'>309</span> * @since jsrsasign 8.0.0 x509 1.2.0
<span class='line'>310</span> * @example
<span class='line'>311</span> * x = new X509();
<span class='line'>312</span> * x.readCertPEM(sCertPEM);
<span class='line'>313</span> * idx = x.getPublicKeyContentIdx(); // return string index in x.hex parameter
<span class='line'>314</span> */</span><span class="WHIT">
<span class='line'>315</span> </span><span class="WHIT"> </span><span class="COMM">// NOTE: Without BITSTRING encapsulation.</span><span class="WHIT">
<span class='line'>316</span> </span><span class="WHIT"> </span><span class="NAME">this.getPublicKeyContentIdx</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>317</span> </span><span class="WHIT"> </span><span class="KEYW">var</span><span class="WHIT"> </span><span class="NAME">idx</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="NAME">this.getPublicKeyIdx</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>318</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getIdxbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NAME">idx</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">1</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"30"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>319</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>320</span>
<span class='line'>321</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>322</span> * get a RSAKey/ECDSA/DSA public key object of subjectPublicKeyInfo field.<br/>
<span class='line'>323</span> * @name getPublicKey
<span class='line'>324</span> * @memberOf X509#
<span class='line'>325</span> * @function
<span class='line'>326</span> * @return {Object} RSAKey/ECDSA/DSA public key object of subjectPublicKeyInfo field
<span class='line'>327</span> * @since jsrsasign 7.1.4 x509 1.1.13
<span class='line'>328</span> * @example
<span class='line'>329</span> * x = new X509();
<span class='line'>330</span> * x.readCertPEM(sCertPEM);
<span class='line'>331</span> * pubkey= x.getPublicKey();
<span class='line'>332</span> */</span><span class="WHIT">
<span class='line'>333</span> </span><span class="WHIT"> </span><span class="NAME">this.getPublicKey</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>334</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">KEYUTIL.getKey</span><span class="PUNC">(</span><span class="NAME">this.getPublicKeyHex</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="KEYW">null</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"pkcs8pub"</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>335</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>336</span>
<span class='line'>337</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>338</span> * get signature algorithm name from hexadecimal certificate data
<span class='line'>339</span> * @name getSignatureAlgorithmName
<span class='line'>340</span> * @memberOf X509#
<span class='line'>341</span> * @function
<span class='line'>342</span> * @param {String} hCert hexadecimal string of X.509 certificate binary
<span class='line'>343</span> * @return {String} signature algorithm name (ex. SHA1withRSA, SHA256withECDSA)
<span class='line'>344</span> * @since jsrsasign 7.2.0 x509 1.1.14
<span class='line'>345</span> * @description
<span class='line'>346</span> * This method will get signature algorithm name of certificate:
<span class='line'>347</span> * @example
<span class='line'>348</span> * var x = new X509();
<span class='line'>349</span> * x.readCertPEM(sCertPEM);
<span class='line'>350</span> * x.getSignatureAlgorithmName() → "SHA256withRSA"
<span class='line'>351</span> */</span><span class="WHIT">
<span class='line'>352</span> </span><span class="WHIT"> </span><span class="NAME">this.getSignatureAlgorithmName</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>353</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_oidname</span><span class="PUNC">(</span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">1</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"06"</span><span class="PUNC">)</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>354</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>355</span>
<span class='line'>356</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>357</span> * get signature value in hexadecimal string<br/>
<span class='line'>358</span> * @name getSignatureValueHex
<span class='line'>359</span> * @memberOf X509#
<span class='line'>360</span> * @function
<span class='line'>361</span> * @return {String} signature value hexadecimal string without BitString unused bits
<span class='line'>362</span> * @since jsrsasign 7.2.0 x509 1.1.14
<span class='line'>363</span> * @description
<span class='line'>364</span> * This method will get signature value of certificate:
<span class='line'>365</span> * @example
<span class='line'>366</span> * var x = new X509();
<span class='line'>367</span> * x.readCertPEM(sCertPEM);
<span class='line'>368</span> * x.getSignatureValueHex() &rarr "8a4c47913..."
<span class='line'>369</span> */</span><span class="WHIT">
<span class='line'>370</span> </span><span class="WHIT"> </span><span class="NAME">this.getSignatureValueHex</span><span class="WHIT"> </span><span class="PUNC">=</span><span class="WHIT"> </span><span class="KEYW">function</span><span class="PUNC">(</span><span class="PUNC">)</span><span class="WHIT"> </span><span class="PUNC">{</span><span class="WHIT">
<span class='line'>371</span> </span><span class="WHIT"> </span><span class="KEYW">return</span><span class="WHIT"> </span><span class="NAME">_getVbyList</span><span class="PUNC">(</span><span class="NAME">this.hex</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="NUMB">0</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="PUNC">[</span><span class="NUMB">2</span><span class="PUNC">]</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="STRN">"03"</span><span class="PUNC">,</span><span class="WHIT"> </span><span class="KEYW">true</span><span class="PUNC">)</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>372</span> </span><span class="WHIT"> </span><span class="PUNC">}</span><span class="PUNC">;</span><span class="WHIT">
<span class='line'>373</span>
<span class='line'>374</span> </span><span class="WHIT"> </span><span class="COMM">/**
<span class='line'>375</span> * verifies signature value by public key<br/>
<span class='line'>376</span> * @name verifySignature
<span class='line'>377</span> * @memberOf X509#
<span class='line'>378</span> * @function
<span class='line'>379</span> * @param {Object} pubKey public key object
<span class='line'>380</span> * @return {Boolean} true if signature value is valid otherwise false
<span class='line'>381</span> * @since jsrsasign 7.2.0 x509 1.1.14
<span class='line'>382</span> * @description
<span class='line'>383</span> * This method verifies signature value of hexadecimal string of
<span class='line'>384</span> * X.509 certificate by specified public key object.
<span class='line'>385</span> *