sproutit-narwhal 0.1.106
Sign up to get free protection for your applications and to get access to all the features.
- data/DISTRIBUTION.yml +15 -0
- data/README.md +86 -0
- data/Rakefile +349 -0
- data/VERSION.yml +7 -0
- data/bin/activate +50 -0
- data/bin/activate.bash +50 -0
- data/bin/activate.cmd +3 -0
- data/bin/js +67 -0
- data/bin/json +2 -0
- data/bin/narwhal +67 -0
- data/bin/narwhal.cmd +29 -0
- data/bin/sea +45 -0
- data/bin/sea.cmd +25 -0
- data/bin/tusk +2 -0
- data/bin/tusk.cmd +5 -0
- data/catalog.json +902 -0
- data/docs/available-packages.md +32 -0
- data/docs/browser-api-plan.md +290 -0
- data/docs/browser-api.md +153 -0
- data/docs/download.md +25 -0
- data/docs/engines.md +32 -0
- data/docs/json-tool.md +121 -0
- data/docs/lib/binary.wiki +242 -0
- data/docs/lib/file.wiki +325 -0
- data/docs/lib/os/popen.md +70 -0
- data/docs/modules.md +38 -0
- data/docs/narwhal.md +487 -0
- data/docs/packages-howto.md +32 -0
- data/docs/packages.md +30 -0
- data/docs/posts/2009-07-29-hello-0.1.md +19 -0
- data/docs/quick-start.md +69 -0
- data/docs/sea.md +49 -0
- data/engines/browser/lib/binary.js +2 -0
- data/engines/browser/lib/reactor.js +21 -0
- data/engines/browser/lib/system.js +3 -0
- data/engines/default/lib/array.js +164 -0
- data/engines/default/lib/binary-engine.js +53 -0
- data/engines/default/lib/binary.js +755 -0
- data/engines/default/lib/date.js +8 -0
- data/engines/default/lib/file-engine.js +119 -0
- data/engines/default/lib/function.js +119 -0
- data/engines/default/lib/global.js +11 -0
- data/engines/default/lib/io-engine.js +26 -0
- data/engines/default/lib/json.js +488 -0
- data/engines/default/lib/object.js +69 -0
- data/engines/default/lib/os-engine.js +3 -0
- data/engines/default/lib/reactor.js +12 -0
- data/engines/default/lib/string.js +84 -0
- data/engines/default/lib/system.js +20 -0
- data/engines/default/lib/worker.js +133 -0
- data/engines/jsc/README.md +18 -0
- data/engines/jsc/bootstrap.js +53 -0
- data/engines/jsc/deps/http-parser/LICENSE +77 -0
- data/engines/jsc/deps/http-parser/README.md +145 -0
- data/engines/jsc/deps/http-parser/http_parser.c +6087 -0
- data/engines/jsc/deps/http-parser/http_parser.h +141 -0
- data/engines/jsc/deps/http-parser/http_parser.rl +500 -0
- data/engines/jsc/deps/http-parser/test.c +858 -0
- data/engines/jsc/include/binary-engine.h +11 -0
- data/engines/jsc/include/io-engine.h +23 -0
- data/engines/jsc/include/narwhal.h +427 -0
- data/engines/jsc/lib/file-engine.js +31 -0
- data/engines/jsc/lib/http.js +1 -0
- data/engines/jsc/lib/io-engine.js +202 -0
- data/engines/jsc/lib/os-engine.js +25 -0
- data/engines/jsc/lib/system.js +18 -0
- data/engines/jsc/lib/zip.js +1 -0
- data/engines/jsc/narwhal-jsc.c +273 -0
- data/engines/jsc/narwhal.c +29 -0
- data/engines/jsc/package.json +8 -0
- data/engines/jsc/src/binary-engine.cc +290 -0
- data/engines/jsc/src/file-engine.cc +405 -0
- data/engines/jsc/src/io-engine.cc +423 -0
- data/engines/jsc/src/jack/handler/jill.cc +710 -0
- data/engines/jsc/src/os-engine.cc +210 -0
- data/engines/rhino/bin/narwhal-rhino +68 -0
- data/engines/rhino/bin/narwhal-rhino.cmd +34 -0
- data/engines/rhino/bootstrap.js +119 -0
- data/engines/rhino/jars/jline.jar +0 -0
- data/engines/rhino/jars/jna.jar +0 -0
- data/engines/rhino/jars/js.jar +0 -0
- data/engines/rhino/lib/binary-engine.js +83 -0
- data/engines/rhino/lib/concurrency.js +6 -0
- data/engines/rhino/lib/event-queue.js +18 -0
- data/engines/rhino/lib/file-engine.js +216 -0
- data/engines/rhino/lib/http-client-engine.js +90 -0
- data/engines/rhino/lib/http-engine.js +10 -0
- data/engines/rhino/lib/io-engine.js +347 -0
- data/engines/rhino/lib/md5-engine.js +40 -0
- data/engines/rhino/lib/os-engine.js +150 -0
- data/engines/rhino/lib/packages-engine.js +71 -0
- data/engines/rhino/lib/sandbox-engine.js +70 -0
- data/engines/rhino/lib/system.js +38 -0
- data/engines/rhino/lib/worker-engine.js +23 -0
- data/engines/rhino/lib/zip.js +78 -0
- data/engines/rhino/package.json +4 -0
- data/engines/secure/lib/file.js +6 -0
- data/engines/secure/lib/system.js +6 -0
- data/engines/template/bin/narwhal-engine-name +32 -0
- data/engines/template/bootstrap.js +40 -0
- data/engines/template/lib/file-engine.js +118 -0
- data/engines/template/lib/system.js +17 -0
- data/examples/browser-deployment-jackconfig.js +35 -0
- data/examples/fibonacci-worker.js +35 -0
- data/examples/fibonacci.js +19 -0
- data/examples/hello +2 -0
- data/examples/narwhal +3 -0
- data/examples/not-quite-a-quine.js +1 -0
- data/extconf.rb +44 -0
- data/gem_bin/narwhal +5 -0
- data/gem_bin/sea +4 -0
- data/gem_bin/tusk +4 -0
- data/lib/args.js +849 -0
- data/lib/base16.js +16 -0
- data/lib/base64.js +120 -0
- data/lib/codec/base64.js +8 -0
- data/lib/crc32.js +60 -0
- data/lib/file-bootstrap.js +187 -0
- data/lib/file.js +659 -0
- data/lib/hash.js +28 -0
- data/lib/hashp.js +65 -0
- data/lib/html.js +16 -0
- data/lib/http-client.js +134 -0
- data/lib/http.js +17 -0
- data/lib/io.js +98 -0
- data/lib/jsmin.js +315 -0
- data/lib/jsonpath.js +89 -0
- data/lib/logger.js +55 -0
- data/lib/md4.js +146 -0
- data/lib/md5.js +164 -0
- data/lib/mime.js +166 -0
- data/lib/narwhal.js +102 -0
- data/lib/narwhal/client.js +261 -0
- data/lib/narwhal/compile.js +99 -0
- data/lib/narwhal/env.js +140 -0
- data/lib/narwhal/inline.js +106 -0
- data/lib/narwhal/json.js +324 -0
- data/lib/narwhal/json.md +178 -0
- data/lib/narwhal/repl.js +96 -0
- data/lib/narwhal/server-test.js +6 -0
- data/lib/narwhal/server.js +270 -0
- data/lib/narwhal/tusk.js +170 -0
- data/lib/narwhal/tusk/bin.js +13 -0
- data/lib/narwhal/tusk/bundle.js +0 -0
- data/lib/narwhal/tusk/catalog.js +22 -0
- data/lib/narwhal/tusk/clone.js +66 -0
- data/lib/narwhal/tusk/consolidate.js +25 -0
- data/lib/narwhal/tusk/create-catalog.js +80 -0
- data/lib/narwhal/tusk/engine.js +42 -0
- data/lib/narwhal/tusk/freeze.js +0 -0
- data/lib/narwhal/tusk/init.js +56 -0
- data/lib/narwhal/tusk/install.js +288 -0
- data/lib/narwhal/tusk/list.js +20 -0
- data/lib/narwhal/tusk/orphans.js +0 -0
- data/lib/narwhal/tusk/reheat.js +15 -0
- data/lib/narwhal/tusk/remove.js +15 -0
- data/lib/narwhal/tusk/search.js +145 -0
- data/lib/narwhal/tusk/update.js +21 -0
- data/lib/narwhal/tusk/upgrade.js +0 -0
- data/lib/os.js +33 -0
- data/lib/packages.js +423 -0
- data/lib/printf.js +169 -0
- data/lib/promise.js +352 -0
- data/lib/querystring.js +176 -0
- data/lib/ref-send.js +257 -0
- data/lib/regexp.js +12 -0
- data/lib/sandbox.js +422 -0
- data/lib/sha.js +112 -0
- data/lib/sha256.js +102 -0
- data/lib/struct.js +228 -0
- data/lib/term.js +179 -0
- data/lib/test/assert.js +95 -0
- data/lib/test/equiv.js +188 -0
- data/lib/test/jsdump.js +165 -0
- data/lib/test/runner.js +129 -0
- data/lib/unload.js +13 -0
- data/lib/uri.js +378 -0
- data/lib/url.js +5 -0
- data/lib/utf8.js +64 -0
- data/lib/util.js +985 -0
- data/lib/uuid.js +89 -0
- data/lib/xregexp.js +521 -0
- data/local.json.template +1 -0
- data/narwhal.gemspec +105 -0
- data/narwhal.js +213 -0
- data/package.json +26 -0
- data/packages/readline/engines/default/lib/readline.js +4 -0
- data/packages/readline/engines/rhino/lib/readline.js +6 -0
- data/packages/readline/package.json +5 -0
- data/sources.json +207 -0
- data/tests/all-tests.js +17 -0
- data/tests/args.js +31 -0
- data/tests/args/domain.js +215 -0
- data/tests/args/options.js +36 -0
- data/tests/args/shifting.js +92 -0
- data/tests/args/validation.js +31 -0
- data/tests/base64.js +23 -0
- data/tests/commonjs.js +3 -0
- data/tests/commonjs/all-tests.js +12 -0
- data/tests/commonjs/bytearray-encodings-tests.js +69 -0
- data/tests/commonjs/bytearray-tests.js +465 -0
- data/tests/commonjs/bytestring-encodings-tests.js +89 -0
- data/tests/commonjs/bytestring-tests.js +263 -0
- data/tests/commonjs/es5/all-tests.js +3 -0
- data/tests/commonjs/es5/bind.js +29 -0
- data/tests/commonjs/file-tests.js +315 -0
- data/tests/commonjs/file/dirname.js +31 -0
- data/tests/commonjs/file/extension.js +45 -0
- data/tests/commonjs/file/is-absolute.js +11 -0
- data/tests/commonjs/file/iterator.js +101 -0
- data/tests/commonjs/file/normal.js +27 -0
- data/tests/commonjs/file/path.js +17 -0
- data/tests/commonjs/file/relative.js +42 -0
- data/tests/commonjs/file/resolve.js +44 -0
- data/tests/commonjs/module-tests.js +9 -0
- data/tests/commonjs/modules/absolute/b.js +1 -0
- data/tests/commonjs/modules/absolute/program.js +5 -0
- data/tests/commonjs/modules/absolute/submodule/a.js +3 -0
- data/tests/commonjs/modules/absolute/test.js +9 -0
- data/tests/commonjs/modules/all-tests.js +47 -0
- data/tests/commonjs/modules/config.js +11 -0
- data/tests/commonjs/modules/cyclic/a.js +4 -0
- data/tests/commonjs/modules/cyclic/b.js +4 -0
- data/tests/commonjs/modules/cyclic/program.js +10 -0
- data/tests/commonjs/modules/cyclic/test.js +9 -0
- data/tests/commonjs/modules/determinism/program.js +3 -0
- data/tests/commonjs/modules/determinism/submodule/a.js +8 -0
- data/tests/commonjs/modules/determinism/submodule/b.js +2 -0
- data/tests/commonjs/modules/determinism/test.js +9 -0
- data/tests/commonjs/modules/exactExports/a.js +3 -0
- data/tests/commonjs/modules/exactExports/program.js +4 -0
- data/tests/commonjs/modules/exactExports/test.js +9 -0
- data/tests/commonjs/modules/hasOwnProperty/hasOwnProperty.js +0 -0
- data/tests/commonjs/modules/hasOwnProperty/program.js +3 -0
- data/tests/commonjs/modules/hasOwnProperty/test.js +9 -0
- data/tests/commonjs/modules/hasOwnProperty/toString.js +0 -0
- data/tests/commonjs/modules/method/a.js +12 -0
- data/tests/commonjs/modules/method/program.js +8 -0
- data/tests/commonjs/modules/method/test.js +9 -0
- data/tests/commonjs/modules/missing/program.js +8 -0
- data/tests/commonjs/modules/missing/test.js +9 -0
- data/tests/commonjs/modules/monkeys/a.js +1 -0
- data/tests/commonjs/modules/monkeys/program.js +4 -0
- data/tests/commonjs/modules/monkeys/test.js +9 -0
- data/tests/commonjs/modules/nested/a/b/c/d.js +3 -0
- data/tests/commonjs/modules/nested/program.js +3 -0
- data/tests/commonjs/modules/nested/test.js +9 -0
- data/tests/commonjs/modules/relative/program.js +5 -0
- data/tests/commonjs/modules/relative/submodule/a.js +1 -0
- data/tests/commonjs/modules/relative/submodule/b.js +2 -0
- data/tests/commonjs/modules/relative/test.js +9 -0
- data/tests/commonjs/modules/transitive/a.js +1 -0
- data/tests/commonjs/modules/transitive/b.js +1 -0
- data/tests/commonjs/modules/transitive/c.js +3 -0
- data/tests/commonjs/modules/transitive/program.js +3 -0
- data/tests/commonjs/modules/transitive/test.js +9 -0
- data/tests/file/all-tests.js +61 -0
- data/tests/file/fnmatch.js +102 -0
- data/tests/file/glob.js +466 -0
- data/tests/file/match.js +102 -0
- data/tests/global.js +6 -0
- data/tests/global/array.js +19 -0
- data/tests/hashes.js +94 -0
- data/tests/html.js +13 -0
- data/tests/io/stringio.js +21 -0
- data/tests/os/all-tests.js +4 -0
- data/tests/os/popen.js +41 -0
- data/tests/os/system.js +22 -0
- data/tests/printf.js +123 -0
- data/tests/query-string.js +87 -0
- data/tests/sandbox/byte-io.js +20 -0
- data/tests/sandbox/fileName.js +3 -0
- data/tests/sandbox/foo.js +0 -0
- data/tests/sandbox/reload.js +79 -0
- data/tests/string.js +35 -0
- data/tests/uri.js +41 -0
- data/tests/util/all-tests.js +79 -0
- data/tests/util/array.js +207 -0
- data/tests/util/array/is-arguments.js +29 -0
- data/tests/util/array/is-array-like.js +29 -0
- data/tests/util/case.js +9 -0
- data/tests/util/collection.js +104 -0
- data/tests/util/eq.js +57 -0
- data/tests/util/expand.js +45 -0
- data/tests/util/object.js +125 -0
- data/tests/util/operator.js +25 -0
- data/tests/util/range.js +19 -0
- data/tests/util/repr.js +26 -0
- data/tests/util/string.js +34 -0
- data/tests/util/unique.js +12 -0
- metadata +434 -0
data/lib/jsonpath.js
ADDED
@@ -0,0 +1,89 @@
|
|
1
|
+
/* JSONPath 0.8.0 - XPath for JSON
|
2
|
+
*
|
3
|
+
* Copyright (c) 2007 Stefan Goessner (goessner.net)
|
4
|
+
* Licensed under the MIT (MIT-LICENSE.txt) licence.
|
5
|
+
*/
|
6
|
+
|
7
|
+
exports.resolve = function (obj, expr, arg) {
|
8
|
+
var P = {
|
9
|
+
resultType: arg && arg.resultType || "VALUE",
|
10
|
+
result: [],
|
11
|
+
normalize: function(expr) {
|
12
|
+
var subx = [];
|
13
|
+
return expr.replace(/[\['](\??\(.*?\))[\]']/g, function($0,$1){return "[#"+(subx.push($1)-1)+"]";})
|
14
|
+
.replace(/'?\.'?|\['?/g, ";")
|
15
|
+
.replace(/;;;|;;/g, ";..;")
|
16
|
+
.replace(/;$|'?\]|'$/g, "")
|
17
|
+
.replace(/#([0-9]+)/g, function($0,$1){return subx[$1];});
|
18
|
+
},
|
19
|
+
asPath: function(path) {
|
20
|
+
var x = path.split(";"), p = "$";
|
21
|
+
for (var i=1,n=x.length; i<n; i++)
|
22
|
+
p += /^[0-9*]+$/.test(x[i]) ? ("["+x[i]+"]") : ("['"+x[i]+"']");
|
23
|
+
return p;
|
24
|
+
},
|
25
|
+
store: function(p, v) {
|
26
|
+
if (p) P.result[P.result.length] = P.resultType == "PATH" ? P.asPath(p) : v;
|
27
|
+
return !!p;
|
28
|
+
},
|
29
|
+
trace: function(expr, val, path) {
|
30
|
+
if (expr) {
|
31
|
+
var x = expr.split(";"), loc = x.shift();
|
32
|
+
x = x.join(";");
|
33
|
+
if (val && val.hasOwnProperty(loc))
|
34
|
+
P.trace(x, val[loc], path + ";" + loc);
|
35
|
+
else if (loc === "*")
|
36
|
+
P.walk(loc, x, val, path, function(m,l,x,v,p) { P.trace(m+";"+x,v,p); });
|
37
|
+
else if (loc === "..") {
|
38
|
+
P.trace(x, val, path);
|
39
|
+
P.walk(loc, x, val, path, function(m,l,x,v,p) { typeof v[m] === "object" && P.trace("..;"+x,v[m],p+";"+m); });
|
40
|
+
}
|
41
|
+
else if (/,/.test(loc)) { // [name1,name2,...]
|
42
|
+
for (var s=loc.split(/'?,'?/),i=0,n=s.length; i<n; i++)
|
43
|
+
P.trace(s[i]+";"+x, val, path);
|
44
|
+
}
|
45
|
+
else if (/^\(.*?\)$/.test(loc)) // [(expr)]
|
46
|
+
P.trace(P.eval(loc, val, path.substr(path.lastIndexOf(";")+1))+";"+x, val, path);
|
47
|
+
else if (/^\?\(.*?\)$/.test(loc)) // [?(expr)]
|
48
|
+
P.walk(loc, x, val, path, function(m,l,x,v,p) { if (P.eval(l.replace(/^\?\((.*?)\)$/,"$1"),v[m],m)) P.trace(m+";"+x,v,p); });
|
49
|
+
else if (/^(-?[0-9]*):(-?[0-9]*):?([0-9]*)$/.test(loc)) // [start:end:step] phyton slice syntax
|
50
|
+
P.slice(loc, x, val, path);
|
51
|
+
}
|
52
|
+
else
|
53
|
+
P.store(path, val);
|
54
|
+
},
|
55
|
+
walk: function(loc, expr, val, path, f) {
|
56
|
+
if (val instanceof Array) {
|
57
|
+
for (var i=0,n=val.length; i<n; i++)
|
58
|
+
if (i in val)
|
59
|
+
f(i,loc,expr,val,path);
|
60
|
+
}
|
61
|
+
else if (typeof val === "object") {
|
62
|
+
for (var m in val)
|
63
|
+
if (val.hasOwnProperty(m))
|
64
|
+
f(m,loc,expr,val,path);
|
65
|
+
}
|
66
|
+
},
|
67
|
+
slice: function(loc, expr, val, path) {
|
68
|
+
if (val instanceof Array) {
|
69
|
+
var len=val.length, start=0, end=len, step=1;
|
70
|
+
loc.replace(/^(-?[0-9]*):(-?[0-9]*):?(-?[0-9]*)$/g, function($0,$1,$2,$3){start=parseInt($1||start);end=parseInt($2||end);step=parseInt($3||step);});
|
71
|
+
start = (start < 0) ? Math.max(0,start+len) : Math.min(len,start);
|
72
|
+
end = (end < 0) ? Math.max(0,end+len) : Math.min(len,end);
|
73
|
+
for (var i=start; i<end; i+=step)
|
74
|
+
P.trace(i+";"+expr, val, path);
|
75
|
+
}
|
76
|
+
},
|
77
|
+
eval: function(x, _v, _vname) {
|
78
|
+
try { return $ && _v && eval(x.replace(/@/g, "_v")); }
|
79
|
+
catch(e) { throw new SyntaxError("jsonPath: " + e.message + ": " + x.replace(/@/g, "_v").replace(/\^/g, "_a")); }
|
80
|
+
}
|
81
|
+
};
|
82
|
+
|
83
|
+
var $ = obj;
|
84
|
+
if (expr && obj && (P.resultType == "VALUE" || P.resultType == "PATH")) {
|
85
|
+
P.trace(P.normalize(expr).replace(/^\$;/,""), obj, "$");
|
86
|
+
return P.result.length ? P.result : false;
|
87
|
+
}
|
88
|
+
};
|
89
|
+
|
data/lib/logger.js
ADDED
@@ -0,0 +1,55 @@
|
|
1
|
+
// Logging
|
2
|
+
//
|
3
|
+
// FATAL: an unhandleable error that results in a program crash
|
4
|
+
// ERROR: a handleable error condition
|
5
|
+
// WARN: a warning
|
6
|
+
// INFO: generic (useful) information about system operation
|
7
|
+
// DEBUG: low-level information for developers
|
8
|
+
// (Stolen from Ruby)
|
9
|
+
//
|
10
|
+
|
11
|
+
var system = require("system");
|
12
|
+
|
13
|
+
var Logger = exports.Logger = function(output) {
|
14
|
+
if (typeof output === "string")
|
15
|
+
this.output = system.fs.open(output, "a");
|
16
|
+
else
|
17
|
+
this.output = output;
|
18
|
+
|
19
|
+
this.level = Logger.INFO;
|
20
|
+
};
|
21
|
+
|
22
|
+
Logger.FATAL = 0;
|
23
|
+
Logger.ERROR = 1;
|
24
|
+
Logger.WARN = 2;
|
25
|
+
Logger.INFO = 3;
|
26
|
+
Logger.DEBUG = 4;
|
27
|
+
|
28
|
+
Logger.SEV_LABEL = ["FATAL", "ERROR", "WARN" , "INFO" , "DEBUG"];
|
29
|
+
|
30
|
+
Logger.prototype.fatal = function() {
|
31
|
+
return this.add(Logger.FATAL, this.format(Logger.FATAL, arguments));
|
32
|
+
};
|
33
|
+
Logger.prototype.error = function() {
|
34
|
+
return this.add(Logger.ERROR, this.format(Logger.ERROR, arguments));
|
35
|
+
};
|
36
|
+
Logger.prototype.warn = function() {
|
37
|
+
return this.add(Logger.WARN, this.format(Logger.WARN, arguments));
|
38
|
+
};
|
39
|
+
Logger.prototype.info = function() {
|
40
|
+
return this.add(Logger.INFO, this.format(Logger.INFO, arguments));
|
41
|
+
};
|
42
|
+
Logger.prototype.debug = function() {
|
43
|
+
return this.add(Logger.DEBUG, this.format(Logger.DEBUG, arguments));
|
44
|
+
};
|
45
|
+
|
46
|
+
Logger.prototype.add = function(severity, message, progname) {
|
47
|
+
if (severity > this.level)
|
48
|
+
return false;
|
49
|
+
this.output.write(message || progname);
|
50
|
+
};
|
51
|
+
|
52
|
+
Logger.prototype.format = function(severity, args) {
|
53
|
+
return new Date() + " ["+Logger.SEV_LABEL[severity].toLowerCase()+"] " +Array.prototype.join.apply(args, [" "]).replace(/\n/g, "");
|
54
|
+
};
|
55
|
+
|
data/lib/md4.js
ADDED
@@ -0,0 +1,146 @@
|
|
1
|
+
/*
|
2
|
+
|
3
|
+
Version 2.1 Copyright (C) Jerrad Pierce, Paul Johnston 1999 - 2002.
|
4
|
+
Distributed under the BSD License
|
5
|
+
|
6
|
+
Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
|
7
|
+
See http://pajhome.org.uk/crypt/md5 for more info.
|
8
|
+
|
9
|
+
*/
|
10
|
+
|
11
|
+
/**
|
12
|
+
|
13
|
+
A JavaScript implementation of the RSA Data Security, Inc. MD4 Message
|
14
|
+
Digest Algorithm, as defined in RFC 1320.
|
15
|
+
|
16
|
+
*/
|
17
|
+
|
18
|
+
var util = require('./util');
|
19
|
+
var struct = require('./struct');
|
20
|
+
|
21
|
+
/*** hash
|
22
|
+
returns a hexadecimal string of the md4 hash for a given byte string
|
23
|
+
*/
|
24
|
+
exports.hash = function (s, _characterSize) {
|
25
|
+
if (util.no(_characterSize))
|
26
|
+
_characterSize = struct.characterSize;
|
27
|
+
return struct.binl2bin(core_md4(struct.str2binl(s), s.length * _characterSize));
|
28
|
+
};
|
29
|
+
|
30
|
+
/*
|
31
|
+
Calculate the MD4 of an array of little-endian words, and a bit length
|
32
|
+
*/
|
33
|
+
var core_md4 = function (x, len) {
|
34
|
+
/* append padding */
|
35
|
+
x[len >> 5] |= 0x80 << (len % 32);
|
36
|
+
x[(((len + 64) >>> 9) << 4) + 14] = len;
|
37
|
+
|
38
|
+
var a = 1732584193;
|
39
|
+
var b = -271733879;
|
40
|
+
var c = -1732584194;
|
41
|
+
var d = 271733878;
|
42
|
+
|
43
|
+
for(var i = 0; i < x.length; i += 16) {
|
44
|
+
var olda = a;
|
45
|
+
var oldb = b;
|
46
|
+
var oldc = c;
|
47
|
+
var oldd = d;
|
48
|
+
|
49
|
+
a = md4_ff(a, b, c, d, x[i+ 0], 3 );
|
50
|
+
d = md4_ff(d, a, b, c, x[i+ 1], 7 );
|
51
|
+
c = md4_ff(c, d, a, b, x[i+ 2], 11);
|
52
|
+
b = md4_ff(b, c, d, a, x[i+ 3], 19);
|
53
|
+
a = md4_ff(a, b, c, d, x[i+ 4], 3 );
|
54
|
+
d = md4_ff(d, a, b, c, x[i+ 5], 7 );
|
55
|
+
c = md4_ff(c, d, a, b, x[i+ 6], 11);
|
56
|
+
b = md4_ff(b, c, d, a, x[i+ 7], 19);
|
57
|
+
a = md4_ff(a, b, c, d, x[i+ 8], 3 );
|
58
|
+
d = md4_ff(d, a, b, c, x[i+ 9], 7 );
|
59
|
+
c = md4_ff(c, d, a, b, x[i+10], 11);
|
60
|
+
b = md4_ff(b, c, d, a, x[i+11], 19);
|
61
|
+
a = md4_ff(a, b, c, d, x[i+12], 3 );
|
62
|
+
d = md4_ff(d, a, b, c, x[i+13], 7 );
|
63
|
+
c = md4_ff(c, d, a, b, x[i+14], 11);
|
64
|
+
b = md4_ff(b, c, d, a, x[i+15], 19);
|
65
|
+
|
66
|
+
a = md4_gg(a, b, c, d, x[i+ 0], 3 );
|
67
|
+
d = md4_gg(d, a, b, c, x[i+ 4], 5 );
|
68
|
+
c = md4_gg(c, d, a, b, x[i+ 8], 9 );
|
69
|
+
b = md4_gg(b, c, d, a, x[i+12], 13);
|
70
|
+
a = md4_gg(a, b, c, d, x[i+ 1], 3 );
|
71
|
+
d = md4_gg(d, a, b, c, x[i+ 5], 5 );
|
72
|
+
c = md4_gg(c, d, a, b, x[i+ 9], 9 );
|
73
|
+
b = md4_gg(b, c, d, a, x[i+13], 13);
|
74
|
+
a = md4_gg(a, b, c, d, x[i+ 2], 3 );
|
75
|
+
d = md4_gg(d, a, b, c, x[i+ 6], 5 );
|
76
|
+
c = md4_gg(c, d, a, b, x[i+10], 9 );
|
77
|
+
b = md4_gg(b, c, d, a, x[i+14], 13);
|
78
|
+
a = md4_gg(a, b, c, d, x[i+ 3], 3 );
|
79
|
+
d = md4_gg(d, a, b, c, x[i+ 7], 5 );
|
80
|
+
c = md4_gg(c, d, a, b, x[i+11], 9 );
|
81
|
+
b = md4_gg(b, c, d, a, x[i+15], 13);
|
82
|
+
|
83
|
+
a = md4_hh(a, b, c, d, x[i+ 0], 3 );
|
84
|
+
d = md4_hh(d, a, b, c, x[i+ 8], 9 );
|
85
|
+
c = md4_hh(c, d, a, b, x[i+ 4], 11);
|
86
|
+
b = md4_hh(b, c, d, a, x[i+12], 15);
|
87
|
+
a = md4_hh(a, b, c, d, x[i+ 2], 3 );
|
88
|
+
d = md4_hh(d, a, b, c, x[i+10], 9 );
|
89
|
+
c = md4_hh(c, d, a, b, x[i+ 6], 11);
|
90
|
+
b = md4_hh(b, c, d, a, x[i+14], 15);
|
91
|
+
a = md4_hh(a, b, c, d, x[i+ 1], 3 );
|
92
|
+
d = md4_hh(d, a, b, c, x[i+ 9], 9 );
|
93
|
+
c = md4_hh(c, d, a, b, x[i+ 5], 11);
|
94
|
+
b = md4_hh(b, c, d, a, x[i+13], 15);
|
95
|
+
a = md4_hh(a, b, c, d, x[i+ 3], 3 );
|
96
|
+
d = md4_hh(d, a, b, c, x[i+11], 9 );
|
97
|
+
c = md4_hh(c, d, a, b, x[i+ 7], 11);
|
98
|
+
b = md4_hh(b, c, d, a, x[i+15], 15);
|
99
|
+
|
100
|
+
a = struct.addU32(a, olda);
|
101
|
+
b = struct.addU32(b, oldb);
|
102
|
+
c = struct.addU32(c, oldc);
|
103
|
+
d = struct.addU32(d, oldd);
|
104
|
+
|
105
|
+
}
|
106
|
+
return [a, b, c, d];
|
107
|
+
|
108
|
+
};
|
109
|
+
|
110
|
+
/*
|
111
|
+
These functions implement the basic operation for each round of the
|
112
|
+
algorithm.
|
113
|
+
*/
|
114
|
+
|
115
|
+
var md4_cmn = function (q, a, b, x, s, t) {
|
116
|
+
return struct.addU32(struct.rolU32(struct.addU32(a, q, x, t), s), b);
|
117
|
+
};
|
118
|
+
var md4_ff = function (a, b, c, d, x, s) {
|
119
|
+
return md4_cmn((b & c) | ((~b) & d), a, 0, x, s, 0);
|
120
|
+
};
|
121
|
+
var md4_gg = function (a, b, c, d, x, s) {
|
122
|
+
return md4_cmn((b & c) | (b & d) | (c & d), a, 0, x, s, 1518500249);
|
123
|
+
};
|
124
|
+
var md4_hh = function (a, b, c, d, x, s) {
|
125
|
+
return md4_cmn(b ^ c ^ d, a, 0, x, s, 1859775393);
|
126
|
+
};
|
127
|
+
|
128
|
+
/*
|
129
|
+
Calculate the HMAC-MD4, of a key and some data
|
130
|
+
*/
|
131
|
+
var core_hmac_md4 = function (key, data, _characterSize) {
|
132
|
+
if (no(_characterSize))
|
133
|
+
_characterSize = struct.characterSize;
|
134
|
+
var bkey = struct.str2binl(key);
|
135
|
+
if(bkey.length > 16) bkey = core_md4(bkey, key.length * _characterSize);
|
136
|
+
|
137
|
+
var ipad = [], opad = [];
|
138
|
+
for(var i = 0; i < 16; i++) {
|
139
|
+
ipad[i] = bkey[i] ^ 0x36363636;
|
140
|
+
opad[i] = bkey[i] ^ 0x5C5C5C5C;
|
141
|
+
}
|
142
|
+
|
143
|
+
var hash = core_md4(ipad.concat(struct.str2binl(data)), 512 + data.length * _characterSize);
|
144
|
+
return core_md4(opad.concat(hash), 512 + 128);
|
145
|
+
};
|
146
|
+
|
data/lib/md5.js
ADDED
@@ -0,0 +1,164 @@
|
|
1
|
+
|
2
|
+
/*
|
3
|
+
A JavaScript implementation of the RSA Data Security, Inc. MD5 Message
|
4
|
+
Digest Algorithm, as defined in RFC 1321.
|
5
|
+
Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.
|
6
|
+
Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
|
7
|
+
Distributed under the BSD License
|
8
|
+
See http://pajhome.org.uk/crypt/md5 for more info.
|
9
|
+
*/
|
10
|
+
|
11
|
+
var util = require('./util');
|
12
|
+
var struct = require('./struct');
|
13
|
+
|
14
|
+
/*
|
15
|
+
* Configurable variables. You may need to tweak these to be compatible with
|
16
|
+
* the server-side, but the defaults work in most cases.
|
17
|
+
*/
|
18
|
+
|
19
|
+
/*** hash
|
20
|
+
returns a hex string of the md5 hash for a given string.
|
21
|
+
*/
|
22
|
+
exports.hash = function (s, _characterSize) {
|
23
|
+
if (util.no(_characterSize)) _characterSize = struct.characterSize;
|
24
|
+
return struct.binl2bin(core_md5(struct.str2binl(s), s.length * _characterSize));
|
25
|
+
};
|
26
|
+
|
27
|
+
/*
|
28
|
+
* Calculate the MD5 of an array of little-endian words, and a bit length
|
29
|
+
*/
|
30
|
+
var core_md5 = function (x, len) {
|
31
|
+
/* append padding */
|
32
|
+
x[len >> 5] |= 0x80 << ((len) % 32);
|
33
|
+
x[(((len + 64) >>> 9) << 4) + 14] = len;
|
34
|
+
|
35
|
+
var a = 1732584193;
|
36
|
+
var b = -271733879;
|
37
|
+
var c = -1732584194;
|
38
|
+
var d = 271733878;
|
39
|
+
|
40
|
+
for (var i = 0; i < x.length; i += 16) {
|
41
|
+
var olda = a;
|
42
|
+
var oldb = b;
|
43
|
+
var oldc = c;
|
44
|
+
var oldd = d;
|
45
|
+
|
46
|
+
a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936);
|
47
|
+
d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586);
|
48
|
+
c = md5_ff(c, d, a, b, x[i+ 2], 17, 606105819);
|
49
|
+
b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330);
|
50
|
+
a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897);
|
51
|
+
d = md5_ff(d, a, b, c, x[i+ 5], 12, 1200080426);
|
52
|
+
c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341);
|
53
|
+
b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983);
|
54
|
+
a = md5_ff(a, b, c, d, x[i+ 8], 7 , 1770035416);
|
55
|
+
d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417);
|
56
|
+
c = md5_ff(c, d, a, b, x[i+10], 17, -42063);
|
57
|
+
b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162);
|
58
|
+
a = md5_ff(a, b, c, d, x[i+12], 7 , 1804603682);
|
59
|
+
d = md5_ff(d, a, b, c, x[i+13], 12, -40341101);
|
60
|
+
c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290);
|
61
|
+
b = md5_ff(b, c, d, a, x[i+15], 22, 1236535329);
|
62
|
+
|
63
|
+
a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510);
|
64
|
+
d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632);
|
65
|
+
c = md5_gg(c, d, a, b, x[i+11], 14, 643717713);
|
66
|
+
b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302);
|
67
|
+
a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691);
|
68
|
+
d = md5_gg(d, a, b, c, x[i+10], 9 , 38016083);
|
69
|
+
c = md5_gg(c, d, a, b, x[i+15], 14, -660478335);
|
70
|
+
b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848);
|
71
|
+
a = md5_gg(a, b, c, d, x[i+ 9], 5 , 568446438);
|
72
|
+
d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690);
|
73
|
+
c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961);
|
74
|
+
b = md5_gg(b, c, d, a, x[i+ 8], 20, 1163531501);
|
75
|
+
a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467);
|
76
|
+
d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784);
|
77
|
+
c = md5_gg(c, d, a, b, x[i+ 7], 14, 1735328473);
|
78
|
+
b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734);
|
79
|
+
|
80
|
+
a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558);
|
81
|
+
d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463);
|
82
|
+
c = md5_hh(c, d, a, b, x[i+11], 16, 1839030562);
|
83
|
+
b = md5_hh(b, c, d, a, x[i+14], 23, -35309556);
|
84
|
+
a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060);
|
85
|
+
d = md5_hh(d, a, b, c, x[i+ 4], 11, 1272893353);
|
86
|
+
c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632);
|
87
|
+
b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640);
|
88
|
+
a = md5_hh(a, b, c, d, x[i+13], 4 , 681279174);
|
89
|
+
d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222);
|
90
|
+
c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979);
|
91
|
+
b = md5_hh(b, c, d, a, x[i+ 6], 23, 76029189);
|
92
|
+
a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487);
|
93
|
+
d = md5_hh(d, a, b, c, x[i+12], 11, -421815835);
|
94
|
+
c = md5_hh(c, d, a, b, x[i+15], 16, 530742520);
|
95
|
+
b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651);
|
96
|
+
|
97
|
+
a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844);
|
98
|
+
d = md5_ii(d, a, b, c, x[i+ 7], 10, 1126891415);
|
99
|
+
c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905);
|
100
|
+
b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055);
|
101
|
+
a = md5_ii(a, b, c, d, x[i+12], 6 , 1700485571);
|
102
|
+
d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606);
|
103
|
+
c = md5_ii(c, d, a, b, x[i+10], 15, -1051523);
|
104
|
+
b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799);
|
105
|
+
a = md5_ii(a, b, c, d, x[i+ 8], 6 , 1873313359);
|
106
|
+
d = md5_ii(d, a, b, c, x[i+15], 10, -30611744);
|
107
|
+
c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380);
|
108
|
+
b = md5_ii(b, c, d, a, x[i+13], 21, 1309151649);
|
109
|
+
a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070);
|
110
|
+
d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379);
|
111
|
+
c = md5_ii(c, d, a, b, x[i+ 2], 15, 718787259);
|
112
|
+
b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551);
|
113
|
+
|
114
|
+
a = struct.addU32(a, olda);
|
115
|
+
b = struct.addU32(b, oldb);
|
116
|
+
c = struct.addU32(c, oldc);
|
117
|
+
d = struct.addU32(d, oldd);
|
118
|
+
}
|
119
|
+
return [a, b, c, d];
|
120
|
+
|
121
|
+
};
|
122
|
+
|
123
|
+
/*
|
124
|
+
* These functions implement the four basic operations the algorithm uses.
|
125
|
+
*/
|
126
|
+
|
127
|
+
var md5_cmn = function (q, a, b, x, s, t) {
|
128
|
+
return struct.addU32(struct.rolU32(struct.addU32(a, q, x, t), s), b);
|
129
|
+
};
|
130
|
+
|
131
|
+
var md5_ff = function (a, b, c, d, x, s, t) {
|
132
|
+
return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t);
|
133
|
+
};
|
134
|
+
|
135
|
+
var md5_gg = function (a, b, c, d, x, s, t) {
|
136
|
+
return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t);
|
137
|
+
};
|
138
|
+
|
139
|
+
var md5_hh = function (a, b, c, d, x, s, t) {
|
140
|
+
return md5_cmn(b ^ c ^ d, a, b, x, s, t);
|
141
|
+
};
|
142
|
+
|
143
|
+
var md5_ii = function (a, b, c, d, x, s, t) {
|
144
|
+
return md5_cmn(c ^ (b | (~d)), a, b, x, s, t);
|
145
|
+
};
|
146
|
+
|
147
|
+
/*
|
148
|
+
* Calculate the HMAC-MD5, of a key and some data
|
149
|
+
*/
|
150
|
+
var core_hmac_md5 = function (key, data, _characterSize) {
|
151
|
+
if (util.no(_characterSize)) _characterSize = struct.characterSize;
|
152
|
+
var bkey = struct.str2binl(key);
|
153
|
+
if(bkey.length > 16) bkey = core_md5(bkey, key.length * _characterSize);
|
154
|
+
|
155
|
+
var ipad = [], opad = [];
|
156
|
+
for (var i = 0; i < 16; i++) {
|
157
|
+
ipad[i] = bkey[i] ^ 0x36363636;
|
158
|
+
opad[i] = bkey[i] ^ 0x5C5C5C5C;
|
159
|
+
}
|
160
|
+
|
161
|
+
var hash = core_md5(ipad.concat(struct.str2binl(data)), 512 + data.length * _characterSize);
|
162
|
+
return core_md5(opad.concat(hash), 512 + 128);
|
163
|
+
};
|
164
|
+
|