tedious-fabric 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CLAUDE.md +91 -0
- package/LICENSE +21 -0
- package/README.md +67 -0
- package/appveyor.yml +67 -0
- package/eslint.config.mjs +314 -0
- package/lib/all-headers.d.ts +2 -0
- package/lib/all-headers.js +24 -0
- package/lib/all-headers.js.map +1 -0
- package/lib/always-encrypted/aead-aes-256-cbc-hmac-algorithm.js +82 -0
- package/lib/always-encrypted/aead-aes-256-cbc-hmac-algorithm.js.map +1 -0
- package/lib/always-encrypted/aead-aes-256-cbc-hmac-encryption-key.js +55 -0
- package/lib/always-encrypted/aead-aes-256-cbc-hmac-encryption-key.js.map +1 -0
- package/lib/always-encrypted/cek-entry.d.ts +11 -0
- package/lib/always-encrypted/cek-entry.js +42 -0
- package/lib/always-encrypted/cek-entry.js.map +1 -0
- package/lib/always-encrypted/get-parameter-encryption-metadata.js +90 -0
- package/lib/always-encrypted/get-parameter-encryption-metadata.js.map +1 -0
- package/lib/always-encrypted/key-crypto.js +94 -0
- package/lib/always-encrypted/key-crypto.js.map +1 -0
- package/lib/always-encrypted/keystore-provider-azure-key-vault.d.ts +21 -0
- package/lib/always-encrypted/keystore-provider-azure-key-vault.js +247 -0
- package/lib/always-encrypted/keystore-provider-azure-key-vault.js.map +1 -0
- package/lib/always-encrypted/symmetric-key-cache.js +36 -0
- package/lib/always-encrypted/symmetric-key-cache.js.map +1 -0
- package/lib/always-encrypted/symmetric-key.js +25 -0
- package/lib/always-encrypted/symmetric-key.js.map +1 -0
- package/lib/always-encrypted/types.d.ts +73 -0
- package/lib/always-encrypted/types.js +61 -0
- package/lib/always-encrypted/types.js.map +1 -0
- package/lib/always-encrypted/utils.js +23 -0
- package/lib/always-encrypted/utils.js.map +1 -0
- package/lib/bulk-load-payload.d.ts +8 -0
- package/lib/bulk-load-payload.js +23 -0
- package/lib/bulk-load-payload.js.map +1 -0
- package/lib/bulk-load.d.ts +275 -0
- package/lib/bulk-load.js +515 -0
- package/lib/bulk-load.js.map +1 -0
- package/lib/collation.d.ts +28 -0
- package/lib/collation.js +348 -0
- package/lib/collation.js.map +1 -0
- package/lib/connection.d.ts +1309 -0
- package/lib/connection.js +2732 -0
- package/lib/connection.js.map +1 -0
- package/lib/connector.d.ts +18 -0
- package/lib/connector.js +142 -0
- package/lib/connector.js.map +1 -0
- package/lib/data-type.d.ts +554 -0
- package/lib/data-type.js +428 -0
- package/lib/data-type.js.map +1 -0
- package/lib/data-types/bigint.d.ts +3 -0
- package/lib/data-types/bigint.js +53 -0
- package/lib/data-types/bigint.js.map +1 -0
- package/lib/data-types/binary.d.ts +5 -0
- package/lib/data-types/binary.js +67 -0
- package/lib/data-types/binary.js.map +1 -0
- package/lib/data-types/bit.d.ts +3 -0
- package/lib/data-types/bit.js +46 -0
- package/lib/data-types/bit.js.map +1 -0
- package/lib/data-types/bitn.d.ts +3 -0
- package/lib/data-types/bitn.js +29 -0
- package/lib/data-types/bitn.js.map +1 -0
- package/lib/data-types/char.d.ts +5 -0
- package/lib/data-types/char.js +86 -0
- package/lib/data-types/char.js.map +1 -0
- package/lib/data-types/date.d.ts +3 -0
- package/lib/data-types/date.js +72 -0
- package/lib/data-types/date.js.map +1 -0
- package/lib/data-types/datetime.d.ts +3 -0
- package/lib/data-types/datetime.js +93 -0
- package/lib/data-types/datetime.js.map +1 -0
- package/lib/data-types/datetime2.d.ts +5 -0
- package/lib/data-types/datetime2.js +118 -0
- package/lib/data-types/datetime2.js.map +1 -0
- package/lib/data-types/datetimen.d.ts +3 -0
- package/lib/data-types/datetimen.js +29 -0
- package/lib/data-types/datetimen.js.map +1 -0
- package/lib/data-types/datetimeoffset.d.ts +5 -0
- package/lib/data-types/datetimeoffset.js +111 -0
- package/lib/data-types/datetimeoffset.js.map +1 -0
- package/lib/data-types/decimal.d.ts +6 -0
- package/lib/data-types/decimal.js +107 -0
- package/lib/data-types/decimal.js.map +1 -0
- package/lib/data-types/decimaln.d.ts +3 -0
- package/lib/data-types/decimaln.js +29 -0
- package/lib/data-types/decimaln.js.map +1 -0
- package/lib/data-types/float.d.ts +3 -0
- package/lib/data-types/float.js +47 -0
- package/lib/data-types/float.js.map +1 -0
- package/lib/data-types/floatn.d.ts +3 -0
- package/lib/data-types/floatn.js +29 -0
- package/lib/data-types/floatn.js.map +1 -0
- package/lib/data-types/image.d.ts +3 -0
- package/lib/data-types/image.js +56 -0
- package/lib/data-types/image.js.map +1 -0
- package/lib/data-types/int.d.ts +3 -0
- package/lib/data-types/int.js +53 -0
- package/lib/data-types/int.js.map +1 -0
- package/lib/data-types/intn.d.ts +3 -0
- package/lib/data-types/intn.js +29 -0
- package/lib/data-types/intn.js.map +1 -0
- package/lib/data-types/money.d.ts +3 -0
- package/lib/data-types/money.js +59 -0
- package/lib/data-types/money.js.map +1 -0
- package/lib/data-types/moneyn.d.ts +3 -0
- package/lib/data-types/moneyn.js +29 -0
- package/lib/data-types/moneyn.js.map +1 -0
- package/lib/data-types/nchar.d.ts +5 -0
- package/lib/data-types/nchar.js +100 -0
- package/lib/data-types/nchar.js.map +1 -0
- package/lib/data-types/ntext.d.ts +3 -0
- package/lib/data-types/ntext.js +60 -0
- package/lib/data-types/ntext.js.map +1 -0
- package/lib/data-types/null.d.ts +3 -0
- package/lib/data-types/null.js +29 -0
- package/lib/data-types/null.js.map +1 -0
- package/lib/data-types/numeric.d.ts +6 -0
- package/lib/data-types/numeric.js +106 -0
- package/lib/data-types/numeric.js.map +1 -0
- package/lib/data-types/numericn.d.ts +3 -0
- package/lib/data-types/numericn.js +29 -0
- package/lib/data-types/numericn.js.map +1 -0
- package/lib/data-types/nvarchar.d.ts +5 -0
- package/lib/data-types/nvarchar.js +133 -0
- package/lib/data-types/nvarchar.js.map +1 -0
- package/lib/data-types/real.d.ts +3 -0
- package/lib/data-types/real.js +48 -0
- package/lib/data-types/real.js.map +1 -0
- package/lib/data-types/smalldatetime.d.ts +3 -0
- package/lib/data-types/smalldatetime.js +83 -0
- package/lib/data-types/smalldatetime.js.map +1 -0
- package/lib/data-types/smallint.d.ts +3 -0
- package/lib/data-types/smallint.js +53 -0
- package/lib/data-types/smallint.js.map +1 -0
- package/lib/data-types/smallmoney.d.ts +3 -0
- package/lib/data-types/smallmoney.js +51 -0
- package/lib/data-types/smallmoney.js.map +1 -0
- package/lib/data-types/sql-variant.d.ts +3 -0
- package/lib/data-types/sql-variant.js +29 -0
- package/lib/data-types/sql-variant.js.map +1 -0
- package/lib/data-types/text.d.ts +3 -0
- package/lib/data-types/text.js +69 -0
- package/lib/data-types/text.js.map +1 -0
- package/lib/data-types/time.d.ts +3 -0
- package/lib/data-types/time.js +96 -0
- package/lib/data-types/time.js.map +1 -0
- package/lib/data-types/tinyint.d.ts +3 -0
- package/lib/data-types/tinyint.js +53 -0
- package/lib/data-types/tinyint.js.map +1 -0
- package/lib/data-types/tvp.d.ts +3 -0
- package/lib/data-types/tvp.js +117 -0
- package/lib/data-types/tvp.js.map +1 -0
- package/lib/data-types/udt.d.ts +3 -0
- package/lib/data-types/udt.js +29 -0
- package/lib/data-types/udt.js.map +1 -0
- package/lib/data-types/uniqueidentifier.d.ts +3 -0
- package/lib/data-types/uniqueidentifier.js +50 -0
- package/lib/data-types/uniqueidentifier.js.map +1 -0
- package/lib/data-types/varbinary.d.ts +5 -0
- package/lib/data-types/varbinary.js +119 -0
- package/lib/data-types/varbinary.js.map +1 -0
- package/lib/data-types/varchar.d.ts +5 -0
- package/lib/data-types/varchar.js +112 -0
- package/lib/data-types/varchar.js.map +1 -0
- package/lib/data-types/xml.d.ts +3 -0
- package/lib/data-types/xml.js +29 -0
- package/lib/data-types/xml.js.map +1 -0
- package/lib/debug.d.ts +25 -0
- package/lib/debug.js +66 -0
- package/lib/debug.js.map +1 -0
- package/lib/errors.d.ts +17 -0
- package/lib/errors.js +23 -0
- package/lib/errors.js.map +1 -0
- package/lib/guid-parser.d.ts +3 -0
- package/lib/guid-parser.js +30 -0
- package/lib/guid-parser.js.map +1 -0
- package/lib/incoming-message-stream.d.ts +19 -0
- package/lib/incoming-message-stream.js +97 -0
- package/lib/incoming-message-stream.js.map +1 -0
- package/lib/instance-lookup.d.ts +13 -0
- package/lib/instance-lookup.js +91 -0
- package/lib/instance-lookup.js.map +1 -0
- package/lib/library.d.ts +1 -0
- package/lib/library.js +8 -0
- package/lib/library.js.map +1 -0
- package/lib/login7-payload.d.ts +51 -0
- package/lib/login7-payload.js +408 -0
- package/lib/login7-payload.js.map +1 -0
- package/lib/message-io.d.ts +28 -0
- package/lib/message-io.js +152 -0
- package/lib/message-io.js.map +1 -0
- package/lib/message.d.ts +11 -0
- package/lib/message.js +21 -0
- package/lib/message.js.map +1 -0
- package/lib/metadata-parser.d.ts +48 -0
- package/lib/metadata-parser.js +380 -0
- package/lib/metadata-parser.js.map +1 -0
- package/lib/ntlm-payload.d.ts +23 -0
- package/lib/ntlm-payload.js +135 -0
- package/lib/ntlm-payload.js.map +1 -0
- package/lib/ntlm.d.ts +4 -0
- package/lib/ntlm.js +72 -0
- package/lib/ntlm.js.map +1 -0
- package/lib/outgoing-message-stream.d.ts +15 -0
- package/lib/outgoing-message-stream.js +81 -0
- package/lib/outgoing-message-stream.js.map +1 -0
- package/lib/packet.d.ts +33 -0
- package/lib/packet.js +191 -0
- package/lib/packet.js.map +1 -0
- package/lib/prelogin-payload.d.ts +67 -0
- package/lib/prelogin-payload.js +228 -0
- package/lib/prelogin-payload.js.map +1 -0
- package/lib/request.d.ts +370 -0
- package/lib/request.js +387 -0
- package/lib/request.js.map +1 -0
- package/lib/rpcrequest-payload.d.ts +16 -0
- package/lib/rpcrequest-payload.js +109 -0
- package/lib/rpcrequest-payload.js.map +1 -0
- package/lib/sender.d.ts +5 -0
- package/lib/sender.js +78 -0
- package/lib/sender.js.map +1 -0
- package/lib/special-stored-procedure.d.ts +18 -0
- package/lib/special-stored-procedure.js +26 -0
- package/lib/special-stored-procedure.js.map +1 -0
- package/lib/sqlbatch-payload.d.ts +13 -0
- package/lib/sqlbatch-payload.js +34 -0
- package/lib/sqlbatch-payload.js.map +1 -0
- package/lib/tds-versions.d.ts +6 -0
- package/lib/tds-versions.js +19 -0
- package/lib/tds-versions.js.map +1 -0
- package/lib/tedious.d.ts +13 -0
- package/lib/tedious.js +73 -0
- package/lib/tedious.js.map +1 -0
- package/lib/token/colmetadata-token-parser.d.ts +12 -0
- package/lib/token/colmetadata-token-parser.js +124 -0
- package/lib/token/colmetadata-token-parser.js.map +1 -0
- package/lib/token/done-token-parser.d.ts +6 -0
- package/lib/token/done-token-parser.js +76 -0
- package/lib/token/done-token-parser.js.map +1 -0
- package/lib/token/env-change-token-parser.d.ts +5 -0
- package/lib/token/env-change-token-parser.js +190 -0
- package/lib/token/env-change-token-parser.js.map +1 -0
- package/lib/token/feature-ext-ack-parser.d.ts +5 -0
- package/lib/token/feature-ext-ack-parser.js +52 -0
- package/lib/token/feature-ext-ack-parser.js.map +1 -0
- package/lib/token/fedauth-info-parser.d.ts +5 -0
- package/lib/token/fedauth-info-parser.js +62 -0
- package/lib/token/fedauth-info-parser.js.map +1 -0
- package/lib/token/handler.d.ts +136 -0
- package/lib/token/handler.js +445 -0
- package/lib/token/handler.js.map +1 -0
- package/lib/token/helpers.d.ts +28 -0
- package/lib/token/helpers.js +205 -0
- package/lib/token/helpers.js.map +1 -0
- package/lib/token/infoerror-token-parser.d.ts +5 -0
- package/lib/token/infoerror-token-parser.js +80 -0
- package/lib/token/infoerror-token-parser.js.map +1 -0
- package/lib/token/loginack-token-parser.d.ts +5 -0
- package/lib/token/loginack-token-parser.js +75 -0
- package/lib/token/loginack-token-parser.js.map +1 -0
- package/lib/token/nbcrow-token-parser.d.ts +4 -0
- package/lib/token/nbcrow-token-parser.js +103 -0
- package/lib/token/nbcrow-token-parser.js.map +1 -0
- package/lib/token/order-token-parser.d.ts +5 -0
- package/lib/token/order-token-parser.js +34 -0
- package/lib/token/order-token-parser.js.map +1 -0
- package/lib/token/returnstatus-token-parser.d.ts +5 -0
- package/lib/token/returnstatus-token-parser.js +21 -0
- package/lib/token/returnstatus-token-parser.js.map +1 -0
- package/lib/token/returnvalue-token-parser.d.ts +4 -0
- package/lib/token/returnvalue-token-parser.js +93 -0
- package/lib/token/returnvalue-token-parser.js.map +1 -0
- package/lib/token/row-token-parser.d.ts +4 -0
- package/lib/token/row-token-parser.js +76 -0
- package/lib/token/row-token-parser.js.map +1 -0
- package/lib/token/sspi-token-parser.d.ts +5 -0
- package/lib/token/sspi-token-parser.js +42 -0
- package/lib/token/sspi-token-parser.js.map +1 -0
- package/lib/token/stream-parser.d.ts +34 -0
- package/lib/token/stream-parser.js +341 -0
- package/lib/token/stream-parser.js.map +1 -0
- package/lib/token/token-stream-parser.d.ts +15 -0
- package/lib/token/token-stream-parser.js +36 -0
- package/lib/token/token-stream-parser.js.map +1 -0
- package/lib/token/token.d.ts +312 -0
- package/lib/token/token.js +328 -0
- package/lib/token/token.js.map +1 -0
- package/lib/tracking-buffer/writable-tracking-buffer.d.ts +47 -0
- package/lib/tracking-buffer/writable-tracking-buffer.js +249 -0
- package/lib/tracking-buffer/writable-tracking-buffer.js.map +1 -0
- package/lib/transaction.d.ts +39 -0
- package/lib/transaction.js +137 -0
- package/lib/transaction.js.map +1 -0
- package/lib/transient-error-lookup.d.ts +3 -0
- package/lib/transient-error-lookup.js +19 -0
- package/lib/transient-error-lookup.js.map +1 -0
- package/lib/value-parser.d.ts +7 -0
- package/lib/value-parser.js +813 -0
- package/lib/value-parser.js.map +1 -0
- package/package.json +145 -0
- package/pull_request_template.md +9 -0
- package/tsconfig.build-types.json +15 -0
- package/tsconfig.json +30 -0
- package/types/js-md4.d.ts +7 -0
- package/types/native-duplexpair.d.ts +12 -0
|
@@ -0,0 +1,2732 @@
|
|
|
1
|
+
"use strict";
|
|
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 _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
44
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
45
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* @private
|
|
49
|
+
*/
|
|
50
|
+
const KEEP_ALIVE_INITIAL_DELAY = 30 * 1000;
|
|
51
|
+
/**
|
|
52
|
+
* @private
|
|
53
|
+
*/
|
|
54
|
+
const DEFAULT_CONNECT_TIMEOUT = 15 * 1000;
|
|
55
|
+
/**
|
|
56
|
+
* @private
|
|
57
|
+
*/
|
|
58
|
+
const DEFAULT_CLIENT_REQUEST_TIMEOUT = 15 * 1000;
|
|
59
|
+
/**
|
|
60
|
+
* @private
|
|
61
|
+
*/
|
|
62
|
+
const DEFAULT_CANCEL_TIMEOUT = 5 * 1000;
|
|
63
|
+
/**
|
|
64
|
+
* @private
|
|
65
|
+
*/
|
|
66
|
+
const DEFAULT_CONNECT_RETRY_INTERVAL = 500;
|
|
67
|
+
/**
|
|
68
|
+
* @private
|
|
69
|
+
*/
|
|
70
|
+
const DEFAULT_PACKET_SIZE = 4 * 1024;
|
|
71
|
+
/**
|
|
72
|
+
* @private
|
|
73
|
+
*/
|
|
74
|
+
const DEFAULT_TEXTSIZE = 2147483647;
|
|
75
|
+
/**
|
|
76
|
+
* @private
|
|
77
|
+
*/
|
|
78
|
+
const DEFAULT_DATEFIRST = 7;
|
|
79
|
+
/**
|
|
80
|
+
* @private
|
|
81
|
+
*/
|
|
82
|
+
const DEFAULT_PORT = 1433;
|
|
83
|
+
/**
|
|
84
|
+
* @private
|
|
85
|
+
*/
|
|
86
|
+
const DEFAULT_TDS_VERSION = '7_4';
|
|
87
|
+
/**
|
|
88
|
+
* @private
|
|
89
|
+
*/
|
|
90
|
+
const DEFAULT_LANGUAGE = 'us_english';
|
|
91
|
+
/**
|
|
92
|
+
* @private
|
|
93
|
+
*/
|
|
94
|
+
const DEFAULT_DATEFORMAT = 'mdy';
|
|
95
|
+
|
|
96
|
+
/** Structure that defines the options that are necessary to authenticate the Tedious.JS instance with an `@azure/identity` token credential. */
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* @private
|
|
100
|
+
*/
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Helper function, equivalent to `Promise.withResolvers()`.
|
|
104
|
+
*
|
|
105
|
+
* @returns An object with the properties `promise`, `resolve`, and `reject`.
|
|
106
|
+
*/
|
|
107
|
+
function withResolvers() {
|
|
108
|
+
let resolve;
|
|
109
|
+
let reject;
|
|
110
|
+
const promise = new Promise((res, rej) => {
|
|
111
|
+
resolve = res;
|
|
112
|
+
reject = rej;
|
|
113
|
+
});
|
|
114
|
+
return {
|
|
115
|
+
promise,
|
|
116
|
+
resolve: resolve,
|
|
117
|
+
reject: reject
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* A [[Connection]] instance represents a single connection to a database server.
|
|
123
|
+
*
|
|
124
|
+
* ```js
|
|
125
|
+
* var Connection = require('tedious').Connection;
|
|
126
|
+
* var config = {
|
|
127
|
+
* "authentication": {
|
|
128
|
+
* ...,
|
|
129
|
+
* "options": {...}
|
|
130
|
+
* },
|
|
131
|
+
* "options": {...}
|
|
132
|
+
* };
|
|
133
|
+
* var connection = new Connection(config);
|
|
134
|
+
* ```
|
|
135
|
+
*
|
|
136
|
+
* Only one request at a time may be executed on a connection. Once a [[Request]]
|
|
137
|
+
* has been initiated (with [[Connection.callProcedure]], [[Connection.execSql]],
|
|
138
|
+
* or [[Connection.execSqlBatch]]), another should not be initiated until the
|
|
139
|
+
* [[Request]]'s completion callback is called.
|
|
140
|
+
*/
|
|
141
|
+
class Connection extends _events.EventEmitter {
|
|
142
|
+
/**
|
|
143
|
+
* @private
|
|
144
|
+
*/
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* @private
|
|
148
|
+
*/
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* @private
|
|
152
|
+
*/
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* @private
|
|
156
|
+
*/
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* @private
|
|
160
|
+
*/
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* @private
|
|
164
|
+
*/
|
|
165
|
+
|
|
166
|
+
/**
|
|
167
|
+
* @private
|
|
168
|
+
*/
|
|
169
|
+
|
|
170
|
+
/**
|
|
171
|
+
* @private
|
|
172
|
+
*/
|
|
173
|
+
|
|
174
|
+
/**
|
|
175
|
+
* @private
|
|
176
|
+
*/
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* @private
|
|
180
|
+
*/
|
|
181
|
+
|
|
182
|
+
/**
|
|
183
|
+
* @private
|
|
184
|
+
*/
|
|
185
|
+
|
|
186
|
+
/**
|
|
187
|
+
* @private
|
|
188
|
+
*/
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* @private
|
|
192
|
+
*/
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* @private
|
|
196
|
+
*/
|
|
197
|
+
|
|
198
|
+
/**
|
|
199
|
+
* @private
|
|
200
|
+
*/
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* @private
|
|
204
|
+
*/
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* @private
|
|
208
|
+
*/
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* @private
|
|
212
|
+
*/
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* @private
|
|
216
|
+
*/
|
|
217
|
+
|
|
218
|
+
/**
|
|
219
|
+
* @private
|
|
220
|
+
*/
|
|
221
|
+
|
|
222
|
+
/**
|
|
223
|
+
* @private
|
|
224
|
+
*/
|
|
225
|
+
|
|
226
|
+
/**
|
|
227
|
+
* @private
|
|
228
|
+
*/
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* @private
|
|
232
|
+
*/
|
|
233
|
+
|
|
234
|
+
/**
|
|
235
|
+
* @private
|
|
236
|
+
*/
|
|
237
|
+
|
|
238
|
+
/**
|
|
239
|
+
* @private
|
|
240
|
+
*/
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* @private
|
|
244
|
+
*/
|
|
245
|
+
|
|
246
|
+
/**
|
|
247
|
+
* @private
|
|
248
|
+
*/
|
|
249
|
+
|
|
250
|
+
/**
|
|
251
|
+
* @private
|
|
252
|
+
*/
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* @private
|
|
256
|
+
*/
|
|
257
|
+
|
|
258
|
+
/**
|
|
259
|
+
* @private
|
|
260
|
+
*/
|
|
261
|
+
|
|
262
|
+
/**
|
|
263
|
+
* Note: be aware of the different options field:
|
|
264
|
+
* 1. config.authentication.options
|
|
265
|
+
* 2. config.options
|
|
266
|
+
*
|
|
267
|
+
* ```js
|
|
268
|
+
* const { Connection } = require('tedious');
|
|
269
|
+
*
|
|
270
|
+
* const config = {
|
|
271
|
+
* "authentication": {
|
|
272
|
+
* ...,
|
|
273
|
+
* "options": {...}
|
|
274
|
+
* },
|
|
275
|
+
* "options": {...}
|
|
276
|
+
* };
|
|
277
|
+
*
|
|
278
|
+
* const connection = new Connection(config);
|
|
279
|
+
* ```
|
|
280
|
+
*
|
|
281
|
+
* @param config
|
|
282
|
+
*/
|
|
283
|
+
constructor(config) {
|
|
284
|
+
super();
|
|
285
|
+
if (typeof config !== 'object' || config === null) {
|
|
286
|
+
throw new TypeError('The "config" argument is required and must be of type Object.');
|
|
287
|
+
}
|
|
288
|
+
if (typeof config.server !== 'string') {
|
|
289
|
+
throw new TypeError('The "config.server" property is required and must be of type string.');
|
|
290
|
+
}
|
|
291
|
+
this.fedAuthRequired = false;
|
|
292
|
+
let authentication;
|
|
293
|
+
if (config.authentication !== undefined) {
|
|
294
|
+
if (typeof config.authentication !== 'object' || config.authentication === null) {
|
|
295
|
+
throw new TypeError('The "config.authentication" property must be of type Object.');
|
|
296
|
+
}
|
|
297
|
+
const type = config.authentication.type;
|
|
298
|
+
const options = config.authentication.options === undefined ? {} : config.authentication.options;
|
|
299
|
+
if (typeof type !== 'string') {
|
|
300
|
+
throw new TypeError('The "config.authentication.type" property must be of type string.');
|
|
301
|
+
}
|
|
302
|
+
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') {
|
|
303
|
+
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".');
|
|
304
|
+
}
|
|
305
|
+
if (typeof options !== 'object' || options === null) {
|
|
306
|
+
throw new TypeError('The "config.authentication.options" property must be of type object.');
|
|
307
|
+
}
|
|
308
|
+
if (type === 'ntlm') {
|
|
309
|
+
if (typeof options.domain !== 'string') {
|
|
310
|
+
throw new TypeError('The "config.authentication.options.domain" property must be of type string.');
|
|
311
|
+
}
|
|
312
|
+
if (options.userName !== undefined && typeof options.userName !== 'string') {
|
|
313
|
+
throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
|
314
|
+
}
|
|
315
|
+
if (options.password !== undefined && typeof options.password !== 'string') {
|
|
316
|
+
throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
|
317
|
+
}
|
|
318
|
+
authentication = {
|
|
319
|
+
type: 'ntlm',
|
|
320
|
+
options: {
|
|
321
|
+
userName: options.userName,
|
|
322
|
+
password: options.password,
|
|
323
|
+
domain: options.domain && options.domain.toUpperCase()
|
|
324
|
+
}
|
|
325
|
+
};
|
|
326
|
+
} else if (type === 'token-credential') {
|
|
327
|
+
if (!(0, _coreAuth.isTokenCredential)(options.credential)) {
|
|
328
|
+
throw new TypeError('The "config.authentication.options.credential" property must be an instance of the token credential class.');
|
|
329
|
+
}
|
|
330
|
+
authentication = {
|
|
331
|
+
type: 'token-credential',
|
|
332
|
+
options: {
|
|
333
|
+
credential: options.credential
|
|
334
|
+
}
|
|
335
|
+
};
|
|
336
|
+
} else if (type === 'azure-active-directory-password') {
|
|
337
|
+
if (typeof options.clientId !== 'string') {
|
|
338
|
+
throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
|
339
|
+
}
|
|
340
|
+
if (options.userName !== undefined && typeof options.userName !== 'string') {
|
|
341
|
+
throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
|
342
|
+
}
|
|
343
|
+
if (options.password !== undefined && typeof options.password !== 'string') {
|
|
344
|
+
throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
|
345
|
+
}
|
|
346
|
+
if (options.tenantId !== undefined && typeof options.tenantId !== 'string') {
|
|
347
|
+
throw new TypeError('The "config.authentication.options.tenantId" property must be of type string.');
|
|
348
|
+
}
|
|
349
|
+
authentication = {
|
|
350
|
+
type: 'azure-active-directory-password',
|
|
351
|
+
options: {
|
|
352
|
+
userName: options.userName,
|
|
353
|
+
password: options.password,
|
|
354
|
+
tenantId: options.tenantId,
|
|
355
|
+
clientId: options.clientId
|
|
356
|
+
}
|
|
357
|
+
};
|
|
358
|
+
} else if (type === 'azure-active-directory-access-token') {
|
|
359
|
+
if (typeof options.token !== 'string') {
|
|
360
|
+
throw new TypeError('The "config.authentication.options.token" property must be of type string.');
|
|
361
|
+
}
|
|
362
|
+
authentication = {
|
|
363
|
+
type: 'azure-active-directory-access-token',
|
|
364
|
+
options: {
|
|
365
|
+
token: options.token
|
|
366
|
+
}
|
|
367
|
+
};
|
|
368
|
+
} else if (type === 'azure-active-directory-msi-vm') {
|
|
369
|
+
if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
|
370
|
+
throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
|
371
|
+
}
|
|
372
|
+
authentication = {
|
|
373
|
+
type: 'azure-active-directory-msi-vm',
|
|
374
|
+
options: {
|
|
375
|
+
clientId: options.clientId
|
|
376
|
+
}
|
|
377
|
+
};
|
|
378
|
+
} else if (type === 'azure-active-directory-default') {
|
|
379
|
+
if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
|
380
|
+
throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
|
381
|
+
}
|
|
382
|
+
authentication = {
|
|
383
|
+
type: 'azure-active-directory-default',
|
|
384
|
+
options: {
|
|
385
|
+
clientId: options.clientId
|
|
386
|
+
}
|
|
387
|
+
};
|
|
388
|
+
} else if (type === 'azure-active-directory-msi-app-service') {
|
|
389
|
+
if (options.clientId !== undefined && typeof options.clientId !== 'string') {
|
|
390
|
+
throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
|
391
|
+
}
|
|
392
|
+
authentication = {
|
|
393
|
+
type: 'azure-active-directory-msi-app-service',
|
|
394
|
+
options: {
|
|
395
|
+
clientId: options.clientId
|
|
396
|
+
}
|
|
397
|
+
};
|
|
398
|
+
} else if (type === 'azure-active-directory-service-principal-secret') {
|
|
399
|
+
if (typeof options.clientId !== 'string') {
|
|
400
|
+
throw new TypeError('The "config.authentication.options.clientId" property must be of type string.');
|
|
401
|
+
}
|
|
402
|
+
if (typeof options.clientSecret !== 'string') {
|
|
403
|
+
throw new TypeError('The "config.authentication.options.clientSecret" property must be of type string.');
|
|
404
|
+
}
|
|
405
|
+
if (typeof options.tenantId !== 'string') {
|
|
406
|
+
throw new TypeError('The "config.authentication.options.tenantId" property must be of type string.');
|
|
407
|
+
}
|
|
408
|
+
authentication = {
|
|
409
|
+
type: 'azure-active-directory-service-principal-secret',
|
|
410
|
+
options: {
|
|
411
|
+
clientId: options.clientId,
|
|
412
|
+
clientSecret: options.clientSecret,
|
|
413
|
+
tenantId: options.tenantId
|
|
414
|
+
}
|
|
415
|
+
};
|
|
416
|
+
} else {
|
|
417
|
+
if (options.userName !== undefined && typeof options.userName !== 'string') {
|
|
418
|
+
throw new TypeError('The "config.authentication.options.userName" property must be of type string.');
|
|
419
|
+
}
|
|
420
|
+
if (options.password !== undefined && typeof options.password !== 'string') {
|
|
421
|
+
throw new TypeError('The "config.authentication.options.password" property must be of type string.');
|
|
422
|
+
}
|
|
423
|
+
authentication = {
|
|
424
|
+
type: 'default',
|
|
425
|
+
options: {
|
|
426
|
+
userName: options.userName,
|
|
427
|
+
password: options.password
|
|
428
|
+
}
|
|
429
|
+
};
|
|
430
|
+
}
|
|
431
|
+
} else {
|
|
432
|
+
authentication = {
|
|
433
|
+
type: 'default',
|
|
434
|
+
options: {
|
|
435
|
+
userName: undefined,
|
|
436
|
+
password: undefined
|
|
437
|
+
}
|
|
438
|
+
};
|
|
439
|
+
}
|
|
440
|
+
this.config = {
|
|
441
|
+
server: config.server,
|
|
442
|
+
authentication: authentication,
|
|
443
|
+
options: {
|
|
444
|
+
abortTransactionOnError: false,
|
|
445
|
+
appName: undefined,
|
|
446
|
+
camelCaseColumns: false,
|
|
447
|
+
cancelTimeout: DEFAULT_CANCEL_TIMEOUT,
|
|
448
|
+
columnEncryptionKeyCacheTTL: 2 * 60 * 60 * 1000,
|
|
449
|
+
// Units: milliseconds
|
|
450
|
+
columnEncryptionSetting: false,
|
|
451
|
+
columnNameReplacer: undefined,
|
|
452
|
+
connectionRetryInterval: DEFAULT_CONNECT_RETRY_INTERVAL,
|
|
453
|
+
connectTimeout: DEFAULT_CONNECT_TIMEOUT,
|
|
454
|
+
connector: undefined,
|
|
455
|
+
connectionIsolationLevel: _transaction.ISOLATION_LEVEL.READ_COMMITTED,
|
|
456
|
+
cryptoCredentialsDetails: {},
|
|
457
|
+
database: undefined,
|
|
458
|
+
datefirst: DEFAULT_DATEFIRST,
|
|
459
|
+
dateFormat: DEFAULT_DATEFORMAT,
|
|
460
|
+
debug: {
|
|
461
|
+
data: false,
|
|
462
|
+
packet: false,
|
|
463
|
+
payload: false,
|
|
464
|
+
token: false
|
|
465
|
+
},
|
|
466
|
+
enableAnsiNull: true,
|
|
467
|
+
enableAnsiNullDefault: true,
|
|
468
|
+
enableAnsiPadding: true,
|
|
469
|
+
enableAnsiWarnings: true,
|
|
470
|
+
enableArithAbort: true,
|
|
471
|
+
enableConcatNullYieldsNull: true,
|
|
472
|
+
enableCursorCloseOnCommit: null,
|
|
473
|
+
enableImplicitTransactions: false,
|
|
474
|
+
enableNumericRoundabort: false,
|
|
475
|
+
enableQuotedIdentifier: true,
|
|
476
|
+
encrypt: true,
|
|
477
|
+
fallbackToDefaultDb: false,
|
|
478
|
+
encryptionKeyStoreProviders: undefined,
|
|
479
|
+
instanceName: undefined,
|
|
480
|
+
isolationLevel: _transaction.ISOLATION_LEVEL.READ_COMMITTED,
|
|
481
|
+
language: DEFAULT_LANGUAGE,
|
|
482
|
+
localAddress: undefined,
|
|
483
|
+
maxRetriesOnTransientErrors: 3,
|
|
484
|
+
multiSubnetFailover: false,
|
|
485
|
+
packetSize: DEFAULT_PACKET_SIZE,
|
|
486
|
+
port: DEFAULT_PORT,
|
|
487
|
+
readOnlyIntent: false,
|
|
488
|
+
requestTimeout: DEFAULT_CLIENT_REQUEST_TIMEOUT,
|
|
489
|
+
rowCollectionOnDone: false,
|
|
490
|
+
rowCollectionOnRequestCompletion: false,
|
|
491
|
+
serverName: undefined,
|
|
492
|
+
serverSupportsColumnEncryption: false,
|
|
493
|
+
tdsVersion: DEFAULT_TDS_VERSION,
|
|
494
|
+
textsize: DEFAULT_TEXTSIZE,
|
|
495
|
+
trustedServerNameAE: undefined,
|
|
496
|
+
trustServerCertificate: false,
|
|
497
|
+
useColumnNames: false,
|
|
498
|
+
useUTC: true,
|
|
499
|
+
workstationId: undefined,
|
|
500
|
+
lowerCaseGuids: false
|
|
501
|
+
}
|
|
502
|
+
};
|
|
503
|
+
if (config.options) {
|
|
504
|
+
if (config.options.port && config.options.instanceName) {
|
|
505
|
+
throw new Error('Port and instanceName are mutually exclusive, but ' + config.options.port + ' and ' + config.options.instanceName + ' provided');
|
|
506
|
+
}
|
|
507
|
+
if (config.options.abortTransactionOnError !== undefined) {
|
|
508
|
+
if (typeof config.options.abortTransactionOnError !== 'boolean' && config.options.abortTransactionOnError !== null) {
|
|
509
|
+
throw new TypeError('The "config.options.abortTransactionOnError" property must be of type string or null.');
|
|
510
|
+
}
|
|
511
|
+
this.config.options.abortTransactionOnError = config.options.abortTransactionOnError;
|
|
512
|
+
}
|
|
513
|
+
if (config.options.appName !== undefined) {
|
|
514
|
+
if (typeof config.options.appName !== 'string') {
|
|
515
|
+
throw new TypeError('The "config.options.appName" property must be of type string.');
|
|
516
|
+
}
|
|
517
|
+
this.config.options.appName = config.options.appName;
|
|
518
|
+
}
|
|
519
|
+
if (config.options.camelCaseColumns !== undefined) {
|
|
520
|
+
if (typeof config.options.camelCaseColumns !== 'boolean') {
|
|
521
|
+
throw new TypeError('The "config.options.camelCaseColumns" property must be of type boolean.');
|
|
522
|
+
}
|
|
523
|
+
this.config.options.camelCaseColumns = config.options.camelCaseColumns;
|
|
524
|
+
}
|
|
525
|
+
if (config.options.cancelTimeout !== undefined) {
|
|
526
|
+
if (typeof config.options.cancelTimeout !== 'number') {
|
|
527
|
+
throw new TypeError('The "config.options.cancelTimeout" property must be of type number.');
|
|
528
|
+
}
|
|
529
|
+
this.config.options.cancelTimeout = config.options.cancelTimeout;
|
|
530
|
+
}
|
|
531
|
+
if (config.options.columnNameReplacer) {
|
|
532
|
+
if (typeof config.options.columnNameReplacer !== 'function') {
|
|
533
|
+
throw new TypeError('The "config.options.cancelTimeout" property must be of type function.');
|
|
534
|
+
}
|
|
535
|
+
this.config.options.columnNameReplacer = config.options.columnNameReplacer;
|
|
536
|
+
}
|
|
537
|
+
if (config.options.connectionIsolationLevel !== undefined) {
|
|
538
|
+
(0, _transaction.assertValidIsolationLevel)(config.options.connectionIsolationLevel, 'config.options.connectionIsolationLevel');
|
|
539
|
+
this.config.options.connectionIsolationLevel = config.options.connectionIsolationLevel;
|
|
540
|
+
}
|
|
541
|
+
if (config.options.connectTimeout !== undefined) {
|
|
542
|
+
if (typeof config.options.connectTimeout !== 'number') {
|
|
543
|
+
throw new TypeError('The "config.options.connectTimeout" property must be of type number.');
|
|
544
|
+
}
|
|
545
|
+
this.config.options.connectTimeout = config.options.connectTimeout;
|
|
546
|
+
}
|
|
547
|
+
if (config.options.connector !== undefined) {
|
|
548
|
+
if (typeof config.options.connector !== 'function') {
|
|
549
|
+
throw new TypeError('The "config.options.connector" property must be a function.');
|
|
550
|
+
}
|
|
551
|
+
this.config.options.connector = config.options.connector;
|
|
552
|
+
}
|
|
553
|
+
if (config.options.cryptoCredentialsDetails !== undefined) {
|
|
554
|
+
if (typeof config.options.cryptoCredentialsDetails !== 'object' || config.options.cryptoCredentialsDetails === null) {
|
|
555
|
+
throw new TypeError('The "config.options.cryptoCredentialsDetails" property must be of type Object.');
|
|
556
|
+
}
|
|
557
|
+
this.config.options.cryptoCredentialsDetails = config.options.cryptoCredentialsDetails;
|
|
558
|
+
}
|
|
559
|
+
if (config.options.database !== undefined) {
|
|
560
|
+
if (typeof config.options.database !== 'string') {
|
|
561
|
+
throw new TypeError('The "config.options.database" property must be of type string.');
|
|
562
|
+
}
|
|
563
|
+
this.config.options.database = config.options.database;
|
|
564
|
+
}
|
|
565
|
+
if (config.options.datefirst !== undefined) {
|
|
566
|
+
if (typeof config.options.datefirst !== 'number' && config.options.datefirst !== null) {
|
|
567
|
+
throw new TypeError('The "config.options.datefirst" property must be of type number.');
|
|
568
|
+
}
|
|
569
|
+
if (config.options.datefirst !== null && (config.options.datefirst < 1 || config.options.datefirst > 7)) {
|
|
570
|
+
throw new RangeError('The "config.options.datefirst" property must be >= 1 and <= 7');
|
|
571
|
+
}
|
|
572
|
+
this.config.options.datefirst = config.options.datefirst;
|
|
573
|
+
}
|
|
574
|
+
if (config.options.dateFormat !== undefined) {
|
|
575
|
+
if (typeof config.options.dateFormat !== 'string' && config.options.dateFormat !== null) {
|
|
576
|
+
throw new TypeError('The "config.options.dateFormat" property must be of type string or null.');
|
|
577
|
+
}
|
|
578
|
+
this.config.options.dateFormat = config.options.dateFormat;
|
|
579
|
+
}
|
|
580
|
+
if (config.options.debug) {
|
|
581
|
+
if (config.options.debug.data !== undefined) {
|
|
582
|
+
if (typeof config.options.debug.data !== 'boolean') {
|
|
583
|
+
throw new TypeError('The "config.options.debug.data" property must be of type boolean.');
|
|
584
|
+
}
|
|
585
|
+
this.config.options.debug.data = config.options.debug.data;
|
|
586
|
+
}
|
|
587
|
+
if (config.options.debug.packet !== undefined) {
|
|
588
|
+
if (typeof config.options.debug.packet !== 'boolean') {
|
|
589
|
+
throw new TypeError('The "config.options.debug.packet" property must be of type boolean.');
|
|
590
|
+
}
|
|
591
|
+
this.config.options.debug.packet = config.options.debug.packet;
|
|
592
|
+
}
|
|
593
|
+
if (config.options.debug.payload !== undefined) {
|
|
594
|
+
if (typeof config.options.debug.payload !== 'boolean') {
|
|
595
|
+
throw new TypeError('The "config.options.debug.payload" property must be of type boolean.');
|
|
596
|
+
}
|
|
597
|
+
this.config.options.debug.payload = config.options.debug.payload;
|
|
598
|
+
}
|
|
599
|
+
if (config.options.debug.token !== undefined) {
|
|
600
|
+
if (typeof config.options.debug.token !== 'boolean') {
|
|
601
|
+
throw new TypeError('The "config.options.debug.token" property must be of type boolean.');
|
|
602
|
+
}
|
|
603
|
+
this.config.options.debug.token = config.options.debug.token;
|
|
604
|
+
}
|
|
605
|
+
}
|
|
606
|
+
if (config.options.enableAnsiNull !== undefined) {
|
|
607
|
+
if (typeof config.options.enableAnsiNull !== 'boolean' && config.options.enableAnsiNull !== null) {
|
|
608
|
+
throw new TypeError('The "config.options.enableAnsiNull" property must be of type boolean or null.');
|
|
609
|
+
}
|
|
610
|
+
this.config.options.enableAnsiNull = config.options.enableAnsiNull;
|
|
611
|
+
}
|
|
612
|
+
if (config.options.enableAnsiNullDefault !== undefined) {
|
|
613
|
+
if (typeof config.options.enableAnsiNullDefault !== 'boolean' && config.options.enableAnsiNullDefault !== null) {
|
|
614
|
+
throw new TypeError('The "config.options.enableAnsiNullDefault" property must be of type boolean or null.');
|
|
615
|
+
}
|
|
616
|
+
this.config.options.enableAnsiNullDefault = config.options.enableAnsiNullDefault;
|
|
617
|
+
}
|
|
618
|
+
if (config.options.enableAnsiPadding !== undefined) {
|
|
619
|
+
if (typeof config.options.enableAnsiPadding !== 'boolean' && config.options.enableAnsiPadding !== null) {
|
|
620
|
+
throw new TypeError('The "config.options.enableAnsiPadding" property must be of type boolean or null.');
|
|
621
|
+
}
|
|
622
|
+
this.config.options.enableAnsiPadding = config.options.enableAnsiPadding;
|
|
623
|
+
}
|
|
624
|
+
if (config.options.enableAnsiWarnings !== undefined) {
|
|
625
|
+
if (typeof config.options.enableAnsiWarnings !== 'boolean' && config.options.enableAnsiWarnings !== null) {
|
|
626
|
+
throw new TypeError('The "config.options.enableAnsiWarnings" property must be of type boolean or null.');
|
|
627
|
+
}
|
|
628
|
+
this.config.options.enableAnsiWarnings = config.options.enableAnsiWarnings;
|
|
629
|
+
}
|
|
630
|
+
if (config.options.enableArithAbort !== undefined) {
|
|
631
|
+
if (typeof config.options.enableArithAbort !== 'boolean' && config.options.enableArithAbort !== null) {
|
|
632
|
+
throw new TypeError('The "config.options.enableArithAbort" property must be of type boolean or null.');
|
|
633
|
+
}
|
|
634
|
+
this.config.options.enableArithAbort = config.options.enableArithAbort;
|
|
635
|
+
}
|
|
636
|
+
if (config.options.enableConcatNullYieldsNull !== undefined) {
|
|
637
|
+
if (typeof config.options.enableConcatNullYieldsNull !== 'boolean' && config.options.enableConcatNullYieldsNull !== null) {
|
|
638
|
+
throw new TypeError('The "config.options.enableConcatNullYieldsNull" property must be of type boolean or null.');
|
|
639
|
+
}
|
|
640
|
+
this.config.options.enableConcatNullYieldsNull = config.options.enableConcatNullYieldsNull;
|
|
641
|
+
}
|
|
642
|
+
if (config.options.enableCursorCloseOnCommit !== undefined) {
|
|
643
|
+
if (typeof config.options.enableCursorCloseOnCommit !== 'boolean' && config.options.enableCursorCloseOnCommit !== null) {
|
|
644
|
+
throw new TypeError('The "config.options.enableCursorCloseOnCommit" property must be of type boolean or null.');
|
|
645
|
+
}
|
|
646
|
+
this.config.options.enableCursorCloseOnCommit = config.options.enableCursorCloseOnCommit;
|
|
647
|
+
}
|
|
648
|
+
if (config.options.enableImplicitTransactions !== undefined) {
|
|
649
|
+
if (typeof config.options.enableImplicitTransactions !== 'boolean' && config.options.enableImplicitTransactions !== null) {
|
|
650
|
+
throw new TypeError('The "config.options.enableImplicitTransactions" property must be of type boolean or null.');
|
|
651
|
+
}
|
|
652
|
+
this.config.options.enableImplicitTransactions = config.options.enableImplicitTransactions;
|
|
653
|
+
}
|
|
654
|
+
if (config.options.enableNumericRoundabort !== undefined) {
|
|
655
|
+
if (typeof config.options.enableNumericRoundabort !== 'boolean' && config.options.enableNumericRoundabort !== null) {
|
|
656
|
+
throw new TypeError('The "config.options.enableNumericRoundabort" property must be of type boolean or null.');
|
|
657
|
+
}
|
|
658
|
+
this.config.options.enableNumericRoundabort = config.options.enableNumericRoundabort;
|
|
659
|
+
}
|
|
660
|
+
if (config.options.enableQuotedIdentifier !== undefined) {
|
|
661
|
+
if (typeof config.options.enableQuotedIdentifier !== 'boolean' && config.options.enableQuotedIdentifier !== null) {
|
|
662
|
+
throw new TypeError('The "config.options.enableQuotedIdentifier" property must be of type boolean or null.');
|
|
663
|
+
}
|
|
664
|
+
this.config.options.enableQuotedIdentifier = config.options.enableQuotedIdentifier;
|
|
665
|
+
}
|
|
666
|
+
if (config.options.encrypt !== undefined) {
|
|
667
|
+
if (typeof config.options.encrypt !== 'boolean') {
|
|
668
|
+
if (config.options.encrypt !== 'strict') {
|
|
669
|
+
throw new TypeError('The "encrypt" property must be set to "strict", or of type boolean.');
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
this.config.options.encrypt = config.options.encrypt;
|
|
673
|
+
}
|
|
674
|
+
if (config.options.fallbackToDefaultDb !== undefined) {
|
|
675
|
+
if (typeof config.options.fallbackToDefaultDb !== 'boolean') {
|
|
676
|
+
throw new TypeError('The "config.options.fallbackToDefaultDb" property must be of type boolean.');
|
|
677
|
+
}
|
|
678
|
+
this.config.options.fallbackToDefaultDb = config.options.fallbackToDefaultDb;
|
|
679
|
+
}
|
|
680
|
+
if (config.options.instanceName !== undefined) {
|
|
681
|
+
if (typeof config.options.instanceName !== 'string') {
|
|
682
|
+
throw new TypeError('The "config.options.instanceName" property must be of type string.');
|
|
683
|
+
}
|
|
684
|
+
this.config.options.instanceName = config.options.instanceName;
|
|
685
|
+
this.config.options.port = undefined;
|
|
686
|
+
}
|
|
687
|
+
if (config.options.isolationLevel !== undefined) {
|
|
688
|
+
(0, _transaction.assertValidIsolationLevel)(config.options.isolationLevel, 'config.options.isolationLevel');
|
|
689
|
+
this.config.options.isolationLevel = config.options.isolationLevel;
|
|
690
|
+
}
|
|
691
|
+
if (config.options.language !== undefined) {
|
|
692
|
+
if (typeof config.options.language !== 'string' && config.options.language !== null) {
|
|
693
|
+
throw new TypeError('The "config.options.language" property must be of type string or null.');
|
|
694
|
+
}
|
|
695
|
+
this.config.options.language = config.options.language;
|
|
696
|
+
}
|
|
697
|
+
if (config.options.localAddress !== undefined) {
|
|
698
|
+
if (typeof config.options.localAddress !== 'string') {
|
|
699
|
+
throw new TypeError('The "config.options.localAddress" property must be of type string.');
|
|
700
|
+
}
|
|
701
|
+
this.config.options.localAddress = config.options.localAddress;
|
|
702
|
+
}
|
|
703
|
+
if (config.options.multiSubnetFailover !== undefined) {
|
|
704
|
+
if (typeof config.options.multiSubnetFailover !== 'boolean') {
|
|
705
|
+
throw new TypeError('The "config.options.multiSubnetFailover" property must be of type boolean.');
|
|
706
|
+
}
|
|
707
|
+
this.config.options.multiSubnetFailover = config.options.multiSubnetFailover;
|
|
708
|
+
}
|
|
709
|
+
if (config.options.packetSize !== undefined) {
|
|
710
|
+
if (typeof config.options.packetSize !== 'number') {
|
|
711
|
+
throw new TypeError('The "config.options.packetSize" property must be of type number.');
|
|
712
|
+
}
|
|
713
|
+
this.config.options.packetSize = config.options.packetSize;
|
|
714
|
+
}
|
|
715
|
+
if (config.options.port !== undefined) {
|
|
716
|
+
if (typeof config.options.port !== 'number') {
|
|
717
|
+
throw new TypeError('The "config.options.port" property must be of type number.');
|
|
718
|
+
}
|
|
719
|
+
if (config.options.port <= 0 || config.options.port >= 65536) {
|
|
720
|
+
throw new RangeError('The "config.options.port" property must be > 0 and < 65536');
|
|
721
|
+
}
|
|
722
|
+
this.config.options.port = config.options.port;
|
|
723
|
+
this.config.options.instanceName = undefined;
|
|
724
|
+
}
|
|
725
|
+
if (config.options.readOnlyIntent !== undefined) {
|
|
726
|
+
if (typeof config.options.readOnlyIntent !== 'boolean') {
|
|
727
|
+
throw new TypeError('The "config.options.readOnlyIntent" property must be of type boolean.');
|
|
728
|
+
}
|
|
729
|
+
this.config.options.readOnlyIntent = config.options.readOnlyIntent;
|
|
730
|
+
}
|
|
731
|
+
if (config.options.requestTimeout !== undefined) {
|
|
732
|
+
if (typeof config.options.requestTimeout !== 'number') {
|
|
733
|
+
throw new TypeError('The "config.options.requestTimeout" property must be of type number.');
|
|
734
|
+
}
|
|
735
|
+
this.config.options.requestTimeout = config.options.requestTimeout;
|
|
736
|
+
}
|
|
737
|
+
if (config.options.maxRetriesOnTransientErrors !== undefined) {
|
|
738
|
+
if (typeof config.options.maxRetriesOnTransientErrors !== 'number') {
|
|
739
|
+
throw new TypeError('The "config.options.maxRetriesOnTransientErrors" property must be of type number.');
|
|
740
|
+
}
|
|
741
|
+
if (config.options.maxRetriesOnTransientErrors < 0) {
|
|
742
|
+
throw new TypeError('The "config.options.maxRetriesOnTransientErrors" property must be equal or greater than 0.');
|
|
743
|
+
}
|
|
744
|
+
this.config.options.maxRetriesOnTransientErrors = config.options.maxRetriesOnTransientErrors;
|
|
745
|
+
}
|
|
746
|
+
if (config.options.connectionRetryInterval !== undefined) {
|
|
747
|
+
if (typeof config.options.connectionRetryInterval !== 'number') {
|
|
748
|
+
throw new TypeError('The "config.options.connectionRetryInterval" property must be of type number.');
|
|
749
|
+
}
|
|
750
|
+
if (config.options.connectionRetryInterval <= 0) {
|
|
751
|
+
throw new TypeError('The "config.options.connectionRetryInterval" property must be greater than 0.');
|
|
752
|
+
}
|
|
753
|
+
this.config.options.connectionRetryInterval = config.options.connectionRetryInterval;
|
|
754
|
+
}
|
|
755
|
+
if (config.options.rowCollectionOnDone !== undefined) {
|
|
756
|
+
if (typeof config.options.rowCollectionOnDone !== 'boolean') {
|
|
757
|
+
throw new TypeError('The "config.options.rowCollectionOnDone" property must be of type boolean.');
|
|
758
|
+
}
|
|
759
|
+
this.config.options.rowCollectionOnDone = config.options.rowCollectionOnDone;
|
|
760
|
+
}
|
|
761
|
+
if (config.options.rowCollectionOnRequestCompletion !== undefined) {
|
|
762
|
+
if (typeof config.options.rowCollectionOnRequestCompletion !== 'boolean') {
|
|
763
|
+
throw new TypeError('The "config.options.rowCollectionOnRequestCompletion" property must be of type boolean.');
|
|
764
|
+
}
|
|
765
|
+
this.config.options.rowCollectionOnRequestCompletion = config.options.rowCollectionOnRequestCompletion;
|
|
766
|
+
}
|
|
767
|
+
if (config.options.tdsVersion !== undefined) {
|
|
768
|
+
if (typeof config.options.tdsVersion !== 'string') {
|
|
769
|
+
throw new TypeError('The "config.options.tdsVersion" property must be of type string.');
|
|
770
|
+
}
|
|
771
|
+
this.config.options.tdsVersion = config.options.tdsVersion;
|
|
772
|
+
}
|
|
773
|
+
if (config.options.textsize !== undefined) {
|
|
774
|
+
if (typeof config.options.textsize !== 'number' && config.options.textsize !== null) {
|
|
775
|
+
throw new TypeError('The "config.options.textsize" property must be of type number or null.');
|
|
776
|
+
}
|
|
777
|
+
if (config.options.textsize > 2147483647) {
|
|
778
|
+
throw new TypeError('The "config.options.textsize" can\'t be greater than 2147483647.');
|
|
779
|
+
} else if (config.options.textsize < -1) {
|
|
780
|
+
throw new TypeError('The "config.options.textsize" can\'t be smaller than -1.');
|
|
781
|
+
}
|
|
782
|
+
this.config.options.textsize = config.options.textsize | 0;
|
|
783
|
+
}
|
|
784
|
+
if (config.options.trustServerCertificate !== undefined) {
|
|
785
|
+
if (typeof config.options.trustServerCertificate !== 'boolean') {
|
|
786
|
+
throw new TypeError('The "config.options.trustServerCertificate" property must be of type boolean.');
|
|
787
|
+
}
|
|
788
|
+
this.config.options.trustServerCertificate = config.options.trustServerCertificate;
|
|
789
|
+
}
|
|
790
|
+
if (config.options.serverName !== undefined) {
|
|
791
|
+
if (typeof config.options.serverName !== 'string') {
|
|
792
|
+
throw new TypeError('The "config.options.serverName" property must be of type string.');
|
|
793
|
+
}
|
|
794
|
+
this.config.options.serverName = config.options.serverName;
|
|
795
|
+
}
|
|
796
|
+
if (config.options.useColumnNames !== undefined) {
|
|
797
|
+
if (typeof config.options.useColumnNames !== 'boolean') {
|
|
798
|
+
throw new TypeError('The "config.options.useColumnNames" property must be of type boolean.');
|
|
799
|
+
}
|
|
800
|
+
this.config.options.useColumnNames = config.options.useColumnNames;
|
|
801
|
+
}
|
|
802
|
+
if (config.options.useUTC !== undefined) {
|
|
803
|
+
if (typeof config.options.useUTC !== 'boolean') {
|
|
804
|
+
throw new TypeError('The "config.options.useUTC" property must be of type boolean.');
|
|
805
|
+
}
|
|
806
|
+
this.config.options.useUTC = config.options.useUTC;
|
|
807
|
+
}
|
|
808
|
+
if (config.options.workstationId !== undefined) {
|
|
809
|
+
if (typeof config.options.workstationId !== 'string') {
|
|
810
|
+
throw new TypeError('The "config.options.workstationId" property must be of type string.');
|
|
811
|
+
}
|
|
812
|
+
this.config.options.workstationId = config.options.workstationId;
|
|
813
|
+
}
|
|
814
|
+
if (config.options.lowerCaseGuids !== undefined) {
|
|
815
|
+
if (typeof config.options.lowerCaseGuids !== 'boolean') {
|
|
816
|
+
throw new TypeError('The "config.options.lowerCaseGuids" property must be of type boolean.');
|
|
817
|
+
}
|
|
818
|
+
this.config.options.lowerCaseGuids = config.options.lowerCaseGuids;
|
|
819
|
+
}
|
|
820
|
+
}
|
|
821
|
+
this.secureContextOptions = this.config.options.cryptoCredentialsDetails;
|
|
822
|
+
if (this.secureContextOptions.secureOptions === undefined) {
|
|
823
|
+
// If the caller has not specified their own `secureOptions`,
|
|
824
|
+
// we set `SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS` here.
|
|
825
|
+
// Older SQL Server instances running on older Windows versions have
|
|
826
|
+
// trouble with the BEAST workaround in OpenSSL.
|
|
827
|
+
// As BEAST is a browser specific exploit, we can just disable this option here.
|
|
828
|
+
this.secureContextOptions = Object.create(this.secureContextOptions, {
|
|
829
|
+
secureOptions: {
|
|
830
|
+
value: _constants.default.SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS
|
|
831
|
+
}
|
|
832
|
+
});
|
|
833
|
+
}
|
|
834
|
+
this.debug = this.createDebug();
|
|
835
|
+
this.inTransaction = false;
|
|
836
|
+
this.transactionDescriptors = [Buffer.from([0, 0, 0, 0, 0, 0, 0, 0])];
|
|
837
|
+
|
|
838
|
+
// 'beginTransaction', 'commitTransaction' and 'rollbackTransaction'
|
|
839
|
+
// events are utilized to maintain inTransaction property state which in
|
|
840
|
+
// turn is used in managing transactions. These events are only fired for
|
|
841
|
+
// TDS version 7.2 and beyond. The properties below are used to emulate
|
|
842
|
+
// equivalent behavior for TDS versions before 7.2.
|
|
843
|
+
this.transactionDepth = 0;
|
|
844
|
+
this.isSqlBatch = false;
|
|
845
|
+
this.closed = false;
|
|
846
|
+
this.messageBuffer = Buffer.alloc(0);
|
|
847
|
+
this.curTransientRetryCount = 0;
|
|
848
|
+
this.transientErrorLookup = new _transientErrorLookup.TransientErrorLookup();
|
|
849
|
+
this.state = this.STATE.INITIALIZED;
|
|
850
|
+
this._cancelAfterRequestSent = () => {
|
|
851
|
+
this.messageIo.sendMessage(_packet.TYPE.ATTENTION);
|
|
852
|
+
this.createCancelTimer();
|
|
853
|
+
};
|
|
854
|
+
this._onSocketClose = () => {
|
|
855
|
+
this.socketClose();
|
|
856
|
+
};
|
|
857
|
+
this._onSocketEnd = () => {
|
|
858
|
+
this.socketEnd();
|
|
859
|
+
};
|
|
860
|
+
this._onSocketError = error => {
|
|
861
|
+
this.dispatchEvent('socketError', error);
|
|
862
|
+
process.nextTick(() => {
|
|
863
|
+
this.emit('error', this.wrapSocketError(error));
|
|
864
|
+
});
|
|
865
|
+
};
|
|
866
|
+
}
|
|
867
|
+
connect(connectListener) {
|
|
868
|
+
if (this.state !== this.STATE.INITIALIZED) {
|
|
869
|
+
throw new _errors.ConnectionError('`.connect` can not be called on a Connection in `' + this.state.name + '` state.');
|
|
870
|
+
}
|
|
871
|
+
if (connectListener) {
|
|
872
|
+
const onConnect = err => {
|
|
873
|
+
this.removeListener('error', onError);
|
|
874
|
+
connectListener(err);
|
|
875
|
+
};
|
|
876
|
+
const onError = err => {
|
|
877
|
+
this.removeListener('connect', onConnect);
|
|
878
|
+
connectListener(err);
|
|
879
|
+
};
|
|
880
|
+
this.once('connect', onConnect);
|
|
881
|
+
this.once('error', onError);
|
|
882
|
+
}
|
|
883
|
+
this.transitionTo(this.STATE.CONNECTING);
|
|
884
|
+
this.initialiseConnection().then(() => {
|
|
885
|
+
process.nextTick(() => {
|
|
886
|
+
this.emit('connect');
|
|
887
|
+
});
|
|
888
|
+
}, err => {
|
|
889
|
+
this.transitionTo(this.STATE.FINAL);
|
|
890
|
+
this.closed = true;
|
|
891
|
+
process.nextTick(() => {
|
|
892
|
+
this.emit('connect', err);
|
|
893
|
+
});
|
|
894
|
+
process.nextTick(() => {
|
|
895
|
+
this.emit('end');
|
|
896
|
+
});
|
|
897
|
+
});
|
|
898
|
+
}
|
|
899
|
+
|
|
900
|
+
/**
|
|
901
|
+
* The server has reported that the charset has changed.
|
|
902
|
+
*/
|
|
903
|
+
|
|
904
|
+
/**
|
|
905
|
+
* The attempt to connect and validate has completed.
|
|
906
|
+
*/
|
|
907
|
+
|
|
908
|
+
/**
|
|
909
|
+
* The server has reported that the active database has changed.
|
|
910
|
+
* This may be as a result of a successful login, or a `use` statement.
|
|
911
|
+
*/
|
|
912
|
+
|
|
913
|
+
/**
|
|
914
|
+
* A debug message is available. It may be logged or ignored.
|
|
915
|
+
*/
|
|
916
|
+
|
|
917
|
+
/**
|
|
918
|
+
* Internal error occurs.
|
|
919
|
+
*/
|
|
920
|
+
|
|
921
|
+
/**
|
|
922
|
+
* The server has issued an error message.
|
|
923
|
+
*/
|
|
924
|
+
|
|
925
|
+
/**
|
|
926
|
+
* The connection has ended.
|
|
927
|
+
*
|
|
928
|
+
* This may be as a result of the client calling [[close]], the server
|
|
929
|
+
* closing the connection, or a network error.
|
|
930
|
+
*/
|
|
931
|
+
|
|
932
|
+
/**
|
|
933
|
+
* The server has issued an information message.
|
|
934
|
+
*/
|
|
935
|
+
|
|
936
|
+
/**
|
|
937
|
+
* The server has reported that the language has changed.
|
|
938
|
+
*/
|
|
939
|
+
|
|
940
|
+
/**
|
|
941
|
+
* The connection was reset.
|
|
942
|
+
*/
|
|
943
|
+
|
|
944
|
+
/**
|
|
945
|
+
* A secure connection has been established.
|
|
946
|
+
*/
|
|
947
|
+
|
|
948
|
+
on(event, listener) {
|
|
949
|
+
return super.on(event, listener);
|
|
950
|
+
}
|
|
951
|
+
|
|
952
|
+
/**
|
|
953
|
+
* @private
|
|
954
|
+
*/
|
|
955
|
+
|
|
956
|
+
/**
|
|
957
|
+
* @private
|
|
958
|
+
*/
|
|
959
|
+
|
|
960
|
+
/**
|
|
961
|
+
* @private
|
|
962
|
+
*/
|
|
963
|
+
|
|
964
|
+
/**
|
|
965
|
+
* @private
|
|
966
|
+
*/
|
|
967
|
+
|
|
968
|
+
/**
|
|
969
|
+
* @private
|
|
970
|
+
*/
|
|
971
|
+
|
|
972
|
+
/**
|
|
973
|
+
* @private
|
|
974
|
+
*/
|
|
975
|
+
|
|
976
|
+
/**
|
|
977
|
+
* @private
|
|
978
|
+
*/
|
|
979
|
+
|
|
980
|
+
/**
|
|
981
|
+
* @private
|
|
982
|
+
*/
|
|
983
|
+
|
|
984
|
+
/**
|
|
985
|
+
* @private
|
|
986
|
+
*/
|
|
987
|
+
|
|
988
|
+
/**
|
|
989
|
+
* @private
|
|
990
|
+
*/
|
|
991
|
+
|
|
992
|
+
/**
|
|
993
|
+
* @private
|
|
994
|
+
*/
|
|
995
|
+
|
|
996
|
+
/**
|
|
997
|
+
* @private
|
|
998
|
+
*/
|
|
999
|
+
|
|
1000
|
+
/**
|
|
1001
|
+
* @private
|
|
1002
|
+
*/
|
|
1003
|
+
|
|
1004
|
+
/**
|
|
1005
|
+
* @private
|
|
1006
|
+
*/
|
|
1007
|
+
|
|
1008
|
+
/**
|
|
1009
|
+
* @private
|
|
1010
|
+
*/
|
|
1011
|
+
|
|
1012
|
+
emit(event, ...args) {
|
|
1013
|
+
return super.emit(event, ...args);
|
|
1014
|
+
}
|
|
1015
|
+
|
|
1016
|
+
/**
|
|
1017
|
+
* Closes the connection to the database.
|
|
1018
|
+
*
|
|
1019
|
+
* The [[Event_end]] will be emitted once the connection has been closed.
|
|
1020
|
+
*/
|
|
1021
|
+
close() {
|
|
1022
|
+
this.transitionTo(this.STATE.FINAL);
|
|
1023
|
+
this.cleanupConnection();
|
|
1024
|
+
}
|
|
1025
|
+
|
|
1026
|
+
/**
|
|
1027
|
+
* @private
|
|
1028
|
+
*/
|
|
1029
|
+
async initialiseConnection() {
|
|
1030
|
+
const timeoutController = new AbortController();
|
|
1031
|
+
const connectTimer = setTimeout(() => {
|
|
1032
|
+
const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\${this.config.options.instanceName}`;
|
|
1033
|
+
// If we have routing data stored, this connection has been redirected
|
|
1034
|
+
const server = this.routingData ? this.routingData.server : this.config.server;
|
|
1035
|
+
const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;
|
|
1036
|
+
// Grab the target host from the connection configuration, and from a redirect message
|
|
1037
|
+
// otherwise, leave the message empty.
|
|
1038
|
+
const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';
|
|
1039
|
+
const message = `Failed to connect to ${server}${port}${routingMessage} in ${this.config.options.connectTimeout}ms`;
|
|
1040
|
+
this.debug.log(message);
|
|
1041
|
+
timeoutController.abort(new _errors.ConnectionError(message, 'ETIMEOUT'));
|
|
1042
|
+
}, this.config.options.connectTimeout);
|
|
1043
|
+
try {
|
|
1044
|
+
let signal = timeoutController.signal;
|
|
1045
|
+
let port = this.config.options.port;
|
|
1046
|
+
if (!port) {
|
|
1047
|
+
try {
|
|
1048
|
+
port = await (0, _instanceLookup.instanceLookup)({
|
|
1049
|
+
server: this.config.server,
|
|
1050
|
+
instanceName: this.config.options.instanceName,
|
|
1051
|
+
timeout: this.config.options.connectTimeout,
|
|
1052
|
+
signal: signal
|
|
1053
|
+
});
|
|
1054
|
+
} catch (err) {
|
|
1055
|
+
signal.throwIfAborted();
|
|
1056
|
+
throw new _errors.ConnectionError(err.message, 'EINSTLOOKUP', {
|
|
1057
|
+
cause: err
|
|
1058
|
+
});
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
let socket;
|
|
1062
|
+
try {
|
|
1063
|
+
socket = await this.connectOnPort(port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);
|
|
1064
|
+
} catch (err) {
|
|
1065
|
+
signal.throwIfAborted();
|
|
1066
|
+
throw this.wrapSocketError(err);
|
|
1067
|
+
}
|
|
1068
|
+
try {
|
|
1069
|
+
const controller = new AbortController();
|
|
1070
|
+
const onError = err => {
|
|
1071
|
+
controller.abort(this.wrapSocketError(err));
|
|
1072
|
+
};
|
|
1073
|
+
const onClose = () => {
|
|
1074
|
+
this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');
|
|
1075
|
+
};
|
|
1076
|
+
const onEnd = () => {
|
|
1077
|
+
this.debug.log('socket ended');
|
|
1078
|
+
const error = new Error('socket hang up');
|
|
1079
|
+
error.code = 'ECONNRESET';
|
|
1080
|
+
controller.abort(this.wrapSocketError(error));
|
|
1081
|
+
};
|
|
1082
|
+
socket.once('error', onError);
|
|
1083
|
+
socket.once('close', onClose);
|
|
1084
|
+
socket.once('end', onEnd);
|
|
1085
|
+
try {
|
|
1086
|
+
signal = AbortSignal.any([signal, controller.signal]);
|
|
1087
|
+
socket.setKeepAlive(true, KEEP_ALIVE_INITIAL_DELAY);
|
|
1088
|
+
this.messageIo = new _messageIo.default(socket, this.config.options.packetSize, this.debug);
|
|
1089
|
+
this.messageIo.on('secure', cleartext => {
|
|
1090
|
+
this.emit('secure', cleartext);
|
|
1091
|
+
});
|
|
1092
|
+
this.socket = socket;
|
|
1093
|
+
this.closed = false;
|
|
1094
|
+
this.debug.log('connected to ' + this.config.server + ':' + this.config.options.port);
|
|
1095
|
+
this.sendPreLogin();
|
|
1096
|
+
this.transitionTo(this.STATE.SENT_PRELOGIN);
|
|
1097
|
+
const preloginResponse = await this.readPreloginResponse(signal);
|
|
1098
|
+
await this.performTlsNegotiation(preloginResponse, signal);
|
|
1099
|
+
this.sendLogin7Packet();
|
|
1100
|
+
try {
|
|
1101
|
+
const {
|
|
1102
|
+
authentication
|
|
1103
|
+
} = this.config;
|
|
1104
|
+
switch (authentication.type) {
|
|
1105
|
+
case 'token-credential':
|
|
1106
|
+
case 'azure-active-directory-password':
|
|
1107
|
+
case 'azure-active-directory-msi-vm':
|
|
1108
|
+
case 'azure-active-directory-msi-app-service':
|
|
1109
|
+
case 'azure-active-directory-service-principal-secret':
|
|
1110
|
+
case 'azure-active-directory-default':
|
|
1111
|
+
this.transitionTo(this.STATE.SENT_LOGIN7_WITH_FEDAUTH);
|
|
1112
|
+
this.routingData = await this.performSentLogin7WithFedAuth(signal);
|
|
1113
|
+
break;
|
|
1114
|
+
case 'ntlm':
|
|
1115
|
+
this.transitionTo(this.STATE.SENT_LOGIN7_WITH_NTLM);
|
|
1116
|
+
this.routingData = await this.performSentLogin7WithNTLMLogin(signal);
|
|
1117
|
+
break;
|
|
1118
|
+
default:
|
|
1119
|
+
this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);
|
|
1120
|
+
this.routingData = await this.performSentLogin7WithStandardLogin(signal);
|
|
1121
|
+
break;
|
|
1122
|
+
}
|
|
1123
|
+
} catch (err) {
|
|
1124
|
+
if (isTransientError(err)) {
|
|
1125
|
+
this.debug.log('Initiating retry on transient error');
|
|
1126
|
+
this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);
|
|
1127
|
+
return await this.performTransientFailureRetry();
|
|
1128
|
+
}
|
|
1129
|
+
throw err;
|
|
1130
|
+
}
|
|
1131
|
+
|
|
1132
|
+
// If routing data is present, we need to re-route the connection
|
|
1133
|
+
if (this.routingData) {
|
|
1134
|
+
this.transitionTo(this.STATE.REROUTING);
|
|
1135
|
+
return await this.performReRouting();
|
|
1136
|
+
}
|
|
1137
|
+
this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);
|
|
1138
|
+
await this.performLoggedInSendingInitialSql(signal);
|
|
1139
|
+
} finally {
|
|
1140
|
+
socket.removeListener('error', onError);
|
|
1141
|
+
socket.removeListener('close', onClose);
|
|
1142
|
+
socket.removeListener('end', onEnd);
|
|
1143
|
+
}
|
|
1144
|
+
} catch (err) {
|
|
1145
|
+
socket.destroy();
|
|
1146
|
+
throw err;
|
|
1147
|
+
}
|
|
1148
|
+
socket.on('error', this._onSocketError);
|
|
1149
|
+
socket.on('close', this._onSocketClose);
|
|
1150
|
+
socket.on('end', this._onSocketEnd);
|
|
1151
|
+
this.transitionTo(this.STATE.LOGGED_IN);
|
|
1152
|
+
} finally {
|
|
1153
|
+
clearTimeout(connectTimer);
|
|
1154
|
+
}
|
|
1155
|
+
}
|
|
1156
|
+
|
|
1157
|
+
/**
|
|
1158
|
+
* @private
|
|
1159
|
+
*/
|
|
1160
|
+
cleanupConnection() {
|
|
1161
|
+
if (!this.closed) {
|
|
1162
|
+
this.clearRequestTimer();
|
|
1163
|
+
this.closeConnection();
|
|
1164
|
+
process.nextTick(() => {
|
|
1165
|
+
this.emit('end');
|
|
1166
|
+
});
|
|
1167
|
+
const request = this.request;
|
|
1168
|
+
if (request) {
|
|
1169
|
+
const err = new _errors.RequestError('Connection closed before request completed.', 'ECLOSE');
|
|
1170
|
+
request.callback(err);
|
|
1171
|
+
this.request = undefined;
|
|
1172
|
+
}
|
|
1173
|
+
this.closed = true;
|
|
1174
|
+
}
|
|
1175
|
+
}
|
|
1176
|
+
|
|
1177
|
+
/**
|
|
1178
|
+
* @private
|
|
1179
|
+
*/
|
|
1180
|
+
createDebug() {
|
|
1181
|
+
const debug = new _debug.default(this.config.options.debug);
|
|
1182
|
+
debug.on('debug', message => {
|
|
1183
|
+
this.emit('debug', message);
|
|
1184
|
+
});
|
|
1185
|
+
return debug;
|
|
1186
|
+
}
|
|
1187
|
+
|
|
1188
|
+
/**
|
|
1189
|
+
* @private
|
|
1190
|
+
*/
|
|
1191
|
+
createTokenStreamParser(message, handler) {
|
|
1192
|
+
return new _tokenStreamParser.Parser(message, this.debug, handler, this.config.options);
|
|
1193
|
+
}
|
|
1194
|
+
async wrapWithTls(socket, signal) {
|
|
1195
|
+
signal.throwIfAborted();
|
|
1196
|
+
const secureContext = tls.createSecureContext(this.secureContextOptions);
|
|
1197
|
+
// If connect to an ip address directly,
|
|
1198
|
+
// need to set the servername to an empty string
|
|
1199
|
+
// if the user has not given a servername explicitly
|
|
1200
|
+
const serverName = !net.isIP(this.config.server) ? this.config.server : '';
|
|
1201
|
+
const encryptOptions = {
|
|
1202
|
+
host: this.config.server,
|
|
1203
|
+
socket: socket,
|
|
1204
|
+
ALPNProtocols: ['tds/8.0'],
|
|
1205
|
+
secureContext: secureContext,
|
|
1206
|
+
servername: this.config.options.serverName ? this.config.options.serverName : serverName
|
|
1207
|
+
};
|
|
1208
|
+
const {
|
|
1209
|
+
promise,
|
|
1210
|
+
resolve,
|
|
1211
|
+
reject
|
|
1212
|
+
} = withResolvers();
|
|
1213
|
+
const encryptsocket = tls.connect(encryptOptions);
|
|
1214
|
+
try {
|
|
1215
|
+
const onAbort = () => {
|
|
1216
|
+
reject(signal.reason);
|
|
1217
|
+
};
|
|
1218
|
+
signal.addEventListener('abort', onAbort, {
|
|
1219
|
+
once: true
|
|
1220
|
+
});
|
|
1221
|
+
try {
|
|
1222
|
+
const onError = reject;
|
|
1223
|
+
const onConnect = () => {
|
|
1224
|
+
resolve(encryptsocket);
|
|
1225
|
+
};
|
|
1226
|
+
encryptsocket.once('error', onError);
|
|
1227
|
+
encryptsocket.once('secureConnect', onConnect);
|
|
1228
|
+
try {
|
|
1229
|
+
return await promise;
|
|
1230
|
+
} finally {
|
|
1231
|
+
encryptsocket.removeListener('error', onError);
|
|
1232
|
+
encryptsocket.removeListener('connect', onConnect);
|
|
1233
|
+
}
|
|
1234
|
+
} finally {
|
|
1235
|
+
signal.removeEventListener('abort', onAbort);
|
|
1236
|
+
}
|
|
1237
|
+
} catch (err) {
|
|
1238
|
+
encryptsocket.destroy();
|
|
1239
|
+
throw err;
|
|
1240
|
+
}
|
|
1241
|
+
}
|
|
1242
|
+
async connectOnPort(port, multiSubnetFailover, signal, customConnector) {
|
|
1243
|
+
const connectOpts = {
|
|
1244
|
+
host: this.routingData ? this.routingData.server : this.config.server,
|
|
1245
|
+
port: this.routingData ? this.routingData.port : port,
|
|
1246
|
+
localAddress: this.config.options.localAddress
|
|
1247
|
+
};
|
|
1248
|
+
const connect = customConnector || (multiSubnetFailover ? _connector.connectInParallel : _connector.connectInSequence);
|
|
1249
|
+
let socket = await connect(connectOpts, _dns.default.lookup, signal);
|
|
1250
|
+
if (this.config.options.encrypt === 'strict') {
|
|
1251
|
+
try {
|
|
1252
|
+
// Wrap the socket with TLS for TDS 8.0
|
|
1253
|
+
socket = await this.wrapWithTls(socket, signal);
|
|
1254
|
+
} catch (err) {
|
|
1255
|
+
socket.end();
|
|
1256
|
+
throw err;
|
|
1257
|
+
}
|
|
1258
|
+
}
|
|
1259
|
+
return socket;
|
|
1260
|
+
}
|
|
1261
|
+
|
|
1262
|
+
/**
|
|
1263
|
+
* @private
|
|
1264
|
+
*/
|
|
1265
|
+
closeConnection() {
|
|
1266
|
+
if (this.socket) {
|
|
1267
|
+
this.socket.destroy();
|
|
1268
|
+
}
|
|
1269
|
+
}
|
|
1270
|
+
|
|
1271
|
+
/**
|
|
1272
|
+
* @private
|
|
1273
|
+
*/
|
|
1274
|
+
createCancelTimer() {
|
|
1275
|
+
this.clearCancelTimer();
|
|
1276
|
+
const timeout = this.config.options.cancelTimeout;
|
|
1277
|
+
if (timeout > 0) {
|
|
1278
|
+
this.cancelTimer = setTimeout(() => {
|
|
1279
|
+
this.cancelTimeout();
|
|
1280
|
+
}, timeout);
|
|
1281
|
+
}
|
|
1282
|
+
}
|
|
1283
|
+
|
|
1284
|
+
/**
|
|
1285
|
+
* @private
|
|
1286
|
+
*/
|
|
1287
|
+
createRequestTimer() {
|
|
1288
|
+
this.clearRequestTimer(); // release old timer, just to be safe
|
|
1289
|
+
const request = this.request;
|
|
1290
|
+
const timeout = request.timeout !== undefined ? request.timeout : this.config.options.requestTimeout;
|
|
1291
|
+
if (timeout) {
|
|
1292
|
+
this.requestTimer = setTimeout(() => {
|
|
1293
|
+
this.requestTimeout();
|
|
1294
|
+
}, timeout);
|
|
1295
|
+
}
|
|
1296
|
+
}
|
|
1297
|
+
|
|
1298
|
+
/**
|
|
1299
|
+
* @private
|
|
1300
|
+
*/
|
|
1301
|
+
cancelTimeout() {
|
|
1302
|
+
const message = `Failed to cancel request in ${this.config.options.cancelTimeout}ms`;
|
|
1303
|
+
this.debug.log(message);
|
|
1304
|
+
this.dispatchEvent('socketError', new _errors.ConnectionError(message, 'ETIMEOUT'));
|
|
1305
|
+
}
|
|
1306
|
+
|
|
1307
|
+
/**
|
|
1308
|
+
* @private
|
|
1309
|
+
*/
|
|
1310
|
+
requestTimeout() {
|
|
1311
|
+
this.requestTimer = undefined;
|
|
1312
|
+
const request = this.request;
|
|
1313
|
+
request.cancel();
|
|
1314
|
+
const timeout = request.timeout !== undefined ? request.timeout : this.config.options.requestTimeout;
|
|
1315
|
+
const message = 'Timeout: Request failed to complete in ' + timeout + 'ms';
|
|
1316
|
+
request.error = new _errors.RequestError(message, 'ETIMEOUT');
|
|
1317
|
+
}
|
|
1318
|
+
|
|
1319
|
+
/**
|
|
1320
|
+
* @private
|
|
1321
|
+
*/
|
|
1322
|
+
clearCancelTimer() {
|
|
1323
|
+
if (this.cancelTimer) {
|
|
1324
|
+
clearTimeout(this.cancelTimer);
|
|
1325
|
+
this.cancelTimer = undefined;
|
|
1326
|
+
}
|
|
1327
|
+
}
|
|
1328
|
+
|
|
1329
|
+
/**
|
|
1330
|
+
* @private
|
|
1331
|
+
*/
|
|
1332
|
+
clearRequestTimer() {
|
|
1333
|
+
if (this.requestTimer) {
|
|
1334
|
+
clearTimeout(this.requestTimer);
|
|
1335
|
+
this.requestTimer = undefined;
|
|
1336
|
+
}
|
|
1337
|
+
}
|
|
1338
|
+
|
|
1339
|
+
/**
|
|
1340
|
+
* @private
|
|
1341
|
+
*/
|
|
1342
|
+
transitionTo(newState) {
|
|
1343
|
+
if (this.state === newState) {
|
|
1344
|
+
this.debug.log('State is already ' + newState.name);
|
|
1345
|
+
return;
|
|
1346
|
+
}
|
|
1347
|
+
if (this.state && this.state.exit) {
|
|
1348
|
+
this.state.exit.call(this, newState);
|
|
1349
|
+
}
|
|
1350
|
+
this.debug.log('State change: ' + (this.state ? this.state.name : 'undefined') + ' -> ' + newState.name);
|
|
1351
|
+
this.state = newState;
|
|
1352
|
+
if (this.state.enter) {
|
|
1353
|
+
this.state.enter.apply(this);
|
|
1354
|
+
}
|
|
1355
|
+
}
|
|
1356
|
+
|
|
1357
|
+
/**
|
|
1358
|
+
* @private
|
|
1359
|
+
*/
|
|
1360
|
+
getEventHandler(eventName) {
|
|
1361
|
+
const handler = this.state.events[eventName];
|
|
1362
|
+
if (!handler) {
|
|
1363
|
+
throw new Error(`No event '${eventName}' in state '${this.state.name}'`);
|
|
1364
|
+
}
|
|
1365
|
+
return handler;
|
|
1366
|
+
}
|
|
1367
|
+
|
|
1368
|
+
/**
|
|
1369
|
+
* @private
|
|
1370
|
+
*/
|
|
1371
|
+
dispatchEvent(eventName, ...args) {
|
|
1372
|
+
const handler = this.state.events[eventName];
|
|
1373
|
+
if (handler) {
|
|
1374
|
+
handler.apply(this, args);
|
|
1375
|
+
} else {
|
|
1376
|
+
this.emit('error', new Error(`No event '${eventName}' in state '${this.state.name}'`));
|
|
1377
|
+
this.close();
|
|
1378
|
+
}
|
|
1379
|
+
}
|
|
1380
|
+
|
|
1381
|
+
/**
|
|
1382
|
+
* @private
|
|
1383
|
+
*/
|
|
1384
|
+
wrapSocketError(error) {
|
|
1385
|
+
if (this.state === this.STATE.CONNECTING || this.state === this.STATE.SENT_TLSSSLNEGOTIATION) {
|
|
1386
|
+
const hostPostfix = this.config.options.port ? `:${this.config.options.port}` : `\\${this.config.options.instanceName}`;
|
|
1387
|
+
// If we have routing data stored, this connection has been redirected
|
|
1388
|
+
const server = this.routingData ? this.routingData.server : this.config.server;
|
|
1389
|
+
const port = this.routingData ? `:${this.routingData.port}` : hostPostfix;
|
|
1390
|
+
// Grab the target host from the connection configuration, and from a redirect message
|
|
1391
|
+
// otherwise, leave the message empty.
|
|
1392
|
+
const routingMessage = this.routingData ? ` (redirected from ${this.config.server}${hostPostfix})` : '';
|
|
1393
|
+
const message = `Failed to connect to ${server}${port}${routingMessage} - ${error.message}`;
|
|
1394
|
+
return new _errors.ConnectionError(message, 'ESOCKET', {
|
|
1395
|
+
cause: error
|
|
1396
|
+
});
|
|
1397
|
+
} else {
|
|
1398
|
+
const message = `Connection lost - ${error.message}`;
|
|
1399
|
+
return new _errors.ConnectionError(message, 'ESOCKET', {
|
|
1400
|
+
cause: error
|
|
1401
|
+
});
|
|
1402
|
+
}
|
|
1403
|
+
}
|
|
1404
|
+
|
|
1405
|
+
/**
|
|
1406
|
+
* @private
|
|
1407
|
+
*/
|
|
1408
|
+
socketEnd() {
|
|
1409
|
+
this.debug.log('socket ended');
|
|
1410
|
+
if (this.state !== this.STATE.FINAL) {
|
|
1411
|
+
const error = new Error('socket hang up');
|
|
1412
|
+
error.code = 'ECONNRESET';
|
|
1413
|
+
this.dispatchEvent('socketError', error);
|
|
1414
|
+
process.nextTick(() => {
|
|
1415
|
+
this.emit('error', this.wrapSocketError(error));
|
|
1416
|
+
});
|
|
1417
|
+
}
|
|
1418
|
+
}
|
|
1419
|
+
|
|
1420
|
+
/**
|
|
1421
|
+
* @private
|
|
1422
|
+
*/
|
|
1423
|
+
socketClose() {
|
|
1424
|
+
this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');
|
|
1425
|
+
this.transitionTo(this.STATE.FINAL);
|
|
1426
|
+
this.cleanupConnection();
|
|
1427
|
+
}
|
|
1428
|
+
|
|
1429
|
+
/**
|
|
1430
|
+
* @private
|
|
1431
|
+
*/
|
|
1432
|
+
sendPreLogin() {
|
|
1433
|
+
const [, major, minor, build] = /^(\d+)\.(\d+)\.(\d+)/.exec(_package.version) ?? ['0.0.0', '0', '0', '0'];
|
|
1434
|
+
const payload = new _preloginPayload.default({
|
|
1435
|
+
// If encrypt setting is set to 'strict', then we should have already done the encryption before calling
|
|
1436
|
+
// this function. Therefore, the encrypt will be set to false here.
|
|
1437
|
+
// Otherwise, we will set encrypt here based on the encrypt Boolean value from the configuration.
|
|
1438
|
+
encrypt: typeof this.config.options.encrypt === 'boolean' && this.config.options.encrypt,
|
|
1439
|
+
version: {
|
|
1440
|
+
major: Number(major),
|
|
1441
|
+
minor: Number(minor),
|
|
1442
|
+
build: Number(build),
|
|
1443
|
+
subbuild: 0
|
|
1444
|
+
}
|
|
1445
|
+
});
|
|
1446
|
+
this.messageIo.sendMessage(_packet.TYPE.PRELOGIN, payload.data);
|
|
1447
|
+
this.debug.payload(function () {
|
|
1448
|
+
return payload.toString(' ');
|
|
1449
|
+
});
|
|
1450
|
+
}
|
|
1451
|
+
|
|
1452
|
+
/**
|
|
1453
|
+
* @private
|
|
1454
|
+
*/
|
|
1455
|
+
sendLogin7Packet() {
|
|
1456
|
+
const payload = new _login7Payload.default({
|
|
1457
|
+
tdsVersion: _tdsVersions.versions[this.config.options.tdsVersion],
|
|
1458
|
+
packetSize: this.config.options.packetSize,
|
|
1459
|
+
clientProgVer: 0,
|
|
1460
|
+
clientPid: process.pid,
|
|
1461
|
+
connectionId: 0,
|
|
1462
|
+
clientTimeZone: new Date().getTimezoneOffset(),
|
|
1463
|
+
clientLcid: 0x00000409
|
|
1464
|
+
});
|
|
1465
|
+
const {
|
|
1466
|
+
authentication
|
|
1467
|
+
} = this.config;
|
|
1468
|
+
switch (authentication.type) {
|
|
1469
|
+
case 'azure-active-directory-password':
|
|
1470
|
+
payload.fedAuth = {
|
|
1471
|
+
type: 'ADAL',
|
|
1472
|
+
echo: this.fedAuthRequired,
|
|
1473
|
+
workflow: 'default'
|
|
1474
|
+
};
|
|
1475
|
+
break;
|
|
1476
|
+
case 'azure-active-directory-access-token':
|
|
1477
|
+
payload.fedAuth = {
|
|
1478
|
+
type: 'SECURITYTOKEN',
|
|
1479
|
+
echo: this.fedAuthRequired,
|
|
1480
|
+
fedAuthToken: authentication.options.token
|
|
1481
|
+
};
|
|
1482
|
+
break;
|
|
1483
|
+
case 'token-credential':
|
|
1484
|
+
case 'azure-active-directory-msi-vm':
|
|
1485
|
+
case 'azure-active-directory-default':
|
|
1486
|
+
case 'azure-active-directory-msi-app-service':
|
|
1487
|
+
case 'azure-active-directory-service-principal-secret':
|
|
1488
|
+
payload.fedAuth = {
|
|
1489
|
+
type: 'ADAL',
|
|
1490
|
+
echo: this.fedAuthRequired,
|
|
1491
|
+
workflow: 'integrated'
|
|
1492
|
+
};
|
|
1493
|
+
break;
|
|
1494
|
+
case 'ntlm':
|
|
1495
|
+
payload.sspi = (0, _ntlm.createNTLMRequest)({
|
|
1496
|
+
domain: authentication.options.domain
|
|
1497
|
+
});
|
|
1498
|
+
break;
|
|
1499
|
+
default:
|
|
1500
|
+
payload.userName = authentication.options.userName;
|
|
1501
|
+
payload.password = authentication.options.password;
|
|
1502
|
+
}
|
|
1503
|
+
payload.hostname = this.config.options.workstationId || _os.default.hostname();
|
|
1504
|
+
payload.serverName = this.routingData ? `${this.routingData.server}${this.routingData.instance ? '\\' + this.routingData.instance : ''}` : this.config.server;
|
|
1505
|
+
payload.appName = this.config.options.appName || 'Tedious';
|
|
1506
|
+
payload.libraryName = _library.name;
|
|
1507
|
+
payload.language = this.config.options.language;
|
|
1508
|
+
payload.database = this.config.options.database;
|
|
1509
|
+
payload.clientId = Buffer.from([1, 2, 3, 4, 5, 6]);
|
|
1510
|
+
payload.readOnlyIntent = this.config.options.readOnlyIntent;
|
|
1511
|
+
payload.initDbFatal = !this.config.options.fallbackToDefaultDb;
|
|
1512
|
+
this.routingData = undefined;
|
|
1513
|
+
this.messageIo.sendMessage(_packet.TYPE.LOGIN7, payload.toBuffer());
|
|
1514
|
+
this.debug.payload(function () {
|
|
1515
|
+
return payload.toString(' ');
|
|
1516
|
+
});
|
|
1517
|
+
}
|
|
1518
|
+
|
|
1519
|
+
/**
|
|
1520
|
+
* @private
|
|
1521
|
+
*/
|
|
1522
|
+
sendFedAuthTokenMessage(token) {
|
|
1523
|
+
const accessTokenLen = Buffer.byteLength(token, 'ucs2');
|
|
1524
|
+
const data = Buffer.alloc(8 + accessTokenLen);
|
|
1525
|
+
let offset = 0;
|
|
1526
|
+
offset = data.writeUInt32LE(accessTokenLen + 4, offset);
|
|
1527
|
+
offset = data.writeUInt32LE(accessTokenLen, offset);
|
|
1528
|
+
data.write(token, offset, 'ucs2');
|
|
1529
|
+
this.messageIo.sendMessage(_packet.TYPE.FEDAUTH_TOKEN, data);
|
|
1530
|
+
}
|
|
1531
|
+
|
|
1532
|
+
/**
|
|
1533
|
+
* @private
|
|
1534
|
+
*/
|
|
1535
|
+
sendInitialSql() {
|
|
1536
|
+
const payload = new _sqlbatchPayload.default(this.getInitialSql(), this.currentTransactionDescriptor(), this.config.options);
|
|
1537
|
+
const message = new _message.default({
|
|
1538
|
+
type: _packet.TYPE.SQL_BATCH
|
|
1539
|
+
});
|
|
1540
|
+
this.messageIo.outgoingMessageStream.write(message);
|
|
1541
|
+
_stream.Readable.from(payload).pipe(message);
|
|
1542
|
+
}
|
|
1543
|
+
|
|
1544
|
+
/**
|
|
1545
|
+
* @private
|
|
1546
|
+
*/
|
|
1547
|
+
getInitialSql() {
|
|
1548
|
+
const options = [];
|
|
1549
|
+
if (this.config.options.enableAnsiNull === true) {
|
|
1550
|
+
options.push('set ansi_nulls on');
|
|
1551
|
+
} else if (this.config.options.enableAnsiNull === false) {
|
|
1552
|
+
options.push('set ansi_nulls off');
|
|
1553
|
+
}
|
|
1554
|
+
if (this.config.options.enableAnsiNullDefault === true) {
|
|
1555
|
+
options.push('set ansi_null_dflt_on on');
|
|
1556
|
+
} else if (this.config.options.enableAnsiNullDefault === false) {
|
|
1557
|
+
options.push('set ansi_null_dflt_on off');
|
|
1558
|
+
}
|
|
1559
|
+
if (this.config.options.enableAnsiPadding === true) {
|
|
1560
|
+
options.push('set ansi_padding on');
|
|
1561
|
+
} else if (this.config.options.enableAnsiPadding === false) {
|
|
1562
|
+
options.push('set ansi_padding off');
|
|
1563
|
+
}
|
|
1564
|
+
if (this.config.options.enableAnsiWarnings === true) {
|
|
1565
|
+
options.push('set ansi_warnings on');
|
|
1566
|
+
} else if (this.config.options.enableAnsiWarnings === false) {
|
|
1567
|
+
options.push('set ansi_warnings off');
|
|
1568
|
+
}
|
|
1569
|
+
if (this.config.options.enableArithAbort === true) {
|
|
1570
|
+
options.push('set arithabort on');
|
|
1571
|
+
} else if (this.config.options.enableArithAbort === false) {
|
|
1572
|
+
options.push('set arithabort off');
|
|
1573
|
+
}
|
|
1574
|
+
if (this.config.options.enableConcatNullYieldsNull === true) {
|
|
1575
|
+
options.push('set concat_null_yields_null on');
|
|
1576
|
+
} else if (this.config.options.enableConcatNullYieldsNull === false) {
|
|
1577
|
+
options.push('set concat_null_yields_null off');
|
|
1578
|
+
}
|
|
1579
|
+
if (this.config.options.enableCursorCloseOnCommit === true) {
|
|
1580
|
+
options.push('set cursor_close_on_commit on');
|
|
1581
|
+
} else if (this.config.options.enableCursorCloseOnCommit === false) {
|
|
1582
|
+
options.push('set cursor_close_on_commit off');
|
|
1583
|
+
}
|
|
1584
|
+
if (this.config.options.datefirst !== null) {
|
|
1585
|
+
options.push(`set datefirst ${this.config.options.datefirst}`);
|
|
1586
|
+
}
|
|
1587
|
+
if (this.config.options.dateFormat !== null) {
|
|
1588
|
+
options.push(`set dateformat ${this.config.options.dateFormat}`);
|
|
1589
|
+
}
|
|
1590
|
+
if (this.config.options.enableImplicitTransactions === true) {
|
|
1591
|
+
options.push('set implicit_transactions on');
|
|
1592
|
+
} else if (this.config.options.enableImplicitTransactions === false) {
|
|
1593
|
+
options.push('set implicit_transactions off');
|
|
1594
|
+
}
|
|
1595
|
+
if (this.config.options.language !== null) {
|
|
1596
|
+
options.push(`set language ${this.config.options.language}`);
|
|
1597
|
+
}
|
|
1598
|
+
if (this.config.options.enableNumericRoundabort === true) {
|
|
1599
|
+
options.push('set numeric_roundabort on');
|
|
1600
|
+
} else if (this.config.options.enableNumericRoundabort === false) {
|
|
1601
|
+
options.push('set numeric_roundabort off');
|
|
1602
|
+
}
|
|
1603
|
+
if (this.config.options.enableQuotedIdentifier === true) {
|
|
1604
|
+
options.push('set quoted_identifier on');
|
|
1605
|
+
} else if (this.config.options.enableQuotedIdentifier === false) {
|
|
1606
|
+
options.push('set quoted_identifier off');
|
|
1607
|
+
}
|
|
1608
|
+
if (this.config.options.textsize !== null) {
|
|
1609
|
+
options.push(`set textsize ${this.config.options.textsize}`);
|
|
1610
|
+
}
|
|
1611
|
+
if (this.config.options.connectionIsolationLevel !== null) {
|
|
1612
|
+
options.push(`set transaction isolation level ${this.getIsolationLevelText(this.config.options.connectionIsolationLevel)}`);
|
|
1613
|
+
}
|
|
1614
|
+
if (this.config.options.abortTransactionOnError === true) {
|
|
1615
|
+
options.push('set xact_abort on');
|
|
1616
|
+
} else if (this.config.options.abortTransactionOnError === false) {
|
|
1617
|
+
options.push('set xact_abort off');
|
|
1618
|
+
}
|
|
1619
|
+
return options.join('\n');
|
|
1620
|
+
}
|
|
1621
|
+
|
|
1622
|
+
/**
|
|
1623
|
+
* Execute the SQL batch represented by [[Request]].
|
|
1624
|
+
* There is no param support, and unlike [[Request.execSql]],
|
|
1625
|
+
* it is not likely that SQL Server will reuse the execution plan it generates for the SQL.
|
|
1626
|
+
*
|
|
1627
|
+
* In almost all cases, [[Request.execSql]] will be a better choice.
|
|
1628
|
+
*
|
|
1629
|
+
* @param request A [[Request]] object representing the request.
|
|
1630
|
+
*/
|
|
1631
|
+
execSqlBatch(request) {
|
|
1632
|
+
this.makeRequest(request, _packet.TYPE.SQL_BATCH, new _sqlbatchPayload.default(request.sqlTextOrProcedure, this.currentTransactionDescriptor(), this.config.options));
|
|
1633
|
+
}
|
|
1634
|
+
|
|
1635
|
+
/**
|
|
1636
|
+
* Execute the SQL represented by [[Request]].
|
|
1637
|
+
*
|
|
1638
|
+
* As `sp_executesql` is used to execute the SQL, if the same SQL is executed multiples times
|
|
1639
|
+
* using this function, the SQL Server query optimizer is likely to reuse the execution plan it generates
|
|
1640
|
+
* for the first execution. This may also result in SQL server treating the request like a stored procedure
|
|
1641
|
+
* which can result in the [[Event_doneInProc]] or [[Event_doneProc]] events being emitted instead of the
|
|
1642
|
+
* [[Event_done]] event you might expect. Using [[execSqlBatch]] will prevent this from occurring but may have a negative performance impact.
|
|
1643
|
+
*
|
|
1644
|
+
* 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)
|
|
1645
|
+
* If you're running in to scoping issues, then [[execSqlBatch]] may be a better choice.
|
|
1646
|
+
* See also [issue #24](https://github.com/pekim/tedious/issues/24)
|
|
1647
|
+
*
|
|
1648
|
+
* @param request A [[Request]] object representing the request.
|
|
1649
|
+
*/
|
|
1650
|
+
execSql(request) {
|
|
1651
|
+
try {
|
|
1652
|
+
request.validateParameters(this.databaseCollation);
|
|
1653
|
+
} catch (error) {
|
|
1654
|
+
request.error = error;
|
|
1655
|
+
process.nextTick(() => {
|
|
1656
|
+
this.debug.log(error.message);
|
|
1657
|
+
request.callback(error);
|
|
1658
|
+
});
|
|
1659
|
+
return;
|
|
1660
|
+
}
|
|
1661
|
+
const parameters = [];
|
|
1662
|
+
parameters.push({
|
|
1663
|
+
type: _dataType.TYPES.NVarChar,
|
|
1664
|
+
name: 'statement',
|
|
1665
|
+
value: request.sqlTextOrProcedure,
|
|
1666
|
+
output: false,
|
|
1667
|
+
length: undefined,
|
|
1668
|
+
precision: undefined,
|
|
1669
|
+
scale: undefined
|
|
1670
|
+
});
|
|
1671
|
+
if (request.parameters.length) {
|
|
1672
|
+
parameters.push({
|
|
1673
|
+
type: _dataType.TYPES.NVarChar,
|
|
1674
|
+
name: 'params',
|
|
1675
|
+
value: request.makeParamsParameter(request.parameters),
|
|
1676
|
+
output: false,
|
|
1677
|
+
length: undefined,
|
|
1678
|
+
precision: undefined,
|
|
1679
|
+
scale: undefined
|
|
1680
|
+
});
|
|
1681
|
+
parameters.push(...request.parameters);
|
|
1682
|
+
}
|
|
1683
|
+
this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_ExecuteSql, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
|
1684
|
+
}
|
|
1685
|
+
|
|
1686
|
+
/**
|
|
1687
|
+
* Creates a new BulkLoad instance.
|
|
1688
|
+
*
|
|
1689
|
+
* @param table The name of the table to bulk-insert into.
|
|
1690
|
+
* @param options A set of bulk load options.
|
|
1691
|
+
*/
|
|
1692
|
+
|
|
1693
|
+
newBulkLoad(table, callbackOrOptions, callback) {
|
|
1694
|
+
let options;
|
|
1695
|
+
if (callback === undefined) {
|
|
1696
|
+
callback = callbackOrOptions;
|
|
1697
|
+
options = {};
|
|
1698
|
+
} else {
|
|
1699
|
+
options = callbackOrOptions;
|
|
1700
|
+
}
|
|
1701
|
+
if (typeof options !== 'object') {
|
|
1702
|
+
throw new TypeError('"options" argument must be an object');
|
|
1703
|
+
}
|
|
1704
|
+
return new _bulkLoad.default(table, this.databaseCollation, this.config.options, options, callback);
|
|
1705
|
+
}
|
|
1706
|
+
|
|
1707
|
+
/**
|
|
1708
|
+
* Execute a [[BulkLoad]].
|
|
1709
|
+
*
|
|
1710
|
+
* ```js
|
|
1711
|
+
* // We want to perform a bulk load into a table with the following format:
|
|
1712
|
+
* // CREATE TABLE employees (first_name nvarchar(255), last_name nvarchar(255), day_of_birth date);
|
|
1713
|
+
*
|
|
1714
|
+
* const bulkLoad = connection.newBulkLoad('employees', (err, rowCount) => {
|
|
1715
|
+
* // ...
|
|
1716
|
+
* });
|
|
1717
|
+
*
|
|
1718
|
+
* // First, we need to specify the columns that we want to write to,
|
|
1719
|
+
* // and their definitions. These definitions must match the actual table,
|
|
1720
|
+
* // otherwise the bulk load will fail.
|
|
1721
|
+
* bulkLoad.addColumn('first_name', TYPES.NVarchar, { nullable: false });
|
|
1722
|
+
* bulkLoad.addColumn('last_name', TYPES.NVarchar, { nullable: false });
|
|
1723
|
+
* bulkLoad.addColumn('date_of_birth', TYPES.Date, { nullable: false });
|
|
1724
|
+
*
|
|
1725
|
+
* // Execute a bulk load with a predefined list of rows.
|
|
1726
|
+
* //
|
|
1727
|
+
* // Note that these rows are held in memory until the
|
|
1728
|
+
* // bulk load was performed, so if you need to write a large
|
|
1729
|
+
* // number of rows (e.g. by reading from a CSV file),
|
|
1730
|
+
* // passing an `AsyncIterable` is advisable to keep memory usage low.
|
|
1731
|
+
* connection.execBulkLoad(bulkLoad, [
|
|
1732
|
+
* { 'first_name': 'Steve', 'last_name': 'Jobs', 'day_of_birth': new Date('02-24-1955') },
|
|
1733
|
+
* { 'first_name': 'Bill', 'last_name': 'Gates', 'day_of_birth': new Date('10-28-1955') }
|
|
1734
|
+
* ]);
|
|
1735
|
+
* ```
|
|
1736
|
+
*
|
|
1737
|
+
* @param bulkLoad A previously created [[BulkLoad]].
|
|
1738
|
+
* @param rows A [[Iterable]] or [[AsyncIterable]] that contains the rows that should be bulk loaded.
|
|
1739
|
+
*/
|
|
1740
|
+
|
|
1741
|
+
execBulkLoad(bulkLoad, rows) {
|
|
1742
|
+
bulkLoad.executionStarted = true;
|
|
1743
|
+
if (rows) {
|
|
1744
|
+
if (bulkLoad.streamingMode) {
|
|
1745
|
+
throw new Error("Connection.execBulkLoad can't be called with a BulkLoad that was put in streaming mode.");
|
|
1746
|
+
}
|
|
1747
|
+
if (bulkLoad.firstRowWritten) {
|
|
1748
|
+
throw new Error("Connection.execBulkLoad can't be called with a BulkLoad that already has rows written to it.");
|
|
1749
|
+
}
|
|
1750
|
+
const rowStream = _stream.Readable.from(rows);
|
|
1751
|
+
|
|
1752
|
+
// Destroy the packet transform if an error happens in the row stream,
|
|
1753
|
+
// e.g. if an error is thrown from within a generator or stream.
|
|
1754
|
+
rowStream.on('error', err => {
|
|
1755
|
+
bulkLoad.rowToPacketTransform.destroy(err);
|
|
1756
|
+
});
|
|
1757
|
+
|
|
1758
|
+
// Destroy the row stream if an error happens in the packet transform,
|
|
1759
|
+
// e.g. if the bulk load is cancelled.
|
|
1760
|
+
bulkLoad.rowToPacketTransform.on('error', err => {
|
|
1761
|
+
rowStream.destroy(err);
|
|
1762
|
+
});
|
|
1763
|
+
rowStream.pipe(bulkLoad.rowToPacketTransform);
|
|
1764
|
+
} else if (!bulkLoad.streamingMode) {
|
|
1765
|
+
// If the bulkload was not put into streaming mode by the user,
|
|
1766
|
+
// we end the rowToPacketTransform here for them.
|
|
1767
|
+
//
|
|
1768
|
+
// If it was put into streaming mode, it's the user's responsibility
|
|
1769
|
+
// to end the stream.
|
|
1770
|
+
bulkLoad.rowToPacketTransform.end();
|
|
1771
|
+
}
|
|
1772
|
+
const onCancel = () => {
|
|
1773
|
+
request.cancel();
|
|
1774
|
+
};
|
|
1775
|
+
const payload = new _bulkLoadPayload.BulkLoadPayload(bulkLoad);
|
|
1776
|
+
const request = new _request.default(bulkLoad.getBulkInsertSql(), error => {
|
|
1777
|
+
bulkLoad.removeListener('cancel', onCancel);
|
|
1778
|
+
if (error) {
|
|
1779
|
+
if (error.code === 'UNKNOWN') {
|
|
1780
|
+
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.';
|
|
1781
|
+
}
|
|
1782
|
+
bulkLoad.error = error;
|
|
1783
|
+
bulkLoad.callback(error);
|
|
1784
|
+
return;
|
|
1785
|
+
}
|
|
1786
|
+
this.makeRequest(bulkLoad, _packet.TYPE.BULK_LOAD, payload);
|
|
1787
|
+
});
|
|
1788
|
+
bulkLoad.once('cancel', onCancel);
|
|
1789
|
+
this.execSqlBatch(request);
|
|
1790
|
+
}
|
|
1791
|
+
|
|
1792
|
+
/**
|
|
1793
|
+
* Prepare the SQL represented by the request.
|
|
1794
|
+
*
|
|
1795
|
+
* The request can then be used in subsequent calls to
|
|
1796
|
+
* [[execute]] and [[unprepare]]
|
|
1797
|
+
*
|
|
1798
|
+
* @param request A [[Request]] object representing the request.
|
|
1799
|
+
* Parameters only require a name and type. Parameter values are ignored.
|
|
1800
|
+
*/
|
|
1801
|
+
prepare(request) {
|
|
1802
|
+
const parameters = [];
|
|
1803
|
+
parameters.push({
|
|
1804
|
+
type: _dataType.TYPES.Int,
|
|
1805
|
+
name: 'handle',
|
|
1806
|
+
value: undefined,
|
|
1807
|
+
output: true,
|
|
1808
|
+
length: undefined,
|
|
1809
|
+
precision: undefined,
|
|
1810
|
+
scale: undefined
|
|
1811
|
+
});
|
|
1812
|
+
parameters.push({
|
|
1813
|
+
type: _dataType.TYPES.NVarChar,
|
|
1814
|
+
name: 'params',
|
|
1815
|
+
value: request.parameters.length ? request.makeParamsParameter(request.parameters) : null,
|
|
1816
|
+
output: false,
|
|
1817
|
+
length: undefined,
|
|
1818
|
+
precision: undefined,
|
|
1819
|
+
scale: undefined
|
|
1820
|
+
});
|
|
1821
|
+
parameters.push({
|
|
1822
|
+
type: _dataType.TYPES.NVarChar,
|
|
1823
|
+
name: 'stmt',
|
|
1824
|
+
value: request.sqlTextOrProcedure,
|
|
1825
|
+
output: false,
|
|
1826
|
+
length: undefined,
|
|
1827
|
+
precision: undefined,
|
|
1828
|
+
scale: undefined
|
|
1829
|
+
});
|
|
1830
|
+
request.preparing = true;
|
|
1831
|
+
|
|
1832
|
+
// TODO: We need to clean up this event handler, otherwise this leaks memory
|
|
1833
|
+
request.on('returnValue', (name, value) => {
|
|
1834
|
+
if (name === 'handle') {
|
|
1835
|
+
request.handle = value;
|
|
1836
|
+
} else {
|
|
1837
|
+
request.error = new _errors.RequestError(`Tedious > Unexpected output parameter ${name} from sp_prepare`);
|
|
1838
|
+
}
|
|
1839
|
+
});
|
|
1840
|
+
this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Prepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
|
1841
|
+
}
|
|
1842
|
+
|
|
1843
|
+
/**
|
|
1844
|
+
* Release the SQL Server resources associated with a previously prepared request.
|
|
1845
|
+
*
|
|
1846
|
+
* @param request A [[Request]] object representing the request.
|
|
1847
|
+
* Parameters only require a name and type.
|
|
1848
|
+
* Parameter values are ignored.
|
|
1849
|
+
*/
|
|
1850
|
+
unprepare(request) {
|
|
1851
|
+
const parameters = [];
|
|
1852
|
+
parameters.push({
|
|
1853
|
+
type: _dataType.TYPES.Int,
|
|
1854
|
+
name: 'handle',
|
|
1855
|
+
// TODO: Abort if `request.handle` is not set
|
|
1856
|
+
value: request.handle,
|
|
1857
|
+
output: false,
|
|
1858
|
+
length: undefined,
|
|
1859
|
+
precision: undefined,
|
|
1860
|
+
scale: undefined
|
|
1861
|
+
});
|
|
1862
|
+
this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Unprepare, parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
|
1863
|
+
}
|
|
1864
|
+
|
|
1865
|
+
/**
|
|
1866
|
+
* Execute previously prepared SQL, using the supplied parameters.
|
|
1867
|
+
*
|
|
1868
|
+
* @param request A previously prepared [[Request]].
|
|
1869
|
+
* @param parameters An object whose names correspond to the names of
|
|
1870
|
+
* parameters that were added to the [[Request]] before it was prepared.
|
|
1871
|
+
* The object's values are passed as the parameters' values when the
|
|
1872
|
+
* request is executed.
|
|
1873
|
+
*/
|
|
1874
|
+
execute(request, parameters) {
|
|
1875
|
+
const executeParameters = [];
|
|
1876
|
+
executeParameters.push({
|
|
1877
|
+
type: _dataType.TYPES.Int,
|
|
1878
|
+
name: '',
|
|
1879
|
+
// TODO: Abort if `request.handle` is not set
|
|
1880
|
+
value: request.handle,
|
|
1881
|
+
output: false,
|
|
1882
|
+
length: undefined,
|
|
1883
|
+
precision: undefined,
|
|
1884
|
+
scale: undefined
|
|
1885
|
+
});
|
|
1886
|
+
try {
|
|
1887
|
+
for (let i = 0, len = request.parameters.length; i < len; i++) {
|
|
1888
|
+
const parameter = request.parameters[i];
|
|
1889
|
+
executeParameters.push({
|
|
1890
|
+
...parameter,
|
|
1891
|
+
value: parameter.type.validate(parameters ? parameters[parameter.name] : null, this.databaseCollation)
|
|
1892
|
+
});
|
|
1893
|
+
}
|
|
1894
|
+
} catch (error) {
|
|
1895
|
+
request.error = error;
|
|
1896
|
+
process.nextTick(() => {
|
|
1897
|
+
this.debug.log(error.message);
|
|
1898
|
+
request.callback(error);
|
|
1899
|
+
});
|
|
1900
|
+
return;
|
|
1901
|
+
}
|
|
1902
|
+
this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(_specialStoredProcedure.default.Sp_Execute, executeParameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
|
1903
|
+
}
|
|
1904
|
+
|
|
1905
|
+
/**
|
|
1906
|
+
* Call a stored procedure represented by [[Request]].
|
|
1907
|
+
*
|
|
1908
|
+
* @param request A [[Request]] object representing the request.
|
|
1909
|
+
*/
|
|
1910
|
+
callProcedure(request) {
|
|
1911
|
+
try {
|
|
1912
|
+
request.validateParameters(this.databaseCollation);
|
|
1913
|
+
} catch (error) {
|
|
1914
|
+
request.error = error;
|
|
1915
|
+
process.nextTick(() => {
|
|
1916
|
+
this.debug.log(error.message);
|
|
1917
|
+
request.callback(error);
|
|
1918
|
+
});
|
|
1919
|
+
return;
|
|
1920
|
+
}
|
|
1921
|
+
this.makeRequest(request, _packet.TYPE.RPC_REQUEST, new _rpcrequestPayload.default(request.sqlTextOrProcedure, request.parameters, this.currentTransactionDescriptor(), this.config.options, this.databaseCollation));
|
|
1922
|
+
}
|
|
1923
|
+
|
|
1924
|
+
/**
|
|
1925
|
+
* Start a transaction.
|
|
1926
|
+
*
|
|
1927
|
+
* @param callback
|
|
1928
|
+
* @param name A string representing a name to associate with the transaction.
|
|
1929
|
+
* Optional, and defaults to an empty string. Required when `isolationLevel`
|
|
1930
|
+
* is present.
|
|
1931
|
+
* @param isolationLevel The isolation level that the transaction is to be run with.
|
|
1932
|
+
*
|
|
1933
|
+
* The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.
|
|
1934
|
+
* * `READ_UNCOMMITTED`
|
|
1935
|
+
* * `READ_COMMITTED`
|
|
1936
|
+
* * `REPEATABLE_READ`
|
|
1937
|
+
* * `SERIALIZABLE`
|
|
1938
|
+
* * `SNAPSHOT`
|
|
1939
|
+
*
|
|
1940
|
+
* Optional, and defaults to the Connection's isolation level.
|
|
1941
|
+
*/
|
|
1942
|
+
beginTransaction(callback, name = '', isolationLevel = this.config.options.isolationLevel) {
|
|
1943
|
+
(0, _transaction.assertValidIsolationLevel)(isolationLevel, 'isolationLevel');
|
|
1944
|
+
const transaction = new _transaction.Transaction(name, isolationLevel);
|
|
1945
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
1946
|
+
return this.execSqlBatch(new _request.default('SET TRANSACTION ISOLATION LEVEL ' + transaction.isolationLevelToTSQL() + ';BEGIN TRAN ' + transaction.name, err => {
|
|
1947
|
+
this.transactionDepth++;
|
|
1948
|
+
if (this.transactionDepth === 1) {
|
|
1949
|
+
this.inTransaction = true;
|
|
1950
|
+
}
|
|
1951
|
+
callback(err);
|
|
1952
|
+
}));
|
|
1953
|
+
}
|
|
1954
|
+
const request = new _request.default(undefined, err => {
|
|
1955
|
+
return callback(err, this.currentTransactionDescriptor());
|
|
1956
|
+
});
|
|
1957
|
+
return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.beginPayload(this.currentTransactionDescriptor()));
|
|
1958
|
+
}
|
|
1959
|
+
|
|
1960
|
+
/**
|
|
1961
|
+
* Commit a transaction.
|
|
1962
|
+
*
|
|
1963
|
+
* There should be an active transaction - that is, [[beginTransaction]]
|
|
1964
|
+
* should have been previously called.
|
|
1965
|
+
*
|
|
1966
|
+
* @param callback
|
|
1967
|
+
* @param name A string representing a name to associate with the transaction.
|
|
1968
|
+
* Optional, and defaults to an empty string. Required when `isolationLevel`is present.
|
|
1969
|
+
*/
|
|
1970
|
+
commitTransaction(callback, name = '') {
|
|
1971
|
+
const transaction = new _transaction.Transaction(name);
|
|
1972
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
1973
|
+
return this.execSqlBatch(new _request.default('COMMIT TRAN ' + transaction.name, err => {
|
|
1974
|
+
this.transactionDepth--;
|
|
1975
|
+
if (this.transactionDepth === 0) {
|
|
1976
|
+
this.inTransaction = false;
|
|
1977
|
+
}
|
|
1978
|
+
callback(err);
|
|
1979
|
+
}));
|
|
1980
|
+
}
|
|
1981
|
+
const request = new _request.default(undefined, callback);
|
|
1982
|
+
return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.commitPayload(this.currentTransactionDescriptor()));
|
|
1983
|
+
}
|
|
1984
|
+
|
|
1985
|
+
/**
|
|
1986
|
+
* Rollback a transaction.
|
|
1987
|
+
*
|
|
1988
|
+
* There should be an active transaction - that is, [[beginTransaction]]
|
|
1989
|
+
* should have been previously called.
|
|
1990
|
+
*
|
|
1991
|
+
* @param callback
|
|
1992
|
+
* @param name A string representing a name to associate with the transaction.
|
|
1993
|
+
* Optional, and defaults to an empty string.
|
|
1994
|
+
* Required when `isolationLevel` is present.
|
|
1995
|
+
*/
|
|
1996
|
+
rollbackTransaction(callback, name = '') {
|
|
1997
|
+
const transaction = new _transaction.Transaction(name);
|
|
1998
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
1999
|
+
return this.execSqlBatch(new _request.default('ROLLBACK TRAN ' + transaction.name, err => {
|
|
2000
|
+
this.transactionDepth--;
|
|
2001
|
+
if (this.transactionDepth === 0) {
|
|
2002
|
+
this.inTransaction = false;
|
|
2003
|
+
}
|
|
2004
|
+
callback(err);
|
|
2005
|
+
}));
|
|
2006
|
+
}
|
|
2007
|
+
const request = new _request.default(undefined, callback);
|
|
2008
|
+
return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.rollbackPayload(this.currentTransactionDescriptor()));
|
|
2009
|
+
}
|
|
2010
|
+
|
|
2011
|
+
/**
|
|
2012
|
+
* Set a savepoint within a transaction.
|
|
2013
|
+
*
|
|
2014
|
+
* There should be an active transaction - that is, [[beginTransaction]]
|
|
2015
|
+
* should have been previously called.
|
|
2016
|
+
*
|
|
2017
|
+
* @param callback
|
|
2018
|
+
* @param name A string representing a name to associate with the transaction.\
|
|
2019
|
+
* Optional, and defaults to an empty string.
|
|
2020
|
+
* Required when `isolationLevel` is present.
|
|
2021
|
+
*/
|
|
2022
|
+
saveTransaction(callback, name) {
|
|
2023
|
+
const transaction = new _transaction.Transaction(name);
|
|
2024
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
2025
|
+
return this.execSqlBatch(new _request.default('SAVE TRAN ' + transaction.name, err => {
|
|
2026
|
+
this.transactionDepth++;
|
|
2027
|
+
callback(err);
|
|
2028
|
+
}));
|
|
2029
|
+
}
|
|
2030
|
+
const request = new _request.default(undefined, callback);
|
|
2031
|
+
return this.makeRequest(request, _packet.TYPE.TRANSACTION_MANAGER, transaction.savePayload(this.currentTransactionDescriptor()));
|
|
2032
|
+
}
|
|
2033
|
+
|
|
2034
|
+
/**
|
|
2035
|
+
* Run the given callback after starting a transaction, and commit or
|
|
2036
|
+
* rollback the transaction afterwards.
|
|
2037
|
+
*
|
|
2038
|
+
* This is a helper that employs [[beginTransaction]], [[commitTransaction]],
|
|
2039
|
+
* [[rollbackTransaction]], and [[saveTransaction]] to greatly simplify the
|
|
2040
|
+
* use of database transactions and automatically handle transaction nesting.
|
|
2041
|
+
*
|
|
2042
|
+
* @param cb
|
|
2043
|
+
* @param isolationLevel
|
|
2044
|
+
* The isolation level that the transaction is to be run with.
|
|
2045
|
+
*
|
|
2046
|
+
* The isolation levels are available from `require('tedious').ISOLATION_LEVEL`.
|
|
2047
|
+
* * `READ_UNCOMMITTED`
|
|
2048
|
+
* * `READ_COMMITTED`
|
|
2049
|
+
* * `REPEATABLE_READ`
|
|
2050
|
+
* * `SERIALIZABLE`
|
|
2051
|
+
* * `SNAPSHOT`
|
|
2052
|
+
*
|
|
2053
|
+
* Optional, and defaults to the Connection's isolation level.
|
|
2054
|
+
*/
|
|
2055
|
+
transaction(cb, isolationLevel) {
|
|
2056
|
+
if (typeof cb !== 'function') {
|
|
2057
|
+
throw new TypeError('`cb` must be a function');
|
|
2058
|
+
}
|
|
2059
|
+
const useSavepoint = this.inTransaction;
|
|
2060
|
+
const name = '_tedious_' + _crypto.default.randomBytes(10).toString('hex');
|
|
2061
|
+
const txDone = (err, done, ...args) => {
|
|
2062
|
+
if (err) {
|
|
2063
|
+
if (this.inTransaction && this.state === this.STATE.LOGGED_IN) {
|
|
2064
|
+
this.rollbackTransaction(txErr => {
|
|
2065
|
+
done(txErr || err, ...args);
|
|
2066
|
+
}, name);
|
|
2067
|
+
} else {
|
|
2068
|
+
done(err, ...args);
|
|
2069
|
+
}
|
|
2070
|
+
} else if (useSavepoint) {
|
|
2071
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
2072
|
+
this.transactionDepth--;
|
|
2073
|
+
}
|
|
2074
|
+
done(null, ...args);
|
|
2075
|
+
} else {
|
|
2076
|
+
this.commitTransaction(txErr => {
|
|
2077
|
+
done(txErr, ...args);
|
|
2078
|
+
}, name);
|
|
2079
|
+
}
|
|
2080
|
+
};
|
|
2081
|
+
if (useSavepoint) {
|
|
2082
|
+
return this.saveTransaction(err => {
|
|
2083
|
+
if (err) {
|
|
2084
|
+
return cb(err);
|
|
2085
|
+
}
|
|
2086
|
+
if (isolationLevel) {
|
|
2087
|
+
return this.execSqlBatch(new _request.default('SET transaction isolation level ' + this.getIsolationLevelText(isolationLevel), err => {
|
|
2088
|
+
return cb(err, txDone);
|
|
2089
|
+
}));
|
|
2090
|
+
} else {
|
|
2091
|
+
return cb(null, txDone);
|
|
2092
|
+
}
|
|
2093
|
+
}, name);
|
|
2094
|
+
} else {
|
|
2095
|
+
return this.beginTransaction(err => {
|
|
2096
|
+
if (err) {
|
|
2097
|
+
return cb(err);
|
|
2098
|
+
}
|
|
2099
|
+
return cb(null, txDone);
|
|
2100
|
+
}, name, isolationLevel);
|
|
2101
|
+
}
|
|
2102
|
+
}
|
|
2103
|
+
|
|
2104
|
+
/**
|
|
2105
|
+
* @private
|
|
2106
|
+
*/
|
|
2107
|
+
makeRequest(request, packetType, payload) {
|
|
2108
|
+
if (this.state !== this.STATE.LOGGED_IN) {
|
|
2109
|
+
const message = 'Requests can only be made in the ' + this.STATE.LOGGED_IN.name + ' state, not the ' + this.state.name + ' state';
|
|
2110
|
+
this.debug.log(message);
|
|
2111
|
+
request.callback(new _errors.RequestError(message, 'EINVALIDSTATE'));
|
|
2112
|
+
} else if (request.canceled) {
|
|
2113
|
+
process.nextTick(() => {
|
|
2114
|
+
request.callback(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
|
2115
|
+
});
|
|
2116
|
+
} else {
|
|
2117
|
+
if (packetType === _packet.TYPE.SQL_BATCH) {
|
|
2118
|
+
this.isSqlBatch = true;
|
|
2119
|
+
} else {
|
|
2120
|
+
this.isSqlBatch = false;
|
|
2121
|
+
}
|
|
2122
|
+
this.request = request;
|
|
2123
|
+
request.connection = this;
|
|
2124
|
+
request.rowCount = 0;
|
|
2125
|
+
request.rows = [];
|
|
2126
|
+
request.rst = [];
|
|
2127
|
+
const onCancel = () => {
|
|
2128
|
+
payloadStream.unpipe(message);
|
|
2129
|
+
payloadStream.destroy(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
|
2130
|
+
|
|
2131
|
+
// set the ignore bit and end the message.
|
|
2132
|
+
message.ignore = true;
|
|
2133
|
+
message.end();
|
|
2134
|
+
if (request instanceof _request.default && request.paused) {
|
|
2135
|
+
// resume the request if it was paused so we can read the remaining tokens
|
|
2136
|
+
request.resume();
|
|
2137
|
+
}
|
|
2138
|
+
};
|
|
2139
|
+
request.once('cancel', onCancel);
|
|
2140
|
+
this.createRequestTimer();
|
|
2141
|
+
const message = new _message.default({
|
|
2142
|
+
type: packetType,
|
|
2143
|
+
resetConnection: this.resetConnectionOnNextRequest
|
|
2144
|
+
});
|
|
2145
|
+
this.messageIo.outgoingMessageStream.write(message);
|
|
2146
|
+
this.transitionTo(this.STATE.SENT_CLIENT_REQUEST);
|
|
2147
|
+
message.once('finish', () => {
|
|
2148
|
+
request.removeListener('cancel', onCancel);
|
|
2149
|
+
request.once('cancel', this._cancelAfterRequestSent);
|
|
2150
|
+
this.resetConnectionOnNextRequest = false;
|
|
2151
|
+
this.debug.payload(function () {
|
|
2152
|
+
return payload.toString(' ');
|
|
2153
|
+
});
|
|
2154
|
+
});
|
|
2155
|
+
const payloadStream = _stream.Readable.from(payload);
|
|
2156
|
+
payloadStream.once('error', error => {
|
|
2157
|
+
payloadStream.unpipe(message);
|
|
2158
|
+
|
|
2159
|
+
// Only set a request error if no error was set yet.
|
|
2160
|
+
request.error ??= error;
|
|
2161
|
+
message.ignore = true;
|
|
2162
|
+
message.end();
|
|
2163
|
+
});
|
|
2164
|
+
payloadStream.pipe(message);
|
|
2165
|
+
}
|
|
2166
|
+
}
|
|
2167
|
+
|
|
2168
|
+
/**
|
|
2169
|
+
* Cancel currently executed request.
|
|
2170
|
+
*/
|
|
2171
|
+
cancel() {
|
|
2172
|
+
if (!this.request) {
|
|
2173
|
+
return false;
|
|
2174
|
+
}
|
|
2175
|
+
if (this.request.canceled) {
|
|
2176
|
+
return false;
|
|
2177
|
+
}
|
|
2178
|
+
this.request.cancel();
|
|
2179
|
+
return true;
|
|
2180
|
+
}
|
|
2181
|
+
|
|
2182
|
+
/**
|
|
2183
|
+
* Reset the connection to its initial state.
|
|
2184
|
+
* Can be useful for connection pool implementations.
|
|
2185
|
+
*
|
|
2186
|
+
* @param callback
|
|
2187
|
+
*/
|
|
2188
|
+
reset(callback) {
|
|
2189
|
+
const request = new _request.default(this.getInitialSql(), err => {
|
|
2190
|
+
if (this.config.options.tdsVersion < '7_2') {
|
|
2191
|
+
this.inTransaction = false;
|
|
2192
|
+
}
|
|
2193
|
+
callback(err);
|
|
2194
|
+
});
|
|
2195
|
+
this.resetConnectionOnNextRequest = true;
|
|
2196
|
+
this.execSqlBatch(request);
|
|
2197
|
+
}
|
|
2198
|
+
|
|
2199
|
+
/**
|
|
2200
|
+
* @private
|
|
2201
|
+
*/
|
|
2202
|
+
currentTransactionDescriptor() {
|
|
2203
|
+
return this.transactionDescriptors[this.transactionDescriptors.length - 1];
|
|
2204
|
+
}
|
|
2205
|
+
|
|
2206
|
+
/**
|
|
2207
|
+
* @private
|
|
2208
|
+
*/
|
|
2209
|
+
getIsolationLevelText(isolationLevel) {
|
|
2210
|
+
switch (isolationLevel) {
|
|
2211
|
+
case _transaction.ISOLATION_LEVEL.READ_UNCOMMITTED:
|
|
2212
|
+
return 'read uncommitted';
|
|
2213
|
+
case _transaction.ISOLATION_LEVEL.REPEATABLE_READ:
|
|
2214
|
+
return 'repeatable read';
|
|
2215
|
+
case _transaction.ISOLATION_LEVEL.SERIALIZABLE:
|
|
2216
|
+
return 'serializable';
|
|
2217
|
+
case _transaction.ISOLATION_LEVEL.SNAPSHOT:
|
|
2218
|
+
return 'snapshot';
|
|
2219
|
+
default:
|
|
2220
|
+
return 'read committed';
|
|
2221
|
+
}
|
|
2222
|
+
}
|
|
2223
|
+
|
|
2224
|
+
/**
|
|
2225
|
+
* @private
|
|
2226
|
+
*/
|
|
2227
|
+
async performTlsNegotiation(preloginPayload, signal) {
|
|
2228
|
+
signal.throwIfAborted();
|
|
2229
|
+
const {
|
|
2230
|
+
promise: signalAborted,
|
|
2231
|
+
reject
|
|
2232
|
+
} = withResolvers();
|
|
2233
|
+
const onAbort = () => {
|
|
2234
|
+
reject(signal.reason);
|
|
2235
|
+
};
|
|
2236
|
+
signal.addEventListener('abort', onAbort, {
|
|
2237
|
+
once: true
|
|
2238
|
+
});
|
|
2239
|
+
try {
|
|
2240
|
+
if (preloginPayload.fedAuthRequired === 1) {
|
|
2241
|
+
this.fedAuthRequired = true;
|
|
2242
|
+
}
|
|
2243
|
+
if ('strict' !== this.config.options.encrypt && (preloginPayload.encryptionString === 'ON' || preloginPayload.encryptionString === 'REQ')) {
|
|
2244
|
+
if (!this.config.options.encrypt) {
|
|
2245
|
+
throw new _errors.ConnectionError("Server requires encryption, set 'encrypt' config option to true.", 'EENCRYPT');
|
|
2246
|
+
}
|
|
2247
|
+
this.transitionTo(this.STATE.SENT_TLSSSLNEGOTIATION);
|
|
2248
|
+
await Promise.race([this.messageIo.startTls(this.secureContextOptions, this.config.options.serverName ? this.config.options.serverName : this.routingData?.server ?? this.config.server, this.config.options.trustServerCertificate).catch(err => {
|
|
2249
|
+
throw this.wrapSocketError(err);
|
|
2250
|
+
}), signalAborted]);
|
|
2251
|
+
}
|
|
2252
|
+
} finally {
|
|
2253
|
+
signal.removeEventListener('abort', onAbort);
|
|
2254
|
+
}
|
|
2255
|
+
}
|
|
2256
|
+
async readPreloginResponse(signal) {
|
|
2257
|
+
signal.throwIfAborted();
|
|
2258
|
+
let messageBuffer = Buffer.alloc(0);
|
|
2259
|
+
const {
|
|
2260
|
+
promise: signalAborted,
|
|
2261
|
+
reject
|
|
2262
|
+
} = withResolvers();
|
|
2263
|
+
const onAbort = () => {
|
|
2264
|
+
reject(signal.reason);
|
|
2265
|
+
};
|
|
2266
|
+
signal.addEventListener('abort', onAbort, {
|
|
2267
|
+
once: true
|
|
2268
|
+
});
|
|
2269
|
+
try {
|
|
2270
|
+
const message = await Promise.race([this.messageIo.readMessage().catch(err => {
|
|
2271
|
+
throw this.wrapSocketError(err);
|
|
2272
|
+
}), signalAborted]);
|
|
2273
|
+
const iterator = message[Symbol.asyncIterator]();
|
|
2274
|
+
try {
|
|
2275
|
+
while (true) {
|
|
2276
|
+
const {
|
|
2277
|
+
done,
|
|
2278
|
+
value
|
|
2279
|
+
} = await Promise.race([iterator.next(), signalAborted]);
|
|
2280
|
+
if (done) {
|
|
2281
|
+
break;
|
|
2282
|
+
}
|
|
2283
|
+
messageBuffer = Buffer.concat([messageBuffer, value]);
|
|
2284
|
+
}
|
|
2285
|
+
} finally {
|
|
2286
|
+
if (iterator.return) {
|
|
2287
|
+
await iterator.return();
|
|
2288
|
+
}
|
|
2289
|
+
}
|
|
2290
|
+
} finally {
|
|
2291
|
+
signal.removeEventListener('abort', onAbort);
|
|
2292
|
+
}
|
|
2293
|
+
const preloginPayload = new _preloginPayload.default(messageBuffer);
|
|
2294
|
+
this.debug.payload(function () {
|
|
2295
|
+
return preloginPayload.toString(' ');
|
|
2296
|
+
});
|
|
2297
|
+
return preloginPayload;
|
|
2298
|
+
}
|
|
2299
|
+
|
|
2300
|
+
/**
|
|
2301
|
+
* @private
|
|
2302
|
+
*/
|
|
2303
|
+
async performReRouting() {
|
|
2304
|
+
this.socket.removeListener('error', this._onSocketError);
|
|
2305
|
+
this.socket.removeListener('close', this._onSocketClose);
|
|
2306
|
+
this.socket.removeListener('end', this._onSocketEnd);
|
|
2307
|
+
this.socket.destroy();
|
|
2308
|
+
this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');
|
|
2309
|
+
this.emit('rerouting');
|
|
2310
|
+
this.debug.log('Rerouting to ' + this.routingData.server + ':' + this.routingData.port);
|
|
2311
|
+
|
|
2312
|
+
// Attempt connecting to the rerouting target
|
|
2313
|
+
this.transitionTo(this.STATE.CONNECTING);
|
|
2314
|
+
await this.initialiseConnection();
|
|
2315
|
+
}
|
|
2316
|
+
|
|
2317
|
+
/**
|
|
2318
|
+
* @private
|
|
2319
|
+
*/
|
|
2320
|
+
async performTransientFailureRetry() {
|
|
2321
|
+
this.curTransientRetryCount++;
|
|
2322
|
+
this.socket.removeListener('error', this._onSocketError);
|
|
2323
|
+
this.socket.removeListener('close', this._onSocketClose);
|
|
2324
|
+
this.socket.removeListener('end', this._onSocketEnd);
|
|
2325
|
+
this.socket.destroy();
|
|
2326
|
+
this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');
|
|
2327
|
+
const server = this.routingData ? this.routingData.server : this.config.server;
|
|
2328
|
+
const port = this.routingData ? this.routingData.port : this.config.options.port;
|
|
2329
|
+
this.debug.log('Retry after transient failure connecting to ' + server + ':' + port);
|
|
2330
|
+
const {
|
|
2331
|
+
promise,
|
|
2332
|
+
resolve
|
|
2333
|
+
} = withResolvers();
|
|
2334
|
+
setTimeout(resolve, this.config.options.connectionRetryInterval);
|
|
2335
|
+
await promise;
|
|
2336
|
+
this.emit('retry');
|
|
2337
|
+
this.transitionTo(this.STATE.CONNECTING);
|
|
2338
|
+
await this.initialiseConnection();
|
|
2339
|
+
}
|
|
2340
|
+
|
|
2341
|
+
/**
|
|
2342
|
+
* @private
|
|
2343
|
+
*/
|
|
2344
|
+
async performSentLogin7WithStandardLogin(signal) {
|
|
2345
|
+
signal.throwIfAborted();
|
|
2346
|
+
const {
|
|
2347
|
+
promise: signalAborted,
|
|
2348
|
+
reject
|
|
2349
|
+
} = withResolvers();
|
|
2350
|
+
const onAbort = () => {
|
|
2351
|
+
reject(signal.reason);
|
|
2352
|
+
};
|
|
2353
|
+
signal.addEventListener('abort', onAbort, {
|
|
2354
|
+
once: true
|
|
2355
|
+
});
|
|
2356
|
+
try {
|
|
2357
|
+
const message = await Promise.race([this.messageIo.readMessage().catch(err => {
|
|
2358
|
+
throw this.wrapSocketError(err);
|
|
2359
|
+
}), signalAborted]);
|
|
2360
|
+
const handler = new _handler.Login7TokenHandler(this);
|
|
2361
|
+
const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
|
2362
|
+
await (0, _events.once)(tokenStreamParser, 'end');
|
|
2363
|
+
if (handler.loginAckReceived) {
|
|
2364
|
+
return handler.routingData;
|
|
2365
|
+
} else if (this.loginError) {
|
|
2366
|
+
throw this.loginError;
|
|
2367
|
+
} else {
|
|
2368
|
+
throw new _errors.ConnectionError('Login failed.', 'ELOGIN');
|
|
2369
|
+
}
|
|
2370
|
+
} finally {
|
|
2371
|
+
this.loginError = undefined;
|
|
2372
|
+
signal.removeEventListener('abort', onAbort);
|
|
2373
|
+
}
|
|
2374
|
+
}
|
|
2375
|
+
|
|
2376
|
+
/**
|
|
2377
|
+
* @private
|
|
2378
|
+
*/
|
|
2379
|
+
async performSentLogin7WithNTLMLogin(signal) {
|
|
2380
|
+
signal.throwIfAborted();
|
|
2381
|
+
const {
|
|
2382
|
+
promise: signalAborted,
|
|
2383
|
+
reject
|
|
2384
|
+
} = withResolvers();
|
|
2385
|
+
const onAbort = () => {
|
|
2386
|
+
reject(signal.reason);
|
|
2387
|
+
};
|
|
2388
|
+
signal.addEventListener('abort', onAbort, {
|
|
2389
|
+
once: true
|
|
2390
|
+
});
|
|
2391
|
+
try {
|
|
2392
|
+
while (true) {
|
|
2393
|
+
const message = await Promise.race([this.messageIo.readMessage().catch(err => {
|
|
2394
|
+
throw this.wrapSocketError(err);
|
|
2395
|
+
}), signalAborted]);
|
|
2396
|
+
const handler = new _handler.Login7TokenHandler(this);
|
|
2397
|
+
const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
|
2398
|
+
await Promise.race([(0, _events.once)(tokenStreamParser, 'end'), signalAborted]);
|
|
2399
|
+
if (handler.loginAckReceived) {
|
|
2400
|
+
return handler.routingData;
|
|
2401
|
+
} else if (this.ntlmpacket) {
|
|
2402
|
+
const authentication = this.config.authentication;
|
|
2403
|
+
const payload = new _ntlmPayload.default({
|
|
2404
|
+
domain: authentication.options.domain,
|
|
2405
|
+
userName: authentication.options.userName,
|
|
2406
|
+
password: authentication.options.password,
|
|
2407
|
+
ntlmpacket: this.ntlmpacket
|
|
2408
|
+
});
|
|
2409
|
+
this.messageIo.sendMessage(_packet.TYPE.NTLMAUTH_PKT, payload.data);
|
|
2410
|
+
this.debug.payload(function () {
|
|
2411
|
+
return payload.toString(' ');
|
|
2412
|
+
});
|
|
2413
|
+
this.ntlmpacket = undefined;
|
|
2414
|
+
} else if (this.loginError) {
|
|
2415
|
+
throw this.loginError;
|
|
2416
|
+
} else {
|
|
2417
|
+
throw new _errors.ConnectionError('Login failed.', 'ELOGIN');
|
|
2418
|
+
}
|
|
2419
|
+
}
|
|
2420
|
+
} finally {
|
|
2421
|
+
this.loginError = undefined;
|
|
2422
|
+
signal.removeEventListener('abort', onAbort);
|
|
2423
|
+
}
|
|
2424
|
+
}
|
|
2425
|
+
|
|
2426
|
+
/**
|
|
2427
|
+
* @private
|
|
2428
|
+
*/
|
|
2429
|
+
async performSentLogin7WithFedAuth(signal) {
|
|
2430
|
+
signal.throwIfAborted();
|
|
2431
|
+
const {
|
|
2432
|
+
promise: signalAborted,
|
|
2433
|
+
reject
|
|
2434
|
+
} = withResolvers();
|
|
2435
|
+
const onAbort = () => {
|
|
2436
|
+
reject(signal.reason);
|
|
2437
|
+
};
|
|
2438
|
+
signal.addEventListener('abort', onAbort, {
|
|
2439
|
+
once: true
|
|
2440
|
+
});
|
|
2441
|
+
try {
|
|
2442
|
+
const message = await Promise.race([this.messageIo.readMessage().catch(err => {
|
|
2443
|
+
throw this.wrapSocketError(err);
|
|
2444
|
+
}), signalAborted]);
|
|
2445
|
+
const handler = new _handler.Login7TokenHandler(this);
|
|
2446
|
+
const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
|
2447
|
+
await Promise.race([(0, _events.once)(tokenStreamParser, 'end'), signalAborted]);
|
|
2448
|
+
if (handler.loginAckReceived) {
|
|
2449
|
+
return handler.routingData;
|
|
2450
|
+
}
|
|
2451
|
+
const fedAuthInfoToken = handler.fedAuthInfoToken;
|
|
2452
|
+
if (fedAuthInfoToken && fedAuthInfoToken.stsurl && fedAuthInfoToken.spn) {
|
|
2453
|
+
/** Federated authentication configation. */
|
|
2454
|
+
const authentication = this.config.authentication;
|
|
2455
|
+
/** Permission scope to pass to Entra ID when requesting an authentication token. */
|
|
2456
|
+
const tokenScope = new _url.URL('/.default', fedAuthInfoToken.spn).toString();
|
|
2457
|
+
|
|
2458
|
+
/** Instance of the token credential to use to authenticate to the resource. */
|
|
2459
|
+
let credentials;
|
|
2460
|
+
switch (authentication.type) {
|
|
2461
|
+
case 'token-credential':
|
|
2462
|
+
credentials = authentication.options.credential;
|
|
2463
|
+
break;
|
|
2464
|
+
case 'azure-active-directory-password':
|
|
2465
|
+
credentials = new _identity.UsernamePasswordCredential(authentication.options.tenantId ?? 'common', authentication.options.clientId, authentication.options.userName, authentication.options.password);
|
|
2466
|
+
break;
|
|
2467
|
+
case 'azure-active-directory-msi-vm':
|
|
2468
|
+
case 'azure-active-directory-msi-app-service':
|
|
2469
|
+
const msiArgs = authentication.options.clientId ? [authentication.options.clientId, {}] : [{}];
|
|
2470
|
+
credentials = new _identity.ManagedIdentityCredential(...msiArgs);
|
|
2471
|
+
break;
|
|
2472
|
+
case 'azure-active-directory-default':
|
|
2473
|
+
const args = authentication.options.clientId ? {
|
|
2474
|
+
managedIdentityClientId: authentication.options.clientId
|
|
2475
|
+
} : {};
|
|
2476
|
+
credentials = new _identity.DefaultAzureCredential(args);
|
|
2477
|
+
break;
|
|
2478
|
+
case 'azure-active-directory-service-principal-secret':
|
|
2479
|
+
credentials = new _identity.ClientSecretCredential(authentication.options.tenantId, authentication.options.clientId, authentication.options.clientSecret);
|
|
2480
|
+
break;
|
|
2481
|
+
}
|
|
2482
|
+
|
|
2483
|
+
/** Access token retrieved from Entra ID for the configured permission scope(s). */
|
|
2484
|
+
let tokenResponse;
|
|
2485
|
+
try {
|
|
2486
|
+
tokenResponse = await Promise.race([credentials.getToken(tokenScope), signalAborted]);
|
|
2487
|
+
} catch (err) {
|
|
2488
|
+
signal.throwIfAborted();
|
|
2489
|
+
throw new AggregateError([new _errors.ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH'), err]);
|
|
2490
|
+
}
|
|
2491
|
+
|
|
2492
|
+
// Type guard the token value so that it is never null.
|
|
2493
|
+
if (tokenResponse === null) {
|
|
2494
|
+
throw new AggregateError([new _errors.ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH')]);
|
|
2495
|
+
}
|
|
2496
|
+
this.sendFedAuthTokenMessage(tokenResponse.token);
|
|
2497
|
+
// sent the fedAuth token message, the rest is similar to standard login 7
|
|
2498
|
+
this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);
|
|
2499
|
+
return await this.performSentLogin7WithStandardLogin(signal);
|
|
2500
|
+
} else if (this.loginError) {
|
|
2501
|
+
throw this.loginError;
|
|
2502
|
+
} else {
|
|
2503
|
+
throw new _errors.ConnectionError('Login failed.', 'ELOGIN');
|
|
2504
|
+
}
|
|
2505
|
+
} finally {
|
|
2506
|
+
this.loginError = undefined;
|
|
2507
|
+
signal.removeEventListener('abort', onAbort);
|
|
2508
|
+
}
|
|
2509
|
+
}
|
|
2510
|
+
|
|
2511
|
+
/**
|
|
2512
|
+
* @private
|
|
2513
|
+
*/
|
|
2514
|
+
async performLoggedInSendingInitialSql(signal) {
|
|
2515
|
+
signal.throwIfAborted();
|
|
2516
|
+
const {
|
|
2517
|
+
promise: signalAborted,
|
|
2518
|
+
reject
|
|
2519
|
+
} = withResolvers();
|
|
2520
|
+
const onAbort = () => {
|
|
2521
|
+
reject(signal.reason);
|
|
2522
|
+
};
|
|
2523
|
+
signal.addEventListener('abort', onAbort, {
|
|
2524
|
+
once: true
|
|
2525
|
+
});
|
|
2526
|
+
try {
|
|
2527
|
+
this.sendInitialSql();
|
|
2528
|
+
const message = await Promise.race([this.messageIo.readMessage().catch(err => {
|
|
2529
|
+
throw this.wrapSocketError(err);
|
|
2530
|
+
}), signalAborted]);
|
|
2531
|
+
const tokenStreamParser = this.createTokenStreamParser(message, new _handler.InitialSqlTokenHandler(this));
|
|
2532
|
+
await Promise.race([(0, _events.once)(tokenStreamParser, 'end'), signalAborted]);
|
|
2533
|
+
} finally {
|
|
2534
|
+
signal.removeEventListener('abort', onAbort);
|
|
2535
|
+
}
|
|
2536
|
+
}
|
|
2537
|
+
}
|
|
2538
|
+
function isTransientError(error) {
|
|
2539
|
+
if (error instanceof AggregateError) {
|
|
2540
|
+
error = error.errors[0];
|
|
2541
|
+
}
|
|
2542
|
+
return error instanceof _errors.ConnectionError && !!error.isTransient;
|
|
2543
|
+
}
|
|
2544
|
+
var _default = exports.default = Connection;
|
|
2545
|
+
module.exports = Connection;
|
|
2546
|
+
Connection.prototype.STATE = {
|
|
2547
|
+
INITIALIZED: {
|
|
2548
|
+
name: 'Initialized',
|
|
2549
|
+
events: {}
|
|
2550
|
+
},
|
|
2551
|
+
CONNECTING: {
|
|
2552
|
+
name: 'Connecting',
|
|
2553
|
+
events: {}
|
|
2554
|
+
},
|
|
2555
|
+
SENT_PRELOGIN: {
|
|
2556
|
+
name: 'SentPrelogin',
|
|
2557
|
+
events: {}
|
|
2558
|
+
},
|
|
2559
|
+
REROUTING: {
|
|
2560
|
+
name: 'ReRouting',
|
|
2561
|
+
events: {}
|
|
2562
|
+
},
|
|
2563
|
+
TRANSIENT_FAILURE_RETRY: {
|
|
2564
|
+
name: 'TRANSIENT_FAILURE_RETRY',
|
|
2565
|
+
events: {}
|
|
2566
|
+
},
|
|
2567
|
+
SENT_TLSSSLNEGOTIATION: {
|
|
2568
|
+
name: 'SentTLSSSLNegotiation',
|
|
2569
|
+
events: {}
|
|
2570
|
+
},
|
|
2571
|
+
SENT_LOGIN7_WITH_STANDARD_LOGIN: {
|
|
2572
|
+
name: 'SentLogin7WithStandardLogin',
|
|
2573
|
+
events: {}
|
|
2574
|
+
},
|
|
2575
|
+
SENT_LOGIN7_WITH_NTLM: {
|
|
2576
|
+
name: 'SentLogin7WithNTLMLogin',
|
|
2577
|
+
events: {}
|
|
2578
|
+
},
|
|
2579
|
+
SENT_LOGIN7_WITH_FEDAUTH: {
|
|
2580
|
+
name: 'SentLogin7WithFedauth',
|
|
2581
|
+
events: {}
|
|
2582
|
+
},
|
|
2583
|
+
LOGGED_IN_SENDING_INITIAL_SQL: {
|
|
2584
|
+
name: 'LoggedInSendingInitialSql',
|
|
2585
|
+
events: {}
|
|
2586
|
+
},
|
|
2587
|
+
LOGGED_IN: {
|
|
2588
|
+
name: 'LoggedIn',
|
|
2589
|
+
events: {
|
|
2590
|
+
socketError: function () {
|
|
2591
|
+
this.transitionTo(this.STATE.FINAL);
|
|
2592
|
+
this.cleanupConnection();
|
|
2593
|
+
}
|
|
2594
|
+
}
|
|
2595
|
+
},
|
|
2596
|
+
SENT_CLIENT_REQUEST: {
|
|
2597
|
+
name: 'SentClientRequest',
|
|
2598
|
+
enter: function () {
|
|
2599
|
+
(async () => {
|
|
2600
|
+
let message;
|
|
2601
|
+
try {
|
|
2602
|
+
message = await this.messageIo.readMessage();
|
|
2603
|
+
} catch (err) {
|
|
2604
|
+
this.dispatchEvent('socketError', err);
|
|
2605
|
+
process.nextTick(() => {
|
|
2606
|
+
this.emit('error', this.wrapSocketError(err));
|
|
2607
|
+
});
|
|
2608
|
+
return;
|
|
2609
|
+
}
|
|
2610
|
+
// request timer is stopped on first data package
|
|
2611
|
+
this.clearRequestTimer();
|
|
2612
|
+
const tokenStreamParser = this.createTokenStreamParser(message, new _handler.RequestTokenHandler(this, this.request));
|
|
2613
|
+
|
|
2614
|
+
// If the request was canceled and we have a `cancelTimer`
|
|
2615
|
+
// defined, we send a attention message after the
|
|
2616
|
+
// request message was fully sent off.
|
|
2617
|
+
//
|
|
2618
|
+
// We already started consuming the current message
|
|
2619
|
+
// (but all the token handlers should be no-ops), and
|
|
2620
|
+
// need to ensure the next message is handled by the
|
|
2621
|
+
// `SENT_ATTENTION` state.
|
|
2622
|
+
if (this.request?.canceled && this.cancelTimer) {
|
|
2623
|
+
return this.transitionTo(this.STATE.SENT_ATTENTION);
|
|
2624
|
+
}
|
|
2625
|
+
const onResume = () => {
|
|
2626
|
+
tokenStreamParser.resume();
|
|
2627
|
+
};
|
|
2628
|
+
const onPause = () => {
|
|
2629
|
+
tokenStreamParser.pause();
|
|
2630
|
+
this.request?.once('resume', onResume);
|
|
2631
|
+
};
|
|
2632
|
+
this.request?.on('pause', onPause);
|
|
2633
|
+
if (this.request instanceof _request.default && this.request.paused) {
|
|
2634
|
+
onPause();
|
|
2635
|
+
}
|
|
2636
|
+
const onCancel = () => {
|
|
2637
|
+
tokenStreamParser.removeListener('end', onEndOfMessage);
|
|
2638
|
+
if (this.request instanceof _request.default && this.request.paused) {
|
|
2639
|
+
// resume the request if it was paused so we can read the remaining tokens
|
|
2640
|
+
this.request.resume();
|
|
2641
|
+
}
|
|
2642
|
+
this.request?.removeListener('pause', onPause);
|
|
2643
|
+
this.request?.removeListener('resume', onResume);
|
|
2644
|
+
|
|
2645
|
+
// The `_cancelAfterRequestSent` callback will have sent a
|
|
2646
|
+
// attention message, so now we need to also switch to
|
|
2647
|
+
// the `SENT_ATTENTION` state to make sure the attention ack
|
|
2648
|
+
// message is processed correctly.
|
|
2649
|
+
this.transitionTo(this.STATE.SENT_ATTENTION);
|
|
2650
|
+
};
|
|
2651
|
+
const onEndOfMessage = () => {
|
|
2652
|
+
this.request?.removeListener('cancel', this._cancelAfterRequestSent);
|
|
2653
|
+
this.request?.removeListener('cancel', onCancel);
|
|
2654
|
+
this.request?.removeListener('pause', onPause);
|
|
2655
|
+
this.request?.removeListener('resume', onResume);
|
|
2656
|
+
this.transitionTo(this.STATE.LOGGED_IN);
|
|
2657
|
+
const sqlRequest = this.request;
|
|
2658
|
+
this.request = undefined;
|
|
2659
|
+
if (this.config.options.tdsVersion < '7_2' && sqlRequest.error && this.isSqlBatch) {
|
|
2660
|
+
this.inTransaction = false;
|
|
2661
|
+
}
|
|
2662
|
+
sqlRequest.callback(sqlRequest.error, sqlRequest.rowCount, sqlRequest.rows);
|
|
2663
|
+
};
|
|
2664
|
+
tokenStreamParser.once('end', onEndOfMessage);
|
|
2665
|
+
this.request?.once('cancel', onCancel);
|
|
2666
|
+
})();
|
|
2667
|
+
},
|
|
2668
|
+
exit: function (nextState) {
|
|
2669
|
+
this.clearRequestTimer();
|
|
2670
|
+
},
|
|
2671
|
+
events: {
|
|
2672
|
+
socketError: function (err) {
|
|
2673
|
+
const sqlRequest = this.request;
|
|
2674
|
+
this.request = undefined;
|
|
2675
|
+
this.transitionTo(this.STATE.FINAL);
|
|
2676
|
+
this.cleanupConnection();
|
|
2677
|
+
sqlRequest.callback(err);
|
|
2678
|
+
}
|
|
2679
|
+
}
|
|
2680
|
+
},
|
|
2681
|
+
SENT_ATTENTION: {
|
|
2682
|
+
name: 'SentAttention',
|
|
2683
|
+
enter: function () {
|
|
2684
|
+
(async () => {
|
|
2685
|
+
let message;
|
|
2686
|
+
try {
|
|
2687
|
+
message = await this.messageIo.readMessage();
|
|
2688
|
+
} catch (err) {
|
|
2689
|
+
this.dispatchEvent('socketError', err);
|
|
2690
|
+
process.nextTick(() => {
|
|
2691
|
+
this.emit('error', this.wrapSocketError(err));
|
|
2692
|
+
});
|
|
2693
|
+
return;
|
|
2694
|
+
}
|
|
2695
|
+
const handler = new _handler.AttentionTokenHandler(this, this.request);
|
|
2696
|
+
const tokenStreamParser = this.createTokenStreamParser(message, handler);
|
|
2697
|
+
await (0, _events.once)(tokenStreamParser, 'end');
|
|
2698
|
+
// 3.2.5.7 Sent Attention State
|
|
2699
|
+
// Discard any data contained in the response, until we receive the attention response
|
|
2700
|
+
if (handler.attentionReceived) {
|
|
2701
|
+
this.clearCancelTimer();
|
|
2702
|
+
const sqlRequest = this.request;
|
|
2703
|
+
this.request = undefined;
|
|
2704
|
+
this.transitionTo(this.STATE.LOGGED_IN);
|
|
2705
|
+
if (sqlRequest.error && sqlRequest.error instanceof _errors.RequestError && sqlRequest.error.code === 'ETIMEOUT') {
|
|
2706
|
+
sqlRequest.callback(sqlRequest.error);
|
|
2707
|
+
} else {
|
|
2708
|
+
sqlRequest.callback(new _errors.RequestError('Canceled.', 'ECANCEL'));
|
|
2709
|
+
}
|
|
2710
|
+
}
|
|
2711
|
+
})().catch(err => {
|
|
2712
|
+
process.nextTick(() => {
|
|
2713
|
+
throw err;
|
|
2714
|
+
});
|
|
2715
|
+
});
|
|
2716
|
+
},
|
|
2717
|
+
events: {
|
|
2718
|
+
socketError: function (err) {
|
|
2719
|
+
const sqlRequest = this.request;
|
|
2720
|
+
this.request = undefined;
|
|
2721
|
+
this.transitionTo(this.STATE.FINAL);
|
|
2722
|
+
this.cleanupConnection();
|
|
2723
|
+
sqlRequest.callback(err);
|
|
2724
|
+
}
|
|
2725
|
+
}
|
|
2726
|
+
},
|
|
2727
|
+
FINAL: {
|
|
2728
|
+
name: 'Final',
|
|
2729
|
+
events: {}
|
|
2730
|
+
}
|
|
2731
|
+
};
|
|
2732
|
+
//# 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","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","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","withResolvers","resolve","reject","promise","Promise","res","rej","Connection","EventEmitter","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","_cancelAfterRequestSent","messageIo","sendMessage","TYPE","ATTENTION","createCancelTimer","_onSocketClose","socketClose","_onSocketEnd","socketEnd","_onSocketError","error","dispatchEvent","process","nextTick","emit","wrapSocketError","connect","connectListener","ConnectionError","name","onConnect","err","removeListener","onError","once","transitionTo","CONNECTING","initialiseConnection","then","FINAL","on","event","listener","args","close","cleanupConnection","timeoutController","AbortController","connectTimer","setTimeout","hostPostfix","routingData","routingMessage","message","log","abort","signal","instanceLookup","timeout","throwIfAborted","cause","socket","connectOnPort","controller","onClose","onEnd","code","AbortSignal","any","setKeepAlive","MessageIO","cleartext","sendPreLogin","SENT_PRELOGIN","preloginResponse","readPreloginResponse","performTlsNegotiation","sendLogin7Packet","SENT_LOGIN7_WITH_FEDAUTH","performSentLogin7WithFedAuth","SENT_LOGIN7_WITH_NTLM","performSentLogin7WithNTLMLogin","SENT_LOGIN7_WITH_STANDARD_LOGIN","performSentLogin7WithStandardLogin","isTransientError","TRANSIENT_FAILURE_RETRY","performTransientFailureRetry","REROUTING","performReRouting","LOGGED_IN_SENDING_INITIAL_SQL","performLoggedInSendingInitialSql","destroy","LOGGED_IN","clearTimeout","clearRequestTimer","closeConnection","request","RequestError","callback","Debug","createTokenStreamParser","handler","TokenStreamParser","wrapWithTls","secureContext","createSecureContext","isIP","encryptOptions","host","ALPNProtocols","servername","encryptsocket","onAbort","reason","addEventListener","removeEventListener","customConnector","connectOpts","connectInParallel","connectInSequence","dns","lookup","end","clearCancelTimer","cancelTimer","createRequestTimer","requestTimer","cancel","newState","exit","enter","apply","getEventHandler","eventName","events","SENT_TLSSSLNEGOTIATION","major","minor","build","exec","version","PreloginPayload","Number","subbuild","PRELOGIN","toString","Login7Payload","versions","clientProgVer","clientPid","pid","connectionId","clientTimeZone","Date","getTimezoneOffset","clientLcid","fedAuth","echo","workflow","fedAuthToken","sspi","createNTLMRequest","hostname","os","instance","libraryName","initDbFatal","LOGIN7","toBuffer","sendFedAuthTokenMessage","accessTokenLen","byteLength","offset","writeUInt32LE","write","FEDAUTH_TOKEN","sendInitialSql","SqlBatchPayload","getInitialSql","currentTransactionDescriptor","Message","SQL_BATCH","outgoingMessageStream","Readable","pipe","push","getIsolationLevelText","join","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","txErr","packetType","canceled","connection","rowCount","rst","payloadStream","unpipe","ignore","paused","resume","resetConnection","resetConnectionOnNextRequest","SENT_CLIENT_REQUEST","reset","READ_UNCOMMITTED","REPEATABLE_READ","SERIALIZABLE","SNAPSHOT","preloginPayload","signalAborted","encryptionString","race","startTls","catch","readMessage","iterator","Symbol","asyncIterator","next","concat","return","Login7TokenHandler","tokenStreamParser","loginAckReceived","loginError","ntlmpacket","NTLMResponsePayload","NTLMAUTH_PKT","fedAuthInfoToken","stsurl","spn","tokenScope","URL","credentials","UsernamePasswordCredential","msiArgs","ManagedIdentityCredential","managedIdentityClientId","DefaultAzureCredential","ClientSecretCredential","tokenResponse","getToken","AggregateError","InitialSqlTokenHandler","errors","isTransient","_default","exports","module","prototype","socketError","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    message?(this: Connection, message: Message): 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\ninterface RoutingData {\n  server: string;\n  port: number;\n  instance: string;\n}\n\n/**\n * Helper function, equivalent to `Promise.withResolvers()`.\n *\n * @returns An object with the properties `promise`, `resolve`, and `reject`.\n */\nfunction withResolvers<T>() {\n  let resolve: (value: T | PromiseLike<T>) => void;\n  let reject: (reason?: any) => void;\n\n  const promise = new Promise<T>((res, rej) => {\n    resolve = res;\n    reject = rej;\n  });\n\n  return { promise, resolve: resolve!, reject: reject! };\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 cancelTimer: undefined | NodeJS.Timeout;\n  /**\n   * @private\n   */\n  declare requestTimer: undefined | NodeJS.Timeout;\n\n  /**\n   * @private\n   */\n  declare _cancelAfterRequestSent: () => void;\n\n  /**\n   * @private\n   */\n  declare databaseCollation: Collation | undefined;\n\n  /**\n   * @private\n   */\n  declare _onSocketClose: (hadError: boolean) => void;\n\n  /**\n   * @private\n   */\n  declare _onSocketError: (err: Error) => void;\n\n  /**\n   * @private\n   */\n  declare _onSocketEnd: () => void;\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    this._onSocketClose = () => {\n      this.socketClose();\n    };\n\n    this._onSocketEnd = () => {\n      this.socketEnd();\n    };\n\n    this._onSocketError = (error) => {\n      this.dispatchEvent('socketError', error);\n      process.nextTick(() => {\n        this.emit('error', this.wrapSocketError(error));\n      });\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    this.initialiseConnection().then(() => {\n      process.nextTick(() => {\n        this.emit('connect');\n      });\n    }, (err) => {\n      this.transitionTo(this.STATE.FINAL);\n      this.closed = true;\n\n      process.nextTick(() => {\n        this.emit('connect', err);\n      });\n      process.nextTick(() => {\n        this.emit('end');\n      });\n    });\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: 'databaseMirroringPartner', partnerInstanceName: 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    this.cleanupConnection();\n  }\n\n  /**\n   * @private\n   */\n  async initialiseConnection() {\n    const timeoutController = new AbortController();\n\n    const connectTimer = setTimeout(() => {\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\n      timeoutController.abort(new ConnectionError(message, 'ETIMEOUT'));\n    }, this.config.options.connectTimeout);\n\n    try {\n      let signal = timeoutController.signal;\n\n      let port = this.config.options.port;\n\n      if (!port) {\n        try {\n          port = await instanceLookup({\n            server: this.config.server,\n            instanceName: this.config.options.instanceName!,\n            timeout: this.config.options.connectTimeout,\n            signal: signal\n          });\n        } catch (err: any) {\n          signal.throwIfAborted();\n\n          throw new ConnectionError(err.message, 'EINSTLOOKUP', { cause: err });\n        }\n      }\n\n      let socket;\n      try {\n        socket = await this.connectOnPort(port, this.config.options.multiSubnetFailover, signal, this.config.options.connector);\n      } catch (err: any) {\n        signal.throwIfAborted();\n\n        throw this.wrapSocketError(err);\n      }\n\n      try {\n        const controller = new AbortController();\n        const onError = (err: Error) => {\n          controller.abort(this.wrapSocketError(err));\n        };\n        const onClose = () => {\n          this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');\n        };\n        const onEnd = () => {\n          this.debug.log('socket ended');\n\n          const error: ErrorWithCode = new Error('socket hang up');\n          error.code = 'ECONNRESET';\n          controller.abort(this.wrapSocketError(error));\n        };\n\n        socket.once('error', onError);\n        socket.once('close', onClose);\n        socket.once('end', onEnd);\n\n        try {\n          signal = AbortSignal.any([signal, controller.signal]);\n\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\n          this.transitionTo(this.STATE.SENT_PRELOGIN);\n          const preloginResponse = await this.readPreloginResponse(signal);\n          await this.performTlsNegotiation(preloginResponse, signal);\n\n          this.sendLogin7Packet();\n\n          try {\n            const { authentication } = this.config;\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                this.routingData = await this.performSentLogin7WithFedAuth(signal);\n                break;\n              case 'ntlm':\n                this.transitionTo(this.STATE.SENT_LOGIN7_WITH_NTLM);\n                this.routingData = await this.performSentLogin7WithNTLMLogin(signal);\n                break;\n              default:\n                this.transitionTo(this.STATE.SENT_LOGIN7_WITH_STANDARD_LOGIN);\n                this.routingData = await this.performSentLogin7WithStandardLogin(signal);\n                break;\n            }\n          } catch (err: any) {\n            if (isTransientError(err)) {\n              this.debug.log('Initiating retry on transient error');\n              this.transitionTo(this.STATE.TRANSIENT_FAILURE_RETRY);\n              return await this.performTransientFailureRetry();\n            }\n\n            throw err;\n          }\n\n          // If routing data is present, we need to re-route the connection\n          if (this.routingData) {\n            this.transitionTo(this.STATE.REROUTING);\n            return await this.performReRouting();\n          }\n\n          this.transitionTo(this.STATE.LOGGED_IN_SENDING_INITIAL_SQL);\n          await this.performLoggedInSendingInitialSql(signal);\n        } finally {\n          socket.removeListener('error', onError);\n          socket.removeListener('close', onClose);\n          socket.removeListener('end', onEnd);\n        }\n      } catch (err) {\n        socket.destroy();\n\n        throw err;\n      }\n\n      socket.on('error', this._onSocketError);\n      socket.on('close', this._onSocketClose);\n      socket.on('end', this._onSocketEnd);\n\n      this.transitionTo(this.STATE.LOGGED_IN);\n    } finally {\n      clearTimeout(connectTimer);\n    }\n  }\n\n  /**\n   * @private\n   */\n  cleanupConnection() {\n    if (!this.closed) {\n      this.clearRequestTimer();\n      this.closeConnection();\n\n      process.nextTick(() => {\n        this.emit('end');\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    }\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  async wrapWithTls(socket: net.Socket, signal: AbortSignal): Promise<tls.TLSSocket> {\n    signal.throwIfAborted();\n\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 { promise, resolve, reject } = withResolvers<tls.TLSSocket>();\n    const encryptsocket = tls.connect(encryptOptions);\n\n    try {\n      const onAbort = () => { reject(signal.reason); };\n      signal.addEventListener('abort', onAbort, { once: true });\n\n      try {\n        const onError = reject;\n        const onConnect = () => { resolve(encryptsocket); };\n\n        encryptsocket.once('error', onError);\n        encryptsocket.once('secureConnect', onConnect);\n\n        try {\n          return await promise;\n        } finally {\n          encryptsocket.removeListener('error', onError);\n          encryptsocket.removeListener('connect', onConnect);\n        }\n      } finally {\n        signal.removeEventListener('abort', onAbort);\n      }\n    } catch (err: any) {\n      encryptsocket.destroy();\n\n      throw err;\n    }\n  }\n\n  async 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    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    return socket;\n  }\n\n  /**\n   * @private\n   */\n  closeConnection() {\n    if (this.socket) {\n      this.socket.destroy();\n    }\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  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  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  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  wrapSocketError(error: Error): ConnectionError {\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\n      return new ConnectionError(message, 'ESOCKET', { cause: error });\n    } else {\n      const message = `Connection lost - ${error.message}`;\n      return new ConnectionError(message, 'ESOCKET', { cause: error });\n    }\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\n      this.dispatchEvent('socketError', error);\n      process.nextTick(() => {\n        this.emit('error', this.wrapSocketError(error));\n      });\n    }\n  }\n\n  /**\n   * @private\n   */\n  socketClose() {\n    this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');\n    this.transitionTo(this.STATE.FINAL);\n    this.cleanupConnection();\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 ?\n      `${this.routingData.server}${this.routingData.instance ? '\\\\' + this.routingData.instance : ''}` :\n      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  }\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   * 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  /**\n   * @private\n   */\n  async performTlsNegotiation(preloginPayload: PreloginPayload, signal: AbortSignal) {\n    signal.throwIfAborted();\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\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          throw new ConnectionError(\"Server requires encryption, set 'encrypt' config option to true.\", 'EENCRYPT');\n        }\n\n        this.transitionTo(this.STATE.SENT_TLSSSLNEGOTIATION);\n        await Promise.race([\n          this.messageIo.startTls(this.secureContextOptions, this.config.options.serverName ? this.config.options.serverName : this.routingData?.server ?? this.config.server, this.config.options.trustServerCertificate).catch((err) => {\n            throw this.wrapSocketError(err);\n          }),\n          signalAborted\n        ]);\n      }\n    } finally {\n      signal.removeEventListener('abort', onAbort);\n    }\n  }\n\n  async readPreloginResponse(signal: AbortSignal): Promise<PreloginPayload> {\n    signal.throwIfAborted();\n\n    let messageBuffer = Buffer.alloc(0);\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\n      const message = await Promise.race([\n        this.messageIo.readMessage().catch((err) => {\n          throw this.wrapSocketError(err);\n        }),\n        signalAborted\n      ]);\n\n      const iterator = message[Symbol.asyncIterator]();\n      try {\n        while (true) {\n          const { done, value } = await Promise.race([\n            iterator.next(),\n            signalAborted\n          ]);\n\n          if (done) {\n            break;\n          }\n\n          messageBuffer = Buffer.concat([messageBuffer, value]);\n        }\n      } finally {\n        if (iterator.return) {\n          await iterator.return();\n        }\n      }\n    } finally {\n      signal.removeEventListener('abort', onAbort);\n    }\n\n    const preloginPayload = new PreloginPayload(messageBuffer);\n    this.debug.payload(function() {\n      return preloginPayload.toString('  ');\n    });\n    return preloginPayload;\n  }\n\n  /**\n   * @private\n   */\n  async performReRouting() {\n    this.socket!.removeListener('error', this._onSocketError);\n    this.socket!.removeListener('close', this._onSocketClose);\n    this.socket!.removeListener('end', this._onSocketEnd);\n    this.socket!.destroy();\n\n    this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');\n\n    this.emit('rerouting');\n    this.debug.log('Rerouting to ' + this.routingData!.server + ':' + this.routingData!.port);\n\n    // Attempt connecting to the rerouting target\n    this.transitionTo(this.STATE.CONNECTING);\n    await this.initialiseConnection();\n  }\n\n  /**\n   * @private\n   */\n  async performTransientFailureRetry() {\n    this.curTransientRetryCount++;\n\n    this.socket!.removeListener('error', this._onSocketError);\n    this.socket!.removeListener('close', this._onSocketClose);\n    this.socket!.removeListener('end', this._onSocketEnd);\n    this.socket!.destroy();\n\n    this.debug.log('connection to ' + this.config.server + ':' + this.config.options.port + ' closed');\n\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    const { promise, resolve } = withResolvers<void>();\n    setTimeout(resolve, this.config.options.connectionRetryInterval);\n    await promise;\n\n    this.emit('retry');\n    this.transitionTo(this.STATE.CONNECTING);\n    await this.initialiseConnection();\n  }\n\n  /**\n   * @private\n   */\n  async performSentLogin7WithStandardLogin(signal: AbortSignal): Promise<RoutingData | undefined> {\n    signal.throwIfAborted();\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\n      const message = await Promise.race([\n        this.messageIo.readMessage().catch((err) => {\n          throw this.wrapSocketError(err);\n        }),\n        signalAborted\n      ]);\n\n      const handler = new Login7TokenHandler(this);\n      const tokenStreamParser = this.createTokenStreamParser(message, handler);\n      await once(tokenStreamParser, 'end');\n\n      if (handler.loginAckReceived) {\n        return handler.routingData;\n      } else if (this.loginError) {\n        throw this.loginError;\n      } else {\n        throw new ConnectionError('Login failed.', 'ELOGIN');\n      }\n    } finally {\n      this.loginError = undefined;\n      signal.removeEventListener('abort', onAbort);\n    }\n  }\n\n  /**\n   * @private\n   */\n  async performSentLogin7WithNTLMLogin(signal: AbortSignal): Promise<RoutingData | undefined> {\n    signal.throwIfAborted();\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\n      while (true) {\n        const message = await Promise.race([\n          this.messageIo.readMessage().catch((err) => {\n            throw this.wrapSocketError(err);\n          }),\n          signalAborted\n        ]);\n\n        const handler = new Login7TokenHandler(this);\n        const tokenStreamParser = this.createTokenStreamParser(message, handler);\n        await Promise.race([\n          once(tokenStreamParser, 'end'),\n          signalAborted\n        ]);\n\n        if (handler.loginAckReceived) {\n          return handler.routingData;\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          throw this.loginError;\n        } else {\n          throw new ConnectionError('Login failed.', 'ELOGIN');\n        }\n      }\n    } finally {\n      this.loginError = undefined;\n      signal.removeEventListener('abort', onAbort);\n    }\n  }\n\n  /**\n   * @private\n   */\n  async performSentLogin7WithFedAuth(signal: AbortSignal): Promise<RoutingData | undefined> {\n    signal.throwIfAborted();\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\n      const message = await Promise.race([\n        this.messageIo.readMessage().catch((err) => {\n          throw this.wrapSocketError(err);\n        }),\n        signalAborted\n      ]);\n\n      const handler = new Login7TokenHandler(this);\n      const tokenStreamParser = this.createTokenStreamParser(message, handler);\n      await Promise.race([\n        once(tokenStreamParser, 'end'),\n        signalAborted\n      ]);\n\n      if (handler.loginAckReceived) {\n        return handler.routingData;\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 Promise.race([\n            credentials.getToken(tokenScope),\n            signalAborted\n          ]);\n        } catch (err) {\n          signal.throwIfAborted();\n\n          throw new AggregateError(\n            [new ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH'), err]);\n        }\n\n        // Type guard the token value so that it is never null.\n        if (tokenResponse === null) {\n          throw new AggregateError(\n            [new ConnectionError('Security token could not be authenticated or authorized.', 'EFEDAUTH')]);\n        }\n\n        this.sendFedAuthTokenMessage(tokenResponse.token);\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        return await this.performSentLogin7WithStandardLogin(signal);\n      } else if (this.loginError) {\n        throw this.loginError;\n      } else {\n        throw new ConnectionError('Login failed.', 'ELOGIN');\n      }\n    } finally {\n      this.loginError = undefined;\n      signal.removeEventListener('abort', onAbort);\n    }\n  }\n\n  /**\n   * @private\n   */\n  async performLoggedInSendingInitialSql(signal: AbortSignal) {\n    signal.throwIfAborted();\n\n    const { promise: signalAborted, reject } = withResolvers<never>();\n\n    const onAbort = () => { reject(signal.reason); };\n    signal.addEventListener('abort', onAbort, { once: true });\n\n    try {\n      this.sendInitialSql();\n\n      const message = await Promise.race([\n        this.messageIo.readMessage().catch((err) => {\n          throw this.wrapSocketError(err);\n        }),\n        signalAborted\n      ]);\n\n      const tokenStreamParser = this.createTokenStreamParser(message, new InitialSqlTokenHandler(this));\n      await Promise.race([\n        once(tokenStreamParser, 'end'),\n        signalAborted\n      ]);\n    } finally {\n      signal.removeEventListener('abort', onAbort);\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    events: {}\n  },\n  SENT_PRELOGIN: {\n    name: 'SentPrelogin',\n    events: {}\n  },\n  REROUTING: {\n    name: 'ReRouting',\n    events: {}\n  },\n  TRANSIENT_FAILURE_RETRY: {\n    name: 'TRANSIENT_FAILURE_RETRY',\n    events: {}\n  },\n  SENT_TLSSSLNEGOTIATION: {\n    name: 'SentTLSSSLNegotiation',\n    events: {}\n  },\n  SENT_LOGIN7_WITH_STANDARD_LOGIN: {\n    name: 'SentLogin7WithStandardLogin',\n    events: {}\n  },\n  SENT_LOGIN7_WITH_NTLM: {\n    name: 'SentLogin7WithNTLMLogin',\n    events: {}\n  },\n  SENT_LOGIN7_WITH_FEDAUTH: {\n    name: 'SentLogin7WithFedauth',\n    events: {}\n  },\n  LOGGED_IN_SENDING_INITIAL_SQL: {\n    name: 'LoggedInSendingInitialSql',\n    events: {}\n  },\n  LOGGED_IN: {\n    name: 'LoggedIn',\n    events: {\n      socketError: function() {\n        this.transitionTo(this.STATE.FINAL);\n        this.cleanupConnection();\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          this.dispatchEvent('socketError', err);\n          process.nextTick(() => {\n            this.emit('error', this.wrapSocketError(err));\n          });\n          return;\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        this.cleanupConnection();\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          this.dispatchEvent('socketError', err);\n          process.nextTick(() => {\n            this.emit('error', this.wrapSocketError(err));\n          });\n          return;\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      })().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        this.cleanupConnection();\n\n        sqlRequest.callback(err);\n      }\n    }\n  },\n  FINAL: {\n    name: 'Final',\n    events: {}\n  }\n};\n"],"mappings":"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A,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;;AA+cA;AACA;AACA;AACA;AACA;AACA,SAASC,aAAaA,CAAA,EAAM;EAC1B,IAAIC,OAA4C;EAChD,IAAIC,MAA8B;EAElC,MAAMC,OAAO,GAAG,IAAIC,OAAO,CAAI,CAACC,GAAG,EAAEC,GAAG,KAAK;IAC3CL,OAAO,GAAGI,GAAG;IACbH,MAAM,GAAGI,GAAG;EACd,CAAC,CAAC;EAEF,OAAO;IAAEH,OAAO;IAAEF,OAAO,EAAEA,OAAQ;IAAEC,MAAM,EAAEA;EAAQ,CAAC;AACxD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMK,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;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAA+B,EAAE;IAC3C,KAAK,CAAC,CAAC;IAEP,IAAI,OAAOA,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;MACjD,MAAM,IAAIC,SAAS,CAAC,+DAA+D,CAAC;IACtF;IAEA,IAAI,OAAOD,MAAM,CAACE,MAAM,KAAK,QAAQ,EAAE;MACrC,MAAM,IAAID,SAAS,CAAC,sEAAsE,CAAC;IAC7F;IAEA,IAAI,CAACE,eAAe,GAAG,KAAK;IAE5B,IAAIC,cAAwC;IAC5C,IAAIJ,MAAM,CAACI,cAAc,KAAKC,SAAS,EAAE;MACvC,IAAI,OAAOL,MAAM,CAACI,cAAc,KAAK,QAAQ,IAAIJ,MAAM,CAACI,cAAc,KAAK,IAAI,EAAE;QAC/E,MAAM,IAAIH,SAAS,CAAC,8DAA8D,CAAC;MACrF;MAEA,MAAMK,IAAI,GAAGN,MAAM,CAACI,cAAc,CAACE,IAAI;MACvC,MAAMC,OAAO,GAAGP,MAAM,CAACI,cAAc,CAACG,OAAO,KAAKF,SAAS,GAAG,CAAC,CAAC,GAAGL,MAAM,CAACI,cAAc,CAACG,OAAO;MAEhG,IAAI,OAAOD,IAAI,KAAK,QAAQ,EAAE;QAC5B,MAAM,IAAIL,SAAS,CAAC,mEAAmE,CAAC;MAC1F;MAEA,IAAIK,IAAI,KAAK,SAAS,IAAIA,IAAI,KAAK,MAAM,IAAIA,IAAI,KAAK,kBAAkB,IAAIA,IAAI,KAAK,iCAAiC,IAAIA,IAAI,KAAK,qCAAqC,IAAIA,IAAI,KAAK,+BAA+B,IAAIA,IAAI,KAAK,wCAAwC,IAAIA,IAAI,KAAK,iDAAiD,IAAIA,IAAI,KAAK,gCAAgC,EAAE;QACpX,MAAM,IAAIL,SAAS,CAAC,sTAAsT,CAAC;MAC7U;MAEA,IAAI,OAAOM,OAAO,KAAK,QAAQ,IAAIA,OAAO,KAAK,IAAI,EAAE;QACnD,MAAM,IAAIN,SAAS,CAAC,sEAAsE,CAAC;MAC7F;MAEA,IAAIK,IAAI,KAAK,MAAM,EAAE;QACnB,IAAI,OAAOC,OAAO,CAACC,MAAM,KAAK,QAAQ,EAAE;UACtC,MAAM,IAAIP,SAAS,CAAC,6EAA6E,CAAC;QACpG;QAEA,IAAIM,OAAO,CAACE,QAAQ,KAAKJ,SAAS,IAAI,OAAOE,OAAO,CAACE,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIR,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAIM,OAAO,CAACG,QAAQ,KAAKL,SAAS,IAAI,OAAOE,OAAO,CAACG,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIT,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,MAAM;UACZC,OAAO,EAAE;YACPE,QAAQ,EAAEF,OAAO,CAACE,QAAQ;YAC1BC,QAAQ,EAAEH,OAAO,CAACG,QAAQ;YAC1BF,MAAM,EAAED,OAAO,CAACC,MAAM,IAAID,OAAO,CAACC,MAAM,CAACG,WAAW,CAAC;UACvD;QACF,CAAC;MACH,CAAC,MAAM,IAAIL,IAAI,KAAK,kBAAkB,EAAE;QACtC,IAAI,CAAC,IAAAM,2BAAiB,EAACL,OAAO,CAACM,UAAU,CAAC,EAAE;UAC1C,MAAM,IAAIZ,SAAS,CAAC,4GAA4G,CAAC;QACnI;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,kBAAkB;UACxBC,OAAO,EAAE;YACPM,UAAU,EAAEN,OAAO,CAACM;UACtB;QACF,CAAC;MACH,CAAC,MAAM,IAAIP,IAAI,KAAK,iCAAiC,EAAE;QACrD,IAAI,OAAOC,OAAO,CAACO,QAAQ,KAAK,QAAQ,EAAE;UACxC,MAAM,IAAIb,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAIM,OAAO,CAACE,QAAQ,KAAKJ,SAAS,IAAI,OAAOE,OAAO,CAACE,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIR,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAIM,OAAO,CAACG,QAAQ,KAAKL,SAAS,IAAI,OAAOE,OAAO,CAACG,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIT,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAIM,OAAO,CAACQ,QAAQ,KAAKV,SAAS,IAAI,OAAOE,OAAO,CAACQ,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAId,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,iCAAiC;UACvCC,OAAO,EAAE;YACPE,QAAQ,EAAEF,OAAO,CAACE,QAAQ;YAC1BC,QAAQ,EAAEH,OAAO,CAACG,QAAQ;YAC1BK,QAAQ,EAAER,OAAO,CAACQ,QAAQ;YAC1BD,QAAQ,EAAEP,OAAO,CAACO;UACpB;QACF,CAAC;MACH,CAAC,MAAM,IAAIR,IAAI,KAAK,qCAAqC,EAAE;QACzD,IAAI,OAAOC,OAAO,CAACS,KAAK,KAAK,QAAQ,EAAE;UACrC,MAAM,IAAIf,SAAS,CAAC,4EAA4E,CAAC;QACnG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,qCAAqC;UAC3CC,OAAO,EAAE;YACPS,KAAK,EAAET,OAAO,CAACS;UACjB;QACF,CAAC;MACH,CAAC,MAAM,IAAIV,IAAI,KAAK,+BAA+B,EAAE;QACnD,IAAIC,OAAO,CAACO,QAAQ,KAAKT,SAAS,IAAI,OAAOE,OAAO,CAACO,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIb,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,+BAA+B;UACrCC,OAAO,EAAE;YACPO,QAAQ,EAAEP,OAAO,CAACO;UACpB;QACF,CAAC;MACH,CAAC,MAAM,IAAIR,IAAI,KAAK,gCAAgC,EAAE;QACpD,IAAIC,OAAO,CAACO,QAAQ,KAAKT,SAAS,IAAI,OAAOE,OAAO,CAACO,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIb,SAAS,CAAC,+EAA+E,CAAC;QACtG;QACAG,cAAc,GAAG;UACfE,IAAI,EAAE,gCAAgC;UACtCC,OAAO,EAAE;YACPO,QAAQ,EAAEP,OAAO,CAACO;UACpB;QACF,CAAC;MACH,CAAC,MAAM,IAAIR,IAAI,KAAK,wCAAwC,EAAE;QAC5D,IAAIC,OAAO,CAACO,QAAQ,KAAKT,SAAS,IAAI,OAAOE,OAAO,CAACO,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIb,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,wCAAwC;UAC9CC,OAAO,EAAE;YACPO,QAAQ,EAAEP,OAAO,CAACO;UACpB;QACF,CAAC;MACH,CAAC,MAAM,IAAIR,IAAI,KAAK,iDAAiD,EAAE;QACrE,IAAI,OAAOC,OAAO,CAACO,QAAQ,KAAK,QAAQ,EAAE;UACxC,MAAM,IAAIb,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAI,OAAOM,OAAO,CAACU,YAAY,KAAK,QAAQ,EAAE;UAC5C,MAAM,IAAIhB,SAAS,CAAC,mFAAmF,CAAC;QAC1G;QAEA,IAAI,OAAOM,OAAO,CAACQ,QAAQ,KAAK,QAAQ,EAAE;UACxC,MAAM,IAAId,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,iDAAiD;UACvDC,OAAO,EAAE;YACPO,QAAQ,EAAEP,OAAO,CAACO,QAAQ;YAC1BG,YAAY,EAAEV,OAAO,CAACU,YAAY;YAClCF,QAAQ,EAAER,OAAO,CAACQ;UACpB;QACF,CAAC;MACH,CAAC,MAAM;QACL,IAAIR,OAAO,CAACE,QAAQ,KAAKJ,SAAS,IAAI,OAAOE,OAAO,CAACE,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIR,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAIM,OAAO,CAACG,QAAQ,KAAKL,SAAS,IAAI,OAAOE,OAAO,CAACG,QAAQ,KAAK,QAAQ,EAAE;UAC1E,MAAM,IAAIT,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEAG,cAAc,GAAG;UACfE,IAAI,EAAE,SAAS;UACfC,OAAO,EAAE;YACPE,QAAQ,EAAEF,OAAO,CAACE,QAAQ;YAC1BC,QAAQ,EAAEH,OAAO,CAACG;UACpB;QACF,CAAC;MACH;IACF,CAAC,MAAM;MACLN,cAAc,GAAG;QACfE,IAAI,EAAE,SAAS;QACfC,OAAO,EAAE;UACPE,QAAQ,EAAEJ,SAAS;UACnBK,QAAQ,EAAEL;QACZ;MACF,CAAC;IACH;IAEA,IAAI,CAACL,MAAM,GAAG;MACZE,MAAM,EAAEF,MAAM,CAACE,MAAM;MACrBE,cAAc,EAAEA,cAAc;MAC9BG,OAAO,EAAE;QACPW,uBAAuB,EAAE,KAAK;QAC9BC,OAAO,EAAEd,SAAS;QAClBe,gBAAgB,EAAE,KAAK;QACvBC,aAAa,EAAExC,sBAAsB;QACrCyC,2BAA2B,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;QAAG;QAClDC,uBAAuB,EAAE,KAAK;QAC9BC,kBAAkB,EAAEnB,SAAS;QAC7BoB,uBAAuB,EAAE3C,8BAA8B;QACvD4C,cAAc,EAAE/C,uBAAuB;QACvCgD,SAAS,EAAEtB,SAAS;QACpBuB,wBAAwB,EAAEC,4BAAe,CAACC,cAAc;QACxDC,wBAAwB,EAAE,CAAC,CAAC;QAC5BC,QAAQ,EAAE3B,SAAS;QACnB4B,SAAS,EAAEhD,iBAAiB;QAC5BiD,UAAU,EAAE7C,kBAAkB;QAC9B8C,KAAK,EAAE;UACLC,IAAI,EAAE,KAAK;UACXC,MAAM,EAAE,KAAK;UACbC,OAAO,EAAE,KAAK;UACdtB,KAAK,EAAE;QACT,CAAC;QACDuB,cAAc,EAAE,IAAI;QACpBC,qBAAqB,EAAE,IAAI;QAC3BC,iBAAiB,EAAE,IAAI;QACvBC,kBAAkB,EAAE,IAAI;QACxBC,gBAAgB,EAAE,IAAI;QACtBC,0BAA0B,EAAE,IAAI;QAChCC,yBAAyB,EAAE,IAAI;QAC/BC,0BAA0B,EAAE,KAAK;QACjCC,uBAAuB,EAAE,KAAK;QAC9BC,sBAAsB,EAAE,IAAI;QAC5BC,OAAO,EAAE,IAAI;QACbC,mBAAmB,EAAE,KAAK;QAC1BC,2BAA2B,EAAE9C,SAAS;QACtC+C,YAAY,EAAE/C,SAAS;QACvBgD,cAAc,EAAExB,4BAAe,CAACC,cAAc;QAC9CwB,QAAQ,EAAElE,gBAAgB;QAC1BmE,YAAY,EAAElD,SAAS;QACvBmD,2BAA2B,EAAE,CAAC;QAC9BC,mBAAmB,EAAE,KAAK;QAC1BC,UAAU,EAAE3E,mBAAmB;QAC/B4E,IAAI,EAAEzE,YAAY;QAClB0E,cAAc,EAAE,KAAK;QACrBC,cAAc,EAAEjF,8BAA8B;QAC9CkF,mBAAmB,EAAE,KAAK;QAC1BC,gCAAgC,EAAE,KAAK;QACvCC,UAAU,EAAE3D,SAAS;QACrB4D,8BAA8B,EAAE,KAAK;QACrCC,UAAU,EAAE/E,mBAAmB;QAC/BgF,QAAQ,EAAEnF,gBAAgB;QAC1BoF,mBAAmB,EAAE/D,SAAS;QAC9BgE,sBAAsB,EAAE,KAAK;QAC7BC,cAAc,EAAE,KAAK;QACrBC,MAAM,EAAE,IAAI;QACZC,aAAa,EAAEnE,SAAS;QACxBoE,cAAc,EAAE;MAClB;IACF,CAAC;IAED,IAAIzE,MAAM,CAACO,OAAO,EAAE;MAClB,IAAIP,MAAM,CAACO,OAAO,CAACoD,IAAI,IAAI3D,MAAM,CAACO,OAAO,CAAC6C,YAAY,EAAE;QACtD,MAAM,IAAIsB,KAAK,CAAC,oDAAoD,GAAG1E,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,OAAO,GAAG3D,MAAM,CAACO,OAAO,CAAC6C,YAAY,GAAG,WAAW,CAAC;MACnJ;MAEA,IAAIpD,MAAM,CAACO,OAAO,CAACW,uBAAuB,KAAKb,SAAS,EAAE;QACxD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACW,uBAAuB,KAAK,SAAS,IAAIlB,MAAM,CAACO,OAAO,CAACW,uBAAuB,KAAK,IAAI,EAAE;UAClH,MAAM,IAAIjB,SAAS,CAAC,uFAAuF,CAAC;QAC9G;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACW,uBAAuB,GAAGlB,MAAM,CAACO,OAAO,CAACW,uBAAuB;MACtF;MAEA,IAAIlB,MAAM,CAACO,OAAO,CAACY,OAAO,KAAKd,SAAS,EAAE;QACxC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACY,OAAO,KAAK,QAAQ,EAAE;UAC9C,MAAM,IAAIlB,SAAS,CAAC,+DAA+D,CAAC;QACtF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACY,OAAO,GAAGnB,MAAM,CAACO,OAAO,CAACY,OAAO;MACtD;MAEA,IAAInB,MAAM,CAACO,OAAO,CAACa,gBAAgB,KAAKf,SAAS,EAAE;QACjD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACa,gBAAgB,KAAK,SAAS,EAAE;UACxD,MAAM,IAAInB,SAAS,CAAC,yEAAyE,CAAC;QAChG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACa,gBAAgB,GAAGpB,MAAM,CAACO,OAAO,CAACa,gBAAgB;MACxE;MAEA,IAAIpB,MAAM,CAACO,OAAO,CAACc,aAAa,KAAKhB,SAAS,EAAE;QAC9C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACc,aAAa,KAAK,QAAQ,EAAE;UACpD,MAAM,IAAIpB,SAAS,CAAC,qEAAqE,CAAC;QAC5F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACc,aAAa,GAAGrB,MAAM,CAACO,OAAO,CAACc,aAAa;MAClE;MAEA,IAAIrB,MAAM,CAACO,OAAO,CAACiB,kBAAkB,EAAE;QACrC,IAAI,OAAOxB,MAAM,CAACO,OAAO,CAACiB,kBAAkB,KAAK,UAAU,EAAE;UAC3D,MAAM,IAAIvB,SAAS,CAAC,uEAAuE,CAAC;QAC9F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACiB,kBAAkB,GAAGxB,MAAM,CAACO,OAAO,CAACiB,kBAAkB;MAC5E;MAEA,IAAIxB,MAAM,CAACO,OAAO,CAACqB,wBAAwB,KAAKvB,SAAS,EAAE;QACzD,IAAAsE,sCAAyB,EAAC3E,MAAM,CAACO,OAAO,CAACqB,wBAAwB,EAAE,yCAAyC,CAAC;QAE7G,IAAI,CAAC5B,MAAM,CAACO,OAAO,CAACqB,wBAAwB,GAAG5B,MAAM,CAACO,OAAO,CAACqB,wBAAwB;MACxF;MAEA,IAAI5B,MAAM,CAACO,OAAO,CAACmB,cAAc,KAAKrB,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACmB,cAAc,KAAK,QAAQ,EAAE;UACrD,MAAM,IAAIzB,SAAS,CAAC,sEAAsE,CAAC;QAC7F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACmB,cAAc,GAAG1B,MAAM,CAACO,OAAO,CAACmB,cAAc;MACpE;MAEA,IAAI1B,MAAM,CAACO,OAAO,CAACoB,SAAS,KAAKtB,SAAS,EAAE;QAC1C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACoB,SAAS,KAAK,UAAU,EAAE;UAClD,MAAM,IAAI1B,SAAS,CAAC,6DAA6D,CAAC;QACpF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACoB,SAAS,GAAG3B,MAAM,CAACO,OAAO,CAACoB,SAAS;MAC1D;MAEA,IAAI3B,MAAM,CAACO,OAAO,CAACwB,wBAAwB,KAAK1B,SAAS,EAAE;QACzD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACwB,wBAAwB,KAAK,QAAQ,IAAI/B,MAAM,CAACO,OAAO,CAACwB,wBAAwB,KAAK,IAAI,EAAE;UACnH,MAAM,IAAI9B,SAAS,CAAC,gFAAgF,CAAC;QACvG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACwB,wBAAwB,GAAG/B,MAAM,CAACO,OAAO,CAACwB,wBAAwB;MACxF;MAEA,IAAI/B,MAAM,CAACO,OAAO,CAACyB,QAAQ,KAAK3B,SAAS,EAAE;QACzC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACyB,QAAQ,KAAK,QAAQ,EAAE;UAC/C,MAAM,IAAI/B,SAAS,CAAC,gEAAgE,CAAC;QACvF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACyB,QAAQ,GAAGhC,MAAM,CAACO,OAAO,CAACyB,QAAQ;MACxD;MAEA,IAAIhC,MAAM,CAACO,OAAO,CAAC0B,SAAS,KAAK5B,SAAS,EAAE;QAC1C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC0B,SAAS,KAAK,QAAQ,IAAIjC,MAAM,CAACO,OAAO,CAAC0B,SAAS,KAAK,IAAI,EAAE;UACrF,MAAM,IAAIhC,SAAS,CAAC,iEAAiE,CAAC;QACxF;QAEA,IAAID,MAAM,CAACO,OAAO,CAAC0B,SAAS,KAAK,IAAI,KAAKjC,MAAM,CAACO,OAAO,CAAC0B,SAAS,GAAG,CAAC,IAAIjC,MAAM,CAACO,OAAO,CAAC0B,SAAS,GAAG,CAAC,CAAC,EAAE;UACvG,MAAM,IAAI2C,UAAU,CAAC,+DAA+D,CAAC;QACvF;QAEA,IAAI,CAAC5E,MAAM,CAACO,OAAO,CAAC0B,SAAS,GAAGjC,MAAM,CAACO,OAAO,CAAC0B,SAAS;MAC1D;MAEA,IAAIjC,MAAM,CAACO,OAAO,CAAC2B,UAAU,KAAK7B,SAAS,EAAE;QAC3C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC2B,UAAU,KAAK,QAAQ,IAAIlC,MAAM,CAACO,OAAO,CAAC2B,UAAU,KAAK,IAAI,EAAE;UACvF,MAAM,IAAIjC,SAAS,CAAC,0EAA0E,CAAC;QACjG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC2B,UAAU,GAAGlC,MAAM,CAACO,OAAO,CAAC2B,UAAU;MAC5D;MAEA,IAAIlC,MAAM,CAACO,OAAO,CAAC4B,KAAK,EAAE;QACxB,IAAInC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACC,IAAI,KAAK/B,SAAS,EAAE;UAC3C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACC,IAAI,KAAK,SAAS,EAAE;YAClD,MAAM,IAAInC,SAAS,CAAC,mEAAmE,CAAC;UAC1F;UAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACC,IAAI,GAAGpC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACC,IAAI;QAC5D;QAEA,IAAIpC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACE,MAAM,KAAKhC,SAAS,EAAE;UAC7C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACE,MAAM,KAAK,SAAS,EAAE;YACpD,MAAM,IAAIpC,SAAS,CAAC,qEAAqE,CAAC;UAC5F;UAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACE,MAAM,GAAGrC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACE,MAAM;QAChE;QAEA,IAAIrC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACG,OAAO,KAAKjC,SAAS,EAAE;UAC9C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACG,OAAO,KAAK,SAAS,EAAE;YACrD,MAAM,IAAIrC,SAAS,CAAC,sEAAsE,CAAC;UAC7F;UAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACG,OAAO,GAAGtC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACG,OAAO;QAClE;QAEA,IAAItC,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACnB,KAAK,KAAKX,SAAS,EAAE;UAC5C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACnB,KAAK,KAAK,SAAS,EAAE;YACnD,MAAM,IAAIf,SAAS,CAAC,oEAAoE,CAAC;UAC3F;UAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACnB,KAAK,GAAGhB,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAACnB,KAAK;QAC9D;MACF;MAEA,IAAIhB,MAAM,CAACO,OAAO,CAACgC,cAAc,KAAKlC,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACgC,cAAc,KAAK,SAAS,IAAIvC,MAAM,CAACO,OAAO,CAACgC,cAAc,KAAK,IAAI,EAAE;UAChG,MAAM,IAAItC,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACgC,cAAc,GAAGvC,MAAM,CAACO,OAAO,CAACgC,cAAc;MACpE;MAEA,IAAIvC,MAAM,CAACO,OAAO,CAACiC,qBAAqB,KAAKnC,SAAS,EAAE;QACtD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACiC,qBAAqB,KAAK,SAAS,IAAIxC,MAAM,CAACO,OAAO,CAACiC,qBAAqB,KAAK,IAAI,EAAE;UAC9G,MAAM,IAAIvC,SAAS,CAAC,sFAAsF,CAAC;QAC7G;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACiC,qBAAqB,GAAGxC,MAAM,CAACO,OAAO,CAACiC,qBAAqB;MAClF;MAEA,IAAIxC,MAAM,CAACO,OAAO,CAACkC,iBAAiB,KAAKpC,SAAS,EAAE;QAClD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACkC,iBAAiB,KAAK,SAAS,IAAIzC,MAAM,CAACO,OAAO,CAACkC,iBAAiB,KAAK,IAAI,EAAE;UACtG,MAAM,IAAIxC,SAAS,CAAC,kFAAkF,CAAC;QACzG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACkC,iBAAiB,GAAGzC,MAAM,CAACO,OAAO,CAACkC,iBAAiB;MAC1E;MAEA,IAAIzC,MAAM,CAACO,OAAO,CAACmC,kBAAkB,KAAKrC,SAAS,EAAE;QACnD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACmC,kBAAkB,KAAK,SAAS,IAAI1C,MAAM,CAACO,OAAO,CAACmC,kBAAkB,KAAK,IAAI,EAAE;UACxG,MAAM,IAAIzC,SAAS,CAAC,mFAAmF,CAAC;QAC1G;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACmC,kBAAkB,GAAG1C,MAAM,CAACO,OAAO,CAACmC,kBAAkB;MAC5E;MAEA,IAAI1C,MAAM,CAACO,OAAO,CAACoC,gBAAgB,KAAKtC,SAAS,EAAE;QACjD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACoC,gBAAgB,KAAK,SAAS,IAAI3C,MAAM,CAACO,OAAO,CAACoC,gBAAgB,KAAK,IAAI,EAAE;UACpG,MAAM,IAAI1C,SAAS,CAAC,iFAAiF,CAAC;QACxG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACoC,gBAAgB,GAAG3C,MAAM,CAACO,OAAO,CAACoC,gBAAgB;MACxE;MAEA,IAAI3C,MAAM,CAACO,OAAO,CAACqC,0BAA0B,KAAKvC,SAAS,EAAE;QAC3D,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACqC,0BAA0B,KAAK,SAAS,IAAI5C,MAAM,CAACO,OAAO,CAACqC,0BAA0B,KAAK,IAAI,EAAE;UACxH,MAAM,IAAI3C,SAAS,CAAC,2FAA2F,CAAC;QAClH;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACqC,0BAA0B,GAAG5C,MAAM,CAACO,OAAO,CAACqC,0BAA0B;MAC5F;MAEA,IAAI5C,MAAM,CAACO,OAAO,CAACsC,yBAAyB,KAAKxC,SAAS,EAAE;QAC1D,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACsC,yBAAyB,KAAK,SAAS,IAAI7C,MAAM,CAACO,OAAO,CAACsC,yBAAyB,KAAK,IAAI,EAAE;UACtH,MAAM,IAAI5C,SAAS,CAAC,0FAA0F,CAAC;QACjH;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACsC,yBAAyB,GAAG7C,MAAM,CAACO,OAAO,CAACsC,yBAAyB;MAC1F;MAEA,IAAI7C,MAAM,CAACO,OAAO,CAACuC,0BAA0B,KAAKzC,SAAS,EAAE;QAC3D,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACuC,0BAA0B,KAAK,SAAS,IAAI9C,MAAM,CAACO,OAAO,CAACuC,0BAA0B,KAAK,IAAI,EAAE;UACxH,MAAM,IAAI7C,SAAS,CAAC,2FAA2F,CAAC;QAClH;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACuC,0BAA0B,GAAG9C,MAAM,CAACO,OAAO,CAACuC,0BAA0B;MAC5F;MAEA,IAAI9C,MAAM,CAACO,OAAO,CAACwC,uBAAuB,KAAK1C,SAAS,EAAE;QACxD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACwC,uBAAuB,KAAK,SAAS,IAAI/C,MAAM,CAACO,OAAO,CAACwC,uBAAuB,KAAK,IAAI,EAAE;UAClH,MAAM,IAAI9C,SAAS,CAAC,wFAAwF,CAAC;QAC/G;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACwC,uBAAuB,GAAG/C,MAAM,CAACO,OAAO,CAACwC,uBAAuB;MACtF;MAEA,IAAI/C,MAAM,CAACO,OAAO,CAACyC,sBAAsB,KAAK3C,SAAS,EAAE;QACvD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACyC,sBAAsB,KAAK,SAAS,IAAIhD,MAAM,CAACO,OAAO,CAACyC,sBAAsB,KAAK,IAAI,EAAE;UAChH,MAAM,IAAI/C,SAAS,CAAC,uFAAuF,CAAC;QAC9G;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACyC,sBAAsB,GAAGhD,MAAM,CAACO,OAAO,CAACyC,sBAAsB;MACpF;MACA,IAAIhD,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK5C,SAAS,EAAE;QACxC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK,SAAS,EAAE;UAC/C,IAAIjD,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK,QAAQ,EAAE;YACvC,MAAM,IAAIhD,SAAS,CAAC,qEAAqE,CAAC;UAC5F;QACF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC0C,OAAO,GAAGjD,MAAM,CAACO,OAAO,CAAC0C,OAAO;MACtD;MAEA,IAAIjD,MAAM,CAACO,OAAO,CAAC2C,mBAAmB,KAAK7C,SAAS,EAAE;QACpD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC2C,mBAAmB,KAAK,SAAS,EAAE;UAC3D,MAAM,IAAIjD,SAAS,CAAC,4EAA4E,CAAC;QACnG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC2C,mBAAmB,GAAGlD,MAAM,CAACO,OAAO,CAAC2C,mBAAmB;MAC9E;MAEA,IAAIlD,MAAM,CAACO,OAAO,CAAC6C,YAAY,KAAK/C,SAAS,EAAE;QAC7C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC6C,YAAY,KAAK,QAAQ,EAAE;UACnD,MAAM,IAAInD,SAAS,CAAC,oEAAoE,CAAC;QAC3F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC6C,YAAY,GAAGpD,MAAM,CAACO,OAAO,CAAC6C,YAAY;QAC9D,IAAI,CAACpD,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAGtD,SAAS;MACtC;MAEA,IAAIL,MAAM,CAACO,OAAO,CAAC8C,cAAc,KAAKhD,SAAS,EAAE;QAC/C,IAAAsE,sCAAyB,EAAC3E,MAAM,CAACO,OAAO,CAAC8C,cAAc,EAAE,+BAA+B,CAAC;QAEzF,IAAI,CAACrD,MAAM,CAACO,OAAO,CAAC8C,cAAc,GAAGrD,MAAM,CAACO,OAAO,CAAC8C,cAAc;MACpE;MAEA,IAAIrD,MAAM,CAACO,OAAO,CAAC+C,QAAQ,KAAKjD,SAAS,EAAE;QACzC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC+C,QAAQ,KAAK,QAAQ,IAAItD,MAAM,CAACO,OAAO,CAAC+C,QAAQ,KAAK,IAAI,EAAE;UACnF,MAAM,IAAIrD,SAAS,CAAC,wEAAwE,CAAC;QAC/F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC+C,QAAQ,GAAGtD,MAAM,CAACO,OAAO,CAAC+C,QAAQ;MACxD;MAEA,IAAItD,MAAM,CAACO,OAAO,CAACgD,YAAY,KAAKlD,SAAS,EAAE;QAC7C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACgD,YAAY,KAAK,QAAQ,EAAE;UACnD,MAAM,IAAItD,SAAS,CAAC,oEAAoE,CAAC;QAC3F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACgD,YAAY,GAAGvD,MAAM,CAACO,OAAO,CAACgD,YAAY;MAChE;MAEA,IAAIvD,MAAM,CAACO,OAAO,CAACkD,mBAAmB,KAAKpD,SAAS,EAAE;QACpD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACkD,mBAAmB,KAAK,SAAS,EAAE;UAC3D,MAAM,IAAIxD,SAAS,CAAC,4EAA4E,CAAC;QACnG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACkD,mBAAmB,GAAGzD,MAAM,CAACO,OAAO,CAACkD,mBAAmB;MAC9E;MAEA,IAAIzD,MAAM,CAACO,OAAO,CAACmD,UAAU,KAAKrD,SAAS,EAAE;QAC3C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACmD,UAAU,KAAK,QAAQ,EAAE;UACjD,MAAM,IAAIzD,SAAS,CAAC,kEAAkE,CAAC;QACzF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACmD,UAAU,GAAG1D,MAAM,CAACO,OAAO,CAACmD,UAAU;MAC5D;MAEA,IAAI1D,MAAM,CAACO,OAAO,CAACoD,IAAI,KAAKtD,SAAS,EAAE;QACrC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACoD,IAAI,KAAK,QAAQ,EAAE;UAC3C,MAAM,IAAI1D,SAAS,CAAC,4DAA4D,CAAC;QACnF;QAEA,IAAID,MAAM,CAACO,OAAO,CAACoD,IAAI,IAAI,CAAC,IAAI3D,MAAM,CAACO,OAAO,CAACoD,IAAI,IAAI,KAAK,EAAE;UAC5D,MAAM,IAAIiB,UAAU,CAAC,4DAA4D,CAAC;QACpF;QAEA,IAAI,CAAC5E,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG3D,MAAM,CAACO,OAAO,CAACoD,IAAI;QAC9C,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAAC6C,YAAY,GAAG/C,SAAS;MAC9C;MAEA,IAAIL,MAAM,CAACO,OAAO,CAACqD,cAAc,KAAKvD,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACqD,cAAc,KAAK,SAAS,EAAE;UACtD,MAAM,IAAI3D,SAAS,CAAC,uEAAuE,CAAC;QAC9F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACqD,cAAc,GAAG5D,MAAM,CAACO,OAAO,CAACqD,cAAc;MACpE;MAEA,IAAI5D,MAAM,CAACO,OAAO,CAACsD,cAAc,KAAKxD,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACsD,cAAc,KAAK,QAAQ,EAAE;UACrD,MAAM,IAAI5D,SAAS,CAAC,sEAAsE,CAAC;QAC7F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACsD,cAAc,GAAG7D,MAAM,CAACO,OAAO,CAACsD,cAAc;MACpE;MAEA,IAAI7D,MAAM,CAACO,OAAO,CAACiD,2BAA2B,KAAKnD,SAAS,EAAE;QAC5D,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACiD,2BAA2B,KAAK,QAAQ,EAAE;UAClE,MAAM,IAAIvD,SAAS,CAAC,mFAAmF,CAAC;QAC1G;QAEA,IAAID,MAAM,CAACO,OAAO,CAACiD,2BAA2B,GAAG,CAAC,EAAE;UAClD,MAAM,IAAIvD,SAAS,CAAC,4FAA4F,CAAC;QACnH;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACiD,2BAA2B,GAAGxD,MAAM,CAACO,OAAO,CAACiD,2BAA2B;MAC9F;MAEA,IAAIxD,MAAM,CAACO,OAAO,CAACkB,uBAAuB,KAAKpB,SAAS,EAAE;QACxD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACkB,uBAAuB,KAAK,QAAQ,EAAE;UAC9D,MAAM,IAAIxB,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAID,MAAM,CAACO,OAAO,CAACkB,uBAAuB,IAAI,CAAC,EAAE;UAC/C,MAAM,IAAIxB,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACkB,uBAAuB,GAAGzB,MAAM,CAACO,OAAO,CAACkB,uBAAuB;MACtF;MAEA,IAAIzB,MAAM,CAACO,OAAO,CAACuD,mBAAmB,KAAKzD,SAAS,EAAE;QACpD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACuD,mBAAmB,KAAK,SAAS,EAAE;UAC3D,MAAM,IAAI7D,SAAS,CAAC,4EAA4E,CAAC;QACnG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACuD,mBAAmB,GAAG9D,MAAM,CAACO,OAAO,CAACuD,mBAAmB;MAC9E;MAEA,IAAI9D,MAAM,CAACO,OAAO,CAACwD,gCAAgC,KAAK1D,SAAS,EAAE;QACjE,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACwD,gCAAgC,KAAK,SAAS,EAAE;UACxE,MAAM,IAAI9D,SAAS,CAAC,yFAAyF,CAAC;QAChH;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACwD,gCAAgC,GAAG/D,MAAM,CAACO,OAAO,CAACwD,gCAAgC;MACxG;MAEA,IAAI/D,MAAM,CAACO,OAAO,CAAC2D,UAAU,KAAK7D,SAAS,EAAE;QAC3C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC2D,UAAU,KAAK,QAAQ,EAAE;UACjD,MAAM,IAAIjE,SAAS,CAAC,kEAAkE,CAAC;QACzF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAGlE,MAAM,CAACO,OAAO,CAAC2D,UAAU;MAC5D;MAEA,IAAIlE,MAAM,CAACO,OAAO,CAAC4D,QAAQ,KAAK9D,SAAS,EAAE;QACzC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC4D,QAAQ,KAAK,QAAQ,IAAInE,MAAM,CAACO,OAAO,CAAC4D,QAAQ,KAAK,IAAI,EAAE;UACnF,MAAM,IAAIlE,SAAS,CAAC,wEAAwE,CAAC;QAC/F;QAEA,IAAID,MAAM,CAACO,OAAO,CAAC4D,QAAQ,GAAG,UAAU,EAAE;UACxC,MAAM,IAAIlE,SAAS,CAAC,kEAAkE,CAAC;QACzF,CAAC,MAAM,IAAID,MAAM,CAACO,OAAO,CAAC4D,QAAQ,GAAG,CAAC,CAAC,EAAE;UACvC,MAAM,IAAIlE,SAAS,CAAC,0DAA0D,CAAC;QACjF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC4D,QAAQ,GAAGnE,MAAM,CAACO,OAAO,CAAC4D,QAAQ,GAAG,CAAC;MAC5D;MAEA,IAAInE,MAAM,CAACO,OAAO,CAAC8D,sBAAsB,KAAKhE,SAAS,EAAE;QACvD,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC8D,sBAAsB,KAAK,SAAS,EAAE;UAC9D,MAAM,IAAIpE,SAAS,CAAC,+EAA+E,CAAC;QACtG;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC8D,sBAAsB,GAAGrE,MAAM,CAACO,OAAO,CAAC8D,sBAAsB;MACpF;MAEA,IAAIrE,MAAM,CAACO,OAAO,CAACyD,UAAU,KAAK3D,SAAS,EAAE;QAC3C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACyD,UAAU,KAAK,QAAQ,EAAE;UACjD,MAAM,IAAI/D,SAAS,CAAC,kEAAkE,CAAC;QACzF;QACA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACyD,UAAU,GAAGhE,MAAM,CAACO,OAAO,CAACyD,UAAU;MAC5D;MAEA,IAAIhE,MAAM,CAACO,OAAO,CAAC+D,cAAc,KAAKjE,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAAC+D,cAAc,KAAK,SAAS,EAAE;UACtD,MAAM,IAAIrE,SAAS,CAAC,uEAAuE,CAAC;QAC9F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAAC+D,cAAc,GAAGtE,MAAM,CAACO,OAAO,CAAC+D,cAAc;MACpE;MAEA,IAAItE,MAAM,CAACO,OAAO,CAACgE,MAAM,KAAKlE,SAAS,EAAE;QACvC,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACgE,MAAM,KAAK,SAAS,EAAE;UAC9C,MAAM,IAAItE,SAAS,CAAC,+DAA+D,CAAC;QACtF;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACgE,MAAM,GAAGvE,MAAM,CAACO,OAAO,CAACgE,MAAM;MACpD;MAEA,IAAIvE,MAAM,CAACO,OAAO,CAACiE,aAAa,KAAKnE,SAAS,EAAE;QAC9C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACiE,aAAa,KAAK,QAAQ,EAAE;UACpD,MAAM,IAAIvE,SAAS,CAAC,qEAAqE,CAAC;QAC5F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACiE,aAAa,GAAGxE,MAAM,CAACO,OAAO,CAACiE,aAAa;MAClE;MAEA,IAAIxE,MAAM,CAACO,OAAO,CAACkE,cAAc,KAAKpE,SAAS,EAAE;QAC/C,IAAI,OAAOL,MAAM,CAACO,OAAO,CAACkE,cAAc,KAAK,SAAS,EAAE;UACtD,MAAM,IAAIxE,SAAS,CAAC,uEAAuE,CAAC;QAC9F;QAEA,IAAI,CAACD,MAAM,CAACO,OAAO,CAACkE,cAAc,GAAGzE,MAAM,CAACO,OAAO,CAACkE,cAAc;MACpE;IACF;IAEA,IAAI,CAACI,oBAAoB,GAAG,IAAI,CAAC7E,MAAM,CAACO,OAAO,CAACwB,wBAAwB;IACxE,IAAI,IAAI,CAAC8C,oBAAoB,CAACC,aAAa,KAAKzE,SAAS,EAAE;MACzD;MACA;MACA;MACA;MACA;MACA,IAAI,CAACwE,oBAAoB,GAAGtG,MAAM,CAACwG,MAAM,CAAC,IAAI,CAACF,oBAAoB,EAAE;QACnEC,aAAa,EAAE;UACbE,KAAK,EAAEC,kBAAS,CAACC;QACnB;MACF,CAAC,CAAC;IACJ;IAEA,IAAI,CAAC/C,KAAK,GAAG,IAAI,CAACgD,WAAW,CAAC,CAAC;IAC/B,IAAI,CAACC,aAAa,GAAG,KAAK;IAC1B,IAAI,CAACC,sBAAsB,GAAG,CAACC,MAAM,CAACC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;;IAErE;IACA;IACA;IACA;IACA;IACA,IAAI,CAACC,gBAAgB,GAAG,CAAC;IACzB,IAAI,CAACC,UAAU,GAAG,KAAK;IACvB,IAAI,CAACC,MAAM,GAAG,KAAK;IACnB,IAAI,CAACC,aAAa,GAAGL,MAAM,CAACM,KAAK,CAAC,CAAC,CAAC;IAEpC,IAAI,CAACC,sBAAsB,GAAG,CAAC;IAC/B,IAAI,CAACC,oBAAoB,GAAG,IAAIC,0CAAoB,CAAC,CAAC;IAEtD,IAAI,CAACC,KAAK,GAAG,IAAI,CAACC,KAAK,CAACC,WAAW;IAEnC,IAAI,CAACC,uBAAuB,GAAG,MAAM;MACnC,IAAI,CAACC,SAAS,CAACC,WAAW,CAACC,YAAI,CAACC,SAAS,CAAC;MAC1C,IAAI,CAACC,iBAAiB,CAAC,CAAC;IAC1B,CAAC;IAED,IAAI,CAACC,cAAc,GAAG,MAAM;MAC1B,IAAI,CAACC,WAAW,CAAC,CAAC;IACpB,CAAC;IAED,IAAI,CAACC,YAAY,GAAG,MAAM;MACxB,IAAI,CAACC,SAAS,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,CAACC,cAAc,GAAIC,KAAK,IAAK;MAC/B,IAAI,CAACC,aAAa,CAAC,aAAa,EAAED,KAAK,CAAC;MACxCE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,OAAO,EAAE,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC,CAAC;MACjD,CAAC,CAAC;IACJ,CAAC;EACH;EAEAM,OAAOA,CAACC,eAAuC,EAAE;IAC/C,IAAI,IAAI,CAACrB,KAAK,KAAK,IAAI,CAACC,KAAK,CAACC,WAAW,EAAE;MACzC,MAAM,IAAIoB,uBAAe,CAAC,mDAAmD,GAAG,IAAI,CAACtB,KAAK,CAACuB,IAAI,GAAG,UAAU,CAAC;IAC/G;IAEA,IAAIF,eAAe,EAAE;MACnB,MAAMG,SAAS,GAAIC,GAAW,IAAK;QACjC,IAAI,CAACC,cAAc,CAAC,OAAO,EAAEC,OAAO,CAAC;QACrCN,eAAe,CAACI,GAAG,CAAC;MACtB,CAAC;MAED,MAAME,OAAO,GAAIF,GAAU,IAAK;QAC9B,IAAI,CAACC,cAAc,CAAC,SAAS,EAAEF,SAAS,CAAC;QACzCH,eAAe,CAACI,GAAG,CAAC;MACtB,CAAC;MAED,IAAI,CAACG,IAAI,CAAC,SAAS,EAAEJ,SAAS,CAAC;MAC/B,IAAI,CAACI,IAAI,CAAC,OAAO,EAAED,OAAO,CAAC;IAC7B;IAEA,IAAI,CAACE,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC6B,UAAU,CAAC;IACxC,IAAI,CAACC,oBAAoB,CAAC,CAAC,CAACC,IAAI,CAAC,MAAM;MACrChB,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,SAAS,CAAC;MACtB,CAAC,CAAC;IACJ,CAAC,EAAGO,GAAG,IAAK;MACV,IAAI,CAACI,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;MACnC,IAAI,CAACvC,MAAM,GAAG,IAAI;MAElBsB,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,SAAS,EAAEO,GAAG,CAAC;MAC3B,CAAC,CAAC;MACFT,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,KAAK,CAAC;MAClB,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;;EAGE;AACF;AACA;;EAUE;AACF;AACA;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;AACA;AACA;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGE;AACF;AACA;;EAGEgB,EAAEA,CAACC,KAAsB,EAAEC,QAAkC,EAAE;IAC7D,OAAO,KAAK,CAACF,EAAE,CAACC,KAAK,EAAEC,QAAQ,CAAC;EAClC;;EAEA;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;;EAEE;AACF;AACA;;EAGElB,IAAIA,CAACiB,KAAsB,EAAE,GAAGE,IAAW,EAAE;IAC3C,OAAO,KAAK,CAACnB,IAAI,CAACiB,KAAK,EAAE,GAAGE,IAAI,CAAC;EACnC;;EAEA;AACF;AACA;AACA;AACA;EACEC,KAAKA,CAAA,EAAG;IACN,IAAI,CAACT,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;IACnC,IAAI,CAACM,iBAAiB,CAAC,CAAC;EAC1B;;EAEA;AACF;AACA;EACE,MAAMR,oBAAoBA,CAAA,EAAG;IAC3B,MAAMS,iBAAiB,GAAG,IAAIC,eAAe,CAAC,CAAC;IAE/C,MAAMC,YAAY,GAAGC,UAAU,CAAC,MAAM;MACpC,MAAMC,WAAW,GAAG,IAAI,CAAC5I,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,IAAI,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAACoD,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAAC6C,YAAY,EAAE;MACvH;MACA,MAAMlD,MAAM,GAAG,IAAI,CAAC2I,WAAW,GAAG,IAAI,CAACA,WAAW,CAAC3I,MAAM,GAAG,IAAI,CAACF,MAAM,CAACE,MAAM;MAC9E,MAAMyD,IAAI,GAAG,IAAI,CAACkF,WAAW,GAAG,IAAI,IAAI,CAACA,WAAW,CAAClF,IAAI,EAAE,GAAGiF,WAAW;MACzE;MACA;MACA,MAAME,cAAc,GAAG,IAAI,CAACD,WAAW,GAAG,qBAAqB,IAAI,CAAC7I,MAAM,CAACE,MAAM,GAAG0I,WAAW,GAAG,GAAG,EAAE;MACvG,MAAMG,OAAO,GAAG,wBAAwB7I,MAAM,GAAGyD,IAAI,GAAGmF,cAAc,OAAO,IAAI,CAAC9I,MAAM,CAACO,OAAO,CAACmB,cAAc,IAAI;MACnH,IAAI,CAACS,KAAK,CAAC6G,GAAG,CAACD,OAAO,CAAC;MAEvBP,iBAAiB,CAACS,KAAK,CAAC,IAAI3B,uBAAe,CAACyB,OAAO,EAAE,UAAU,CAAC,CAAC;IACnE,CAAC,EAAE,IAAI,CAAC/I,MAAM,CAACO,OAAO,CAACmB,cAAc,CAAC;IAEtC,IAAI;MACF,IAAIwH,MAAM,GAAGV,iBAAiB,CAACU,MAAM;MAErC,IAAIvF,IAAI,GAAG,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAACoD,IAAI;MAEnC,IAAI,CAACA,IAAI,EAAE;QACT,IAAI;UACFA,IAAI,GAAG,MAAM,IAAAwF,8BAAc,EAAC;YAC1BjJ,MAAM,EAAE,IAAI,CAACF,MAAM,CAACE,MAAM;YAC1BkD,YAAY,EAAE,IAAI,CAACpD,MAAM,CAACO,OAAO,CAAC6C,YAAa;YAC/CgG,OAAO,EAAE,IAAI,CAACpJ,MAAM,CAACO,OAAO,CAACmB,cAAc;YAC3CwH,MAAM,EAAEA;UACV,CAAC,CAAC;QACJ,CAAC,CAAC,OAAOzB,GAAQ,EAAE;UACjByB,MAAM,CAACG,cAAc,CAAC,CAAC;UAEvB,MAAM,IAAI/B,uBAAe,CAACG,GAAG,CAACsB,OAAO,EAAE,aAAa,EAAE;YAAEO,KAAK,EAAE7B;UAAI,CAAC,CAAC;QACvE;MACF;MAEA,IAAI8B,MAAM;MACV,IAAI;QACFA,MAAM,GAAG,MAAM,IAAI,CAACC,aAAa,CAAC7F,IAAI,EAAE,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAACkD,mBAAmB,EAAEyF,MAAM,EAAE,IAAI,CAAClJ,MAAM,CAACO,OAAO,CAACoB,SAAS,CAAC;MACzH,CAAC,CAAC,OAAO8F,GAAQ,EAAE;QACjByB,MAAM,CAACG,cAAc,CAAC,CAAC;QAEvB,MAAM,IAAI,CAAClC,eAAe,CAACM,GAAG,CAAC;MACjC;MAEA,IAAI;QACF,MAAMgC,UAAU,GAAG,IAAIhB,eAAe,CAAC,CAAC;QACxC,MAAMd,OAAO,GAAIF,GAAU,IAAK;UAC9BgC,UAAU,CAACR,KAAK,CAAC,IAAI,CAAC9B,eAAe,CAACM,GAAG,CAAC,CAAC;QAC7C,CAAC;QACD,MAAMiC,OAAO,GAAGA,CAAA,KAAM;UACpB,IAAI,CAACvH,KAAK,CAAC6G,GAAG,CAAC,gBAAgB,GAAG,IAAI,CAAChJ,MAAM,CAACE,MAAM,GAAG,GAAG,GAAG,IAAI,CAACF,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,SAAS,CAAC;QACpG,CAAC;QACD,MAAMgG,KAAK,GAAGA,CAAA,KAAM;UAClB,IAAI,CAACxH,KAAK,CAAC6G,GAAG,CAAC,cAAc,CAAC;UAE9B,MAAMlC,KAAoB,GAAG,IAAIpC,KAAK,CAAC,gBAAgB,CAAC;UACxDoC,KAAK,CAAC8C,IAAI,GAAG,YAAY;UACzBH,UAAU,CAACR,KAAK,CAAC,IAAI,CAAC9B,eAAe,CAACL,KAAK,CAAC,CAAC;QAC/C,CAAC;QAEDyC,MAAM,CAAC3B,IAAI,CAAC,OAAO,EAAED,OAAO,CAAC;QAC7B4B,MAAM,CAAC3B,IAAI,CAAC,OAAO,EAAE8B,OAAO,CAAC;QAC7BH,MAAM,CAAC3B,IAAI,CAAC,KAAK,EAAE+B,KAAK,CAAC;QAEzB,IAAI;UACFT,MAAM,GAAGW,WAAW,CAACC,GAAG,CAAC,CAACZ,MAAM,EAAEO,UAAU,CAACP,MAAM,CAAC,CAAC;UAErDK,MAAM,CAACQ,YAAY,CAAC,IAAI,EAAErL,wBAAwB,CAAC;UAEnD,IAAI,CAAC0H,SAAS,GAAG,IAAI4D,kBAAS,CAACT,MAAM,EAAE,IAAI,CAACvJ,MAAM,CAACO,OAAO,CAACmD,UAAU,EAAE,IAAI,CAACvB,KAAK,CAAC;UAClF,IAAI,CAACiE,SAAS,CAAC8B,EAAE,CAAC,QAAQ,EAAG+B,SAAS,IAAK;YAAE,IAAI,CAAC/C,IAAI,CAAC,QAAQ,EAAE+C,SAAS,CAAC;UAAE,CAAC,CAAC;UAE/E,IAAI,CAACV,MAAM,GAAGA,MAAM;UAEpB,IAAI,CAAC7D,MAAM,GAAG,KAAK;UACnB,IAAI,CAACvD,KAAK,CAAC6G,GAAG,CAAC,eAAe,GAAG,IAAI,CAAChJ,MAAM,CAACE,MAAM,GAAG,GAAG,GAAG,IAAI,CAACF,MAAM,CAACO,OAAO,CAACoD,IAAI,CAAC;UAErF,IAAI,CAACuG,YAAY,CAAC,CAAC;UAEnB,IAAI,CAACrC,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACkE,aAAa,CAAC;UAC3C,MAAMC,gBAAgB,GAAG,MAAM,IAAI,CAACC,oBAAoB,CAACnB,MAAM,CAAC;UAChE,MAAM,IAAI,CAACoB,qBAAqB,CAACF,gBAAgB,EAAElB,MAAM,CAAC;UAE1D,IAAI,CAACqB,gBAAgB,CAAC,CAAC;UAEvB,IAAI;YACF,MAAM;cAAEnK;YAAe,CAAC,GAAG,IAAI,CAACJ,MAAM;YACtC,QAAQI,cAAc,CAACE,IAAI;cACzB,KAAK,kBAAkB;cACvB,KAAK,iCAAiC;cACtC,KAAK,+BAA+B;cACpC,KAAK,wCAAwC;cAC7C,KAAK,iDAAiD;cACtD,KAAK,gCAAgC;gBACnC,IAAI,CAACuH,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACuE,wBAAwB,CAAC;gBACtD,IAAI,CAAC3B,WAAW,GAAG,MAAM,IAAI,CAAC4B,4BAA4B,CAACvB,MAAM,CAAC;gBAClE;cACF,KAAK,MAAM;gBACT,IAAI,CAACrB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACyE,qBAAqB,CAAC;gBACnD,IAAI,CAAC7B,WAAW,GAAG,MAAM,IAAI,CAAC8B,8BAA8B,CAACzB,MAAM,CAAC;gBACpE;cACF;gBACE,IAAI,CAACrB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC2E,+BAA+B,CAAC;gBAC7D,IAAI,CAAC/B,WAAW,GAAG,MAAM,IAAI,CAACgC,kCAAkC,CAAC3B,MAAM,CAAC;gBACxE;YACJ;UACF,CAAC,CAAC,OAAOzB,GAAQ,EAAE;YACjB,IAAIqD,gBAAgB,CAACrD,GAAG,CAAC,EAAE;cACzB,IAAI,CAACtF,KAAK,CAAC6G,GAAG,CAAC,qCAAqC,CAAC;cACrD,IAAI,CAACnB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC8E,uBAAuB,CAAC;cACrD,OAAO,MAAM,IAAI,CAACC,4BAA4B,CAAC,CAAC;YAClD;YAEA,MAAMvD,GAAG;UACX;;UAEA;UACA,IAAI,IAAI,CAACoB,WAAW,EAAE;YACpB,IAAI,CAAChB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgF,SAAS,CAAC;YACvC,OAAO,MAAM,IAAI,CAACC,gBAAgB,CAAC,CAAC;UACtC;UAEA,IAAI,CAACrD,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACkF,6BAA6B,CAAC;UAC3D,MAAM,IAAI,CAACC,gCAAgC,CAAClC,MAAM,CAAC;QACrD,CAAC,SAAS;UACRK,MAAM,CAAC7B,cAAc,CAAC,OAAO,EAAEC,OAAO,CAAC;UACvC4B,MAAM,CAAC7B,cAAc,CAAC,OAAO,EAAEgC,OAAO,CAAC;UACvCH,MAAM,CAAC7B,cAAc,CAAC,KAAK,EAAEiC,KAAK,CAAC;QACrC;MACF,CAAC,CAAC,OAAOlC,GAAG,EAAE;QACZ8B,MAAM,CAAC8B,OAAO,CAAC,CAAC;QAEhB,MAAM5D,GAAG;MACX;MAEA8B,MAAM,CAACrB,EAAE,CAAC,OAAO,EAAE,IAAI,CAACrB,cAAc,CAAC;MACvC0C,MAAM,CAACrB,EAAE,CAAC,OAAO,EAAE,IAAI,CAACzB,cAAc,CAAC;MACvC8C,MAAM,CAACrB,EAAE,CAAC,KAAK,EAAE,IAAI,CAACvB,YAAY,CAAC;MAEnC,IAAI,CAACkB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACqF,SAAS,CAAC;IACzC,CAAC,SAAS;MACRC,YAAY,CAAC7C,YAAY,CAAC;IAC5B;EACF;;EAEA;AACF;AACA;EACEH,iBAAiBA,CAAA,EAAG;IAClB,IAAI,CAAC,IAAI,CAAC7C,MAAM,EAAE;MAChB,IAAI,CAAC8F,iBAAiB,CAAC,CAAC;MACxB,IAAI,CAACC,eAAe,CAAC,CAAC;MAEtBzE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,KAAK,CAAC;MAClB,CAAC,CAAC;MAEF,MAAMwE,OAAO,GAAG,IAAI,CAACA,OAAO;MAC5B,IAAIA,OAAO,EAAE;QACX,MAAMjE,GAAG,GAAG,IAAIkE,oBAAY,CAAC,6CAA6C,EAAE,QAAQ,CAAC;QACrFD,OAAO,CAACE,QAAQ,CAACnE,GAAG,CAAC;QACrB,IAAI,CAACiE,OAAO,GAAGrL,SAAS;MAC1B;MAEA,IAAI,CAACqF,MAAM,GAAG,IAAI;IACpB;EACF;;EAEA;AACF;AACA;EACEP,WAAWA,CAAA,EAAG;IACZ,MAAMhD,KAAK,GAAG,IAAI0J,cAAK,CAAC,IAAI,CAAC7L,MAAM,CAACO,OAAO,CAAC4B,KAAK,CAAC;IAClDA,KAAK,CAAC+F,EAAE,CAAC,OAAO,EAAGa,OAAO,IAAK;MAC7B,IAAI,CAAC7B,IAAI,CAAC,OAAO,EAAE6B,OAAO,CAAC;IAC7B,CAAC,CAAC;IACF,OAAO5G,KAAK;EACd;;EAEA;AACF;AACA;EACE2J,uBAAuBA,CAAC/C,OAAgB,EAAEgD,OAAqB,EAAE;IAC/D,OAAO,IAAIC,yBAAiB,CAACjD,OAAO,EAAE,IAAI,CAAC5G,KAAK,EAAE4J,OAAO,EAAE,IAAI,CAAC/L,MAAM,CAACO,OAAO,CAAC;EACjF;EAEA,MAAM0L,WAAWA,CAAC1C,MAAkB,EAAEL,MAAmB,EAA0B;IACjFA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM6C,aAAa,GAAG9Q,GAAG,CAAC+Q,mBAAmB,CAAC,IAAI,CAACtH,oBAAoB,CAAC;IACxE;IACA;IACA;IACA,MAAMb,UAAU,GAAG,CAAC1I,GAAG,CAAC8Q,IAAI,CAAC,IAAI,CAACpM,MAAM,CAACE,MAAM,CAAC,GAAG,IAAI,CAACF,MAAM,CAACE,MAAM,GAAG,EAAE;IAC1E,MAAMmM,cAAc,GAAG;MACrBC,IAAI,EAAE,IAAI,CAACtM,MAAM,CAACE,MAAM;MACxBqJ,MAAM,EAAEA,MAAM;MACdgD,aAAa,EAAE,CAAC,SAAS,CAAC;MAC1BL,aAAa,EAAEA,aAAa;MAC5BM,UAAU,EAAE,IAAI,CAACxM,MAAM,CAACO,OAAO,CAACyD,UAAU,GAAG,IAAI,CAAChE,MAAM,CAACO,OAAO,CAACyD,UAAU,GAAGA;IAChF,CAAC;IAED,MAAM;MAAEvE,OAAO;MAAEF,OAAO;MAAEC;IAAO,CAAC,GAAGF,aAAa,CAAgB,CAAC;IACnE,MAAMmN,aAAa,GAAGrR,GAAG,CAACgM,OAAO,CAACiF,cAAc,CAAC;IAEjD,IAAI;MACF,MAAMK,OAAO,GAAGA,CAAA,KAAM;QAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;MAAE,CAAC;MAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;QAAE9E,IAAI,EAAE;MAAK,CAAC,CAAC;MAEzD,IAAI;QACF,MAAMD,OAAO,GAAGnI,MAAM;QACtB,MAAMgI,SAAS,GAAGA,CAAA,KAAM;UAAEjI,OAAO,CAACkN,aAAa,CAAC;QAAE,CAAC;QAEnDA,aAAa,CAAC7E,IAAI,CAAC,OAAO,EAAED,OAAO,CAAC;QACpC8E,aAAa,CAAC7E,IAAI,CAAC,eAAe,EAAEJ,SAAS,CAAC;QAE9C,IAAI;UACF,OAAO,MAAM/H,OAAO;QACtB,CAAC,SAAS;UACRgN,aAAa,CAAC/E,cAAc,CAAC,OAAO,EAAEC,OAAO,CAAC;UAC9C8E,aAAa,CAAC/E,cAAc,CAAC,SAAS,EAAEF,SAAS,CAAC;QACpD;MACF,CAAC,SAAS;QACR0B,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;MAC9C;IACF,CAAC,CAAC,OAAOjF,GAAQ,EAAE;MACjBgF,aAAa,CAACpB,OAAO,CAAC,CAAC;MAEvB,MAAM5D,GAAG;IACX;EACF;EAEA,MAAM+B,aAAaA,CAAC7F,IAAY,EAAEF,mBAA4B,EAAEyF,MAAmB,EAAE4D,eAA2C,EAAE;IAChI,MAAMC,WAAW,GAAG;MAClBT,IAAI,EAAE,IAAI,CAACzD,WAAW,GAAG,IAAI,CAACA,WAAW,CAAC3I,MAAM,GAAG,IAAI,CAACF,MAAM,CAACE,MAAM;MACrEyD,IAAI,EAAE,IAAI,CAACkF,WAAW,GAAG,IAAI,CAACA,WAAW,CAAClF,IAAI,GAAGA,IAAI;MACrDJ,YAAY,EAAE,IAAI,CAACvD,MAAM,CAACO,OAAO,CAACgD;IACpC,CAAC;IAED,MAAM6D,OAAO,GAAG0F,eAAe,KAAKrJ,mBAAmB,GAAGuJ,4BAAiB,GAAGC,4BAAiB,CAAC;IAEhG,IAAI1D,MAAM,GAAG,MAAMnC,OAAO,CAAC2F,WAAW,EAAEG,YAAG,CAACC,MAAM,EAAEjE,MAAM,CAAC;IAE3D,IAAI,IAAI,CAAClJ,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK,QAAQ,EAAE;MAC5C,IAAI;QACF;QACAsG,MAAM,GAAG,MAAM,IAAI,CAAC0C,WAAW,CAAC1C,MAAM,EAAEL,MAAM,CAAC;MACjD,CAAC,CAAC,OAAOzB,GAAG,EAAE;QACZ8B,MAAM,CAAC6D,GAAG,CAAC,CAAC;QAEZ,MAAM3F,GAAG;MACX;IACF;IAEA,OAAO8B,MAAM;EACf;;EAEA;AACF;AACA;EACEkC,eAAeA,CAAA,EAAG;IAChB,IAAI,IAAI,CAAClC,MAAM,EAAE;MACf,IAAI,CAACA,MAAM,CAAC8B,OAAO,CAAC,CAAC;IACvB;EACF;;EAEA;AACF;AACA;EACE7E,iBAAiBA,CAAA,EAAG;IAClB,IAAI,CAAC6G,gBAAgB,CAAC,CAAC;IACvB,MAAMjE,OAAO,GAAG,IAAI,CAACpJ,MAAM,CAACO,OAAO,CAACc,aAAa;IACjD,IAAI+H,OAAO,GAAG,CAAC,EAAE;MACf,IAAI,CAACkE,WAAW,GAAG3E,UAAU,CAAC,MAAM;QAClC,IAAI,CAACtH,aAAa,CAAC,CAAC;MACtB,CAAC,EAAE+H,OAAO,CAAC;IACb;EACF;;EAEA;AACF;AACA;EACEmE,kBAAkBA,CAAA,EAAG;IACnB,IAAI,CAAC/B,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC1B,MAAME,OAAO,GAAG,IAAI,CAACA,OAAkB;IACvC,MAAMtC,OAAO,GAAIsC,OAAO,CAACtC,OAAO,KAAK/I,SAAS,GAAIqL,OAAO,CAACtC,OAAO,GAAG,IAAI,CAACpJ,MAAM,CAACO,OAAO,CAACsD,cAAc;IACtG,IAAIuF,OAAO,EAAE;MACX,IAAI,CAACoE,YAAY,GAAG7E,UAAU,CAAC,MAAM;QACnC,IAAI,CAAC9E,cAAc,CAAC,CAAC;MACvB,CAAC,EAAEuF,OAAO,CAAC;IACb;EACF;;EAEA;AACF;AACA;EACE/H,aAAaA,CAAA,EAAG;IACd,MAAM0H,OAAO,GAAG,+BAA+B,IAAI,CAAC/I,MAAM,CAACO,OAAO,CAACc,aAAa,IAAI;IACpF,IAAI,CAACc,KAAK,CAAC6G,GAAG,CAACD,OAAO,CAAC;IACvB,IAAI,CAAChC,aAAa,CAAC,aAAa,EAAE,IAAIO,uBAAe,CAACyB,OAAO,EAAE,UAAU,CAAC,CAAC;EAC7E;;EAEA;AACF;AACA;EACElF,cAAcA,CAAA,EAAG;IACf,IAAI,CAAC2J,YAAY,GAAGnN,SAAS;IAC7B,MAAMqL,OAAO,GAAG,IAAI,CAACA,OAAQ;IAC7BA,OAAO,CAAC+B,MAAM,CAAC,CAAC;IAChB,MAAMrE,OAAO,GAAIsC,OAAO,CAACtC,OAAO,KAAK/I,SAAS,GAAIqL,OAAO,CAACtC,OAAO,GAAG,IAAI,CAACpJ,MAAM,CAACO,OAAO,CAACsD,cAAc;IACtG,MAAMkF,OAAO,GAAG,yCAAyC,GAAGK,OAAO,GAAG,IAAI;IAC1EsC,OAAO,CAAC5E,KAAK,GAAG,IAAI6E,oBAAY,CAAC5C,OAAO,EAAE,UAAU,CAAC;EACvD;;EAEA;AACF;AACA;EACEsE,gBAAgBA,CAAA,EAAG;IACjB,IAAI,IAAI,CAACC,WAAW,EAAE;MACpB/B,YAAY,CAAC,IAAI,CAAC+B,WAAW,CAAC;MAC9B,IAAI,CAACA,WAAW,GAAGjN,SAAS;IAC9B;EACF;;EAEA;AACF;AACA;EACEmL,iBAAiBA,CAAA,EAAG;IAClB,IAAI,IAAI,CAACgC,YAAY,EAAE;MACrBjC,YAAY,CAAC,IAAI,CAACiC,YAAY,CAAC;MAC/B,IAAI,CAACA,YAAY,GAAGnN,SAAS;IAC/B;EACF;;EAEA;AACF;AACA;EACEwH,YAAYA,CAAC6F,QAAe,EAAE;IAC5B,IAAI,IAAI,CAAC1H,KAAK,KAAK0H,QAAQ,EAAE;MAC3B,IAAI,CAACvL,KAAK,CAAC6G,GAAG,CAAC,mBAAmB,GAAG0E,QAAQ,CAACnG,IAAI,CAAC;MACnD;IACF;IAEA,IAAI,IAAI,CAACvB,KAAK,IAAI,IAAI,CAACA,KAAK,CAAC2H,IAAI,EAAE;MACjC,IAAI,CAAC3H,KAAK,CAAC2H,IAAI,CAACrP,IAAI,CAAC,IAAI,EAAEoP,QAAQ,CAAC;IACtC;IAEA,IAAI,CAACvL,KAAK,CAAC6G,GAAG,CAAC,gBAAgB,IAAI,IAAI,CAAChD,KAAK,GAAG,IAAI,CAACA,KAAK,CAACuB,IAAI,GAAG,WAAW,CAAC,GAAG,MAAM,GAAGmG,QAAQ,CAACnG,IAAI,CAAC;IACxG,IAAI,CAACvB,KAAK,GAAG0H,QAAQ;IAErB,IAAI,IAAI,CAAC1H,KAAK,CAAC4H,KAAK,EAAE;MACpB,IAAI,CAAC5H,KAAK,CAAC4H,KAAK,CAACC,KAAK,CAAC,IAAI,CAAC;IAC9B;EACF;;EAEA;AACF;AACA;EACEC,eAAeA,CAAkCC,SAAY,EAAmC;IAC9F,MAAMhC,OAAO,GAAG,IAAI,CAAC/F,KAAK,CAACgI,MAAM,CAACD,SAAS,CAAC;IAE5C,IAAI,CAAChC,OAAO,EAAE;MACZ,MAAM,IAAIrH,KAAK,CAAC,aAAaqJ,SAAS,eAAe,IAAI,CAAC/H,KAAK,CAACuB,IAAI,GAAG,CAAC;IAC1E;IAEA,OAAOwE,OAAO;EAChB;;EAEA;AACF;AACA;EACEhF,aAAaA,CAAkCgH,SAAY,EAAE,GAAG1F,IAAiD,EAAE;IACjH,MAAM0D,OAAO,GAAG,IAAI,CAAC/F,KAAK,CAACgI,MAAM,CAACD,SAAS,CAA6D;IACxG,IAAIhC,OAAO,EAAE;MACXA,OAAO,CAAC8B,KAAK,CAAC,IAAI,EAAExF,IAAI,CAAC;IAC3B,CAAC,MAAM;MACL,IAAI,CAACnB,IAAI,CAAC,OAAO,EAAE,IAAIxC,KAAK,CAAC,aAAaqJ,SAAS,eAAe,IAAI,CAAC/H,KAAK,CAACuB,IAAI,GAAG,CAAC,CAAC;MACtF,IAAI,CAACe,KAAK,CAAC,CAAC;IACd;EACF;;EAEA;AACF;AACA;EACEnB,eAAeA,CAACL,KAAY,EAAmB;IAC7C,IAAI,IAAI,CAACd,KAAK,KAAK,IAAI,CAACC,KAAK,CAAC6B,UAAU,IAAI,IAAI,CAAC9B,KAAK,KAAK,IAAI,CAACC,KAAK,CAACgI,sBAAsB,EAAE;MAC5F,MAAMrF,WAAW,GAAG,IAAI,CAAC5I,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,IAAI,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAACoD,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAAC6C,YAAY,EAAE;MACvH;MACA,MAAMlD,MAAM,GAAG,IAAI,CAAC2I,WAAW,GAAG,IAAI,CAACA,WAAW,CAAC3I,MAAM,GAAG,IAAI,CAACF,MAAM,CAACE,MAAM;MAC9E,MAAMyD,IAAI,GAAG,IAAI,CAACkF,WAAW,GAAG,IAAI,IAAI,CAACA,WAAW,CAAClF,IAAI,EAAE,GAAGiF,WAAW;MACzE;MACA;MACA,MAAME,cAAc,GAAG,IAAI,CAACD,WAAW,GAAG,qBAAqB,IAAI,CAAC7I,MAAM,CAACE,MAAM,GAAG0I,WAAW,GAAG,GAAG,EAAE;MACvG,MAAMG,OAAO,GAAG,wBAAwB7I,MAAM,GAAGyD,IAAI,GAAGmF,cAAc,MAAMhC,KAAK,CAACiC,OAAO,EAAE;MAE3F,OAAO,IAAIzB,uBAAe,CAACyB,OAAO,EAAE,SAAS,EAAE;QAAEO,KAAK,EAAExC;MAAM,CAAC,CAAC;IAClE,CAAC,MAAM;MACL,MAAMiC,OAAO,GAAG,qBAAqBjC,KAAK,CAACiC,OAAO,EAAE;MACpD,OAAO,IAAIzB,uBAAe,CAACyB,OAAO,EAAE,SAAS,EAAE;QAAEO,KAAK,EAAExC;MAAM,CAAC,CAAC;IAClE;EACF;;EAEA;AACF;AACA;EACEF,SAASA,CAAA,EAAG;IACV,IAAI,CAACzE,KAAK,CAAC6G,GAAG,CAAC,cAAc,CAAC;IAC9B,IAAI,IAAI,CAAChD,KAAK,KAAK,IAAI,CAACC,KAAK,CAACgC,KAAK,EAAE;MACnC,MAAMnB,KAAoB,GAAG,IAAIpC,KAAK,CAAC,gBAAgB,CAAC;MACxDoC,KAAK,CAAC8C,IAAI,GAAG,YAAY;MAEzB,IAAI,CAAC7C,aAAa,CAAC,aAAa,EAAED,KAAK,CAAC;MACxCE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAACC,IAAI,CAAC,OAAO,EAAE,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC,CAAC;MACjD,CAAC,CAAC;IACJ;EACF;;EAEA;AACF;AACA;EACEJ,WAAWA,CAAA,EAAG;IACZ,IAAI,CAACvE,KAAK,CAAC6G,GAAG,CAAC,gBAAgB,GAAG,IAAI,CAAChJ,MAAM,CAACE,MAAM,GAAG,GAAG,GAAG,IAAI,CAACF,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,SAAS,CAAC;IAClG,IAAI,CAACkE,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;IACnC,IAAI,CAACM,iBAAiB,CAAC,CAAC;EAC1B;;EAEA;AACF;AACA;EACE2B,YAAYA,CAAA,EAAG;IACb,MAAM,GAAGgE,KAAK,EAAEC,KAAK,EAAEC,KAAK,CAAC,GAAG,sBAAsB,CAACC,IAAI,CAACC,gBAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;IAChG,MAAMhM,OAAO,GAAG,IAAIiM,wBAAe,CAAC;MAClC;MACA;MACA;MACAtL,OAAO,EAAE,OAAO,IAAI,CAACjD,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK,SAAS,IAAI,IAAI,CAACjD,MAAM,CAACO,OAAO,CAAC0C,OAAO;MACxFqL,OAAO,EAAE;QAAEJ,KAAK,EAAEM,MAAM,CAACN,KAAK,CAAC;QAAEC,KAAK,EAAEK,MAAM,CAACL,KAAK,CAAC;QAAEC,KAAK,EAAEI,MAAM,CAACJ,KAAK,CAAC;QAAEK,QAAQ,EAAE;MAAE;IAC3F,CAAC,CAAC;IAEF,IAAI,CAACrI,SAAS,CAACC,WAAW,CAACC,YAAI,CAACoI,QAAQ,EAAEpM,OAAO,CAACF,IAAI,CAAC;IACvD,IAAI,CAACD,KAAK,CAACG,OAAO,CAAC,YAAW;MAC5B,OAAOA,OAAO,CAACqM,QAAQ,CAAC,IAAI,CAAC;IAC/B,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;EACEpE,gBAAgBA,CAAA,EAAG;IACjB,MAAMjI,OAAO,GAAG,IAAIsM,sBAAa,CAAC;MAChC1K,UAAU,EAAE2K,qBAAQ,CAAC,IAAI,CAAC7O,MAAM,CAACO,OAAO,CAAC2D,UAAU,CAAC;MACpDR,UAAU,EAAE,IAAI,CAAC1D,MAAM,CAACO,OAAO,CAACmD,UAAU;MAC1CoL,aAAa,EAAE,CAAC;MAChBC,SAAS,EAAE/H,OAAO,CAACgI,GAAG;MACtBC,YAAY,EAAE,CAAC;MACfC,cAAc,EAAE,IAAIC,IAAI,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;MAC9CC,UAAU,EAAE;IACd,CAAC,CAAC;IAEF,MAAM;MAAEjP;IAAe,CAAC,GAAG,IAAI,CAACJ,MAAM;IACtC,QAAQI,cAAc,CAACE,IAAI;MACzB,KAAK,iCAAiC;QACpCgC,OAAO,CAACgN,OAAO,GAAG;UAChBhP,IAAI,EAAE,MAAM;UACZiP,IAAI,EAAE,IAAI,CAACpP,eAAe;UAC1BqP,QAAQ,EAAE;QACZ,CAAC;QACD;MAEF,KAAK,qCAAqC;QACxClN,OAAO,CAACgN,OAAO,GAAG;UAChBhP,IAAI,EAAE,eAAe;UACrBiP,IAAI,EAAE,IAAI,CAACpP,eAAe;UAC1BsP,YAAY,EAAErP,cAAc,CAACG,OAAO,CAACS;QACvC,CAAC;QACD;MAEF,KAAK,kBAAkB;MACvB,KAAK,+BAA+B;MACpC,KAAK,gCAAgC;MACrC,KAAK,wCAAwC;MAC7C,KAAK,iDAAiD;QACpDsB,OAAO,CAACgN,OAAO,GAAG;UAChBhP,IAAI,EAAE,MAAM;UACZiP,IAAI,EAAE,IAAI,CAACpP,eAAe;UAC1BqP,QAAQ,EAAE;QACZ,CAAC;QACD;MAEF,KAAK,MAAM;QACTlN,OAAO,CAACoN,IAAI,GAAG,IAAAC,uBAAiB,EAAC;UAAEnP,MAAM,EAAEJ,cAAc,CAACG,OAAO,CAACC;QAAO,CAAC,CAAC;QAC3E;MAEF;QACE8B,OAAO,CAAC7B,QAAQ,GAAGL,cAAc,CAACG,OAAO,CAACE,QAAQ;QAClD6B,OAAO,CAAC5B,QAAQ,GAAGN,cAAc,CAACG,OAAO,CAACG,QAAQ;IACtD;IAEA4B,OAAO,CAACsN,QAAQ,GAAG,IAAI,CAAC5P,MAAM,CAACO,OAAO,CAACiE,aAAa,IAAIqL,WAAE,CAACD,QAAQ,CAAC,CAAC;IACrEtN,OAAO,CAAC0B,UAAU,GAAG,IAAI,CAAC6E,WAAW,GACnC,GAAG,IAAI,CAACA,WAAW,CAAC3I,MAAM,GAAG,IAAI,CAAC2I,WAAW,CAACiH,QAAQ,GAAG,IAAI,GAAG,IAAI,CAACjH,WAAW,CAACiH,QAAQ,GAAG,EAAE,EAAE,GAChG,IAAI,CAAC9P,MAAM,CAACE,MAAM;IACpBoC,OAAO,CAACnB,OAAO,GAAG,IAAI,CAACnB,MAAM,CAACO,OAAO,CAACY,OAAO,IAAI,SAAS;IAC1DmB,OAAO,CAACyN,WAAW,GAAGA,aAAW;IACjCzN,OAAO,CAACgB,QAAQ,GAAG,IAAI,CAACtD,MAAM,CAACO,OAAO,CAAC+C,QAAQ;IAC/ChB,OAAO,CAACN,QAAQ,GAAG,IAAI,CAAChC,MAAM,CAACO,OAAO,CAACyB,QAAQ;IAC/CM,OAAO,CAACxB,QAAQ,GAAGwE,MAAM,CAACC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAElDjD,OAAO,CAACsB,cAAc,GAAG,IAAI,CAAC5D,MAAM,CAACO,OAAO,CAACqD,cAAc;IAC3DtB,OAAO,CAAC0N,WAAW,GAAG,CAAC,IAAI,CAAChQ,MAAM,CAACO,OAAO,CAAC2C,mBAAmB;IAE9D,IAAI,CAAC2F,WAAW,GAAGxI,SAAS;IAC5B,IAAI,CAAC+F,SAAS,CAACC,WAAW,CAACC,YAAI,CAAC2J,MAAM,EAAE3N,OAAO,CAAC4N,QAAQ,CAAC,CAAC,CAAC;IAE3D,IAAI,CAAC/N,KAAK,CAACG,OAAO,CAAC,YAAW;MAC5B,OAAOA,OAAO,CAACqM,QAAQ,CAAC,IAAI,CAAC;IAC/B,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;EACEwB,uBAAuBA,CAACnP,KAAa,EAAE;IACrC,MAAMoP,cAAc,GAAG9K,MAAM,CAAC+K,UAAU,CAACrP,KAAK,EAAE,MAAM,CAAC;IACvD,MAAMoB,IAAI,GAAGkD,MAAM,CAACM,KAAK,CAAC,CAAC,GAAGwK,cAAc,CAAC;IAC7C,IAAIE,MAAM,GAAG,CAAC;IACdA,MAAM,GAAGlO,IAAI,CAACmO,aAAa,CAACH,cAAc,GAAG,CAAC,EAAEE,MAAM,CAAC;IACvDA,MAAM,GAAGlO,IAAI,CAACmO,aAAa,CAACH,cAAc,EAAEE,MAAM,CAAC;IACnDlO,IAAI,CAACoO,KAAK,CAACxP,KAAK,EAAEsP,MAAM,EAAE,MAAM,CAAC;IACjC,IAAI,CAAClK,SAAS,CAACC,WAAW,CAACC,YAAI,CAACmK,aAAa,EAAErO,IAAI,CAAC;EACtD;;EAEA;AACF;AACA;EACEsO,cAAcA,CAAA,EAAG;IACf,MAAMpO,OAAO,GAAG,IAAIqO,wBAAe,CAAC,IAAI,CAACC,aAAa,CAAC,CAAC,EAAE,IAAI,CAACC,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,CAAC;IAEnH,MAAMwI,OAAO,GAAG,IAAI+H,gBAAO,CAAC;MAAExQ,IAAI,EAAEgG,YAAI,CAACyK;IAAU,CAAC,CAAC;IACrD,IAAI,CAAC3K,SAAS,CAAC4K,qBAAqB,CAACR,KAAK,CAACzH,OAAO,CAAC;IACnDkI,gBAAQ,CAAC1L,IAAI,CAACjD,OAAO,CAAC,CAAC4O,IAAI,CAACnI,OAAO,CAAC;EACtC;;EAEA;AACF;AACA;EACE6H,aAAaA,CAAA,EAAG;IACd,MAAMrQ,OAAO,GAAG,EAAE;IAElB,IAAI,IAAI,CAACP,MAAM,CAACO,OAAO,CAACgC,cAAc,KAAK,IAAI,EAAE;MAC/ChC,OAAO,CAAC4Q,IAAI,CAAC,mBAAmB,CAAC;IACnC,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACgC,cAAc,KAAK,KAAK,EAAE;MACvDhC,OAAO,CAAC4Q,IAAI,CAAC,oBAAoB,CAAC;IACpC;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACiC,qBAAqB,KAAK,IAAI,EAAE;MACtDjC,OAAO,CAAC4Q,IAAI,CAAC,0BAA0B,CAAC;IAC1C,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACiC,qBAAqB,KAAK,KAAK,EAAE;MAC9DjC,OAAO,CAAC4Q,IAAI,CAAC,2BAA2B,CAAC;IAC3C;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACkC,iBAAiB,KAAK,IAAI,EAAE;MAClDlC,OAAO,CAAC4Q,IAAI,CAAC,qBAAqB,CAAC;IACrC,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACkC,iBAAiB,KAAK,KAAK,EAAE;MAC1DlC,OAAO,CAAC4Q,IAAI,CAAC,sBAAsB,CAAC;IACtC;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACmC,kBAAkB,KAAK,IAAI,EAAE;MACnDnC,OAAO,CAAC4Q,IAAI,CAAC,sBAAsB,CAAC;IACtC,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACmC,kBAAkB,KAAK,KAAK,EAAE;MAC3DnC,OAAO,CAAC4Q,IAAI,CAAC,uBAAuB,CAAC;IACvC;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACoC,gBAAgB,KAAK,IAAI,EAAE;MACjDpC,OAAO,CAAC4Q,IAAI,CAAC,mBAAmB,CAAC;IACnC,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACoC,gBAAgB,KAAK,KAAK,EAAE;MACzDpC,OAAO,CAAC4Q,IAAI,CAAC,oBAAoB,CAAC;IACpC;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACqC,0BAA0B,KAAK,IAAI,EAAE;MAC3DrC,OAAO,CAAC4Q,IAAI,CAAC,gCAAgC,CAAC;IAChD,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACqC,0BAA0B,KAAK,KAAK,EAAE;MACnErC,OAAO,CAAC4Q,IAAI,CAAC,iCAAiC,CAAC;IACjD;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACsC,yBAAyB,KAAK,IAAI,EAAE;MAC1DtC,OAAO,CAAC4Q,IAAI,CAAC,+BAA+B,CAAC;IAC/C,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACsC,yBAAyB,KAAK,KAAK,EAAE;MAClEtC,OAAO,CAAC4Q,IAAI,CAAC,gCAAgC,CAAC;IAChD;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC0B,SAAS,KAAK,IAAI,EAAE;MAC1C1B,OAAO,CAAC4Q,IAAI,CAAC,iBAAiB,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC0B,SAAS,EAAE,CAAC;IAChE;IAEA,IAAI,IAAI,CAACjC,MAAM,CAACO,OAAO,CAAC2B,UAAU,KAAK,IAAI,EAAE;MAC3C3B,OAAO,CAAC4Q,IAAI,CAAC,kBAAkB,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC2B,UAAU,EAAE,CAAC;IAClE;IAEA,IAAI,IAAI,CAAClC,MAAM,CAACO,OAAO,CAACuC,0BAA0B,KAAK,IAAI,EAAE;MAC3DvC,OAAO,CAAC4Q,IAAI,CAAC,8BAA8B,CAAC;IAC9C,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACuC,0BAA0B,KAAK,KAAK,EAAE;MACnEvC,OAAO,CAAC4Q,IAAI,CAAC,+BAA+B,CAAC;IAC/C;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC+C,QAAQ,KAAK,IAAI,EAAE;MACzC/C,OAAO,CAAC4Q,IAAI,CAAC,gBAAgB,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC+C,QAAQ,EAAE,CAAC;IAC9D;IAEA,IAAI,IAAI,CAACtD,MAAM,CAACO,OAAO,CAACwC,uBAAuB,KAAK,IAAI,EAAE;MACxDxC,OAAO,CAAC4Q,IAAI,CAAC,2BAA2B,CAAC;IAC3C,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACwC,uBAAuB,KAAK,KAAK,EAAE;MAChExC,OAAO,CAAC4Q,IAAI,CAAC,4BAA4B,CAAC;IAC5C;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACyC,sBAAsB,KAAK,IAAI,EAAE;MACvDzC,OAAO,CAAC4Q,IAAI,CAAC,0BAA0B,CAAC;IAC1C,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACyC,sBAAsB,KAAK,KAAK,EAAE;MAC/DzC,OAAO,CAAC4Q,IAAI,CAAC,2BAA2B,CAAC;IAC3C;IAEA,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC4D,QAAQ,KAAK,IAAI,EAAE;MACzC5D,OAAO,CAAC4Q,IAAI,CAAC,gBAAgB,IAAI,CAACnR,MAAM,CAACO,OAAO,CAAC4D,QAAQ,EAAE,CAAC;IAC9D;IAEA,IAAI,IAAI,CAACnE,MAAM,CAACO,OAAO,CAACqB,wBAAwB,KAAK,IAAI,EAAE;MACzDrB,OAAO,CAAC4Q,IAAI,CAAC,mCAAmC,IAAI,CAACC,qBAAqB,CAAC,IAAI,CAACpR,MAAM,CAACO,OAAO,CAACqB,wBAAwB,CAAC,EAAE,CAAC;IAC7H;IAEA,IAAI,IAAI,CAAC5B,MAAM,CAACO,OAAO,CAACW,uBAAuB,KAAK,IAAI,EAAE;MACxDX,OAAO,CAAC4Q,IAAI,CAAC,mBAAmB,CAAC;IACnC,CAAC,MAAM,IAAI,IAAI,CAACnR,MAAM,CAACO,OAAO,CAACW,uBAAuB,KAAK,KAAK,EAAE;MAChEX,OAAO,CAAC4Q,IAAI,CAAC,oBAAoB,CAAC;IACpC;IAEA,OAAO5Q,OAAO,CAAC8Q,IAAI,CAAC,IAAI,CAAC;EAC3B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,YAAYA,CAAC5F,OAAgB,EAAE;IAC7B,IAAI,CAAC6F,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAACyK,SAAS,EAAE,IAAIJ,wBAAe,CAACjF,OAAO,CAAC8F,kBAAkB,EAAG,IAAI,CAACX,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,CAAC,CAAC;EACvJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEkR,OAAOA,CAAC/F,OAAgB,EAAE;IACxB,IAAI;MACFA,OAAO,CAACgG,kBAAkB,CAAC,IAAI,CAACC,iBAAiB,CAAC;IACpD,CAAC,CAAC,OAAO7K,KAAU,EAAE;MACnB4E,OAAO,CAAC5E,KAAK,GAAGA,KAAK;MAErBE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAAC9E,KAAK,CAAC6G,GAAG,CAAClC,KAAK,CAACiC,OAAO,CAAC;QAC7B2C,OAAO,CAACE,QAAQ,CAAC9E,KAAK,CAAC;MACzB,CAAC,CAAC;MAEF;IACF;IAEA,MAAM8K,UAAuB,GAAG,EAAE;IAElCA,UAAU,CAACT,IAAI,CAAC;MACd7Q,IAAI,EAAEuR,eAAK,CAACC,QAAQ;MACpBvK,IAAI,EAAE,WAAW;MACjBvC,KAAK,EAAE0G,OAAO,CAAC8F,kBAAkB;MACjCO,MAAM,EAAE,KAAK;MACbC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEF,IAAIqL,OAAO,CAACkG,UAAU,CAACI,MAAM,EAAE;MAC7BJ,UAAU,CAACT,IAAI,CAAC;QACd7Q,IAAI,EAAEuR,eAAK,CAACC,QAAQ;QACpBvK,IAAI,EAAE,QAAQ;QACdvC,KAAK,EAAE0G,OAAO,CAACyG,mBAAmB,CAACzG,OAAO,CAACkG,UAAU,CAAC;QACtDG,MAAM,EAAE,KAAK;QACbC,MAAM,EAAE3R,SAAS;QACjB4R,SAAS,EAAE5R,SAAS;QACpB6R,KAAK,EAAE7R;MACT,CAAC,CAAC;MAEFuR,UAAU,CAACT,IAAI,CAAC,GAAGzF,OAAO,CAACkG,UAAU,CAAC;IACxC;IAEA,IAAI,CAACL,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAAC8L,WAAW,EAAE,IAAIC,0BAAiB,CAACC,+BAAU,CAACC,aAAa,EAAEX,UAAU,EAAE,IAAI,CAACf,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,EAAE,IAAI,CAACoR,iBAAiB,CAAC,CAAC;EAC5L;;EAEA;AACF;AACA;AACA;AACA;AACA;;EAGEa,WAAWA,CAACC,KAAa,EAAEC,iBAAqD,EAAE9G,QAA2B,EAAE;IAC7G,IAAIrL,OAAwB;IAE5B,IAAIqL,QAAQ,KAAKvL,SAAS,EAAE;MAC1BuL,QAAQ,GAAG8G,iBAAqC;MAChDnS,OAAO,GAAG,CAAC,CAAC;IACd,CAAC,MAAM;MACLA,OAAO,GAAGmS,iBAAoC;IAChD;IAEA,IAAI,OAAOnS,OAAO,KAAK,QAAQ,EAAE;MAC/B,MAAM,IAAIN,SAAS,CAAC,sCAAsC,CAAC;IAC7D;IACA,OAAO,IAAI0S,iBAAQ,CAACF,KAAK,EAAE,IAAI,CAACd,iBAAiB,EAAE,IAAI,CAAC3R,MAAM,CAACO,OAAO,EAAEA,OAAO,EAAEqL,QAAQ,CAAC;EAC5F;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;EAGEgH,YAAYA,CAACC,QAAkB,EAAEC,IAA6H,EAAE;IAC9JD,QAAQ,CAACE,gBAAgB,GAAG,IAAI;IAEhC,IAAID,IAAI,EAAE;MACR,IAAID,QAAQ,CAACG,aAAa,EAAE;QAC1B,MAAM,IAAItO,KAAK,CAAC,yFAAyF,CAAC;MAC5G;MAEA,IAAImO,QAAQ,CAACI,eAAe,EAAE;QAC5B,MAAM,IAAIvO,KAAK,CAAC,8FAA8F,CAAC;MACjH;MAEA,MAAMwO,SAAS,GAAGjC,gBAAQ,CAAC1L,IAAI,CAACuN,IAAI,CAAC;;MAErC;MACA;MACAI,SAAS,CAAChL,EAAE,CAAC,OAAO,EAAGT,GAAG,IAAK;QAC7BoL,QAAQ,CAACM,oBAAoB,CAAC9H,OAAO,CAAC5D,GAAG,CAAC;MAC5C,CAAC,CAAC;;MAEF;MACA;MACAoL,QAAQ,CAACM,oBAAoB,CAACjL,EAAE,CAAC,OAAO,EAAGT,GAAG,IAAK;QACjDyL,SAAS,CAAC7H,OAAO,CAAC5D,GAAG,CAAC;MACxB,CAAC,CAAC;MAEFyL,SAAS,CAAChC,IAAI,CAAC2B,QAAQ,CAACM,oBAAoB,CAAC;IAC/C,CAAC,MAAM,IAAI,CAACN,QAAQ,CAACG,aAAa,EAAE;MAClC;MACA;MACA;MACA;MACA;MACAH,QAAQ,CAACM,oBAAoB,CAAC/F,GAAG,CAAC,CAAC;IACrC;IAEA,MAAMgG,QAAQ,GAAGA,CAAA,KAAM;MACrB1H,OAAO,CAAC+B,MAAM,CAAC,CAAC;IAClB,CAAC;IAED,MAAMnL,OAAO,GAAG,IAAI+Q,gCAAe,CAACR,QAAQ,CAAC;IAE7C,MAAMnH,OAAO,GAAG,IAAI4H,gBAAO,CAACT,QAAQ,CAACU,gBAAgB,CAAC,CAAC,EAAGzM,KAAqD,IAAK;MAClH+L,QAAQ,CAACnL,cAAc,CAAC,QAAQ,EAAE0L,QAAQ,CAAC;MAE3C,IAAItM,KAAK,EAAE;QACT,IAAIA,KAAK,CAAC8C,IAAI,KAAK,SAAS,EAAE;UAC5B9C,KAAK,CAACiC,OAAO,IAAI,8HAA8H;QACjJ;QACA8J,QAAQ,CAAC/L,KAAK,GAAGA,KAAK;QACtB+L,QAAQ,CAACjH,QAAQ,CAAC9E,KAAK,CAAC;QACxB;MACF;MAEA,IAAI,CAACyK,WAAW,CAACsB,QAAQ,EAAEvM,YAAI,CAACkN,SAAS,EAAElR,OAAO,CAAC;IACrD,CAAC,CAAC;IAEFuQ,QAAQ,CAACjL,IAAI,CAAC,QAAQ,EAAEwL,QAAQ,CAAC;IAEjC,IAAI,CAAC9B,YAAY,CAAC5F,OAAO,CAAC;EAC5B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE+H,OAAOA,CAAC/H,OAAgB,EAAE;IACxB,MAAMkG,UAAuB,GAAG,EAAE;IAElCA,UAAU,CAACT,IAAI,CAAC;MACd7Q,IAAI,EAAEuR,eAAK,CAAC6B,GAAG;MACfnM,IAAI,EAAE,QAAQ;MACdvC,KAAK,EAAE3E,SAAS;MAChB0R,MAAM,EAAE,IAAI;MACZC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEFuR,UAAU,CAACT,IAAI,CAAC;MACd7Q,IAAI,EAAEuR,eAAK,CAACC,QAAQ;MACpBvK,IAAI,EAAE,QAAQ;MACdvC,KAAK,EAAE0G,OAAO,CAACkG,UAAU,CAACI,MAAM,GAAGtG,OAAO,CAACyG,mBAAmB,CAACzG,OAAO,CAACkG,UAAU,CAAC,GAAG,IAAI;MACzFG,MAAM,EAAE,KAAK;MACbC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEFuR,UAAU,CAACT,IAAI,CAAC;MACd7Q,IAAI,EAAEuR,eAAK,CAACC,QAAQ;MACpBvK,IAAI,EAAE,MAAM;MACZvC,KAAK,EAAE0G,OAAO,CAAC8F,kBAAkB;MACjCO,MAAM,EAAE,KAAK;MACbC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEFqL,OAAO,CAACiI,SAAS,GAAG,IAAI;;IAExB;IACAjI,OAAO,CAACxD,EAAE,CAAC,aAAa,EAAE,CAACX,IAAY,EAAEvC,KAAU,KAAK;MACtD,IAAIuC,IAAI,KAAK,QAAQ,EAAE;QACrBmE,OAAO,CAACkI,MAAM,GAAG5O,KAAK;MACxB,CAAC,MAAM;QACL0G,OAAO,CAAC5E,KAAK,GAAG,IAAI6E,oBAAY,CAAC,yCAAyCpE,IAAI,kBAAkB,CAAC;MACnG;IACF,CAAC,CAAC;IAEF,IAAI,CAACgK,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAAC8L,WAAW,EAAE,IAAIC,0BAAiB,CAACC,+BAAU,CAACuB,UAAU,EAAEjC,UAAU,EAAE,IAAI,CAACf,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,EAAE,IAAI,CAACoR,iBAAiB,CAAC,CAAC;EACzL;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEmC,SAASA,CAACpI,OAAgB,EAAE;IAC1B,MAAMkG,UAAuB,GAAG,EAAE;IAElCA,UAAU,CAACT,IAAI,CAAC;MACd7Q,IAAI,EAAEuR,eAAK,CAAC6B,GAAG;MACfnM,IAAI,EAAE,QAAQ;MACd;MACAvC,KAAK,EAAE0G,OAAO,CAACkI,MAAM;MACrB7B,MAAM,EAAE,KAAK;MACbC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEF,IAAI,CAACkR,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAAC8L,WAAW,EAAE,IAAIC,0BAAiB,CAACC,+BAAU,CAACyB,YAAY,EAAEnC,UAAU,EAAE,IAAI,CAACf,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,EAAE,IAAI,CAACoR,iBAAiB,CAAC,CAAC;EAC3L;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEqC,OAAOA,CAACtI,OAAgB,EAAEkG,UAAuC,EAAE;IACjE,MAAMqC,iBAA8B,GAAG,EAAE;IAEzCA,iBAAiB,CAAC9C,IAAI,CAAC;MACrB7Q,IAAI,EAAEuR,eAAK,CAAC6B,GAAG;MACfnM,IAAI,EAAE,EAAE;MACR;MACAvC,KAAK,EAAE0G,OAAO,CAACkI,MAAM;MACrB7B,MAAM,EAAE,KAAK;MACbC,MAAM,EAAE3R,SAAS;MACjB4R,SAAS,EAAE5R,SAAS;MACpB6R,KAAK,EAAE7R;IACT,CAAC,CAAC;IAEF,IAAI;MACF,KAAK,IAAIvC,CAAC,GAAG,CAAC,EAAEoW,GAAG,GAAGxI,OAAO,CAACkG,UAAU,CAACI,MAAM,EAAElU,CAAC,GAAGoW,GAAG,EAAEpW,CAAC,EAAE,EAAE;QAC7D,MAAMqW,SAAS,GAAGzI,OAAO,CAACkG,UAAU,CAAC9T,CAAC,CAAC;QAEvCmW,iBAAiB,CAAC9C,IAAI,CAAC;UACrB,GAAGgD,SAAS;UACZnP,KAAK,EAAEmP,SAAS,CAAC7T,IAAI,CAAC8T,QAAQ,CAACxC,UAAU,GAAGA,UAAU,CAACuC,SAAS,CAAC5M,IAAI,CAAC,GAAG,IAAI,EAAE,IAAI,CAACoK,iBAAiB;QACvG,CAAC,CAAC;MACJ;IACF,CAAC,CAAC,OAAO7K,KAAU,EAAE;MACnB4E,OAAO,CAAC5E,KAAK,GAAGA,KAAK;MAErBE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAAC9E,KAAK,CAAC6G,GAAG,CAAClC,KAAK,CAACiC,OAAO,CAAC;QAC7B2C,OAAO,CAACE,QAAQ,CAAC9E,KAAK,CAAC;MACzB,CAAC,CAAC;MAEF;IACF;IAEA,IAAI,CAACyK,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAAC8L,WAAW,EAAE,IAAIC,0BAAiB,CAACC,+BAAU,CAAC+B,UAAU,EAAEJ,iBAAiB,EAAE,IAAI,CAACpD,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,EAAE,IAAI,CAACoR,iBAAiB,CAAC,CAAC;EAChM;;EAEA;AACF;AACA;AACA;AACA;EACE2C,aAAaA,CAAC5I,OAAgB,EAAE;IAC9B,IAAI;MACFA,OAAO,CAACgG,kBAAkB,CAAC,IAAI,CAACC,iBAAiB,CAAC;IACpD,CAAC,CAAC,OAAO7K,KAAU,EAAE;MACnB4E,OAAO,CAAC5E,KAAK,GAAGA,KAAK;MAErBE,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrB,IAAI,CAAC9E,KAAK,CAAC6G,GAAG,CAAClC,KAAK,CAACiC,OAAO,CAAC;QAC7B2C,OAAO,CAACE,QAAQ,CAAC9E,KAAK,CAAC;MACzB,CAAC,CAAC;MAEF;IACF;IAEA,IAAI,CAACyK,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAAC8L,WAAW,EAAE,IAAIC,0BAAiB,CAAC3G,OAAO,CAAC8F,kBAAkB,EAAG9F,OAAO,CAACkG,UAAU,EAAE,IAAI,CAACf,4BAA4B,CAAC,CAAC,EAAE,IAAI,CAAC7Q,MAAM,CAACO,OAAO,EAAE,IAAI,CAACoR,iBAAiB,CAAC,CAAC;EACvM;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE4C,gBAAgBA,CAAC3I,QAAkC,EAAErE,IAAI,GAAG,EAAE,EAAElE,cAAc,GAAG,IAAI,CAACrD,MAAM,CAACO,OAAO,CAAC8C,cAAc,EAAE;IACnH,IAAAsB,sCAAyB,EAACtB,cAAc,EAAE,gBAAgB,CAAC;IAE3D,MAAMmR,WAAW,GAAG,IAAIC,wBAAW,CAAClN,IAAI,EAAElE,cAAc,CAAC;IAEzD,IAAI,IAAI,CAACrD,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;MAC1C,OAAO,IAAI,CAACoN,YAAY,CAAC,IAAIgC,gBAAO,CAAC,kCAAkC,GAAIkB,WAAW,CAACE,oBAAoB,CAAC,CAAE,GAAG,cAAc,GAAGF,WAAW,CAACjN,IAAI,EAAGE,GAAG,IAAK;QAC3J,IAAI,CAACjC,gBAAgB,EAAE;QACvB,IAAI,IAAI,CAACA,gBAAgB,KAAK,CAAC,EAAE;UAC/B,IAAI,CAACJ,aAAa,GAAG,IAAI;QAC3B;QACAwG,QAAQ,CAACnE,GAAG,CAAC;MACf,CAAC,CAAC,CAAC;IACL;IAEA,MAAMiE,OAAO,GAAG,IAAI4H,gBAAO,CAACjT,SAAS,EAAGoH,GAAG,IAAK;MAC9C,OAAOmE,QAAQ,CAACnE,GAAG,EAAE,IAAI,CAACoJ,4BAA4B,CAAC,CAAC,CAAC;IAC3D,CAAC,CAAC;IACF,OAAO,IAAI,CAACU,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAACqO,mBAAmB,EAAEH,WAAW,CAACI,YAAY,CAAC,IAAI,CAAC/D,4BAA4B,CAAC,CAAC,CAAC,CAAC;EAC3H;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEgE,iBAAiBA,CAACjJ,QAAmC,EAAErE,IAAI,GAAG,EAAE,EAAE;IAChE,MAAMiN,WAAW,GAAG,IAAIC,wBAAW,CAAClN,IAAI,CAAC;IACzC,IAAI,IAAI,CAACvH,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;MAC1C,OAAO,IAAI,CAACoN,YAAY,CAAC,IAAIgC,gBAAO,CAAC,cAAc,GAAGkB,WAAW,CAACjN,IAAI,EAAGE,GAAG,IAAK;QAC/E,IAAI,CAACjC,gBAAgB,EAAE;QACvB,IAAI,IAAI,CAACA,gBAAgB,KAAK,CAAC,EAAE;UAC/B,IAAI,CAACJ,aAAa,GAAG,KAAK;QAC5B;QAEAwG,QAAQ,CAACnE,GAAG,CAAC;MACf,CAAC,CAAC,CAAC;IACL;IACA,MAAMiE,OAAO,GAAG,IAAI4H,gBAAO,CAACjT,SAAS,EAAEuL,QAAQ,CAAC;IAChD,OAAO,IAAI,CAAC2F,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAACqO,mBAAmB,EAAEH,WAAW,CAACM,aAAa,CAAC,IAAI,CAACjE,4BAA4B,CAAC,CAAC,CAAC,CAAC;EAC5H;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEkE,mBAAmBA,CAACnJ,QAAqC,EAAErE,IAAI,GAAG,EAAE,EAAE;IACpE,MAAMiN,WAAW,GAAG,IAAIC,wBAAW,CAAClN,IAAI,CAAC;IACzC,IAAI,IAAI,CAACvH,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;MAC1C,OAAO,IAAI,CAACoN,YAAY,CAAC,IAAIgC,gBAAO,CAAC,gBAAgB,GAAGkB,WAAW,CAACjN,IAAI,EAAGE,GAAG,IAAK;QACjF,IAAI,CAACjC,gBAAgB,EAAE;QACvB,IAAI,IAAI,CAACA,gBAAgB,KAAK,CAAC,EAAE;UAC/B,IAAI,CAACJ,aAAa,GAAG,KAAK;QAC5B;QACAwG,QAAQ,CAACnE,GAAG,CAAC;MACf,CAAC,CAAC,CAAC;IACL;IACA,MAAMiE,OAAO,GAAG,IAAI4H,gBAAO,CAACjT,SAAS,EAAEuL,QAAQ,CAAC;IAChD,OAAO,IAAI,CAAC2F,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAACqO,mBAAmB,EAAEH,WAAW,CAACQ,eAAe,CAAC,IAAI,CAACnE,4BAA4B,CAAC,CAAC,CAAC,CAAC;EAC9H;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEoE,eAAeA,CAACrJ,QAAiC,EAAErE,IAAY,EAAE;IAC/D,MAAMiN,WAAW,GAAG,IAAIC,wBAAW,CAAClN,IAAI,CAAC;IACzC,IAAI,IAAI,CAACvH,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;MAC1C,OAAO,IAAI,CAACoN,YAAY,CAAC,IAAIgC,gBAAO,CAAC,YAAY,GAAGkB,WAAW,CAACjN,IAAI,EAAGE,GAAG,IAAK;QAC7E,IAAI,CAACjC,gBAAgB,EAAE;QACvBoG,QAAQ,CAACnE,GAAG,CAAC;MACf,CAAC,CAAC,CAAC;IACL;IACA,MAAMiE,OAAO,GAAG,IAAI4H,gBAAO,CAACjT,SAAS,EAAEuL,QAAQ,CAAC;IAChD,OAAO,IAAI,CAAC2F,WAAW,CAAC7F,OAAO,EAAEpF,YAAI,CAACqO,mBAAmB,EAAEH,WAAW,CAACU,WAAW,CAAC,IAAI,CAACrE,4BAA4B,CAAC,CAAC,CAAC,CAAC;EAC1H;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE2D,WAAWA,CAACW,EAAyK,EAAE9R,cAAqE,EAAE;IAC5P,IAAI,OAAO8R,EAAE,KAAK,UAAU,EAAE;MAC5B,MAAM,IAAIlV,SAAS,CAAC,yBAAyB,CAAC;IAChD;IAEA,MAAMmV,YAAY,GAAG,IAAI,CAAChQ,aAAa;IACvC,MAAMmC,IAAI,GAAG,WAAW,GAAI8N,eAAM,CAACC,WAAW,CAAC,EAAE,CAAC,CAAC3G,QAAQ,CAAC,KAAK,CAAE;IACnE,MAAM4G,MAA2H,GAAGA,CAAC9N,GAAG,EAAE+N,IAAI,EAAE,GAAGnN,IAAI,KAAK;MAC1J,IAAIZ,GAAG,EAAE;QACP,IAAI,IAAI,CAACrC,aAAa,IAAI,IAAI,CAACY,KAAK,KAAK,IAAI,CAACC,KAAK,CAACqF,SAAS,EAAE;UAC7D,IAAI,CAACyJ,mBAAmB,CAAEU,KAAK,IAAK;YAClCD,IAAI,CAACC,KAAK,IAAIhO,GAAG,EAAE,GAAGY,IAAI,CAAC;UAC7B,CAAC,EAAEd,IAAI,CAAC;QACV,CAAC,MAAM;UACLiO,IAAI,CAAC/N,GAAG,EAAE,GAAGY,IAAI,CAAC;QACpB;MACF,CAAC,MAAM,IAAI+M,YAAY,EAAE;QACvB,IAAI,IAAI,CAACpV,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;UAC1C,IAAI,CAACsB,gBAAgB,EAAE;QACzB;QACAgQ,IAAI,CAAC,IAAI,EAAE,GAAGnN,IAAI,CAAC;MACrB,CAAC,MAAM;QACL,IAAI,CAACwM,iBAAiB,CAAEY,KAAK,IAAK;UAChCD,IAAI,CAACC,KAAK,EAAE,GAAGpN,IAAI,CAAC;QACtB,CAAC,EAAEd,IAAI,CAAC;MACV;IACF,CAAC;IAED,IAAI6N,YAAY,EAAE;MAChB,OAAO,IAAI,CAACH,eAAe,CAAExN,GAAG,IAAK;QACnC,IAAIA,GAAG,EAAE;UACP,OAAO0N,EAAE,CAAC1N,GAAG,CAAC;QAChB;QAEA,IAAIpE,cAAc,EAAE;UAClB,OAAO,IAAI,CAACiO,YAAY,CAAC,IAAIgC,gBAAO,CAAC,kCAAkC,GAAG,IAAI,CAAClC,qBAAqB,CAAC/N,cAAc,CAAC,EAAGoE,GAAG,IAAK;YAC7H,OAAO0N,EAAE,CAAC1N,GAAG,EAAE8N,MAAM,CAAC;UACxB,CAAC,CAAC,CAAC;QACL,CAAC,MAAM;UACL,OAAOJ,EAAE,CAAC,IAAI,EAAEI,MAAM,CAAC;QACzB;MACF,CAAC,EAAEhO,IAAI,CAAC;IACV,CAAC,MAAM;MACL,OAAO,IAAI,CAACgN,gBAAgB,CAAE9M,GAAG,IAAK;QACpC,IAAIA,GAAG,EAAE;UACP,OAAO0N,EAAE,CAAC1N,GAAG,CAAC;QAChB;QAEA,OAAO0N,EAAE,CAAC,IAAI,EAAEI,MAAM,CAAC;MACzB,CAAC,EAAEhO,IAAI,EAAElE,cAAc,CAAC;IAC1B;EACF;;EAEA;AACF;AACA;EACEkO,WAAWA,CAAC7F,OAA2B,EAAEgK,UAAkB,EAAEpT,OAA+F,EAAE;IAC5J,IAAI,IAAI,CAAC0D,KAAK,KAAK,IAAI,CAACC,KAAK,CAACqF,SAAS,EAAE;MACvC,MAAMvC,OAAO,GAAG,mCAAmC,GAAG,IAAI,CAAC9C,KAAK,CAACqF,SAAS,CAAC/D,IAAI,GAAG,kBAAkB,GAAG,IAAI,CAACvB,KAAK,CAACuB,IAAI,GAAG,QAAQ;MACjI,IAAI,CAACpF,KAAK,CAAC6G,GAAG,CAACD,OAAO,CAAC;MACvB2C,OAAO,CAACE,QAAQ,CAAC,IAAID,oBAAY,CAAC5C,OAAO,EAAE,eAAe,CAAC,CAAC;IAC9D,CAAC,MAAM,IAAI2C,OAAO,CAACiK,QAAQ,EAAE;MAC3B3O,OAAO,CAACC,QAAQ,CAAC,MAAM;QACrByE,OAAO,CAACE,QAAQ,CAAC,IAAID,oBAAY,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;MAC5D,CAAC,CAAC;IACJ,CAAC,MAAM;MACL,IAAI+J,UAAU,KAAKpP,YAAI,CAACyK,SAAS,EAAE;QACjC,IAAI,CAACtL,UAAU,GAAG,IAAI;MACxB,CAAC,MAAM;QACL,IAAI,CAACA,UAAU,GAAG,KAAK;MACzB;MAEA,IAAI,CAACiG,OAAO,GAAGA,OAAO;MACtBA,OAAO,CAACkK,UAAU,GAAI,IAAI;MAC1BlK,OAAO,CAACmK,QAAQ,GAAI,CAAC;MACrBnK,OAAO,CAACoH,IAAI,GAAI,EAAE;MAClBpH,OAAO,CAACoK,GAAG,GAAI,EAAE;MAEjB,MAAM1C,QAAQ,GAAGA,CAAA,KAAM;QACrB2C,aAAa,CAACC,MAAM,CAACjN,OAAO,CAAC;QAC7BgN,aAAa,CAAC1K,OAAO,CAAC,IAAIM,oBAAY,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;;QAE/D;QACA5C,OAAO,CAACkN,MAAM,GAAG,IAAI;QACrBlN,OAAO,CAACqE,GAAG,CAAC,CAAC;QAEb,IAAI1B,OAAO,YAAY4H,gBAAO,IAAI5H,OAAO,CAACwK,MAAM,EAAE;UAChD;UACAxK,OAAO,CAACyK,MAAM,CAAC,CAAC;QAClB;MACF,CAAC;MAEDzK,OAAO,CAAC9D,IAAI,CAAC,QAAQ,EAAEwL,QAAQ,CAAC;MAEhC,IAAI,CAAC7F,kBAAkB,CAAC,CAAC;MAEzB,MAAMxE,OAAO,GAAG,IAAI+H,gBAAO,CAAC;QAAExQ,IAAI,EAAEoV,UAAU;QAAEU,eAAe,EAAE,IAAI,CAACC;MAA6B,CAAC,CAAC;MACrG,IAAI,CAACjQ,SAAS,CAAC4K,qBAAqB,CAACR,KAAK,CAACzH,OAAO,CAAC;MACnD,IAAI,CAAClB,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACqQ,mBAAmB,CAAC;MAEjDvN,OAAO,CAACnB,IAAI,CAAC,QAAQ,EAAE,MAAM;QAC3B8D,OAAO,CAAChE,cAAc,CAAC,QAAQ,EAAE0L,QAAQ,CAAC;QAC1C1H,OAAO,CAAC9D,IAAI,CAAC,QAAQ,EAAE,IAAI,CAACzB,uBAAuB,CAAC;QAEpD,IAAI,CAACkQ,4BAA4B,GAAG,KAAK;QACzC,IAAI,CAAClU,KAAK,CAACG,OAAO,CAAC,YAAW;UAC5B,OAAOA,OAAO,CAAEqM,QAAQ,CAAC,IAAI,CAAC;QAChC,CAAC,CAAC;MACJ,CAAC,CAAC;MAEF,MAAMoH,aAAa,GAAG9E,gBAAQ,CAAC1L,IAAI,CAACjD,OAAO,CAAC;MAC5CyT,aAAa,CAACnO,IAAI,CAAC,OAAO,EAAGd,KAAK,IAAK;QACrCiP,aAAa,CAACC,MAAM,CAACjN,OAAO,CAAC;;QAE7B;QACA2C,OAAO,CAAC5E,KAAK,KAAKA,KAAK;QAEvBiC,OAAO,CAACkN,MAAM,GAAG,IAAI;QACrBlN,OAAO,CAACqE,GAAG,CAAC,CAAC;MACf,CAAC,CAAC;MACF2I,aAAa,CAAC7E,IAAI,CAACnI,OAAO,CAAC;IAC7B;EACF;;EAEA;AACF;AACA;EACE0E,MAAMA,CAAA,EAAG;IACP,IAAI,CAAC,IAAI,CAAC/B,OAAO,EAAE;MACjB,OAAO,KAAK;IACd;IAEA,IAAI,IAAI,CAACA,OAAO,CAACiK,QAAQ,EAAE;MACzB,OAAO,KAAK;IACd;IAEA,IAAI,CAACjK,OAAO,CAAC+B,MAAM,CAAC,CAAC;IACrB,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE8I,KAAKA,CAAC3K,QAAuB,EAAE;IAC7B,MAAMF,OAAO,GAAG,IAAI4H,gBAAO,CAAC,IAAI,CAAC1C,aAAa,CAAC,CAAC,EAAGnJ,GAAG,IAAK;MACzD,IAAI,IAAI,CAACzH,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,EAAE;QAC1C,IAAI,CAACkB,aAAa,GAAG,KAAK;MAC5B;MACAwG,QAAQ,CAACnE,GAAG,CAAC;IACf,CAAC,CAAC;IACF,IAAI,CAAC4O,4BAA4B,GAAG,IAAI;IACxC,IAAI,CAAC/E,YAAY,CAAC5F,OAAO,CAAC;EAC5B;;EAEA;AACF;AACA;EACEmF,4BAA4BA,CAAA,EAAG;IAC7B,OAAO,IAAI,CAACxL,sBAAsB,CAAC,IAAI,CAACA,sBAAsB,CAAC2M,MAAM,GAAG,CAAC,CAAC;EAC5E;;EAEA;AACF;AACA;EACEZ,qBAAqBA,CAAC/N,cAAoE,EAAE;IAC1F,QAAQA,cAAc;MACpB,KAAKxB,4BAAe,CAAC2U,gBAAgB;QACnC,OAAO,kBAAkB;MAC3B,KAAK3U,4BAAe,CAAC4U,eAAe;QAClC,OAAO,iBAAiB;MAC1B,KAAK5U,4BAAe,CAAC6U,YAAY;QAC/B,OAAO,cAAc;MACvB,KAAK7U,4BAAe,CAAC8U,QAAQ;QAC3B,OAAO,UAAU;MACnB;QACE,OAAO,gBAAgB;IAC3B;EACF;;EAEA;AACF;AACA;EACE,MAAMrM,qBAAqBA,CAACsM,eAAgC,EAAE1N,MAAmB,EAAE;IACjFA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM;MAAE5J,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,IAAIgP,eAAe,CAACzW,eAAe,KAAK,CAAC,EAAE;QACzC,IAAI,CAACA,eAAe,GAAG,IAAI;MAC7B;MACA,IAAI,QAAQ,KAAK,IAAI,CAACH,MAAM,CAACO,OAAO,CAAC0C,OAAO,KAAK2T,eAAe,CAACE,gBAAgB,KAAK,IAAI,IAAIF,eAAe,CAACE,gBAAgB,KAAK,KAAK,CAAC,EAAE;QACzI,IAAI,CAAC,IAAI,CAAC9W,MAAM,CAACO,OAAO,CAAC0C,OAAO,EAAE;UAChC,MAAM,IAAIqE,uBAAe,CAAC,kEAAkE,EAAE,UAAU,CAAC;QAC3G;QAEA,IAAI,CAACO,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgI,sBAAsB,CAAC;QACpD,MAAMvO,OAAO,CAACqX,IAAI,CAAC,CACjB,IAAI,CAAC3Q,SAAS,CAAC4Q,QAAQ,CAAC,IAAI,CAACnS,oBAAoB,EAAE,IAAI,CAAC7E,MAAM,CAACO,OAAO,CAACyD,UAAU,GAAG,IAAI,CAAChE,MAAM,CAACO,OAAO,CAACyD,UAAU,GAAG,IAAI,CAAC6E,WAAW,EAAE3I,MAAM,IAAI,IAAI,CAACF,MAAM,CAACE,MAAM,EAAE,IAAI,CAACF,MAAM,CAACO,OAAO,CAAC8D,sBAAsB,CAAC,CAAC4S,KAAK,CAAExP,GAAG,IAAK;UAC9N,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;QACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;MACJ;IACF,CAAC,SAAS;MACR3N,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;EACF;EAEA,MAAMrC,oBAAoBA,CAACnB,MAAmB,EAA4B;IACxEA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,IAAI1D,aAAa,GAAGL,MAAM,CAACM,KAAK,CAAC,CAAC,CAAC;IAEnC,MAAM;MAAEnG,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,MAAMmB,OAAO,GAAG,MAAMrJ,OAAO,CAACqX,IAAI,CAAC,CACjC,IAAI,CAAC3Q,SAAS,CAAC8Q,WAAW,CAAC,CAAC,CAACD,KAAK,CAAExP,GAAG,IAAK;QAC1C,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;MACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;MAEF,MAAMM,QAAQ,GAAGpO,OAAO,CAACqO,MAAM,CAACC,aAAa,CAAC,CAAC,CAAC;MAChD,IAAI;QACF,OAAO,IAAI,EAAE;UACX,MAAM;YAAE7B,IAAI;YAAExQ;UAAM,CAAC,GAAG,MAAMtF,OAAO,CAACqX,IAAI,CAAC,CACzCI,QAAQ,CAACG,IAAI,CAAC,CAAC,EACfT,aAAa,CACd,CAAC;UAEF,IAAIrB,IAAI,EAAE;YACR;UACF;UAEA7P,aAAa,GAAGL,MAAM,CAACiS,MAAM,CAAC,CAAC5R,aAAa,EAAEX,KAAK,CAAC,CAAC;QACvD;MACF,CAAC,SAAS;QACR,IAAImS,QAAQ,CAACK,MAAM,EAAE;UACnB,MAAML,QAAQ,CAACK,MAAM,CAAC,CAAC;QACzB;MACF;IACF,CAAC,SAAS;MACRtO,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;IAEA,MAAMkK,eAAe,GAAG,IAAIrI,wBAAe,CAAC5I,aAAa,CAAC;IAC1D,IAAI,CAACxD,KAAK,CAACG,OAAO,CAAC,YAAW;MAC5B,OAAOsU,eAAe,CAACjI,QAAQ,CAAC,IAAI,CAAC;IACvC,CAAC,CAAC;IACF,OAAOiI,eAAe;EACxB;;EAEA;AACF;AACA;EACE,MAAM1L,gBAAgBA,CAAA,EAAG;IACvB,IAAI,CAAC3B,MAAM,CAAE7B,cAAc,CAAC,OAAO,EAAE,IAAI,CAACb,cAAc,CAAC;IACzD,IAAI,CAAC0C,MAAM,CAAE7B,cAAc,CAAC,OAAO,EAAE,IAAI,CAACjB,cAAc,CAAC;IACzD,IAAI,CAAC8C,MAAM,CAAE7B,cAAc,CAAC,KAAK,EAAE,IAAI,CAACf,YAAY,CAAC;IACrD,IAAI,CAAC4C,MAAM,CAAE8B,OAAO,CAAC,CAAC;IAEtB,IAAI,CAAClJ,KAAK,CAAC6G,GAAG,CAAC,gBAAgB,GAAG,IAAI,CAAChJ,MAAM,CAACE,MAAM,GAAG,GAAG,GAAG,IAAI,CAACF,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,SAAS,CAAC;IAElG,IAAI,CAACuD,IAAI,CAAC,WAAW,CAAC;IACtB,IAAI,CAAC/E,KAAK,CAAC6G,GAAG,CAAC,eAAe,GAAG,IAAI,CAACH,WAAW,CAAE3I,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC2I,WAAW,CAAElF,IAAI,CAAC;;IAEzF;IACA,IAAI,CAACkE,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC6B,UAAU,CAAC;IACxC,MAAM,IAAI,CAACC,oBAAoB,CAAC,CAAC;EACnC;;EAEA;AACF;AACA;EACE,MAAMiD,4BAA4BA,CAAA,EAAG;IACnC,IAAI,CAACnF,sBAAsB,EAAE;IAE7B,IAAI,CAAC0D,MAAM,CAAE7B,cAAc,CAAC,OAAO,EAAE,IAAI,CAACb,cAAc,CAAC;IACzD,IAAI,CAAC0C,MAAM,CAAE7B,cAAc,CAAC,OAAO,EAAE,IAAI,CAACjB,cAAc,CAAC;IACzD,IAAI,CAAC8C,MAAM,CAAE7B,cAAc,CAAC,KAAK,EAAE,IAAI,CAACf,YAAY,CAAC;IACrD,IAAI,CAAC4C,MAAM,CAAE8B,OAAO,CAAC,CAAC;IAEtB,IAAI,CAAClJ,KAAK,CAAC6G,GAAG,CAAC,gBAAgB,GAAG,IAAI,CAAChJ,MAAM,CAACE,MAAM,GAAG,GAAG,GAAG,IAAI,CAACF,MAAM,CAACO,OAAO,CAACoD,IAAI,GAAG,SAAS,CAAC;IAElG,MAAMzD,MAAM,GAAG,IAAI,CAAC2I,WAAW,GAAG,IAAI,CAACA,WAAW,CAAC3I,MAAM,GAAG,IAAI,CAACF,MAAM,CAACE,MAAM;IAC9E,MAAMyD,IAAI,GAAG,IAAI,CAACkF,WAAW,GAAG,IAAI,CAACA,WAAW,CAAClF,IAAI,GAAG,IAAI,CAAC3D,MAAM,CAACO,OAAO,CAACoD,IAAI;IAChF,IAAI,CAACxB,KAAK,CAAC6G,GAAG,CAAC,8CAA8C,GAAG9I,MAAM,GAAG,GAAG,GAAGyD,IAAI,CAAC;IAEpF,MAAM;MAAElE,OAAO;MAAEF;IAAQ,CAAC,GAAGD,aAAa,CAAO,CAAC;IAClDqJ,UAAU,CAACpJ,OAAO,EAAE,IAAI,CAACS,MAAM,CAACO,OAAO,CAACkB,uBAAuB,CAAC;IAChE,MAAMhC,OAAO;IAEb,IAAI,CAACyH,IAAI,CAAC,OAAO,CAAC;IAClB,IAAI,CAACW,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC6B,UAAU,CAAC;IACxC,MAAM,IAAI,CAACC,oBAAoB,CAAC,CAAC;EACnC;;EAEA;AACF;AACA;EACE,MAAM8C,kCAAkCA,CAAC3B,MAAmB,EAAoC;IAC9FA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM;MAAE5J,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,MAAMmB,OAAO,GAAG,MAAMrJ,OAAO,CAACqX,IAAI,CAAC,CACjC,IAAI,CAAC3Q,SAAS,CAAC8Q,WAAW,CAAC,CAAC,CAACD,KAAK,CAAExP,GAAG,IAAK;QAC1C,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;MACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;MAEF,MAAM9K,OAAO,GAAG,IAAI0L,2BAAkB,CAAC,IAAI,CAAC;MAC5C,MAAMC,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAEgD,OAAO,CAAC;MACxE,MAAM,IAAAnE,YAAI,EAAC8P,iBAAiB,EAAE,KAAK,CAAC;MAEpC,IAAI3L,OAAO,CAAC4L,gBAAgB,EAAE;QAC5B,OAAO5L,OAAO,CAAClD,WAAW;MAC5B,CAAC,MAAM,IAAI,IAAI,CAAC+O,UAAU,EAAE;QAC1B,MAAM,IAAI,CAACA,UAAU;MACvB,CAAC,MAAM;QACL,MAAM,IAAItQ,uBAAe,CAAC,eAAe,EAAE,QAAQ,CAAC;MACtD;IACF,CAAC,SAAS;MACR,IAAI,CAACsQ,UAAU,GAAGvX,SAAS;MAC3B6I,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;EACF;;EAEA;AACF;AACA;EACE,MAAM/B,8BAA8BA,CAACzB,MAAmB,EAAoC;IAC1FA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM;MAAE5J,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,OAAO,IAAI,EAAE;QACX,MAAMmB,OAAO,GAAG,MAAMrJ,OAAO,CAACqX,IAAI,CAAC,CACjC,IAAI,CAAC3Q,SAAS,CAAC8Q,WAAW,CAAC,CAAC,CAACD,KAAK,CAAExP,GAAG,IAAK;UAC1C,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;QACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;QAEF,MAAM9K,OAAO,GAAG,IAAI0L,2BAAkB,CAAC,IAAI,CAAC;QAC5C,MAAMC,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAEgD,OAAO,CAAC;QACxE,MAAMrM,OAAO,CAACqX,IAAI,CAAC,CACjB,IAAAnP,YAAI,EAAC8P,iBAAiB,EAAE,KAAK,CAAC,EAC9Bb,aAAa,CACd,CAAC;QAEF,IAAI9K,OAAO,CAAC4L,gBAAgB,EAAE;UAC5B,OAAO5L,OAAO,CAAClD,WAAW;QAC5B,CAAC,MAAM,IAAI,IAAI,CAACgP,UAAU,EAAE;UAC1B,MAAMzX,cAAc,GAAG,IAAI,CAACJ,MAAM,CAACI,cAAoC;UAEvE,MAAMkC,OAAO,GAAG,IAAIwV,oBAAmB,CAAC;YACtCtX,MAAM,EAAEJ,cAAc,CAACG,OAAO,CAACC,MAAM;YACrCC,QAAQ,EAAEL,cAAc,CAACG,OAAO,CAACE,QAAQ;YACzCC,QAAQ,EAAEN,cAAc,CAACG,OAAO,CAACG,QAAQ;YACzCmX,UAAU,EAAE,IAAI,CAACA;UACnB,CAAC,CAAC;UAEF,IAAI,CAACzR,SAAS,CAACC,WAAW,CAACC,YAAI,CAACyR,YAAY,EAAEzV,OAAO,CAACF,IAAI,CAAC;UAC3D,IAAI,CAACD,KAAK,CAACG,OAAO,CAAC,YAAW;YAC5B,OAAOA,OAAO,CAACqM,QAAQ,CAAC,IAAI,CAAC;UAC/B,CAAC,CAAC;UAEF,IAAI,CAACkJ,UAAU,GAAGxX,SAAS;QAC7B,CAAC,MAAM,IAAI,IAAI,CAACuX,UAAU,EAAE;UAC1B,MAAM,IAAI,CAACA,UAAU;QACvB,CAAC,MAAM;UACL,MAAM,IAAItQ,uBAAe,CAAC,eAAe,EAAE,QAAQ,CAAC;QACtD;MACF;IACF,CAAC,SAAS;MACR,IAAI,CAACsQ,UAAU,GAAGvX,SAAS;MAC3B6I,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;EACF;;EAEA;AACF;AACA;EACE,MAAMjC,4BAA4BA,CAACvB,MAAmB,EAAoC;IACxFA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM;MAAE5J,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,MAAMmB,OAAO,GAAG,MAAMrJ,OAAO,CAACqX,IAAI,CAAC,CACjC,IAAI,CAAC3Q,SAAS,CAAC8Q,WAAW,CAAC,CAAC,CAACD,KAAK,CAAExP,GAAG,IAAK;QAC1C,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;MACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;MAEF,MAAM9K,OAAO,GAAG,IAAI0L,2BAAkB,CAAC,IAAI,CAAC;MAC5C,MAAMC,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAEgD,OAAO,CAAC;MACxE,MAAMrM,OAAO,CAACqX,IAAI,CAAC,CACjB,IAAAnP,YAAI,EAAC8P,iBAAiB,EAAE,KAAK,CAAC,EAC9Bb,aAAa,CACd,CAAC;MAEF,IAAI9K,OAAO,CAAC4L,gBAAgB,EAAE;QAC5B,OAAO5L,OAAO,CAAClD,WAAW;MAC5B;MAEA,MAAMmP,gBAAgB,GAAGjM,OAAO,CAACiM,gBAAgB;MAEjD,IAAIA,gBAAgB,IAAIA,gBAAgB,CAACC,MAAM,IAAID,gBAAgB,CAACE,GAAG,EAAE;QACvE;QACA,MAAM9X,cAAc,GAAG,IAAI,CAACJ,MAAM,CAACI,cAAiR;QACpT;QACA,MAAM+X,UAAU,GAAG,IAAIC,QAAG,CAAC,WAAW,EAAEJ,gBAAgB,CAACE,GAAG,CAAC,CAACvJ,QAAQ,CAAC,CAAC;;QAExE;QACA,IAAI0J,WAA4B;QAEhC,QAAQjY,cAAc,CAACE,IAAI;UACzB,KAAK,kBAAkB;YACrB+X,WAAW,GAAGjY,cAAc,CAACG,OAAO,CAACM,UAAU;YAC/C;UACF,KAAK,iCAAiC;YACpCwX,WAAW,GAAG,IAAIC,oCAA0B,CAC1ClY,cAAc,CAACG,OAAO,CAACQ,QAAQ,IAAI,QAAQ,EAC3CX,cAAc,CAACG,OAAO,CAACO,QAAQ,EAC/BV,cAAc,CAACG,OAAO,CAACE,QAAQ,EAC/BL,cAAc,CAACG,OAAO,CAACG,QACzB,CAAC;YACD;UACF,KAAK,+BAA+B;UACpC,KAAK,wCAAwC;YAC3C,MAAM6X,OAAO,GAAGnY,cAAc,CAACG,OAAO,CAACO,QAAQ,GAAG,CAACV,cAAc,CAACG,OAAO,CAACO,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9FuX,WAAW,GAAG,IAAIG,mCAAyB,CAAC,GAAGD,OAAO,CAAC;YACvD;UACF,KAAK,gCAAgC;YACnC,MAAMlQ,IAAI,GAAGjI,cAAc,CAACG,OAAO,CAACO,QAAQ,GAAG;cAAE2X,uBAAuB,EAAErY,cAAc,CAACG,OAAO,CAACO;YAAS,CAAC,GAAG,CAAC,CAAC;YAChHuX,WAAW,GAAG,IAAIK,gCAAsB,CAACrQ,IAAI,CAAC;YAC9C;UACF,KAAK,iDAAiD;YACpDgQ,WAAW,GAAG,IAAIM,gCAAsB,CACtCvY,cAAc,CAACG,OAAO,CAACQ,QAAQ,EAC/BX,cAAc,CAACG,OAAO,CAACO,QAAQ,EAC/BV,cAAc,CAACG,OAAO,CAACU,YACzB,CAAC;YACD;QACJ;;QAEA;QACA,IAAI2X,aAAiC;QAErC,IAAI;UACFA,aAAa,GAAG,MAAMlZ,OAAO,CAACqX,IAAI,CAAC,CACjCsB,WAAW,CAACQ,QAAQ,CAACV,UAAU,CAAC,EAChCtB,aAAa,CACd,CAAC;QACJ,CAAC,CAAC,OAAOpP,GAAG,EAAE;UACZyB,MAAM,CAACG,cAAc,CAAC,CAAC;UAEvB,MAAM,IAAIyP,cAAc,CACtB,CAAC,IAAIxR,uBAAe,CAAC,0DAA0D,EAAE,UAAU,CAAC,EAAEG,GAAG,CAAC,CAAC;QACvG;;QAEA;QACA,IAAImR,aAAa,KAAK,IAAI,EAAE;UAC1B,MAAM,IAAIE,cAAc,CACtB,CAAC,IAAIxR,uBAAe,CAAC,0DAA0D,EAAE,UAAU,CAAC,CAAC,CAAC;QAClG;QAEA,IAAI,CAAC6I,uBAAuB,CAACyI,aAAa,CAAC5X,KAAK,CAAC;QACjD;QACA,IAAI,CAAC6G,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAAC2E,+BAA+B,CAAC;QAC7D,OAAO,MAAM,IAAI,CAACC,kCAAkC,CAAC3B,MAAM,CAAC;MAC9D,CAAC,MAAM,IAAI,IAAI,CAAC0O,UAAU,EAAE;QAC1B,MAAM,IAAI,CAACA,UAAU;MACvB,CAAC,MAAM;QACL,MAAM,IAAItQ,uBAAe,CAAC,eAAe,EAAE,QAAQ,CAAC;MACtD;IACF,CAAC,SAAS;MACR,IAAI,CAACsQ,UAAU,GAAGvX,SAAS;MAC3B6I,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;EACF;;EAEA;AACF;AACA;EACE,MAAMtB,gCAAgCA,CAAClC,MAAmB,EAAE;IAC1DA,MAAM,CAACG,cAAc,CAAC,CAAC;IAEvB,MAAM;MAAE5J,OAAO,EAAEoX,aAAa;MAAErX;IAAO,CAAC,GAAGF,aAAa,CAAQ,CAAC;IAEjE,MAAMoN,OAAO,GAAGA,CAAA,KAAM;MAAElN,MAAM,CAAC0J,MAAM,CAACyD,MAAM,CAAC;IAAE,CAAC;IAChDzD,MAAM,CAAC0D,gBAAgB,CAAC,OAAO,EAAEF,OAAO,EAAE;MAAE9E,IAAI,EAAE;IAAK,CAAC,CAAC;IAEzD,IAAI;MACF,IAAI,CAAC8I,cAAc,CAAC,CAAC;MAErB,MAAM3H,OAAO,GAAG,MAAMrJ,OAAO,CAACqX,IAAI,CAAC,CACjC,IAAI,CAAC3Q,SAAS,CAAC8Q,WAAW,CAAC,CAAC,CAACD,KAAK,CAAExP,GAAG,IAAK;QAC1C,MAAM,IAAI,CAACN,eAAe,CAACM,GAAG,CAAC;MACjC,CAAC,CAAC,EACFoP,aAAa,CACd,CAAC;MAEF,MAAMa,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAE,IAAIgQ,+BAAsB,CAAC,IAAI,CAAC,CAAC;MACjG,MAAMrZ,OAAO,CAACqX,IAAI,CAAC,CACjB,IAAAnP,YAAI,EAAC8P,iBAAiB,EAAE,KAAK,CAAC,EAC9Bb,aAAa,CACd,CAAC;IACJ,CAAC,SAAS;MACR3N,MAAM,CAAC2D,mBAAmB,CAAC,OAAO,EAAEH,OAAO,CAAC;IAC9C;EACF;AACF;AAEA,SAAS5B,gBAAgBA,CAAChE,KAAuC,EAAW;EAC1E,IAAIA,KAAK,YAAYgS,cAAc,EAAE;IACnChS,KAAK,GAAGA,KAAK,CAACkS,MAAM,CAAC,CAAC,CAAC;EACzB;EACA,OAAQlS,KAAK,YAAYQ,uBAAe,IAAK,CAAC,CAACR,KAAK,CAACmS,WAAW;AAClE;AAAC,IAAAC,QAAA,GAAAC,OAAA,CAAAlb,OAAA,GAEc4B,UAAU;AACzBuZ,MAAM,CAACD,OAAO,GAAGtZ,UAAU;AAE3BA,UAAU,CAACwZ,SAAS,CAACpT,KAAK,GAAG;EAC3BC,WAAW,EAAE;IACXqB,IAAI,EAAE,aAAa;IACnByG,MAAM,EAAE,CAAC;EACX,CAAC;EACDlG,UAAU,EAAE;IACVP,IAAI,EAAE,YAAY;IAClByG,MAAM,EAAE,CAAC;EACX,CAAC;EACD7D,aAAa,EAAE;IACb5C,IAAI,EAAE,cAAc;IACpByG,MAAM,EAAE,CAAC;EACX,CAAC;EACD/C,SAAS,EAAE;IACT1D,IAAI,EAAE,WAAW;IACjByG,MAAM,EAAE,CAAC;EACX,CAAC;EACDjD,uBAAuB,EAAE;IACvBxD,IAAI,EAAE,yBAAyB;IAC/ByG,MAAM,EAAE,CAAC;EACX,CAAC;EACDC,sBAAsB,EAAE;IACtB1G,IAAI,EAAE,uBAAuB;IAC7ByG,MAAM,EAAE,CAAC;EACX,CAAC;EACDpD,+BAA+B,EAAE;IAC/BrD,IAAI,EAAE,6BAA6B;IACnCyG,MAAM,EAAE,CAAC;EACX,CAAC;EACDtD,qBAAqB,EAAE;IACrBnD,IAAI,EAAE,yBAAyB;IAC/ByG,MAAM,EAAE,CAAC;EACX,CAAC;EACDxD,wBAAwB,EAAE;IACxBjD,IAAI,EAAE,uBAAuB;IAC7ByG,MAAM,EAAE,CAAC;EACX,CAAC;EACD7C,6BAA6B,EAAE;IAC7B5D,IAAI,EAAE,2BAA2B;IACjCyG,MAAM,EAAE,CAAC;EACX,CAAC;EACD1C,SAAS,EAAE;IACT/D,IAAI,EAAE,UAAU;IAChByG,MAAM,EAAE;MACNsL,WAAW,EAAE,SAAAA,CAAA,EAAW;QACtB,IAAI,CAACzR,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;QACnC,IAAI,CAACM,iBAAiB,CAAC,CAAC;MAC1B;IACF;EACF,CAAC;EACD+N,mBAAmB,EAAE;IACnB/O,IAAI,EAAE,mBAAmB;IACzBqG,KAAK,EAAE,SAAAA,CAAA,EAAW;MAChB,CAAC,YAAY;QACX,IAAI7E,OAAO;QACX,IAAI;UACFA,OAAO,GAAG,MAAM,IAAI,CAAC3C,SAAS,CAAC8Q,WAAW,CAAC,CAAC;QAC9C,CAAC,CAAC,OAAOzP,GAAQ,EAAE;UACjB,IAAI,CAACV,aAAa,CAAC,aAAa,EAAEU,GAAG,CAAC;UACtCT,OAAO,CAACC,QAAQ,CAAC,MAAM;YACrB,IAAI,CAACC,IAAI,CAAC,OAAO,EAAE,IAAI,CAACC,eAAe,CAACM,GAAG,CAAC,CAAC;UAC/C,CAAC,CAAC;UACF;QACF;QACA;QACA,IAAI,CAAC+D,iBAAiB,CAAC,CAAC;QAExB,MAAMkM,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAE,IAAIwQ,4BAAmB,CAAC,IAAI,EAAE,IAAI,CAAC7N,OAAQ,CAAC,CAAC;;QAE7G;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,IAAI,IAAI,CAACA,OAAO,EAAEiK,QAAQ,IAAI,IAAI,CAACrI,WAAW,EAAE;UAC9C,OAAO,IAAI,CAACzF,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACuT,cAAc,CAAC;QACrD;QAEA,MAAMC,QAAQ,GAAGA,CAAA,KAAM;UACrB/B,iBAAiB,CAACvB,MAAM,CAAC,CAAC;QAC5B,CAAC;QACD,MAAMuD,OAAO,GAAGA,CAAA,KAAM;UACpBhC,iBAAiB,CAACiC,KAAK,CAAC,CAAC;UAEzB,IAAI,CAACjO,OAAO,EAAE9D,IAAI,CAAC,QAAQ,EAAE6R,QAAQ,CAAC;QACxC,CAAC;QAED,IAAI,CAAC/N,OAAO,EAAExD,EAAE,CAAC,OAAO,EAAEwR,OAAO,CAAC;QAElC,IAAI,IAAI,CAAChO,OAAO,YAAY4H,gBAAO,IAAI,IAAI,CAAC5H,OAAO,CAACwK,MAAM,EAAE;UAC1DwD,OAAO,CAAC,CAAC;QACX;QAEA,MAAMtG,QAAQ,GAAGA,CAAA,KAAM;UACrBsE,iBAAiB,CAAChQ,cAAc,CAAC,KAAK,EAAEkS,cAAc,CAAC;UAEvD,IAAI,IAAI,CAAClO,OAAO,YAAY4H,gBAAO,IAAI,IAAI,CAAC5H,OAAO,CAACwK,MAAM,EAAE;YAC1D;YACA,IAAI,CAACxK,OAAO,CAACyK,MAAM,CAAC,CAAC;UACvB;UAEA,IAAI,CAACzK,OAAO,EAAEhE,cAAc,CAAC,OAAO,EAAEgS,OAAO,CAAC;UAC9C,IAAI,CAAChO,OAAO,EAAEhE,cAAc,CAAC,QAAQ,EAAE+R,QAAQ,CAAC;;UAEhD;UACA;UACA;UACA;UACA,IAAI,CAAC5R,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACuT,cAAc,CAAC;QAC9C,CAAC;QAED,MAAMI,cAAc,GAAGA,CAAA,KAAM;UAC3B,IAAI,CAAClO,OAAO,EAAEhE,cAAc,CAAC,QAAQ,EAAE,IAAI,CAACvB,uBAAuB,CAAC;UACpE,IAAI,CAACuF,OAAO,EAAEhE,cAAc,CAAC,QAAQ,EAAE0L,QAAQ,CAAC;UAChD,IAAI,CAAC1H,OAAO,EAAEhE,cAAc,CAAC,OAAO,EAAEgS,OAAO,CAAC;UAC9C,IAAI,CAAChO,OAAO,EAAEhE,cAAc,CAAC,QAAQ,EAAE+R,QAAQ,CAAC;UAEhD,IAAI,CAAC5R,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACqF,SAAS,CAAC;UACvC,MAAMuO,UAAU,GAAG,IAAI,CAACnO,OAAkB;UAC1C,IAAI,CAACA,OAAO,GAAGrL,SAAS;UACxB,IAAI,IAAI,CAACL,MAAM,CAACO,OAAO,CAAC2D,UAAU,GAAG,KAAK,IAAI2V,UAAU,CAAC/S,KAAK,IAAI,IAAI,CAACrB,UAAU,EAAE;YACjF,IAAI,CAACL,aAAa,GAAG,KAAK;UAC5B;UACAyU,UAAU,CAACjO,QAAQ,CAACiO,UAAU,CAAC/S,KAAK,EAAE+S,UAAU,CAAChE,QAAQ,EAAEgE,UAAU,CAAC/G,IAAI,CAAC;QAC7E,CAAC;QAED4E,iBAAiB,CAAC9P,IAAI,CAAC,KAAK,EAAEgS,cAAc,CAAC;QAC7C,IAAI,CAAClO,OAAO,EAAE9D,IAAI,CAAC,QAAQ,EAAEwL,QAAQ,CAAC;MACxC,CAAC,EAAE,CAAC;IAEN,CAAC;IACDzF,IAAI,EAAE,SAAAA,CAASmM,SAAS,EAAE;MACxB,IAAI,CAACtO,iBAAiB,CAAC,CAAC;IAC1B,CAAC;IACDwC,MAAM,EAAE;MACNsL,WAAW,EAAE,SAAAA,CAAS7R,GAAG,EAAE;QACzB,MAAMoS,UAAU,GAAG,IAAI,CAACnO,OAAQ;QAChC,IAAI,CAACA,OAAO,GAAGrL,SAAS;QACxB,IAAI,CAACwH,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;QACnC,IAAI,CAACM,iBAAiB,CAAC,CAAC;QAExBsR,UAAU,CAACjO,QAAQ,CAACnE,GAAG,CAAC;MAC1B;IACF;EACF,CAAC;EACD+R,cAAc,EAAE;IACdjS,IAAI,EAAE,eAAe;IACrBqG,KAAK,EAAE,SAAAA,CAAA,EAAW;MAChB,CAAC,YAAY;QACX,IAAI7E,OAAO;QACX,IAAI;UACFA,OAAO,GAAG,MAAM,IAAI,CAAC3C,SAAS,CAAC8Q,WAAW,CAAC,CAAC;QAC9C,CAAC,CAAC,OAAOzP,GAAQ,EAAE;UACjB,IAAI,CAACV,aAAa,CAAC,aAAa,EAAEU,GAAG,CAAC;UACtCT,OAAO,CAACC,QAAQ,CAAC,MAAM;YACrB,IAAI,CAACC,IAAI,CAAC,OAAO,EAAE,IAAI,CAACC,eAAe,CAACM,GAAG,CAAC,CAAC;UAC/C,CAAC,CAAC;UACF;QACF;QAEA,MAAMsE,OAAO,GAAG,IAAIgO,8BAAqB,CAAC,IAAI,EAAE,IAAI,CAACrO,OAAQ,CAAC;QAC9D,MAAMgM,iBAAiB,GAAG,IAAI,CAAC5L,uBAAuB,CAAC/C,OAAO,EAAEgD,OAAO,CAAC;QAExE,MAAM,IAAAnE,YAAI,EAAC8P,iBAAiB,EAAE,KAAK,CAAC;QACpC;QACA;QACA,IAAI3L,OAAO,CAACiO,iBAAiB,EAAE;UAC7B,IAAI,CAAC3M,gBAAgB,CAAC,CAAC;UAEvB,MAAMwM,UAAU,GAAG,IAAI,CAACnO,OAAQ;UAChC,IAAI,CAACA,OAAO,GAAGrL,SAAS;UACxB,IAAI,CAACwH,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACqF,SAAS,CAAC;UAEvC,IAAIuO,UAAU,CAAC/S,KAAK,IAAI+S,UAAU,CAAC/S,KAAK,YAAY6E,oBAAY,IAAIkO,UAAU,CAAC/S,KAAK,CAAC8C,IAAI,KAAK,UAAU,EAAE;YACxGiQ,UAAU,CAACjO,QAAQ,CAACiO,UAAU,CAAC/S,KAAK,CAAC;UACvC,CAAC,MAAM;YACL+S,UAAU,CAACjO,QAAQ,CAAC,IAAID,oBAAY,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;UAC/D;QACF;MACF,CAAC,EAAE,CAAC,CAACsL,KAAK,CAAExP,GAAG,IAAK;QAClBT,OAAO,CAACC,QAAQ,CAAC,MAAM;UACrB,MAAMQ,GAAG;QACX,CAAC,CAAC;MACJ,CAAC,CAAC;IACJ,CAAC;IACDuG,MAAM,EAAE;MACNsL,WAAW,EAAE,SAAAA,CAAS7R,GAAG,EAAE;QACzB,MAAMoS,UAAU,GAAG,IAAI,CAACnO,OAAQ;QAChC,IAAI,CAACA,OAAO,GAAGrL,SAAS;QAExB,IAAI,CAACwH,YAAY,CAAC,IAAI,CAAC5B,KAAK,CAACgC,KAAK,CAAC;QACnC,IAAI,CAACM,iBAAiB,CAAC,CAAC;QAExBsR,UAAU,CAACjO,QAAQ,CAACnE,GAAG,CAAC;MAC1B;IACF;EACF,CAAC;EACDQ,KAAK,EAAE;IACLV,IAAI,EAAE,OAAO;IACbyG,MAAM,EAAE,CAAC;EACX;AACF,CAAC","ignoreList":[]}
|