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.
- package/CHANGELOG.md +10 -0
- package/build/ox_modules/module-http/ntlm-util.js +32 -0
- package/build/ox_modules/module-http/ntlm.js +514 -0
- package/build/ox_modules/module-http.js +120 -5
- package/build/ox_modules/module-mob.js +4 -2
- package/build/ox_modules/module-utils.js +4 -2
- package/build/ox_modules/module-web.js +4 -2
- package/build/ox_modules/module-win.js +4 -2
- package/package.json +3 -1
|
@@ -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"]}
|