@thangnm.nip/arouter 0.1.2 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/app-path-routes-manifest.json +5 -5
- package/.next/standalone/.next/build-manifest.json +2 -2
- package/.next/standalone/.next/prerender-manifest.json +3 -3
- package/.next/standalone/.next/server/app/(dashboard)/mitm/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error.html +2 -2
- package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/.next/server/app/_not-found.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/alias/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/console-logs/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/settings/route.js +2 -2
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/claude-settings/route.js +2 -2
- package/.next/standalone/.next/server/app/api/cli-tools/claude-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/codex-settings/route.js +2 -2
- package/.next/standalone/.next/server/app/api/cli-tools/codex-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/copilot-settings/route.js +2 -2
- package/.next/standalone/.next/server/app/api/cli-tools/copilot-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/droid-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/droid-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/openclaw-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/openclaw-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/opencode-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/opencode-settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/keys/[id]/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/keys/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/locale/route.js +2 -2
- package/.next/standalone/.next/server/app/api/locale/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/models/alias/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/models/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/providers/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/api/version/route_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/!KGRhc2hib2FyZCk/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/mitm.html +1 -1
- package/.next/standalone/.next/server/app/mitm.rsc +5 -5
- package/.next/standalone/.next/server/app/mitm.segments/!KGRhc2hib2FyZCk/mitm/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/mitm.segments/!KGRhc2hib2FyZCk/mitm.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/mitm.segments/_full.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/mitm.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/mitm.segments/_index.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/mitm.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app-paths-manifest.json +5 -5
- package/.next/standalone/.next/server/chunks/411.js +1 -1
- package/.next/standalone/.next/server/middleware.js +2 -2
- package/.next/standalone/.next/server/pages/404.html +1 -1
- package/.next/standalone/.next/server/pages/500.html +2 -2
- package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/static/chunks/{702-90a93bbee38dba8f.js → 702-0864796c00fc702e.js} +1 -1
- package/.next/standalone/node_modules/node-forge/LICENSE +331 -0
- package/.next/standalone/node_modules/node-forge/README.md +2071 -0
- package/.next/standalone/node_modules/node-forge/dist/forge.all.min.js +2 -0
- package/.next/standalone/node_modules/node-forge/dist/forge.all.min.js.map +1 -0
- package/.next/standalone/node_modules/node-forge/dist/forge.min.js +2 -0
- package/.next/standalone/node_modules/node-forge/dist/forge.min.js.map +1 -0
- package/.next/standalone/node_modules/node-forge/dist/prime.worker.min.js +2 -0
- package/.next/standalone/node_modules/node-forge/dist/prime.worker.min.js.map +1 -0
- package/.next/standalone/node_modules/node-forge/flash/swf/SocketPool.swf +0 -0
- package/.next/standalone/node_modules/node-forge/lib/aes.js +1091 -0
- package/.next/standalone/node_modules/node-forge/lib/aesCipherSuites.js +282 -0
- package/.next/standalone/node_modules/node-forge/lib/asn1-validator.js +91 -0
- package/.next/standalone/node_modules/node-forge/lib/asn1.js +1503 -0
- package/.next/standalone/node_modules/node-forge/lib/baseN.js +186 -0
- package/.next/standalone/node_modules/node-forge/lib/cipher.js +230 -0
- package/.next/standalone/node_modules/node-forge/lib/cipherModes.js +999 -0
- package/.next/standalone/node_modules/node-forge/lib/des.js +496 -0
- package/.next/standalone/node_modules/node-forge/lib/ed25519.js +1072 -0
- package/.next/standalone/node_modules/node-forge/lib/forge.js +13 -0
- package/.next/standalone/node_modules/node-forge/lib/form.js +149 -0
- package/.next/standalone/node_modules/node-forge/lib/hmac.js +146 -0
- package/.next/standalone/node_modules/node-forge/lib/http.js +1346 -0
- package/.next/standalone/node_modules/node-forge/lib/index.all.js +16 -0
- package/.next/standalone/node_modules/node-forge/lib/index.js +33 -0
- package/.next/standalone/node_modules/node-forge/lib/jsbn.js +1264 -0
- package/.next/standalone/node_modules/node-forge/lib/kem.js +168 -0
- package/.next/standalone/node_modules/node-forge/lib/log.js +319 -0
- package/.next/standalone/node_modules/node-forge/lib/md.all.js +13 -0
- package/.next/standalone/node_modules/node-forge/lib/md.js +11 -0
- package/.next/standalone/node_modules/node-forge/lib/md5.js +289 -0
- package/.next/standalone/node_modules/node-forge/lib/mgf.js +12 -0
- package/.next/standalone/node_modules/node-forge/lib/mgf1.js +57 -0
- package/.next/standalone/node_modules/node-forge/lib/oids.js +179 -0
- package/.next/standalone/node_modules/node-forge/lib/pbe.js +1023 -0
- package/.next/standalone/node_modules/node-forge/lib/pbkdf2.js +211 -0
- package/.next/standalone/node_modules/node-forge/lib/pem.js +237 -0
- package/.next/standalone/node_modules/node-forge/lib/pkcs1.js +276 -0
- package/.next/standalone/node_modules/node-forge/lib/pkcs12.js +1078 -0
- package/.next/standalone/node_modules/node-forge/lib/pkcs7.js +1260 -0
- package/.next/standalone/node_modules/node-forge/lib/pkcs7asn1.js +410 -0
- package/.next/standalone/node_modules/node-forge/lib/pki.js +102 -0
- package/.next/standalone/node_modules/node-forge/lib/prime.js +297 -0
- package/.next/standalone/node_modules/node-forge/lib/prime.worker.js +168 -0
- package/.next/standalone/node_modules/node-forge/lib/prng.js +419 -0
- package/.next/standalone/node_modules/node-forge/lib/pss.js +241 -0
- package/.next/standalone/node_modules/node-forge/lib/random.js +191 -0
- package/.next/standalone/node_modules/node-forge/lib/rc2.js +410 -0
- package/.next/standalone/node_modules/node-forge/lib/rsa.js +1949 -0
- package/.next/standalone/node_modules/node-forge/lib/sha1.js +319 -0
- package/.next/standalone/node_modules/node-forge/lib/sha256.js +327 -0
- package/.next/standalone/node_modules/node-forge/lib/sha512.js +561 -0
- package/.next/standalone/node_modules/node-forge/lib/socket.js +287 -0
- package/.next/standalone/node_modules/node-forge/lib/ssh.js +236 -0
- package/.next/standalone/node_modules/node-forge/lib/tls.js +4282 -0
- package/.next/standalone/node_modules/node-forge/lib/tlssocket.js +249 -0
- package/.next/standalone/node_modules/node-forge/lib/util.js +2652 -0
- package/.next/standalone/node_modules/node-forge/lib/x509.js +3242 -0
- package/.next/standalone/node_modules/node-forge/lib/xhr.js +738 -0
- package/.next/standalone/node_modules/node-forge/package.json +123 -0
- package/.next/standalone/node_modules/node-machine-id/.babelrc +26 -0
- package/.next/standalone/node_modules/node-machine-id/.eslintignore +2 -0
- package/.next/standalone/node_modules/node-machine-id/.eslintrc +140 -0
- package/.next/standalone/node_modules/node-machine-id/.flowconfig +9 -0
- package/.next/standalone/node_modules/node-machine-id/LICENSE +21 -0
- package/.next/standalone/node_modules/node-machine-id/README.md +84 -0
- package/.next/standalone/node_modules/node-machine-id/dist/index.js +1 -0
- package/.next/standalone/node_modules/node-machine-id/index.js +80 -0
- package/.next/standalone/node_modules/node-machine-id/package.json +74 -0
- package/.next/standalone/node_modules/node-machine-id/tests/index.js +45 -0
- package/.next/standalone/node_modules/node-machine-id/types/index.d.ts +17 -0
- package/.next/standalone/node_modules/node-machine-id/webpack.config.babel.js +59 -0
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/src/mitm/cert/generate.js +32 -0
- package/.next/standalone/src/mitm/cert/install.js +176 -0
- package/.next/standalone/src/mitm/cert/rootCA.js +173 -0
- package/.next/standalone/src/mitm/dns/dnsConfig.js +216 -0
- package/.next/standalone/src/mitm/logger.js +8 -0
- package/.next/standalone/src/mitm/manager.js +603 -0
- package/.next/standalone/src/mitm/paths.js +16 -0
- package/package.json +1 -1
- /package/.next/standalone/.next/static/{Ws7kclTEFgfHRwd7pk9Ly → DkVxg6bby4SUixuq1vdO8}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{Ws7kclTEFgfHRwd7pk9Ly → DkVxg6bby4SUixuq1vdO8}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Functions for manipulating web forms.
|
|
3
|
+
*
|
|
4
|
+
* @author David I. Lehn <dlehn@digitalbazaar.com>
|
|
5
|
+
* @author Dave Longley
|
|
6
|
+
* @author Mike Johnson
|
|
7
|
+
*
|
|
8
|
+
* Copyright (c) 2011-2014 Digital Bazaar, Inc. All rights reserved.
|
|
9
|
+
*/
|
|
10
|
+
var forge = require('./forge');
|
|
11
|
+
|
|
12
|
+
/* Form API */
|
|
13
|
+
var form = module.exports = forge.form = forge.form || {};
|
|
14
|
+
|
|
15
|
+
(function($) {
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Regex for parsing a single name property (handles array brackets).
|
|
19
|
+
*/
|
|
20
|
+
var _regex = /([^\[]*?)\[(.*?)\]/g;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Parses a single name property into an array with the name and any
|
|
24
|
+
* array indices.
|
|
25
|
+
*
|
|
26
|
+
* @param name the name to parse.
|
|
27
|
+
*
|
|
28
|
+
* @return the array of the name and its array indices in order.
|
|
29
|
+
*/
|
|
30
|
+
var _parseName = function(name) {
|
|
31
|
+
var rval = [];
|
|
32
|
+
|
|
33
|
+
var matches;
|
|
34
|
+
while(!!(matches = _regex.exec(name))) {
|
|
35
|
+
if(matches[1].length > 0) {
|
|
36
|
+
rval.push(matches[1]);
|
|
37
|
+
}
|
|
38
|
+
if(matches.length >= 2) {
|
|
39
|
+
rval.push(matches[2]);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if(rval.length === 0) {
|
|
43
|
+
rval.push(name);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
return rval;
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Adds a field from the given form to the given object.
|
|
51
|
+
*
|
|
52
|
+
* @param obj the object.
|
|
53
|
+
* @param names the field as an array of object property names.
|
|
54
|
+
* @param value the value of the field.
|
|
55
|
+
* @param dict a dictionary of names to replace.
|
|
56
|
+
*/
|
|
57
|
+
var _addField = function(obj, names, value, dict) {
|
|
58
|
+
// combine array names that fall within square brackets
|
|
59
|
+
var tmp = [];
|
|
60
|
+
for(var i = 0; i < names.length; ++i) {
|
|
61
|
+
// check name for starting square bracket but no ending one
|
|
62
|
+
var name = names[i];
|
|
63
|
+
if(name.indexOf('[') !== -1 && name.indexOf(']') === -1 &&
|
|
64
|
+
i < names.length - 1) {
|
|
65
|
+
do {
|
|
66
|
+
name += '.' + names[++i];
|
|
67
|
+
} while(i < names.length - 1 && names[i].indexOf(']') === -1);
|
|
68
|
+
}
|
|
69
|
+
tmp.push(name);
|
|
70
|
+
}
|
|
71
|
+
names = tmp;
|
|
72
|
+
|
|
73
|
+
// split out array indexes
|
|
74
|
+
var tmp = [];
|
|
75
|
+
$.each(names, function(n, name) {
|
|
76
|
+
tmp = tmp.concat(_parseName(name));
|
|
77
|
+
});
|
|
78
|
+
names = tmp;
|
|
79
|
+
|
|
80
|
+
// iterate over object property names until value is set
|
|
81
|
+
$.each(names, function(n, name) {
|
|
82
|
+
// do dictionary name replacement
|
|
83
|
+
if(dict && name.length !== 0 && name in dict) {
|
|
84
|
+
name = dict[name];
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// blank name indicates appending to an array, set name to
|
|
88
|
+
// new last index of array
|
|
89
|
+
if(name.length === 0) {
|
|
90
|
+
name = obj.length;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// value already exists, append value
|
|
94
|
+
if(obj[name]) {
|
|
95
|
+
// last name in the field
|
|
96
|
+
if(n == names.length - 1) {
|
|
97
|
+
// more than one value, so convert into an array
|
|
98
|
+
if(!$.isArray(obj[name])) {
|
|
99
|
+
obj[name] = [obj[name]];
|
|
100
|
+
}
|
|
101
|
+
obj[name].push(value);
|
|
102
|
+
} else {
|
|
103
|
+
// not last name, go deeper into object
|
|
104
|
+
obj = obj[name];
|
|
105
|
+
}
|
|
106
|
+
} else if(n == names.length - 1) {
|
|
107
|
+
// new value, last name in the field, set value
|
|
108
|
+
obj[name] = value;
|
|
109
|
+
} else {
|
|
110
|
+
// new value, not last name, go deeper
|
|
111
|
+
// get next name
|
|
112
|
+
var next = names[n + 1];
|
|
113
|
+
|
|
114
|
+
// blank next value indicates array-appending, so create array
|
|
115
|
+
if(next.length === 0) {
|
|
116
|
+
obj[name] = [];
|
|
117
|
+
} else {
|
|
118
|
+
// if next name is a number create an array, otherwise a map
|
|
119
|
+
var isNum = ((next - 0) == next && next.length > 0);
|
|
120
|
+
obj[name] = isNum ? [] : {};
|
|
121
|
+
}
|
|
122
|
+
obj = obj[name];
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* Serializes a form to a JSON object. Object properties will be separated
|
|
129
|
+
* using the given separator (defaults to '.') and by square brackets.
|
|
130
|
+
*
|
|
131
|
+
* @param input the jquery form to serialize.
|
|
132
|
+
* @param sep the object-property separator (defaults to '.').
|
|
133
|
+
* @param dict a dictionary of names to replace (name=replace).
|
|
134
|
+
*
|
|
135
|
+
* @return the JSON-serialized form.
|
|
136
|
+
*/
|
|
137
|
+
form.serialize = function(input, sep, dict) {
|
|
138
|
+
var rval = {};
|
|
139
|
+
|
|
140
|
+
// add all fields in the form to the object
|
|
141
|
+
sep = sep || '.';
|
|
142
|
+
$.each(input.serializeArray(), function() {
|
|
143
|
+
_addField(rval, this.name.split(sep), this.value || '', dict);
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
return rval;
|
|
147
|
+
};
|
|
148
|
+
|
|
149
|
+
})(jQuery);
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hash-based Message Authentication Code implementation. Requires a message
|
|
3
|
+
* digest object that can be obtained, for example, from forge.md.sha1 or
|
|
4
|
+
* forge.md.md5.
|
|
5
|
+
*
|
|
6
|
+
* @author Dave Longley
|
|
7
|
+
*
|
|
8
|
+
* Copyright (c) 2010-2012 Digital Bazaar, Inc. All rights reserved.
|
|
9
|
+
*/
|
|
10
|
+
var forge = require('./forge');
|
|
11
|
+
require('./md');
|
|
12
|
+
require('./util');
|
|
13
|
+
|
|
14
|
+
/* HMAC API */
|
|
15
|
+
var hmac = module.exports = forge.hmac = forge.hmac || {};
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Creates an HMAC object that uses the given message digest object.
|
|
19
|
+
*
|
|
20
|
+
* @return an HMAC object.
|
|
21
|
+
*/
|
|
22
|
+
hmac.create = function() {
|
|
23
|
+
// the hmac key to use
|
|
24
|
+
var _key = null;
|
|
25
|
+
|
|
26
|
+
// the message digest to use
|
|
27
|
+
var _md = null;
|
|
28
|
+
|
|
29
|
+
// the inner padding
|
|
30
|
+
var _ipadding = null;
|
|
31
|
+
|
|
32
|
+
// the outer padding
|
|
33
|
+
var _opadding = null;
|
|
34
|
+
|
|
35
|
+
// hmac context
|
|
36
|
+
var ctx = {};
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Starts or restarts the HMAC with the given key and message digest.
|
|
40
|
+
*
|
|
41
|
+
* @param md the message digest to use, null to reuse the previous one,
|
|
42
|
+
* a string to use builtin 'sha1', 'md5', 'sha256'.
|
|
43
|
+
* @param key the key to use as a string, array of bytes, byte buffer,
|
|
44
|
+
* or null to reuse the previous key.
|
|
45
|
+
*/
|
|
46
|
+
ctx.start = function(md, key) {
|
|
47
|
+
if(md !== null) {
|
|
48
|
+
if(typeof md === 'string') {
|
|
49
|
+
// create builtin message digest
|
|
50
|
+
md = md.toLowerCase();
|
|
51
|
+
if(md in forge.md.algorithms) {
|
|
52
|
+
_md = forge.md.algorithms[md].create();
|
|
53
|
+
} else {
|
|
54
|
+
throw new Error('Unknown hash algorithm "' + md + '"');
|
|
55
|
+
}
|
|
56
|
+
} else {
|
|
57
|
+
// store message digest
|
|
58
|
+
_md = md;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
if(key === null) {
|
|
63
|
+
// reuse previous key
|
|
64
|
+
key = _key;
|
|
65
|
+
} else {
|
|
66
|
+
if(typeof key === 'string') {
|
|
67
|
+
// convert string into byte buffer
|
|
68
|
+
key = forge.util.createBuffer(key);
|
|
69
|
+
} else if(forge.util.isArray(key)) {
|
|
70
|
+
// convert byte array into byte buffer
|
|
71
|
+
var tmp = key;
|
|
72
|
+
key = forge.util.createBuffer();
|
|
73
|
+
for(var i = 0; i < tmp.length; ++i) {
|
|
74
|
+
key.putByte(tmp[i]);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// if key is longer than blocksize, hash it
|
|
79
|
+
var keylen = key.length();
|
|
80
|
+
if(keylen > _md.blockLength) {
|
|
81
|
+
_md.start();
|
|
82
|
+
_md.update(key.bytes());
|
|
83
|
+
key = _md.digest();
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// mix key into inner and outer padding
|
|
87
|
+
// ipadding = [0x36 * blocksize] ^ key
|
|
88
|
+
// opadding = [0x5C * blocksize] ^ key
|
|
89
|
+
_ipadding = forge.util.createBuffer();
|
|
90
|
+
_opadding = forge.util.createBuffer();
|
|
91
|
+
keylen = key.length();
|
|
92
|
+
for(var i = 0; i < keylen; ++i) {
|
|
93
|
+
var tmp = key.at(i);
|
|
94
|
+
_ipadding.putByte(0x36 ^ tmp);
|
|
95
|
+
_opadding.putByte(0x5C ^ tmp);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
// if key is shorter than blocksize, add additional padding
|
|
99
|
+
if(keylen < _md.blockLength) {
|
|
100
|
+
var tmp = _md.blockLength - keylen;
|
|
101
|
+
for(var i = 0; i < tmp; ++i) {
|
|
102
|
+
_ipadding.putByte(0x36);
|
|
103
|
+
_opadding.putByte(0x5C);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
_key = key;
|
|
107
|
+
_ipadding = _ipadding.bytes();
|
|
108
|
+
_opadding = _opadding.bytes();
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// digest is done like so: hash(opadding | hash(ipadding | message))
|
|
112
|
+
|
|
113
|
+
// prepare to do inner hash
|
|
114
|
+
// hash(ipadding | message)
|
|
115
|
+
_md.start();
|
|
116
|
+
_md.update(_ipadding);
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* Updates the HMAC with the given message bytes.
|
|
121
|
+
*
|
|
122
|
+
* @param bytes the bytes to update with.
|
|
123
|
+
*/
|
|
124
|
+
ctx.update = function(bytes) {
|
|
125
|
+
_md.update(bytes);
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* Produces the Message Authentication Code (MAC).
|
|
130
|
+
*
|
|
131
|
+
* @return a byte buffer containing the digest value.
|
|
132
|
+
*/
|
|
133
|
+
ctx.getMac = function() {
|
|
134
|
+
// digest is done like so: hash(opadding | hash(ipadding | message))
|
|
135
|
+
// here we do the outer hashing
|
|
136
|
+
var inner = _md.digest().bytes();
|
|
137
|
+
_md.start();
|
|
138
|
+
_md.update(_opadding);
|
|
139
|
+
_md.update(inner);
|
|
140
|
+
return _md.digest();
|
|
141
|
+
};
|
|
142
|
+
// alias for getMac
|
|
143
|
+
ctx.digest = ctx.getMac;
|
|
144
|
+
|
|
145
|
+
return ctx;
|
|
146
|
+
};
|