Mercurial > hg > vamp-website
comparison forum/Themes/Vamp/sha1.js @ 76:e3e11437ecea website
Add forum code
author | Chris Cannam |
---|---|
date | Sun, 07 Jul 2013 11:25:48 +0200 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
75:72f59aa7e503 | 76:e3e11437ecea |
---|---|
1 /* | |
2 * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined | |
3 * in FIPS PUB 180-1 | |
4 * Version 2.1 Copyright Paul Johnston 2000 - 2002. | |
5 * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet | |
6 * Distributed under the BSD License | |
7 * See http://pajhome.org.uk/crypt/md5 for details. | |
8 */ | |
9 | |
10 /* | |
11 * Configurable variables. You may need to tweak these to be compatible with | |
12 * the server-side, but the defaults work in most cases. | |
13 */ | |
14 var hexcase = 0; /* hex output format. 0 - lowercase; 1 - uppercase */ | |
15 var b64pad = ""; /* base-64 pad character. "=" for strict RFC compliance */ | |
16 var chrsz = 8; /* bits per input character. 8 - ASCII; 16 - Unicode */ | |
17 | |
18 /* | |
19 * These are the functions you'll usually want to call | |
20 * They take string arguments and return either hex or base-64 encoded strings | |
21 */ | |
22 function hex_sha1(s){return binb2hex(core_sha1(str2binb(s),s.length * chrsz));} | |
23 function b64_sha1(s){return binb2b64(core_sha1(str2binb(s),s.length * chrsz));} | |
24 function str_sha1(s){return binb2str(core_sha1(str2binb(s),s.length * chrsz));} | |
25 function hex_hmac_sha1(key, data){ return binb2hex(core_hmac_sha1(key, data));} | |
26 function b64_hmac_sha1(key, data){ return binb2b64(core_hmac_sha1(key, data));} | |
27 function str_hmac_sha1(key, data){ return binb2str(core_hmac_sha1(key, data));} | |
28 | |
29 /* | |
30 * Perform a simple self-test to see if the VM is working | |
31 */ | |
32 function sha1_vm_test() | |
33 { | |
34 return hex_sha1("abc") == "a9993e364706816aba3e25717850c26c9cd0d89d"; | |
35 } | |
36 | |
37 /* | |
38 * Calculate the SHA-1 of an array of big-endian words, and a bit length | |
39 */ | |
40 function core_sha1(x, len) | |
41 { | |
42 /* append padding */ | |
43 x[len >> 5] |= 0x80 << (24 - len % 32); | |
44 x[((len + 64 >> 9) << 4) + 15] = len; | |
45 | |
46 var w = Array(80); | |
47 var a = 1732584193; | |
48 var b = -271733879; | |
49 var c = -1732584194; | |
50 var d = 271733878; | |
51 var e = -1009589776; | |
52 | |
53 for (var i = 0; i < x.length; i += 16) | |
54 { | |
55 var olda = a; | |
56 var oldb = b; | |
57 var oldc = c; | |
58 var oldd = d; | |
59 var olde = e; | |
60 | |
61 for (var j = 0; j < 80; j++) | |
62 { | |
63 if (j < 16) w[j] = x[i + j]; | |
64 else w[j] = rol(w[j-3] ^ w[j-8] ^ w[j-14] ^ w[j-16], 1); | |
65 var t = safe_add(safe_add(rol(a, 5), sha1_ft(j, b, c, d)), safe_add(safe_add(e, w[j]), sha1_kt(j))); | |
66 e = d; | |
67 d = c; | |
68 c = rol(b, 30); | |
69 b = a; | |
70 a = t; | |
71 } | |
72 | |
73 a = safe_add(a, olda); | |
74 b = safe_add(b, oldb); | |
75 c = safe_add(c, oldc); | |
76 d = safe_add(d, oldd); | |
77 e = safe_add(e, olde); | |
78 } | |
79 return Array(a, b, c, d, e); | |
80 } | |
81 | |
82 /* | |
83 * Perform the appropriate triplet combination function for the current | |
84 * iteration | |
85 */ | |
86 function sha1_ft(t, b, c, d) | |
87 { | |
88 if (t < 20) return (b & c) | ((~b) & d); | |
89 if (t < 40) return b ^ c ^ d; | |
90 if (t < 60) return (b & c) | (b & d) | (c & d); | |
91 return b ^ c ^ d; | |
92 } | |
93 | |
94 /* | |
95 * Determine the appropriate additive constant for the current iteration | |
96 */ | |
97 function sha1_kt(t) | |
98 { | |
99 return (t < 20) ? 1518500249 : (t < 40) ? 1859775393 : | |
100 (t < 60) ? -1894007588 : -899497514; | |
101 } | |
102 | |
103 /* | |
104 * Calculate the HMAC-SHA1 of a key and some data | |
105 */ | |
106 function core_hmac_sha1(key, data) | |
107 { | |
108 var bkey = str2binb(key); | |
109 if (bkey.length > 16) bkey = core_sha1(bkey, key.length * chrsz); | |
110 | |
111 var ipad = Array(16), opad = Array(16); | |
112 for (var i = 0; i < 16; i++) | |
113 { | |
114 ipad[i] = bkey[i] ^ 0x36363636; | |
115 opad[i] = bkey[i] ^ 0x5C5C5C5C; | |
116 } | |
117 | |
118 var hash = core_sha1(ipad.concat(str2binb(data)), 512 + data.length * chrsz); | |
119 return core_sha1(opad.concat(hash), 512 + 160); | |
120 } | |
121 | |
122 /* | |
123 * Add integers, wrapping at 2^32. This uses 16-bit operations internally | |
124 * to work around bugs in some JS interpreters. | |
125 */ | |
126 function safe_add(x, y) | |
127 { | |
128 var lsw = (x & 0xFFFF) + (y & 0xFFFF); | |
129 var msw = (x >> 16) + (y >> 16) + (lsw >> 16); | |
130 return (msw << 16) | (lsw & 0xFFFF); | |
131 } | |
132 | |
133 /* | |
134 * Bitwise rotate a 32-bit number to the left. | |
135 */ | |
136 function rol(num, cnt) | |
137 { | |
138 return (num << cnt) | (num >>> (32 - cnt)); | |
139 } | |
140 | |
141 /* | |
142 * Convert an 8-bit or 16-bit string to an array of big-endian words | |
143 * In 8-bit function, characters >255 have their hi-byte silently ignored. | |
144 */ | |
145 function str2binb(str) | |
146 { | |
147 var bin = Array(); | |
148 var mask = (1 << chrsz) - 1; | |
149 for (var i = 0; i < str.length * chrsz; i += chrsz) | |
150 bin[i>>5] |= (str.charCodeAt(i / chrsz) & mask) << (24 - i%32); | |
151 return bin; | |
152 } | |
153 | |
154 /* | |
155 * Convert an array of big-endian words to a string | |
156 */ | |
157 function binb2str(bin) | |
158 { | |
159 var str = ""; | |
160 var mask = (1 << chrsz) - 1; | |
161 for (var i = 0; i < bin.length * 32; i += chrsz) | |
162 str += String.fromCharCode((bin[i>>5] >>> (24 - i%32)) & mask); | |
163 return str; | |
164 } | |
165 | |
166 /* | |
167 * Convert an array of big-endian words to a hex string. | |
168 */ | |
169 function binb2hex(binarray) | |
170 { | |
171 var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef"; | |
172 var str = ""; | |
173 for (var i = 0; i < binarray.length * 4; i++) | |
174 { | |
175 str += hex_tab.charAt((binarray[i>>2] >> ((3 - i%4)*8+4)) & 0xF) + | |
176 hex_tab.charAt((binarray[i>>2] >> ((3 - i%4)*8 )) & 0xF); | |
177 } | |
178 return str; | |
179 } | |
180 | |
181 /* | |
182 * Convert an array of big-endian words to a base-64 string | |
183 */ | |
184 function binb2b64(binarray) | |
185 { | |
186 var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; | |
187 var str = ""; | |
188 for (var i = 0; i < binarray.length * 4; i += 3) | |
189 { | |
190 var triplet = (((binarray[i >> 2] >> 8 * (3 - i %4)) & 0xFF) << 16) | |
191 | (((binarray[i+1 >> 2] >> 8 * (3 - (i+1)%4)) & 0xFF) << 8 ) | |
192 | ((binarray[i+2 >> 2] >> 8 * (3 - (i+2)%4)) & 0xFF); | |
193 for (var j = 0; j < 4; j++) | |
194 { | |
195 if (i * 8 + j * 6 > binarray.length * 32) str += b64pad; | |
196 else str += tab.charAt((triplet >> 6*(3-j)) & 0x3F); | |
197 } | |
198 } | |
199 return str; | |
200 } | |
201 | |
202 // Character-level replacement function. | |
203 String.prototype.php_strtr = function (sFrom, sTo) { | |
204 return this.replace(new RegExp('[' + sFrom + ']', 'g'), function (sMatch) { | |
205 return sTo.charAt(sFrom.indexOf(sMatch)); | |
206 }); | |
207 } | |
208 | |
209 // Simulate PHP's strtolower (in SOME cases PHP uses ISO-8859-1 case folding). | |
210 String.prototype.php_strtolower = function () { | |
211 return typeof(smf_iso_case_folding) != "undefined" && smf_iso_case_folding == true ? this.php_strtr( | |
212 'ABCDEFGHIJKLMNOPQRSTUVWXYZ\x8a\x8c\x8e\x9f\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde', | |
213 'abcdefghijklmnopqrstuvwxyz\x9a\x9c\x9e\xff\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe' | |
214 ) : this.php_strtr('ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz'); | |
215 } | |
216 | |
217 // Convert a string to an 8 bit representation (like in PHP). | |
218 String.prototype.php_to8bit = function () { | |
219 if (smf_charset == 'UTF-8') | |
220 { | |
221 var n, sReturn = ''; | |
222 | |
223 for (var i = 0, iTextLen = this.length; i < iTextLen; i++) | |
224 { | |
225 n = this.charCodeAt(i); | |
226 if (n < 128) | |
227 sReturn += String.fromCharCode(n) | |
228 else if (n < 2048) | |
229 sReturn += String.fromCharCode(192 | n >> 6) + String.fromCharCode(128 | n & 63); | |
230 else if (n < 65536) | |
231 sReturn += String.fromCharCode(224 | n >> 12) + String.fromCharCode(128 | n >> 6 & 63) + String.fromCharCode(128 | n & 63); | |
232 else | |
233 sReturn += String.fromCharCode(240 | n >> 18) + String.fromCharCode(128 | n >> 12 & 63) + String.fromCharCode(128 | n >> 6 & 63) + String.fromCharCode(128 | n & 63); | |
234 } | |
235 | |
236 return sReturn; | |
237 } | |
238 else if (smf_charset == 'ISO-8859-2') | |
239 { | |
240 return this.php_strtr( | |
241 '\u0104\u02d8\u0141\u013d\u026a\u0160\u015e\u0164\u0179\u017d\u017b\u0105\u02db\u0142\u013e\u015b\u02c7\u0161\u015f\u0165\u017a\u02dd\u017e\u017c\u0154\u0102\u0139\u0106\u010c\u0118\u011a\u010e\u0110\u0143\u0147\u0150\u0158\u016e\u0170\u0162\u0155\u0103\u013a\u0107\u010d\u0119\u011b\u010f\u0111\u0144\u0148\u0151\u0159\u016f\u0171\u0163\u02d9', | |
242 '\xa1\xa2\xa3\xa5\xa6\xa9\xaa\xab\xac\xae\xaf\xb1\xb2\xb3\xb5\xb6\xb7\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc3\xc5\xc6\xc8\xca\xcc\xcf\xd0\xd1\xd2\xd5\xd8\xd9\xdc\xde\xe0\xe3\xe5\xe6\xe8\xea\xec\xef\xf0\xf1\xf2\xf5\xf8\xf9\xfb\xfe\xff' | |
243 ); | |
244 } | |
245 else if (smf_charset == 'ISO-8859-9') | |
246 { | |
247 return this.php_strtr( | |
248 '\u011e\u0130\u015e\u011f\u0131\u015f', | |
249 '\xd0\xdd\xde\xf0\xfd\xfe' | |
250 ); | |
251 } | |
252 else if (smf_charset == 'tis-620') | |
253 { | |
254 return this.php_strtr( | |
255 '\u0e01\u0e02\u0e03\u0e04\u0e05\u0e06\u0e07\u0e08\u0e09\u0e0a\u0e0b\u0e0c\u0e0d\u0e0e\u0e0f\u0e10\u0e11\u0e12\u0e13\u0e14\u0e15\u0e16\u0e17\u0e18\u0e19\u0e1a\u0e1b\u0e1c\u0e1d\u0e1e\u0e1f\u0e20\u0e21\u0e22\u0e23\u0e24\u0e25\u0e26\u0e27\u0e28\u0e29\u0e2a\u0e2b\u0e2c\u0e2d\u0e2e\u0e2f\u0e30\u0e31\u0e32\u0e33\u0e34\u0e35\u0e36\u0e37\u0e38\u0e39\u0e3a\u0e3f\u0e40\u0e41\u0e42\u0e43\u0e44\u0e45\u0e46\u0e47\u0e48\u0e49\u0e4a\u0e4b\u0e4c\u0e4d\u0e4e\u0e4f\u0e50\u0e51\u0e52\u0e53\u0e54\u0e55\u0e56\u0e57\u0e58\u0e59\u0e5a\u0e5b', | |
256 '\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb' | |
257 ); | |
258 } | |
259 else if (smf_charset == 'windows-1251') | |
260 { | |
261 return this.php_strtr( | |
262 '\u0402\u0403\u201a\u0453\u201e\u2026\u2020\u2021\u20ac\u2030\u0409\u2039\u040a\u040c\u040b\u040f\u0452\u2018\u2019\u201c\u201d\u2022\u2013\u2014\u2122\u0459\u203a\u045a\u045c\u045b\u045f\u040e\u045e\u0408\u0490\u0401\u0404\u0407\u0406\u0456\u0491\u0451\u2116\u0454\u0458\u0405\u0455\u0457\u0410\u0411\u0412\u0413\u0414\u0415\u0416\u0417\u0418\u0419\u041a\u041b\u041c\u041d\u041e\u041f\u0420\u0421\u0422\u0423\u0424\u0425\u0426\u0427\u0428\u0429\u042a\u042b\u042c\u042d\u042e\u042f\u0430\u0431\u0432\u0433\u0434\u0435\u0436\u0437\u0438\u0439\u043a\u043b\u043c\u043d\u043e\u043f\u0440\u0441\u0442\u0443\u0444\u0445\u0446\u0447\u0448\u0449\u044a\u044b\u044c\u044d\u044e\u044f', | |
263 '\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa1\xa2\xa3\xa5\xa8\xaa\xaf\xb2\xb3\xb4\xb8\xb9\xba\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff' | |
264 ); | |
265 } | |
266 else if (smf_charset == 'windows-1253') | |
267 { | |
268 return this.php_strtr( | |
269 '\u20ac\u201a\u0192\u201e\u2026\u2020\u2021\u2030\u2039\u2018\u2019\u201c\u201d\u2022\u2013\u2014\u2122\u203a\u0385\u0386\u2015\u0384\u0388\u0389\u038a\u038c\u038e\u038f\u0390\u0391\u0392\u0393\u0394\u0395\u0396\u0397\u0398\u0399\u039a\u039b\u039c\u039d\u039e\u039f\u03a0\u03a1\u03a3\u03a4\u03a5\u03a6\u03a7\u03a8\u03a9\u03aa\u03ab\u03ac\u03ad\u03ae\u03af\u03b0\u03b1\u03b2\u03b3\u03b4\u03b5\u03b6\u03b7\u03b8\u03b9\u03ba\u03bb\u03bc\u03bd\u03be\u03bf\u03c0\u03c1\u03c2\u03c3\u03c4\u03c5\u03c6\u03c7\u03c8\u03c9\u03ca\u03cb\u03cc\u03cd\u03ce', | |
270 '\x80\x82\x83\x84\x85\x86\x87\x89\x8b\x91\x92\x93\x94\x95\x96\x97\x99\x9b\xa1\xa2\xaf\xb4\xb8\xb9\xba\xbc\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe' | |
271 ); | |
272 } | |
273 else if (smf_charset == 'windows-1255') | |
274 { | |
275 return this.php_strtr( | |
276 '\u20ac\u201a\u0192\u201e\u2026\u2020\u2021\u02c6\u2030\u2039\u2018\u2019\u201c\u201d\u2022\u2013\u2014\u02dc\u2122\u203a\u20aa\u00d7\u00f7\u05b0\u05b1\u05b2\u05b3\u05b4\u05b5\u05b6\u05b7\u05b8\u05b9\u05bb\u05bc\u05bd\u05be\u05bf\u05c0\u05c1\u05c2\u05c3\u05f0\u05f1\u05f2\u05f3\u05f4\u05d0\u05d1\u05d2\u05d3\u05d4\u05d5\u05d6\u05d7\u05d8\u05d9\u05da\u05db\u05dc\u05dd\u05de\u05df\u05e0\u05e1\u05e2\u05e3\u05e4\u05e5\u05e6\u05e7\u05e8\u05e9\u05ea\u200e\u200f', | |
277 '\x80\x82\x83\x84\x85\x86\x87\x88\x89\x8b\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9b\xa4\xaa\xba\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfd\xfe' | |
278 ); | |
279 } | |
280 else if (smf_charset == 'windows-1256') | |
281 { | |
282 return this.php_strtr( | |
283 '\u20ac\u067e\u201a\u0192\u201e\u2026\u2020\u2021\u02c6\u2030\u0679\u2039\u0152\u0686\u0698\u0688\u06af\u2018\u2019\u201c\u201d\u2022\u2013\u2014\u06a9\u2122\u0691\u203a\u0153\u200c\u200d\u06ba\u060c\u06be\u061b\u061f\u06c1\u0621\u0622\u0623\u0624\u0625\u0626\u0627\u0628\u0629\u062a\u062b\u062c\u062d\u062e\u062f\u0630\u0631\u0632\u0633\u0634\u0635\u0636\u0637\u0638\u0639\u063a\u0640\u0641\u0642\u0643\u0644\u0645\u0646\u0647\u0648\u0649\u064a\u064b\u064c\u064d\u064e\u064f\u0650\u0651\u0652\u200e\u200f\u06d2', | |
284 '\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa1\xaa\xba\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe1\xe3\xe4\xe5\xe6\xec\xed\xf0\xf1\xf2\xf3\xf5\xf6\xf8\xfa\xfd\xfe\xff' | |
285 ); | |
286 } | |
287 else | |
288 return this; | |
289 } |