oxygen-cli 1.33.5 → 1.34.0

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.
@@ -0,0 +1,514 @@
1
+ "use strict";
2
+
3
+ require("source-map-support/register");
4
+
5
+ /**
6
+ * Copyright (c) 2013 Sam Decrock https://github.com/SamDecrock/
7
+ * All rights reserved.
8
+ *
9
+ * This source code is licensed under the MIT license found in the
10
+ * LICENSE file in the root directory of this source tree.
11
+ */
12
+
13
+ /* eslint-disable */
14
+ var crypto = require('crypto');
15
+
16
+ var jsmd4 = require("js-md4");
17
+
18
+ var desjs = require("des.js");
19
+
20
+ var flags = {
21
+ NTLM_NegotiateUnicode: 0x00000001,
22
+ NTLM_NegotiateOEM: 0x00000002,
23
+ NTLM_RequestTarget: 0x00000004,
24
+ NTLM_Unknown9: 0x00000008,
25
+ NTLM_NegotiateSign: 0x00000010,
26
+ NTLM_NegotiateSeal: 0x00000020,
27
+ NTLM_NegotiateDatagram: 0x00000040,
28
+ NTLM_NegotiateLanManagerKey: 0x00000080,
29
+ NTLM_Unknown8: 0x00000100,
30
+ NTLM_NegotiateNTLM: 0x00000200,
31
+ NTLM_NegotiateNTOnly: 0x00000400,
32
+ NTLM_Anonymous: 0x00000800,
33
+ NTLM_NegotiateOemDomainSupplied: 0x00001000,
34
+ NTLM_NegotiateOemWorkstationSupplied: 0x00002000,
35
+ NTLM_Unknown6: 0x00004000,
36
+ NTLM_NegotiateAlwaysSign: 0x00008000,
37
+ NTLM_TargetTypeDomain: 0x00010000,
38
+ NTLM_TargetTypeServer: 0x00020000,
39
+ NTLM_TargetTypeShare: 0x00040000,
40
+ NTLM_NegotiateExtendedSecurity: 0x00080000,
41
+ NTLM_NegotiateIdentify: 0x00100000,
42
+ NTLM_Unknown5: 0x00200000,
43
+ NTLM_RequestNonNTSessionKey: 0x00400000,
44
+ NTLM_NegotiateTargetInfo: 0x00800000,
45
+ NTLM_Unknown4: 0x01000000,
46
+ NTLM_NegotiateVersion: 0x02000000,
47
+ NTLM_Unknown3: 0x04000000,
48
+ NTLM_Unknown2: 0x08000000,
49
+ NTLM_Unknown1: 0x10000000,
50
+ NTLM_Negotiate128: 0x20000000,
51
+ NTLM_NegotiateKeyExchange: 0x40000000,
52
+ NTLM_Negotiate56: 0x80000000
53
+ };
54
+ var typeflags = {
55
+ NTLM_TYPE1_FLAGS: flags.NTLM_NegotiateUnicode + flags.NTLM_NegotiateOEM + flags.NTLM_RequestTarget + flags.NTLM_NegotiateNTLM + flags.NTLM_NegotiateOemDomainSupplied + flags.NTLM_NegotiateOemWorkstationSupplied + flags.NTLM_NegotiateAlwaysSign + flags.NTLM_NegotiateExtendedSecurity + flags.NTLM_NegotiateVersion + flags.NTLM_Negotiate128 + flags.NTLM_Negotiate56,
56
+ NTLM_TYPE2_FLAGS: flags.NTLM_NegotiateUnicode + flags.NTLM_RequestTarget + flags.NTLM_NegotiateNTLM + flags.NTLM_NegotiateAlwaysSign + flags.NTLM_NegotiateExtendedSecurity + flags.NTLM_NegotiateTargetInfo + flags.NTLM_NegotiateVersion + flags.NTLM_Negotiate128 + flags.NTLM_Negotiate56
57
+ };
58
+
59
+ function createType1Message(options) {
60
+ if (!options.domain) options.domain = '';
61
+ if (!options.workstation) options.workstation = '';
62
+ var domain = escape(options.domain.toUpperCase());
63
+ var workstation = escape(options.workstation.toUpperCase());
64
+ var protocol = 'NTLMSSP\0';
65
+ var BODY_LENGTH = 40;
66
+ var type1flags = typeflags.NTLM_TYPE1_FLAGS;
67
+ if (!domain || domain === '') type1flags = type1flags - flags.NTLM_NegotiateOemDomainSupplied;
68
+ var pos = 0;
69
+ var buf = Buffer.alloc(BODY_LENGTH + domain.length + workstation.length);
70
+ buf.write(protocol, pos, protocol.length);
71
+ pos += protocol.length; // protocol
72
+
73
+ buf.writeUInt32LE(1, pos);
74
+ pos += 4; // type 1
75
+
76
+ buf.writeUInt32LE(type1flags, pos);
77
+ pos += 4; // TYPE1 flag
78
+
79
+ buf.writeUInt16LE(domain.length, pos);
80
+ pos += 2; // domain length
81
+
82
+ buf.writeUInt16LE(domain.length, pos);
83
+ pos += 2; // domain max length
84
+
85
+ buf.writeUInt32LE(BODY_LENGTH + workstation.length, pos);
86
+ pos += 4; // domain buffer offset
87
+
88
+ buf.writeUInt16LE(workstation.length, pos);
89
+ pos += 2; // workstation length
90
+
91
+ buf.writeUInt16LE(workstation.length, pos);
92
+ pos += 2; // workstation max length
93
+
94
+ buf.writeUInt32LE(BODY_LENGTH, pos);
95
+ pos += 4; // workstation buffer offset
96
+
97
+ buf.writeUInt8(5, pos);
98
+ pos += 1; //ProductMajorVersion
99
+
100
+ buf.writeUInt8(1, pos);
101
+ pos += 1; //ProductMinorVersion
102
+
103
+ buf.writeUInt16LE(2600, pos);
104
+ pos += 2; //ProductBuild
105
+
106
+ buf.writeUInt8(0, pos);
107
+ pos += 1; //VersionReserved1
108
+
109
+ buf.writeUInt8(0, pos);
110
+ pos += 1; //VersionReserved2
111
+
112
+ buf.writeUInt8(0, pos);
113
+ pos += 1; //VersionReserved3
114
+
115
+ buf.writeUInt8(15, pos);
116
+ pos += 1; //NTLMRevisionCurrent
117
+ // length checks is to fix issue #46 and possibly #57
118
+
119
+ if (workstation.length != 0) buf.write(workstation, pos, workstation.length, 'ascii');
120
+ pos += workstation.length; // workstation string
121
+
122
+ if (domain.length != 0) buf.write(domain, pos, domain.length, 'ascii');
123
+ pos += domain.length; // domain string
124
+
125
+ return 'NTLM ' + buf.toString('base64');
126
+ }
127
+
128
+ function parseType2Message(rawmsg) {
129
+ var match = rawmsg.match(/NTLM (.+)?/);
130
+
131
+ if (!match || !match[1]) {
132
+ throw new Error("Couldn't find NTLM in the message type2 coming from the server");
133
+ }
134
+
135
+ var buf = Buffer.from(match[1], 'base64');
136
+ var msg = {};
137
+ msg.signature = buf.slice(0, 8);
138
+ msg.type = buf.readInt16LE(8);
139
+
140
+ if (msg.type != 2) {
141
+ throw new Error("Server didn't return a type 2 message");
142
+ }
143
+
144
+ msg.targetNameLen = buf.readInt16LE(12);
145
+ msg.targetNameMaxLen = buf.readInt16LE(14);
146
+ msg.targetNameOffset = buf.readInt32LE(16);
147
+ msg.targetName = buf.slice(msg.targetNameOffset, msg.targetNameOffset + msg.targetNameMaxLen);
148
+ msg.negotiateFlags = buf.readInt32LE(20);
149
+ msg.serverChallenge = buf.slice(24, 32);
150
+ msg.reserved = buf.slice(32, 40);
151
+
152
+ if (msg.negotiateFlags & flags.NTLM_NegotiateTargetInfo) {
153
+ msg.targetInfoLen = buf.readInt16LE(40);
154
+ msg.targetInfoMaxLen = buf.readInt16LE(42);
155
+ msg.targetInfoOffset = buf.readInt32LE(44);
156
+ msg.targetInfo = buf.slice(msg.targetInfoOffset, msg.targetInfoOffset + msg.targetInfoLen);
157
+ }
158
+
159
+ return msg;
160
+ }
161
+
162
+ function createType3Message(msg2, options) {
163
+ if (!options.domain) options.domain = '';
164
+ if (!options.workstation) options.workstation = '';
165
+ if (!options.username) options.username = '';
166
+ if (!options.password) options.password = '';
167
+ var nonce = msg2.serverChallenge;
168
+ var username = options.username;
169
+ var password = options.password;
170
+ var lm_password = options.lm_password;
171
+ var nt_password = options.nt_password;
172
+ var negotiateFlags = msg2.negotiateFlags;
173
+ var isUnicode = negotiateFlags & flags.NTLM_NegotiateUnicode;
174
+ var isNegotiateExtendedSecurity = negotiateFlags & flags.NTLM_NegotiateExtendedSecurity;
175
+ var BODY_LENGTH = 72;
176
+ var domainName = escape(options.domain.toUpperCase());
177
+ var workstation = escape(options.workstation.toUpperCase());
178
+ var workstationBytes, domainNameBytes, usernameBytes, encryptedRandomSessionKeyBytes;
179
+ var encryptedRandomSessionKey = "";
180
+
181
+ if (isUnicode) {
182
+ workstationBytes = Buffer.from(workstation, 'utf16le');
183
+ domainNameBytes = Buffer.from(domainName, 'utf16le');
184
+ usernameBytes = Buffer.from(username, 'utf16le');
185
+ encryptedRandomSessionKeyBytes = Buffer.from(encryptedRandomSessionKey, 'utf16le');
186
+ } else {
187
+ workstationBytes = Buffer.from(workstation, 'ascii');
188
+ domainNameBytes = Buffer.from(domainName, 'ascii');
189
+ usernameBytes = Buffer.from(username, 'ascii');
190
+ encryptedRandomSessionKeyBytes = Buffer.from(encryptedRandomSessionKey, 'ascii');
191
+ }
192
+
193
+ var lmChallengeResponse = calc_resp(lm_password != null ? lm_password : create_LM_hashed_password_v1(password), nonce);
194
+ var ntChallengeResponse = calc_resp(nt_password != null ? nt_password : create_NT_hashed_password_v1(password), nonce);
195
+
196
+ if (isNegotiateExtendedSecurity) {
197
+ /*
198
+ * NTLMv2 extended security is enabled. While this technically can mean NTLMv2 extended security with NTLMv1 protocol,
199
+ * servers that support extended security likely also support NTLMv2, so use NTLMv2.
200
+ * This is also how curl implements NTLMv2 "detection".
201
+ * By using NTLMv2, this supports communication with servers that forbid the use of NTLMv1 (e.g. via windows policies)
202
+ *
203
+ * However, the target info is needed to construct the NTLMv2 response so if it can't be negotiated,
204
+ * fall back to NTLMv1 with NTLMv2 extended security.
205
+ */
206
+ var pwhash = nt_password != null ? nt_password : create_NT_hashed_password_v1(password);
207
+ var clientChallenge = "";
208
+
209
+ for (var i = 0; i < 8; i++) {
210
+ clientChallenge += String.fromCharCode(Math.floor(Math.random() * 256));
211
+ }
212
+
213
+ var clientChallengeBytes = Buffer.from(clientChallenge, 'ascii');
214
+ var challenges = msg2.targetInfo ? calc_ntlmv2_resp(pwhash, username, domainName, msg2.targetInfo, nonce, clientChallengeBytes) : ntlm2sr_calc_resp(pwhash, nonce, clientChallengeBytes);
215
+ lmChallengeResponse = challenges.lmChallengeResponse;
216
+ ntChallengeResponse = challenges.ntChallengeResponse;
217
+ }
218
+
219
+ var signature = 'NTLMSSP\0';
220
+ var pos = 0;
221
+ var buf = Buffer.alloc(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length + ntChallengeResponse.length + encryptedRandomSessionKeyBytes.length);
222
+ buf.write(signature, pos, signature.length);
223
+ pos += signature.length;
224
+ buf.writeUInt32LE(3, pos);
225
+ pos += 4; // type 1
226
+
227
+ buf.writeUInt16LE(lmChallengeResponse.length, pos);
228
+ pos += 2; // LmChallengeResponseLen
229
+
230
+ buf.writeUInt16LE(lmChallengeResponse.length, pos);
231
+ pos += 2; // LmChallengeResponseMaxLen
232
+
233
+ buf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length, pos);
234
+ pos += 4; // LmChallengeResponseOffset
235
+
236
+ buf.writeUInt16LE(ntChallengeResponse.length, pos);
237
+ pos += 2; // NtChallengeResponseLen
238
+
239
+ buf.writeUInt16LE(ntChallengeResponse.length, pos);
240
+ pos += 2; // NtChallengeResponseMaxLen
241
+
242
+ buf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length, pos);
243
+ pos += 4; // NtChallengeResponseOffset
244
+
245
+ buf.writeUInt16LE(domainNameBytes.length, pos);
246
+ pos += 2; // DomainNameLen
247
+
248
+ buf.writeUInt16LE(domainNameBytes.length, pos);
249
+ pos += 2; // DomainNameMaxLen
250
+
251
+ buf.writeUInt32LE(BODY_LENGTH, pos);
252
+ pos += 4; // DomainNameOffset
253
+
254
+ buf.writeUInt16LE(usernameBytes.length, pos);
255
+ pos += 2; // UserNameLen
256
+
257
+ buf.writeUInt16LE(usernameBytes.length, pos);
258
+ pos += 2; // UserNameMaxLen
259
+
260
+ buf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length, pos);
261
+ pos += 4; // UserNameOffset
262
+
263
+ buf.writeUInt16LE(workstationBytes.length, pos);
264
+ pos += 2; // WorkstationLen
265
+
266
+ buf.writeUInt16LE(workstationBytes.length, pos);
267
+ pos += 2; // WorkstationMaxLen
268
+
269
+ buf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length, pos);
270
+ pos += 4; // WorkstationOffset
271
+
272
+ buf.writeUInt16LE(encryptedRandomSessionKeyBytes.length, pos);
273
+ pos += 2; // EncryptedRandomSessionKeyLen
274
+
275
+ buf.writeUInt16LE(encryptedRandomSessionKeyBytes.length, pos);
276
+ pos += 2; // EncryptedRandomSessionKeyMaxLen
277
+
278
+ buf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length + ntChallengeResponse.length, pos);
279
+ pos += 4; // EncryptedRandomSessionKeyOffset
280
+ // Fix #98
281
+
282
+ var flagsToWrite = isUnicode ? typeflags.NTLM_TYPE2_FLAGS : typeflags.NTLM_TYPE2_FLAGS - flags.NTLM_NegotiateUnicode;
283
+ buf.writeUInt32LE(flagsToWrite, pos);
284
+ pos += 4; // NegotiateFlags
285
+
286
+ buf.writeUInt8(5, pos);
287
+ pos++; // ProductMajorVersion
288
+
289
+ buf.writeUInt8(1, pos);
290
+ pos++; // ProductMinorVersion
291
+
292
+ buf.writeUInt16LE(2600, pos);
293
+ pos += 2; // ProductBuild
294
+
295
+ buf.writeUInt8(0, pos);
296
+ pos++; // VersionReserved1
297
+
298
+ buf.writeUInt8(0, pos);
299
+ pos++; // VersionReserved2
300
+
301
+ buf.writeUInt8(0, pos);
302
+ pos++; // VersionReserved3
303
+
304
+ buf.writeUInt8(15, pos);
305
+ pos++; // NTLMRevisionCurrent
306
+
307
+ domainNameBytes.copy(buf, pos);
308
+ pos += domainNameBytes.length;
309
+ usernameBytes.copy(buf, pos);
310
+ pos += usernameBytes.length;
311
+ workstationBytes.copy(buf, pos);
312
+ pos += workstationBytes.length;
313
+ lmChallengeResponse.copy(buf, pos);
314
+ pos += lmChallengeResponse.length;
315
+ ntChallengeResponse.copy(buf, pos);
316
+ pos += ntChallengeResponse.length;
317
+ encryptedRandomSessionKeyBytes.copy(buf, pos);
318
+ pos += encryptedRandomSessionKeyBytes.length;
319
+ return 'NTLM ' + buf.toString('base64');
320
+ }
321
+
322
+ function create_LM_hashed_password_v1(password) {
323
+ // fix the password length to 14 bytes
324
+ password = password.toUpperCase();
325
+ var passwordBytes = Buffer.from(password, 'ascii');
326
+ var passwordBytesPadded = Buffer.alloc(14);
327
+ passwordBytesPadded.fill("\0");
328
+ var sourceEnd = 14;
329
+ if (passwordBytes.length < 14) sourceEnd = passwordBytes.length;
330
+ passwordBytes.copy(passwordBytesPadded, 0, 0, sourceEnd); // split into 2 parts of 7 bytes:
331
+
332
+ var firstPart = passwordBytesPadded.slice(0, 7);
333
+ var secondPart = passwordBytesPadded.slice(7);
334
+
335
+ function encrypt(buf) {
336
+ var key = insertZerosEvery7Bits(buf);
337
+ var des = desjs.DES.create({
338
+ type: 'encrypt',
339
+ key: key
340
+ });
341
+ var magicKey = Buffer.from('KGS!@#$%', 'ascii'); // page 57 in [MS-NLMP]
342
+
343
+ var encrypted = des.update(magicKey);
344
+ return Buffer.from(encrypted);
345
+ }
346
+
347
+ var firstPartEncrypted = encrypt(firstPart);
348
+ var secondPartEncrypted = encrypt(secondPart);
349
+ return Buffer.concat([firstPartEncrypted, secondPartEncrypted]);
350
+ }
351
+
352
+ function insertZerosEvery7Bits(buf) {
353
+ var binaryArray = bytes2binaryArray(buf);
354
+ var newBinaryArray = [];
355
+
356
+ for (var i = 0; i < binaryArray.length; i++) {
357
+ newBinaryArray.push(binaryArray[i]);
358
+
359
+ if ((i + 1) % 7 === 0) {
360
+ newBinaryArray.push(0);
361
+ }
362
+ }
363
+
364
+ return binaryArray2bytes(newBinaryArray);
365
+ }
366
+
367
+ function bytes2binaryArray(buf) {
368
+ var hex2binary = {
369
+ 0: [0, 0, 0, 0],
370
+ 1: [0, 0, 0, 1],
371
+ 2: [0, 0, 1, 0],
372
+ 3: [0, 0, 1, 1],
373
+ 4: [0, 1, 0, 0],
374
+ 5: [0, 1, 0, 1],
375
+ 6: [0, 1, 1, 0],
376
+ 7: [0, 1, 1, 1],
377
+ 8: [1, 0, 0, 0],
378
+ 9: [1, 0, 0, 1],
379
+ A: [1, 0, 1, 0],
380
+ B: [1, 0, 1, 1],
381
+ C: [1, 1, 0, 0],
382
+ D: [1, 1, 0, 1],
383
+ E: [1, 1, 1, 0],
384
+ F: [1, 1, 1, 1]
385
+ };
386
+ var hexString = buf.toString('hex').toUpperCase();
387
+ var array = [];
388
+
389
+ for (var i = 0; i < hexString.length; i++) {
390
+ var hexchar = hexString.charAt(i);
391
+ array = array.concat(hex2binary[hexchar]);
392
+ }
393
+
394
+ return array;
395
+ }
396
+
397
+ function binaryArray2bytes(array) {
398
+ var binary2hex = {
399
+ '0000': 0,
400
+ '0001': 1,
401
+ '0010': 2,
402
+ '0011': 3,
403
+ '0100': 4,
404
+ '0101': 5,
405
+ '0110': 6,
406
+ '0111': 7,
407
+ '1000': 8,
408
+ '1001': 9,
409
+ '1010': 'A',
410
+ '1011': 'B',
411
+ '1100': 'C',
412
+ '1101': 'D',
413
+ '1110': 'E',
414
+ '1111': 'F'
415
+ };
416
+ var bufArray = [];
417
+
418
+ for (var i = 0; i < array.length; i += 8) {
419
+ if (i + 7 > array.length) break;
420
+ var binString1 = '' + array[i] + '' + array[i + 1] + '' + array[i + 2] + '' + array[i + 3];
421
+ var binString2 = '' + array[i + 4] + '' + array[i + 5] + '' + array[i + 6] + '' + array[i + 7];
422
+ var hexchar1 = binary2hex[binString1];
423
+ var hexchar2 = binary2hex[binString2];
424
+ var buf = Buffer.from(hexchar1 + '' + hexchar2, 'hex');
425
+ bufArray.push(buf);
426
+ }
427
+
428
+ return Buffer.concat(bufArray);
429
+ }
430
+
431
+ function create_NT_hashed_password_v1(password) {
432
+ var buf = Buffer.from(password, 'utf16le');
433
+ var md4 = jsmd4.create();
434
+ md4.update(buf);
435
+ return Buffer.from(md4.digest());
436
+ }
437
+
438
+ function calc_resp(password_hash, server_challenge) {
439
+ // padding with zeros to make the hash 21 bytes long
440
+ var passHashPadded = Buffer.alloc(21);
441
+ passHashPadded.fill("\0");
442
+ password_hash.copy(passHashPadded, 0, 0, password_hash.length);
443
+ var resArray = [];
444
+ var des = desjs.DES.create({
445
+ type: 'encrypt',
446
+ key: insertZerosEvery7Bits(passHashPadded.slice(0, 7))
447
+ });
448
+ resArray.push(Buffer.from(des.update(server_challenge.slice(0, 8))));
449
+ des = desjs.DES.create({
450
+ type: 'encrypt',
451
+ key: insertZerosEvery7Bits(passHashPadded.slice(7, 14))
452
+ });
453
+ resArray.push(Buffer.from(des.update(server_challenge.slice(0, 8))));
454
+ des = desjs.DES.create({
455
+ type: 'encrypt',
456
+ key: insertZerosEvery7Bits(passHashPadded.slice(14, 21))
457
+ });
458
+ resArray.push(Buffer.from(des.update(server_challenge.slice(0, 8))));
459
+ return Buffer.concat(resArray);
460
+ }
461
+
462
+ function hmac_md5(key, data) {
463
+ var hmac = crypto.createHmac('md5', key);
464
+ hmac.update(data);
465
+ return hmac.digest();
466
+ }
467
+
468
+ function ntlm2sr_calc_resp(responseKeyNT, serverChallenge, clientChallenge) {
469
+ // padding with zeros to make the hash 16 bytes longer
470
+ var lmChallengeResponse = Buffer.alloc(clientChallenge.length + 16);
471
+ lmChallengeResponse.fill("\0");
472
+ clientChallenge.copy(lmChallengeResponse, 0, 0, clientChallenge.length);
473
+ var buf = Buffer.concat([serverChallenge, clientChallenge]);
474
+ var md5 = crypto.createHash('md5');
475
+ md5.update(buf);
476
+ var sess = md5.digest();
477
+ var ntChallengeResponse = calc_resp(responseKeyNT, sess.slice(0, 8));
478
+ return {
479
+ lmChallengeResponse: lmChallengeResponse,
480
+ ntChallengeResponse: ntChallengeResponse
481
+ };
482
+ }
483
+
484
+ function calc_ntlmv2_resp(pwhash, username, domain, targetInfo, serverChallenge, clientChallenge) {
485
+ var responseKeyNTLM = NTOWFv2(pwhash, username, domain);
486
+ var lmV2ChallengeResponse = Buffer.concat([hmac_md5(responseKeyNTLM, Buffer.concat([serverChallenge, clientChallenge])), clientChallenge]); // 11644473600000 = diff between 1970 and 1601
487
+
488
+ var now = Date.now();
489
+ var timestamp = (BigInt(now) + BigInt(11644473600000)) * BigInt(10000); // we need BigInt to be able to write it to a buffer
490
+
491
+ var timestampBuffer = Buffer.alloc(8);
492
+ timestampBuffer.writeBigUInt64LE(timestamp);
493
+ var zero32Bit = Buffer.alloc(4, 0);
494
+ var temp = Buffer.concat([// Version
495
+ Buffer.from([0x01, 0x01, 0x00, 0x00]), zero32Bit, timestampBuffer, clientChallenge, zero32Bit, targetInfo, zero32Bit]);
496
+ var proofString = hmac_md5(responseKeyNTLM, Buffer.concat([serverChallenge, temp]));
497
+ var ntV2ChallengeResponse = Buffer.concat([proofString, temp]);
498
+ return {
499
+ lmChallengeResponse: lmV2ChallengeResponse,
500
+ ntChallengeResponse: ntV2ChallengeResponse
501
+ };
502
+ }
503
+
504
+ function NTOWFv2(pwhash, user, domain) {
505
+ return hmac_md5(pwhash, Buffer.from(user.toUpperCase() + domain, 'utf16le'));
506
+ }
507
+
508
+ exports.createType1Message = createType1Message;
509
+ exports.parseType2Message = parseType2Message;
510
+ exports.createType3Message = createType3Message;
511
+ exports.create_NT_hashed_password = create_NT_hashed_password_v1;
512
+ exports.create_LM_hashed_password = create_LM_hashed_password_v1;
513
+ /* eslint-enable */
514
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ox_modules/module-http/ntlm.js"],"names":["crypto","require","jsmd4","desjs","flags","NTLM_NegotiateUnicode","NTLM_NegotiateOEM","NTLM_RequestTarget","NTLM_Unknown9","NTLM_NegotiateSign","NTLM_NegotiateSeal","NTLM_NegotiateDatagram","NTLM_NegotiateLanManagerKey","NTLM_Unknown8","NTLM_NegotiateNTLM","NTLM_NegotiateNTOnly","NTLM_Anonymous","NTLM_NegotiateOemDomainSupplied","NTLM_NegotiateOemWorkstationSupplied","NTLM_Unknown6","NTLM_NegotiateAlwaysSign","NTLM_TargetTypeDomain","NTLM_TargetTypeServer","NTLM_TargetTypeShare","NTLM_NegotiateExtendedSecurity","NTLM_NegotiateIdentify","NTLM_Unknown5","NTLM_RequestNonNTSessionKey","NTLM_NegotiateTargetInfo","NTLM_Unknown4","NTLM_NegotiateVersion","NTLM_Unknown3","NTLM_Unknown2","NTLM_Unknown1","NTLM_Negotiate128","NTLM_NegotiateKeyExchange","NTLM_Negotiate56","typeflags","NTLM_TYPE1_FLAGS","NTLM_TYPE2_FLAGS","createType1Message","options","domain","workstation","escape","toUpperCase","protocol","BODY_LENGTH","type1flags","pos","buf","Buffer","alloc","length","write","writeUInt32LE","writeUInt16LE","writeUInt8","toString","parseType2Message","rawmsg","match","Error","from","msg","signature","slice","type","readInt16LE","targetNameLen","targetNameMaxLen","targetNameOffset","readInt32LE","targetName","negotiateFlags","serverChallenge","reserved","targetInfoLen","targetInfoMaxLen","targetInfoOffset","targetInfo","createType3Message","msg2","username","password","nonce","lm_password","nt_password","isUnicode","isNegotiateExtendedSecurity","domainName","workstationBytes","domainNameBytes","usernameBytes","encryptedRandomSessionKeyBytes","encryptedRandomSessionKey","lmChallengeResponse","calc_resp","create_LM_hashed_password_v1","ntChallengeResponse","create_NT_hashed_password_v1","pwhash","clientChallenge","i","String","fromCharCode","Math","floor","random","clientChallengeBytes","challenges","calc_ntlmv2_resp","ntlm2sr_calc_resp","flagsToWrite","copy","passwordBytes","passwordBytesPadded","fill","sourceEnd","firstPart","secondPart","encrypt","key","insertZerosEvery7Bits","des","DES","create","magicKey","encrypted","update","firstPartEncrypted","secondPartEncrypted","concat","binaryArray","bytes2binaryArray","newBinaryArray","push","binaryArray2bytes","hex2binary","A","B","C","D","E","F","hexString","array","hexchar","charAt","binary2hex","bufArray","binString1","binString2","hexchar1","hexchar2","md4","digest","password_hash","server_challenge","passHashPadded","resArray","hmac_md5","data","hmac","createHmac","responseKeyNT","md5","createHash","sess","responseKeyNTLM","NTOWFv2","lmV2ChallengeResponse","now","Date","timestamp","BigInt","timestampBuffer","writeBigUInt64LE","zero32Bit","temp","proofString","ntV2ChallengeResponse","user","exports","create_NT_hashed_password","create_LM_hashed_password"],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2013 Sam Decrock https://github.com/SamDecrock/\r\n * All rights reserved.\r\n *\r\n * This source code is licensed under the MIT license found in the\r\n * LICENSE file in the root directory of this source tree.\r\n */\r\n/* eslint-disable */\r\nvar crypto = require('crypto');\r\nvar jsmd4 = require(\"js-md4\");\r\nvar desjs = require(\"des.js\");\r\n\r\nvar flags = {\r\n\tNTLM_NegotiateUnicode                :  0x00000001,\r\n\tNTLM_NegotiateOEM                    :  0x00000002,\r\n\tNTLM_RequestTarget                   :  0x00000004,\r\n\tNTLM_Unknown9                        :  0x00000008,\r\n\tNTLM_NegotiateSign                   :  0x00000010,\r\n\tNTLM_NegotiateSeal                   :  0x00000020,\r\n\tNTLM_NegotiateDatagram               :  0x00000040,\r\n\tNTLM_NegotiateLanManagerKey          :  0x00000080,\r\n\tNTLM_Unknown8                        :  0x00000100,\r\n\tNTLM_NegotiateNTLM                   :  0x00000200,\r\n\tNTLM_NegotiateNTOnly                 :  0x00000400,\r\n\tNTLM_Anonymous                       :  0x00000800,\r\n\tNTLM_NegotiateOemDomainSupplied      :  0x00001000,\r\n\tNTLM_NegotiateOemWorkstationSupplied :  0x00002000,\r\n\tNTLM_Unknown6                        :  0x00004000,\r\n\tNTLM_NegotiateAlwaysSign             :  0x00008000,\r\n\tNTLM_TargetTypeDomain                :  0x00010000,\r\n\tNTLM_TargetTypeServer                :  0x00020000,\r\n\tNTLM_TargetTypeShare                 :  0x00040000,\r\n\tNTLM_NegotiateExtendedSecurity       :  0x00080000,\r\n\tNTLM_NegotiateIdentify               :  0x00100000,\r\n\tNTLM_Unknown5                        :  0x00200000,\r\n\tNTLM_RequestNonNTSessionKey          :  0x00400000,\r\n\tNTLM_NegotiateTargetInfo             :  0x00800000,\r\n\tNTLM_Unknown4                        :  0x01000000,\r\n\tNTLM_NegotiateVersion                :  0x02000000,\r\n\tNTLM_Unknown3                        :  0x04000000,\r\n\tNTLM_Unknown2                        :  0x08000000,\r\n\tNTLM_Unknown1                        :  0x10000000,\r\n\tNTLM_Negotiate128                    :  0x20000000,\r\n\tNTLM_NegotiateKeyExchange            :  0x40000000,\r\n\tNTLM_Negotiate56                     :  0x80000000\r\n};\r\nvar typeflags = {\r\n\tNTLM_TYPE1_FLAGS : \t  flags.NTLM_NegotiateUnicode\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateOEM\r\n\t\t\t\t\t\t+ flags.NTLM_RequestTarget\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateNTLM\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateOemDomainSupplied\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateOemWorkstationSupplied\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateAlwaysSign\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateExtendedSecurity\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateVersion\r\n\t\t\t\t\t\t+ flags.NTLM_Negotiate128\r\n\t\t\t\t\t\t+ flags.NTLM_Negotiate56,\r\n\r\n\tNTLM_TYPE2_FLAGS :    flags.NTLM_NegotiateUnicode\r\n\t\t\t\t\t\t+ flags.NTLM_RequestTarget\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateNTLM\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateAlwaysSign\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateExtendedSecurity\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateTargetInfo\r\n\t\t\t\t\t\t+ flags.NTLM_NegotiateVersion\r\n\t\t\t\t\t\t+ flags.NTLM_Negotiate128\r\n\t\t\t\t\t\t+ flags.NTLM_Negotiate56\r\n};\r\n\r\nfunction createType1Message(options){\r\n\tif(!options.domain) options.domain = '';\r\n\tif(!options.workstation) options.workstation = '';\r\n\r\n\tvar domain = escape(options.domain.toUpperCase());\r\n\tvar workstation = escape(options.workstation.toUpperCase());\r\n\tvar protocol = 'NTLMSSP\\0';\r\n\r\n\tvar BODY_LENGTH = 40;\r\n\r\n\tvar type1flags = typeflags.NTLM_TYPE1_FLAGS;\r\n\tif(!domain || domain === '')\r\n\t\ttype1flags = type1flags - flags.NTLM_NegotiateOemDomainSupplied;\r\n\r\n\tvar pos = 0;\r\n\tvar buf = Buffer.alloc(BODY_LENGTH + domain.length + workstation.length);\r\n\r\n\r\n\tbuf.write(protocol, pos, protocol.length); pos += protocol.length; // protocol\r\n\tbuf.writeUInt32LE(1, pos); pos += 4;          // type 1\r\n\tbuf.writeUInt32LE(type1flags, pos); pos += 4; // TYPE1 flag\r\n\r\n\tbuf.writeUInt16LE(domain.length, pos); pos += 2; // domain length\r\n\tbuf.writeUInt16LE(domain.length, pos); pos += 2; // domain max length\r\n\tbuf.writeUInt32LE(BODY_LENGTH + workstation.length, pos); pos += 4; // domain buffer offset\r\n\r\n\tbuf.writeUInt16LE(workstation.length, pos); pos += 2; // workstation length\r\n\tbuf.writeUInt16LE(workstation.length, pos); pos += 2; // workstation max length\r\n\tbuf.writeUInt32LE(BODY_LENGTH, pos); pos += 4; // workstation buffer offset\r\n\r\n\tbuf.writeUInt8(5, pos); pos += 1;      //ProductMajorVersion\r\n\tbuf.writeUInt8(1, pos); pos += 1;      //ProductMinorVersion\r\n\tbuf.writeUInt16LE(2600, pos); pos += 2; //ProductBuild\r\n\r\n\tbuf.writeUInt8(0 , pos); pos += 1; //VersionReserved1\r\n\tbuf.writeUInt8(0 , pos); pos += 1; //VersionReserved2\r\n\tbuf.writeUInt8(0 , pos); pos += 1; //VersionReserved3\r\n\tbuf.writeUInt8(15, pos); pos += 1; //NTLMRevisionCurrent\r\n\r\n\r\n\t// length checks is to fix issue #46 and possibly #57\r\n\tif(workstation.length !=0) buf.write(workstation, pos, workstation.length, 'ascii'); pos += workstation.length; // workstation string\r\n\tif(domain.length !=0)      buf.write(domain     , pos, domain.length     , 'ascii'); pos += domain.length; // domain string\r\n\r\n\treturn 'NTLM ' + buf.toString('base64');\r\n}\r\n\r\nfunction parseType2Message(rawmsg){\r\n\tvar match = rawmsg.match(/NTLM (.+)?/);\r\n\tif(!match || !match[1]) {\r\n\t\tthrow new Error(\"Couldn't find NTLM in the message type2 coming from the server\");\r\n\t}\r\n\r\n\tvar buf = Buffer.from(match[1], 'base64');\r\n\r\n\tvar msg = {};\r\n\r\n\tmsg.signature = buf.slice(0, 8);\r\n\tmsg.type = buf.readInt16LE(8);\r\n\r\n\tif(msg.type != 2) {\r\n\t\tthrow new Error(\"Server didn't return a type 2 message\");\r\n\t}\r\n\r\n\tmsg.targetNameLen = buf.readInt16LE(12);\r\n\tmsg.targetNameMaxLen = buf.readInt16LE(14);\r\n\tmsg.targetNameOffset = buf.readInt32LE(16);\r\n\tmsg.targetName  = buf.slice(msg.targetNameOffset, msg.targetNameOffset + msg.targetNameMaxLen);\r\n\r\n    msg.negotiateFlags = buf.readInt32LE(20);\r\n    msg.serverChallenge = buf.slice(24, 32);\r\n    msg.reserved = buf.slice(32, 40);\r\n\r\n    if(msg.negotiateFlags & flags.NTLM_NegotiateTargetInfo){\r\n    \tmsg.targetInfoLen = buf.readInt16LE(40);\r\n    \tmsg.targetInfoMaxLen = buf.readInt16LE(42);\r\n    \tmsg.targetInfoOffset = buf.readInt32LE(44);\r\n    \tmsg.targetInfo = buf.slice(msg.targetInfoOffset, msg.targetInfoOffset + msg.targetInfoLen);\r\n    }\r\n\treturn msg;\r\n}\r\n\r\nfunction createType3Message(msg2, options){\r\n\tif(!options.domain) options.domain = '';\r\n\tif(!options.workstation) options.workstation = '';\r\n\tif(!options.username) options.username = '';\r\n\tif(!options.password) options.password = '';\r\n\r\n\tvar nonce = msg2.serverChallenge;\r\n\tvar username = options.username;\r\n\tvar password = options.password;\r\n\tvar lm_password = options.lm_password;\r\n\tvar nt_password = options.nt_password;\r\n\tvar negotiateFlags = msg2.negotiateFlags;\r\n\r\n\tvar isUnicode = negotiateFlags & flags.NTLM_NegotiateUnicode;\r\n\tvar isNegotiateExtendedSecurity = negotiateFlags & flags.NTLM_NegotiateExtendedSecurity;\r\n\r\n\tvar BODY_LENGTH = 72;\r\n\r\n\tvar domainName = escape(options.domain.toUpperCase());\r\n\tvar workstation = escape(options.workstation.toUpperCase());\r\n\r\n\tvar workstationBytes, domainNameBytes, usernameBytes, encryptedRandomSessionKeyBytes;\r\n\r\n\tvar encryptedRandomSessionKey = \"\";\r\n\tif(isUnicode){\r\n\t\tworkstationBytes = Buffer.from(workstation, 'utf16le');\r\n\t\tdomainNameBytes = Buffer.from(domainName, 'utf16le');\r\n\t\tusernameBytes = Buffer.from(username, 'utf16le');\r\n\t\tencryptedRandomSessionKeyBytes = Buffer.from(encryptedRandomSessionKey, 'utf16le');\r\n\t}else{\r\n\t\tworkstationBytes = Buffer.from(workstation, 'ascii');\r\n\t\tdomainNameBytes = Buffer.from(domainName, 'ascii');\r\n\t\tusernameBytes = Buffer.from(username, 'ascii');\r\n\t\tencryptedRandomSessionKeyBytes = Buffer.from(encryptedRandomSessionKey, 'ascii');\r\n\t}\r\n\r\n\tvar lmChallengeResponse = calc_resp((lm_password!=null)?lm_password:create_LM_hashed_password_v1(password), nonce);\r\n\tvar ntChallengeResponse = calc_resp((nt_password!=null)?nt_password:create_NT_hashed_password_v1(password), nonce);\r\n\r\n\tif(isNegotiateExtendedSecurity){\r\n\t\t/*\r\n\t\t * NTLMv2 extended security is enabled. While this technically can mean NTLMv2 extended security with NTLMv1 protocol,\r\n\t\t * servers that support extended security likely also support NTLMv2, so use NTLMv2.\r\n\t\t * This is also how curl implements NTLMv2 \"detection\".\r\n\t\t * By using NTLMv2, this supports communication with servers that forbid the use of NTLMv1 (e.g. via windows policies)\r\n\t\t *\r\n\t\t * However, the target info is needed to construct the NTLMv2 response so if it can't be negotiated,\r\n\t\t * fall back to NTLMv1 with NTLMv2 extended security.\r\n\t\t */\r\n\t\tvar pwhash = (nt_password!=null)?nt_password:create_NT_hashed_password_v1(password);\r\n\t\tvar clientChallenge = \"\";\r\n\t \tfor(var i=0; i < 8; i++){\r\n\t \t\tclientChallenge += String.fromCharCode( Math.floor(Math.random()*256) );\r\n\t   \t}\r\n\t   \tvar clientChallengeBytes = Buffer.from(clientChallenge, 'ascii');\r\n\t\tvar challenges = msg2.targetInfo\r\n\t\t\t? calc_ntlmv2_resp(pwhash, username, domainName, msg2.targetInfo, nonce, clientChallengeBytes)\r\n\t\t\t: ntlm2sr_calc_resp(pwhash, nonce, clientChallengeBytes);\r\n\t    lmChallengeResponse = challenges.lmChallengeResponse;\r\n\t    ntChallengeResponse = challenges.ntChallengeResponse;\r\n\t}\r\n\r\n\tvar signature = 'NTLMSSP\\0';\r\n\r\n\tvar pos = 0;\r\n\tvar buf = Buffer.alloc(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length + ntChallengeResponse.length + encryptedRandomSessionKeyBytes.length);\r\n\r\n\tbuf.write(signature, pos, signature.length); pos += signature.length;\r\n\tbuf.writeUInt32LE(3, pos); pos += 4;          // type 1\r\n\r\n\tbuf.writeUInt16LE(lmChallengeResponse.length, pos); pos += 2; // LmChallengeResponseLen\r\n\tbuf.writeUInt16LE(lmChallengeResponse.length, pos); pos += 2; // LmChallengeResponseMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length, pos); pos += 4; // LmChallengeResponseOffset\r\n\r\n\tbuf.writeUInt16LE(ntChallengeResponse.length, pos); pos += 2; // NtChallengeResponseLen\r\n\tbuf.writeUInt16LE(ntChallengeResponse.length, pos); pos += 2; // NtChallengeResponseMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length, pos); pos += 4; // NtChallengeResponseOffset\r\n\r\n\tbuf.writeUInt16LE(domainNameBytes.length, pos); pos += 2; // DomainNameLen\r\n\tbuf.writeUInt16LE(domainNameBytes.length, pos); pos += 2; // DomainNameMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH, pos); pos += 4; \t\t\t  // DomainNameOffset\r\n\r\n\tbuf.writeUInt16LE(usernameBytes.length, pos); pos += 2; // UserNameLen\r\n\tbuf.writeUInt16LE(usernameBytes.length, pos); pos += 2; // UserNameMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length, pos); pos += 4; // UserNameOffset\r\n\r\n\tbuf.writeUInt16LE(workstationBytes.length, pos); pos += 2; // WorkstationLen\r\n\tbuf.writeUInt16LE(workstationBytes.length, pos); pos += 2; // WorkstationMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length, pos); pos += 4; // WorkstationOffset\r\n\r\n\tbuf.writeUInt16LE(encryptedRandomSessionKeyBytes.length, pos); pos += 2; // EncryptedRandomSessionKeyLen\r\n\tbuf.writeUInt16LE(encryptedRandomSessionKeyBytes.length, pos); pos += 2; // EncryptedRandomSessionKeyMaxLen\r\n\tbuf.writeUInt32LE(BODY_LENGTH + domainNameBytes.length + usernameBytes.length + workstationBytes.length + lmChallengeResponse.length + ntChallengeResponse.length, pos); pos += 4; // EncryptedRandomSessionKeyOffset\r\n\r\n\t// Fix #98\r\n\tvar flagsToWrite = isUnicode\r\n\t    ? typeflags.NTLM_TYPE2_FLAGS\r\n\t    : typeflags.NTLM_TYPE2_FLAGS - flags.NTLM_NegotiateUnicode;\r\n\tbuf.writeUInt32LE(flagsToWrite , pos); pos += 4; // NegotiateFlags\r\n\r\n\tbuf.writeUInt8(5, pos); pos++; // ProductMajorVersion\r\n\tbuf.writeUInt8(1, pos); pos++; // ProductMinorVersion\r\n\tbuf.writeUInt16LE(2600, pos); pos += 2; // ProductBuild\r\n\tbuf.writeUInt8(0, pos); pos++; // VersionReserved1\r\n\tbuf.writeUInt8(0, pos); pos++; // VersionReserved2\r\n\tbuf.writeUInt8(0, pos); pos++; // VersionReserved3\r\n\tbuf.writeUInt8(15, pos); pos++; // NTLMRevisionCurrent\r\n\r\n\tdomainNameBytes.copy(buf, pos); pos += domainNameBytes.length;\r\n\tusernameBytes.copy(buf, pos); pos += usernameBytes.length;\r\n\tworkstationBytes.copy(buf, pos); pos += workstationBytes.length;\r\n\tlmChallengeResponse.copy(buf, pos); pos += lmChallengeResponse.length;\r\n\tntChallengeResponse.copy(buf, pos); pos += ntChallengeResponse.length;\r\n\tencryptedRandomSessionKeyBytes.copy(buf, pos); pos += encryptedRandomSessionKeyBytes.length;\r\n\r\n\treturn 'NTLM ' + buf.toString('base64');\r\n}\r\n\r\nfunction create_LM_hashed_password_v1(password){\r\n\t// fix the password length to 14 bytes\r\n\tpassword = password.toUpperCase();\r\n\tvar passwordBytes = Buffer.from(password, 'ascii');\r\n\r\n\tvar passwordBytesPadded = Buffer.alloc(14);\r\n\tpasswordBytesPadded.fill(\"\\0\");\r\n\tvar sourceEnd = 14;\r\n\tif(passwordBytes.length < 14) sourceEnd = passwordBytes.length;\r\n\tpasswordBytes.copy(passwordBytesPadded, 0, 0, sourceEnd);\r\n\r\n\t// split into 2 parts of 7 bytes:\r\n\tvar firstPart = passwordBytesPadded.slice(0,7);\r\n\tvar secondPart = passwordBytesPadded.slice(7);\r\n\r\n\tfunction encrypt(buf){\r\n\t\tvar key = insertZerosEvery7Bits(buf);\r\n\t\tvar des = desjs.DES.create({type: 'encrypt', key: key});\r\n\t\tvar magicKey = Buffer.from('KGS!@#$%', 'ascii'); // page 57 in [MS-NLMP]\r\n\t\tvar encrypted = des.update(magicKey);\r\n\t\treturn Buffer.from(encrypted);\r\n\t}\r\n\r\n\tvar firstPartEncrypted = encrypt(firstPart);\r\n\tvar secondPartEncrypted = encrypt(secondPart);\r\n\r\n\treturn Buffer.concat([firstPartEncrypted, secondPartEncrypted]);\r\n}\r\n\r\nfunction insertZerosEvery7Bits(buf){\r\n\tvar binaryArray = bytes2binaryArray(buf);\r\n\tvar newBinaryArray = [];\r\n\tfor(var i=0; i<binaryArray.length; i++){\r\n\t\tnewBinaryArray.push(binaryArray[i]);\r\n\r\n\t\tif((i+1)%7 === 0){\r\n\t\t\tnewBinaryArray.push(0);\r\n\t\t}\r\n\t}\r\n\treturn binaryArray2bytes(newBinaryArray);\r\n}\r\n\r\nfunction bytes2binaryArray(buf){\r\n\tvar hex2binary = {\r\n\t\t0: [0,0,0,0],\r\n\t\t1: [0,0,0,1],\r\n\t\t2: [0,0,1,0],\r\n\t\t3: [0,0,1,1],\r\n\t\t4: [0,1,0,0],\r\n\t\t5: [0,1,0,1],\r\n\t\t6: [0,1,1,0],\r\n\t\t7: [0,1,1,1],\r\n\t\t8: [1,0,0,0],\r\n\t\t9: [1,0,0,1],\r\n\t\tA: [1,0,1,0],\r\n\t\tB: [1,0,1,1],\r\n\t\tC: [1,1,0,0],\r\n\t\tD: [1,1,0,1],\r\n\t\tE: [1,1,1,0],\r\n\t\tF: [1,1,1,1]\r\n\t};\r\n\r\n\tvar hexString = buf.toString('hex').toUpperCase();\r\n\tvar array = [];\r\n\tfor(var i=0; i<hexString.length; i++){\r\n   \t\tvar hexchar = hexString.charAt(i);\r\n   \t\tarray = array.concat(hex2binary[hexchar]);\r\n   \t}\r\n   \treturn array;\r\n}\r\n\r\nfunction binaryArray2bytes(array){\r\n\tvar binary2hex = {\r\n\t\t'0000': 0,\r\n\t\t'0001': 1,\r\n\t\t'0010': 2,\r\n\t\t'0011': 3,\r\n\t\t'0100': 4,\r\n\t\t'0101': 5,\r\n\t\t'0110': 6,\r\n\t\t'0111': 7,\r\n\t\t'1000': 8,\r\n\t\t'1001': 9,\r\n\t\t'1010': 'A',\r\n\t\t'1011': 'B',\r\n\t\t'1100': 'C',\r\n\t\t'1101': 'D',\r\n\t\t'1110': 'E',\r\n\t\t'1111': 'F'\r\n\t};\r\n\r\n \tvar bufArray = [];\r\n\r\n\tfor(var i=0; i<array.length; i +=8 ){\r\n\t\tif((i+7) > array.length)\r\n\t\t\tbreak;\r\n\r\n\t\tvar binString1 = '' + array[i] + '' + array[i+1] + '' + array[i+2] + '' + array[i+3];\r\n\t\tvar binString2 = '' + array[i+4] + '' + array[i+5] + '' + array[i+6] + '' + array[i+7];\r\n   \t\tvar hexchar1 = binary2hex[binString1];\r\n   \t\tvar hexchar2 = binary2hex[binString2];\r\n\r\n   \t\tvar buf = Buffer.from(hexchar1 + '' + hexchar2, 'hex');\r\n   \t\tbufArray.push(buf);\r\n   \t}\r\n\r\n   \treturn Buffer.concat(bufArray);\r\n}\r\n\r\nfunction create_NT_hashed_password_v1(password){\r\n\tvar buf = Buffer.from(password, 'utf16le');\r\n\tvar md4 = jsmd4.create();\r\n\tmd4.update(buf);\r\n\treturn Buffer.from(md4.digest());\r\n}\r\n\r\nfunction calc_resp(password_hash, server_challenge){\r\n    // padding with zeros to make the hash 21 bytes long\r\n    var passHashPadded = Buffer.alloc(21);\r\n    passHashPadded.fill(\"\\0\");\r\n    password_hash.copy(passHashPadded, 0, 0, password_hash.length);\r\n\r\n    var resArray = [];\r\n\r\n\tvar des = desjs.DES.create({type: 'encrypt', key: insertZerosEvery7Bits(passHashPadded.slice(0,7))});\r\n\tresArray.push( Buffer.from(des.update(server_challenge.slice(0,8))) );\r\n\r\n\tdes = desjs.DES.create({type: 'encrypt', key: insertZerosEvery7Bits(passHashPadded.slice(7,14))});\r\n\tresArray.push( Buffer.from(des.update(server_challenge.slice(0,8))) );\r\n\r\n\tdes = desjs.DES.create({type: 'encrypt', key: insertZerosEvery7Bits(passHashPadded.slice(14,21))});\r\n\tresArray.push( Buffer.from(des.update(server_challenge.slice(0,8))) );\r\n\r\n   \treturn Buffer.concat(resArray);\r\n}\r\n\r\nfunction hmac_md5(key, data){\r\n\tvar hmac = crypto.createHmac('md5', key);\r\n\thmac.update(data);\r\n\treturn hmac.digest();\r\n}\r\n\r\nfunction ntlm2sr_calc_resp(responseKeyNT, serverChallenge, clientChallenge){\r\n\t// padding with zeros to make the hash 16 bytes longer\r\n    var lmChallengeResponse = Buffer.alloc(clientChallenge.length + 16);\r\n    lmChallengeResponse.fill(\"\\0\");\r\n    clientChallenge.copy(lmChallengeResponse, 0, 0, clientChallenge.length);\r\n\r\n    var buf = Buffer.concat([serverChallenge, clientChallenge]);\r\n    var md5 = crypto.createHash('md5');\r\n    md5.update(buf);\r\n    var sess = md5.digest();\r\n    var ntChallengeResponse = calc_resp(responseKeyNT, sess.slice(0,8));\r\n\r\n    return {\r\n    \tlmChallengeResponse: lmChallengeResponse,\r\n    \tntChallengeResponse: ntChallengeResponse\r\n    };\r\n}\r\n\r\nfunction calc_ntlmv2_resp(pwhash, username, domain, targetInfo, serverChallenge, clientChallenge){\r\n\tvar responseKeyNTLM = NTOWFv2(pwhash, username, domain);\r\n\r\n\tvar lmV2ChallengeResponse = Buffer.concat([\r\n\t\thmac_md5(responseKeyNTLM, Buffer.concat([serverChallenge, clientChallenge])),\r\n\t\tclientChallenge\r\n\t]);\r\n\r\n\t// 11644473600000 = diff between 1970 and 1601\r\n\tvar now = Date.now();\r\n\tvar timestamp = ((BigInt(now) + BigInt(11644473600000)) * BigInt(10000));  // we need BigInt to be able to write it to a buffer\r\n\tvar timestampBuffer = Buffer.alloc(8);\r\n\ttimestampBuffer.writeBigUInt64LE(timestamp);\r\n\r\n\tvar zero32Bit = Buffer.alloc(4, 0)\r\n\tvar temp = Buffer.concat([\r\n\t\t// Version\r\n\t\tBuffer.from([0x01, 0x01, 0x00, 0x00]),\r\n\t\tzero32Bit,\r\n\t\ttimestampBuffer,\r\n\t\tclientChallenge,\r\n\t\tzero32Bit,\r\n\t\ttargetInfo,\r\n\t\tzero32Bit\r\n\t]);\r\n\tvar proofString = hmac_md5(responseKeyNTLM, Buffer.concat([serverChallenge, temp]));\r\n\tvar ntV2ChallengeResponse = Buffer.concat([proofString, temp]);\r\n\r\n    return {\r\n    \tlmChallengeResponse: lmV2ChallengeResponse,\r\n    \tntChallengeResponse: ntV2ChallengeResponse\r\n    };\r\n}\r\n\r\nfunction NTOWFv2(pwhash, user, domain){\r\n\treturn hmac_md5(pwhash, Buffer.from(user.toUpperCase() + domain, 'utf16le'));\r\n}\r\n\r\nexports.createType1Message = createType1Message;\r\nexports.parseType2Message = parseType2Message;\r\nexports.createType3Message = createType3Message;\r\nexports.create_NT_hashed_password = create_NT_hashed_password_v1;\r\nexports.create_LM_hashed_password = create_LM_hashed_password_v1;\r\n/* eslint-enable */\r\n"]}