node-forge 0.6.47 → 0.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/CHANGELOG.md +106 -0
  2. package/LICENSE +3 -3
  3. package/README.md +254 -175
  4. package/dist/forge.all.min.js +11 -0
  5. package/dist/forge.all.min.js.map +1 -0
  6. package/dist/forge.min.js +10 -0
  7. package/dist/forge.min.js.map +1 -0
  8. package/dist/prime.worker.min.js +2 -0
  9. package/dist/prime.worker.min.js.map +1 -0
  10. package/flash/README.md +48 -0
  11. package/flash/package.json +28 -0
  12. package/flash/swf/SocketPool.swf +0 -0
  13. package/{js → lib}/aes.js +5 -61
  14. package/{js → lib}/aesCipherSuites.js +4 -58
  15. package/{js → lib}/asn1.js +371 -132
  16. package/{js → lib}/cipher.js +3 -59
  17. package/{js → lib}/cipherModes.js +3 -65
  18. package/{js → lib}/debug.js +2 -58
  19. package/{js → lib}/des.js +6 -63
  20. package/lib/forge.js +13 -0
  21. package/{js → lib}/form.js +5 -13
  22. package/{js → lib}/hmac.js +4 -58
  23. package/{js → lib}/http.js +15 -20
  24. package/lib/index.all.js +16 -0
  25. package/lib/index.js +34 -0
  26. package/{js → lib}/jsbn.js +3 -60
  27. package/{js → lib}/kem.js +5 -58
  28. package/{js → lib}/log.js +3 -58
  29. package/lib/md.all.js +13 -0
  30. package/lib/md.js +11 -0
  31. package/{js → lib}/md5.js +4 -60
  32. package/lib/mgf.js +12 -0
  33. package/lib/mgf1.js +57 -0
  34. package/lib/oids.js +159 -0
  35. package/{js → lib}/pbe.js +29 -79
  36. package/{js → lib}/pbkdf2.js +10 -64
  37. package/{js → lib}/pem.js +3 -58
  38. package/{js → lib}/pkcs1.js +6 -59
  39. package/{js → lib}/pkcs12.js +15 -74
  40. package/{js → lib}/pkcs7.js +12 -72
  41. package/{js → lib}/pkcs7asn1.js +4 -58
  42. package/{js → lib}/pki.js +12 -71
  43. package/{js → lib}/prime.js +18 -58
  44. package/{js → lib}/prime.worker.js +4 -1
  45. package/{js → lib}/prng.js +5 -62
  46. package/{js → lib}/pss.js +7 -61
  47. package/{js → lib}/random.js +11 -57
  48. package/{js → lib}/rc2.js +13 -73
  49. package/{js → lib}/rsa.js +13 -71
  50. package/{js → lib}/sha1.js +4 -60
  51. package/{js → lib}/sha256.js +4 -60
  52. package/{js → lib}/sha512.js +19 -61
  53. package/{js → lib}/socket.js +8 -63
  54. package/{js → lib}/ssh.js +7 -66
  55. package/{js → lib}/task.js +5 -58
  56. package/{js → lib}/tls.js +10 -67
  57. package/{js → lib}/tlssocket.js +6 -61
  58. package/{js → lib}/util.js +39 -68
  59. package/{js → lib}/x509.js +25 -102
  60. package/{js → lib}/xhr.js +12 -15
  61. package/package.json +58 -21
  62. package/js/forge.js +0 -94
  63. package/js/md.js +0 -75
  64. package/js/mgf.js +0 -67
  65. package/js/mgf1.js +0 -112
  66. package/js/oids.js +0 -288
  67. package/swf/SocketPool.swf +0 -0
package/js/oids.js DELETED
@@ -1,288 +0,0 @@
1
- /**
2
- * Object IDs for ASN.1.
3
- *
4
- * @author Dave Longley
5
- *
6
- * Copyright (c) 2010-2013 Digital Bazaar, Inc.
7
- */
8
- (function() {
9
- /* ########## Begin module implementation ########## */
10
- function initModule(forge) {
11
-
12
- forge.pki = forge.pki || {};
13
- var oids = forge.pki.oids = forge.oids = forge.oids || {};
14
-
15
- // algorithm OIDs
16
- oids['1.2.840.113549.1.1.1'] = 'rsaEncryption';
17
- oids['rsaEncryption'] = '1.2.840.113549.1.1.1';
18
- // Note: md2 & md4 not implemented
19
- //oids['1.2.840.113549.1.1.2'] = 'md2WithRSAEncryption';
20
- //oids['md2WithRSAEncryption'] = '1.2.840.113549.1.1.2';
21
- //oids['1.2.840.113549.1.1.3'] = 'md4WithRSAEncryption';
22
- //oids['md4WithRSAEncryption'] = '1.2.840.113549.1.1.3';
23
- oids['1.2.840.113549.1.1.4'] = 'md5WithRSAEncryption';
24
- oids['md5WithRSAEncryption'] = '1.2.840.113549.1.1.4';
25
- oids['1.2.840.113549.1.1.5'] = 'sha1WithRSAEncryption';
26
- oids['sha1WithRSAEncryption'] = '1.2.840.113549.1.1.5';
27
- oids['1.2.840.113549.1.1.7'] = 'RSAES-OAEP';
28
- oids['RSAES-OAEP'] = '1.2.840.113549.1.1.7';
29
- oids['1.2.840.113549.1.1.8'] = 'mgf1';
30
- oids['mgf1'] = '1.2.840.113549.1.1.8';
31
- oids['1.2.840.113549.1.1.9'] = 'pSpecified';
32
- oids['pSpecified'] = '1.2.840.113549.1.1.9';
33
- oids['1.2.840.113549.1.1.10'] = 'RSASSA-PSS';
34
- oids['RSASSA-PSS'] = '1.2.840.113549.1.1.10';
35
- oids['1.2.840.113549.1.1.11'] = 'sha256WithRSAEncryption';
36
- oids['sha256WithRSAEncryption'] = '1.2.840.113549.1.1.11';
37
- oids['1.2.840.113549.1.1.12'] = 'sha384WithRSAEncryption';
38
- oids['sha384WithRSAEncryption'] = '1.2.840.113549.1.1.12';
39
- oids['1.2.840.113549.1.1.13'] = 'sha512WithRSAEncryption';
40
- oids['sha512WithRSAEncryption'] = '1.2.840.113549.1.1.13';
41
-
42
- oids['1.3.14.3.2.7'] = 'desCBC';
43
- oids['desCBC'] = '1.3.14.3.2.7';
44
-
45
- oids['1.3.14.3.2.26'] = 'sha1';
46
- oids['sha1'] = '1.3.14.3.2.26';
47
- oids['2.16.840.1.101.3.4.2.1'] = 'sha256';
48
- oids['sha256'] = '2.16.840.1.101.3.4.2.1';
49
- oids['2.16.840.1.101.3.4.2.2'] = 'sha384';
50
- oids['sha384'] = '2.16.840.1.101.3.4.2.2';
51
- oids['2.16.840.1.101.3.4.2.3'] = 'sha512';
52
- oids['sha512'] = '2.16.840.1.101.3.4.2.3';
53
- oids['1.2.840.113549.2.5'] = 'md5';
54
- oids['md5'] = '1.2.840.113549.2.5';
55
-
56
- // pkcs#7 content types
57
- oids['1.2.840.113549.1.7.1'] = 'data';
58
- oids['data'] = '1.2.840.113549.1.7.1';
59
- oids['1.2.840.113549.1.7.2'] = 'signedData';
60
- oids['signedData'] = '1.2.840.113549.1.7.2';
61
- oids['1.2.840.113549.1.7.3'] = 'envelopedData';
62
- oids['envelopedData'] = '1.2.840.113549.1.7.3';
63
- oids['1.2.840.113549.1.7.4'] = 'signedAndEnvelopedData';
64
- oids['signedAndEnvelopedData'] = '1.2.840.113549.1.7.4';
65
- oids['1.2.840.113549.1.7.5'] = 'digestedData';
66
- oids['digestedData'] = '1.2.840.113549.1.7.5';
67
- oids['1.2.840.113549.1.7.6'] = 'encryptedData';
68
- oids['encryptedData'] = '1.2.840.113549.1.7.6';
69
-
70
- // pkcs#9 oids
71
- oids['1.2.840.113549.1.9.1'] = 'emailAddress';
72
- oids['emailAddress'] = '1.2.840.113549.1.9.1';
73
- oids['1.2.840.113549.1.9.2'] = 'unstructuredName';
74
- oids['unstructuredName'] = '1.2.840.113549.1.9.2';
75
- oids['1.2.840.113549.1.9.3'] = 'contentType';
76
- oids['contentType'] = '1.2.840.113549.1.9.3';
77
- oids['1.2.840.113549.1.9.4'] = 'messageDigest';
78
- oids['messageDigest'] = '1.2.840.113549.1.9.4';
79
- oids['1.2.840.113549.1.9.5'] = 'signingTime';
80
- oids['signingTime'] = '1.2.840.113549.1.9.5';
81
- oids['1.2.840.113549.1.9.6'] = 'counterSignature';
82
- oids['counterSignature'] = '1.2.840.113549.1.9.6';
83
- oids['1.2.840.113549.1.9.7'] = 'challengePassword';
84
- oids['challengePassword'] = '1.2.840.113549.1.9.7';
85
- oids['1.2.840.113549.1.9.8'] = 'unstructuredAddress';
86
- oids['unstructuredAddress'] = '1.2.840.113549.1.9.8';
87
- oids['1.2.840.113549.1.9.14'] = 'extensionRequest';
88
- oids['extensionRequest'] = '1.2.840.113549.1.9.14';
89
-
90
- oids['1.2.840.113549.1.9.20'] = 'friendlyName';
91
- oids['friendlyName'] = '1.2.840.113549.1.9.20';
92
- oids['1.2.840.113549.1.9.21'] = 'localKeyId';
93
- oids['localKeyId'] = '1.2.840.113549.1.9.21';
94
- oids['1.2.840.113549.1.9.22.1'] = 'x509Certificate';
95
- oids['x509Certificate'] = '1.2.840.113549.1.9.22.1';
96
-
97
- // pkcs#12 safe bags
98
- oids['1.2.840.113549.1.12.10.1.1'] = 'keyBag';
99
- oids['keyBag'] = '1.2.840.113549.1.12.10.1.1';
100
- oids['1.2.840.113549.1.12.10.1.2'] = 'pkcs8ShroudedKeyBag';
101
- oids['pkcs8ShroudedKeyBag'] = '1.2.840.113549.1.12.10.1.2';
102
- oids['1.2.840.113549.1.12.10.1.3'] = 'certBag';
103
- oids['certBag'] = '1.2.840.113549.1.12.10.1.3';
104
- oids['1.2.840.113549.1.12.10.1.4'] = 'crlBag';
105
- oids['crlBag'] = '1.2.840.113549.1.12.10.1.4';
106
- oids['1.2.840.113549.1.12.10.1.5'] = 'secretBag';
107
- oids['secretBag'] = '1.2.840.113549.1.12.10.1.5';
108
- oids['1.2.840.113549.1.12.10.1.6'] = 'safeContentsBag';
109
- oids['safeContentsBag'] = '1.2.840.113549.1.12.10.1.6';
110
-
111
- // password-based-encryption for pkcs#12
112
- oids['1.2.840.113549.1.5.13'] = 'pkcs5PBES2';
113
- oids['pkcs5PBES2'] = '1.2.840.113549.1.5.13';
114
- oids['1.2.840.113549.1.5.12'] = 'pkcs5PBKDF2';
115
- oids['pkcs5PBKDF2'] = '1.2.840.113549.1.5.12';
116
-
117
- oids['1.2.840.113549.1.12.1.1'] = 'pbeWithSHAAnd128BitRC4';
118
- oids['pbeWithSHAAnd128BitRC4'] = '1.2.840.113549.1.12.1.1';
119
- oids['1.2.840.113549.1.12.1.2'] = 'pbeWithSHAAnd40BitRC4';
120
- oids['pbeWithSHAAnd40BitRC4'] = '1.2.840.113549.1.12.1.2';
121
- oids['1.2.840.113549.1.12.1.3'] = 'pbeWithSHAAnd3-KeyTripleDES-CBC';
122
- oids['pbeWithSHAAnd3-KeyTripleDES-CBC'] = '1.2.840.113549.1.12.1.3';
123
- oids['1.2.840.113549.1.12.1.4'] = 'pbeWithSHAAnd2-KeyTripleDES-CBC';
124
- oids['pbeWithSHAAnd2-KeyTripleDES-CBC'] = '1.2.840.113549.1.12.1.4';
125
- oids['1.2.840.113549.1.12.1.5'] = 'pbeWithSHAAnd128BitRC2-CBC';
126
- oids['pbeWithSHAAnd128BitRC2-CBC'] = '1.2.840.113549.1.12.1.5';
127
- oids['1.2.840.113549.1.12.1.6'] = 'pbewithSHAAnd40BitRC2-CBC';
128
- oids['pbewithSHAAnd40BitRC2-CBC'] = '1.2.840.113549.1.12.1.6';
129
-
130
- // hmac OIDs
131
- oids['1.2.840.113549.2.7'] = 'hmacWithSHA1';
132
- oids['hmacWithSHA1'] = '1.2.840.113549.2.7';
133
- oids['1.2.840.113549.2.8'] = 'hmacWithSHA224';
134
- oids['hmacWithSHA224'] = '1.2.840.113549.2.8';
135
- oids['1.2.840.113549.2.9'] = 'hmacWithSHA256';
136
- oids['hmacWithSHA256'] = '1.2.840.113549.2.9';
137
- oids['1.2.840.113549.2.10'] = 'hmacWithSHA384';
138
- oids['hmacWithSHA384'] = '1.2.840.113549.2.10';
139
- oids['1.2.840.113549.2.11'] = 'hmacWithSHA512';
140
- oids['hmacWithSHA512'] = '1.2.840.113549.2.11';
141
-
142
- // symmetric key algorithm oids
143
- oids['1.2.840.113549.3.7'] = 'des-EDE3-CBC';
144
- oids['des-EDE3-CBC'] = '1.2.840.113549.3.7';
145
- oids['2.16.840.1.101.3.4.1.2'] = 'aes128-CBC';
146
- oids['aes128-CBC'] = '2.16.840.1.101.3.4.1.2';
147
- oids['2.16.840.1.101.3.4.1.22'] = 'aes192-CBC';
148
- oids['aes192-CBC'] = '2.16.840.1.101.3.4.1.22';
149
- oids['2.16.840.1.101.3.4.1.42'] = 'aes256-CBC';
150
- oids['aes256-CBC'] = '2.16.840.1.101.3.4.1.42';
151
-
152
- // certificate issuer/subject OIDs
153
- oids['2.5.4.3'] = 'commonName';
154
- oids['commonName'] = '2.5.4.3';
155
- oids['2.5.4.5'] = 'serialName';
156
- oids['serialName'] = '2.5.4.5';
157
- oids['2.5.4.6'] = 'countryName';
158
- oids['countryName'] = '2.5.4.6';
159
- oids['2.5.4.7'] = 'localityName';
160
- oids['localityName'] = '2.5.4.7';
161
- oids['2.5.4.8'] = 'stateOrProvinceName';
162
- oids['stateOrProvinceName'] = '2.5.4.8';
163
- oids['2.5.4.10'] = 'organizationName';
164
- oids['organizationName'] = '2.5.4.10';
165
- oids['2.5.4.11'] = 'organizationalUnitName';
166
- oids['organizationalUnitName'] = '2.5.4.11';
167
-
168
- // X.509 extension OIDs
169
- oids['2.16.840.1.113730.1.1'] = 'nsCertType';
170
- oids['nsCertType'] = '2.16.840.1.113730.1.1';
171
- oids['2.5.29.1'] = 'authorityKeyIdentifier'; // deprecated, use .35
172
- oids['2.5.29.2'] = 'keyAttributes'; // obsolete use .37 or .15
173
- oids['2.5.29.3'] = 'certificatePolicies'; // deprecated, use .32
174
- oids['2.5.29.4'] = 'keyUsageRestriction'; // obsolete use .37 or .15
175
- oids['2.5.29.5'] = 'policyMapping'; // deprecated use .33
176
- oids['2.5.29.6'] = 'subtreesConstraint'; // obsolete use .30
177
- oids['2.5.29.7'] = 'subjectAltName'; // deprecated use .17
178
- oids['2.5.29.8'] = 'issuerAltName'; // deprecated use .18
179
- oids['2.5.29.9'] = 'subjectDirectoryAttributes';
180
- oids['2.5.29.10'] = 'basicConstraints'; // deprecated use .19
181
- oids['2.5.29.11'] = 'nameConstraints'; // deprecated use .30
182
- oids['2.5.29.12'] = 'policyConstraints'; // deprecated use .36
183
- oids['2.5.29.13'] = 'basicConstraints'; // deprecated use .19
184
- oids['2.5.29.14'] = 'subjectKeyIdentifier';
185
- oids['subjectKeyIdentifier'] = '2.5.29.14';
186
- oids['2.5.29.15'] = 'keyUsage';
187
- oids['keyUsage'] = '2.5.29.15';
188
- oids['2.5.29.16'] = 'privateKeyUsagePeriod';
189
- oids['2.5.29.17'] = 'subjectAltName';
190
- oids['subjectAltName'] = '2.5.29.17';
191
- oids['2.5.29.18'] = 'issuerAltName';
192
- oids['issuerAltName'] = '2.5.29.18';
193
- oids['2.5.29.19'] = 'basicConstraints';
194
- oids['basicConstraints'] = '2.5.29.19';
195
- oids['2.5.29.20'] = 'cRLNumber';
196
- oids['2.5.29.21'] = 'cRLReason';
197
- oids['2.5.29.22'] = 'expirationDate';
198
- oids['2.5.29.23'] = 'instructionCode';
199
- oids['2.5.29.24'] = 'invalidityDate';
200
- oids['2.5.29.25'] = 'cRLDistributionPoints'; // deprecated use .31
201
- oids['2.5.29.26'] = 'issuingDistributionPoint'; // deprecated use .28
202
- oids['2.5.29.27'] = 'deltaCRLIndicator';
203
- oids['2.5.29.28'] = 'issuingDistributionPoint';
204
- oids['2.5.29.29'] = 'certificateIssuer';
205
- oids['2.5.29.30'] = 'nameConstraints';
206
- oids['2.5.29.31'] = 'cRLDistributionPoints';
207
- oids['cRLDistributionPoints'] = '2.5.29.31';
208
- oids['2.5.29.32'] = 'certificatePolicies';
209
- oids['certificatePolicies'] = '2.5.29.32';
210
- oids['2.5.29.33'] = 'policyMappings';
211
- oids['2.5.29.34'] = 'policyConstraints'; // deprecated use .36
212
- oids['2.5.29.35'] = 'authorityKeyIdentifier';
213
- oids['authorityKeyIdentifier'] = '2.5.29.35';
214
- oids['2.5.29.36'] = 'policyConstraints';
215
- oids['2.5.29.37'] = 'extKeyUsage';
216
- oids['extKeyUsage'] = '2.5.29.37';
217
- oids['2.5.29.46'] = 'freshestCRL';
218
- oids['2.5.29.54'] = 'inhibitAnyPolicy';
219
-
220
- // extKeyUsage purposes
221
- oids['1.3.6.1.4.1.11129.2.4.2'] = 'timestampList';
222
- oids['timestampList'] = '1.3.6.1.4.1.11129.2.4.2';
223
- oids['1.3.6.1.5.5.7.1.1'] = 'authorityInfoAccess';
224
- oids['authorityInfoAccess'] = '1.3.6.1.5.5.7.1.1';
225
- oids['1.3.6.1.5.5.7.3.1'] = 'serverAuth';
226
- oids['serverAuth'] = '1.3.6.1.5.5.7.3.1';
227
- oids['1.3.6.1.5.5.7.3.2'] = 'clientAuth';
228
- oids['clientAuth'] = '1.3.6.1.5.5.7.3.2';
229
- oids['1.3.6.1.5.5.7.3.3'] = 'codeSigning';
230
- oids['codeSigning'] = '1.3.6.1.5.5.7.3.3';
231
- oids['1.3.6.1.5.5.7.3.4'] = 'emailProtection';
232
- oids['emailProtection'] = '1.3.6.1.5.5.7.3.4';
233
- oids['1.3.6.1.5.5.7.3.8'] = 'timeStamping';
234
- oids['timeStamping'] = '1.3.6.1.5.5.7.3.8';
235
-
236
- } // end module implementation
237
-
238
- /* ########## Begin module wrapper ########## */
239
- var name = 'oids';
240
- if(typeof define !== 'function') {
241
- // NodeJS -> AMD
242
- if(typeof module === 'object' && module.exports) {
243
- var nodeJS = true;
244
- define = function(ids, factory) {
245
- factory(require, module);
246
- };
247
- } else {
248
- // <script>
249
- if(typeof forge === 'undefined') {
250
- forge = {};
251
- }
252
- return initModule(forge);
253
- }
254
- }
255
- // AMD
256
- var deps;
257
- var defineFunc = function(require, module) {
258
- module.exports = function(forge) {
259
- var mods = deps.map(function(dep) {
260
- return require(dep);
261
- }).concat(initModule);
262
- // handle circular dependencies
263
- forge = forge || {};
264
- forge.defined = forge.defined || {};
265
- if(forge.defined[name]) {
266
- return forge[name];
267
- }
268
- forge.defined[name] = true;
269
- for(var i = 0; i < mods.length; ++i) {
270
- mods[i](forge);
271
- }
272
- return forge[name];
273
- };
274
- };
275
- var tmpDefine = define;
276
- define = function(ids, factory) {
277
- deps = (typeof ids === 'string') ? factory.slice(2) : ids.slice(2);
278
- if(nodeJS) {
279
- delete define;
280
- return tmpDefine.apply(null, Array.prototype.slice.call(arguments, 0));
281
- }
282
- define = tmpDefine;
283
- return define.apply(null, Array.prototype.slice.call(arguments, 0));
284
- };
285
- define(['require', 'module'], function() {
286
- defineFunc.apply(null, Array.prototype.slice.call(arguments, 0));
287
- });
288
- })();
Binary file