1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.default = void 0;
|
7 | var _crypto = _interopRequireDefault(require("crypto"));
|
8 | var _os = _interopRequireDefault(require("os"));
|
9 | var tls = _interopRequireWildcard(require("tls"));
|
10 | var net = _interopRequireWildcard(require("net"));
|
11 | var _dns = _interopRequireDefault(require("dns"));
|
12 | var _constants = _interopRequireDefault(require("constants"));
|
13 | var _stream = require("stream");
|
14 | var _identity = require("@azure/identity");
|
15 | var _coreAuth = require("@azure/core-auth");
|
16 | var _bulkLoad = _interopRequireDefault(require("./bulk-load"));
|
17 | var _debug = _interopRequireDefault(require("./debug"));
|
18 | var _events = require("events");
|
19 | var _instanceLookup = require("./instance-lookup");
|
20 | var _transientErrorLookup = require("./transient-error-lookup");
|
21 | var _packet = require("./packet");
|
22 | var _preloginPayload = _interopRequireDefault(require("./prelogin-payload"));
|
23 | var _login7Payload = _interopRequireDefault(require("./login7-payload"));
|
24 | var _ntlmPayload = _interopRequireDefault(require("./ntlm-payload"));
|
25 | var _request = _interopRequireDefault(require("./request"));
|
26 | var _rpcrequestPayload = _interopRequireDefault(require("./rpcrequest-payload"));
|
27 | var _sqlbatchPayload = _interopRequireDefault(require("./sqlbatch-payload"));
|
28 | var _messageIo = _interopRequireDefault(require("./message-io"));
|
29 | var _tokenStreamParser = require("./token/token-stream-parser");
|
30 | var _transaction = require("./transaction");
|
31 | var _errors = require("./errors");
|
32 | var _connector = require("./connector");
|
33 | var _library = require("./library");
|
34 | var _tdsVersions = require("./tds-versions");
|
35 | var _message = _interopRequireDefault(require("./message"));
|
36 | var _ntlm = require("./ntlm");
|
37 | var _dataType = require("./data-type");
|
38 | var _bulkLoadPayload = require("./bulk-load-payload");
|
39 | var _specialStoredProcedure = _interopRequireDefault(require("./special-stored-procedure"));
|
40 | var _package = require("../package.json");
|
41 | var _url = require("url");
|
42 | var _handler = require("./token/handler");
|
43 | function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
44 | function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
45 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
46 | // eslint-disable-next-line @typescript-eslint/no-unused-vars
|
47 |
|
48 | /**
|
49 | * @private
|
50 | */
|
51 | const KEEP_ALIVE_INITIAL_DELAY = 30 * 1000;
|
52 | /**
|
53 | * @private
|
54 | */
|
55 | const DEFAULT_CONNECT_TIMEOUT = 15 * 1000;
|
56 | /**
|
57 | * @private
|
58 | */
|
59 | const DEFAULT_CLIENT_REQUEST_TIMEOUT = 15 * 1000;
|
60 | /**
|
61 | * @private
|
62 | */
|
63 | const DEFAULT_CANCEL_TIMEOUT = 5 * 1000;
|
64 | /**
|
65 | * @private
|
66 | */
|
67 | const DEFAULT_CONNECT_RETRY_INTERVAL = 500;
|
68 | /**
|
69 | * @private
|
70 | */
|
71 | const DEFAULT_PACKET_SIZE = 4 * 1024;
|
72 | /**
|
73 | * @private
|
74 | */
|
75 | const DEFAULT_TEXTSIZE = 2147483647;
|
76 | /**
|
77 | * @private
|
78 | */
|
79 | const DEFAULT_DATEFIRST = 7;
|
80 | /**
|
81 | * @private
|
82 | */
|
83 | const DEFAULT_PORT = 1433;
|
84 | /**
|
85 | * @private
|
86 | */
|
87 | const DEFAULT_TDS_VERSION = '7_4';
|
88 | /**
|
89 | * @private
|
90 | */
|
91 | const DEFAULT_LANGUAGE = 'us_english';
|
92 | /**
|
93 | * @private
|
94 | */
|
95 | const DEFAULT_DATEFORMAT = 'mdy';
|
96 |
|
97 | /** Structure that defines the options that are necessary to authenticate the Tedious.JS instance with an `@azure/identity` token credential. */
|
98 |
|
99 | /**
|
100 | * @private
|
101 | */
|
102 |
|
103 | /**
|
104 | * @private
|
105 | */
|
106 | const CLEANUP_TYPE = {
|
107 | NORMAL: 0,
|
108 | REDIRECT: 1,
|
109 | RETRY: 2
|
110 | };
|
111 | /**
|
112 | * A [[Connection]] instance represents a single connection to a database server.
|
113 | *
|
114 | * ```js
|
115 | * var Connection = require('tedious').Connection;
|
116 | * var config = {
|
117 | * "authentication": {
|
118 | * ...,
|
119 | * "options": {...}
|
120 | * },
|
121 | * "options": {...}
|
122 | * };
|
123 | * var connection = new Connection(config);
|
124 | * ```
|
125 | *
|
126 | * Only one request at a time may be executed on a connection. Once a [[Request]]
|
127 | * has been initiated (with [[Connection.callProcedure]], [[Connection.execSql]],
|
128 | * or [[Connection.execSqlBatch]]), another should not be initiated until the
|
129 | * [[Request]]'s completion callback is called.
|
130 | */
|
131 | class Connection extends _events.EventEmitter {
|
132 | /**
|
133 | * @private
|
134 | */
|
135 |
|
136 | /**
|
137 | * @private
|
138 | */
|
139 |
|
140 | /**
|
141 | * @private
|
142 | */
|
143 |
|
144 | /**
|
145 | * @private
|
146 | */
|
147 |
|
148 | /**
|
149 | * @private
|
150 | */
|
151 |
|
152 | /**
|
153 | * @private
|
154 | */
|
155 |
|
156 | /**
|
157 | * @private
|
158 | */
|
159 |
|
160 | /**
|
161 | * @private
|
162 | */
|
163 |
|
164 | /**
|
165 | * @private
|
166 | */
|
167 |
|
168 | /**
|
169 | * @private
|
170 | */
|
171 |
|
172 | /**
|
173 | * @private
|
174 | */
|
175 |
|
176 | /**
|
177 | * @private
|
178 | */
|
179 |
|
180 | /**
|
181 | * @private
|
182 | */
|
183 |
|
184 | /**
|
185 | * @private
|
186 | */
|
187 |
|
188 | /**
|
189 | * @private
|
190 | */
|
191 |
|
192 | /**
|
193 | * @private
|
194 | */
|
195 |
|
196 | /**
|
197 | * @private
|
198 | */
|
199 |
|
200 | /**
|
201 | * @private
|
202 | */
|
203 |
|
204 | /**
|
205 | * @private
|
206 | */
|
207 |
|
208 | /**
|
209 | * @private
|
210 | */
|
211 |
|
212 | /**
|
213 | * @private
|
214 | */
|
215 |
|
216 | /**
|
217 | * @private
|
218 | */
|
219 |
|
220 | /**
|
221 | * @private
|
222 | */
|
223 |
|
224 | /**
|
225 | * @private
|
226 | */
|
227 |
|
228 | /**
|
229 | * @private
|
230 | */
|
231 |
|
232 | /**
|
233 | * @private
|
234 | */
|
235 |
|
236 | /**
|
237 | * @private
|
238 | */
|
239 |
|
240 | /**
|
241 | * @private
|
242 | */
|
243 | _cancelAfterRequestSent;
|
244 |
|
245 | /**
|
246 | * @private
|
247 | */
|
248 |
|
249 | /**
|
250 | * Note: be aware of the different options field:
|
251 | * 1. config.authentication.options
|
252 | * 2. config.options
|
253 | *
|
254 | * ```js
|
255 | * const { Connection } = require('tedious');
|
256 | *
|
257 | * const config = {
|
258 | * "authentication": {
|
259 | * ...,
|
260 | * "options": {...}
|
261 | * },
|
262 | * "options": {...}
|
263 | * };
|
264 | *
|
265 | * const connection = new Connection(config);
|
266 | * ```
|
267 | *
|
268 | * @param config
|
269 | */
|
270 | constructor(config) {
|
271 | super();
|
272 | if (typeof config !== 'object' || config === null) {
|
273 | throw new TypeError('The "config" argument is required and must be of type Object.');
|
274 | }
|
275 | if (typeof config.server !== 'string') {
|
276 | throw new TypeError('The "config.server" property is required and must be of type string.');
|
277 | }
|
278 | this.fedAuthRequired = false;
|
279 | let authentication;
|
280 | if (config.authentication !== undefined) {
|
281 | if (typeof config.authentication !== 'object' || config.authentication === null) {
|
282 | throw new TypeError('The "config.authentication" property must be of type Object.');
|
283 | }
|
284 | const type = config.authentication.type;
|
285 | const options = config.authentication.options === undefined ? {} : config.authentication.options;
|
286 | if (typeof type !== 'string') {
|
287 | throw new TypeError('The "config.authentication.type" property must be of type string.');
|
288 | }
|
289 | if (type !== 'default' && type !== 'ntlm' && type !== 'token-credential' && type !== 'azure-active-directory-password' && type !== 'azure-active-directory-access-token' && type !== 'azure-active-directory-msi-vm' && type !== 'azure-active-directory-msi-app-service' && type !== 'azure-active-directory-service-principal-secret' && type !== 'azure-active-directory-default') {
|
290 | throw new TypeError('The "type" property must one of "default", "ntlm", "token-credential", "azure-active-directory-password", "azure-active-directory-access-token", "azure-active-directory-default", "azure-active-directory-msi-vm" or "azure-active-directory-msi-app-service" or "azure-active-directory-service-principal-secret".');
|
291 | }
|
292 | if (typeof options !== 'object' || options === null) {
|
293 | throw new TypeError('The "config.authentication.options" property must be of type object.');
|
294 | }
|
295 | if (type === 'ntlm') {
|
296 | if (typeof options.domain !== 'string') {
|
297 | throw new TypeError('The "config.authentication.options.domain" property must be of type string.');
|
298 | }
|
299 | if (options.userName !== undefined && typeof options.userName !== 'string') {
|
300 | throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
301 | }
|
302 | if (options.password !== undefined && typeof options.password !== 'string') {
|
303 | throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
304 | }
|
305 | authentication = {
|
306 | type: 'ntlm',
|
307 | options: {
|
308 | userName: options.userName,
|
309 | password: options.password,
|
310 | domain: options.domain && options.domain.toUpperCase()
|
311 | }
|
312 | };
|
313 | } else if (type === 'token-credential') {
|
314 | if (!(0, _coreAuth.isTokenCredential)(options.credential)) {
|
315 | throw new TypeError('The "config.authentication.options.credential" property must be an instance of the token credential class.');
|
316 | }
|
317 | authentication = {
|
318 | type: 'token-credential',
|
319 | options: {
|
320 | credential: options.credential
|
321 | }
|
322 | };
|
323 | } else if (type === 'azure-active-directory-password') {
|
324 | if (typeof options.clientId !== 'string') {
|
325 | throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
326 | }
|
327 | if (options.userName !== undefined && typeof options.userName !== 'string') {
|
328 | throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
329 | }
|
330 | if (options.password !== undefined && typeof options.password !== 'string') {
|
331 | throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
332 | }
|
333 | if (options.tenantId !== undefined && typeof options.tenantId !== 'string') {
|
334 | throw new TypeError('The "config.authentication.options.tenantId" property must be of type string.');
|
335 | }
|
336 | authentication = {
|
337 | type: 'azure-active-directory-password',
|
338 | options: {
|
339 | userName: options.userName,
|
340 | password: options.password,
|
341 | tenantId: options.tenantId,
|
342 | clientId: options.clientId
|
343 | }
|
344 | };
|
345 | } else if (type === 'azure-active-directory-access-token') {
|
346 | if (typeof options.token !== 'string') {
|
347 | throw new TypeError('The "config.authentication.options.token" property must be of type string.');
|
348 | }
|
349 | authentication = {
|
350 | type: 'azure-active-directory-access-token',
|
351 | options: {
|
352 | token: options.token
|
353 | }
|
354 | };
|
355 | } else if (type === 'azure-active-directory-msi-vm') {
|
356 | if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
357 | throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
358 | }
|
359 | authentication = {
|
360 | type: 'azure-active-directory-msi-vm',
|
361 | options: {
|
362 | clientId: options.clientId
|
363 | }
|
364 | };
|
365 | } else if (type === 'azure-active-directory-default') {
|
366 | if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
367 | throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
368 | }
|
369 | authentication = {
|
370 | type: 'azure-active-directory-default',
|
371 | options: {
|
372 | clientId: options.clientId
|
373 | }
|
374 | };
|
375 | } else if (type === 'azure-active-directory-msi-app-service') {
|
376 | if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
377 | throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
378 | }
|
379 | authentication = {
|
380 | type: 'azure-active-directory-msi-app-service',
|
381 | options: {
|
382 | clientId: options.clientId
|
383 | }
|
384 | };
|
385 | } else if (type === 'azure-active-directory-service-principal-secret') {
|
386 | if (typeof options.clientId !== 'string') {
|
387 | throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
388 | }
|
389 | if (typeof options.clientSecret !== 'string') {
|
390 | throw new TypeError('The "config.authentication.options.clientSecret" property must be of type string.');
|
391 | }
|
392 | if (typeof options.tenantId !== 'string') {
|
393 | throw new TypeError('The "config.authentication.options.tenantId" property must be of type string.');
|
394 | }
|
395 | authentication = {
|
396 | type: 'azure-active-directory-service-principal-secret',
|
397 | options: {
|
398 | clientId: options.clientId,
|
399 | clientSecret: options.clientSecret,
|
400 | tenantId: options.tenantId
|
401 | }
|
402 | };
|
403 | } else {
|
404 | if (options.userName !== undefined && typeof options.userName !== 'string') {
|
405 | throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
406 | }
|
407 | if (options.password !== undefined && typeof options.password !== 'string') {
|
408 | throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
409 | }
|
410 | authentication = {
|
411 | type: 'default',
|
412 | options: {
|
413 | userName: options.userName,
|
414 | password: options.password
|
415 | }
|
416 | };
|
417 | }
|
418 | } else {
|
419 | authentication = {
|
420 | type: 'default',
|
421 | options: {
|
422 | userName: undefined,
|
423 | password: undefined
|
424 | }
|
425 | };
|
426 | }
|
427 | this.config = {
|
428 | server: config.server,
|
429 | authentication: authentication,
|
430 | options: {
|
431 | abortTransactionOnError: false,
|
432 | appName: undefined,
|
433 | camelCaseColumns: false,
|
434 | cancelTimeout: DEFAULT_CANCEL_TIMEOUT,
|
435 | columnEncryptionKeyCacheTTL: 2 * 60 * 60 * 1000,
|
436 | // Units: milliseconds
|
437 | columnEncryptionSetting: false,
|
438 | columnNameReplacer: undefined,
|
439 | connectionRetryInterval: DEFAULT_CONNECT_RETRY_INTERVAL,
|
440 | connectTimeout: DEFAULT_CONNECT_TIMEOUT,
|
441 | connector: undefined,
|
442 | connectionIsolationLevel: _transaction.ISOLATION_LEVEL.READ_COMMITTED,
|
443 | cryptoCredentialsDetails: {},
|
444 | database: undefined,
|
445 | datefirst: DEFAULT_DATEFIRST,
|
446 | dateFormat: DEFAULT_DATEFORMAT,
|
447 | debug: {
|
448 | data: false,
|
449 | packet: false,
|
450 | payload: false,
|
451 | token: false
|
452 | },
|
453 | enableAnsiNull: true,
|
454 | enableAnsiNullDefault: true,
|
455 | enableAnsiPadding: true,
|
456 | enableAnsiWarnings: true,
|
457 | enableArithAbort: true,
|
458 | enableConcatNullYieldsNull: true,
|
459 | enableCursorCloseOnCommit: null,
|
460 | enableImplicitTransactions: false,
|
461 | enableNumericRoundabort: false,
|
462 | enableQuotedIdentifier: true,
|
463 | encrypt: true,
|
464 | fallbackToDefaultDb: false,
|
465 | encryptionKeyStoreProviders: undefined,
|
466 | instanceName: undefined,
|
467 | isolationLevel: _transaction.ISOLATION_LEVEL.READ_COMMITTED,
|
468 | language: DEFAULT_LANGUAGE,
|
469 | localAddress: undefined,
|
470 | maxRetriesOnTransientErrors: 3,
|
471 | multiSubnetFailover: false,
|
472 | packetSize: DEFAULT_PACKET_SIZE,
|
473 | port: DEFAULT_PORT,
|
474 | readOnlyIntent: false,
|
475 | requestTimeout: DEFAULT_CLIENT_REQUEST_TIMEOUT,
|
476 | rowCollectionOnDone: false,
|
477 | rowCollectionOnRequestCompletion: false,
|
478 | serverName: undefined,
|
479 | serverSupportsColumnEncryption: false,
|
480 | tdsVersion: DEFAULT_TDS_VERSION,
|
481 | textsize: DEFAULT_TEXTSIZE,
|
482 | trustedServerNameAE: undefined,
|
483 | trustServerCertificate: false,
|
484 | useColumnNames: false,
|
485 | useUTC: true,
|
486 | workstationId: undefined,
|
487 | lowerCaseGuids: false
|
488 | }
|
489 | };
|
490 | if (config.options) {
|
491 | if (config.options.port && config.options.instanceName) {
|
492 | throw new Error('Port and instanceName are mutually exclusive, but ' + config.options.port + ' and ' + config.options.instanceName + ' provided');
|
493 | }
|
494 | if (config.options.abortTransactionOnError !== undefined) {
|
495 | if (typeof config.options.abortTransactionOnError !== 'boolean' && config.options.abortTransactionOnError !== null) {
|
496 | throw new TypeError('The "config.options.abortTransactionOnError" property must be of type string or null.');
|
497 | }
|
498 | this.config.options.abortTransactionOnError = config.options.abortTransactionOnError;
|
499 | }
|
500 | if (config.options.appName !== undefined) {
|
501 | if (typeof config.options.appName !== 'string') {
|
502 | throw new TypeError('The "config.options.appName" property must be of type string.');
|
503 | }
|
504 | this.config.options.appName = config.options.appName;
|
505 | }
|
506 | if (config.options.camelCaseColumns !== undefined) {
|
507 | if (typeof config.options.camelCaseColumns !== 'boolean') {
|
508 | throw new TypeError('The "config.options.camelCaseColumns" property must be of type boolean.');
|
509 | }
|
510 | this.config.options.camelCaseColumns = config.options.camelCaseColumns;
|
511 | }
|
512 | if (config.options.cancelTimeout !== undefined) {
|
513 | if (typeof config.options.cancelTimeout !== 'number') {
|
514 | throw new TypeError('The "config.options.cancelTimeout" property must be of type number.');
|
515 | }
|
516 | this.config.options.cancelTimeout = config.options.cancelTimeout;
|
517 | }
|
518 | if (config.options.columnNameReplacer) {
|
519 | if (typeof config.options.columnNameReplacer !== 'function') {
|
520 | throw new TypeError('The "config.options.cancelTimeout" property must be of type function.');
|
521 | }
|
522 | this.config.options.columnNameReplacer = config.options.columnNameReplacer;
|
523 | }
|
524 | if (config.options.connectionIsolationLevel !== undefined) {
|
525 | (0, _transaction.assertValidIsolationLevel)(config.options.connectionIsolationLevel, 'config.options.connectionIsolationLevel');
|
526 | this.config.options.connectionIsolationLevel = config.options.connectionIsolationLevel;
|
527 | }
|
528 | if (config.options.connectTimeout !== undefined) {
|
529 | if (typeof config.options.connectTimeout !== 'number') {
|
530 | throw new TypeError('The "config.options.connectTimeout" property must be of type number.');
|
531 | }
|
532 | this.config.options.connectTimeout = config.options.connectTimeout;
|
533 | }
|
534 | if (config.options.connector !== undefined) {
|
535 | if (typeof config.options.connector !== 'function') {
|
536 | throw new TypeError('The "config.options.connector" property must be a function.');
|
537 | }
|
538 | this.config.options.connector = config.options.connector;
|
539 | }
|
540 | if (config.options.cryptoCredentialsDetails !== undefined) {
|
541 | if (typeof config.options.cryptoCredentialsDetails !== 'object' || config.options.cryptoCredentialsDetails === null) {
|
542 | throw new TypeError('The "config.options.cryptoCredentialsDetails" property must be of type Object.');
|
543 | }
|
544 | this.config.options.cryptoCredentialsDetails = config.options.cryptoCredentialsDetails;
|
545 | }
|
546 | if (config.options.database !== undefined) {
|
547 | if (typeof config.options.database !== 'string') {
|
548 | throw new TypeError('The "config.options.database" property must be of type string.');
|
549 | }
|
550 | this.config.options.database = config.options.database;
|
551 | }
|
552 | if (config.options.datefirst !== undefined) {
|
553 | if (typeof config.options.datefirst !== 'number' && config.options.datefirst !== null) {
|
554 | throw new TypeError('The "config.options.datefirst" property must be of type number.');
|
555 | }
|
556 | if (config.options.datefirst !== null && (config.options.datefirst < 1 || config.options.datefirst > 7)) {
|
557 | throw new RangeError('The "config.options.datefirst" property must be >= 1 and <= 7');
|
558 | }
|
559 | this.config.options.datefirst = config.options.datefirst;
|
560 | }
|
561 | if (config.options.dateFormat !== undefined) {
|
562 | if (typeof config.options.dateFormat !== 'string' && config.options.dateFormat !== null) {
|
563 | throw new TypeError('The "config.options.dateFormat" property must be of type string or null.');
|
564 | }
|
565 | this.config.options.dateFormat = config.options.dateFormat;
|
566 | }
|
567 | if (config.options.debug) {
|
568 | if (config.options.debug.data !== undefined) {
|
569 | if (typeof config.options.debug.data !== 'boolean') {
|
570 | throw new TypeError('The "config.options.debug.data" property must be of type boolean.');
|
571 | }
|
572 | this.config.options.debug.data = config.options.debug.data;
|
573 | }
|
574 | if (config.options.debug.packet !== undefined) {
|
575 | if (typeof config.options.debug.packet !== 'boolean') {
|
576 | throw new TypeError('The "config.options.debug.packet" property must be of type boolean.');
|
577 | }
|
578 | this.config.options.debug.packet = config.options.debug.packet;
|
579 | }
|
580 | if (config.options.debug.payload !== undefined) {
|
581 | if (typeof config.options.debug.payload !== 'boolean') {
|
582 | throw new TypeError('The "config.options.debug.payload" property must be of type boolean.');
|
583 | }
|
584 | this.config.options.debug.payload = config.options.debug.payload;
|
585 | }
|
586 | if (config.options.debug.token !== undefined) {
|
587 | if (typeof config.options.debug.token !== 'boolean') {
|
588 | throw new TypeError('The "config.options.debug.token" property must be of type boolean.');
|
589 | }
|
590 | this.config.options.debug.token = config.options.debug.token;
|
591 | }
|
592 | }
|
593 | if (config.options.enableAnsiNull !== undefined) {
|
594 | if (typeof config.options.enableAnsiNull !== 'boolean' && config.options.enableAnsiNull !== null) {
|
595 | throw new TypeError('The "config.options.enableAnsiNull" property must be of type boolean or null.');
|
596 | }
|
597 | this.config.options.enableAnsiNull = config.options.enableAnsiNull;
|
598 | }
|
599 | if (config.options.enableAnsiNullDefault !== undefined) {
|
600 | if (typeof config.options.enableAnsiNullDefault !== 'boolean' && config.options.enableAnsiNullDefault !== null) {
|
601 | throw new TypeError('The "config.options.enableAnsiNullDefault" property must be of type boolean or null.');
|
602 | }
|
603 | this.config.options.enableAnsiNullDefault = config.options.enableAnsiNullDefault;
|
604 | }
|
605 | if (config.options.enableAnsiPadding !== undefined) {
|
606 | if (typeof config.options.enableAnsiPadding !== 'boolean' && config.options.enableAnsiPadding !== null) {
|
607 | throw new TypeError('The "config.options.enableAnsiPadding" property must be of type boolean or null.');
|
608 | }
|
609 | this.config.options.enableAnsiPadding = config.options.enableAnsiPadding;
|
610 | }
|
611 | if (config.options.enableAnsiWarnings !== undefined) {
|
612 | if (typeof config.options.enableAnsiWarnings !== 'boolean' && config.options.enableAnsiWarnings !== null) {
|
613 | throw new TypeError('The "config.options.enableAnsiWarnings" property must be of type boolean or null.');
|
614 | }
|
615 | this.config.options.enableAnsiWarnings = config.options.enableAnsiWarnings;
|
616 | }
|
617 | if (config.options.enableArithAbort !== undefined) {
|
618 | if (typeof config.options.enableArithAbort !== 'boolean' && config.options.enableArithAbort !== null) {
|
619 | throw new TypeError('The "config.options.enableArithAbort" property must be of type boolean or null.');
|
620 | }
|
621 | this.config.options.enableArithAbort = config.options.enableArithAbort;
|
622 | }
|
623 | if (config.options.enableConcatNullYieldsNull !== undefined) {
|
624 | if (typeof config.options.enableConcatNullYieldsNull !== 'boolean' && config.options.enableConcatNullYieldsNull !== null) {
|
625 | throw new TypeError('The "config.options.enableConcatNullYieldsNull" property must be of type boolean or null.');
|
626 | }
|
627 | this.config.options.enableConcatNullYieldsNull = config.options.enableConcatNullYieldsNull;
|
628 | }
|
629 | if (config.options.enableCursorCloseOnCommit !== undefined) {
|
630 | if (typeof config.options.enableCursorCloseOnCommit !== 'boolean' && config.options.enableCursorCloseOnCommit !== null) {
|
631 | throw new TypeError('The "config.options.enableCursorCloseOnCommit" property must be of type boolean or null.');
|
632 | }
|
633 | this.config.options.enableCursorCloseOnCommit = config.options.enableCursorCloseOnCommit;
|
634 | }
|
635 | if (config.options.enableImplicitTransactions !== undefined) {
|
636 | if (typeof config.options.enableImplicitTransactions !== 'boolean' && config.options.enableImplicitTransactions !== null) {
|
637 | throw new TypeError('The "config.options.enableImplicitTransactions" property must be of type boolean or null.');
|
638 | }
|
639 | this.config.options.enableImplicitTransactions = config.options.enableImplicitTransactions;
|
640 | }
|
641 | if (config.options.enableNumericRoundabort !== undefined) {
|
642 | if (typeof config.options.enableNumericRoundabort !== 'boolean' && config.options.enableNumericRoundabort !== null) {
|
643 | throw new TypeError('The "config.options.enableNumericRoundabort" property must be of type boolean or null.');
|
644 | }
|
645 | this.config.options.enableNumericRoundabort = config.options.enableNumericRoundabort;
|
646 | }
|
647 | if (config.options.enableQuotedIdentifier !== undefined) {
|
648 | if (typeof config.options.enableQuotedIdentifier !== 'boolean' && config.options.enableQuotedIdentifier !== null) {
|
649 | throw new TypeError('The "config.options.enableQuotedIdentifier" property must be of type boolean or null.');
|
650 | }
|
651 | this.config.options.enableQuotedIdentifier = config.options.enableQuotedIdentifier;
|
652 | }
|
653 | if (config.options.encrypt !== undefined) {
|
654 | if (typeof config.options.encrypt !== 'boolean') {
|
655 | if (config.options.encrypt !== 'strict') {
|
656 | throw new TypeError('The "encrypt" property must be set to "strict", or of type boolean.');
|
657 | }
|
658 | }
|
659 | this.config.options.encrypt = config.options.encrypt;
|
660 | }
|
661 | if (config.options.fallbackToDefaultDb !== undefined) {
|
662 | if (typeof config.options.fallbackToDefaultDb !== 'boolean') {
|
663 | throw new TypeError('The "config.options.fallbackToDefaultDb" property must be of type boolean.');
|
664 | }
|
665 | this.config.options.fallbackToDefaultDb = config.options.fallbackToDefaultDb;
|
666 | }
|
667 | if (config.options.instanceName !== undefined) {
|
668 | if (typeof config.options.instanceName !== 'string') {
|
669 | throw new TypeError('The "config.options.instanceName" property must be of type string.');
|
670 | }
|
671 | this.config.options.instanceName = config.options.instanceName;
|
672 | this.config.options.port = undefined;
|
673 | }
|
674 | if (config.options.isolationLevel !== undefined) {
|
675 | (0, _transaction.assertValidIsolationLevel)(config.options.isolationLevel, 'config.options.isolationLevel');
|
676 | this.config.options.isolationLevel = config.options.isolationLevel;
|
677 | }
|
678 | if (config.options.language !== undefined) {
|
679 | if (typeof config.options.language !== 'string' && config.options.language !== null) {
|
680 | throw new TypeError('The "config.options.language" property must be of type string or null.');
|
681 | }
|
682 | this.config.options.language = config.options.language;
|
683 | }
|
684 | if (config.options.localAddress !== undefined) {
|
685 | if (typeof config.options.localAddress !== 'string') {
|
686 | throw new TypeError('The "config.options.localAddress" property must be of type string.');
|
687 | }
|
688 | this.config.options.localAddress = config.options.localAddress;
|
689 | }
|
690 | if (config.options.multiSubnetFailover !== undefined) {
|
691 | if (typeof config.options.multiSubnetFailover !== 'boolean') {
|
692 | throw new TypeError('The "config.options.multiSubnetFailover" property must be of type boolean.');
|
693 | }
|
694 | this.config.options.multiSubnetFailover = config.options.multiSubnetFailover;
|
695 | }
|
696 | if (config.options.packetSize !== undefined) {
|
697 | if (typeof config.options.packetSize !== 'number') {
|
698 | throw new TypeError('The "config.options.packetSize" property must be of type number.');
|
699 | }
|
700 | this.config.options.packetSize = config.options.packetSize;
|
701 | }
|
702 | if (config.options.port !== undefined) {
|
703 | if (typeof config.options.port !== 'number') {
|
704 | throw new TypeError('The "config.options.port" property must be of type number.');
|
705 | }
|
706 | if (config.options.port <= 0 || config.options.port >= 65536) {
|
707 | throw new RangeError('The "config.options.port" property must be > 0 and < 65536');
|
708 | }
|
709 | this.config.options.port = config.options.port;
|
710 | this.config.options.instanceName = undefined;
|
711 | }
|
712 | if (config.options.readOnlyIntent !== undefined) {
|
713 | if (typeof config.options.readOnlyIntent !== 'boolean') {
|
714 | throw new TypeError('The "config.options.readOnlyIntent" property must be of type boolean.');
|
715 | }
|
716 | this.config.options.readOnlyIntent = config.options.readOnlyIntent;
|
717 | }
|
718 | if (config.options.requestTimeout !== undefined) {
|
719 | if (typeof config.options.requestTimeout !== 'number') {
|
720 | throw new TypeError('The "config.options.requestTimeout" property must be of type number.');
|
721 | }
|
722 | this.config.options.requestTimeout = config.options.requestTimeout;
|
723 | }
|
724 | if (config.options.maxRetriesOnTransientErrors !== undefined) {
|
725 | if (typeof config.options.maxRetriesOnTransientErrors !== 'number') {
|
726 | throw new TypeError('The "config.options.maxRetriesOnTransientErrors" property must be of type number.');
|
727 | }
|
728 | if (config.options.maxRetriesOnTransientErrors < 0) {
|
729 | throw new TypeError('The "config.options.maxRetriesOnTransientErrors" property must be equal or greater than 0.');
|
730 | }
|
731 | this.config.options.maxRetriesOnTransientErrors = config.options.maxRetriesOnTransientErrors;
|
732 | }
|
733 | if (config.options.connectionRetryInterval !== undefined) {
|
734 | if (typeof config.options.connectionRetryInterval !== 'number') {
|
735 | throw new TypeError('The "config.options.connectionRetryInterval" property must be of type number.');
|
736 | }
|
737 | if (config.options.connectionRetryInterval <= 0) {
|
738 | throw new TypeError('The "config.options.connectionRetryInterval" property must be greater than 0.');
|
739 | }
|
740 | this.config.options.connectionRetryInterval = config.options.connectionRetryInterval;
|
741 | }
|
742 | if (config.options.rowCollectionOnDone !== undefined) {
|
743 | if (typeof config.options.rowCollectionOnDone !== 'boolean') {
|
744 | throw new TypeError('The "config.options.rowCollectionOnDone" property must be of type boolean.');
|
745 | }
|
746 | this.config.options.rowCollectionOnDone = config.options.rowCollectionOnDone;
|
747 | }
|
748 | if (config.options.rowCollectionOnRequestCompletion !== undefined) {
|
749 | if (typeof config.options.rowCollectionOnRequestCompletion !== 'boolean') {
|
750 | throw new TypeError('The "config.options.rowCollectionOnRequestCompletion" property must be of type boolean.');
|
751 | }
|
752 | this.config.options.rowCollectionOnRequestCompletion = config.options.rowCollectionOnRequestCompletion;
|
753 | }
|
754 | if (config.options.tdsVersion !== undefined) {
|
755 | if (typeof config.options.tdsVersion !== 'string') {
|
756 | throw new TypeError('The "config.options.tdsVersion" property must be of type string.');
|
757 | }
|
758 | this.config.options.tdsVersion = config.options.tdsVersion;
|
759 | }
|
760 | if (config.options.textsize !== undefined) {
|
761 | if (typeof config.options.textsize !== 'number' && config.options.textsize !== null) {
|
762 | throw new TypeError('The "config.options.textsize" property must be of type number or null.');
|
763 | }
|
764 | if (config.options.textsize > 2147483647) {
|
765 | throw new TypeError('The "config.options.textsize" can\'t be greater than 2147483647.');
|
766 | } else if (config.options.textsize < -1) {
|
767 | throw new TypeError('The "config.options.textsize" can\'t be smaller than -1.');
|
768 | }
|
769 | this.config.options.textsize = config.options.textsize | 0;
|
770 | }
|
771 | if (config.options.trustServerCertificate !== undefined) {
|
772 | if (typeof config.options.trustServerCertificate !== 'boolean') {
|
773 | throw new TypeError('The "config.options.trustServerCertificate" property must be of type boolean.');
|
774 | }
|
775 | this.config.options.trustServerCertificate = config.options.trustServerCertificate;
|
776 | }
|
777 | if (config.options.serverName !== undefined) {
|
778 | if (typeof config.options.serverName !== 'string') {
|
779 | throw new TypeError('The "config.options.serverName" property must be of type string.');
|
780 | }
|
781 | this.config.options.serverName = config.options.serverName;
|
782 | }
|
783 | if (config.options.useColumnNames !== undefined) {
|
784 | if (typeof config.options.useColumnNames !== 'boolean') {
|
785 | throw new TypeError('The "config.options.useColumnNames" property must be of type boolean.');
|
786 | }
|
787 | this.config.options.useColumnNames = config.options.useColumnNames;
|
788 | }
|
789 | if (config.options.useUTC !== undefined) {
|
790 | if (typeof config.options.useUTC !== 'boolean') {
|
791 | throw new TypeError('The "config.options.useUTC" property must be of type boolean.');
|
792 | }
|
793 | this.config.options.useUTC = config.options.useUTC;
|
794 | }
|
795 | if (config.options.workstationId !== undefined) {
|
796 | if (typeof config.options.workstationId !== 'string') {
|
797 | throw new TypeError('The "config.options.workstationId" property must be of type string.');
|
798 | }
|
799 | this.config.options.workstationId = config.options.workstationId;
|
800 | }
|
801 | if (config.options.lowerCaseGuids !== undefined) {
|
802 | if (typeof config.options.lowerCaseGuids !== 'boolean') {
|
803 | throw new TypeError('The "config.options.lowerCaseGuids" property must be of type boolean.');
|
804 | }
|
805 | this.config.options.lowerCaseGuids = config.options.lowerCaseGuids;
|
806 | }
|
807 | }
|
808 | this.secureContextOptions = this.config.options.cryptoCredentialsDetails;
|
809 | if (this.secureContextOptions.secureOptions === undefined) {
|
810 | // If the caller has not specified their own `secureOptions`,
|
811 | // we set `SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS` here.
|
812 | // Older SQL Server instances running on older Windows versions have
|
813 | // trouble with the BEAST workaround in OpenSSL.
|
814 | // As BEAST is a browser specific exploit, we can just disable this option here.
|
815 | this.secureContextOptions = Object.create(this.secureContextOptions, {
|
816 | secureOptions: {
|
817 | value: _constants.default.SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS
|
818 | }
|
819 | });
|
820 | }
|
821 | this.debug = this.createDebug();
|
822 | this.inTransaction = false;
|
823 | this.transactionDescriptors = [Buffer.from([0, 0, 0, 0, 0, 0, 0, 0])];
|
824 |
|
825 | // 'beginTransaction', 'commitTransaction' and 'rollbackTransaction'
|
826 | // events are utilized to maintain inTransaction property state which in
|
827 | // turn is used in managing transactions. These events are only fired for
|
828 | // TDS version 7.2 and beyond. The properties below are used to emulate
|
829 | // equivalent behavior for TDS versions before 7.2.
|
830 | this.transactionDepth = 0;
|
831 | this.isSqlBatch = false;
|
832 | this.closed = false;
|
833 | this.messageBuffer = Buffer.alloc(0);
|
834 | this.curTransientRetryCount = 0;
|
835 | this.transientErrorLookup = new _transientErrorLookup.TransientErrorLookup();
|
836 | this.state = this.STATE.INITIALIZED;
|
837 | this._cancelAfterRequestSent = () => {
|
838 | this.messageIo.sendMessage(_packet.TYPE.ATTENTION);
|
839 | this.createCancelTimer();
|
840 | };
|
841 | }
|
842 | connect(connectListener) {
|
843 | if (this.state !== this.STATE.INITIALIZED) {
|
844 | throw new _errors.ConnectionError('`.connect` can not be called on a Connection in `' + this.state.name + '` state.');
|
845 | }
|
846 | if (connectListener) {
|
847 | const onConnect = err => {
|
848 | this.removeListener('error', onError);
|
849 | connectListener(err);
|
850 | };
|
851 | const onError = err => {
|
852 | this.removeListener('connect', onConnect);
|
853 | connectListener(err);
|
854 | };
|
855 | this.once('connect', onConnect);
|
856 | this.once('error', onError);
|
857 | }
|
858 | this.transitionTo(this.STATE.CONNECTING);
|
859 | }
|
860 |
|
861 | /**
|
862 | * The server has reported that the charset has changed.
|
863 | */
|
864 |
|
865 | /**
|
866 | * The attempt to connect and validate has completed.
|
867 | */
|
868 |
|
869 | /**
|
870 | * The server has reported that the active database has changed.
|
871 | * This may be as a result of a successful login, or a `use` statement.
|
872 | */
|
873 |
|
874 | /**
|
875 | * A debug message is available. It may be logged or ignored.
|
876 | */
|
877 |
|
878 | /**
|
879 | * Internal error occurs.
|
880 | */
|
881 |
|
882 | /**
|
883 | * The server has issued an error message.
|
884 | */
|
885 |
|
886 | /**
|
887 | * The connection has ended.
|
888 | *
|
889 | * This may be as a result of the client calling [[close]], the server
|
890 | * closing the connection, or a network error.
|
891 | */
|
892 |
|
893 | /**
|
894 | * The server has issued an information message.
|
895 | */
|
896 |
|
897 | /**
|
898 | * The server has reported that the language has changed.
|
899 | */
|
900 |
|
901 | /**
|
902 | * The connection was reset.
|
903 | */
|
904 |
|
905 | /**
|
906 | * A secure connection has been established.
|
907 | */
|
908 |
|
909 | on(event, listener) {
|
910 | return super.on(event, listener);
|
911 | }
|
912 |
|
913 | /**
|
914 | * @private
|
915 | */
|
916 |
|
917 | /**
|
918 | * @private
|
919 | */
|
920 |
|
921 | /**
|
922 | * @private
|
923 | */
|
924 |
|
925 | /**
|
926 | * @private
|
927 | */
|
928 |
|
929 | /**
|
930 | * @private
|
931 | */
|
932 |
|
933 | /**
|
934 | * @private
|
935 | */
|
936 |
|
937 | /**
|
938 | * @private
|
939 | */
|
940 |
|
941 | /**
|
942 | * @private
|
943 | */
|
944 |
|
945 | /**
|
946 | * @private
|
947 | */
|
948 |
|
949 | /**
|
950 | * @private
|
951 | */
|
952 |
|
953 | /**
|
954 | * @private
|
955 | */
|
956 |
|
957 | /**
|
958 | * @private
|
959 | */
|
960 |
|
961 | /**
|
962 | * @private
|
963 | */
|
964 |
|
965 | /**
|
966 | * @private
|
967 | */
|
968 |
|
969 | emit(event, ...args) {
|
970 | return super.emit(event, ...args);
|
971 | }
|
972 |
|
973 | /**
|
974 | * Closes the connection to the database.
|
975 | *
|
976 | * The [[Event_end]] will be emitted once the connection has been closed.
|
977 | */
|
978 | close() {
|
979 | this.transitionTo(this.STATE.FINAL);
|
980 | }
|
981 |
|
982 | /**
|
983 | * @private
|
984 | */
|
985 | initialiseConnection() {
|
986 | const signal = this.createConnectTimer();
|
987 | if (this.config.options.port) {
|
988 | return this.connectOnPort(this.config.options.port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);
|
989 | } else {
|
990 | return (0, _instanceLookup.instanceLookup)({
|
991 | server: this.config.server,
|
992 | instanceName: this.config.options.instanceName,
|
993 | timeout: this.config.options.connectTimeout,
|
994 | signal: signal
|
995 | }).then(port => {
|
996 | process.nextTick(() => {
|
997 | this.connectOnPort(port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);
|
998 | });
|
999 | }, err => {
|
1000 | this.clearConnectTimer();
|
1001 | if (signal.aborted) {
|
1002 | // Ignore the AbortError for now, this is still handled by the connectTimer firing
|
1003 | return;
|
1004 | }
|
1005 | process.nextTick(() => {
|
1006 | this.emit('connect', new _errors.ConnectionError(err.message, 'EINSTLOOKUP', {
|
1007 | cause: err
|
1008 | }));
|
1009 | });
|
1010 | });
|
1011 | }
|
1012 | }
|
1013 |
|
1014 | /**
|
1015 | * @private
|
1016 | */
|
1017 | cleanupConnection(cleanupType) {
|
1018 | if (!this.closed) {
|
1019 | this.clearConnectTimer();
|
1020 | this.clearRequestTimer();
|
1021 | this.clearRetryTimer();
|
1022 | this.closeConnection();
|
1023 | if (cleanupType === CLEANUP_TYPE.REDIRECT) {
|
1024 | this.emit('rerouting');
|
1025 | } else if (cleanupType !== CLEANUP_TYPE.RETRY) {
|
1026 | process.nextTick(() => {
|
1027 | this.emit('end');
|
1028 | });
|
1029 | }
|
1030 | const request = this.request;
|
1031 | if (request) {
|
1032 | const err = new _errors.RequestError('Connection closed before request completed.', 'ECLOSE');
|
1033 | request.callback(err);
|
1034 | this.request = undefined;
|
1035 | }
|
1036 | this.closed = true;
|
1037 | this.loginError = undefined;
|
1038 | }
|
1039 | }
|
1040 |
|
1041 | /**
|
1042 | * @private
|
1043 | */
|
1044 | createDebug() {
|
1045 | const debug = new _debug.default(this.config.options.debug);
|
1046 | debug.on('debug', message => {
|
1047 | this.emit('debug', message);
|
1048 | });
|
1049 | return debug;
|
1050 | }
|
1051 |
|
1052 | /**
|
1053 | * @private
|
1054 | */
|
1055 | createTokenStreamParser(message, handler) {
|
1056 | return new _tokenStreamParser.Parser(message, this.debug, handler, this.config.options);
|
1057 | }
|
1058 | socketHandlingForSendPreLogin(socket) {
|
1059 | socket.on('error', error => {
|
1060 | this.socketError(error);
|
1061 | });
|
1062 | socket.on('close', () => {
|
1063 | this.socketClose();
|
1064 | });
|
1065 | socket.on('end', () => {
|
1066 | this.socketEnd();
|
1067 | });
|
1068 | socket.setKeepAlive(true, KEEP_ALIVE_INITIAL_DELAY);
|
1069 | this.messageIo = new _messageIo.default(socket, this.config.options.packetSize, this.debug);
|
1070 | this.messageIo.on('secure', cleartext => {
|
1071 | this.emit('secure', cleartext);
|
1072 | });
|
1073 | this.socket = socket;
|
1074 | this.closed = false;
|
1075 | this.debug.log('connected to ' + this.config.server + ':' + this.config.options.port);
|
1076 | this.sendPreLogin();
|
1077 | this.transitionTo(this.STATE.SENT_PRELOGIN);
|
1078 | }
|
1079 | wrapWithTls(socket, signal) {
|
1080 | signal.throwIfAborted();
|
1081 | return new Promise((resolve, reject) => {
|
1082 | const secureContext = tls.createSecureContext(this.secureContextOptions);
|
1083 | // If connect to an ip address directly,
|
1084 | // need to set the servername to an empty string
|
1085 | // if the user has not given a servername explicitly
|
1086 | const serverName = !net.isIP(this.config.server) ? this.config.server : '';
|
1087 | const encryptOptions = {
|
1088 | host: this.config.server,
|
1089 | socket: socket,
|
1090 | ALPNProtocols: ['tds/8.0'],
|
1091 | secureContext: secureContext,
|
1092 | servername: this.config.options.serverName ? this.config.options.serverName : serverName
|
1093 | };
|
1094 | const encryptsocket = tls.connect(encryptOptions);
|
1095 | const onAbort = () => {
|
1096 | encryptsocket.removeListener('error', onError);
|
1097 | encryptsocket.removeListener('connect', onConnect);
|
1098 | encryptsocket.destroy();
|
1099 | reject(signal.reason);
|
1100 | };
|
1101 | const onError = err => {
|
1102 | signal.removeEventListener('abort', onAbort);
|
1103 | encryptsocket.removeListener('error', onError);
|
1104 | encryptsocket.removeListener('connect', onConnect);
|
1105 | encryptsocket.destroy();
|
1106 | reject(err);
|
1107 | };
|
1108 | const onConnect = () => {
|
1109 | signal.removeEventListener('abort', onAbort);
|
1110 | encryptsocket.removeListener('error', onError);
|
1111 | encryptsocket.removeListener('connect', onConnect);
|
1112 | resolve(encryptsocket);
|
1113 | };
|
1114 | signal.addEventListener('abort', onAbort, {
|
1115 | once: true
|
1116 | });
|
1117 | encryptsocket.on('error', onError);
|
1118 | encryptsocket.on('secureConnect', onConnect);
|
1119 | });
|
1120 | }
|
1121 | connectOnPort(port, multiSubnetFailover, signal, customConnector) {
|
1122 | const connectOpts = {
|
1123 | host: this.routingData ? this.routingData.server : this.config.server,
|
1124 | port: this.routingData ? this.routingData.port : port,
|
1125 | localAddress: this.config.options.localAddress
|
1126 | };
|
1127 | const connect = customConnector || (multiSubnetFailover ? _connector.connectInParallel : _connector.connectInSequence);
|
1128 | (async () => {
|
1129 | let socket = await connect(connectOpts, _dns.default.lookup, signal);
|
1130 | if (this.config.options.encrypt === 'strict') {
|
1131 | try {
|
1132 | // Wrap the socket with TLS for TDS 8.0
|
1133 | socket = await this.wrapWithTls(socket, signal);
|
1134 | } catch (err) {
|
1135 | socket.end();
|
1136 | throw err;
|
1137 | }
|
1138 | }
|
1139 | this.socketHandlingForSendPreLogin(socket);
|
1140 | })().catch(err => {
|
1141 | this.clearConnectTimer();
|
1142 | if (signal.aborted) {
|
1143 | return;
|
1144 | }
|
1145 | process.nextTick(() => {
|
1146 | this.socketError(err);
|
1147 | });
|
1148 | });
|
1149 | }
|
1150 |
|
1151 | /**
|
1152 | * @private
|
1153 | */
|
1154 | closeConnection() {
|
1155 | if (this.socket) {
|
1156 | this.socket.destroy();
|
1157 | }
|
1158 | }
|
1159 |
|
1160 | /**
|
1161 | * @private
|
1162 | */
|
1163 | createConnectTimer() {
|
1164 | const controller = new AbortController();
|
1165 | this.connectTimer = setTimeout(() => {
|
1166 | controller.abort();
|
1167 | this.connectTimeout();
|
1168 | }, this.config.options.connectTimeout);
|
1169 | return controller.signal;
|
1170 | }
|
1171 |
|
1172 | /**
|
1173 | * @private
|
1174 | */
|
1175 | createCancelTimer() {
|
1176 | this.clearCancelTimer();
|
1177 | const timeout = this.config.options.cancelTimeout;
|
1178 | if (timeout > 0) {
|
1179 | this.cancelTimer = setTimeout(() => {
|
1180 | this.cancelTimeout();
|
1181 | }, timeout);
|
1182 | }
|
1183 | }
|
1184 |
|
1185 | /**
|
1186 | * @private
|
1187 | */
|
1188 | createRequestTimer() {
|
1189 | this.clearRequestTimer(); // release old timer, just to be safe
|
1190 | const request = this.request;
|
1191 | const timeout = request.timeout !== undefined ? request.timeout : this.config.options.requestTimeout;
|
1192 | if (timeout) {
|
1193 | this.requestTimer = setTimeout(() => {
|
1194 | this.requestTimeout();
|
1195 | }, timeout);
|
1196 | }
|
1197 | }
|
1198 |
|
1199 | /**
|
1200 | * @private
|
1201 | */
|
1202 | createRetryTimer() {
|
1203 | this.clearRetryTimer();
|
1204 | this.retryTimer = setTimeout(() => {
|
1205 | this.retryTimeout();
|
1206 | }, this.config.options.connectionRetryInterval);
|
1207 | }
|
1208 |
|
1209 | /**
|
1210 | * @private
|
1211 | */
|
1212 | connectTimeout() {
|
1213 | const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\${this.config.options.instanceName}`;
|
1214 | // If we have routing data stored, this connection has been redirected
|
1215 | const server = this.routingData ? this.routingData.server : this.config.server;
|
1216 | const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;
|
1217 | // Grab the target host from the connection configuration, and from a redirect message
|
1218 | // otherwise, leave the message empty.
|
1219 | const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';
|
1220 | const message = `Failed to connect to ${server}${port}${routingMessage} in ${this.config.options.connectTimeout}ms`;
|
1221 | this.debug.log(message);
|
1222 | this.emit('connect', new _errors.ConnectionError(message, 'ETIMEOUT'));
|
1223 | this.connectTimer = undefined;
|
1224 | this.dispatchEvent('connectTimeout');
|
1225 | }
|
1226 |
|
1227 | /**
|
1228 | * @private
|
1229 | */
|
1230 | cancelTimeout() {
|
1231 | const message = `Failed to cancel request in ${this.config.options.cancelTimeout}ms`;
|
1232 | this.debug.log(message);
|
1233 | this.dispatchEvent('socketError', new _errors.ConnectionError(message, 'ETIMEOUT'));
|
1234 | }
|
1235 |
|
1236 | /**
|
1237 | * @private
|
1238 | */
|
1239 | requestTimeout() {
|
1240 | this.requestTimer = undefined;
|
1241 | const request = this.request;
|
1242 | request.cancel();
|
1243 | const timeout = request.timeout !== undefined ? request.timeout : this.config.options.requestTimeout;
|
1244 | const message = 'Timeout: Request failed to complete in ' + timeout + 'ms';
|
1245 | request.error = new _errors.RequestError(message, 'ETIMEOUT');
|
1246 | }
|
1247 |
|
1248 | /**
|
1249 | * @private
|
1250 | */
|
1251 | retryTimeout() {
|
1252 | this.retryTimer = undefined;
|
1253 | this.emit('retry');
|
1254 | this.transitionTo(this.STATE.CONNECTING);
|
1255 | }
|
1256 |
|
1257 | /**
|
1258 | * @private
|
1259 | */
|
1260 | clearConnectTimer() {
|
1261 | if (this.connectTimer) {
|
1262 | clearTimeout(this.connectTimer);
|
1263 | this.connectTimer = undefined;
|
1264 | }
|
1265 | }
|
1266 |
|
1267 | /**
|
1268 | * @private
|
1269 | */
|
1270 | clearCancelTimer() {
|
1271 | if (this.cancelTimer) {
|
1272 | clearTimeout(this.cancelTimer);
|
1273 | this.cancelTimer = undefined;
|
1274 | }
|
1275 | }
|
1276 |
|
1277 | /**
|
1278 | * @private
|
1279 | */
|
1280 | clearRequestTimer() {
|
1281 | if (this.requestTimer) {
|
1282 | clearTimeout(this.requestTimer);
|
1283 | this.requestTimer = undefined;
|
1284 | }
|
1285 | }
|
1286 |
|
1287 | /**
|
1288 | * @private
|
1289 | */
|
1290 | clearRetryTimer() {
|
1291 | if (this.retryTimer) {
|
1292 | clearTimeout(this.retryTimer);
|
1293 | this.retryTimer = undefined;
|
1294 | }
|
1295 | }
|
1296 |
|
1297 | /**
|
1298 | * @private
|
1299 | */
|
1300 | transitionTo(newState) {
|
1301 | if (this.state === newState) {
|
1302 | this.debug.log('State is already ' + newState.name);
|
1303 | return;
|
1304 | }
|
1305 | if (this.state && this.state.exit) {
|
1306 | this.state.exit.call(this, newState);
|
1307 | }
|
1308 | this.debug.log('State change: ' + (this.state ? this.state.name : 'undefined') + ' -> ' + newState.name);
|
1309 | this.state = newState;
|
1310 | if (this.state.enter) {
|
1311 | this.state.enter.apply(this);
|
1312 | }
|
1313 | }
|
1314 |
|
1315 | /**
|
1316 | * @private
|
1317 | */
|
1318 | getEventHandler(eventName) {
|
1319 | const handler = this.state.events[eventName];
|
1320 | if (!handler) {
|
1321 | throw new Error(`No event '${eventName}' in state '${this.state.name}'`);
|
1322 | }
|
1323 | return handler;
|
1324 | }
|
1325 |
|
1326 | /**
|
1327 | * @private
|
1328 | */
|
1329 | dispatchEvent(eventName, ...args) {
|
1330 | const handler = this.state.events[eventName];
|
1331 | if (handler) {
|
1332 | handler.apply(this, args);
|
1333 | } else {
|
1334 | this.emit('error', new Error(`No event '${eventName}' in state '${this.state.name}'`));
|
1335 | this.close();
|
1336 | }
|
1337 | }
|
1338 |
|
1339 | /**
|
1340 | * @private
|
1341 | */
|
1342 | socketError(error) {
|
1343 | if (this.state === this.STATE.CONNECTING || this.state === this.STATE.SENT_TLSSSLNEGOTIATION) {
|
1344 | const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\${this.config.options.instanceName}`;
|
1345 | // If we have routing data stored, this connection has been redirected
|
1346 | const server = this.routingData ? this.routingData.server : this.config.server;
|
1347 | const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;
|
1348 | // Grab the target host from the connection configuration, and from a redirect message
|
1349 | // otherwise, leave the message empty.
|
1350 | const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';
|
1351 | const message = `Failed to connect to ${server}${port}${routingMessage} - ${error.message}`;
|
1352 | this.debug.log(message);
|
1353 | this.emit('connect', new _errors.ConnectionError(message, 'ESOCKET', {
|
1354 | cause: error
|
1355 | }));
|
1356 | } else {
|
1357 | const message = `Connection lost - ${error.message}`;
|
1358 | this.debug.log(message);
|
1359 | this.emit('error', new _errors.ConnectionError(message, 'ESOCKET', {
|
1360 | cause: error
|
1361 | }));
|
1362 | }
|
1363 | this.dispatchEvent('socketError', error);
|
1364 | }
|
1365 |
|
1366 | /**
|
1367 | * @private
|
1368 | */
|
1369 | socketEnd() {
|
1370 | this.debug.log('socket ended');
|
1371 | if (this.state !== this.STATE.FINAL) {
|
1372 | const error = new Error('socket hang up');
|
1373 | error.code = 'ECONNRESET';
|
1374 | this.socketError(error);
|
1375 | }
|
1376 | }
|
1377 |
|
1378 | /**
|
1379 | * @private
|
1380 | */
|
1381 | socketClose() {
|
1382 | this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');
|
1383 | if (this.state === this.STATE.REROUTING) {
|
1384 | this.debug.log('Rerouting to ' + this.routingData.server + ':' + this.routingData.port);
|
1385 | this.dispatchEvent('reconnect');
|
1386 | } else if (this.state === this.STATE.TRANSIENT_FAILURE_RETRY) {
|
1387 | const server = this.routingData ? this.routingData.server : this.config.server;
|
1388 | const port = this.routingData ? this.routingData.port : this.config.options.port;
|
1389 | this.debug.log('Retry after transient failure connecting to ' + server + ':' + port);
|
1390 | this.dispatchEvent('retry');
|
1391 | } else {
|
1392 | this.transitionTo(this.STATE.FINAL);
|
1393 | }
|
1394 | }
|
1395 |
|
1396 | /**
|
1397 | * @private
|
1398 | */
|
1399 | sendPreLogin() {
|
1400 | const [, major, minor, build] = /^(\d+)\.(\d+)\.(\d+)/.exec(_package.version) ?? ['0.0.0', '0', '0', '0'];
|
1401 | const payload = new _preloginPayload.default({
|
1402 | // If encrypt setting is set to 'strict', then we should have already done the encryption before calling
|
1403 | // this function. Therefore, the encrypt will be set to false here.
|
1404 | // Otherwise, we will set encrypt here based on the encrypt Boolean value from the configuration.
|
1405 | encrypt: typeof this.config.options.encrypt === 'boolean' && this.config.options.encrypt,
|
1406 | version: {
|
1407 | major: Number(major),
|
1408 | minor: Number(minor),
|
1409 | build: Number(build),
|
1410 | subbuild: 0
|
1411 | }
|
1412 | });
|
1413 | this.messageIo.sendMessage(_packet.TYPE.PRELOGIN, payload.data);
|
1414 | this.debug.payload(function () {
|
1415 | return payload.toString(' ');
|
1416 | });
|
1417 | }
|
1418 |
|
1419 | /**
|
1420 | * @private
|
1421 | */
|
1422 | sendLogin7Packet() {
|
1423 | const payload = new _login7Payload.default({
|
1424 | tdsVersion: _tdsVersions.versions[this.config.options.tdsVersion],
|
1425 | packetSize: this.config.options.packetSize,
|
1426 | clientProgVer: 0,
|
1427 | clientPid: process.pid,
|
1428 | connectionId: 0,
|
1429 | clientTimeZone: new Date().getTimezoneOffset(),
|
1430 | clientLcid: 0x00000409
|
1431 | });
|
1432 | const {
|
1433 | authentication
|
1434 | } = this.config;
|
1435 | switch (authentication.type) {
|
1436 | case 'azure-active-directory-password':
|
1437 | payload.fedAuth = {
|
1438 | type: 'ADAL',
|
1439 | echo: this.fedAuthRequired,
|
1440 | workflow: 'default'
|
1441 | };
|
1442 | break;
|
1443 | case 'azure-active-directory-access-token':
|
1444 | payload.fedAuth = {
|
1445 | type: 'SECURITYTOKEN',
|
1446 | echo: this.fedAuthRequired,
|
1447 | fedAuthToken: authentication.options.token
|
1448 | };
|
1449 | break;
|
1450 | case 'token-credential':
|
1451 | case 'azure-active-directory-msi-vm':
|
1452 | case 'azure-active-directory-default':
|
1453 | case 'azure-active-directory-msi-app-service':
|
1454 | case 'azure-active-directory-service-principal-secret':
|
1455 | payload.fedAuth = {
|
1456 | type: 'ADAL',
|
1457 | echo: this.fedAuthRequired,
|
1458 | workflow: 'integrated'
|
1459 | };
|
1460 | break;
|
1461 | case 'ntlm':
|
1462 | payload.sspi = (0, _ntlm.createNTLMRequest)({
|
1463 | domain: authentication.options.domain
|
1464 | });
|
1465 | break;
|
1466 | default:
|
1467 | payload.userName = authentication.options.userName;
|
1468 | payload.password = authentication.options.password;
|
1469 | }
|
1470 | payload.hostname = this.config.options.workstationId || _os.default.hostname();
|
1471 | payload.serverName = this.routingData ? this.routingData.server : this.config.server;
|
1472 | payload.appName = this.config.options.appName || 'Tedious';
|
1473 | payload.libraryName = _library.name;
|
1474 | payload.language = this.config.options.language;
|
1475 | payload.database = this.config.options.database;
|
1476 | payload.clientId = Buffer.from([1, 2, 3, 4, 5, 6]);
|
1477 | payload.readOnlyIntent = this.config.options.readOnlyIntent;
|
1478 | payload.initDbFatal = !this.config.options.fallbackToDefaultDb;
|
1479 | this.routingData = undefined;
|
1480 | this.messageIo.sendMessage(_packet.TYPE.LOGIN7, payload.toBuffer());
|
1481 | this.debug.payload(function () {
|
1482 | return payload.toString(' ');
|
1483 | });
|
1484 | }
|
1485 |
|
1486 | /**
|
1487 | * @private
|
1488 | */
|
1489 | sendFedAuthTokenMessage(token) {
|
1490 | const accessTokenLen = Buffer.byteLength(token, 'ucs2');
|
1491 | const data = Buffer.alloc(8 + accessTokenLen);
|
1492 | let offset = 0;
|
1493 | offset = data.writeUInt32LE(accessTokenLen + 4, offset);
|
1494 | offset = data.writeUInt32LE(accessTokenLen, offset);
|
1495 | data.write(token, offset, 'ucs2');
|
1496 | this.messageIo.sendMessage(_packet.TYPE.FEDAUTH_TOKEN, data);
|
1497 | // sent the fedAuth token message, the rest is similar to standard login 7
|
1498 | this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);
|
1499 | }
|
1500 |
|
1501 | /**
|
1502 | * @private
|
1503 | */
|
1504 | sendInitialSql() {
|
1505 | const payload = new _sqlbatchPayload.default(this.getInitialSql(), this.currentTransactionDescriptor(), this.config.options);
|
1506 | const message = new _message.default({
|
1507 | type: _packet.TYPE.SQL_BATCH
|
1508 | });
|
1509 | this.messageIo.outgoingMessageStream.write(message);
|
1510 | _stream.Readable.from(payload).pipe(message);
|
1511 | }
|
1512 |
|
1513 | /**
|
1514 | * @private
|
1515 | */
|
1516 | getInitialSql() {
|
1517 | const options = [];
|
1518 | if (this.config.options.enableAnsiNull === true) {
|
1519 | options.push('set ansi_nulls on');
|
1520 | } else if (this.config.options.enableAnsiNull === false) {
|
1521 | options.push('set ansi_nulls off');
|
1522 | }
|
1523 | if (this.config.options.enableAnsiNullDefault === true) {
|
1524 | options.push('set ansi_null_dflt_on on');
|
1525 | } else if (this.config.options.enableAnsiNullDefault === false) {
|
1526 | options.push('set ansi_null_dflt_on off');
|
1527 | }
|
1528 | if (this.config.options.enableAnsiPadding === true) {
|
1529 | options.push('set ansi_padding on');
|
1530 | } else if (this.config.options.enableAnsiPadding === false) {
|
1531 | options.push('set ansi_padding off');
|
1532 | }
|
1533 | if (this.config.options.enableAnsiWarnings === true) {
|
1534 | options.push('set ansi_warnings on');
|
1535 | } else if (this.config.options.enableAnsiWarnings === false) {
|
1536 | options.push('set ansi_warnings off');
|
1537 | }
|
1538 | if (this.config.options.enableArithAbort === true) {
|
1539 | options.push('set arithabort on');
|
1540 | } else if (this.config.options.enableArithAbort === false) {
|
1541 | options.push('set arithabort off');
|
1542 | }
|
1543 | if (this.config.options.enableConcatNullYieldsNull === true) {
|
1544 | options.push('set concat_null_yields_null on');
|
1545 | } else if (this.config.options.enableConcatNullYieldsNull === false) {
|
1546 | options.push('set concat_null_yields_null off');
|
1547 | }
|
1548 | if (this.config.options.enableCursorCloseOnCommit === true) {
|
1549 | options.push('set cursor_close_on_commit on');
|
1550 | } else if (this.config.options.enableCursorCloseOnCommit === false) {
|
1551 | options.push('set cursor_close_on_commit off');
|
1552 | }
|
1553 | if (this.config.options.datefirst !== null) {
|
1554 | options.push(`set datefirst ${this.config.options.datefirst}`);
|
1555 | }
|
1556 | if (this.config.options.dateFormat !== null) {
|
1557 | options.push(`set dateformat ${this.config.options.dateFormat}`);
|
1558 | }
|
1559 | if (this.config.options.enableImplicitTransactions === true) {
|
1560 | options.push('set implicit_transactions on');
|
1561 | } else if (this.config.options.enableImplicitTransactions === false) {
|
1562 | options.push('set implicit_transactions off');
|
1563 | }
|
1564 | if (this.config.options.language !== null) {
|
1565 | options.push(`set language ${this.config.options.language}`);
|
1566 | }
|
1567 | if (this.config.options.enableNumericRoundabort === true) {
|
1568 | options.push('set numeric_roundabort on');
|
1569 | } else if (this.config.options.enableNumericRoundabort === false) {
|
1570 | options.push('set numeric_roundabort off');
|
1571 | }
|
1572 | if (this.config.options.enableQuotedIdentifier === true) {
|
1573 | options.push('set quoted_identifier on');
|
1574 | } else if (this.config.options.enableQuotedIdentifier === false) {
|
1575 | options.push('set quoted_identifier off');
|
1576 | }
|
1577 | if (this.config.options.textsize !== null) {
|
1578 | options.push(`set textsize ${this.config.options.textsize}`);
|
1579 | }
|
1580 | if (this.config.options.connectionIsolationLevel !== null) {
|
1581 | options.push(`set transaction isolation level ${this.getIsolationLevelText(this.config.options.connectionIsolationLevel)}`);
|
1582 | }
|
1583 | if (this.config.options.abortTransactionOnError === true) {
|
1584 | options.push('set xact_abort on');
|
1585 | } else if (this.config.options.abortTransactionOnError === false) {
|
1586 | options.push('set xact_abort off');
|
1587 | }
|
1588 | return options.join('\n');
|
1589 | }
|
1590 |
|
1591 | /**
|
1592 | * @private
|
1593 | */
|
1594 | processedInitialSql() {
|
1595 | this.clearConnectTimer();
|
1596 | this.emit('connect');
|
1597 | }
|
1598 |
|
1599 | /**
|
1600 | * Execute the SQL batch represented by [[Request]].
|
1601 | * There is no param support, and unlike [[Request.execSql]],
|
1602 | * it is not likely that SQL Server will reuse the execution plan it generates for the SQL.
|
1603 | *
|
1604 | * In almost all cases, [[Request.execSql]] will be a better choice.
|
1605 | *
|
1606 | * @param request A [[Request]] object representing the request.
|
1607 | */
|
1608 | execSqlBatch(request) {
|
1609 | this.makeRequest(request, _packet.TYPE.SQL_BATCH, new _sqlbatchPayload.default(request.sqlTextOrProcedure, this.currentTransactionDescriptor(), this.config.options));
|
1610 | }
|
1611 |
|
1612 | /**
|
1613 | * Execute the SQL represented by [[Request]].
|
1614 | *
|
1615 | * As `sp_executesql` is used to execute the SQL, if the same SQL is executed multiples times
|
1616 | * using this function, the SQL Server query optimizer is likely to reuse the execution plan it generates
|
1617 | * for the first execution. This may also result in SQL server treating the request like a stored procedure
|
1618 | * which can result in the [[Event_doneInProc]] or [[Event_doneProc]] events being emitted instead of the
|
1619 | * [[Event_done]] event you might expect. Using [[execSqlBatch]] will prevent this from occurring but may have a negative performance impact.
|
1620 | *
|
1621 | * Beware of the way that scoping rules apply, and how they may [affect local temp tables](http://weblogs.sqlteam.com/mladenp/archive/2006/11/03/17197.aspx)
|
1622 | * If you're running in to scoping issues, then [[execSqlBatch]] may be a better choice.
|
1623 | * See also [issue #24](https://github.com/pekim/tedious/issues/24)
|
1624 | *
|
1625 | * @param request A [[Request]] object representing the request.
|
1626 | */
|
1627 | execSql(request) {
|
1628 | try {
|
1629 | request.validateParameters(this.databaseCollation);
|
1630 | } catch (error) {
|
1631 | request.error = error;
|
1632 | process.nextTick(() => {
|
1633 | this.debug.log(error.message);
|
1634 | request.callback(error);
|
1635 | });
|
1636 | return;
|
1637 | }
|
1638 | const parameters = [];
|
1639 | parameters.push({
|
1640 | type: _dataType.TYPES.NVarChar,
|
1641 | name: 'statement',
|
1642 | value: request.sqlTextOrProcedure,
|
1643 | output: false,
|
1644 | length: undefined,
|
1645 | precision: undefined,
|
1646 | scale: undefined
|
1647 | });
|
1648 | if (request.parameters.length) {
|
1649 | parameters.push({
|
1650 | type: _dataType.TYPES.NVarChar,
|
1651 | name: 'params',
|
1652 | value: request.makeParamsParameter(request.parameters),
|
1653 | output: false,
|
1654 | length: undefined,
|
1655 | precision: undefined,
|
1656 | scale: undefined
|
1657 | });
|
1658 | parameters.push(...request.parameters);
|
1659 | }
|
1660 | this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_ExecuteSql, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
1661 | }
|
1662 |
|
1663 | /**
|
1664 | * Creates a new BulkLoad instance.
|
1665 | *
|
1666 | * @param table The name of the table to bulk-insert into.
|
1667 | * @param options A set of bulk load options.
|
1668 | */
|
1669 |
|
1670 | newBulkLoad(table, callbackOrOptions, callback) {
|
1671 | let options;
|
1672 | if (callback === undefined) {
|
1673 | callback = callbackOrOptions;
|
1674 | options = {};
|
1675 | } else {
|
1676 | options = callbackOrOptions;
|
1677 | }
|
1678 | if (typeof options !== 'object') {
|
1679 | throw new TypeError('"options" argument must be an object');
|
1680 | }
|
1681 | return new _bulkLoad.default(table, this.databaseCollation, this.config.options, options, callback);
|
1682 | }
|
1683 |
|
1684 | /**
|
1685 | * Execute a [[BulkLoad]].
|
1686 | *
|
1687 | * ```js
|
1688 | * // We want to perform a bulk load into a table with the following format:
|
1689 | * // CREATE TABLE employees (first_name nvarchar(255), last_name nvarchar(255), day_of_birth date);
|
1690 | *
|
1691 | * const bulkLoad = connection.newBulkLoad('employees', (err, rowCount) => {
|
1692 | * // ...
|
1693 | * });
|
1694 | *
|
1695 | * // First, we need to specify the columns that we want to write to,
|
1696 | * // and their definitions. These definitions must match the actual table,
|
1697 | * // otherwise the bulk load will fail.
|
1698 | * bulkLoad.addColumn('first_name', TYPES.NVarchar, { nullable: false });
|
1699 | * bulkLoad.addColumn('last_name', TYPES.NVarchar, { nullable: false });
|
1700 | * bulkLoad.addColumn('date_of_birth', TYPES.Date, { nullable: false });
|
1701 | *
|
1702 | * // Execute a bulk load with a predefined list of rows.
|
1703 | * //
|
1704 | * // Note that these rows are held in memory until the
|
1705 | * // bulk load was performed, so if you need to write a large
|
1706 | * // number of rows (e.g. by reading from a CSV file),
|
1707 | * // passing an `AsyncIterable` is advisable to keep memory usage low.
|
1708 | * connection.execBulkLoad(bulkLoad, [
|
1709 | * { 'first_name': 'Steve', 'last_name': 'Jobs', 'day_of_birth': new Date('02-24-1955') },
|
1710 | * { 'first_name': 'Bill', 'last_name': 'Gates', 'day_of_birth': new Date('10-28-1955') }
|
1711 | * ]);
|
1712 | * ```
|
1713 | *
|
1714 | * @param bulkLoad A previously created [[BulkLoad]].
|
1715 | * @param rows A [[Iterable]] or [[AsyncIterable]] that contains the rows that should be bulk loaded.
|
1716 | */
|
1717 |
|
1718 | execBulkLoad(bulkLoad, rows) {
|
1719 | bulkLoad.executionStarted = true;
|
1720 | if (rows) {
|
1721 | if (bulkLoad.streamingMode) {
|
1722 | throw new Error("Connection.execBulkLoad can't be called with a BulkLoad that was put in streaming mode.");
|
1723 | }
|
1724 | if (bulkLoad.firstRowWritten) {
|
1725 | throw new Error("Connection.execBulkLoad can't be called with a BulkLoad that already has rows written to it.");
|
1726 | }
|
1727 | const rowStream = _stream.Readable.from(rows);
|
1728 |
|
1729 | // Destroy the packet transform if an error happens in the row stream,
|
1730 | // e.g. if an error is thrown from within a generator or stream.
|
1731 | rowStream.on('error', err => {
|
1732 | bulkLoad.rowToPacketTransform.destroy(err);
|
1733 | });
|
1734 |
|
1735 | // Destroy the row stream if an error happens in the packet transform,
|
1736 | // e.g. if the bulk load is cancelled.
|
1737 | bulkLoad.rowToPacketTransform.on('error', err => {
|
1738 | rowStream.destroy(err);
|
1739 | });
|
1740 | rowStream.pipe(bulkLoad.rowToPacketTransform);
|
1741 | } else if (!bulkLoad.streamingMode) {
|
1742 | // If the bulkload was not put into streaming mode by the user,
|
1743 | // we end the rowToPacketTransform here for them.
|
1744 | //
|
1745 | // If it was put into streaming mode, it's the user's responsibility
|
1746 | // to end the stream.
|
1747 | bulkLoad.rowToPacketTransform.end();
|
1748 | }
|
1749 | const onCancel = () => {
|
1750 | request.cancel();
|
1751 | };
|
1752 | const payload = new _bulkLoadPayload.BulkLoadPayload(bulkLoad);
|
1753 | const request = new _request.default(bulkLoad.getBulkInsertSql(), error => {
|
1754 | bulkLoad.removeListener('cancel', onCancel);
|
1755 | if (error) {
|
1756 | if (error.code === 'UNKNOWN') {
|
1757 | error.message += ' This is likely because the schema of the BulkLoad does not match the schema of the table you are attempting to insert into.';
|
1758 | }
|
1759 | bulkLoad.error = error;
|
1760 | bulkLoad.callback(error);
|
1761 | return;
|
1762 | }
|
1763 | this.makeRequest(bulkLoad, _packet.TYPE.BULK_LOAD, payload);
|
1764 | });
|
1765 | bulkLoad.once('cancel', onCancel);
|
1766 | this.execSqlBatch(request);
|
1767 | }
|
1768 |
|
1769 | /**
|
1770 | * Prepare the SQL represented by the request.
|
1771 | *
|
1772 | * The request can then be used in subsequent calls to
|
1773 | * [[execute]] and [[unprepare]]
|
1774 | *
|
1775 | * @param request A [[Request]] object representing the request.
|
1776 | * Parameters only require a name and type. Parameter values are ignored.
|
1777 | */
|
1778 | prepare(request) {
|
1779 | const parameters = [];
|
1780 | parameters.push({
|
1781 | type: _dataType.TYPES.Int,
|
1782 | name: 'handle',
|
1783 | value: undefined,
|
1784 | output: true,
|
1785 | length: undefined,
|
1786 | precision: undefined,
|
1787 | scale: undefined
|
1788 | });
|
1789 | parameters.push({
|
1790 | type: _dataType.TYPES.NVarChar,
|
1791 | name: 'params',
|
1792 | value: request.parameters.length ? request.makeParamsParameter(request.parameters) : null,
|
1793 | output: false,
|
1794 | length: undefined,
|
1795 | precision: undefined,
|
1796 | scale: undefined
|
1797 | });
|
1798 | parameters.push({
|
1799 | type: _dataType.TYPES.NVarChar,
|
1800 | name: 'stmt',
|
1801 | value: request.sqlTextOrProcedure,
|
1802 | output: false,
|
1803 | length: undefined,
|
1804 | precision: undefined,
|
1805 | scale: undefined
|
1806 | });
|
1807 | request.preparing = true;
|
1808 |
|
1809 | // TODO: We need to clean up this event handler, otherwise this leaks memory
|
1810 | request.on('returnValue', (name, value) => {
|
1811 | if (name === 'handle') {
|
1812 | request.handle = value;
|
1813 | } else {
|
1814 | request.error = new _errors.RequestError(`Tedious > Unexpected output parameter ${name} from sp_prepare`);
|
1815 | }
|
1816 | });
|
1817 | this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Prepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
1818 | }
|
1819 |
|
1820 | /**
|
1821 | * Release the SQL Server resources associated with a previously prepared request.
|
1822 | *
|
1823 | * @param request A [[Request]] object representing the request.
|
1824 | * Parameters only require a name and type.
|
1825 | * Parameter values are ignored.
|
1826 | */
|
1827 | unprepare(request) {
|
1828 | const parameters = [];
|
1829 | parameters.push({
|
1830 | type: _dataType.TYPES.Int,
|
1831 | name: 'handle',
|
1832 | // TODO: Abort if `request.handle` is not set
|
1833 | value: request.handle,
|
1834 | output: false,
|
1835 | length: undefined,
|
1836 | precision: undefined,
|
1837 | scale: undefined
|
1838 | });
|
1839 | this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Unprepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
1840 | }
|
1841 |
|
1842 | /**
|
1843 | * Execute previously prepared SQL, using the supplied parameters.
|
1844 | *
|
1845 | * @param request A previously prepared [[Request]].
|
1846 | * @param parameters An object whose names correspond to the names of
|
1847 | * parameters that were added to the [[Request]] before it was prepared.
|
1848 | * The object's values are passed as the parameters' values when the
|
1849 | * request is executed.
|
1850 | */
|
1851 | execute(request, parameters) {
|
1852 | const executeParameters = [];
|
1853 | executeParameters.push({
|
1854 | type: _dataType.TYPES.Int,
|
1855 | name: '',
|
1856 | // TODO: Abort if `request.handle` is not set
|
1857 | value: request.handle,
|
1858 | output: false,
|
1859 | length: undefined,
|
1860 | precision: undefined,
|
1861 | scale: undefined
|
1862 | });
|
1863 | try {
|
1864 | for (let i = 0, len = request.parameters.length; i < len; i++) {
|
1865 | const parameter = request.parameters[i];
|
1866 | executeParameters.push({
|
1867 | ...parameter,
|
1868 | value: parameter.type.validate(parameters ? parameters[parameter.name] : null, this.databaseCollation)
|
1869 | });
|
1870 | }
|
1871 | } catch (error) {
|
1872 | request.error = error;
|
1873 | process.nextTick(() => {
|
1874 | this.debug.log(error.message);
|
1875 | request.callback(error);
|
1876 | });
|
1877 | return;
|
1878 | }
|
1879 | this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Execute, executeParameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
1880 | }
|
1881 |
|
1882 | /**
|
1883 | * Call a stored procedure represented by [[Request]].
|
1884 | *
|
1885 | * @param request A [[Request]] object representing the request.
|
1886 | */
|
1887 | callProcedure(request) {
|
1888 | try {
|
1889 | request.validateParameters(this.databaseCollation);
|
1890 | } catch (error) {
|
1891 | request.error = error;
|
1892 | process.nextTick(() => {
|
1893 | this.debug.log(error.message);
|
1894 | request.callback(error);
|
1895 | });
|
1896 | return;
|
1897 | }
|
1898 | this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(request.sqlTextOrProcedure, request.parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
1899 | }
|
1900 |
|
1901 | /**
|
1902 | * Start a transaction.
|
1903 | *
|
1904 | * @param callback
|
1905 | * @param name A string representing a name to associate with the transaction.
|
1906 | * Optional, and defaults to an empty string. Required when `isolationLevel`
|
1907 | * is present.
|
1908 | * @param isolationLevel The isolation level that the transaction is to be run with.
|
1909 | *
|
1910 | * The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.
|
1911 | * * `READ_UNCOMMITTED`
|
1912 | * * `READ_COMMITTED`
|
1913 | * * `REPEATABLE_READ`
|
1914 | * * `SERIALIZABLE`
|
1915 | * * `SNAPSHOT`
|
1916 | *
|
1917 | * Optional, and defaults to the Connection's isolation level.
|
1918 | */
|
1919 | beginTransaction(callback, name = '', isolationLevel = this.config.options.isolationLevel) {
|
1920 | (0, _transaction.assertValidIsolationLevel)(isolationLevel, 'isolationLevel');
|
1921 | const transaction = new _transaction.Transaction(name, isolationLevel);
|
1922 | if (this.config.options.tdsVersion < '7_2') {
|
1923 | return this.execSqlBatch(new _request.default('SET TRANSACTION ISOLATION LEVEL ' + transaction.isolationLevelToTSQL() + ';BEGIN TRAN ' + transaction.name, err => {
|
1924 | this.transactionDepth++;
|
1925 | if (this.transactionDepth === 1) {
|
1926 | this.inTransaction = true;
|
1927 | }
|
1928 | callback(err);
|
1929 | }));
|
1930 | }
|
1931 | const request = new _request.default(undefined, err => {
|
1932 | return callback(err, this.currentTransactionDescriptor());
|
1933 | });
|
1934 | return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.beginPayload(this.currentTransactionDescriptor()));
|
1935 | }
|
1936 |
|
1937 | /**
|
1938 | * Commit a transaction.
|
1939 | *
|
1940 | * There should be an active transaction - that is, [[beginTransaction]]
|
1941 | * should have been previously called.
|
1942 | *
|
1943 | * @param callback
|
1944 | * @param name A string representing a name to associate with the transaction.
|
1945 | * Optional, and defaults to an empty string. Required when `isolationLevel`is present.
|
1946 | */
|
1947 | commitTransaction(callback, name = '') {
|
1948 | const transaction = new _transaction.Transaction(name);
|
1949 | if (this.config.options.tdsVersion < '7_2') {
|
1950 | return this.execSqlBatch(new _request.default('COMMIT TRAN ' + transaction.name, err => {
|
1951 | this.transactionDepth--;
|
1952 | if (this.transactionDepth === 0) {
|
1953 | this.inTransaction = false;
|
1954 | }
|
1955 | callback(err);
|
1956 | }));
|
1957 | }
|
1958 | const request = new _request.default(undefined, callback);
|
1959 | return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.commitPayload(this.currentTransactionDescriptor()));
|
1960 | }
|
1961 |
|
1962 | /**
|
1963 | * Rollback a transaction.
|
1964 | *
|
1965 | * There should be an active transaction - that is, [[beginTransaction]]
|
1966 | * should have been previously called.
|
1967 | *
|
1968 | * @param callback
|
1969 | * @param name A string representing a name to associate with the transaction.
|
1970 | * Optional, and defaults to an empty string.
|
1971 | * Required when `isolationLevel` is present.
|
1972 | */
|
1973 | rollbackTransaction(callback, name = '') {
|
1974 | const transaction = new _transaction.Transaction(name);
|
1975 | if (this.config.options.tdsVersion < '7_2') {
|
1976 | return this.execSqlBatch(new _request.default('ROLLBACK TRAN ' + transaction.name, err => {
|
1977 | this.transactionDepth--;
|
1978 | if (this.transactionDepth === 0) {
|
1979 | this.inTransaction = false;
|
1980 | }
|
1981 | callback(err);
|
1982 | }));
|
1983 | }
|
1984 | const request = new _request.default(undefined, callback);
|
1985 | return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.rollbackPayload(this.currentTransactionDescriptor()));
|
1986 | }
|
1987 |
|
1988 | /**
|
1989 | * Set a savepoint within a transaction.
|
1990 | *
|
1991 | * There should be an active transaction - that is, [[beginTransaction]]
|
1992 | * should have been previously called.
|
1993 | *
|
1994 | * @param callback
|
1995 | * @param name A string representing a name to associate with the transaction.\
|
1996 | * Optional, and defaults to an empty string.
|
1997 | * Required when `isolationLevel` is present.
|
1998 | */
|
1999 | saveTransaction(callback, name) {
|
2000 | const transaction = new _transaction.Transaction(name);
|
2001 | if (this.config.options.tdsVersion < '7_2') {
|
2002 | return this.execSqlBatch(new _request.default('SAVE TRAN ' + transaction.name, err => {
|
2003 | this.transactionDepth++;
|
2004 | callback(err);
|
2005 | }));
|
2006 | }
|
2007 | const request = new _request.default(undefined, callback);
|
2008 | return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.savePayload(this.currentTransactionDescriptor()));
|
2009 | }
|
2010 |
|
2011 | /**
|
2012 | * Run the given callback after starting a transaction, and commit or
|
2013 | * rollback the transaction afterwards.
|
2014 | *
|
2015 | * This is a helper that employs [[beginTransaction]], [[commitTransaction]],
|
2016 | * [[rollbackTransaction]], and [[saveTransaction]] to greatly simplify the
|
2017 | * use of database transactions and automatically handle transaction nesting.
|
2018 | *
|
2019 | * @param cb
|
2020 | * @param isolationLevel
|
2021 | * The isolation level that the transaction is to be run with.
|
2022 | *
|
2023 | * The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.
|
2024 | * * `READ_UNCOMMITTED`
|
2025 | * * `READ_COMMITTED`
|
2026 | * * `REPEATABLE_READ`
|
2027 | * * `SERIALIZABLE`
|
2028 | * * `SNAPSHOT`
|
2029 | *
|
2030 | * Optional, and defaults to the Connection's isolation level.
|
2031 | */
|
2032 | transaction(cb, isolationLevel) {
|
2033 | if (typeof cb !== 'function') {
|
2034 | throw new TypeError('`cb` must be a function');
|
2035 | }
|
2036 | const useSavepoint = this.inTransaction;
|
2037 | const name = '_tedious_' + _crypto.default.randomBytes(10).toString('hex');
|
2038 | const txDone = (err, done, ...args) => {
|
2039 | if (err) {
|
2040 | if (this.inTransaction && this.state === this.STATE.LOGGED_IN) {
|
2041 | this.rollbackTransaction(txErr => {
|
2042 | done(txErr || err, ...args);
|
2043 | }, name);
|
2044 | } else {
|
2045 | done(err, ...args);
|
2046 | }
|
2047 | } else if (useSavepoint) {
|
2048 | if (this.config.options.tdsVersion < '7_2') {
|
2049 | this.transactionDepth--;
|
2050 | }
|
2051 | done(null, ...args);
|
2052 | } else {
|
2053 | this.commitTransaction(txErr => {
|
2054 | done(txErr, ...args);
|
2055 | }, name);
|
2056 | }
|
2057 | };
|
2058 | if (useSavepoint) {
|
2059 | return this.saveTransaction(err => {
|
2060 | if (err) {
|
2061 | return cb(err);
|
2062 | }
|
2063 | if (isolationLevel) {
|
2064 | return this.execSqlBatch(new _request.default('SET transaction isolation level ' + this.getIsolationLevelText(isolationLevel), err => {
|
2065 | return cb(err, txDone);
|
2066 | }));
|
2067 | } else {
|
2068 | return cb(null, txDone);
|
2069 | }
|
2070 | }, name);
|
2071 | } else {
|
2072 | return this.beginTransaction(err => {
|
2073 | if (err) {
|
2074 | return cb(err);
|
2075 | }
|
2076 | return cb(null, txDone);
|
2077 | }, name, isolationLevel);
|
2078 | }
|
2079 | }
|
2080 |
|
2081 | /**
|
2082 | * @private
|
2083 | */
|
2084 | makeRequest(request, packetType, payload) {
|
2085 | if (this.state !== this.STATE.LOGGED_IN) {
|
2086 | const message = 'Requests can only be made in the ' + this.STATE.LOGGED_IN.name + ' state, not the ' + this.state.name + ' state';
|
2087 | this.debug.log(message);
|
2088 | request.callback(new _errors.RequestError(message, 'EINVALIDSTATE'));
|
2089 | } else if (request.canceled) {
|
2090 | process.nextTick(() => {
|
2091 | request.callback(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
2092 | });
|
2093 | } else {
|
2094 | if (packetType === _packet.TYPE.SQL_BATCH) {
|
2095 | this.isSqlBatch = true;
|
2096 | } else {
|
2097 | this.isSqlBatch = false;
|
2098 | }
|
2099 | this.request = request;
|
2100 | request.connection = this;
|
2101 | request.rowCount = 0;
|
2102 | request.rows = [];
|
2103 | request.rst = [];
|
2104 | const onCancel = () => {
|
2105 | payloadStream.unpipe(message);
|
2106 | payloadStream.destroy(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
2107 |
|
2108 | // set the ignore bit and end the message.
|
2109 | message.ignore = true;
|
2110 | message.end();
|
2111 | if (request instanceof _request.default && request.paused) {
|
2112 | // resume the request if it was paused so we can read the remaining tokens
|
2113 | request.resume();
|
2114 | }
|
2115 | };
|
2116 | request.once('cancel', onCancel);
|
2117 | this.createRequestTimer();
|
2118 | const message = new _message.default({
|
2119 | type: packetType,
|
2120 | resetConnection: this.resetConnectionOnNextRequest
|
2121 | });
|
2122 | this.messageIo.outgoingMessageStream.write(message);
|
2123 | this.transitionTo(this.STATE.SENT_CLIENT_REQUEST);
|
2124 | message.once('finish', () => {
|
2125 | request.removeListener('cancel', onCancel);
|
2126 | request.once('cancel', this._cancelAfterRequestSent);
|
2127 | this.resetConnectionOnNextRequest = false;
|
2128 | this.debug.payload(function () {
|
2129 | return payload.toString(' ');
|
2130 | });
|
2131 | });
|
2132 | const payloadStream = _stream.Readable.from(payload);
|
2133 | payloadStream.once('error', error => {
|
2134 | payloadStream.unpipe(message);
|
2135 |
|
2136 | // Only set a request error if no error was set yet.
|
2137 | request.error ??= error;
|
2138 | message.ignore = true;
|
2139 | message.end();
|
2140 | });
|
2141 | payloadStream.pipe(message);
|
2142 | }
|
2143 | }
|
2144 |
|
2145 | /**
|
2146 | * Cancel currently executed request.
|
2147 | */
|
2148 | cancel() {
|
2149 | if (!this.request) {
|
2150 | return false;
|
2151 | }
|
2152 | if (this.request.canceled) {
|
2153 | return false;
|
2154 | }
|
2155 | this.request.cancel();
|
2156 | return true;
|
2157 | }
|
2158 |
|
2159 | /**
|
2160 | * Reset the connection to its initial state.
|
2161 | * Can be useful for connection pool implementations.
|
2162 | *
|
2163 | * @param callback
|
2164 | */
|
2165 | reset(callback) {
|
2166 | const request = new _request.default(this.getInitialSql(), err => {
|
2167 | if (this.config.options.tdsVersion < '7_2') {
|
2168 | this.inTransaction = false;
|
2169 | }
|
2170 | callback(err);
|
2171 | });
|
2172 | this.resetConnectionOnNextRequest = true;
|
2173 | this.execSqlBatch(request);
|
2174 | }
|
2175 |
|
2176 | /**
|
2177 | * @private
|
2178 | */
|
2179 | currentTransactionDescriptor() {
|
2180 | return this.transactionDescriptors[this.transactionDescriptors.length - 1];
|
2181 | }
|
2182 |
|
2183 | /**
|
2184 | * @private
|
2185 | */
|
2186 | getIsolationLevelText(isolationLevel) {
|
2187 | switch (isolationLevel) {
|
2188 | case _transaction.ISOLATION_LEVEL.READ_UNCOMMITTED:
|
2189 | return 'read uncommitted';
|
2190 | case _transaction.ISOLATION_LEVEL.REPEATABLE_READ:
|
2191 | return 'repeatable read';
|
2192 | case _transaction.ISOLATION_LEVEL.SERIALIZABLE:
|
2193 | return 'serializable';
|
2194 | case _transaction.ISOLATION_LEVEL.SNAPSHOT:
|
2195 | return 'snapshot';
|
2196 | default:
|
2197 | return 'read committed';
|
2198 | }
|
2199 | }
|
2200 | }
|
2201 | function isTransientError(error) {
|
2202 | if (error instanceof AggregateError) {
|
2203 | error = error.errors[0];
|
2204 | }
|
2205 | return error instanceof _errors.ConnectionError && !!error.isTransient;
|
2206 | }
|
2207 | var _default = exports.default = Connection;
|
2208 | module.exports = Connection;
|
2209 | Connection.prototype.STATE = {
|
2210 | INITIALIZED: {
|
2211 | name: 'Initialized',
|
2212 | events: {}
|
2213 | },
|
2214 | CONNECTING: {
|
2215 | name: 'Connecting',
|
2216 | enter: function () {
|
2217 | this.initialiseConnection();
|
2218 | },
|
2219 | events: {
|
2220 | socketError: function () {
|
2221 | this.transitionTo(this.STATE.FINAL);
|
2222 | },
|
2223 | connectTimeout: function () {
|
2224 | this.transitionTo(this.STATE.FINAL);
|
2225 | }
|
2226 | }
|
2227 | },
|
2228 | SENT_PRELOGIN: {
|
2229 | name: 'SentPrelogin',
|
2230 | enter: function () {
|
2231 | (async () => {
|
2232 | let messageBuffer = Buffer.alloc(0);
|
2233 | let message;
|
2234 | try {
|
2235 | message = await this.messageIo.readMessage();
|
2236 | } catch (err) {
|
2237 | return this.socketError(err);
|
2238 | }
|
2239 | for await (const data of message) {
|
2240 | messageBuffer = Buffer.concat([messageBuffer, data]);
|
2241 | }
|
2242 | const preloginPayload = new _preloginPayload.default(messageBuffer);
|
2243 | this.debug.payload(function () {
|
2244 | return preloginPayload.toString(' ');
|
2245 | });
|
2246 | if (preloginPayload.fedAuthRequired === 1) {
|
2247 | this.fedAuthRequired = true;
|
2248 | }
|
2249 | if ('strict' !== this.config.options.encrypt && (preloginPayload.encryptionString === 'ON' || preloginPayload.encryptionString === 'REQ')) {
|
2250 | if (!this.config.options.encrypt) {
|
2251 | this.emit('connect', new _errors.ConnectionError("Server requires encryption, set 'encrypt' config option to true.", 'EENCRYPT'));
|
2252 | return this.close();
|
2253 | }
|
2254 | try {
|
2255 | this.transitionTo(this.STATE.SENT_TLSSSLNEGOTIATION);
|
2256 | await this.messageIo.startTls(this.secureContextOptions, this.config.options.serverName ? this.config.options.serverName : this.routingData?.server ?? this.config.server, this.config.options.trustServerCertificate);
|
2257 | } catch (err) {
|
2258 | return this.socketError(err);
|
2259 | }
|
2260 | }
|
2261 | this.sendLogin7Packet();
|
2262 | const {
|
2263 | authentication
|
2264 | } = this.config;
|
2265 | switch (authentication.type) {
|
2266 | case 'token-credential':
|
2267 | case 'azure-active-directory-password':
|
2268 | case 'azure-active-directory-msi-vm':
|
2269 | case 'azure-active-directory-msi-app-service':
|
2270 | case 'azure-active-directory-service-principal-secret':
|
2271 | case 'azure-active-directory-default':
|
2272 | this.transitionTo(this.STATE.SENT_LOGIN7_WITH_FEDAUTH);
|
2273 | break;
|
2274 | case 'ntlm':
|
2275 | this.transitionTo(this.STATE.SENT_LOGIN7_WITH_NTLM);
|
2276 | break;
|
2277 | default:
|
2278 | this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);
|
2279 | break;
|
2280 | }
|
2281 | })().catch(err => {
|
2282 | process.nextTick(() => {
|
2283 | throw err;
|
2284 | });
|
2285 | });
|
2286 | },
|
2287 | events: {
|
2288 | socketError: function () {
|
2289 | this.transitionTo(this.STATE.FINAL);
|
2290 | },
|
2291 | connectTimeout: function () {
|
2292 | this.transitionTo(this.STATE.FINAL);
|
2293 | }
|
2294 | }
|
2295 | },
|
2296 | REROUTING: {
|
2297 | name: 'ReRouting',
|
2298 | enter: function () {
|
2299 | this.cleanupConnection(CLEANUP_TYPE.REDIRECT);
|
2300 | },
|
2301 | events: {
|
2302 | message: function () {},
|
2303 | socketError: function () {
|
2304 | this.transitionTo(this.STATE.FINAL);
|
2305 | },
|
2306 | connectTimeout: function () {
|
2307 | this.transitionTo(this.STATE.FINAL);
|
2308 | },
|
2309 | reconnect: function () {
|
2310 | this.transitionTo(this.STATE.CONNECTING);
|
2311 | }
|
2312 | }
|
2313 | },
|
2314 | TRANSIENT_FAILURE_RETRY: {
|
2315 | name: 'TRANSIENT_FAILURE_RETRY',
|
2316 | enter: function () {
|
2317 | this.curTransientRetryCount++;
|
2318 | this.cleanupConnection(CLEANUP_TYPE.RETRY);
|
2319 | },
|
2320 | events: {
|
2321 | message: function () {},
|
2322 | socketError: function () {
|
2323 | this.transitionTo(this.STATE.FINAL);
|
2324 | },
|
2325 | connectTimeout: function () {
|
2326 | this.transitionTo(this.STATE.FINAL);
|
2327 | },
|
2328 | retry: function () {
|
2329 | this.createRetryTimer();
|
2330 | }
|
2331 | }
|
2332 | },
|
2333 | SENT_TLSSSLNEGOTIATION: {
|
2334 | name: 'SentTLSSSLNegotiation',
|
2335 | events: {
|
2336 | socketError: function () {
|
2337 | this.transitionTo(this.STATE.FINAL);
|
2338 | },
|
2339 | connectTimeout: function () {
|
2340 | this.transitionTo(this.STATE.FINAL);
|
2341 | }
|
2342 | }
|
2343 | },
|
2344 | SENT_LOGIN7_WITH_STANDARD_LOGIN: {
|
2345 | name: 'SentLogin7WithStandardLogin',
|
2346 | enter: function () {
|
2347 | (async () => {
|
2348 | let message;
|
2349 | try {
|
2350 | message = await this.messageIo.readMessage();
|
2351 | } catch (err) {
|
2352 | return this.socketError(err);
|
2353 | }
|
2354 | const handler = new _handler.Login7TokenHandler(this);
|
2355 | const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
2356 | await (0, _events.once)(tokenStreamParser, 'end');
|
2357 | if (handler.loginAckReceived) {
|
2358 | if (handler.routingData) {
|
2359 | this.routingData = handler.routingData;
|
2360 | this.transitionTo(this.STATE.REROUTING);
|
2361 | } else {
|
2362 | this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);
|
2363 | }
|
2364 | } else if (this.loginError) {
|
2365 | if (isTransientError(this.loginError)) {
|
2366 | this.debug.log('Initiating retry on transient error');
|
2367 | this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);
|
2368 | } else {
|
2369 | this.emit('connect', this.loginError);
|
2370 | this.transitionTo(this.STATE.FINAL);
|
2371 | }
|
2372 | } else {
|
2373 | this.emit('connect', new _errors.ConnectionError('Login failed.', 'ELOGIN'));
|
2374 | this.transitionTo(this.STATE.FINAL);
|
2375 | }
|
2376 | })().catch(err => {
|
2377 | process.nextTick(() => {
|
2378 | throw err;
|
2379 | });
|
2380 | });
|
2381 | },
|
2382 | events: {
|
2383 | socketError: function () {
|
2384 | this.transitionTo(this.STATE.FINAL);
|
2385 | },
|
2386 | connectTimeout: function () {
|
2387 | this.transitionTo(this.STATE.FINAL);
|
2388 | }
|
2389 | }
|
2390 | },
|
2391 | SENT_LOGIN7_WITH_NTLM: {
|
2392 | name: 'SentLogin7WithNTLMLogin',
|
2393 | enter: function () {
|
2394 | (async () => {
|
2395 | while (true) {
|
2396 | let message;
|
2397 | try {
|
2398 | message = await this.messageIo.readMessage();
|
2399 | } catch (err) {
|
2400 | return this.socketError(err);
|
2401 | }
|
2402 | const handler = new _handler.Login7TokenHandler(this);
|
2403 | const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
2404 | await (0, _events.once)(tokenStreamParser, 'end');
|
2405 | if (handler.loginAckReceived) {
|
2406 | if (handler.routingData) {
|
2407 | this.routingData = handler.routingData;
|
2408 | return this.transitionTo(this.STATE.REROUTING);
|
2409 | } else {
|
2410 | return this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);
|
2411 | }
|
2412 | } else if (this.ntlmpacket) {
|
2413 | const authentication = this.config.authentication;
|
2414 | const payload = new _ntlmPayload.default({
|
2415 | domain: authentication.options.domain,
|
2416 | userName: authentication.options.userName,
|
2417 | password: authentication.options.password,
|
2418 | ntlmpacket: this.ntlmpacket
|
2419 | });
|
2420 | this.messageIo.sendMessage(_packet.TYPE.NTLMAUTH_PKT, payload.data);
|
2421 | this.debug.payload(function () {
|
2422 | return payload.toString(' ');
|
2423 | });
|
2424 | this.ntlmpacket = undefined;
|
2425 | } else if (this.loginError) {
|
2426 | if (isTransientError(this.loginError)) {
|
2427 | this.debug.log('Initiating retry on transient error');
|
2428 | return this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);
|
2429 | } else {
|
2430 | this.emit('connect', this.loginError);
|
2431 | return this.transitionTo(this.STATE.FINAL);
|
2432 | }
|
2433 | } else {
|
2434 | this.emit('connect', new _errors.ConnectionError('Login failed.', 'ELOGIN'));
|
2435 | return this.transitionTo(this.STATE.FINAL);
|
2436 | }
|
2437 | }
|
2438 | })().catch(err => {
|
2439 | process.nextTick(() => {
|
2440 | throw err;
|
2441 | });
|
2442 | });
|
2443 | },
|
2444 | events: {
|
2445 | socketError: function () {
|
2446 | this.transitionTo(this.STATE.FINAL);
|
2447 | },
|
2448 | connectTimeout: function () {
|
2449 | this.transitionTo(this.STATE.FINAL);
|
2450 | }
|
2451 | }
|
2452 | },
|
2453 | SENT_LOGIN7_WITH_FEDAUTH: {
|
2454 | name: 'SentLogin7Withfedauth',
|
2455 | enter: function () {
|
2456 | (async () => {
|
2457 | let message;
|
2458 | try {
|
2459 | message = await this.messageIo.readMessage();
|
2460 | } catch (err) {
|
2461 | return this.socketError(err);
|
2462 | }
|
2463 | const handler = new _handler.Login7TokenHandler(this);
|
2464 | const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
2465 | await (0, _events.once)(tokenStreamParser, 'end');
|
2466 | if (handler.loginAckReceived) {
|
2467 | if (handler.routingData) {
|
2468 | this.routingData = handler.routingData;
|
2469 | this.transitionTo(this.STATE.REROUTING);
|
2470 | } else {
|
2471 | this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);
|
2472 | }
|
2473 | return;
|
2474 | }
|
2475 | const fedAuthInfoToken = handler.fedAuthInfoToken;
|
2476 | if (fedAuthInfoToken && fedAuthInfoToken.stsurl && fedAuthInfoToken.spn) {
|
2477 | /** Federated authentication configation. */
|
2478 | const authentication = this.config.authentication;
|
2479 | /** Permission scope to pass to Entra ID when requesting an authentication token. */
|
2480 | const tokenScope = new _url.URL('/.default', fedAuthInfoToken.spn).toString();
|
2481 |
|
2482 | /** Instance of the token credential to use to authenticate to the resource. */
|
2483 | let credentials;
|
2484 | switch (authentication.type) {
|
2485 | case 'token-credential':
|
2486 | credentials = authentication.options.credential;
|
2487 | break;
|
2488 | case 'azure-active-directory-password':
|
2489 | credentials = new _identity.UsernamePasswordCredential(authentication.options.tenantId ?? 'common', authentication.options.clientId, authentication.options.userName, authentication.options.password);
|
2490 | break;
|
2491 | case 'azure-active-directory-msi-vm':
|
2492 | case 'azure-active-directory-msi-app-service':
|
2493 | const msiArgs = authentication.options.clientId ? [authentication.options.clientId, {}] : [{}];
|
2494 | credentials = new _identity.ManagedIdentityCredential(...msiArgs);
|
2495 | break;
|
2496 | case 'azure-active-directory-default':
|
2497 | const args = authentication.options.clientId ? {
|
2498 | managedIdentityClientId: authentication.options.clientId
|
2499 | } : {};
|
2500 | credentials = new _identity.DefaultAzureCredential(args);
|
2501 | break;
|
2502 | case 'azure-active-directory-service-principal-secret':
|
2503 | credentials = new _identity.ClientSecretCredential(authentication.options.tenantId, authentication.options.clientId, authentication.options.clientSecret);
|
2504 | break;
|
2505 | }
|
2506 |
|
2507 | /** Access token retrieved from Entra ID for the configured permission scope(s). */
|
2508 | let tokenResponse;
|
2509 | try {
|
2510 | tokenResponse = await credentials.getToken(tokenScope);
|
2511 | } catch (err) {
|
2512 | this.loginError = new AggregateError([new _errors.ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH'), err]);
|
2513 | this.emit('connect', this.loginError);
|
2514 | this.transitionTo(this.STATE.FINAL);
|
2515 | return;
|
2516 | }
|
2517 |
|
2518 | // Type guard the token value so that it is never null.
|
2519 | if (tokenResponse === null) {
|
2520 | this.loginError = new AggregateError([new _errors.ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH')]);
|
2521 | this.emit('connect', this.loginError);
|
2522 | this.transitionTo(this.STATE.FINAL);
|
2523 | return;
|
2524 | }
|
2525 | this.sendFedAuthTokenMessage(tokenResponse.token);
|
2526 | } else if (this.loginError) {
|
2527 | if (isTransientError(this.loginError)) {
|
2528 | this.debug.log('Initiating retry on transient error');
|
2529 | this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);
|
2530 | } else {
|
2531 | this.emit('connect', this.loginError);
|
2532 | this.transitionTo(this.STATE.FINAL);
|
2533 | }
|
2534 | } else {
|
2535 | this.emit('connect', new _errors.ConnectionError('Login failed.', 'ELOGIN'));
|
2536 | this.transitionTo(this.STATE.FINAL);
|
2537 | }
|
2538 | })().catch(err => {
|
2539 | process.nextTick(() => {
|
2540 | throw err;
|
2541 | });
|
2542 | });
|
2543 | },
|
2544 | events: {
|
2545 | socketError: function () {
|
2546 | this.transitionTo(this.STATE.FINAL);
|
2547 | },
|
2548 | connectTimeout: function () {
|
2549 | this.transitionTo(this.STATE.FINAL);
|
2550 | }
|
2551 | }
|
2552 | },
|
2553 | LOGGED_IN_SENDING_INITIAL_SQL: {
|
2554 | name: 'LoggedInSendingInitialSql',
|
2555 | enter: function () {
|
2556 | (async () => {
|
2557 | this.sendInitialSql();
|
2558 | let message;
|
2559 | try {
|
2560 | message = await this.messageIo.readMessage();
|
2561 | } catch (err) {
|
2562 | return this.socketError(err);
|
2563 | }
|
2564 | const tokenStreamParser = this.createTokenStreamParser(message, new _handler.InitialSqlTokenHandler(this));
|
2565 | await (0, _events.once)(tokenStreamParser, 'end');
|
2566 | this.transitionTo(this.STATE.LOGGED_IN);
|
2567 | this.processedInitialSql();
|
2568 | })().catch(err => {
|
2569 | process.nextTick(() => {
|
2570 | throw err;
|
2571 | });
|
2572 | });
|
2573 | },
|
2574 | events: {
|
2575 | socketError: function socketError() {
|
2576 | this.transitionTo(this.STATE.FINAL);
|
2577 | },
|
2578 | connectTimeout: function () {
|
2579 | this.transitionTo(this.STATE.FINAL);
|
2580 | }
|
2581 | }
|
2582 | },
|
2583 | LOGGED_IN: {
|
2584 | name: 'LoggedIn',
|
2585 | events: {
|
2586 | socketError: function () {
|
2587 | this.transitionTo(this.STATE.FINAL);
|
2588 | }
|
2589 | }
|
2590 | },
|
2591 | SENT_CLIENT_REQUEST: {
|
2592 | name: 'SentClientRequest',
|
2593 | enter: function () {
|
2594 | (async () => {
|
2595 | let message;
|
2596 | try {
|
2597 | message = await this.messageIo.readMessage();
|
2598 | } catch (err) {
|
2599 | return this.socketError(err);
|
2600 | }
|
2601 | // request timer is stopped on first data package
|
2602 | this.clearRequestTimer();
|
2603 | const tokenStreamParser = this.createTokenStreamParser(message, new _handler.RequestTokenHandler(this, this.request));
|
2604 |
|
2605 | // If the request was canceled and we have a `cancelTimer`
|
2606 | // defined, we send a attention message after the
|
2607 | // request message was fully sent off.
|
2608 | //
|
2609 | // We already started consuming the current message
|
2610 | // (but all the token handlers should be no-ops), and
|
2611 | // need to ensure the next message is handled by the
|
2612 | // `SENT_ATTENTION` state.
|
2613 | if (this.request?.canceled && this.cancelTimer) {
|
2614 | return this.transitionTo(this.STATE.SENT_ATTENTION);
|
2615 | }
|
2616 | const onResume = () => {
|
2617 | tokenStreamParser.resume();
|
2618 | };
|
2619 | const onPause = () => {
|
2620 | tokenStreamParser.pause();
|
2621 | this.request?.once('resume', onResume);
|
2622 | };
|
2623 | this.request?.on('pause', onPause);
|
2624 | if (this.request instanceof _request.default && this.request.paused) {
|
2625 | onPause();
|
2626 | }
|
2627 | const onCancel = () => {
|
2628 | tokenStreamParser.removeListener('end', onEndOfMessage);
|
2629 | if (this.request instanceof _request.default && this.request.paused) {
|
2630 | // resume the request if it was paused so we can read the remaining tokens
|
2631 | this.request.resume();
|
2632 | }
|
2633 | this.request?.removeListener('pause', onPause);
|
2634 | this.request?.removeListener('resume', onResume);
|
2635 |
|
2636 | // The `_cancelAfterRequestSent` callback will have sent a
|
2637 | // attention message, so now we need to also switch to
|
2638 | // the `SENT_ATTENTION` state to make sure the attention ack
|
2639 | // message is processed correctly.
|
2640 | this.transitionTo(this.STATE.SENT_ATTENTION);
|
2641 | };
|
2642 | const onEndOfMessage = () => {
|
2643 | this.request?.removeListener('cancel', this._cancelAfterRequestSent);
|
2644 | this.request?.removeListener('cancel', onCancel);
|
2645 | this.request?.removeListener('pause', onPause);
|
2646 | this.request?.removeListener('resume', onResume);
|
2647 | this.transitionTo(this.STATE.LOGGED_IN);
|
2648 | const sqlRequest = this.request;
|
2649 | this.request = undefined;
|
2650 | if (this.config.options.tdsVersion < '7_2' && sqlRequest.error && this.isSqlBatch) {
|
2651 | this.inTransaction = false;
|
2652 | }
|
2653 | sqlRequest.callback(sqlRequest.error, sqlRequest.rowCount, sqlRequest.rows);
|
2654 | };
|
2655 | tokenStreamParser.once('end', onEndOfMessage);
|
2656 | this.request?.once('cancel', onCancel);
|
2657 | })();
|
2658 | },
|
2659 | exit: function (nextState) {
|
2660 | this.clearRequestTimer();
|
2661 | },
|
2662 | events: {
|
2663 | socketError: function (err) {
|
2664 | const sqlRequest = this.request;
|
2665 | this.request = undefined;
|
2666 | this.transitionTo(this.STATE.FINAL);
|
2667 | sqlRequest.callback(err);
|
2668 | }
|
2669 | }
|
2670 | },
|
2671 | SENT_ATTENTION: {
|
2672 | name: 'SentAttention',
|
2673 | enter: function () {
|
2674 | (async () => {
|
2675 | let message;
|
2676 | try {
|
2677 | message = await this.messageIo.readMessage();
|
2678 | } catch (err) {
|
2679 | return this.socketError(err);
|
2680 | }
|
2681 | const handler = new _handler.AttentionTokenHandler(this, this.request);
|
2682 | const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
2683 | await (0, _events.once)(tokenStreamParser, 'end');
|
2684 | // 3.2.5.7 Sent Attention State
|
2685 | // Discard any data contained in the response, until we receive the attention response
|
2686 | if (handler.attentionReceived) {
|
2687 | this.clearCancelTimer();
|
2688 | const sqlRequest = this.request;
|
2689 | this.request = undefined;
|
2690 | this.transitionTo(this.STATE.LOGGED_IN);
|
2691 | if (sqlRequest.error && sqlRequest.error instanceof _errors.RequestError && sqlRequest.error.code === 'ETIMEOUT') {
|
2692 | sqlRequest.callback(sqlRequest.error);
|
2693 | } else {
|
2694 | sqlRequest.callback(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
2695 | }
|
2696 | }
|
2697 | })().catch(err => {
|
2698 | process.nextTick(() => {
|
2699 | throw err;
|
2700 | });
|
2701 | });
|
2702 | },
|
2703 | events: {
|
2704 | socketError: function (err) {
|
2705 | const sqlRequest = this.request;
|
2706 | this.request = undefined;
|
2707 | this.transitionTo(this.STATE.FINAL);
|
2708 | sqlRequest.callback(err);
|
2709 | }
|
2710 | }
|
2711 | },
|
2712 | FINAL: {
|
2713 | name: 'Final',
|
2714 | enter: function () {
|
2715 | this.cleanupConnection(CLEANUP_TYPE.NORMAL);
|
2716 | },
|
2717 | events: {
|
2718 | connectTimeout: function () {
|
2719 | // Do nothing, as the timer should be cleaned up.
|
2720 | },
|
2721 | message: function () {
|
2722 | // Do nothing
|
2723 | },
|
2724 | socketError: function () {
|
2725 | // Do nothing
|
2726 | }
|
2727 | }
|
2728 | }
|
2729 | };
|
2730 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_crypto","_interopRequireDefault","require","_os","tls","_interopRequireWildcard","net","_dns","_constants","_stream","_identity","_coreAuth","_bulkLoad","_debug","_events","_instanceLookup","_transientErrorLookup","_packet","_preloginPayload","_login7Payload","_ntlmPayload","_request","_rpcrequestPayload","_sqlbatchPayload","_messageIo","_tokenStreamParser","_transaction","_errors","_connector","_library","_tdsVersions","_message","_ntlm","_dataType","_bulkLoadPayload","_specialStoredProcedure","_package","_url","_handler","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","KEEP_ALIVE_INITIAL_DELAY","DEFAULT_CONNECT_TIMEOUT","DEFAULT_CLIENT_REQUEST_TIMEOUT","DEFAULT_CANCEL_TIMEOUT","DEFAULT_CONNECT_RETRY_INTERVAL","DEFAULT_PACKET_SIZE","DEFAULT_TEXTSIZE","DEFAULT_DATEFIRST","DEFAULT_PORT","DEFAULT_TDS_VERSION","DEFAULT_LANGUAGE","DEFAULT_DATEFORMAT","CLEANUP_TYPE","NORMAL","REDIRECT","RETRY","Connection","EventEmitter","_cancelAfterRequestSent","constructor","config","TypeError","server","fedAuthRequired","authentication","undefined","type","options","domain","userName","password","toUpperCase","isTokenCredential","credential","clientId","tenantId","token","clientSecret","abortTransactionOnError","appName","camelCaseColumns","cancelTimeout","columnEncryptionKeyCacheTTL","columnEncryptionSetting","columnNameReplacer","connectionRetryInterval","connectTimeout","connector","connectionIsolationLevel","ISOLATION_LEVEL","READ_COMMITTED","cryptoCredentialsDetails","database","datefirst","dateFormat","debug","data","packet","payload","enableAnsiNull","enableAnsiNullDefault","enableAnsiPadding","enableAnsiWarnings","enableArithAbort","enableConcatNullYieldsNull","enableCursorCloseOnCommit","enableImplicitTransactions","enableNumericRoundabort","enableQuotedIdentifier","encrypt","fallbackToDefaultDb","encryptionKeyStoreProviders","instanceName","isolationLevel","language","localAddress","maxRetriesOnTransientErrors","multiSubnetFailover","packetSize","port","readOnlyIntent","requestTimeout","rowCollectionOnDone","rowCollectionOnRequestCompletion","serverName","serverSupportsColumnEncryption","tdsVersion","textsize","trustedServerNameAE","trustServerCertificate","useColumnNames","useUTC","workstationId","lowerCaseGuids","Error","assertValidIsolationLevel","RangeError","secureContextOptions","secureOptions","create","value","constants","SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS","createDebug","inTransaction","transactionDescriptors","Buffer","from","transactionDepth","isSqlBatch","closed","messageBuffer","alloc","curTransientRetryCount","transientErrorLookup","TransientErrorLookup","state","STATE","INITIALIZED","messageIo","sendMessage","TYPE","ATTENTION","createCancelTimer","connect","connectListener","ConnectionError","name","onConnect","err","removeListener","onError","once","transitionTo","CONNECTING","on","event","listener","emit","args","close","FINAL","initialiseConnection","signal","createConnectTimer","connectOnPort","instanceLookup","timeout","then","process","nextTick","clearConnectTimer","aborted","message","cause","cleanupConnection","cleanupType","clearRequestTimer","clearRetryTimer","closeConnection","request","RequestError","callback","loginError","Debug","createTokenStreamParser","handler","TokenStreamParser","socketHandlingForSendPreLogin","socket","error","socketError","socketClose","socketEnd","setKeepAlive","MessageIO","cleartext","log","sendPreLogin","SENT_PRELOGIN","wrapWithTls","throwIfAborted","Promise","resolve","reject","secureContext","createSecureContext","isIP","encryptOptions","host","ALPNProtocols","servername","encryptsocket","onAbort","destroy","reason","removeEventListener","addEventListener","customConnector","connectOpts","routingData","connectInParallel","connectInSequence","dns","lookup","end","catch","controller","AbortController","connectTimer","setTimeout","abort","clearCancelTimer","cancelTimer","createRequestTimer","requestTimer","createRetryTimer","retryTimer","retryTimeout","hostPostfix","routingMessage","dispatchEvent","cancel","clearTimeout","newState","exit","enter","apply","getEventHandler","eventName","events","SENT_TLSSSLNEGOTIATION","code","REROUTING","TRANSIENT_FAILURE_RETRY","major","minor","build","exec","version","PreloginPayload","Number","subbuild","PRELOGIN","toString","sendLogin7Packet","Login7Payload","versions","clientProgVer","clientPid","pid","connectionId","clientTimeZone","Date","getTimezoneOffset","clientLcid","fedAuth","echo","workflow","fedAuthToken","sspi","createNTLMRequest","hostname","os","libraryName","initDbFatal","LOGIN7","toBuffer","sendFedAuthTokenMessage","accessTokenLen","byteLength","offset","writeUInt32LE","write","FEDAUTH_TOKEN","SENT_LOGIN7_WITH_STANDARD_LOGIN","sendInitialSql","SqlBatchPayload","getInitialSql","currentTransactionDescriptor","Message","SQL_BATCH","outgoingMessageStream","Readable","pipe","push","getIsolationLevelText","join","processedInitialSql","execSqlBatch","makeRequest","sqlTextOrProcedure","execSql","validateParameters","databaseCollation","parameters","TYPES","NVarChar","output","length","precision","scale","makeParamsParameter","RPC_REQUEST","RpcRequestPayload","Procedures","Sp_ExecuteSql","newBulkLoad","table","callbackOrOptions","BulkLoad","execBulkLoad","bulkLoad","rows","executionStarted","streamingMode","firstRowWritten","rowStream","rowToPacketTransform","onCancel","BulkLoadPayload","Request","getBulkInsertSql","BULK_LOAD","prepare","Int","preparing","handle","Sp_Prepare","unprepare","Sp_Unprepare","execute","executeParameters","len","parameter","validate","Sp_Execute","callProcedure","beginTransaction","transaction","Transaction","isolationLevelToTSQL","TRANSACTION_MANAGER","beginPayload","commitTransaction","commitPayload","rollbackTransaction","rollbackPayload","saveTransaction","savePayload","cb","useSavepoint","crypto","randomBytes","txDone","done","LOGGED_IN","txErr","packetType","canceled","connection","rowCount","rst","payloadStream","unpipe","ignore","paused","resume","resetConnection","resetConnectionOnNextRequest","SENT_CLIENT_REQUEST","reset","READ_UNCOMMITTED","REPEATABLE_READ","SERIALIZABLE","SNAPSHOT","isTransientError","AggregateError","errors","isTransient","_default","exports","module","readMessage","concat","preloginPayload","encryptionString","startTls","SENT_LOGIN7_WITH_FEDAUTH","SENT_LOGIN7_WITH_NTLM","reconnect","retry","Login7TokenHandler","tokenStreamParser","loginAckReceived","LOGGED_IN_SENDING_INITIAL_SQL","ntlmpacket","NTLMResponsePayload","NTLMAUTH_PKT","fedAuthInfoToken","stsurl","spn","tokenScope","URL","credentials","UsernamePasswordCredential","msiArgs","ManagedIdentityCredential","managedIdentityClientId","DefaultAzureCredential","ClientSecretCredential","tokenResponse","getToken","InitialSqlTokenHandler","RequestTokenHandler","SENT_ATTENTION","onResume","onPause","pause","onEndOfMessage","sqlRequest","nextState","AttentionTokenHandler","attentionReceived"],"sources":["../src/connection.ts"],"sourcesContent":["import crypto from 'crypto';\nimport os from 'os';\nimport * as tls from 'tls';\nimport * as net from 'net';\nimport dns from 'dns';\n\nimport constants from 'constants';\nimport { type SecureContextOptions } from 'tls';\n\nimport { Readable } from 'stream';\n\nimport {\n  ClientSecretCredential,\n  DefaultAzureCredential,\n  ManagedIdentityCredential,\n  UsernamePasswordCredential\n} from '@azure/identity';\nimport { type AccessToken, type TokenCredential, isTokenCredential } from '@azure/core-auth';\n\nimport BulkLoad, { type Options as BulkLoadOptions, type Callback as BulkLoadCallback } from './bulk-load';\nimport Debug from './debug';\nimport { EventEmitter, once } from 'events';\nimport { instanceLookup } from './instance-lookup';\nimport { TransientErrorLookup } from './transient-error-lookup';\nimport { TYPE } from './packet';\nimport PreloginPayload from './prelogin-payload';\nimport Login7Payload from './login7-payload';\nimport NTLMResponsePayload from './ntlm-payload';\nimport Request from './request';\nimport RpcRequestPayload from './rpcrequest-payload';\nimport SqlBatchPayload from './sqlbatch-payload';\nimport MessageIO from './message-io';\nimport { Parser as TokenStreamParser } from './token/token-stream-parser';\nimport { Transaction, ISOLATION_LEVEL, assertValidIsolationLevel } from './transaction';\nimport { ConnectionError, RequestError } from './errors';\nimport { connectInParallel, connectInSequence } from './connector';\nimport { name as libraryName } from './library';\nimport { versions } from './tds-versions';\nimport Message from './message';\nimport { type Metadata } from './metadata-parser';\nimport { createNTLMRequest } from './ntlm';\nimport { ColumnEncryptionAzureKeyVaultProvider } from './always-encrypted/keystore-provider-azure-key-vault';\n\nimport { type Parameter, TYPES } from './data-type';\nimport { BulkLoadPayload } from './bulk-load-payload';\nimport { Collation } from './collation';\nimport Procedures from './special-stored-procedure';\n\nimport { version } from '../package.json';\nimport { URL } from 'url';\nimport { AttentionTokenHandler, InitialSqlTokenHandler, Login7TokenHandler, RequestTokenHandler, TokenHandler } from './token/handler';\n\ntype BeginTransactionCallback =\n  /**\n   * The callback is called when the request to start the transaction has completed,\n   * either successfully or with an error.\n   * If an error occurred then `err` will describe the error.\n   *\n   * As only one request at a time may be executed on a connection, another request should not\n   * be initiated until this callback is called.\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   * @param transactionDescriptor A Buffer that describe the transaction\n   */\n  (err: Error | null | undefined, transactionDescriptor?: Buffer) => void\n\ntype SaveTransactionCallback =\n  /**\n   * The callback is called when the request to set a savepoint within the\n   * transaction has completed, either successfully or with an error.\n   * If an error occurred then `err` will describe the error.\n   *\n   * As only one request at a time may be executed on a connection, another request should not\n   * be initiated until this callback is called.\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   */\n  (err: Error | null | undefined) => void;\n\ntype CommitTransactionCallback =\n  /**\n   * The callback is called when the request to commit the transaction has completed,\n   * either successfully or with an error.\n   * If an error occurred then `err` will describe the error.\n   *\n   * As only one request at a time may be executed on a connection, another request should not\n   * be initiated until this callback is called.\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   */\n  (err: Error | null | undefined) => void;\n\ntype RollbackTransactionCallback =\n  /**\n   * The callback is called when the request to rollback the transaction has\n   * completed, either successfully or with an error.\n   * If an error occurred then err will describe the error.\n   *\n   * As only one request at a time may be executed on a connection, another request should not\n   * be initiated until this callback is called.\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   */\n  (err: Error | null | undefined) => void;\n\ntype ResetCallback =\n  /**\n   * The callback is called when the connection reset has completed,\n   * either successfully or with an error.\n   *\n   * If an error occurred then `err` will describe the error.\n   *\n   * As only one request at a time may be executed on a connection, another\n   * request should not be initiated until this callback is called\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   */\n  (err: Error | null | undefined) => void;\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\ntype TransactionCallback<T extends (err: Error | null | undefined, ...args: any[]) => void> =\n  /**\n   * The callback is called when the request to start a transaction (or create a savepoint, in\n   * the case of a nested transaction) has completed, either successfully or with an error.\n   * If an error occurred, then `err` will describe the error.\n   * If no error occurred, the callback should perform its work and eventually call\n   * `done` with an error or null (to trigger a transaction rollback or a\n   * transaction commit) and an additional completion callback that will be called when the request\n   * to rollback or commit the current transaction has completed, either successfully or with an error.\n   * Additional arguments given to `done` will be passed through to this callback.\n   *\n   * As only one request at a time may be executed on a connection, another request should not\n   * be initiated until the completion callback is called.\n   *\n   * @param err If an error occurred, an [[Error]] object with details of the error.\n   * @param txDone If no error occurred, a function to be called to commit or rollback the transaction.\n   */\n  (err: Error | null | undefined, txDone?: TransactionDone<T>) => void;\n\ntype TransactionDoneCallback = (err: Error | null | undefined, ...args: any[]) => void;\ntype CallbackParameters<T extends (err: Error | null | undefined, ...args: any[]) => any> = T extends (err: Error | null | undefined, ...args: infer P) => any ? P : never;\n\ntype TransactionDone<T extends (err: Error | null | undefined, ...args: any[]) => void> =\n  /**\n   * If no error occurred, a function to be called to commit or rollback the transaction.\n   *\n   * @param err If an err occurred, a string with details of the error.\n   */\n  (err: Error | null | undefined, done: T, ...args: CallbackParameters<T>) => void;\n\n/**\n * @private\n */\nconst KEEP_ALIVE_INITIAL_DELAY = 30 * 1000;\n/**\n * @private\n */\nconst DEFAULT_CONNECT_TIMEOUT = 15 * 1000;\n/**\n * @private\n */\nconst DEFAULT_CLIENT_REQUEST_TIMEOUT = 15 * 1000;\n/**\n * @private\n */\nconst DEFAULT_CANCEL_TIMEOUT = 5 * 1000;\n/**\n * @private\n */\nconst DEFAULT_CONNECT_RETRY_INTERVAL = 500;\n/**\n * @private\n */\nconst DEFAULT_PACKET_SIZE = 4 * 1024;\n/**\n * @private\n */\nconst DEFAULT_TEXTSIZE = 2147483647;\n/**\n * @private\n */\nconst DEFAULT_DATEFIRST = 7;\n/**\n * @private\n */\nconst DEFAULT_PORT = 1433;\n/**\n * @private\n */\nconst DEFAULT_TDS_VERSION = '7_4';\n/**\n * @private\n */\nconst DEFAULT_LANGUAGE = 'us_english';\n/**\n * @private\n */\nconst DEFAULT_DATEFORMAT = 'mdy';\n\ninterface AzureActiveDirectoryMsiAppServiceAuthentication {\n  type: 'azure-active-directory-msi-app-service';\n  options: {\n    /**\n     * If you user want to connect to an Azure app service using a specific client account\n     * they need to provide `clientId` associate to their created identity.\n     *\n     * This is optional for retrieve token from azure web app service\n     */\n    clientId?: string;\n  };\n}\n\ninterface AzureActiveDirectoryMsiVmAuthentication {\n  type: 'azure-active-directory-msi-vm';\n  options: {\n    /**\n     * If you want to connect using a specific client account\n     * they need to provide `clientId` associated to their created identity.\n     *\n     * This is optional for retrieve a token\n     */\n    clientId?: string;\n  };\n}\n\ninterface AzureActiveDirectoryDefaultAuthentication {\n  type: 'azure-active-directory-default';\n  options: {\n    /**\n     * If you want to connect using a specific client account\n     * they need to provide `clientId` associated to their created identity.\n     *\n     * This is optional for retrieving a token\n     */\n    clientId?: string;\n  };\n}\n\n\ninterface AzureActiveDirectoryAccessTokenAuthentication {\n  type: 'azure-active-directory-access-token';\n  options: {\n    /**\n     * A user need to provide `token` which they retrieved else where\n     * to forming the connection.\n     */\n    token: string;\n  };\n}\n\ninterface AzureActiveDirectoryPasswordAuthentication {\n  type: 'azure-active-directory-password';\n  options: {\n    /**\n     * A user need to provide `userName` associate to their account.\n     */\n    userName: string;\n\n    /**\n     * A user need to provide `password` associate to their account.\n     */\n    password: string;\n\n    /**\n     * A client id to use.\n     */\n    clientId: string;\n\n    /**\n     * Optional parameter for specific Azure tenant ID\n     */\n    tenantId: string;\n  };\n}\n\ninterface AzureActiveDirectoryServicePrincipalSecret {\n  type: 'azure-active-directory-service-principal-secret';\n  options: {\n    /**\n     * Application (`client`) ID from your registered Azure application\n     */\n    clientId: string;\n    /**\n     * The created `client secret` for this registered Azure application\n     */\n    clientSecret: string;\n    /**\n     * Directory (`tenant`) ID from your registered Azure application\n     */\n    tenantId: string;\n  };\n}\n\n/** Structure that defines the options that are necessary to authenticate the Tedious.JS instance with an `@azure/identity` token credential. */\ninterface TokenCredentialAuthentication {\n  /** Unique designator for the type of authentication to be used. */\n  type: 'token-credential';\n  /** Set of configurations that are required or allowed with this authentication type. */\n  options: {\n    /** Credential object used to authenticate to the resource. */\n    credential: TokenCredential;\n  };\n}\n\ninterface NtlmAuthentication {\n  type: 'ntlm';\n  options: {\n    /**\n     * User name from your windows account.\n     */\n    userName: string;\n    /**\n     * Password from your windows account.\n     */\n    password: string;\n    /**\n     * Once you set domain for ntlm authentication type, driver will connect to SQL Server using domain login.\n     *\n     * This is necessary for forming a connection using ntlm type\n     */\n    domain: string;\n  };\n}\n\ninterface DefaultAuthentication {\n  type: 'default';\n  options: {\n    /**\n     * User name to use for sql server login.\n     */\n    userName?: string | undefined;\n    /**\n     * Password to use for sql server login.\n     */\n    password?: string | undefined;\n  };\n}\n\ninterface ErrorWithCode extends Error {\n  code?: string;\n}\n\nexport type ConnectionAuthentication = DefaultAuthentication | NtlmAuthentication | TokenCredentialAuthentication | AzureActiveDirectoryPasswordAuthentication | AzureActiveDirectoryMsiAppServiceAuthentication | AzureActiveDirectoryMsiVmAuthentication | AzureActiveDirectoryAccessTokenAuthentication | AzureActiveDirectoryServicePrincipalSecret | AzureActiveDirectoryDefaultAuthentication;\n\ninterface InternalConnectionConfig {\n  server: string;\n  authentication: ConnectionAuthentication;\n  options: InternalConnectionOptions;\n}\n\nexport interface InternalConnectionOptions {\n  abortTransactionOnError: boolean;\n  appName: undefined | string;\n  camelCaseColumns: boolean;\n  cancelTimeout: number;\n  columnEncryptionKeyCacheTTL: number;\n  columnEncryptionSetting: boolean;\n  columnNameReplacer: undefined | ((colName: string, index: number, metadata: Metadata) => string);\n  connectionRetryInterval: number;\n  connector: undefined | (() => Promise<net.Socket>);\n  connectTimeout: number;\n  connectionIsolationLevel: typeof ISOLATION_LEVEL[keyof typeof ISOLATION_LEVEL];\n  cryptoCredentialsDetails: SecureContextOptions;\n  database: undefined | string;\n  datefirst: number;\n  dateFormat: string;\n  debug: {\n    data: boolean;\n    packet: boolean;\n    payload: boolean;\n    token: boolean;\n  };\n  enableAnsiNull: null | boolean;\n  enableAnsiNullDefault: null | boolean;\n  enableAnsiPadding: null | boolean;\n  enableAnsiWarnings: null | boolean;\n  enableArithAbort: null | boolean;\n  enableConcatNullYieldsNull: null | boolean;\n  enableCursorCloseOnCommit: null | boolean;\n  enableImplicitTransactions: null | boolean;\n  enableNumericRoundabort: null | boolean;\n  enableQuotedIdentifier: null | boolean;\n  encrypt: string | boolean;\n  encryptionKeyStoreProviders: KeyStoreProviderMap | undefined;\n  fallbackToDefaultDb: boolean;\n  instanceName: undefined | string;\n  isolationLevel: typeof ISOLATION_LEVEL[keyof typeof ISOLATION_LEVEL];\n  language: string;\n  localAddress: undefined | string;\n  maxRetriesOnTransientErrors: number;\n  multiSubnetFailover: boolean;\n  packetSize: number;\n  port: undefined | number;\n  readOnlyIntent: boolean;\n  requestTimeout: number;\n  rowCollectionOnDone: boolean;\n  rowCollectionOnRequestCompletion: boolean;\n  serverName: undefined | string;\n  serverSupportsColumnEncryption: boolean;\n  tdsVersion: string;\n  textsize: number;\n  trustedServerNameAE: string | undefined;\n  trustServerCertificate: boolean;\n  useColumnNames: boolean;\n  useUTC: boolean;\n  workstationId: undefined | string;\n  lowerCaseGuids: boolean;\n}\n\ninterface KeyStoreProviderMap {\n  [key: string]: ColumnEncryptionAzureKeyVaultProvider;\n}\n\n/**\n * @private\n */\ninterface State {\n  name: string;\n  enter?(this: Connection): void;\n  exit?(this: Connection, newState: State): void;\n  events: {\n    socketError?(this: Connection, err: Error): void;\n    connectTimeout?(this: Connection): void;\n    message?(this: Connection, message: Message): void;\n    retry?(this: Connection): void;\n    reconnect?(this: Connection): void;\n  };\n}\n\ntype Authentication = DefaultAuthentication |\n  NtlmAuthentication |\n  TokenCredentialAuthentication |\n  AzureActiveDirectoryPasswordAuthentication |\n  AzureActiveDirectoryMsiAppServiceAuthentication |\n  AzureActiveDirectoryMsiVmAuthentication |\n  AzureActiveDirectoryAccessTokenAuthentication |\n  AzureActiveDirectoryServicePrincipalSecret |\n  AzureActiveDirectoryDefaultAuthentication;\n\ntype AuthenticationType = Authentication['type'];\n\nexport interface ConnectionConfiguration {\n  /**\n   * Hostname to connect to.\n   */\n  server: string;\n  /**\n   * Configuration options for forming the connection.\n   */\n  options?: ConnectionOptions;\n  /**\n   * Authentication related options for connection.\n   */\n  authentication?: AuthenticationOptions;\n}\n\ninterface DebugOptions {\n  /**\n   * A boolean, controlling whether [[debug]] events will be emitted with text describing packet data details\n   *\n   * (default: `false`)\n   */\n  data: boolean;\n  /**\n   * A boolean, controlling whether [[debug]] events will be emitted with text describing packet details\n   *\n   * (default: `false`)\n   */\n  packet: boolean;\n  /**\n   * A boolean, controlling whether [[debug]] events will be emitted with text describing packet payload details\n   *\n   * (default: `false`)\n   */\n  payload: boolean;\n  /**\n   * A boolean, controlling whether [[debug]] events will be emitted with text describing token stream tokens\n   *\n   * (default: `false`)\n   */\n  token: boolean;\n}\n\ninterface AuthenticationOptions {\n  /**\n   * Type of the authentication method, valid types are `default`, `ntlm`,\n   * `azure-active-directory-password`, `azure-active-directory-access-token`,\n   * `azure-active-directory-msi-vm`, `azure-active-directory-msi-app-service`,\n   * `azure-active-directory-default`\n   * or `azure-active-directory-service-principal-secret`\n   */\n  type?: AuthenticationType;\n  /**\n   * Different options for authentication types:\n   *\n   * * `default`: [[DefaultAuthentication.options]]\n   * * `ntlm` :[[NtlmAuthentication]]\n   * * `token-credential`: [[CredentialChainAuthentication.options]]\n   * * `azure-active-directory-password` : [[AzureActiveDirectoryPasswordAuthentication.options]]\n   * * `azure-active-directory-access-token` : [[AzureActiveDirectoryAccessTokenAuthentication.options]]\n   * * `azure-active-directory-msi-vm` : [[AzureActiveDirectoryMsiVmAuthentication.options]]\n   * * `azure-active-directory-msi-app-service` : [[AzureActiveDirectoryMsiAppServiceAuthentication.options]]\n   * * `azure-active-directory-service-principal-secret` : [[AzureActiveDirectoryServicePrincipalSecret.options]]\n   * * `azure-active-directory-default` : [[AzureActiveDirectoryDefaultAuthentication.options]]\n   */\n  options?: any;\n}\n\nexport interface ConnectionOptions {\n  /**\n   * A boolean determining whether to rollback a transaction automatically if any error is encountered\n   * during the given transaction's execution. This sets the value for `SET XACT_ABORT` during the\n   * initial SQL phase of a connection [documentation](https://docs.microsoft.com/en-us/sql/t-sql/statements/set-xact-abort-transact-sql).\n   */\n  abortTransactionOnError?: boolean | undefined;\n\n  /**\n   * Application name used for identifying a specific application in profiling, logging or tracing tools of SQLServer.\n   *\n   * (default: `Tedious`)\n   */\n  appName?: string | undefined;\n\n  /**\n   * A boolean, controlling whether the column names returned will have the first letter converted to lower case\n   * (`true`) or not. This value is ignored if you provide a [[columnNameReplacer]].\n   *\n   * (default: `false`).\n   */\n  camelCaseColumns?: boolean;\n\n  /**\n   * The number of milliseconds before the [[Request.cancel]] (abort) of a request is considered failed\n   *\n   * (default: `5000`).\n   */\n  cancelTimeout?: number;\n\n  /**\n   * A function with parameters `(columnName, index, columnMetaData)` and returning a string. If provided,\n   * this will be called once per column per result-set. The returned value will be used instead of the SQL-provided\n   * column name on row and meta data objects. This allows you to dynamically convert between naming conventions.\n   *\n   * (default: `null`)\n   */\n  columnNameReplacer?: (colName: string, index: number, metadata: Metadata) => string;\n\n  /**\n   * Number of milliseconds before retrying to establish connection, in case of transient failure.\n   *\n   * (default:`500`)\n   */\n  connectionRetryInterval?: number;\n\n  /**\n   * Custom connector factory method.\n   *\n   * (default: `undefined`)\n   */\n  connector?: () => Promise<net.Socket>;\n\n  /**\n   * The number of milliseconds before the attempt to connect is considered failed\n   *\n   * (default: `15000`).\n   */\n  connectTimeout?: number;\n\n  /**\n   * The default isolation level for new connections. All out-of-transaction queries are executed with this setting.\n   *\n   * The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.\n   * * `READ_UNCOMMITTED`\n   * * `READ_COMMITTED`\n   * * `REPEATABLE_READ`\n   * * `SERIALIZABLE`\n   * * `SNAPSHOT`\n   *\n   * (default: `READ_COMMITED`).\n   */\n  connectionIsolationLevel?: number;\n\n  /**\n   * When encryption is used, an object may be supplied that will be used\n   * for the first argument when calling [`tls.createSecurePair`](http://nodejs.org/docs/latest/api/tls.html#tls_tls_createsecurepair_credentials_isserver_requestcert_rejectunauthorized)\n   *\n   * (default: `{}`)\n   */\n  cryptoCredentialsDetails?: SecureContextOptions;\n\n  /**\n   * Database to connect to (default: dependent on server configuration).\n   */\n  database?: string | undefined;\n\n  /**\n   * Sets the first day of the week to a number from 1 through 7.\n   */\n  datefirst?: number;\n\n  /**\n   * A string representing position of month, day and year in temporal datatypes.\n   *\n   * (default: `mdy`)\n   */\n  dateFormat?: string;\n\n  debug?: DebugOptions;\n\n  /**\n   * A boolean, controls the way null values should be used during comparison operation.\n   *\n   * (default: `true`)\n   */\n  enableAnsiNull?: boolean;\n\n  /**\n   * If true, `SET ANSI_NULL_DFLT_ON ON` will be set in the initial sql. This means new columns will be\n   * nullable by default. See the [T-SQL documentation](https://msdn.microsoft.com/en-us/library/ms187375.aspx)\n   *\n   * (default: `true`).\n   */\n  enableAnsiNullDefault?: boolean;\n\n  /**\n   * A boolean, controls if padding should be applied for values shorter than the size of defined column.\n   *\n   * (default: `true`)\n   */\n  enableAnsiPadding?: boolean;\n\n  /**\n   * If true, SQL Server will follow ISO standard behavior during various error conditions. For details,\n   * see [documentation](https://docs.microsoft.com/en-us/sql/t-sql/statements/set-ansi-warnings-transact-sql)\n   *\n   * (default: `true`)\n   */\n  enableAnsiWarnings?: boolean;\n\n  /**\n   * Ends a query when an overflow or divide-by-zero error occurs during query execution.\n   * See [documentation](https://docs.microsoft.com/en-us/sql/t-sql/statements/set-arithabort-transact-sql?view=sql-server-2017)\n   * for more details.\n   *\n   * (default: `true`)\n   */\n  enableArithAbort?: boolean;\n\n  /**\n   * A boolean, determines if concatenation with NULL should result in NULL or empty string value, more details in\n   * [documentation](https://docs.microsoft.com/en-us/sql/t-sql/statements/set-concat-null-yields-null-transact-sql)\n   *\n   * (default: `true`)\n   */\n  enableConcatNullYieldsNull?: boolean;\n\n  /**\n   * A boolean, controls whether cursor should be closed, if the transaction opening it gets committed or rolled\n   * back.\n   *\n   * (default: `null`)\n   */\n  enableCursorCloseOnCommit?: boolean | null;\n\n  /**\n   * A boolean, sets the connection to either implicit or autocommit transaction mode.\n   *\n   * (default: `false`)\n   */\n  enableImplicitTransactions?: boolean;\n\n  /**\n   * If false, error is not generated during loss of precession.\n   *\n   * (default: `false`)\n   */\n  enableNumericRoundabort?: boolean;\n\n  /**\n   * If true, characters enclosed in single quotes are treated as literals and those enclosed double quotes are treated as identifiers.\n   *\n   * (default: `true`)\n   */\n  enableQuotedIdentifier?: boolean;\n\n  /**\n   * A string value that can be only set to 'strict', which indicates the usage TDS 8.0 protocol. Otherwise,\n   * a boolean determining whether or not the connection will be encrypted.\n   *\n   * (default: `true`)\n   */\n  encrypt?: string | boolean;\n\n  /**\n   * By default, if the database requested by [[database]] cannot be accessed,\n   * the connection will fail with an error. However, if [[fallbackToDefaultDb]] is\n   * set to `true`, then the user's default database will be used instead\n   *\n   * (default: `false`)\n   */\n  fallbackToDefaultDb?: boolean;\n\n  /**\n   * The instance name to connect to.\n   * The SQL Server Browser service must be running on the database server,\n   * and UDP port 1434 on the database server must be reachable.\n   *\n   * (no default)\n   *\n   * Mutually exclusive with [[port]].\n   */\n  instanceName?: string | undefined;\n\n  /**\n   * The default isolation level that transactions will be run with.\n   *\n   * The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.\n   * * `READ_UNCOMMITTED`\n   * * `READ_COMMITTED`\n   * * `REPEATABLE_READ`\n   * * `SERIALIZABLE`\n   * * `SNAPSHOT`\n   *\n   * (default: `READ_COMMITED`).\n   */\n  isolationLevel?: number;\n\n  /**\n   * Specifies the language environment for the session. The session language determines the datetime formats and system messages.\n   *\n   * (default: `us_english`).\n   */\n  language?: string;\n\n  /**\n   * A string indicating which network interface (ip address) to use when connecting to SQL Server.\n   */\n  localAddress?: string | undefined;\n\n  /**\n   * A boolean determining whether to parse unique identifier type with lowercase case characters.\n   *\n   * (default: `false`).\n   */\n  lowerCaseGuids?: boolean;\n\n  /**\n   * The maximum number of connection retries for transient errors.、\n   *\n   * (default: `3`).\n   */\n  maxRetriesOnTransientErrors?: number;\n\n  /**\n   * Sets the MultiSubnetFailover = True parameter, which can help minimize the client recovery latency when failovers occur.\n   *\n   * (default: `false`).\n   */\n  multiSubnetFailover?: boolean;\n\n  /**\n   * The size of TDS packets (subject to negotiation with the server).\n   * Should be a power of 2.\n   *\n   * (default: `4096`).\n   */\n  packetSize?: number;\n\n  /**\n   * Port to connect to (default: `1433`).\n   *\n   * Mutually exclusive with [[instanceName]]\n   */\n  port?: number | undefined;\n\n  /**\n   * A boolean, determining whether the connection will request read only access from a SQL Server Availability\n   * Group. For more information, see [here](http://msdn.microsoft.com/en-us/library/hh710054.aspx \"Microsoft: Configure Read-Only Routing for an Availability Group (SQL Server)\")\n   *\n   * (default: `false`).\n   */\n  readOnlyIntent?: boolean;\n\n  /**\n   * The number of milliseconds before a request is considered failed, or `0` for no timeout.\n   *\n   * As soon as a response is received, the timeout is cleared. This means that queries that immediately return a response have ability to run longer than this timeout.\n   *\n   * (default: `15000`).\n   */\n  requestTimeout?: number;\n\n  /**\n   * A boolean, that when true will expose received rows in Requests done related events:\n   * * [[Request.Event_doneInProc]]\n   * * [[Request.Event_doneProc]]\n   * * [[Request.Event_done]]\n   *\n   * (default: `false`)\n   *\n   * Caution: If many row are received, enabling this option could result in\n   * excessive memory usage.\n   */\n  rowCollectionOnDone?: boolean;\n\n  /**\n   * A boolean, that when true will expose received rows in Requests' completion callback.See [[Request.constructor]].\n   *\n   * (default: `false`)\n   *\n   * Caution: If many row are received, enabling this option could result in\n   * excessive memory usage.\n   */\n  rowCollectionOnRequestCompletion?: boolean;\n\n  /**\n   * The version of TDS to use. If server doesn't support specified version, negotiated version is used instead.\n   *\n   * The versions are available from `require('tedious').TDS_VERSION`.\n   * * `7_1`\n   * * `7_2`\n   * * `7_3_A`\n   * * `7_3_B`\n   * * `7_4`\n   *\n   * (default: `7_4`)\n   */\n  tdsVersion?: string | undefined;\n\n  /**\n   * Specifies the size of varchar(max), nvarchar(max), varbinary(max), text, ntext, and image data returned by a SELECT statement.\n   *\n   * (default: `2147483647`)\n   */\n  textsize?: number;\n\n  /**\n   * If \"true\", the SQL Server SSL certificate is automatically trusted when the communication layer is encrypted using SSL.\n   *\n   * If \"false\", the SQL Server validates the server SSL certificate. If the server certificate validation fails,\n   * the driver raises an error and terminates the connection. Make sure the value passed to serverName exactly\n   * matches the Common Name (CN) or DNS name in the Subject Alternate Name in the server certificate for an SSL connection to succeed.\n   *\n   * (default: `true`)\n   */\n  trustServerCertificate?: boolean;\n\n  /**\n   *\n   */\n  serverName?: string;\n  /**\n   * A boolean determining whether to return rows as arrays or key-value collections.\n   *\n   * (default: `false`).\n   */\n  useColumnNames?: boolean;\n\n  /**\n   * A boolean determining whether to pass time values in UTC or local time.\n   *\n   * (default: `true`).\n   */\n  useUTC?: boolean;\n\n  /**\n   * The workstation ID (WSID) of the client, default os.hostname().\n   * Used for identifying a specific client in profiling, logging or\n   * tracing client activity in SQLServer.\n   *\n   * The value is reported by the TSQL function HOST_NAME().\n   */\n  workstationId?: string | undefined;\n}\n\n/**\n * @private\n */\nconst CLEANUP_TYPE = {\n  NORMAL: 0,\n  REDIRECT: 1,\n  RETRY: 2\n};\n\ninterface RoutingData {\n  server: string;\n  port: number;\n}\n\n/**\n * A [[Connection]] instance represents a single connection to a database server.\n *\n * ```js\n * var Connection = require('tedious').Connection;\n * var config = {\n *  \"authentication\": {\n *    ...,\n *    \"options\": {...}\n *  },\n *  \"options\": {...}\n * };\n * var connection = new Connection(config);\n * ```\n *\n * Only one request at a time may be executed on a connection. Once a [[Request]]\n * has been initiated (with [[Connection.callProcedure]], [[Connection.execSql]],\n * or [[Connection.execSqlBatch]]), another should not be initiated until the\n * [[Request]]'s completion callback is called.\n */\nclass Connection extends EventEmitter {\n  /**\n   * @private\n   */\n  declare fedAuthRequired: boolean;\n  /**\n   * @private\n   */\n  declare config: InternalConnectionConfig;\n  /**\n   * @private\n   */\n  declare secureContextOptions: SecureContextOptions;\n  /**\n   * @private\n   */\n  declare inTransaction: boolean;\n  /**\n   * @private\n   */\n  declare transactionDescriptors: Buffer[];\n  /**\n   * @private\n   */\n  declare transactionDepth: number;\n  /**\n   * @private\n   */\n  declare isSqlBatch: boolean;\n  /**\n   * @private\n   */\n  declare curTransientRetryCount: number;\n  /**\n   * @private\n   */\n  declare transientErrorLookup: TransientErrorLookup;\n  /**\n   * @private\n   */\n  declare closed: boolean;\n  /**\n   * @private\n   */\n  declare loginError: undefined | AggregateError | ConnectionError;\n  /**\n   * @private\n   */\n  declare debug: Debug;\n  /**\n   * @private\n   */\n  declare ntlmpacket: undefined | any;\n  /**\n   * @private\n   */\n  declare ntlmpacketBuffer: undefined | Buffer;\n\n  /**\n   * @private\n   */\n  declare STATE: {\n    INITIALIZED: State;\n    CONNECTING: State;\n    SENT_PRELOGIN: State;\n    REROUTING: State;\n    TRANSIENT_FAILURE_RETRY: State;\n    SENT_TLSSSLNEGOTIATION: State;\n    SENT_LOGIN7_WITH_STANDARD_LOGIN: State;\n    SENT_LOGIN7_WITH_NTLM: State;\n    SENT_LOGIN7_WITH_FEDAUTH: State;\n    LOGGED_IN_SENDING_INITIAL_SQL: State;\n    LOGGED_IN: State;\n    SENT_CLIENT_REQUEST: State;\n    SENT_ATTENTION: State;\n    FINAL: State;\n  };\n\n  /**\n   * @private\n   */\n  declare routingData: undefined | RoutingData;\n\n  /**\n   * @private\n   */\n  declare messageIo: MessageIO;\n  /**\n   * @private\n   */\n  declare state: State;\n  /**\n   * @private\n   */\n  declare resetConnectionOnNextRequest: undefined | boolean;\n\n  /**\n   * @private\n   */\n  declare request: undefined | Request | BulkLoad;\n  /**\n   * @private\n   */\n  declare procReturnStatusValue: undefined | any;\n  /**\n   * @private\n   */\n  declare socket: undefined | net.Socket;\n  /**\n   * @private\n   */\n  declare messageBuffer: Buffer;\n\n  /**\n   * @private\n   */\n  declare connectTimer: undefined | NodeJS.Timeout;\n  /**\n   * @private\n   */\n  declare cancelTimer: undefined | NodeJS.Timeout;\n  /**\n   * @private\n   */\n  declare requestTimer: undefined | NodeJS.Timeout;\n  /**\n   * @private\n   */\n  declare retryTimer: undefined | NodeJS.Timeout;\n\n  /**\n   * @private\n   */\n  _cancelAfterRequestSent: () => void;\n\n  /**\n   * @private\n   */\n  declare databaseCollation: Collation | undefined;\n\n  /**\n   * Note: be aware of the different options field:\n   * 1. config.authentication.options\n   * 2. config.options\n   *\n   * ```js\n   * const { Connection } = require('tedious');\n   *\n   * const config = {\n   *  \"authentication\": {\n   *    ...,\n   *    \"options\": {...}\n   *  },\n   *  \"options\": {...}\n   * };\n   *\n   * const connection = new Connection(config);\n   * ```\n   *\n   * @param config\n   */\n  constructor(config: ConnectionConfiguration) {\n    super();\n\n    if (typeof config !== 'object' || config === null) {\n      throw new TypeError('The \"config\" argument is required and must be of type Object.');\n    }\n\n    if (typeof config.server !== 'string') {\n      throw new TypeError('The \"config.server\" property is required and must be of type string.');\n    }\n\n    this.fedAuthRequired = false;\n\n    let authentication: ConnectionAuthentication;\n    if (config.authentication !== undefined) {\n      if (typeof config.authentication !== 'object' || config.authentication === null) {\n        throw new TypeError('The \"config.authentication\" property must be of type Object.');\n      }\n\n      const type = config.authentication.type;\n      const options = config.authentication.options === undefined ? {} : config.authentication.options;\n\n      if (typeof type !== 'string') {\n        throw new TypeError('The \"config.authentication.type\" property must be of type string.');\n      }\n\n      if (type !== 'default' && type !== 'ntlm' && type !== 'token-credential' && type !== 'azure-active-directory-password' && type !== 'azure-active-directory-access-token' && type !== 'azure-active-directory-msi-vm' && type !== 'azure-active-directory-msi-app-service' && type !== 'azure-active-directory-service-principal-secret' && type !== 'azure-active-directory-default') {\n        throw new TypeError('The \"type\" property must one of \"default\", \"ntlm\", \"token-credential\", \"azure-active-directory-password\", \"azure-active-directory-access-token\", \"azure-active-directory-default\", \"azure-active-directory-msi-vm\" or \"azure-active-directory-msi-app-service\" or \"azure-active-directory-service-principal-secret\".');\n      }\n\n      if (typeof options !== 'object' || options === null) {\n        throw new TypeError('The \"config.authentication.options\" property must be of type object.');\n      }\n\n      if (type === 'ntlm') {\n        if (typeof options.domain !== 'string') {\n          throw new TypeError('The \"config.authentication.options.domain\" property must be of type string.');\n        }\n\n        if (options.userName !== undefined && typeof options.userName !== 'string') {\n          throw new TypeError('The \"config.authentication.options.userName\" property must be of type string.');\n        }\n\n        if (options.password !== undefined && typeof options.password !== 'string') {\n          throw new TypeError('The \"config.authentication.options.password\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'ntlm',\n          options: {\n            userName: options.userName,\n            password: options.password,\n            domain: options.domain && options.domain.toUpperCase()\n          }\n        };\n      } else if (type === 'token-credential') {\n        if (!isTokenCredential(options.credential)) {\n          throw new TypeError('The \"config.authentication.options.credential\" property must be an instance of the token credential class.');\n        }\n\n        authentication = {\n          type: 'token-credential',\n          options: {\n            credential: options.credential\n          }\n        };\n      } else if (type === 'azure-active-directory-password') {\n        if (typeof options.clientId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientId\" property must be of type string.');\n        }\n\n        if (options.userName !== undefined && typeof options.userName !== 'string') {\n          throw new TypeError('The \"config.authentication.options.userName\" property must be of type string.');\n        }\n\n        if (options.password !== undefined && typeof options.password !== 'string') {\n          throw new TypeError('The \"config.authentication.options.password\" property must be of type string.');\n        }\n\n        if (options.tenantId !== undefined && typeof options.tenantId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.tenantId\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'azure-active-directory-password',\n          options: {\n            userName: options.userName,\n            password: options.password,\n            tenantId: options.tenantId,\n            clientId: options.clientId\n          }\n        };\n      } else if (type === 'azure-active-directory-access-token') {\n        if (typeof options.token !== 'string') {\n          throw new TypeError('The \"config.authentication.options.token\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'azure-active-directory-access-token',\n          options: {\n            token: options.token\n          }\n        };\n      } else if (type === 'azure-active-directory-msi-vm') {\n        if (options.clientId !== undefined && typeof options.clientId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientId\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'azure-active-directory-msi-vm',\n          options: {\n            clientId: options.clientId\n          }\n        };\n      } else if (type === 'azure-active-directory-default') {\n        if (options.clientId !== undefined && typeof options.clientId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientId\" property must be of type string.');\n        }\n        authentication = {\n          type: 'azure-active-directory-default',\n          options: {\n            clientId: options.clientId\n          }\n        };\n      } else if (type === 'azure-active-directory-msi-app-service') {\n        if (options.clientId !== undefined && typeof options.clientId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientId\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'azure-active-directory-msi-app-service',\n          options: {\n            clientId: options.clientId\n          }\n        };\n      } else if (type === 'azure-active-directory-service-principal-secret') {\n        if (typeof options.clientId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientId\" property must be of type string.');\n        }\n\n        if (typeof options.clientSecret !== 'string') {\n          throw new TypeError('The \"config.authentication.options.clientSecret\" property must be of type string.');\n        }\n\n        if (typeof options.tenantId !== 'string') {\n          throw new TypeError('The \"config.authentication.options.tenantId\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'azure-active-directory-service-principal-secret',\n          options: {\n            clientId: options.clientId,\n            clientSecret: options.clientSecret,\n            tenantId: options.tenantId\n          }\n        };\n      } else {\n        if (options.userName !== undefined && typeof options.userName !== 'string') {\n          throw new TypeError('The \"config.authentication.options.userName\" property must be of type string.');\n        }\n\n        if (options.password !== undefined && typeof options.password !== 'string') {\n          throw new TypeError('The \"config.authentication.options.password\" property must be of type string.');\n        }\n\n        authentication = {\n          type: 'default',\n          options: {\n            userName: options.userName,\n            password: options.password\n          }\n        };\n      }\n    } else {\n      authentication = {\n        type: 'default',\n        options: {\n          userName: undefined,\n          password: undefined\n        }\n      };\n    }\n\n    this.config = {\n      server: config.server,\n      authentication: authentication,\n      options: {\n        abortTransactionOnError: false,\n        appName: undefined,\n        camelCaseColumns: false,\n        cancelTimeout: DEFAULT_CANCEL_TIMEOUT,\n        columnEncryptionKeyCacheTTL: 2 * 60 * 60 * 1000,  // Units: milliseconds\n        columnEncryptionSetting: false,\n        columnNameReplacer: undefined,\n        connectionRetryInterval: DEFAULT_CONNECT_RETRY_INTERVAL,\n        connectTimeout: DEFAULT_CONNECT_TIMEOUT,\n        connector: undefined,\n        connectionIsolationLevel: ISOLATION_LEVEL.READ_COMMITTED,\n        cryptoCredentialsDetails: {},\n        database: undefined,\n        datefirst: DEFAULT_DATEFIRST,\n        dateFormat: DEFAULT_DATEFORMAT,\n        debug: {\n          data: false,\n          packet: false,\n          payload: false,\n          token: false\n        },\n        enableAnsiNull: true,\n        enableAnsiNullDefault: true,\n        enableAnsiPadding: true,\n        enableAnsiWarnings: true,\n        enableArithAbort: true,\n        enableConcatNullYieldsNull: true,\n        enableCursorCloseOnCommit: null,\n        enableImplicitTransactions: false,\n        enableNumericRoundabort: false,\n        enableQuotedIdentifier: true,\n        encrypt: true,\n        fallbackToDefaultDb: false,\n        encryptionKeyStoreProviders: undefined,\n        instanceName: undefined,\n        isolationLevel: ISOLATION_LEVEL.READ_COMMITTED,\n        language: DEFAULT_LANGUAGE,\n        localAddress: undefined,\n        maxRetriesOnTransientErrors: 3,\n        multiSubnetFailover: false,\n        packetSize: DEFAULT_PACKET_SIZE,\n        port: DEFAULT_PORT,\n        readOnlyIntent: false,\n        requestTimeout: DEFAULT_CLIENT_REQUEST_TIMEOUT,\n        rowCollectionOnDone: false,\n        rowCollectionOnRequestCompletion: false,\n        serverName: undefined,\n        serverSupportsColumnEncryption: false,\n        tdsVersion: DEFAULT_TDS_VERSION,\n        textsize: DEFAULT_TEXTSIZE,\n        trustedServerNameAE: undefined,\n        trustServerCertificate: false,\n        useColumnNames: false,\n        useUTC: true,\n        workstationId: undefined,\n        lowerCaseGuids: false\n      }\n    };\n\n    if (config.options) {\n      if (config.options.port && config.options.instanceName) {\n        throw new Error('Port and instanceName are mutually exclusive, but ' + config.options.port + ' and ' + config.options.instanceName + ' provided');\n      }\n\n      if (config.options.abortTransactionOnError !== undefined) {\n        if (typeof config.options.abortTransactionOnError !== 'boolean' && config.options.abortTransactionOnError !== null) {\n          throw new TypeError('The \"config.options.abortTransactionOnError\" property must be of type string or null.');\n        }\n\n        this.config.options.abortTransactionOnError = config.options.abortTransactionOnError;\n      }\n\n      if (config.options.appName !== undefined) {\n        if (typeof config.options.appName !== 'string') {\n          throw new TypeError('The \"config.options.appName\" property must be of type string.');\n        }\n\n        this.config.options.appName = config.options.appName;\n      }\n\n      if (config.options.camelCaseColumns !== undefined) {\n        if (typeof config.options.camelCaseColumns !== 'boolean') {\n          throw new TypeError('The \"config.options.camelCaseColumns\" property must be of type boolean.');\n        }\n\n        this.config.options.camelCaseColumns = config.options.camelCaseColumns;\n      }\n\n      if (config.options.cancelTimeout !== undefined) {\n        if (typeof config.options.cancelTimeout !== 'number') {\n          throw new TypeError('The \"config.options.cancelTimeout\" property must be of type number.');\n        }\n\n        this.config.options.cancelTimeout = config.options.cancelTimeout;\n      }\n\n      if (config.options.columnNameReplacer) {\n        if (typeof config.options.columnNameReplacer !== 'function') {\n          throw new TypeError('The \"config.options.cancelTimeout\" property must be of type function.');\n        }\n\n        this.config.options.columnNameReplacer = config.options.columnNameReplacer;\n      }\n\n      if (config.options.connectionIsolationLevel !== undefined) {\n        assertValidIsolationLevel(config.options.connectionIsolationLevel, 'config.options.connectionIsolationLevel');\n\n        this.config.options.connectionIsolationLevel = config.options.connectionIsolationLevel;\n      }\n\n      if (config.options.connectTimeout !== undefined) {\n        if (typeof config.options.connectTimeout !== 'number') {\n          throw new TypeError('The \"config.options.connectTimeout\" property must be of type number.');\n        }\n\n        this.config.options.connectTimeout = config.options.connectTimeout;\n      }\n\n      if (config.options.connector !== undefined) {\n        if (typeof config.options.connector !== 'function') {\n          throw new TypeError('The \"config.options.connector\" property must be a function.');\n        }\n\n        this.config.options.connector = config.options.connector;\n      }\n\n      if (config.options.cryptoCredentialsDetails !== undefined) {\n        if (typeof config.options.cryptoCredentialsDetails !== 'object' || config.options.cryptoCredentialsDetails === null) {\n          throw new TypeError('The \"config.options.cryptoCredentialsDetails\" property must be of type Object.');\n        }\n\n        this.config.options.cryptoCredentialsDetails = config.options.cryptoCredentialsDetails;\n      }\n\n      if (config.options.database !== undefined) {\n        if (typeof config.options.database !== 'string') {\n          throw new TypeError('The \"config.options.database\" property must be of type string.');\n        }\n\n        this.config.options.database = config.options.database;\n      }\n\n      if (config.options.datefirst !== undefined) {\n        if (typeof config.options.datefirst !== 'number' && config.options.datefirst !== null) {\n          throw new TypeError('The \"config.options.datefirst\" property must be of type number.');\n        }\n\n        if (config.options.datefirst !== null && (config.options.datefirst < 1 || config.options.datefirst > 7)) {\n          throw new RangeError('The \"config.options.datefirst\" property must be >= 1 and <= 7');\n        }\n\n        this.config.options.datefirst = config.options.datefirst;\n      }\n\n      if (config.options.dateFormat !== undefined) {\n        if (typeof config.options.dateFormat !== 'string' && config.options.dateFormat !== null) {\n          throw new TypeError('The \"config.options.dateFormat\" property must be of type string or null.');\n        }\n\n        this.config.options.dateFormat = config.options.dateFormat;\n      }\n\n      if (config.options.debug) {\n        if (config.options.debug.data !== undefined) {\n          if (typeof config.options.debug.data !== 'boolean') {\n            throw new TypeError('The \"config.options.debug.data\" property must be of type boolean.');\n          }\n\n          this.config.options.debug.data = config.options.debug.data;\n        }\n\n        if (config.options.debug.packet !== undefined) {\n          if (typeof config.options.debug.packet !== 'boolean') {\n            throw new TypeError('The \"config.options.debug.packet\" property must be of type boolean.');\n          }\n\n          this.config.options.debug.packet = config.options.debug.packet;\n        }\n\n        if (config.options.debug.payload !== undefined) {\n          if (typeof config.options.debug.payload !== 'boolean') {\n            throw new TypeError('The \"config.options.debug.payload\" property must be of type boolean.');\n          }\n\n          this.config.options.debug.payload = config.options.debug.payload;\n        }\n\n        if (config.options.debug.token !== undefined) {\n          if (typeof config.options.debug.token !== 'boolean') {\n            throw new TypeError('The \"config.options.debug.token\" property must be of type boolean.');\n          }\n\n          this.config.options.debug.token = config.options.debug.token;\n        }\n      }\n\n      if (config.options.enableAnsiNull !== undefined) {\n        if (typeof config.options.enableAnsiNull !== 'boolean' && config.options.enableAnsiNull !== null) {\n          throw new TypeError('The \"config.options.enableAnsiNull\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableAnsiNull = config.options.enableAnsiNull;\n      }\n\n      if (config.options.enableAnsiNullDefault !== undefined) {\n        if (typeof config.options.enableAnsiNullDefault !== 'boolean' && config.options.enableAnsiNullDefault !== null) {\n          throw new TypeError('The \"config.options.enableAnsiNullDefault\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableAnsiNullDefault = config.options.enableAnsiNullDefault;\n      }\n\n      if (config.options.enableAnsiPadding !== undefined) {\n        if (typeof config.options.enableAnsiPadding !== 'boolean' && config.options.enableAnsiPadding !== null) {\n          throw new TypeError('The \"config.options.enableAnsiPadding\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableAnsiPadding = config.options.enableAnsiPadding;\n      }\n\n      if (config.options.enableAnsiWarnings !== undefined) {\n        if (typeof config.options.enableAnsiWarnings !== 'boolean' && config.options.enableAnsiWarnings !== null) {\n          throw new TypeError('The \"config.options.enableAnsiWarnings\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableAnsiWarnings = config.options.enableAnsiWarnings;\n      }\n\n      if (config.options.enableArithAbort !== undefined) {\n        if (typeof config.options.enableArithAbort !== 'boolean' && config.options.enableArithAbort !== null) {\n          throw new TypeError('The \"config.options.enableArithAbort\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableArithAbort = config.options.enableArithAbort;\n      }\n\n      if (config.options.enableConcatNullYieldsNull !== undefined) {\n        if (typeof config.options.enableConcatNullYieldsNull !== 'boolean' && config.options.enableConcatNullYieldsNull !== null) {\n          throw new TypeError('The \"config.options.enableConcatNullYieldsNull\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableConcatNullYieldsNull = config.options.enableConcatNullYieldsNull;\n      }\n\n      if (config.options.enableCursorCloseOnCommit !== undefined) {\n        if (typeof config.options.enableCursorCloseOnCommit !== 'boolean' && config.options.enableCursorCloseOnCommit !== null) {\n          throw new TypeError('The \"config.options.enableCursorCloseOnCommit\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableCursorCloseOnCommit = config.options.enableCursorCloseOnCommit;\n      }\n\n      if (config.options.enableImplicitTransactions !== undefined) {\n        if (typeof config.options.enableImplicitTransactions !== 'boolean' && config.options.enableImplicitTransactions !== null) {\n          throw new TypeError('The \"config.options.enableImplicitTransactions\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableImplicitTransactions = config.options.enableImplicitTransactions;\n      }\n\n      if (config.options.enableNumericRoundabort !== undefined) {\n        if (typeof config.options.enableNumericRoundabort !== 'boolean' && config.options.enableNumericRoundabort !== null) {\n          throw new TypeError('The \"config.options.enableNumericRoundabort\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableNumericRoundabort = config.options.enableNumericRoundabort;\n      }\n\n      if (config.options.enableQuotedIdentifier !== undefined) {\n        if (typeof config.options.enableQuotedIdentifier !== 'boolean' && config.options.enableQuotedIdentifier !== null) {\n          throw new TypeError('The \"config.options.enableQuotedIdentifier\" property must be of type boolean or null.');\n        }\n\n        this.config.options.enableQuotedIdentifier = config.options.enableQuotedIdentifier;\n      }\n      if (config.options.encrypt !== undefined) {\n        if (typeof config.options.encrypt !== 'boolean') {\n          if (config.options.encrypt !== 'strict') {\n            throw new TypeError('The \"encrypt\" property must be set to \"strict\", or of type boolean.');\n          }\n        }\n\n        this.config.options.encrypt = config.options.encrypt;\n      }\n\n      if (config.options.fallbackToDefaultDb !== undefined) {\n        if (typeof config.options.fallbackToDefaultDb !== 'boolean') {\n          throw new TypeError('The \"config.options.fallbackToDefaultDb\" property must be of type boolean.');\n        }\n\n        this.config.options.fallbackToDefaultDb = config.options.fallbackToDefaultDb;\n      }\n\n      if (config.options.instanceName !== undefined) {\n        if (typeof config.options.instanceName !== 'string') {\n          throw new TypeError('The \"config.options.instanceName\" property must be of type string.');\n        }\n\n        this.config.options.instanceName = config.options.instanceName;\n        this.config.options.port = undefined;\n      }\n\n      if (config.options.isolationLevel !== undefined) {\n        assertValidIsolationLevel(config.options.isolationLevel, 'config.options.isolationLevel');\n\n        this.config.options.isolationLevel = config.options.isolationLevel;\n      }\n\n      if (config.options.language !== undefined) {\n        if (typeof config.options.language !== 'string' && config.options.language !== null) {\n          throw new TypeError('The \"config.options.language\" property must be of type string or null.');\n        }\n\n        this.config.options.language = config.options.language;\n      }\n\n      if (config.options.localAddress !== undefined) {\n        if (typeof config.options.localAddress !== 'string') {\n          throw new TypeError('The \"config.options.localAddress\" property must be of type string.');\n        }\n\n        this.config.options.localAddress = config.options.localAddress;\n      }\n\n      if (config.options.multiSubnetFailover !== undefined) {\n        if (typeof config.options.multiSubnetFailover !== 'boolean') {\n          throw new TypeError('The \"config.options.multiSubnetFailover\" property must be of type boolean.');\n        }\n\n        this.config.options.multiSubnetFailover = config.options.multiSubnetFailover;\n      }\n\n      if (config.options.packetSize !== undefined) {\n        if (typeof config.options.packetSize !== 'number') {\n          throw new TypeError('The \"config.options.packetSize\" property must be of type number.');\n        }\n\n        this.config.options.packetSize = config.options.packetSize;\n      }\n\n      if (config.options.port !== undefined) {\n        if (typeof config.options.port !== 'number') {\n          throw new TypeError('The \"config.options.port\" property must be of type number.');\n        }\n\n        if (config.options.port <= 0 || config.options.port >= 65536) {\n          throw new RangeError('The \"config.options.port\" property must be > 0 and < 65536');\n        }\n\n        this.config.options.port = config.options.port;\n        this.config.options.instanceName = undefined;\n      }\n\n      if (config.options.readOnlyIntent !== undefined) {\n        if (typeof config.options.readOnlyIntent !== 'boolean') {\n          throw new TypeError('The \"config.options.readOnlyIntent\" property must be of type boolean.');\n        }\n\n        this.config.options.readOnlyIntent = config.options.readOnlyIntent;\n      }\n\n      if (config.options.requestTimeout !== undefined) {\n        if (typeof config.options.requestTimeout !== 'number') {\n          throw new TypeError('The \"config.options.requestTimeout\" property must be of type number.');\n        }\n\n        this.config.options.requestTimeout = config.options.requestTimeout;\n      }\n\n      if (config.options.maxRetriesOnTransientErrors !== undefined) {\n        if (typeof config.options.maxRetriesOnTransientErrors !== 'number') {\n          throw new TypeError('The \"config.options.maxRetriesOnTransientErrors\" property must be of type number.');\n        }\n\n        if (config.options.maxRetriesOnTransientErrors < 0) {\n          throw new TypeError('The \"config.options.maxRetriesOnTransientErrors\" property must be equal or greater than 0.');\n        }\n\n        this.config.options.maxRetriesOnTransientErrors = config.options.maxRetriesOnTransientErrors;\n      }\n\n      if (config.options.connectionRetryInterval !== undefined) {\n        if (typeof config.options.connectionRetryInterval !== 'number') {\n          throw new TypeError('The \"config.options.connectionRetryInterval\" property must be of type number.');\n        }\n\n        if (config.options.connectionRetryInterval <= 0) {\n          throw new TypeError('The \"config.options.connectionRetryInterval\" property must be greater than 0.');\n        }\n\n        this.config.options.connectionRetryInterval = config.options.connectionRetryInterval;\n      }\n\n      if (config.options.rowCollectionOnDone !== undefined) {\n        if (typeof config.options.rowCollectionOnDone !== 'boolean') {\n          throw new TypeError('The \"config.options.rowCollectionOnDone\" property must be of type boolean.');\n        }\n\n        this.config.options.rowCollectionOnDone = config.options.rowCollectionOnDone;\n      }\n\n      if (config.options.rowCollectionOnRequestCompletion !== undefined) {\n        if (typeof config.options.rowCollectionOnRequestCompletion !== 'boolean') {\n          throw new TypeError('The \"config.options.rowCollectionOnRequestCompletion\" property must be of type boolean.');\n        }\n\n        this.config.options.rowCollectionOnRequestCompletion = config.options.rowCollectionOnRequestCompletion;\n      }\n\n      if (config.options.tdsVersion !== undefined) {\n        if (typeof config.options.tdsVersion !== 'string') {\n          throw new TypeError('The \"config.options.tdsVersion\" property must be of type string.');\n        }\n\n        this.config.options.tdsVersion = config.options.tdsVersion;\n      }\n\n      if (config.options.textsize !== undefined) {\n        if (typeof config.options.textsize !== 'number' && config.options.textsize !== null) {\n          throw new TypeError('The \"config.options.textsize\" property must be of type number or null.');\n        }\n\n        if (config.options.textsize > 2147483647) {\n          throw new TypeError('The \"config.options.textsize\" can\\'t be greater than 2147483647.');\n        } else if (config.options.textsize < -1) {\n          throw new TypeError('The \"config.options.textsize\" can\\'t be smaller than -1.');\n        }\n\n        this.config.options.textsize = config.options.textsize | 0;\n      }\n\n      if (config.options.trustServerCertificate !== undefined) {\n        if (typeof config.options.trustServerCertificate !== 'boolean') {\n          throw new TypeError('The \"config.options.trustServerCertificate\" property must be of type boolean.');\n        }\n\n        this.config.options.trustServerCertificate = config.options.trustServerCertificate;\n      }\n\n      if (config.options.serverName !== undefined) {\n        if (typeof config.options.serverName !== 'string') {\n          throw new TypeError('The \"config.options.serverName\" property must be of type string.');\n        }\n        this.config.options.serverName = config.options.serverName;\n      }\n\n      if (config.options.useColumnNames !== undefined) {\n        if (typeof config.options.useColumnNames !== 'boolean') {\n          throw new TypeError('The \"config.options.useColumnNames\" property must be of type boolean.');\n        }\n\n        this.config.options.useColumnNames = config.options.useColumnNames;\n      }\n\n      if (config.options.useUTC !== undefined) {\n        if (typeof config.options.useUTC !== 'boolean') {\n          throw new TypeError('The \"config.options.useUTC\" property must be of type boolean.');\n        }\n\n        this.config.options.useUTC = config.options.useUTC;\n      }\n\n      if (config.options.workstationId !== undefined) {\n        if (typeof config.options.workstationId !== 'string') {\n          throw new TypeError('The \"config.options.workstationId\" property must be of type string.');\n        }\n\n        this.config.options.workstationId = config.options.workstationId;\n      }\n\n      if (config.options.lowerCaseGuids !== undefined) {\n        if (typeof config.options.lowerCaseGuids !== 'boolean') {\n          throw new TypeError('The \"config.options.lowerCaseGuids\" property must be of type boolean.');\n        }\n\n        this.config.options.lowerCaseGuids = config.options.lowerCaseGuids;\n      }\n    }\n\n    this.secureContextOptions = this.config.options.cryptoCredentialsDetails;\n    if (this.secureContextOptions.secureOptions === undefined) {\n      // If the caller has not specified their own `secureOptions`,\n      // we set `SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS` here.\n      // Older SQL Server instances running on older Windows versions have\n      // trouble with the BEAST workaround in OpenSSL.\n      // As BEAST is a browser specific exploit, we can just disable this option here.\n      this.secureContextOptions = Object.create(this.secureContextOptions, {\n        secureOptions: {\n          value: constants.SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS\n        }\n      });\n    }\n\n    this.debug = this.createDebug();\n    this.inTransaction = false;\n    this.transactionDescriptors = [Buffer.from([0, 0, 0, 0, 0, 0, 0, 0])];\n\n    // 'beginTransaction', 'commitTransaction' and 'rollbackTransaction'\n    // events are utilized to maintain inTransaction property state which in\n    // turn is used in managing transactions. These events are only fired for\n    // TDS version 7.2 and beyond. The properties below are used to emulate\n    // equivalent behavior for TDS versions before 7.2.\n    this.transactionDepth = 0;\n    this.isSqlBatch = false;\n    this.closed = false;\n    this.messageBuffer = Buffer.alloc(0);\n\n    this.curTransientRetryCount = 0;\n    this.transientErrorLookup = new TransientErrorLookup();\n\n    this.state = this.STATE.INITIALIZED;\n\n    this._cancelAfterRequestSent = () => {\n      this.messageIo.sendMessage(TYPE.ATTENTION);\n      this.createCancelTimer();\n    };\n  }\n\n  connect(connectListener?: (err?: Error) => void) {\n    if (this.state !== this.STATE.INITIALIZED) {\n      throw new ConnectionError('`.connect` can not be called on a Connection in `' + this.state.name + '` state.');\n    }\n\n    if (connectListener) {\n      const onConnect = (err?: Error) => {\n        this.removeListener('error', onError);\n        connectListener(err);\n      };\n\n      const onError = (err: Error) => {\n        this.removeListener('connect', onConnect);\n        connectListener(err);\n      };\n\n      this.once('connect', onConnect);\n      this.once('error', onError);\n    }\n\n    this.transitionTo(this.STATE.CONNECTING);\n  }\n\n  /**\n   * The server has reported that the charset has changed.\n   */\n  on(event: 'charsetChange', listener: (charset: string) => void): this\n\n  /**\n   * The attempt to connect and validate has completed.\n   */\n  on(\n    event: 'connect',\n    /**\n     * @param err If successfully connected, will be falsey. If there was a\n     *   problem (with either connecting or validation), will be an [[Error]] object.\n     */\n    listener: (err: Error | undefined) => void\n  ): this\n\n  /**\n   * The server has reported that the active database has changed.\n   * This may be as a result of a successful login, or a `use` statement.\n   */\n  on(event: 'databaseChange', listener: (databaseName: string) => void): this\n\n  /**\n   * A debug message is available. It may be logged or ignored.\n   */\n  on(event: 'debug', listener: (messageText: string) => void): this\n\n  /**\n   * Internal error occurs.\n   */\n  on(event: 'error', listener: (err: Error) => void): this\n\n  /**\n   * The server has issued an error message.\n   */\n  on(event: 'errorMessage', listener: (message: import('./token/token').ErrorMessageToken) => void): this\n\n  /**\n   * The connection has ended.\n   *\n   * This may be as a result of the client calling [[close]], the server\n   * closing the connection, or a network error.\n   */\n  on(event: 'end', listener: () => void): this\n\n  /**\n   * The server has issued an information message.\n   */\n  on(event: 'infoMessage', listener: (message: import('./token/token').InfoMessageToken) => void): this\n\n  /**\n   * The server has reported that the language has changed.\n   */\n  on(event: 'languageChange', listener: (languageName: string) => void): this\n\n  /**\n   * The connection was reset.\n   */\n  on(event: 'resetConnection', listener: () => void): this\n\n  /**\n   * A secure connection has been established.\n   */\n  on(event: 'secure', listener: (cleartext: import('tls').TLSSocket) => void): this\n\n  on(event: string | symbol, listener: (...args: any[]) => void) {\n    return super.on(event, listener);\n  }\n\n  /**\n   * @private\n   */\n  emit(event: 'charsetChange', charset: string): boolean\n  /**\n   * @private\n   */\n  emit(event: 'connect', error?: Error): boolean\n  /**\n   * @private\n   */\n  emit(event: 'databaseChange', databaseName: string): boolean\n  /**\n   * @private\n   */\n  emit(event: 'debug', messageText: string): boolean\n  /**\n   * @private\n   */\n  emit(event: 'error', error: Error): boolean\n  /**\n   * @private\n   */\n  emit(event: 'errorMessage', message: import('./token/token').ErrorMessageToken): boolean\n  /**\n   * @private\n   */\n  emit(event: 'end'): boolean\n  /**\n   * @private\n   */\n  emit(event: 'infoMessage', message: import('./token/token').InfoMessageToken): boolean\n  /**\n   * @private\n   */\n  emit(event: 'languageChange', languageName: string): boolean\n  /**\n   * @private\n   */\n  emit(event: 'secure', cleartext: import('tls').TLSSocket): boolean\n  /**\n   * @private\n   */\n  emit(event: 'rerouting'): boolean\n  /**\n   * @private\n   */\n  emit(event: 'resetConnection'): boolean\n  /**\n   * @private\n   */\n  emit(event: 'retry'): boolean\n  /**\n   * @private\n   */\n  emit(event: 'rollbackTransaction'): boolean\n\n  emit(event: string | symbol, ...args: any[]) {\n    return super.emit(event, ...args);\n  }\n\n  /**\n   * Closes the connection to the database.\n   *\n   * The [[Event_end]] will be emitted once the connection has been closed.\n   */\n  close() {\n    this.transitionTo(this.STATE.FINAL);\n  }\n\n  /**\n   * @private\n   */\n  initialiseConnection() {\n    const signal = this.createConnectTimer();\n\n    if (this.config.options.port) {\n      return this.connectOnPort(this.config.options.port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);\n    } else {\n      return instanceLookup({\n        server: this.config.server,\n        instanceName: this.config.options.instanceName!,\n        timeout: this.config.options.connectTimeout,\n        signal: signal\n      }).then((port) => {\n        process.nextTick(() => {\n          this.connectOnPort(port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);\n        });\n      }, (err) => {\n        this.clearConnectTimer();\n\n        if (signal.aborted) {\n          // Ignore the AbortError for now, this is still handled by the connectTimer firing\n          return;\n        }\n\n        process.nextTick(() => {\n          this.emit('connect', new ConnectionError(err.message, 'EINSTLOOKUP', { cause: err }));\n        });\n      });\n    }\n  }\n\n  /**\n   * @private\n   */\n  cleanupConnection(cleanupType: typeof CLEANUP_TYPE[keyof typeof CLEANUP_TYPE]) {\n    if (!this.closed) {\n      this.clearConnectTimer();\n      this.clearRequestTimer();\n      this.clearRetryTimer();\n      this.closeConnection();\n      if (cleanupType === CLEANUP_TYPE.REDIRECT) {\n        this.emit('rerouting');\n      } else if (cleanupType !== CLEANUP_TYPE.RETRY) {\n        process.nextTick(() => {\n          this.emit('end');\n        });\n      }\n\n      const request = this.request;\n      if (request) {\n        const err = new RequestError('Connection closed before request completed.', 'ECLOSE');\n        request.callback(err);\n        this.request = undefined;\n      }\n\n      this.closed = true;\n      this.loginError = undefined;\n    }\n  }\n\n  /**\n   * @private\n   */\n  createDebug() {\n    const debug = new Debug(this.config.options.debug);\n    debug.on('debug', (message) => {\n      this.emit('debug', message);\n    });\n    return debug;\n  }\n\n  /**\n   * @private\n   */\n  createTokenStreamParser(message: Message, handler: TokenHandler) {\n    return new TokenStreamParser(message, this.debug, handler, this.config.options);\n  }\n\n  socketHandlingForSendPreLogin(socket: net.Socket) {\n    socket.on('error', (error) => { this.socketError(error); });\n    socket.on('close', () => { this.socketClose(); });\n    socket.on('end', () => { this.socketEnd(); });\n    socket.setKeepAlive(true, KEEP_ALIVE_INITIAL_DELAY);\n\n    this.messageIo = new MessageIO(socket, this.config.options.packetSize, this.debug);\n    this.messageIo.on('secure', (cleartext) => { this.emit('secure', cleartext); });\n\n    this.socket = socket;\n\n    this.closed = false;\n    this.debug.log('connected to ' + this.config.server + ':' + this.config.options.port);\n\n    this.sendPreLogin();\n    this.transitionTo(this.STATE.SENT_PRELOGIN);\n  }\n\n  wrapWithTls(socket: net.Socket, signal: AbortSignal): Promise<tls.TLSSocket> {\n    signal.throwIfAborted();\n\n    return new Promise((resolve, reject) => {\n      const secureContext = tls.createSecureContext(this.secureContextOptions);\n      // If connect to an ip address directly,\n      // need to set the servername to an empty string\n      // if the user has not given a servername explicitly\n      const serverName = !net.isIP(this.config.server) ? this.config.server : '';\n      const encryptOptions = {\n        host: this.config.server,\n        socket: socket,\n        ALPNProtocols: ['tds/8.0'],\n        secureContext: secureContext,\n        servername: this.config.options.serverName ? this.config.options.serverName : serverName,\n      };\n\n      const encryptsocket = tls.connect(encryptOptions);\n\n      const onAbort = () => {\n        encryptsocket.removeListener('error', onError);\n        encryptsocket.removeListener('connect', onConnect);\n\n        encryptsocket.destroy();\n\n        reject(signal.reason);\n      };\n\n      const onError = (err: Error) => {\n        signal.removeEventListener('abort', onAbort);\n\n        encryptsocket.removeListener('error', onError);\n        encryptsocket.removeListener('connect', onConnect);\n\n        encryptsocket.destroy();\n\n        reject(err);\n      };\n\n      const onConnect = () => {\n        signal.removeEventListener('abort', onAbort);\n\n        encryptsocket.removeListener('error', onError);\n        encryptsocket.removeListener('connect', onConnect);\n\n        resolve(encryptsocket);\n      };\n\n      signal.addEventListener('abort', onAbort, { once: true });\n\n      encryptsocket.on('error', onError);\n      encryptsocket.on('secureConnect', onConnect);\n    });\n  }\n\n  connectOnPort(port: number, multiSubnetFailover: boolean, signal: AbortSignal, customConnector?: () => Promise<net.Socket>) {\n    const connectOpts = {\n      host: this.routingData ? this.routingData.server : this.config.server,\n      port: this.routingData ? this.routingData.port : port,\n      localAddress: this.config.options.localAddress\n    };\n\n    const connect = customConnector || (multiSubnetFailover ? connectInParallel : connectInSequence);\n\n    (async () => {\n      let socket = await connect(connectOpts, dns.lookup, signal);\n\n      if (this.config.options.encrypt === 'strict') {\n        try {\n          // Wrap the socket with TLS for TDS 8.0\n          socket = await this.wrapWithTls(socket, signal);\n        } catch (err) {\n          socket.end();\n\n          throw err;\n        }\n      }\n\n      this.socketHandlingForSendPreLogin(socket);\n    })().catch((err) => {\n      this.clearConnectTimer();\n\n      if (signal.aborted) {\n        return;\n      }\n\n      process.nextTick(() => { this.socketError(err); });\n    });\n  }\n\n  /**\n   * @private\n   */\n  closeConnection() {\n    if (this.socket) {\n      this.socket.destroy();\n    }\n  }\n\n  /**\n   * @private\n   */\n  createConnectTimer() {\n    const controller = new AbortController();\n    this.connectTimer = setTimeout(() => {\n      controller.abort();\n      this.connectTimeout();\n    }, this.config.options.connectTimeout);\n    return controller.signal;\n  }\n\n  /**\n   * @private\n   */\n  createCancelTimer() {\n    this.clearCancelTimer();\n    const timeout = this.config.options.cancelTimeout;\n    if (timeout > 0) {\n      this.cancelTimer = setTimeout(() => {\n        this.cancelTimeout();\n      }, timeout);\n    }\n  }\n\n  /**\n   * @private\n   */\n  createRequestTimer() {\n    this.clearRequestTimer(); // release old timer, just to be safe\n    const request = this.request as Request;\n    const timeout = (request.timeout !== undefined) ? request.timeout : this.config.options.requestTimeout;\n    if (timeout) {\n      this.requestTimer = setTimeout(() => {\n        this.requestTimeout();\n      }, timeout);\n    }\n  }\n\n  /**\n   * @private\n   */\n  createRetryTimer() {\n    this.clearRetryTimer();\n    this.retryTimer = setTimeout(() => {\n      this.retryTimeout();\n    }, this.config.options.connectionRetryInterval);\n  }\n\n  /**\n   * @private\n   */\n  connectTimeout() {\n    const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\\\${this.config.options.instanceName}`;\n    // If we have routing data stored, this connection has been redirected\n    const server = this.routingData ? this.routingData.server : this.config.server;\n    const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;\n    // Grab the target host from the connection configuration, and from a redirect message\n    // otherwise, leave the message empty.\n    const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';\n    const message = `Failed to connect to ${server}${port}${routingMessage} in ${this.config.options.connectTimeout}ms`;\n    this.debug.log(message);\n    this.emit('connect', new ConnectionError(message, 'ETIMEOUT'));\n    this.connectTimer = undefined;\n    this.dispatchEvent('connectTimeout');\n  }\n\n  /**\n   * @private\n   */\n  cancelTimeout() {\n    const message = `Failed to cancel request in ${this.config.options.cancelTimeout}ms`;\n    this.debug.log(message);\n    this.dispatchEvent('socketError', new ConnectionError(message, 'ETIMEOUT'));\n  }\n\n  /**\n   * @private\n   */\n  requestTimeout() {\n    this.requestTimer = undefined;\n    const request = this.request!;\n    request.cancel();\n    const timeout = (request.timeout !== undefined) ? request.timeout : this.config.options.requestTimeout;\n    const message = 'Timeout: Request failed to complete in ' + timeout + 'ms';\n    request.error = new RequestError(message, 'ETIMEOUT');\n  }\n\n  /**\n   * @private\n   */\n  retryTimeout() {\n    this.retryTimer = undefined;\n    this.emit('retry');\n    this.transitionTo(this.STATE.CONNECTING);\n  }\n\n  /**\n   * @private\n   */\n  clearConnectTimer() {\n    if (this.connectTimer) {\n      clearTimeout(this.connectTimer);\n      this.connectTimer = undefined;\n    }\n  }\n\n  /**\n   * @private\n   */\n  clearCancelTimer() {\n    if (this.cancelTimer) {\n      clearTimeout(this.cancelTimer);\n      this.cancelTimer = undefined;\n    }\n  }\n\n  /**\n   * @private\n   */\n  clearRequestTimer() {\n    if (this.requestTimer) {\n      clearTimeout(this.requestTimer);\n      this.requestTimer = undefined;\n    }\n  }\n\n  /**\n   * @private\n   */\n  clearRetryTimer() {\n    if (this.retryTimer) {\n      clearTimeout(this.retryTimer);\n      this.retryTimer = undefined;\n    }\n  }\n\n  /**\n   * @private\n   */\n  transitionTo(newState: State) {\n    if (this.state === newState) {\n      this.debug.log('State is already ' + newState.name);\n      return;\n    }\n\n    if (this.state && this.state.exit) {\n      this.state.exit.call(this, newState);\n    }\n\n    this.debug.log('State change: ' + (this.state ? this.state.name : 'undefined') + ' -> ' + newState.name);\n    this.state = newState;\n\n    if (this.state.enter) {\n      this.state.enter.apply(this);\n    }\n  }\n\n  /**\n   * @private\n   */\n  getEventHandler<T extends keyof State['events']>(eventName: T): NonNullable<State['events'][T]> {\n    const handler = this.state.events[eventName];\n\n    if (!handler) {\n      throw new Error(`No event '${eventName}' in state '${this.state.name}'`);\n    }\n\n    return handler!;\n  }\n\n  /**\n   * @private\n   */\n  dispatchEvent<T extends keyof State['events']>(eventName: T, ...args: Parameters<NonNullable<State['events'][T]>>) {\n    const handler = this.state.events[eventName] as ((this: Connection, ...args: any[]) => void) | undefined;\n    if (handler) {\n      handler.apply(this, args);\n    } else {\n      this.emit('error', new Error(`No event '${eventName}' in state '${this.state.name}'`));\n      this.close();\n    }\n  }\n\n  /**\n   * @private\n   */\n  socketError(error: Error) {\n    if (this.state === this.STATE.CONNECTING || this.state === this.STATE.SENT_TLSSSLNEGOTIATION) {\n      const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\\\${this.config.options.instanceName}`;\n      // If we have routing data stored, this connection has been redirected\n      const server = this.routingData ? this.routingData.server : this.config.server;\n      const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;\n      // Grab the target host from the connection configuration, and from a redirect message\n      // otherwise, leave the message empty.\n      const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';\n      const message = `Failed to connect to ${server}${port}${routingMessage} - ${error.message}`;\n      this.debug.log(message);\n      this.emit('connect', new ConnectionError(message, 'ESOCKET', { cause: error }));\n    } else {\n      const message = `Connection lost - ${error.message}`;\n      this.debug.log(message);\n      this.emit('error', new ConnectionError(message, 'ESOCKET', { cause: error }));\n    }\n    this.dispatchEvent('socketError', error);\n  }\n\n  /**\n   * @private\n   */\n  socketEnd() {\n    this.debug.log('socket ended');\n    if (this.state !== this.STATE.FINAL) {\n      const error: ErrorWithCode = new Error('socket hang up');\n      error.code = 'ECONNRESET';\n      this.socketError(error);\n    }\n  }\n\n  /**\n   * @private\n   */\n  socketClose() {\n    this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');\n    if (this.state === this.STATE.REROUTING) {\n      this.debug.log('Rerouting to ' + this.routingData!.server + ':' + this.routingData!.port);\n\n      this.dispatchEvent('reconnect');\n    } else if (this.state === this.STATE.TRANSIENT_FAILURE_RETRY) {\n      const server = this.routingData ? this.routingData.server : this.config.server;\n      const port = this.routingData ? this.routingData.port : this.config.options.port;\n      this.debug.log('Retry after transient failure connecting to ' + server + ':' + port);\n\n      this.dispatchEvent('retry');\n    } else {\n      this.transitionTo(this.STATE.FINAL);\n    }\n  }\n\n  /**\n   * @private\n   */\n  sendPreLogin() {\n    const [, major, minor, build] = /^(\\d+)\\.(\\d+)\\.(\\d+)/.exec(version) ?? ['0.0.0', '0', '0', '0'];\n    const payload = new PreloginPayload({\n      // If encrypt setting is set to 'strict', then we should have already done the encryption before calling\n      // this function. Therefore, the encrypt will be set to false here.\n      // Otherwise, we will set encrypt here based on the encrypt Boolean value from the configuration.\n      encrypt: typeof this.config.options.encrypt === 'boolean' && this.config.options.encrypt,\n      version: { major: Number(major), minor: Number(minor), build: Number(build), subbuild: 0 }\n    });\n\n    this.messageIo.sendMessage(TYPE.PRELOGIN, payload.data);\n    this.debug.payload(function() {\n      return payload.toString('  ');\n    });\n  }\n\n  /**\n   * @private\n   */\n  sendLogin7Packet() {\n    const payload = new Login7Payload({\n      tdsVersion: versions[this.config.options.tdsVersion],\n      packetSize: this.config.options.packetSize,\n      clientProgVer: 0,\n      clientPid: process.pid,\n      connectionId: 0,\n      clientTimeZone: new Date().getTimezoneOffset(),\n      clientLcid: 0x00000409\n    });\n\n    const { authentication } = this.config;\n    switch (authentication.type) {\n      case 'azure-active-directory-password':\n        payload.fedAuth = {\n          type: 'ADAL',\n          echo: this.fedAuthRequired,\n          workflow: 'default'\n        };\n        break;\n\n      case 'azure-active-directory-access-token':\n        payload.fedAuth = {\n          type: 'SECURITYTOKEN',\n          echo: this.fedAuthRequired,\n          fedAuthToken: authentication.options.token\n        };\n        break;\n\n      case 'token-credential':\n      case 'azure-active-directory-msi-vm':\n      case 'azure-active-directory-default':\n      case 'azure-active-directory-msi-app-service':\n      case 'azure-active-directory-service-principal-secret':\n        payload.fedAuth = {\n          type: 'ADAL',\n          echo: this.fedAuthRequired,\n          workflow: 'integrated'\n        };\n        break;\n\n      case 'ntlm':\n        payload.sspi = createNTLMRequest({ domain: authentication.options.domain });\n        break;\n\n      default:\n        payload.userName = authentication.options.userName;\n        payload.password = authentication.options.password;\n    }\n\n    payload.hostname = this.config.options.workstationId || os.hostname();\n    payload.serverName = this.routingData ? this.routingData.server : this.config.server;\n    payload.appName = this.config.options.appName || 'Tedious';\n    payload.libraryName = libraryName;\n    payload.language = this.config.options.language;\n    payload.database = this.config.options.database;\n    payload.clientId = Buffer.from([1, 2, 3, 4, 5, 6]);\n\n    payload.readOnlyIntent = this.config.options.readOnlyIntent;\n    payload.initDbFatal = !this.config.options.fallbackToDefaultDb;\n\n    this.routingData = undefined;\n    this.messageIo.sendMessage(TYPE.LOGIN7, payload.toBuffer());\n\n    this.debug.payload(function() {\n      return payload.toString('  ');\n    });\n  }\n\n  /**\n   * @private\n   */\n  sendFedAuthTokenMessage(token: string) {\n    const accessTokenLen = Buffer.byteLength(token, 'ucs2');\n    const data = Buffer.alloc(8 + accessTokenLen);\n    let offset = 0;\n    offset = data.writeUInt32LE(accessTokenLen + 4, offset);\n    offset = data.writeUInt32LE(accessTokenLen, offset);\n    data.write(token, offset, 'ucs2');\n    this.messageIo.sendMessage(TYPE.FEDAUTH_TOKEN, data);\n    // sent the fedAuth token message, the rest is similar to standard login 7\n    this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);\n  }\n\n  /**\n   * @private\n   */\n  sendInitialSql() {\n    const payload = new SqlBatchPayload(this.getInitialSql(), this.currentTransactionDescriptor(), this.config.options);\n\n    const message = new Message({ type: TYPE.SQL_BATCH });\n    this.messageIo.outgoingMessageStream.write(message);\n    Readable.from(payload).pipe(message);\n  }\n\n  /**\n   * @private\n   */\n  getInitialSql() {\n    const options = [];\n\n    if (this.config.options.enableAnsiNull === true) {\n      options.push('set ansi_nulls on');\n    } else if (this.config.options.enableAnsiNull === false) {\n      options.push('set ansi_nulls off');\n    }\n\n    if (this.config.options.enableAnsiNullDefault === true) {\n      options.push('set ansi_null_dflt_on on');\n    } else if (this.config.options.enableAnsiNullDefault === false) {\n      options.push('set ansi_null_dflt_on off');\n    }\n\n    if (this.config.options.enableAnsiPadding === true) {\n      options.push('set ansi_padding on');\n    } else if (this.config.options.enableAnsiPadding === false) {\n      options.push('set ansi_padding off');\n    }\n\n    if (this.config.options.enableAnsiWarnings === true) {\n      options.push('set ansi_warnings on');\n    } else if (this.config.options.enableAnsiWarnings === false) {\n      options.push('set ansi_warnings off');\n    }\n\n    if (this.config.options.enableArithAbort === true) {\n      options.push('set arithabort on');\n    } else if (this.config.options.enableArithAbort === false) {\n      options.push('set arithabort off');\n    }\n\n    if (this.config.options.enableConcatNullYieldsNull === true) {\n      options.push('set concat_null_yields_null on');\n    } else if (this.config.options.enableConcatNullYieldsNull === false) {\n      options.push('set concat_null_yields_null off');\n    }\n\n    if (this.config.options.enableCursorCloseOnCommit === true) {\n      options.push('set cursor_close_on_commit on');\n    } else if (this.config.options.enableCursorCloseOnCommit === false) {\n      options.push('set cursor_close_on_commit off');\n    }\n\n    if (this.config.options.datefirst !== null) {\n      options.push(`set datefirst ${this.config.options.datefirst}`);\n    }\n\n    if (this.config.options.dateFormat !== null) {\n      options.push(`set dateformat ${this.config.options.dateFormat}`);\n    }\n\n    if (this.config.options.enableImplicitTransactions === true) {\n      options.push('set implicit_transactions on');\n    } else if (this.config.options.enableImplicitTransactions === false) {\n      options.push('set implicit_transactions off');\n    }\n\n    if (this.config.options.language !== null) {\n      options.push(`set language ${this.config.options.language}`);\n    }\n\n    if (this.config.options.enableNumericRoundabort === true) {\n      options.push('set numeric_roundabort on');\n    } else if (this.config.options.enableNumericRoundabort === false) {\n      options.push('set numeric_roundabort off');\n    }\n\n    if (this.config.options.enableQuotedIdentifier === true) {\n      options.push('set quoted_identifier on');\n    } else if (this.config.options.enableQuotedIdentifier === false) {\n      options.push('set quoted_identifier off');\n    }\n\n    if (this.config.options.textsize !== null) {\n      options.push(`set textsize ${this.config.options.textsize}`);\n    }\n\n    if (this.config.options.connectionIsolationLevel !== null) {\n      options.push(`set transaction isolation level ${this.getIsolationLevelText(this.config.options.connectionIsolationLevel)}`);\n    }\n\n    if (this.config.options.abortTransactionOnError === true) {\n      options.push('set xact_abort on');\n    } else if (this.config.options.abortTransactionOnError === false) {\n      options.push('set xact_abort off');\n    }\n\n    return options.join('\\n');\n  }\n\n  /**\n   * @private\n   */\n  processedInitialSql() {\n    this.clearConnectTimer();\n    this.emit('connect');\n  }\n\n  /**\n   * Execute the SQL batch represented by [[Request]].\n   * There is no param support, and unlike [[Request.execSql]],\n   * it is not likely that SQL Server will reuse the execution plan it generates for the SQL.\n   *\n   * In almost all cases, [[Request.execSql]] will be a better choice.\n   *\n   * @param request A [[Request]] object representing the request.\n   */\n  execSqlBatch(request: Request) {\n    this.makeRequest(request, TYPE.SQL_BATCH, new SqlBatchPayload(request.sqlTextOrProcedure!, this.currentTransactionDescriptor(), this.config.options));\n  }\n\n  /**\n   *  Execute the SQL represented by [[Request]].\n   *\n   * As `sp_executesql` is used to execute the SQL, if the same SQL is executed multiples times\n   * using this function, the SQL Server query optimizer is likely to reuse the execution plan it generates\n   * for the first execution. This may also result in SQL server treating the request like a stored procedure\n   * which can result in the [[Event_doneInProc]] or [[Event_doneProc]] events being emitted instead of the\n   * [[Event_done]] event you might expect. Using [[execSqlBatch]] will prevent this from occurring but may have a negative performance impact.\n   *\n   * Beware of the way that scoping rules apply, and how they may [affect local temp tables](http://weblogs.sqlteam.com/mladenp/archive/2006/11/03/17197.aspx)\n   * If you're running in to scoping issues, then [[execSqlBatch]] may be a better choice.\n   * See also [issue #24](https://github.com/pekim/tedious/issues/24)\n   *\n   * @param request A [[Request]] object representing the request.\n   */\n  execSql(request: Request) {\n    try {\n      request.validateParameters(this.databaseCollation);\n    } catch (error: any) {\n      request.error = error;\n\n      process.nextTick(() => {\n        this.debug.log(error.message);\n        request.callback(error);\n      });\n\n      return;\n    }\n\n    const parameters: Parameter[] = [];\n\n    parameters.push({\n      type: TYPES.NVarChar,\n      name: 'statement',\n      value: request.sqlTextOrProcedure,\n      output: false,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    if (request.parameters.length) {\n      parameters.push({\n        type: TYPES.NVarChar,\n        name: 'params',\n        value: request.makeParamsParameter(request.parameters),\n        output: false,\n        length: undefined,\n        precision: undefined,\n        scale: undefined\n      });\n\n      parameters.push(...request.parameters);\n    }\n\n    this.makeRequest(request, TYPE.RPC_REQUEST, new RpcRequestPayload(Procedures.Sp_ExecuteSql, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));\n  }\n\n  /**\n   * Creates a new BulkLoad instance.\n   *\n   * @param table The name of the table to bulk-insert into.\n   * @param options A set of bulk load options.\n   */\n  newBulkLoad(table: string, callback: BulkLoadCallback): BulkLoad\n  newBulkLoad(table: string, options: BulkLoadOptions, callback: BulkLoadCallback): BulkLoad\n  newBulkLoad(table: string, callbackOrOptions: BulkLoadOptions | BulkLoadCallback, callback?: BulkLoadCallback) {\n    let options: BulkLoadOptions;\n\n    if (callback === undefined) {\n      callback = callbackOrOptions as BulkLoadCallback;\n      options = {};\n    } else {\n      options = callbackOrOptions as BulkLoadOptions;\n    }\n\n    if (typeof options !== 'object') {\n      throw new TypeError('\"options\" argument must be an object');\n    }\n    return new BulkLoad(table, this.databaseCollation, this.config.options, options, callback);\n  }\n\n  /**\n   * Execute a [[BulkLoad]].\n   *\n   * ```js\n   * // We want to perform a bulk load into a table with the following format:\n   * // CREATE TABLE employees (first_name nvarchar(255), last_name nvarchar(255), day_of_birth date);\n   *\n   * const bulkLoad = connection.newBulkLoad('employees', (err, rowCount) => {\n   *   // ...\n   * });\n   *\n   * // First, we need to specify the columns that we want to write to,\n   * // and their definitions. These definitions must match the actual table,\n   * // otherwise the bulk load will fail.\n   * bulkLoad.addColumn('first_name', TYPES.NVarchar, { nullable: false });\n   * bulkLoad.addColumn('last_name', TYPES.NVarchar, { nullable: false });\n   * bulkLoad.addColumn('date_of_birth', TYPES.Date, { nullable: false });\n   *\n   * // Execute a bulk load with a predefined list of rows.\n   * //\n   * // Note that these rows are held in memory until the\n   * // bulk load was performed, so if you need to write a large\n   * // number of rows (e.g. by reading from a CSV file),\n   * // passing an `AsyncIterable` is advisable to keep memory usage low.\n   * connection.execBulkLoad(bulkLoad, [\n   *   { 'first_name': 'Steve', 'last_name': 'Jobs', 'day_of_birth': new Date('02-24-1955') },\n   *   { 'first_name': 'Bill', 'last_name': 'Gates', 'day_of_birth': new Date('10-28-1955') }\n   * ]);\n   * ```\n   *\n   * @param bulkLoad A previously created [[BulkLoad]].\n   * @param rows A [[Iterable]] or [[AsyncIterable]] that contains the rows that should be bulk loaded.\n   */\n  execBulkLoad(bulkLoad: BulkLoad, rows: AsyncIterable<unknown[] | { [columnName: string]: unknown }> | Iterable<unknown[] | { [columnName: string]: unknown }>): void\n\n  execBulkLoad(bulkLoad: BulkLoad, rows?: AsyncIterable<unknown[] | { [columnName: string]: unknown }> | Iterable<unknown[] | { [columnName: string]: unknown }>) {\n    bulkLoad.executionStarted = true;\n\n    if (rows) {\n      if (bulkLoad.streamingMode) {\n        throw new Error(\"Connection.execBulkLoad can't be called with a BulkLoad that was put in streaming mode.\");\n      }\n\n      if (bulkLoad.firstRowWritten) {\n        throw new Error(\"Connection.execBulkLoad can't be called with a BulkLoad that already has rows written to it.\");\n      }\n\n      const rowStream = Readable.from(rows);\n\n      // Destroy the packet transform if an error happens in the row stream,\n      // e.g. if an error is thrown from within a generator or stream.\n      rowStream.on('error', (err) => {\n        bulkLoad.rowToPacketTransform.destroy(err);\n      });\n\n      // Destroy the row stream if an error happens in the packet transform,\n      // e.g. if the bulk load is cancelled.\n      bulkLoad.rowToPacketTransform.on('error', (err) => {\n        rowStream.destroy(err);\n      });\n\n      rowStream.pipe(bulkLoad.rowToPacketTransform);\n    } else if (!bulkLoad.streamingMode) {\n      // If the bulkload was not put into streaming mode by the user,\n      // we end the rowToPacketTransform here for them.\n      //\n      // If it was put into streaming mode, it's the user's responsibility\n      // to end the stream.\n      bulkLoad.rowToPacketTransform.end();\n    }\n\n    const onCancel = () => {\n      request.cancel();\n    };\n\n    const payload = new BulkLoadPayload(bulkLoad);\n\n    const request = new Request(bulkLoad.getBulkInsertSql(), (error: (Error & { code?: string }) | null | undefined) => {\n      bulkLoad.removeListener('cancel', onCancel);\n\n      if (error) {\n        if (error.code === 'UNKNOWN') {\n          error.message += ' This is likely because the schema of the BulkLoad does not match the schema of the table you are attempting to insert into.';\n        }\n        bulkLoad.error = error;\n        bulkLoad.callback(error);\n        return;\n      }\n\n      this.makeRequest(bulkLoad, TYPE.BULK_LOAD, payload);\n    });\n\n    bulkLoad.once('cancel', onCancel);\n\n    this.execSqlBatch(request);\n  }\n\n  /**\n   * Prepare the SQL represented by the request.\n   *\n   * The request can then be used in subsequent calls to\n   * [[execute]] and [[unprepare]]\n   *\n   * @param request A [[Request]] object representing the request.\n   *   Parameters only require a name and type. Parameter values are ignored.\n   */\n  prepare(request: Request) {\n    const parameters: Parameter[] = [];\n\n    parameters.push({\n      type: TYPES.Int,\n      name: 'handle',\n      value: undefined,\n      output: true,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    parameters.push({\n      type: TYPES.NVarChar,\n      name: 'params',\n      value: request.parameters.length ? request.makeParamsParameter(request.parameters) : null,\n      output: false,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    parameters.push({\n      type: TYPES.NVarChar,\n      name: 'stmt',\n      value: request.sqlTextOrProcedure,\n      output: false,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    request.preparing = true;\n\n    // TODO: We need to clean up this event handler, otherwise this leaks memory\n    request.on('returnValue', (name: string, value: any) => {\n      if (name === 'handle') {\n        request.handle = value;\n      } else {\n        request.error = new RequestError(`Tedious > Unexpected output parameter ${name} from sp_prepare`);\n      }\n    });\n\n    this.makeRequest(request, TYPE.RPC_REQUEST, new RpcRequestPayload(Procedures.Sp_Prepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));\n  }\n\n  /**\n   * Release the SQL Server resources associated with a previously prepared request.\n   *\n   * @param request A [[Request]] object representing the request.\n   *   Parameters only require a name and type.\n   *   Parameter values are ignored.\n   */\n  unprepare(request: Request) {\n    const parameters: Parameter[] = [];\n\n    parameters.push({\n      type: TYPES.Int,\n      name: 'handle',\n      // TODO: Abort if `request.handle` is not set\n      value: request.handle,\n      output: false,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    this.makeRequest(request, TYPE.RPC_REQUEST, new RpcRequestPayload(Procedures.Sp_Unprepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));\n  }\n\n  /**\n   * Execute previously prepared SQL, using the supplied parameters.\n   *\n   * @param request A previously prepared [[Request]].\n   * @param parameters  An object whose names correspond to the names of\n   *   parameters that were added to the [[Request]] before it was prepared.\n   *   The object's values are passed as the parameters' values when the\n   *   request is executed.\n   */\n  execute(request: Request, parameters?: { [key: string]: unknown }) {\n    const executeParameters: Parameter[] = [];\n\n    executeParameters.push({\n      type: TYPES.Int,\n      name: '',\n      // TODO: Abort if `request.handle` is not set\n      value: request.handle,\n      output: false,\n      length: undefined,\n      precision: undefined,\n      scale: undefined\n    });\n\n    try {\n      for (let i = 0, len = request.parameters.length; i < len; i++) {\n        const parameter = request.parameters[i];\n\n        executeParameters.push({\n          ...parameter,\n          value: parameter.type.validate(parameters ? parameters[parameter.name] : null, this.databaseCollation)\n        });\n      }\n    } catch (error: any) {\n      request.error = error;\n\n      process.nextTick(() => {\n        this.debug.log(error.message);\n        request.callback(error);\n      });\n\n      return;\n    }\n\n    this.makeRequest(request, TYPE.RPC_REQUEST, new RpcRequestPayload(Procedures.Sp_Execute, executeParameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));\n  }\n\n  /**\n   * Call a stored procedure represented by [[Request]].\n   *\n   * @param request A [[Request]] object representing the request.\n   */\n  callProcedure(request: Request) {\n    try {\n      request.validateParameters(this.databaseCollation);\n    } catch (error: any) {\n      request.error = error;\n\n      process.nextTick(() => {\n        this.debug.log(error.message);\n        request.callback(error);\n      });\n\n      return;\n    }\n\n    this.makeRequest(request, TYPE.RPC_REQUEST, new RpcRequestPayload(request.sqlTextOrProcedure!, request.parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));\n  }\n\n  /**\n   * Start a transaction.\n   *\n   * @param callback\n   * @param name A string representing a name to associate with the transaction.\n   *   Optional, and defaults to an empty string. Required when `isolationLevel`\n   *   is present.\n   * @param isolationLevel The isolation level that the transaction is to be run with.\n   *\n   *   The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.\n   *   * `READ_UNCOMMITTED`\n   *   * `READ_COMMITTED`\n   *   * `REPEATABLE_READ`\n   *   * `SERIALIZABLE`\n   *   * `SNAPSHOT`\n   *\n   *   Optional, and defaults to the Connection's isolation level.\n   */\n  beginTransaction(callback: BeginTransactionCallback, name = '', isolationLevel = this.config.options.isolationLevel) {\n    assertValidIsolationLevel(isolationLevel, 'isolationLevel');\n\n    const transaction = new Transaction(name, isolationLevel);\n\n    if (this.config.options.tdsVersion < '7_2') {\n      return this.execSqlBatch(new Request('SET TRANSACTION ISOLATION LEVEL ' + (transaction.isolationLevelToTSQL()) + ';BEGIN TRAN ' + transaction.name, (err) => {\n        this.transactionDepth++;\n        if (this.transactionDepth === 1) {\n          this.inTransaction = true;\n        }\n        callback(err);\n      }));\n    }\n\n    const request = new Request(undefined, (err) => {\n      return callback(err, this.currentTransactionDescriptor());\n    });\n    return this.makeRequest(request, TYPE.TRANSACTION_MANAGER, transaction.beginPayload(this.currentTransactionDescriptor()));\n  }\n\n  /**\n   * Commit a transaction.\n   *\n   * There should be an active transaction - that is, [[beginTransaction]]\n   * should have been previously called.\n   *\n   * @param callback\n   * @param name A string representing a name to associate with the transaction.\n   *   Optional, and defaults to an empty string. Required when `isolationLevel`is present.\n   */\n  commitTransaction(callback: CommitTransactionCallback, name = '') {\n    const transaction = new Transaction(name);\n    if (this.config.options.tdsVersion < '7_2') {\n      return this.execSqlBatch(new Request('COMMIT TRAN ' + transaction.name, (err) => {\n        this.transactionDepth--;\n        if (this.transactionDepth === 0) {\n          this.inTransaction = false;\n        }\n\n        callback(err);\n      }));\n    }\n    const request = new Request(undefined, callback);\n    return this.makeRequest(request, TYPE.TRANSACTION_MANAGER, transaction.commitPayload(this.currentTransactionDescriptor()));\n  }\n\n  /**\n   * Rollback a transaction.\n   *\n   * There should be an active transaction - that is, [[beginTransaction]]\n   * should have been previously called.\n   *\n   * @param callback\n   * @param name A string representing a name to associate with the transaction.\n   *   Optional, and defaults to an empty string.\n   *   Required when `isolationLevel` is present.\n   */\n  rollbackTransaction(callback: RollbackTransactionCallback, name = '') {\n    const transaction = new Transaction(name);\n    if (this.config.options.tdsVersion < '7_2') {\n      return this.execSqlBatch(new Request('ROLLBACK TRAN ' + transaction.name, (err) => {\n        this.transactionDepth--;\n        if (this.transactionDepth === 0) {\n          this.inTransaction = false;\n        }\n        callback(err);\n      }));\n    }\n    const request = new Request(undefined, callback);\n    return this.makeRequest(request, TYPE.TRANSACTION_MANAGER, transaction.rollbackPayload(this.currentTransactionDescriptor()));\n  }\n\n  /**\n   * Set a savepoint within a transaction.\n   *\n   * There should be an active transaction - that is, [[beginTransaction]]\n   * should have been previously called.\n   *\n   * @param callback\n   * @param name A string representing a name to associate with the transaction.\\\n   *   Optional, and defaults to an empty string.\n   *   Required when `isolationLevel` is present.\n   */\n  saveTransaction(callback: SaveTransactionCallback, name: string) {\n    const transaction = new Transaction(name);\n    if (this.config.options.tdsVersion < '7_2') {\n      return this.execSqlBatch(new Request('SAVE TRAN ' + transaction.name, (err) => {\n        this.transactionDepth++;\n        callback(err);\n      }));\n    }\n    const request = new Request(undefined, callback);\n    return this.makeRequest(request, TYPE.TRANSACTION_MANAGER, transaction.savePayload(this.currentTransactionDescriptor()));\n  }\n\n  /**\n   * Run the given callback after starting a transaction, and commit or\n   * rollback the transaction afterwards.\n   *\n   * This is a helper that employs [[beginTransaction]], [[commitTransaction]],\n   * [[rollbackTransaction]], and [[saveTransaction]] to greatly simplify the\n   * use of database transactions and automatically handle transaction nesting.\n   *\n   * @param cb\n   * @param isolationLevel\n   *   The isolation level that the transaction is to be run with.\n   *\n   *   The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.\n   *   * `READ_UNCOMMITTED`\n   *   * `READ_COMMITTED`\n   *   * `REPEATABLE_READ`\n   *   * `SERIALIZABLE`\n   *   * `SNAPSHOT`\n   *\n   *   Optional, and defaults to the Connection's isolation level.\n   */\n  transaction(cb: (err: Error | null | undefined, txDone?: <T extends TransactionDoneCallback>(err: Error | null | undefined, done: T, ...args: CallbackParameters<T>) => void) => void, isolationLevel?: typeof ISOLATION_LEVEL[keyof typeof ISOLATION_LEVEL]) {\n    if (typeof cb !== 'function') {\n      throw new TypeError('`cb` must be a function');\n    }\n\n    const useSavepoint = this.inTransaction;\n    const name = '_tedious_' + (crypto.randomBytes(10).toString('hex'));\n    const txDone: <T extends TransactionDoneCallback>(err: Error | null | undefined, done: T, ...args: CallbackParameters<T>) => void = (err, done, ...args) => {\n      if (err) {\n        if (this.inTransaction && this.state === this.STATE.LOGGED_IN) {\n          this.rollbackTransaction((txErr) => {\n            done(txErr || err, ...args);\n          }, name);\n        } else {\n          done(err, ...args);\n        }\n      } else if (useSavepoint) {\n        if (this.config.options.tdsVersion < '7_2') {\n          this.transactionDepth--;\n        }\n        done(null, ...args);\n      } else {\n        this.commitTransaction((txErr) => {\n          done(txErr, ...args);\n        }, name);\n      }\n    };\n\n    if (useSavepoint) {\n      return this.saveTransaction((err) => {\n        if (err) {\n          return cb(err);\n        }\n\n        if (isolationLevel) {\n          return this.execSqlBatch(new Request('SET transaction isolation level ' + this.getIsolationLevelText(isolationLevel), (err) => {\n            return cb(err, txDone);\n          }));\n        } else {\n          return cb(null, txDone);\n        }\n      }, name);\n    } else {\n      return this.beginTransaction((err) => {\n        if (err) {\n          return cb(err);\n        }\n\n        return cb(null, txDone);\n      }, name, isolationLevel);\n    }\n  }\n\n  /**\n   * @private\n   */\n  makeRequest(request: Request | BulkLoad, packetType: number, payload: (Iterable<Buffer> | AsyncIterable<Buffer>) & { toString: (indent?: string) => string }) {\n    if (this.state !== this.STATE.LOGGED_IN) {\n      const message = 'Requests can only be made in the ' + this.STATE.LOGGED_IN.name + ' state, not the ' + this.state.name + ' state';\n      this.debug.log(message);\n      request.callback(new RequestError(message, 'EINVALIDSTATE'));\n    } else if (request.canceled) {\n      process.nextTick(() => {\n        request.callback(new RequestError('Canceled.', 'ECANCEL'));\n      });\n    } else {\n      if (packetType === TYPE.SQL_BATCH) {\n        this.isSqlBatch = true;\n      } else {\n        this.isSqlBatch = false;\n      }\n\n      this.request = request;\n      request.connection! = this;\n      request.rowCount! = 0;\n      request.rows! = [];\n      request.rst! = [];\n\n      const onCancel = () => {\n        payloadStream.unpipe(message);\n        payloadStream.destroy(new RequestError('Canceled.', 'ECANCEL'));\n\n        // set the ignore bit and end the message.\n        message.ignore = true;\n        message.end();\n\n        if (request instanceof Request && request.paused) {\n          // resume the request if it was paused so we can read the remaining tokens\n          request.resume();\n        }\n      };\n\n      request.once('cancel', onCancel);\n\n      this.createRequestTimer();\n\n      const message = new Message({ type: packetType, resetConnection: this.resetConnectionOnNextRequest });\n      this.messageIo.outgoingMessageStream.write(message);\n      this.transitionTo(this.STATE.SENT_CLIENT_REQUEST);\n\n      message.once('finish', () => {\n        request.removeListener('cancel', onCancel);\n        request.once('cancel', this._cancelAfterRequestSent);\n\n        this.resetConnectionOnNextRequest = false;\n        this.debug.payload(function() {\n          return payload!.toString('  ');\n        });\n      });\n\n      const payloadStream = Readable.from(payload);\n      payloadStream.once('error', (error) => {\n        payloadStream.unpipe(message);\n\n        // Only set a request error if no error was set yet.\n        request.error ??= error;\n\n        message.ignore = true;\n        message.end();\n      });\n      payloadStream.pipe(message);\n    }\n  }\n\n  /**\n   * Cancel currently executed request.\n   */\n  cancel() {\n    if (!this.request) {\n      return false;\n    }\n\n    if (this.request.canceled) {\n      return false;\n    }\n\n    this.request.cancel();\n    return true;\n  }\n\n  /**\n   * Reset the connection to its initial state.\n   * Can be useful for connection pool implementations.\n   *\n   * @param callback\n   */\n  reset(callback: ResetCallback) {\n    const request = new Request(this.getInitialSql(), (err) => {\n      if (this.config.options.tdsVersion < '7_2') {\n        this.inTransaction = false;\n      }\n      callback(err);\n    });\n    this.resetConnectionOnNextRequest = true;\n    this.execSqlBatch(request);\n  }\n\n  /**\n   * @private\n   */\n  currentTransactionDescriptor() {\n    return this.transactionDescriptors[this.transactionDescriptors.length - 1];\n  }\n\n  /**\n   * @private\n   */\n  getIsolationLevelText(isolationLevel: typeof ISOLATION_LEVEL[keyof typeof ISOLATION_LEVEL]) {\n    switch (isolationLevel) {\n      case ISOLATION_LEVEL.READ_UNCOMMITTED:\n        return 'read uncommitted';\n      case ISOLATION_LEVEL.REPEATABLE_READ:\n        return 'repeatable read';\n      case ISOLATION_LEVEL.SERIALIZABLE:\n        return 'serializable';\n      case ISOLATION_LEVEL.SNAPSHOT:\n        return 'snapshot';\n      default:\n        return 'read committed';\n    }\n  }\n}\n\nfunction isTransientError(error: AggregateError | ConnectionError): boolean {\n  if (error instanceof AggregateError) {\n    error = error.errors[0];\n  }\n  return (error instanceof ConnectionError) && !!error.isTransient;\n}\n\nexport default Connection;\nmodule.exports = Connection;\n\nConnection.prototype.STATE = {\n  INITIALIZED: {\n    name: 'Initialized',\n    events: {}\n  },\n  CONNECTING: {\n    name: 'Connecting',\n    enter: function() {\n      this.initialiseConnection();\n    },\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  SENT_PRELOGIN: {\n    name: 'SentPrelogin',\n    enter: function() {\n      (async () => {\n        let messageBuffer = Buffer.alloc(0);\n\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n\n        for await (const data of message) {\n          messageBuffer = Buffer.concat([messageBuffer, data]);\n        }\n\n        const preloginPayload = new PreloginPayload(messageBuffer);\n        this.debug.payload(function() {\n          return preloginPayload.toString('  ');\n        });\n\n        if (preloginPayload.fedAuthRequired === 1) {\n          this.fedAuthRequired = true;\n        }\n        if ('strict' !== this.config.options.encrypt && (preloginPayload.encryptionString === 'ON' || preloginPayload.encryptionString === 'REQ')) {\n          if (!this.config.options.encrypt) {\n            this.emit('connect', new ConnectionError(\"Server requires encryption, set 'encrypt' config option to true.\", 'EENCRYPT'));\n            return this.close();\n          }\n\n          try {\n            this.transitionTo(this.STATE.SENT_TLSSSLNEGOTIATION);\n            await this.messageIo.startTls(this.secureContextOptions, this.config.options.serverName ? this.config.options.serverName : this.routingData?.server ?? this.config.server, this.config.options.trustServerCertificate);\n          } catch (err: any) {\n            return this.socketError(err);\n          }\n        }\n\n        this.sendLogin7Packet();\n\n        const { authentication } = this.config;\n\n        switch (authentication.type) {\n          case 'token-credential':\n          case 'azure-active-directory-password':\n          case 'azure-active-directory-msi-vm':\n          case 'azure-active-directory-msi-app-service':\n          case 'azure-active-directory-service-principal-secret':\n          case 'azure-active-directory-default':\n            this.transitionTo(this.STATE.SENT_LOGIN7_WITH_FEDAUTH);\n            break;\n          case 'ntlm':\n            this.transitionTo(this.STATE.SENT_LOGIN7_WITH_NTLM);\n            break;\n          default:\n            this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);\n            break;\n        }\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  REROUTING: {\n    name: 'ReRouting',\n    enter: function() {\n      this.cleanupConnection(CLEANUP_TYPE.REDIRECT);\n    },\n    events: {\n      message: function() {\n      },\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      reconnect: function() {\n        this.transitionTo(this.STATE.CONNECTING);\n      }\n    }\n  },\n  TRANSIENT_FAILURE_RETRY: {\n    name: 'TRANSIENT_FAILURE_RETRY',\n    enter: function() {\n      this.curTransientRetryCount++;\n      this.cleanupConnection(CLEANUP_TYPE.RETRY);\n    },\n    events: {\n      message: function() {\n      },\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      retry: function() {\n        this.createRetryTimer();\n      }\n    }\n  },\n  SENT_TLSSSLNEGOTIATION: {\n    name: 'SentTLSSSLNegotiation',\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  SENT_LOGIN7_WITH_STANDARD_LOGIN: {\n    name: 'SentLogin7WithStandardLogin',\n    enter: function() {\n      (async () => {\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n\n        const handler = new Login7TokenHandler(this);\n        const tokenStreamParser = this.createTokenStreamParser(message, handler);\n\n        await once(tokenStreamParser, 'end');\n\n        if (handler.loginAckReceived) {\n          if (handler.routingData) {\n            this.routingData = handler.routingData;\n            this.transitionTo(this.STATE.REROUTING);\n          } else {\n            this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);\n          }\n        } else if (this.loginError) {\n          if (isTransientError(this.loginError)) {\n            this.debug.log('Initiating retry on transient error');\n            this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);\n          } else {\n            this.emit('connect', this.loginError);\n            this.transitionTo(this.STATE.FINAL);\n          }\n        } else {\n          this.emit('connect', new ConnectionError('Login failed.', 'ELOGIN'));\n          this.transitionTo(this.STATE.FINAL);\n        }\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  SENT_LOGIN7_WITH_NTLM: {\n    name: 'SentLogin7WithNTLMLogin',\n    enter: function() {\n      (async () => {\n        while (true) {\n          let message;\n          try {\n            message = await this.messageIo.readMessage();\n          } catch (err: any) {\n            return this.socketError(err);\n          }\n\n          const handler = new Login7TokenHandler(this);\n          const tokenStreamParser = this.createTokenStreamParser(message, handler);\n\n          await once(tokenStreamParser, 'end');\n\n          if (handler.loginAckReceived) {\n            if (handler.routingData) {\n              this.routingData = handler.routingData;\n              return this.transitionTo(this.STATE.REROUTING);\n            } else {\n              return this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);\n            }\n          } else if (this.ntlmpacket) {\n            const authentication = this.config.authentication as NtlmAuthentication;\n\n            const payload = new NTLMResponsePayload({\n              domain: authentication.options.domain,\n              userName: authentication.options.userName,\n              password: authentication.options.password,\n              ntlmpacket: this.ntlmpacket\n            });\n\n            this.messageIo.sendMessage(TYPE.NTLMAUTH_PKT, payload.data);\n            this.debug.payload(function() {\n              return payload.toString('  ');\n            });\n\n            this.ntlmpacket = undefined;\n          } else if (this.loginError) {\n            if (isTransientError(this.loginError)) {\n              this.debug.log('Initiating retry on transient error');\n              return this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);\n            } else {\n              this.emit('connect', this.loginError);\n              return this.transitionTo(this.STATE.FINAL);\n            }\n          } else {\n            this.emit('connect', new ConnectionError('Login failed.', 'ELOGIN'));\n            return this.transitionTo(this.STATE.FINAL);\n          }\n        }\n\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  SENT_LOGIN7_WITH_FEDAUTH: {\n    name: 'SentLogin7Withfedauth',\n    enter: function() {\n      (async () => {\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n\n        const handler = new Login7TokenHandler(this);\n        const tokenStreamParser = this.createTokenStreamParser(message, handler);\n        await once(tokenStreamParser, 'end');\n        if (handler.loginAckReceived) {\n          if (handler.routingData) {\n            this.routingData = handler.routingData;\n            this.transitionTo(this.STATE.REROUTING);\n          } else {\n            this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);\n          }\n\n          return;\n        }\n\n        const fedAuthInfoToken = handler.fedAuthInfoToken;\n\n        if (fedAuthInfoToken && fedAuthInfoToken.stsurl && fedAuthInfoToken.spn) {\n          /** Federated authentication configation. */\n          const authentication = this.config.authentication as TokenCredentialAuthentication | AzureActiveDirectoryPasswordAuthentication | AzureActiveDirectoryMsiVmAuthentication | AzureActiveDirectoryMsiAppServiceAuthentication | AzureActiveDirectoryServicePrincipalSecret | AzureActiveDirectoryDefaultAuthentication;\n          /** Permission scope to pass to Entra ID when requesting an authentication token. */\n          const tokenScope = new URL('/.default', fedAuthInfoToken.spn).toString();\n\n          /** Instance of the token credential to use to authenticate to the resource. */\n          let credentials: TokenCredential;\n\n          switch (authentication.type) {\n            case 'token-credential':\n              credentials = authentication.options.credential;\n              break;\n            case 'azure-active-directory-password':\n              credentials = new UsernamePasswordCredential(\n                authentication.options.tenantId ?? 'common',\n                authentication.options.clientId,\n                authentication.options.userName,\n                authentication.options.password\n              );\n              break;\n            case 'azure-active-directory-msi-vm':\n            case 'azure-active-directory-msi-app-service':\n              const msiArgs = authentication.options.clientId ? [authentication.options.clientId, {}] : [{}];\n              credentials = new ManagedIdentityCredential(...msiArgs);\n              break;\n            case 'azure-active-directory-default':\n              const args = authentication.options.clientId ? { managedIdentityClientId: authentication.options.clientId } : {};\n              credentials = new DefaultAzureCredential(args);\n              break;\n            case 'azure-active-directory-service-principal-secret':\n              credentials = new ClientSecretCredential(\n                authentication.options.tenantId,\n                authentication.options.clientId,\n                authentication.options.clientSecret\n              );\n              break;\n          }\n\n          /** Access token retrieved from Entra ID for the configured permission scope(s). */\n          let tokenResponse: AccessToken | null;\n\n          try {\n            tokenResponse = await credentials.getToken(tokenScope);\n          } catch (err) {\n            this.loginError = new AggregateError(\n              [new ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH'), err]);\n            this.emit('connect', this.loginError);\n            this.transitionTo(this.STATE.FINAL);\n            return;\n          }\n\n          // Type guard the token value so that it is never null.\n          if (tokenResponse === null) {\n            this.loginError = new AggregateError(\n              [new ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH')]);\n            this.emit('connect', this.loginError);\n            this.transitionTo(this.STATE.FINAL);\n            return;\n          }\n\n          this.sendFedAuthTokenMessage(tokenResponse.token);\n\n        } else if (this.loginError) {\n          if (isTransientError(this.loginError)) {\n            this.debug.log('Initiating retry on transient error');\n            this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);\n          } else {\n            this.emit('connect', this.loginError);\n            this.transitionTo(this.STATE.FINAL);\n          }\n        } else {\n          this.emit('connect', new ConnectionError('Login failed.', 'ELOGIN'));\n          this.transitionTo(this.STATE.FINAL);\n        }\n\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  LOGGED_IN_SENDING_INITIAL_SQL: {\n    name: 'LoggedInSendingInitialSql',\n    enter: function() {\n      (async () => {\n        this.sendInitialSql();\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n        const tokenStreamParser = this.createTokenStreamParser(message, new InitialSqlTokenHandler(this));\n        await once(tokenStreamParser, 'end');\n\n        this.transitionTo(this.STATE.LOGGED_IN);\n        this.processedInitialSql();\n\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function socketError() {\n        this.transitionTo(this.STATE.FINAL);\n      },\n      connectTimeout: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  LOGGED_IN: {\n    name: 'LoggedIn',\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n      }\n    }\n  },\n  SENT_CLIENT_REQUEST: {\n    name: 'SentClientRequest',\n    enter: function() {\n      (async () => {\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n        // request timer is stopped on first data package\n        this.clearRequestTimer();\n\n        const tokenStreamParser = this.createTokenStreamParser(message, new RequestTokenHandler(this, this.request!));\n\n        // If the request was canceled and we have a `cancelTimer`\n        // defined, we send a attention message after the\n        // request message was fully sent off.\n        //\n        // We already started consuming the current message\n        // (but all the token handlers should be no-ops), and\n        // need to ensure the next message is handled by the\n        // `SENT_ATTENTION` state.\n        if (this.request?.canceled && this.cancelTimer) {\n          return this.transitionTo(this.STATE.SENT_ATTENTION);\n        }\n\n        const onResume = () => {\n          tokenStreamParser.resume();\n        };\n        const onPause = () => {\n          tokenStreamParser.pause();\n\n          this.request?.once('resume', onResume);\n        };\n\n        this.request?.on('pause', onPause);\n\n        if (this.request instanceof Request && this.request.paused) {\n          onPause();\n        }\n\n        const onCancel = () => {\n          tokenStreamParser.removeListener('end', onEndOfMessage);\n\n          if (this.request instanceof Request && this.request.paused) {\n            // resume the request if it was paused so we can read the remaining tokens\n            this.request.resume();\n          }\n\n          this.request?.removeListener('pause', onPause);\n          this.request?.removeListener('resume', onResume);\n\n          // The `_cancelAfterRequestSent` callback will have sent a\n          // attention message, so now we need to also switch to\n          // the `SENT_ATTENTION` state to make sure the attention ack\n          // message is processed correctly.\n          this.transitionTo(this.STATE.SENT_ATTENTION);\n        };\n\n        const onEndOfMessage = () => {\n          this.request?.removeListener('cancel', this._cancelAfterRequestSent);\n          this.request?.removeListener('cancel', onCancel);\n          this.request?.removeListener('pause', onPause);\n          this.request?.removeListener('resume', onResume);\n\n          this.transitionTo(this.STATE.LOGGED_IN);\n          const sqlRequest = this.request as Request;\n          this.request = undefined;\n          if (this.config.options.tdsVersion < '7_2' && sqlRequest.error && this.isSqlBatch) {\n            this.inTransaction = false;\n          }\n          sqlRequest.callback(sqlRequest.error, sqlRequest.rowCount, sqlRequest.rows);\n        };\n\n        tokenStreamParser.once('end', onEndOfMessage);\n        this.request?.once('cancel', onCancel);\n      })();\n\n    },\n    exit: function(nextState) {\n      this.clearRequestTimer();\n    },\n    events: {\n      socketError: function(err) {\n        const sqlRequest = this.request!;\n        this.request = undefined;\n        this.transitionTo(this.STATE.FINAL);\n\n        sqlRequest.callback(err);\n      }\n    }\n  },\n  SENT_ATTENTION: {\n    name: 'SentAttention',\n    enter: function() {\n      (async () => {\n        let message;\n        try {\n          message = await this.messageIo.readMessage();\n        } catch (err: any) {\n          return this.socketError(err);\n        }\n\n        const handler = new AttentionTokenHandler(this, this.request!);\n        const tokenStreamParser = this.createTokenStreamParser(message, handler);\n\n        await once(tokenStreamParser, 'end');\n        // 3.2.5.7 Sent Attention State\n        // Discard any data contained in the response, until we receive the attention response\n        if (handler.attentionReceived) {\n          this.clearCancelTimer();\n\n          const sqlRequest = this.request!;\n          this.request = undefined;\n          this.transitionTo(this.STATE.LOGGED_IN);\n\n          if (sqlRequest.error && sqlRequest.error instanceof RequestError && sqlRequest.error.code === 'ETIMEOUT') {\n            sqlRequest.callback(sqlRequest.error);\n          } else {\n            sqlRequest.callback(new RequestError('Canceled.', 'ECANCEL'));\n          }\n        }\n\n      })().catch((err) => {\n        process.nextTick(() => {\n          throw err;\n        });\n      });\n    },\n    events: {\n      socketError: function(err) {\n        const sqlRequest = this.request!;\n        this.request = undefined;\n\n        this.transitionTo(this.STATE.FINAL);\n\n        sqlRequest.callback(err);\n      }\n    }\n  },\n  FINAL: {\n    name: 'Final',\n    enter: function() {\n      this.cleanupConnection(CLEANUP_TYPE.NORMAL);\n    },\n    events: {\n      connectTimeout: function() {\n        // Do nothing, as the timer should be cleaned up.\n      },\n      message: function() {\n        // Do nothing\n      },\n      socketError: function() {\n        // Do nothing\n      }\n    }\n  }\n};\n"],"mappings":"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AAG,IAAI;AAChD;AACA;AACA;AACA,MAAMC,sBAAsB,GAAG,CAAC,GAAG,IAAI;AACvC;AACA;AACA;AACA,MAAMC,8BAA8B,GAAG,GAAG;AAC1C;AACA;AACA;AACA,MAAMC,mBAAmB,GAAG,CAAC,GAAG,IAAI;AACpC;AACA;AACA;AACA,MAAMC,gBAAgB,GAAG,UAAU;AACnC;AACA;AACA;AACA,MAAMC,iBAAiB,GAAG,CAAC;AAC3B;AACA;AACA;AACA,MAAMC,YAAY,GAAG,IAAI;AACzB;AACA;AACA;AACA,MAAMC,mBAAmB,GAAG,KAAK;AACjC;AACA;AACA;AACA,MAAMC,gBAAgB,GAAG,YAAY;AACrC;AACA;AACA;AACA,MAAMC,kBAAkB,GAAG,KAAK;;AAgGhC;;AAwHA;AACA;AACA;;AA4cA;AACA;AACA;AACA,MAAMC,YAAY,GAAG;EACnBC,MAAM,EAAE,CAAC;EACTC,QAAQ,EAAE,CAAC;EACXC,KAAK,EAAE;AACT,CAAC;AAOD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMC,UAAU,SAASC,oBAAY,CAAC;EACpC;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAGE;AACF;AACA;;EAkBE;AACF;AACA;;EAGE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAGE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAGE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAEE;AACF;AACA;;EAGE;AACF;AACA;EACEC,uBAAuB;;EAEvB;AACF;AACA;;EAGE;AACF;AACA;AACA;AACA;AACA;AA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"} |
\ | No newline at end of file |