Enhance refactor commands with controller-aware Route() updates and fix code quality violations
Add semantic token highlighting for 'that' variable and comment file references in VS Code extension Add Phone_Text_Input and Currency_Input components with formatting utilities Implement client widgets, form standardization, and soft delete functionality Add modal scroll lock and update documentation Implement comprehensive modal system with form integration and validation Fix modal component instantiation using jQuery plugin API Implement modal system with responsive sizing, queuing, and validation support Implement form submission with validation, error handling, and loading states Implement country/state selectors with dynamic data loading and Bootstrap styling Revert Rsx::Route() highlighting in Blade/PHP files Target specific PHP scopes for Rsx::Route() highlighting in Blade Expand injection selector for Rsx::Route() highlighting Add custom syntax highlighting for Rsx::Route() and Rsx.Route() calls Update jqhtml packages to v2.2.165 Add bundle path validation for common mistakes (development mode only) Create Ajax_Select_Input widget and Rsx_Reference_Data controller Create Country_Select_Input widget with default country support Initialize Tom Select on Select_Input widgets Add Tom Select bundle for enhanced select dropdowns Implement ISO 3166 geographic data system for country/region selection Implement widget-based form system with disabled state support 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
1
node_modules/pbkdf2/.eslintrc
generated
vendored
Executable file → Normal file
1
node_modules/pbkdf2/.eslintrc
generated
vendored
Executable file → Normal file
@@ -17,6 +17,7 @@
|
||||
},
|
||||
|
||||
"rules": {
|
||||
"complexity": "off",
|
||||
"func-style": "warn",
|
||||
"max-params": "warn",
|
||||
"multiline-comment-style": "off",
|
||||
|
||||
0
node_modules/pbkdf2/.nycrc
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/.nycrc
generated
vendored
Executable file → Normal file
16
node_modules/pbkdf2/CHANGELOG.md
generated
vendored
16
node_modules/pbkdf2/CHANGELOG.md
generated
vendored
@@ -5,6 +5,22 @@ All notable changes to this project will be documented in this file.
|
||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
|
||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||
|
||||
## [v3.1.5](https://github.com/browserify/pbkdf2/compare/v3.1.4...v3.1.5) - 2025-09-23
|
||||
|
||||
### Commits
|
||||
|
||||
- [Fix] only allow finite iterations [`67bd94d`](https://github.com/browserify/pbkdf2/commit/67bd94dbbf21b93f5e282ee910728945c8ef2827)
|
||||
- [Fix] restore node 0.10 support [`8f59d96`](https://github.com/browserify/pbkdf2/commit/8f59d962f71dcb2cc14067d7f514ff96e3406f81)
|
||||
- [Fix] check parameters before the "no Promise" bailout [`d2dc5f0`](https://github.com/browserify/pbkdf2/commit/d2dc5f052cacadf3d4a09d87164158da875ca740)
|
||||
|
||||
## [v3.1.4](https://github.com/browserify/pbkdf2/compare/v3.1.3...v3.1.4) - 2025-09-22
|
||||
|
||||
### Commits
|
||||
|
||||
- [Deps] update `create-hash`, `ripemd160`, `sha.js`, `to-buffer` [`8dbf49b`](https://github.com/browserify/pbkdf2/commit/8dbf49b38235066c565a92eaf3722720a1333a2d)
|
||||
- [meta] update repo URLs [`d15bc35`](https://github.com/browserify/pbkdf2/commit/d15bc351de0edbed394d2a6189176960aaa0d050)
|
||||
- [Dev Deps] update `@ljharb/eslint-config` [`aaf870b`](https://github.com/browserify/pbkdf2/commit/aaf870b1d1855e6a381af05021f304294a79f7c9)
|
||||
|
||||
## [v3.1.3](https://github.com/browserify/pbkdf2/compare/v3.1.2...v3.1.3) - 2025-06-20
|
||||
|
||||
### Commits
|
||||
|
||||
0
node_modules/pbkdf2/LICENSE
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/LICENSE
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/browser.js
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/browser.js
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/index.js
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/index.js
generated
vendored
Executable file → Normal file
14
node_modules/pbkdf2/lib/async.js
generated
vendored
Executable file → Normal file
14
node_modules/pbkdf2/lib/async.js
generated
vendored
Executable file → Normal file
@@ -88,6 +88,13 @@ module.exports = function (password, salt, iterations, keylen, digest, callback)
|
||||
digest = undefined;
|
||||
}
|
||||
|
||||
checkParameters(iterations, keylen);
|
||||
password = toBuffer(password, defaultEncoding, 'Password');
|
||||
salt = toBuffer(salt, defaultEncoding, 'Salt');
|
||||
if (typeof callback !== 'function') {
|
||||
throw new Error('No callback provided to pbkdf2');
|
||||
}
|
||||
|
||||
digest = digest || 'sha1';
|
||||
var algo = toBrowser[digest.toLowerCase()];
|
||||
|
||||
@@ -105,13 +112,6 @@ module.exports = function (password, salt, iterations, keylen, digest, callback)
|
||||
return;
|
||||
}
|
||||
|
||||
checkParameters(iterations, keylen);
|
||||
password = toBuffer(password, defaultEncoding, 'Password');
|
||||
salt = toBuffer(salt, defaultEncoding, 'Salt');
|
||||
if (typeof callback !== 'function') {
|
||||
throw new Error('No callback provided to pbkdf2');
|
||||
}
|
||||
|
||||
resolvePromise(checkNative(algo).then(function (resp) {
|
||||
if (resp) {
|
||||
return browserPbkdf2(password, salt, iterations, keylen, algo);
|
||||
|
||||
0
node_modules/pbkdf2/lib/default-encoding.js
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/lib/default-encoding.js
generated
vendored
Executable file → Normal file
3
node_modules/pbkdf2/lib/precondition.js
generated
vendored
Executable file → Normal file
3
node_modules/pbkdf2/lib/precondition.js
generated
vendored
Executable file → Normal file
@@ -1,5 +1,6 @@
|
||||
'use strict';
|
||||
|
||||
var $isFinite = isFinite;
|
||||
var MAX_ALLOC = Math.pow(2, 30) - 1; // default in iojs
|
||||
|
||||
module.exports = function (iterations, keylen) {
|
||||
@@ -7,7 +8,7 @@ module.exports = function (iterations, keylen) {
|
||||
throw new TypeError('Iterations not a number');
|
||||
}
|
||||
|
||||
if (iterations < 0) {
|
||||
if (iterations < 0 || !$isFinite(iterations)) {
|
||||
throw new TypeError('Bad iterations');
|
||||
}
|
||||
|
||||
|
||||
0
node_modules/pbkdf2/lib/sync-browser.js
generated
vendored
Executable file → Normal file
0
node_modules/pbkdf2/lib/sync-browser.js
generated
vendored
Executable file → Normal file
1
node_modules/pbkdf2/node_modules/create-hash/.npmignore
generated
vendored
1
node_modules/pbkdf2/node_modules/create-hash/.npmignore
generated
vendored
@@ -1 +0,0 @@
|
||||
node_modules
|
||||
15
node_modules/pbkdf2/node_modules/create-hash/.travis.yml
generated
vendored
15
node_modules/pbkdf2/node_modules/create-hash/.travis.yml
generated
vendored
@@ -1,15 +0,0 @@
|
||||
sudo: false
|
||||
language: node_js
|
||||
before_install:
|
||||
- "npm install npm -g"
|
||||
node_js:
|
||||
- "0.10"
|
||||
- "0.12"
|
||||
- "4"
|
||||
- "5"
|
||||
- "6"
|
||||
env:
|
||||
- TEST_SUITE=standard
|
||||
- TEST_SUITE=unit
|
||||
script: "npm run-script $TEST_SUITE"
|
||||
|
||||
52
node_modules/pbkdf2/node_modules/create-hash/browser.js
generated
vendored
52
node_modules/pbkdf2/node_modules/create-hash/browser.js
generated
vendored
@@ -1,52 +0,0 @@
|
||||
'use strict'
|
||||
var inherits = require('inherits')
|
||||
var md5 = require('./md5')
|
||||
var RIPEMD160 = require('ripemd160')
|
||||
var sha = require('sha.js')
|
||||
|
||||
var Base = require('cipher-base')
|
||||
|
||||
function HashNoConstructor (hash) {
|
||||
Base.call(this, 'digest')
|
||||
|
||||
this._hash = hash
|
||||
this.buffers = []
|
||||
}
|
||||
|
||||
inherits(HashNoConstructor, Base)
|
||||
|
||||
HashNoConstructor.prototype._update = function (data) {
|
||||
this.buffers.push(data)
|
||||
}
|
||||
|
||||
HashNoConstructor.prototype._final = function () {
|
||||
var buf = Buffer.concat(this.buffers)
|
||||
var r = this._hash(buf)
|
||||
this.buffers = null
|
||||
|
||||
return r
|
||||
}
|
||||
|
||||
function Hash (hash) {
|
||||
Base.call(this, 'digest')
|
||||
|
||||
this._hash = hash
|
||||
}
|
||||
|
||||
inherits(Hash, Base)
|
||||
|
||||
Hash.prototype._update = function (data) {
|
||||
this._hash.update(data)
|
||||
}
|
||||
|
||||
Hash.prototype._final = function () {
|
||||
return this._hash.digest()
|
||||
}
|
||||
|
||||
module.exports = function createHash (alg) {
|
||||
alg = alg.toLowerCase()
|
||||
if (alg === 'md5') return new HashNoConstructor(md5)
|
||||
if (alg === 'rmd160' || alg === 'ripemd160') return new Hash(new RIPEMD160())
|
||||
|
||||
return new Hash(sha(alg))
|
||||
}
|
||||
1
node_modules/pbkdf2/node_modules/create-hash/index.js
generated
vendored
1
node_modules/pbkdf2/node_modules/create-hash/index.js
generated
vendored
@@ -1 +0,0 @@
|
||||
module.exports = require('crypto').createHash
|
||||
30
node_modules/pbkdf2/node_modules/create-hash/make-hash.js
generated
vendored
30
node_modules/pbkdf2/node_modules/create-hash/make-hash.js
generated
vendored
@@ -1,30 +0,0 @@
|
||||
'use strict'
|
||||
var intSize = 4
|
||||
var zeroBuffer = new Buffer(intSize)
|
||||
zeroBuffer.fill(0)
|
||||
|
||||
var charSize = 8
|
||||
var hashSize = 16
|
||||
|
||||
function toArray (buf) {
|
||||
if ((buf.length % intSize) !== 0) {
|
||||
var len = buf.length + (intSize - (buf.length % intSize))
|
||||
buf = Buffer.concat([buf, zeroBuffer], len)
|
||||
}
|
||||
|
||||
var arr = new Array(buf.length >>> 2)
|
||||
for (var i = 0, j = 0; i < buf.length; i += intSize, j++) {
|
||||
arr[j] = buf.readInt32LE(i)
|
||||
}
|
||||
|
||||
return arr
|
||||
}
|
||||
|
||||
module.exports = function hash (buf, fn) {
|
||||
var arr = fn(toArray(buf), buf.length * charSize)
|
||||
buf = new Buffer(hashSize)
|
||||
for (var i = 0; i < arr.length; i++) {
|
||||
buf.writeInt32LE(arr[i], i << 2, true)
|
||||
}
|
||||
return buf
|
||||
}
|
||||
151
node_modules/pbkdf2/node_modules/create-hash/md5.js
generated
vendored
151
node_modules/pbkdf2/node_modules/create-hash/md5.js
generated
vendored
@@ -1,151 +0,0 @@
|
||||
'use strict'
|
||||
/*
|
||||
* A JavaScript implementation of the RSA Data Security, Inc. MD5 Message
|
||||
* Digest Algorithm, as defined in RFC 1321.
|
||||
* Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.
|
||||
* Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
|
||||
* Distributed under the BSD License
|
||||
* See http://pajhome.org.uk/crypt/md5 for more info.
|
||||
*/
|
||||
|
||||
var makeHash = require('./make-hash')
|
||||
|
||||
/*
|
||||
* Calculate the MD5 of an array of little-endian words, and a bit length
|
||||
*/
|
||||
function core_md5 (x, len) {
|
||||
/* append padding */
|
||||
x[len >> 5] |= 0x80 << ((len) % 32)
|
||||
x[(((len + 64) >>> 9) << 4) + 14] = len
|
||||
|
||||
var a = 1732584193
|
||||
var b = -271733879
|
||||
var c = -1732584194
|
||||
var d = 271733878
|
||||
|
||||
for (var i = 0; i < x.length; i += 16) {
|
||||
var olda = a
|
||||
var oldb = b
|
||||
var oldc = c
|
||||
var oldd = d
|
||||
|
||||
a = md5_ff(a, b, c, d, x[i + 0], 7, -680876936)
|
||||
d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586)
|
||||
c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819)
|
||||
b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330)
|
||||
a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897)
|
||||
d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426)
|
||||
c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341)
|
||||
b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983)
|
||||
a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416)
|
||||
d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417)
|
||||
c = md5_ff(c, d, a, b, x[i + 10], 17, -42063)
|
||||
b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162)
|
||||
a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682)
|
||||
d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101)
|
||||
c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290)
|
||||
b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329)
|
||||
|
||||
a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510)
|
||||
d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632)
|
||||
c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713)
|
||||
b = md5_gg(b, c, d, a, x[i + 0], 20, -373897302)
|
||||
a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691)
|
||||
d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083)
|
||||
c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335)
|
||||
b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848)
|
||||
a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438)
|
||||
d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690)
|
||||
c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961)
|
||||
b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501)
|
||||
a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467)
|
||||
d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784)
|
||||
c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473)
|
||||
b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734)
|
||||
|
||||
a = md5_hh(a, b, c, d, x[i + 5], 4, -378558)
|
||||
d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463)
|
||||
c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562)
|
||||
b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556)
|
||||
a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060)
|
||||
d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353)
|
||||
c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632)
|
||||
b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640)
|
||||
a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174)
|
||||
d = md5_hh(d, a, b, c, x[i + 0], 11, -358537222)
|
||||
c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979)
|
||||
b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189)
|
||||
a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487)
|
||||
d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835)
|
||||
c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520)
|
||||
b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651)
|
||||
|
||||
a = md5_ii(a, b, c, d, x[i + 0], 6, -198630844)
|
||||
d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415)
|
||||
c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905)
|
||||
b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055)
|
||||
a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571)
|
||||
d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606)
|
||||
c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523)
|
||||
b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799)
|
||||
a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359)
|
||||
d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744)
|
||||
c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380)
|
||||
b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649)
|
||||
a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070)
|
||||
d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379)
|
||||
c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259)
|
||||
b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551)
|
||||
|
||||
a = safe_add(a, olda)
|
||||
b = safe_add(b, oldb)
|
||||
c = safe_add(c, oldc)
|
||||
d = safe_add(d, oldd)
|
||||
}
|
||||
|
||||
return [a, b, c, d]
|
||||
}
|
||||
|
||||
/*
|
||||
* These functions implement the four basic operations the algorithm uses.
|
||||
*/
|
||||
function md5_cmn (q, a, b, x, s, t) {
|
||||
return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b)
|
||||
}
|
||||
|
||||
function md5_ff (a, b, c, d, x, s, t) {
|
||||
return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t)
|
||||
}
|
||||
|
||||
function md5_gg (a, b, c, d, x, s, t) {
|
||||
return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t)
|
||||
}
|
||||
|
||||
function md5_hh (a, b, c, d, x, s, t) {
|
||||
return md5_cmn(b ^ c ^ d, a, b, x, s, t)
|
||||
}
|
||||
|
||||
function md5_ii (a, b, c, d, x, s, t) {
|
||||
return md5_cmn(c ^ (b | (~d)), a, b, x, s, t)
|
||||
}
|
||||
|
||||
/*
|
||||
* Add integers, wrapping at 2^32. This uses 16-bit operations internally
|
||||
* to work around bugs in some JS interpreters.
|
||||
*/
|
||||
function safe_add (x, y) {
|
||||
var lsw = (x & 0xFFFF) + (y & 0xFFFF)
|
||||
var msw = (x >> 16) + (y >> 16) + (lsw >> 16)
|
||||
return (msw << 16) | (lsw & 0xFFFF)
|
||||
}
|
||||
|
||||
/*
|
||||
* Bitwise rotate a 32-bit number to the left.
|
||||
*/
|
||||
function bit_rol (num, cnt) {
|
||||
return (num << cnt) | (num >>> (32 - cnt))
|
||||
}
|
||||
|
||||
module.exports = function md5 (buf) {
|
||||
return makeHash(buf, core_md5)
|
||||
}
|
||||
37
node_modules/pbkdf2/node_modules/create-hash/package.json
generated
vendored
37
node_modules/pbkdf2/node_modules/create-hash/package.json
generated
vendored
@@ -1,37 +0,0 @@
|
||||
{
|
||||
"name": "create-hash",
|
||||
"version": "1.1.3",
|
||||
"description": "create hashes for browserify",
|
||||
"browser": "browser.js",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"standard": "standard",
|
||||
"test": "npm run-script standard && npm run-script unit",
|
||||
"unit": "node test.js | tspec"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git@github.com:crypto-browserify/createHash.git"
|
||||
},
|
||||
"keywords": [
|
||||
"crypto"
|
||||
],
|
||||
"author": "",
|
||||
"license": "MIT",
|
||||
"bugs": {
|
||||
"url": "https://github.com/crypto-browserify/createHash/issues"
|
||||
},
|
||||
"homepage": "https://github.com/crypto-browserify/createHash",
|
||||
"devDependencies": {
|
||||
"hash-test-vectors": "^1.3.2",
|
||||
"standard": "^5.3.1",
|
||||
"tap-spec": "^2.1.2",
|
||||
"tape": "^3.0.3"
|
||||
},
|
||||
"dependencies": {
|
||||
"cipher-base": "^1.0.1",
|
||||
"inherits": "^2.0.1",
|
||||
"ripemd160": "^2.0.0",
|
||||
"sha.js": "^2.4.0"
|
||||
}
|
||||
}
|
||||
19
node_modules/pbkdf2/node_modules/create-hash/readme.md
generated
vendored
19
node_modules/pbkdf2/node_modules/create-hash/readme.md
generated
vendored
@@ -1,19 +0,0 @@
|
||||
create-hash
|
||||
===
|
||||
|
||||
[](https://travis-ci.org/crypto-browserify/createHash)
|
||||
|
||||
Node style hashes for use in the browser, with native hash functions in node. Api is the same as hashes in node:
|
||||
|
||||
```js
|
||||
var createHash = require('create-hash');
|
||||
var hash = createHash('sha224');
|
||||
hash.update('synchronous write'); //optional encoding parameter
|
||||
hash.digest();// synchronously get result with optional encoding parameter
|
||||
|
||||
hash.write('write to it as a stream');
|
||||
hash.end();//remember it's a stream
|
||||
hash.read();//only if you ended it as a stream though
|
||||
```
|
||||
|
||||
To get the JavaScript version even in node do `require('create-hash/browser');`
|
||||
40
node_modules/pbkdf2/node_modules/create-hash/test.js
generated
vendored
40
node_modules/pbkdf2/node_modules/create-hash/test.js
generated
vendored
@@ -1,40 +0,0 @@
|
||||
var test = require('tape')
|
||||
|
||||
var algorithms = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160', 'ripemd160']
|
||||
var encodings = ['hex', 'base64'] // ignore binary
|
||||
var vectors = require('hash-test-vectors')
|
||||
vectors.forEach(function (vector) {
|
||||
vector.ripemd160 = vector.rmd160
|
||||
})
|
||||
var createHash = require('./browser')
|
||||
|
||||
algorithms.forEach(function (algorithm) {
|
||||
test('test ' + algorithm + ' against test vectors', function (t) {
|
||||
vectors.forEach(function (obj, i) {
|
||||
var input = new Buffer(obj.input, 'base64')
|
||||
var node = obj[algorithm]
|
||||
var js = createHash(algorithm).update(input).digest('hex')
|
||||
t.equal(js, node, algorithm + '(testVector[' + i + ']) == ' + node)
|
||||
})
|
||||
|
||||
encodings.forEach(function (encoding) {
|
||||
vectors.forEach(function (obj, i) {
|
||||
var input = new Buffer(obj.input, 'base64').toString(encoding)
|
||||
var node = obj[algorithm]
|
||||
var js = createHash(algorithm).update(input, encoding).digest('hex')
|
||||
t.equal(js, node, algorithm + '(testVector[' + i + '], ' + encoding + ') == ' + node)
|
||||
})
|
||||
})
|
||||
|
||||
vectors.forEach(function (obj, i) {
|
||||
var input = new Buffer(obj.input, 'base64')
|
||||
var node = obj[algorithm]
|
||||
var hash = createHash(algorithm)
|
||||
hash.end(input)
|
||||
var js = hash.read().toString('hex')
|
||||
t.equal(js, node, algorithm + '(testVector[' + i + ']) == ' + node)
|
||||
})
|
||||
|
||||
t.end()
|
||||
})
|
||||
})
|
||||
38
node_modules/pbkdf2/node_modules/hash-base/README.md
generated
vendored
38
node_modules/pbkdf2/node_modules/hash-base/README.md
generated
vendored
@@ -1,38 +0,0 @@
|
||||
# hash-base
|
||||
|
||||
[](https://www.npmjs.org/package/hash-base)
|
||||
[](https://travis-ci.org/crypto-browserify/hash-base)
|
||||
[](https://david-dm.org/crypto-browserify/hash-base#info=dependencies)
|
||||
|
||||
[](https://github.com/feross/standard)
|
||||
|
||||
Abstract base class to inherit from if you want to create streams implementing the same API as node crypto [Hash][1] (for [Cipher][2] / [Decipher][3] check [crypto-browserify/cipher-base][4]).
|
||||
|
||||
## Example
|
||||
|
||||
```js
|
||||
function MyHash () {
|
||||
HashBase.call(64) // in bytes
|
||||
}
|
||||
|
||||
inherti(MyHash, HashBase)
|
||||
|
||||
MyHash.prototype._update = function () {
|
||||
// hashing one block with buffer this._block
|
||||
}
|
||||
|
||||
MyHash.prototype._digest = function () {
|
||||
// create padding and produce result
|
||||
}
|
||||
```
|
||||
You also can check [source code](index.js) or [crypto-browserify/md5.js][5]
|
||||
|
||||
## LICENSE
|
||||
|
||||
MIT
|
||||
|
||||
[1]: https://nodejs.org/api/crypto.html#crypto_class_hash
|
||||
[2]: https://nodejs.org/api/crypto.html#crypto_class_cipher
|
||||
[3]: https://nodejs.org/api/crypto.html#crypto_class_decipher
|
||||
[4]: https://github.com/crypto-browserify/cipher-base
|
||||
[5]: https://github.com/crypto-browserify/md5.js
|
||||
83
node_modules/pbkdf2/node_modules/hash-base/index.js
generated
vendored
83
node_modules/pbkdf2/node_modules/hash-base/index.js
generated
vendored
@@ -1,83 +0,0 @@
|
||||
'use strict'
|
||||
var Transform = require('stream').Transform
|
||||
var inherits = require('inherits')
|
||||
|
||||
function HashBase (blockSize) {
|
||||
Transform.call(this)
|
||||
|
||||
this._block = new Buffer(blockSize)
|
||||
this._blockSize = blockSize
|
||||
this._blockOffset = 0
|
||||
this._length = [0, 0, 0, 0]
|
||||
|
||||
this._finalized = false
|
||||
}
|
||||
|
||||
inherits(HashBase, Transform)
|
||||
|
||||
HashBase.prototype._transform = function (chunk, encoding, callback) {
|
||||
var error = null
|
||||
try {
|
||||
if (encoding !== 'buffer') chunk = new Buffer(chunk, encoding)
|
||||
this.update(chunk)
|
||||
} catch (err) {
|
||||
error = err
|
||||
}
|
||||
|
||||
callback(error)
|
||||
}
|
||||
|
||||
HashBase.prototype._flush = function (callback) {
|
||||
var error = null
|
||||
try {
|
||||
this.push(this._digest())
|
||||
} catch (err) {
|
||||
error = err
|
||||
}
|
||||
|
||||
callback(error)
|
||||
}
|
||||
|
||||
HashBase.prototype.update = function (data, encoding) {
|
||||
if (!Buffer.isBuffer(data) && typeof data !== 'string') throw new TypeError('Data must be a string or a buffer')
|
||||
if (this._finalized) throw new Error('Digest already called')
|
||||
if (!Buffer.isBuffer(data)) data = new Buffer(data, encoding || 'binary')
|
||||
|
||||
// consume data
|
||||
var block = this._block
|
||||
var offset = 0
|
||||
while (this._blockOffset + data.length - offset >= this._blockSize) {
|
||||
for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++]
|
||||
this._update()
|
||||
this._blockOffset = 0
|
||||
}
|
||||
while (offset < data.length) block[this._blockOffset++] = data[offset++]
|
||||
|
||||
// update length
|
||||
for (var j = 0, carry = data.length * 8; carry > 0; ++j) {
|
||||
this._length[j] += carry
|
||||
carry = (this._length[j] / 0x0100000000) | 0
|
||||
if (carry > 0) this._length[j] -= 0x0100000000 * carry
|
||||
}
|
||||
|
||||
return this
|
||||
}
|
||||
|
||||
HashBase.prototype._update = function (data) {
|
||||
throw new Error('_update is not implemented')
|
||||
}
|
||||
|
||||
HashBase.prototype.digest = function (encoding) {
|
||||
if (this._finalized) throw new Error('Digest already called')
|
||||
this._finalized = true
|
||||
|
||||
var digest = this._digest()
|
||||
if (encoding !== undefined) digest = digest.toString(encoding)
|
||||
return digest
|
||||
}
|
||||
|
||||
HashBase.prototype._digest = function () {
|
||||
throw new Error('_digest is not implemented')
|
||||
}
|
||||
|
||||
module.exports = HashBase
|
||||
37
node_modules/pbkdf2/node_modules/hash-base/package.json
generated
vendored
37
node_modules/pbkdf2/node_modules/hash-base/package.json
generated
vendored
@@ -1,37 +0,0 @@
|
||||
{
|
||||
"name": "hash-base",
|
||||
"version": "2.0.2",
|
||||
"description": "abstract base class for hash-streams",
|
||||
"keywords": [
|
||||
"hash",
|
||||
"stream"
|
||||
],
|
||||
"homepage": "https://github.com/crypto-browserify/hash-base",
|
||||
"bugs": {
|
||||
"url": "https://github.com/crypto-browserify/hash-base/issues"
|
||||
},
|
||||
"license": "MIT",
|
||||
"author": "Kirill Fomichev <fanatid@ya.ru> (https://github.com/fanatid)",
|
||||
"files": [
|
||||
"index.js"
|
||||
],
|
||||
"main": "index.js",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/crypto-browserify/hash-base.git"
|
||||
},
|
||||
"scripts": {
|
||||
"coverage": "nyc node test/*.js",
|
||||
"lint": "standard",
|
||||
"test": "npm run lint && npm run unit",
|
||||
"unit": "node test/*.js"
|
||||
},
|
||||
"dependencies": {
|
||||
"inherits": "^2.0.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"nyc": "^6.1.1",
|
||||
"standard": "^6.0.8",
|
||||
"tape": "^4.2.0"
|
||||
}
|
||||
}
|
||||
72
node_modules/pbkdf2/node_modules/ripemd160/CHANGELOG.md
generated
vendored
72
node_modules/pbkdf2/node_modules/ripemd160/CHANGELOG.md
generated
vendored
@@ -1,72 +0,0 @@
|
||||
2.0.1 / 2016-06-22
|
||||
------------------
|
||||
- added LICENSE file.
|
||||
|
||||
2.0.0 / 2016-04-11
|
||||
------------------
|
||||
- rewritten, license change BSD-3 to MIT. [#13][#13]
|
||||
- stream support [#13][#13]
|
||||
|
||||
1.0.1 / 2015-05-05
|
||||
------------------
|
||||
- standard formatting
|
||||
|
||||
1.0.0 / 2015-01-14
|
||||
------------------
|
||||
- updated dev deps
|
||||
- added more test fixtures
|
||||
- updated readme with usage, testing, etc
|
||||
- moved from https://github.com/cryptocoinjs/ripemd160 to https://github.com/crypto-browserify/ripemd160
|
||||
|
||||
0.2.1 / 2014-12-31
|
||||
------------------
|
||||
- made license clear in `package.json`
|
||||
- deleted `Makefile`, moved targets to `package.json`
|
||||
- removed `terst` for `assert`
|
||||
|
||||
0.2.0 / 2014-03-09
|
||||
------------------
|
||||
* removed bower.json and component.json
|
||||
* changed 4 spacing to 2
|
||||
* returns `Buffer` type now, input must be Array, Uint8Array, Buffer, or string
|
||||
* remove deps: `convert-hex` and `convert-string`
|
||||
|
||||
0.1.0 / 2013-11-20
|
||||
------------------
|
||||
* changed package name
|
||||
* removed AMD support
|
||||
|
||||
0.0.2 / 2013-11-06
|
||||
------------------
|
||||
* fixed component.json file
|
||||
|
||||
0.0.1 / 2013-11-03
|
||||
------------------
|
||||
* initial release
|
||||
|
||||
<!--- add streams support, unroll loops [enhancement] -->
|
||||
[#13]: https://github.com/crypto-browserify/ripemd160/pull/13
|
||||
<!--- Update all dependencies 🌴 [greenkeeper] -->
|
||||
[#12]: https://github.com/crypto-browserify/ripemd160/pull/12
|
||||
<!--- little optimizations [enhancement] -->
|
||||
[#11]: https://github.com/crypto-browserify/ripemd160/pull/11
|
||||
<!--- Added LICENSE file to repo -->
|
||||
[#10]: https://github.com/crypto-browserify/ripemd160/pull/10
|
||||
<!--- Add LICENCE file -->
|
||||
[#9]: https://github.com/crypto-browserify/ripemd160/pull/9
|
||||
<!--- Support streaming [enhancement] -->
|
||||
[#8]: https://github.com/crypto-browserify/ripemd160/issues/8
|
||||
<!--- Unroll loops [enhancement] -->
|
||||
[#7]: https://github.com/crypto-browserify/ripemd160/pull/7
|
||||
<!--- Use SPDX-standard license naming -->
|
||||
[#6]: https://github.com/crypto-browserify/ripemd160/pull/6
|
||||
<!--- License -->
|
||||
[#5]: https://github.com/crypto-browserify/ripemd160/issues/5
|
||||
<!--- Add BSD license to package.json -->
|
||||
[#4]: https://github.com/crypto-browserify/ripemd160/pull/4
|
||||
<!--- Indicate byte array inputs are supported too -->
|
||||
[#3]: https://github.com/crypto-browserify/ripemd160/pull/3
|
||||
<!--- Node-specific implementation -->
|
||||
[#2]: https://github.com/crypto-browserify/ripemd160/pull/2
|
||||
<!--- Incorrect name of convert-string dependency in bower.json -->
|
||||
[#1]: https://github.com/crypto-browserify/ripemd160/pull/1
|
||||
21
node_modules/pbkdf2/node_modules/ripemd160/LICENSE.md
generated
vendored
21
node_modules/pbkdf2/node_modules/ripemd160/LICENSE.md
generated
vendored
@@ -1,21 +0,0 @@
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2016 crypto-browserify
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
27
node_modules/pbkdf2/node_modules/ripemd160/README.md
generated
vendored
27
node_modules/pbkdf2/node_modules/ripemd160/README.md
generated
vendored
@@ -1,27 +0,0 @@
|
||||
# ripemd160
|
||||
|
||||
[](https://www.npmjs.org/package/ripemd160)
|
||||
[](https://travis-ci.org/crypto-browserify/ripemd160)
|
||||
[](https://david-dm.org/crypto-browserify/ripemd160#info=dependencies)
|
||||
|
||||
[](https://github.com/feross/standard)
|
||||
|
||||
Node style `ripemd160` on pure JavaScript.
|
||||
|
||||
## Example
|
||||
|
||||
```js
|
||||
var RIPEMD160 = require('ripemd160')
|
||||
|
||||
console.log(new RIPEMD160().update('42').digest('hex'))
|
||||
// => 0df020ba32aa9b8b904471ff582ce6b579bf8bc8
|
||||
|
||||
var ripemd160stream = new RIPEMD160()
|
||||
ripemd160stream.end('42')
|
||||
console.log(ripemd160stream.read().toString('hex'))
|
||||
// => 0df020ba32aa9b8b904471ff582ce6b579bf8bc8
|
||||
```
|
||||
|
||||
## LICENSE
|
||||
|
||||
MIT
|
||||
291
node_modules/pbkdf2/node_modules/ripemd160/index.js
generated
vendored
291
node_modules/pbkdf2/node_modules/ripemd160/index.js
generated
vendored
@@ -1,291 +0,0 @@
|
||||
'use strict'
|
||||
var inherits = require('inherits')
|
||||
var HashBase = require('hash-base')
|
||||
|
||||
function RIPEMD160 () {
|
||||
HashBase.call(this, 64)
|
||||
|
||||
// state
|
||||
this._a = 0x67452301
|
||||
this._b = 0xefcdab89
|
||||
this._c = 0x98badcfe
|
||||
this._d = 0x10325476
|
||||
this._e = 0xc3d2e1f0
|
||||
}
|
||||
|
||||
inherits(RIPEMD160, HashBase)
|
||||
|
||||
RIPEMD160.prototype._update = function () {
|
||||
var m = new Array(16)
|
||||
for (var i = 0; i < 16; ++i) m[i] = this._block.readInt32LE(i * 4)
|
||||
|
||||
var al = this._a
|
||||
var bl = this._b
|
||||
var cl = this._c
|
||||
var dl = this._d
|
||||
var el = this._e
|
||||
|
||||
// Mj = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15
|
||||
// K = 0x00000000
|
||||
// Sj = 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8
|
||||
al = fn1(al, bl, cl, dl, el, m[0], 0x00000000, 11); cl = rotl(cl, 10)
|
||||
el = fn1(el, al, bl, cl, dl, m[1], 0x00000000, 14); bl = rotl(bl, 10)
|
||||
dl = fn1(dl, el, al, bl, cl, m[2], 0x00000000, 15); al = rotl(al, 10)
|
||||
cl = fn1(cl, dl, el, al, bl, m[3], 0x00000000, 12); el = rotl(el, 10)
|
||||
bl = fn1(bl, cl, dl, el, al, m[4], 0x00000000, 5); dl = rotl(dl, 10)
|
||||
al = fn1(al, bl, cl, dl, el, m[5], 0x00000000, 8); cl = rotl(cl, 10)
|
||||
el = fn1(el, al, bl, cl, dl, m[6], 0x00000000, 7); bl = rotl(bl, 10)
|
||||
dl = fn1(dl, el, al, bl, cl, m[7], 0x00000000, 9); al = rotl(al, 10)
|
||||
cl = fn1(cl, dl, el, al, bl, m[8], 0x00000000, 11); el = rotl(el, 10)
|
||||
bl = fn1(bl, cl, dl, el, al, m[9], 0x00000000, 13); dl = rotl(dl, 10)
|
||||
al = fn1(al, bl, cl, dl, el, m[10], 0x00000000, 14); cl = rotl(cl, 10)
|
||||
el = fn1(el, al, bl, cl, dl, m[11], 0x00000000, 15); bl = rotl(bl, 10)
|
||||
dl = fn1(dl, el, al, bl, cl, m[12], 0x00000000, 6); al = rotl(al, 10)
|
||||
cl = fn1(cl, dl, el, al, bl, m[13], 0x00000000, 7); el = rotl(el, 10)
|
||||
bl = fn1(bl, cl, dl, el, al, m[14], 0x00000000, 9); dl = rotl(dl, 10)
|
||||
al = fn1(al, bl, cl, dl, el, m[15], 0x00000000, 8); cl = rotl(cl, 10)
|
||||
|
||||
// Mj = 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8
|
||||
// K = 0x5a827999
|
||||
// Sj = 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12
|
||||
el = fn2(el, al, bl, cl, dl, m[7], 0x5a827999, 7); bl = rotl(bl, 10)
|
||||
dl = fn2(dl, el, al, bl, cl, m[4], 0x5a827999, 6); al = rotl(al, 10)
|
||||
cl = fn2(cl, dl, el, al, bl, m[13], 0x5a827999, 8); el = rotl(el, 10)
|
||||
bl = fn2(bl, cl, dl, el, al, m[1], 0x5a827999, 13); dl = rotl(dl, 10)
|
||||
al = fn2(al, bl, cl, dl, el, m[10], 0x5a827999, 11); cl = rotl(cl, 10)
|
||||
el = fn2(el, al, bl, cl, dl, m[6], 0x5a827999, 9); bl = rotl(bl, 10)
|
||||
dl = fn2(dl, el, al, bl, cl, m[15], 0x5a827999, 7); al = rotl(al, 10)
|
||||
cl = fn2(cl, dl, el, al, bl, m[3], 0x5a827999, 15); el = rotl(el, 10)
|
||||
bl = fn2(bl, cl, dl, el, al, m[12], 0x5a827999, 7); dl = rotl(dl, 10)
|
||||
al = fn2(al, bl, cl, dl, el, m[0], 0x5a827999, 12); cl = rotl(cl, 10)
|
||||
el = fn2(el, al, bl, cl, dl, m[9], 0x5a827999, 15); bl = rotl(bl, 10)
|
||||
dl = fn2(dl, el, al, bl, cl, m[5], 0x5a827999, 9); al = rotl(al, 10)
|
||||
cl = fn2(cl, dl, el, al, bl, m[2], 0x5a827999, 11); el = rotl(el, 10)
|
||||
bl = fn2(bl, cl, dl, el, al, m[14], 0x5a827999, 7); dl = rotl(dl, 10)
|
||||
al = fn2(al, bl, cl, dl, el, m[11], 0x5a827999, 13); cl = rotl(cl, 10)
|
||||
el = fn2(el, al, bl, cl, dl, m[8], 0x5a827999, 12); bl = rotl(bl, 10)
|
||||
|
||||
// Mj = 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12
|
||||
// K = 0x6ed9eba1
|
||||
// Sj = 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5
|
||||
dl = fn3(dl, el, al, bl, cl, m[3], 0x6ed9eba1, 11); al = rotl(al, 10)
|
||||
cl = fn3(cl, dl, el, al, bl, m[10], 0x6ed9eba1, 13); el = rotl(el, 10)
|
||||
bl = fn3(bl, cl, dl, el, al, m[14], 0x6ed9eba1, 6); dl = rotl(dl, 10)
|
||||
al = fn3(al, bl, cl, dl, el, m[4], 0x6ed9eba1, 7); cl = rotl(cl, 10)
|
||||
el = fn3(el, al, bl, cl, dl, m[9], 0x6ed9eba1, 14); bl = rotl(bl, 10)
|
||||
dl = fn3(dl, el, al, bl, cl, m[15], 0x6ed9eba1, 9); al = rotl(al, 10)
|
||||
cl = fn3(cl, dl, el, al, bl, m[8], 0x6ed9eba1, 13); el = rotl(el, 10)
|
||||
bl = fn3(bl, cl, dl, el, al, m[1], 0x6ed9eba1, 15); dl = rotl(dl, 10)
|
||||
al = fn3(al, bl, cl, dl, el, m[2], 0x6ed9eba1, 14); cl = rotl(cl, 10)
|
||||
el = fn3(el, al, bl, cl, dl, m[7], 0x6ed9eba1, 8); bl = rotl(bl, 10)
|
||||
dl = fn3(dl, el, al, bl, cl, m[0], 0x6ed9eba1, 13); al = rotl(al, 10)
|
||||
cl = fn3(cl, dl, el, al, bl, m[6], 0x6ed9eba1, 6); el = rotl(el, 10)
|
||||
bl = fn3(bl, cl, dl, el, al, m[13], 0x6ed9eba1, 5); dl = rotl(dl, 10)
|
||||
al = fn3(al, bl, cl, dl, el, m[11], 0x6ed9eba1, 12); cl = rotl(cl, 10)
|
||||
el = fn3(el, al, bl, cl, dl, m[5], 0x6ed9eba1, 7); bl = rotl(bl, 10)
|
||||
dl = fn3(dl, el, al, bl, cl, m[12], 0x6ed9eba1, 5); al = rotl(al, 10)
|
||||
|
||||
// Mj = 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2
|
||||
// K = 0x8f1bbcdc
|
||||
// Sj = 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12
|
||||
cl = fn4(cl, dl, el, al, bl, m[1], 0x8f1bbcdc, 11); el = rotl(el, 10)
|
||||
bl = fn4(bl, cl, dl, el, al, m[9], 0x8f1bbcdc, 12); dl = rotl(dl, 10)
|
||||
al = fn4(al, bl, cl, dl, el, m[11], 0x8f1bbcdc, 14); cl = rotl(cl, 10)
|
||||
el = fn4(el, al, bl, cl, dl, m[10], 0x8f1bbcdc, 15); bl = rotl(bl, 10)
|
||||
dl = fn4(dl, el, al, bl, cl, m[0], 0x8f1bbcdc, 14); al = rotl(al, 10)
|
||||
cl = fn4(cl, dl, el, al, bl, m[8], 0x8f1bbcdc, 15); el = rotl(el, 10)
|
||||
bl = fn4(bl, cl, dl, el, al, m[12], 0x8f1bbcdc, 9); dl = rotl(dl, 10)
|
||||
al = fn4(al, bl, cl, dl, el, m[4], 0x8f1bbcdc, 8); cl = rotl(cl, 10)
|
||||
el = fn4(el, al, bl, cl, dl, m[13], 0x8f1bbcdc, 9); bl = rotl(bl, 10)
|
||||
dl = fn4(dl, el, al, bl, cl, m[3], 0x8f1bbcdc, 14); al = rotl(al, 10)
|
||||
cl = fn4(cl, dl, el, al, bl, m[7], 0x8f1bbcdc, 5); el = rotl(el, 10)
|
||||
bl = fn4(bl, cl, dl, el, al, m[15], 0x8f1bbcdc, 6); dl = rotl(dl, 10)
|
||||
al = fn4(al, bl, cl, dl, el, m[14], 0x8f1bbcdc, 8); cl = rotl(cl, 10)
|
||||
el = fn4(el, al, bl, cl, dl, m[5], 0x8f1bbcdc, 6); bl = rotl(bl, 10)
|
||||
dl = fn4(dl, el, al, bl, cl, m[6], 0x8f1bbcdc, 5); al = rotl(al, 10)
|
||||
cl = fn4(cl, dl, el, al, bl, m[2], 0x8f1bbcdc, 12); el = rotl(el, 10)
|
||||
|
||||
// Mj = 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13
|
||||
// K = 0xa953fd4e
|
||||
// Sj = 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6
|
||||
bl = fn5(bl, cl, dl, el, al, m[4], 0xa953fd4e, 9); dl = rotl(dl, 10)
|
||||
al = fn5(al, bl, cl, dl, el, m[0], 0xa953fd4e, 15); cl = rotl(cl, 10)
|
||||
el = fn5(el, al, bl, cl, dl, m[5], 0xa953fd4e, 5); bl = rotl(bl, 10)
|
||||
dl = fn5(dl, el, al, bl, cl, m[9], 0xa953fd4e, 11); al = rotl(al, 10)
|
||||
cl = fn5(cl, dl, el, al, bl, m[7], 0xa953fd4e, 6); el = rotl(el, 10)
|
||||
bl = fn5(bl, cl, dl, el, al, m[12], 0xa953fd4e, 8); dl = rotl(dl, 10)
|
||||
al = fn5(al, bl, cl, dl, el, m[2], 0xa953fd4e, 13); cl = rotl(cl, 10)
|
||||
el = fn5(el, al, bl, cl, dl, m[10], 0xa953fd4e, 12); bl = rotl(bl, 10)
|
||||
dl = fn5(dl, el, al, bl, cl, m[14], 0xa953fd4e, 5); al = rotl(al, 10)
|
||||
cl = fn5(cl, dl, el, al, bl, m[1], 0xa953fd4e, 12); el = rotl(el, 10)
|
||||
bl = fn5(bl, cl, dl, el, al, m[3], 0xa953fd4e, 13); dl = rotl(dl, 10)
|
||||
al = fn5(al, bl, cl, dl, el, m[8], 0xa953fd4e, 14); cl = rotl(cl, 10)
|
||||
el = fn5(el, al, bl, cl, dl, m[11], 0xa953fd4e, 11); bl = rotl(bl, 10)
|
||||
dl = fn5(dl, el, al, bl, cl, m[6], 0xa953fd4e, 8); al = rotl(al, 10)
|
||||
cl = fn5(cl, dl, el, al, bl, m[15], 0xa953fd4e, 5); el = rotl(el, 10)
|
||||
bl = fn5(bl, cl, dl, el, al, m[13], 0xa953fd4e, 6); dl = rotl(dl, 10)
|
||||
|
||||
var ar = this._a
|
||||
var br = this._b
|
||||
var cr = this._c
|
||||
var dr = this._d
|
||||
var er = this._e
|
||||
|
||||
// M'j = 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12
|
||||
// K' = 0x50a28be6
|
||||
// S'j = 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6
|
||||
ar = fn5(ar, br, cr, dr, er, m[5], 0x50a28be6, 8); cr = rotl(cr, 10)
|
||||
er = fn5(er, ar, br, cr, dr, m[14], 0x50a28be6, 9); br = rotl(br, 10)
|
||||
dr = fn5(dr, er, ar, br, cr, m[7], 0x50a28be6, 9); ar = rotl(ar, 10)
|
||||
cr = fn5(cr, dr, er, ar, br, m[0], 0x50a28be6, 11); er = rotl(er, 10)
|
||||
br = fn5(br, cr, dr, er, ar, m[9], 0x50a28be6, 13); dr = rotl(dr, 10)
|
||||
ar = fn5(ar, br, cr, dr, er, m[2], 0x50a28be6, 15); cr = rotl(cr, 10)
|
||||
er = fn5(er, ar, br, cr, dr, m[11], 0x50a28be6, 15); br = rotl(br, 10)
|
||||
dr = fn5(dr, er, ar, br, cr, m[4], 0x50a28be6, 5); ar = rotl(ar, 10)
|
||||
cr = fn5(cr, dr, er, ar, br, m[13], 0x50a28be6, 7); er = rotl(er, 10)
|
||||
br = fn5(br, cr, dr, er, ar, m[6], 0x50a28be6, 7); dr = rotl(dr, 10)
|
||||
ar = fn5(ar, br, cr, dr, er, m[15], 0x50a28be6, 8); cr = rotl(cr, 10)
|
||||
er = fn5(er, ar, br, cr, dr, m[8], 0x50a28be6, 11); br = rotl(br, 10)
|
||||
dr = fn5(dr, er, ar, br, cr, m[1], 0x50a28be6, 14); ar = rotl(ar, 10)
|
||||
cr = fn5(cr, dr, er, ar, br, m[10], 0x50a28be6, 14); er = rotl(er, 10)
|
||||
br = fn5(br, cr, dr, er, ar, m[3], 0x50a28be6, 12); dr = rotl(dr, 10)
|
||||
ar = fn5(ar, br, cr, dr, er, m[12], 0x50a28be6, 6); cr = rotl(cr, 10)
|
||||
|
||||
// M'j = 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2
|
||||
// K' = 0x5c4dd124
|
||||
// S'j = 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11
|
||||
er = fn4(er, ar, br, cr, dr, m[6], 0x5c4dd124, 9); br = rotl(br, 10)
|
||||
dr = fn4(dr, er, ar, br, cr, m[11], 0x5c4dd124, 13); ar = rotl(ar, 10)
|
||||
cr = fn4(cr, dr, er, ar, br, m[3], 0x5c4dd124, 15); er = rotl(er, 10)
|
||||
br = fn4(br, cr, dr, er, ar, m[7], 0x5c4dd124, 7); dr = rotl(dr, 10)
|
||||
ar = fn4(ar, br, cr, dr, er, m[0], 0x5c4dd124, 12); cr = rotl(cr, 10)
|
||||
er = fn4(er, ar, br, cr, dr, m[13], 0x5c4dd124, 8); br = rotl(br, 10)
|
||||
dr = fn4(dr, er, ar, br, cr, m[5], 0x5c4dd124, 9); ar = rotl(ar, 10)
|
||||
cr = fn4(cr, dr, er, ar, br, m[10], 0x5c4dd124, 11); er = rotl(er, 10)
|
||||
br = fn4(br, cr, dr, er, ar, m[14], 0x5c4dd124, 7); dr = rotl(dr, 10)
|
||||
ar = fn4(ar, br, cr, dr, er, m[15], 0x5c4dd124, 7); cr = rotl(cr, 10)
|
||||
er = fn4(er, ar, br, cr, dr, m[8], 0x5c4dd124, 12); br = rotl(br, 10)
|
||||
dr = fn4(dr, er, ar, br, cr, m[12], 0x5c4dd124, 7); ar = rotl(ar, 10)
|
||||
cr = fn4(cr, dr, er, ar, br, m[4], 0x5c4dd124, 6); er = rotl(er, 10)
|
||||
br = fn4(br, cr, dr, er, ar, m[9], 0x5c4dd124, 15); dr = rotl(dr, 10)
|
||||
ar = fn4(ar, br, cr, dr, er, m[1], 0x5c4dd124, 13); cr = rotl(cr, 10)
|
||||
er = fn4(er, ar, br, cr, dr, m[2], 0x5c4dd124, 11); br = rotl(br, 10)
|
||||
|
||||
// M'j = 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13
|
||||
// K' = 0x6d703ef3
|
||||
// S'j = 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5
|
||||
dr = fn3(dr, er, ar, br, cr, m[15], 0x6d703ef3, 9); ar = rotl(ar, 10)
|
||||
cr = fn3(cr, dr, er, ar, br, m[5], 0x6d703ef3, 7); er = rotl(er, 10)
|
||||
br = fn3(br, cr, dr, er, ar, m[1], 0x6d703ef3, 15); dr = rotl(dr, 10)
|
||||
ar = fn3(ar, br, cr, dr, er, m[3], 0x6d703ef3, 11); cr = rotl(cr, 10)
|
||||
er = fn3(er, ar, br, cr, dr, m[7], 0x6d703ef3, 8); br = rotl(br, 10)
|
||||
dr = fn3(dr, er, ar, br, cr, m[14], 0x6d703ef3, 6); ar = rotl(ar, 10)
|
||||
cr = fn3(cr, dr, er, ar, br, m[6], 0x6d703ef3, 6); er = rotl(er, 10)
|
||||
br = fn3(br, cr, dr, er, ar, m[9], 0x6d703ef3, 14); dr = rotl(dr, 10)
|
||||
ar = fn3(ar, br, cr, dr, er, m[11], 0x6d703ef3, 12); cr = rotl(cr, 10)
|
||||
er = fn3(er, ar, br, cr, dr, m[8], 0x6d703ef3, 13); br = rotl(br, 10)
|
||||
dr = fn3(dr, er, ar, br, cr, m[12], 0x6d703ef3, 5); ar = rotl(ar, 10)
|
||||
cr = fn3(cr, dr, er, ar, br, m[2], 0x6d703ef3, 14); er = rotl(er, 10)
|
||||
br = fn3(br, cr, dr, er, ar, m[10], 0x6d703ef3, 13); dr = rotl(dr, 10)
|
||||
ar = fn3(ar, br, cr, dr, er, m[0], 0x6d703ef3, 13); cr = rotl(cr, 10)
|
||||
er = fn3(er, ar, br, cr, dr, m[4], 0x6d703ef3, 7); br = rotl(br, 10)
|
||||
dr = fn3(dr, er, ar, br, cr, m[13], 0x6d703ef3, 5); ar = rotl(ar, 10)
|
||||
|
||||
// M'j = 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14
|
||||
// K' = 0x7a6d76e9
|
||||
// S'j = 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8
|
||||
cr = fn2(cr, dr, er, ar, br, m[8], 0x7a6d76e9, 15); er = rotl(er, 10)
|
||||
br = fn2(br, cr, dr, er, ar, m[6], 0x7a6d76e9, 5); dr = rotl(dr, 10)
|
||||
ar = fn2(ar, br, cr, dr, er, m[4], 0x7a6d76e9, 8); cr = rotl(cr, 10)
|
||||
er = fn2(er, ar, br, cr, dr, m[1], 0x7a6d76e9, 11); br = rotl(br, 10)
|
||||
dr = fn2(dr, er, ar, br, cr, m[3], 0x7a6d76e9, 14); ar = rotl(ar, 10)
|
||||
cr = fn2(cr, dr, er, ar, br, m[11], 0x7a6d76e9, 14); er = rotl(er, 10)
|
||||
br = fn2(br, cr, dr, er, ar, m[15], 0x7a6d76e9, 6); dr = rotl(dr, 10)
|
||||
ar = fn2(ar, br, cr, dr, er, m[0], 0x7a6d76e9, 14); cr = rotl(cr, 10)
|
||||
er = fn2(er, ar, br, cr, dr, m[5], 0x7a6d76e9, 6); br = rotl(br, 10)
|
||||
dr = fn2(dr, er, ar, br, cr, m[12], 0x7a6d76e9, 9); ar = rotl(ar, 10)
|
||||
cr = fn2(cr, dr, er, ar, br, m[2], 0x7a6d76e9, 12); er = rotl(er, 10)
|
||||
br = fn2(br, cr, dr, er, ar, m[13], 0x7a6d76e9, 9); dr = rotl(dr, 10)
|
||||
ar = fn2(ar, br, cr, dr, er, m[9], 0x7a6d76e9, 12); cr = rotl(cr, 10)
|
||||
er = fn2(er, ar, br, cr, dr, m[7], 0x7a6d76e9, 5); br = rotl(br, 10)
|
||||
dr = fn2(dr, er, ar, br, cr, m[10], 0x7a6d76e9, 15); ar = rotl(ar, 10)
|
||||
cr = fn2(cr, dr, er, ar, br, m[14], 0x7a6d76e9, 8); er = rotl(er, 10)
|
||||
|
||||
// M'j = 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11
|
||||
// K' = 0x00000000
|
||||
// S'j = 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11
|
||||
br = fn1(br, cr, dr, er, ar, m[12], 0x00000000, 8); dr = rotl(dr, 10)
|
||||
ar = fn1(ar, br, cr, dr, er, m[15], 0x00000000, 5); cr = rotl(cr, 10)
|
||||
er = fn1(er, ar, br, cr, dr, m[10], 0x00000000, 12); br = rotl(br, 10)
|
||||
dr = fn1(dr, er, ar, br, cr, m[4], 0x00000000, 9); ar = rotl(ar, 10)
|
||||
cr = fn1(cr, dr, er, ar, br, m[1], 0x00000000, 12); er = rotl(er, 10)
|
||||
br = fn1(br, cr, dr, er, ar, m[5], 0x00000000, 5); dr = rotl(dr, 10)
|
||||
ar = fn1(ar, br, cr, dr, er, m[8], 0x00000000, 14); cr = rotl(cr, 10)
|
||||
er = fn1(er, ar, br, cr, dr, m[7], 0x00000000, 6); br = rotl(br, 10)
|
||||
dr = fn1(dr, er, ar, br, cr, m[6], 0x00000000, 8); ar = rotl(ar, 10)
|
||||
cr = fn1(cr, dr, er, ar, br, m[2], 0x00000000, 13); er = rotl(er, 10)
|
||||
br = fn1(br, cr, dr, er, ar, m[13], 0x00000000, 6); dr = rotl(dr, 10)
|
||||
ar = fn1(ar, br, cr, dr, er, m[14], 0x00000000, 5); cr = rotl(cr, 10)
|
||||
er = fn1(er, ar, br, cr, dr, m[0], 0x00000000, 15); br = rotl(br, 10)
|
||||
dr = fn1(dr, er, ar, br, cr, m[3], 0x00000000, 13); ar = rotl(ar, 10)
|
||||
cr = fn1(cr, dr, er, ar, br, m[9], 0x00000000, 11); er = rotl(er, 10)
|
||||
br = fn1(br, cr, dr, er, ar, m[11], 0x00000000, 11); dr = rotl(dr, 10)
|
||||
|
||||
// change state
|
||||
var t = (this._b + cl + dr) | 0
|
||||
this._b = (this._c + dl + er) | 0
|
||||
this._c = (this._d + el + ar) | 0
|
||||
this._d = (this._e + al + br) | 0
|
||||
this._e = (this._a + bl + cr) | 0
|
||||
this._a = t
|
||||
}
|
||||
|
||||
RIPEMD160.prototype._digest = function () {
|
||||
// create padding and handle blocks
|
||||
this._block[this._blockOffset++] = 0x80
|
||||
if (this._blockOffset > 56) {
|
||||
this._block.fill(0, this._blockOffset, 64)
|
||||
this._update()
|
||||
this._blockOffset = 0
|
||||
}
|
||||
|
||||
this._block.fill(0, this._blockOffset, 56)
|
||||
this._block.writeUInt32LE(this._length[0], 56)
|
||||
this._block.writeUInt32LE(this._length[1], 60)
|
||||
this._update()
|
||||
|
||||
// produce result
|
||||
var buffer = new Buffer(20)
|
||||
buffer.writeInt32LE(this._a, 0)
|
||||
buffer.writeInt32LE(this._b, 4)
|
||||
buffer.writeInt32LE(this._c, 8)
|
||||
buffer.writeInt32LE(this._d, 12)
|
||||
buffer.writeInt32LE(this._e, 16)
|
||||
return buffer
|
||||
}
|
||||
|
||||
function rotl (x, n) {
|
||||
return (x << n) | (x >>> (32 - n))
|
||||
}
|
||||
|
||||
function fn1 (a, b, c, d, e, m, k, s) {
|
||||
return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0
|
||||
}
|
||||
|
||||
function fn2 (a, b, c, d, e, m, k, s) {
|
||||
return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0
|
||||
}
|
||||
|
||||
function fn3 (a, b, c, d, e, m, k, s) {
|
||||
return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0
|
||||
}
|
||||
|
||||
function fn4 (a, b, c, d, e, m, k, s) {
|
||||
return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0
|
||||
}
|
||||
|
||||
function fn5 (a, b, c, d, e, m, k, s) {
|
||||
return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0
|
||||
}
|
||||
|
||||
module.exports = RIPEMD160
|
||||
37
node_modules/pbkdf2/node_modules/ripemd160/package.json
generated
vendored
37
node_modules/pbkdf2/node_modules/ripemd160/package.json
generated
vendored
@@ -1,37 +0,0 @@
|
||||
{
|
||||
"name": "ripemd160",
|
||||
"version": "2.0.1",
|
||||
"description": "Compute ripemd160 of bytes or strings.",
|
||||
"keywords": [
|
||||
"string",
|
||||
"strings",
|
||||
"ripemd160",
|
||||
"ripe160",
|
||||
"bitcoin",
|
||||
"bytes",
|
||||
"cryptography"
|
||||
],
|
||||
"license": "MIT",
|
||||
"files": [
|
||||
"index.js"
|
||||
],
|
||||
"main": "./index",
|
||||
"repository": {
|
||||
"url": "https://github.com/crypto-browserify/ripemd160",
|
||||
"type": "git"
|
||||
},
|
||||
"scripts": {
|
||||
"lint": "standard",
|
||||
"test": "npm run lint && npm run unit",
|
||||
"unit": "node test/*.js"
|
||||
},
|
||||
"dependencies": {
|
||||
"hash-base": "^2.0.0",
|
||||
"inherits": "^2.0.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"hash-test-vectors": "^1.3.2",
|
||||
"standard": "^6.0.7",
|
||||
"tape": "^4.5.1"
|
||||
}
|
||||
}
|
||||
20
node_modules/pbkdf2/package.json
generated
vendored
20
node_modules/pbkdf2/package.json
generated
vendored
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "pbkdf2",
|
||||
"version": "3.1.3",
|
||||
"version": "3.1.5",
|
||||
"description": "This library provides the functionality of PBKDF2 with the ability to use any supported hashing algorithm returned from crypto.getHashes()",
|
||||
"keywords": [
|
||||
"pbkdf2",
|
||||
@@ -8,9 +8,9 @@
|
||||
"salt",
|
||||
"hash"
|
||||
],
|
||||
"homepage": "https://github.com/crypto-browserify/pbkdf2",
|
||||
"homepage": "https://github.com/browserify/pbkdf2",
|
||||
"bugs": {
|
||||
"url": "https://github.com/crypto-browserify/pbkdf2/issues"
|
||||
"url": "https://github.com/browserify/pbkdf2/issues"
|
||||
},
|
||||
"license": "MIT",
|
||||
"author": "Daniel Cousens",
|
||||
@@ -21,7 +21,7 @@
|
||||
"main": "index.js",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/crypto-browserify/pbkdf2.git"
|
||||
"url": "https://github.com/browserify/pbkdf2.git"
|
||||
},
|
||||
"scripts": {
|
||||
"prepack": "npmignore --auto --commentLines=autogenerated",
|
||||
@@ -36,7 +36,7 @@
|
||||
"postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
|
||||
},
|
||||
"devDependencies": {
|
||||
"@ljharb/eslint-config": "^21.1.1",
|
||||
"@ljharb/eslint-config": "^21.2.0",
|
||||
"auto-changelog": "^2.5.0",
|
||||
"benchmark": "^2.1.4",
|
||||
"browserify": "^17.0.1",
|
||||
@@ -49,15 +49,15 @@
|
||||
"tape": "^5.9.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"create-hash": "~1.1.3",
|
||||
"create-hash": "^1.2.0",
|
||||
"create-hmac": "^1.1.7",
|
||||
"ripemd160": "=2.0.1",
|
||||
"ripemd160": "^2.0.3",
|
||||
"safe-buffer": "^5.2.1",
|
||||
"sha.js": "^2.4.11",
|
||||
"to-buffer": "^1.2.0"
|
||||
"sha.js": "^2.4.12",
|
||||
"to-buffer": "^1.2.1"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=0.12"
|
||||
"node": ">= 0.10"
|
||||
},
|
||||
"auto-changelog": {
|
||||
"output": "CHANGELOG.md",
|
||||
|
||||
Reference in New Issue
Block a user