@mysetup/mqtt 1.7.0 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/topic-alias-recv.ts","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/ours/primordials.js","../../node_modules/.pnpm/event-target-shim@5.0.1/node_modules/event-target-shim/src/event.mjs","../../node_modules/.pnpm/event-target-shim@5.0.1/node_modules/event-target-shim/src/event-target.mjs","../../node_modules/.pnpm/abort-controller@3.0.0/node_modules/abort-controller/src/abort-signal.ts","../../node_modules/.pnpm/abort-controller@3.0.0/node_modules/abort-controller/src/abort-controller.ts","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/ours/util.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/ours/errors.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/validators.js","../../node_modules/.pnpm/process@0.11.10/node_modules/process/index.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/utils.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/end-of-stream.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/destroy.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/legacy.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/add-abort-signal.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/buffer_list.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/state.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/from.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/readable.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/writable.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/duplexify.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/duplex.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/transform.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/passthrough.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/pipeline.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/compose.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/internal/streams/operators.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/stream/promises.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/stream.js","../../node_modules/.pnpm/readable-stream@4.5.2/node_modules/readable-stream/lib/ours/index.js","../../node_modules/.pnpm/inherits@2.0.4/node_modules/inherits/inherits_browser.js","../../node_modules/.pnpm/inherits@2.0.4/node_modules/inherits/inherits.js","../../node_modules/.pnpm/bl@6.0.16/node_modules/bl/BufferList.js","../../node_modules/.pnpm/bl@6.0.16/node_modules/bl/bl.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/packet.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/constants.js","../../node_modules/.pnpm/ms@2.1.3/node_modules/ms/index.js","../../node_modules/.pnpm/debug@4.3.7/node_modules/debug/src/common.js","../../node_modules/.pnpm/debug@4.3.7/node_modules/debug/src/browser.js","../../node_modules/.pnpm/has-flag@4.0.0/node_modules/has-flag/index.js","../../node_modules/.pnpm/supports-color@7.2.0/node_modules/supports-color/index.js","../../node_modules/.pnpm/debug@4.3.7/node_modules/debug/src/node.js","../../node_modules/.pnpm/debug@4.3.7/node_modules/debug/src/index.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/parser.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/numbers.js","../../node_modules/.pnpm/process-nextick-args@2.0.1/node_modules/process-nextick-args/index.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/writeToStream.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/generate.js","../../node_modules/.pnpm/mqtt-packet@9.0.0/node_modules/mqtt-packet/mqtt.js","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/default-message-id-provider.ts","../../node_modules/.pnpm/rfdc@1.4.1/node_modules/rfdc/index.js","../../node_modules/.pnpm/rfdc@1.4.1/node_modules/rfdc/default.js","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/validations.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/store.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/publish.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/package.json","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/shared.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/ack.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/auth.ts","../../node_modules/.pnpm/lru-cache@10.4.3/node_modules/lru-cache/src/index.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/ContainerBase/container/ContainerBase/index.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/ContainerBase/index.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/OtherContainer/container/OtherContainer/Stack.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/OtherContainer/Stack.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/OtherContainer/container/OtherContainer/Queue.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/OtherContainer/Queue.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/OtherContainer/container/OtherContainer/PriorityQueue.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/OtherContainer/PriorityQueue.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/SequentialContainer/Base/container/SequentialContainer/Base/index.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/SequentialContainer/Base/index.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/src/utils/throwError.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/utils/utils/throwError.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/SequentialContainer/Base/container/SequentialContainer/Base/RandomIterator.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/SequentialContainer/Base/RandomIterator.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/SequentialContainer/container/SequentialContainer/Vector.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/SequentialContainer/Vector.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/SequentialContainer/container/SequentialContainer/LinkList.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/SequentialContainer/LinkList.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/SequentialContainer/container/SequentialContainer/Deque.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/SequentialContainer/Deque.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/container/TreeContainer/Base/TreeNode.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/TreeContainer/Base/TreeNode.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/container/TreeContainer/Base/index.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/TreeContainer/Base/index.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/container/TreeContainer/Base/TreeIterator.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/TreeContainer/Base/TreeIterator.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/TreeContainer/container/TreeContainer/OrderedSet.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/TreeContainer/OrderedSet.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/TreeContainer/container/TreeContainer/OrderedMap.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/TreeContainer/OrderedMap.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/src/utils/checkObject.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/utils/utils/checkObject.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/HashContainer/Base/container/HashContainer/Base/index.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/src/container/HashContainer/Base/index.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/HashContainer/container/HashContainer/HashSet.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/HashContainer/HashSet.ts","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/container/HashContainer/container/HashContainer/HashMap.js","../../node_modules/.pnpm/js-sdsl@4.3.0/node_modules/js-sdsl/dist/esm/src/container/HashContainer/HashMap.ts","../../node_modules/.pnpm/number-allocator@1.0.14/node_modules/number-allocator/lib/number-allocator.js","../../node_modules/.pnpm/number-allocator@1.0.14/node_modules/number-allocator/index.js","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/topic-alias-send.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/connack.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/pubrel.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/handlers/index.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/TypedEmitter.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/is-browser.ts","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/src/factories/add-unique-number.ts","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/src/factories/cache.ts","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/src/factories/generate-unique-number.ts","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/add-unique-number-factory.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/add-unique-number-function.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/cache-factory.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/cache-function.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/generate-unique-number-factory.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/build/es2019/types/generate-unique-number-function.js","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/src/types/index.ts","../../node_modules/.pnpm/fast-unique-numbers@8.0.13/node_modules/fast-unique-numbers/src/module.ts","../../node_modules/.pnpm/worker-timers-broker@6.1.8/node_modules/worker-timers-broker/src/guards/call-notification.ts","../../node_modules/.pnpm/worker-timers-broker@6.1.8/node_modules/worker-timers-broker/src/guards/clear-response.ts","../../node_modules/.pnpm/worker-timers-broker@6.1.8/node_modules/worker-timers-broker/src/module.ts","../../node_modules/.pnpm/worker-timers@7.1.8/node_modules/worker-timers/src/factories/load-or-return-broker.ts","../../node_modules/.pnpm/worker-timers@7.1.8/node_modules/worker-timers/src/worker/worker.ts","../../node_modules/.pnpm/worker-timers@7.1.8/node_modules/worker-timers/src/module.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/get-timer.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/KeepaliveManager.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/client.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/unique-message-id-provider.ts","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/constants.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/buffer-util.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/limiter.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/permessage-deflate.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/validation.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/receiver.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/sender.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/event-target.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/extension.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/websocket.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/stream.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/subprotocol.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/lib/websocket-server.js","../../node_modules/.pnpm/ws@8.18.0/node_modules/ws/index.js","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/BufferedDuplex.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/ws.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/tcp.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/tls.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/wx.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/ali.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/lib/connect/index.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/mqtt.ts","../../node_modules/.pnpm/mqtt@5.10.1/node_modules/mqtt/src/index.ts","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/err-helpers.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/err-proto.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/err.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/err-with-cause.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/req.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/lib/res.js","../../node_modules/.pnpm/pino-std-serializers@7.0.0/node_modules/pino-std-serializers/index.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/caller.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/validator.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/rx.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/parse.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/redactor.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/modifiers.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/restorer.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/lib/state.js","../../node_modules/.pnpm/fast-redact@3.5.0/node_modules/fast-redact/index.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/symbols.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/redaction.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/time.js","../../node_modules/.pnpm/quick-format-unescaped@4.0.4/node_modules/quick-format-unescaped/index.js","../../node_modules/.pnpm/atomic-sleep@1.0.0/node_modules/atomic-sleep/index.js","../../node_modules/.pnpm/sonic-boom@4.2.0/node_modules/sonic-boom/index.js","../../node_modules/.pnpm/on-exit-leak-free@2.1.2/node_modules/on-exit-leak-free/index.js","../../node_modules/.pnpm/thread-stream@3.1.0/node_modules/thread-stream/package.json","../../node_modules/.pnpm/thread-stream@3.1.0/node_modules/thread-stream/lib/wait.js","../../node_modules/.pnpm/thread-stream@3.1.0/node_modules/thread-stream/lib/indexes.js","../../node_modules/.pnpm/thread-stream@3.1.0/node_modules/thread-stream/index.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/transport.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/tools.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/constants.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/levels.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/meta.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/proto.js","../../node_modules/.pnpm/safe-stable-stringify@2.5.0/node_modules/safe-stable-stringify/index.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/lib/multistream.js","../../node_modules/.pnpm/pino@9.5.0/node_modules/pino/pino.js","../../node_modules/.pnpm/@mysetup+logger@1.1.0/node_modules/@mysetup/logger/dist/logger.js","../../node_modules/.pnpm/@mysetup+logger@1.1.0/node_modules/@mysetup/logger/dist/index.js","../../node_modules/.pnpm/clone@2.1.2/node_modules/clone/clone.js","../../node_modules/.pnpm/node-cache@5.1.2/node_modules/node-cache/lib/node_cache.js","../../node_modules/.pnpm/node-cache@5.1.2/node_modules/node-cache/index.js","../../node_modules/.pnpm/@mysetup+cache@1.1.0/node_modules/@mysetup/cache/dist/cache.js","../../node_modules/.pnpm/@mysetup+cache@1.1.0/node_modules/@mysetup/cache/dist/index.js","../../index.ts","../../mqttClient.ts"],"sourcesContent":["/**\n * Topic Alias receiving manager\n * This holds alias to topic map\n * @param {Number} [max] - topic alias maximum entries\n */\nexport default class TopicAliasRecv {\n\tprivate aliasToTopic: Record<number, string>\n\n\tpublic max: number\n\n\tpublic length: number\n\n\tconstructor(max: number) {\n\t\tthis.aliasToTopic = {}\n\t\tthis.max = max\n\t}\n\n\t/**\n\t * Insert or update topic - alias entry.\n\t * @param {String} [topic] - topic\n\t * @param {Number} [alias] - topic alias\n\t * @returns {Boolean} - if success return true otherwise false\n\t */\n\tput(topic: string, alias: number): boolean {\n\t\tif (alias === 0 || alias > this.max) {\n\t\t\treturn false\n\t\t}\n\t\tthis.aliasToTopic[alias] = topic\n\t\tthis.length = Object.keys(this.aliasToTopic).length\n\t\treturn true\n\t}\n\n\t/**\n\t * Get topic by alias\n\t * @param {String} [topic] - topic\n\t * @returns {Number} - if mapped topic exists return topic alias, otherwise return undefined\n\t */\n\tgetTopicByAlias(alias: number): string {\n\t\treturn this.aliasToTopic[alias]\n\t}\n\n\t/**\n\t * Clear all entries\n\t */\n\tclear() {\n\t\tthis.aliasToTopic = {}\n\t}\n}\n","'use strict'\n\n/*\n This file is a reduced and adapted version of the main lib/internal/per_context/primordials.js file defined at\n\n https://github.com/nodejs/node/blob/master/lib/internal/per_context/primordials.js\n\n Don't try to replace with the original file and keep it up to date with the upstream file.\n*/\nmodule.exports = {\n ArrayIsArray(self) {\n return Array.isArray(self)\n },\n ArrayPrototypeIncludes(self, el) {\n return self.includes(el)\n },\n ArrayPrototypeIndexOf(self, el) {\n return self.indexOf(el)\n },\n ArrayPrototypeJoin(self, sep) {\n return self.join(sep)\n },\n ArrayPrototypeMap(self, fn) {\n return self.map(fn)\n },\n ArrayPrototypePop(self, el) {\n return self.pop(el)\n },\n ArrayPrototypePush(self, el) {\n return self.push(el)\n },\n ArrayPrototypeSlice(self, start, end) {\n return self.slice(start, end)\n },\n Error,\n FunctionPrototypeCall(fn, thisArgs, ...args) {\n return fn.call(thisArgs, ...args)\n },\n FunctionPrototypeSymbolHasInstance(self, instance) {\n return Function.prototype[Symbol.hasInstance].call(self, instance)\n },\n MathFloor: Math.floor,\n Number,\n NumberIsInteger: Number.isInteger,\n NumberIsNaN: Number.isNaN,\n NumberMAX_SAFE_INTEGER: Number.MAX_SAFE_INTEGER,\n NumberMIN_SAFE_INTEGER: Number.MIN_SAFE_INTEGER,\n NumberParseInt: Number.parseInt,\n ObjectDefineProperties(self, props) {\n return Object.defineProperties(self, props)\n },\n ObjectDefineProperty(self, name, prop) {\n return Object.defineProperty(self, name, prop)\n },\n ObjectGetOwnPropertyDescriptor(self, name) {\n return Object.getOwnPropertyDescriptor(self, name)\n },\n ObjectKeys(obj) {\n return Object.keys(obj)\n },\n ObjectSetPrototypeOf(target, proto) {\n return Object.setPrototypeOf(target, proto)\n },\n Promise,\n PromisePrototypeCatch(self, fn) {\n return self.catch(fn)\n },\n PromisePrototypeThen(self, thenFn, catchFn) {\n return self.then(thenFn, catchFn)\n },\n PromiseReject(err) {\n return Promise.reject(err)\n },\n PromiseResolve(val) {\n return Promise.resolve(val)\n },\n ReflectApply: Reflect.apply,\n RegExpPrototypeTest(self, value) {\n return self.test(value)\n },\n SafeSet: Set,\n String,\n StringPrototypeSlice(self, start, end) {\n return self.slice(start, end)\n },\n StringPrototypeToLowerCase(self) {\n return self.toLowerCase()\n },\n StringPrototypeToUpperCase(self) {\n return self.toUpperCase()\n },\n StringPrototypeTrim(self) {\n return self.trim()\n },\n Symbol,\n SymbolFor: Symbol.for,\n SymbolAsyncIterator: Symbol.asyncIterator,\n SymbolHasInstance: Symbol.hasInstance,\n SymbolIterator: Symbol.iterator,\n SymbolDispose: Symbol.dispose || Symbol('Symbol.dispose'),\n SymbolAsyncDispose: Symbol.asyncDispose || Symbol('Symbol.asyncDispose'),\n TypedArrayPrototypeSet(self, buf, len) {\n return self.set(buf, len)\n },\n Boolean: Boolean,\n Uint8Array\n}\n","/**\n * @typedef {object} PrivateData\n * @property {EventTarget} eventTarget The event target.\n * @property {{type:string}} event The original event object.\n * @property {number} eventPhase The current event phase.\n * @property {EventTarget|null} currentTarget The current event target.\n * @property {boolean} canceled The flag to prevent default.\n * @property {boolean} stopped The flag to stop propagation.\n * @property {boolean} immediateStopped The flag to stop propagation immediately.\n * @property {Function|null} passiveListener The listener if the current listener is passive. Otherwise this is null.\n * @property {number} timeStamp The unix time.\n * @private\n */\n\n/**\n * Private data for event wrappers.\n * @type {WeakMap<Event, PrivateData>}\n * @private\n */\nconst privateData = new WeakMap()\n\n/**\n * Cache for wrapper classes.\n * @type {WeakMap<Object, Function>}\n * @private\n */\nconst wrappers = new WeakMap()\n\n/**\n * Get private data.\n * @param {Event} event The event object to get private data.\n * @returns {PrivateData} The private data of the event.\n * @private\n */\nfunction pd(event) {\n const retv = privateData.get(event)\n console.assert(\n retv != null,\n \"'this' is expected an Event object, but got\",\n event\n )\n return retv\n}\n\n/**\n * https://dom.spec.whatwg.org/#set-the-canceled-flag\n * @param data {PrivateData} private data.\n */\nfunction setCancelFlag(data) {\n if (data.passiveListener != null) {\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(\n \"Unable to preventDefault inside passive event listener invocation.\",\n data.passiveListener\n )\n }\n return\n }\n if (!data.event.cancelable) {\n return\n }\n\n data.canceled = true\n if (typeof data.event.preventDefault === \"function\") {\n data.event.preventDefault()\n }\n}\n\n/**\n * @see https://dom.spec.whatwg.org/#interface-event\n * @private\n */\n/**\n * The event wrapper.\n * @constructor\n * @param {EventTarget} eventTarget The event target of this dispatching.\n * @param {Event|{type:string}} event The original event to wrap.\n */\nfunction Event(eventTarget, event) {\n privateData.set(this, {\n eventTarget,\n event,\n eventPhase: 2,\n currentTarget: eventTarget,\n canceled: false,\n stopped: false,\n immediateStopped: false,\n passiveListener: null,\n timeStamp: event.timeStamp || Date.now(),\n })\n\n // https://heycam.github.io/webidl/#Unforgeable\n Object.defineProperty(this, \"isTrusted\", { value: false, enumerable: true })\n\n // Define accessors\n const keys = Object.keys(event)\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i]\n if (!(key in this)) {\n Object.defineProperty(this, key, defineRedirectDescriptor(key))\n }\n }\n}\n\n// Should be enumerable, but class methods are not enumerable.\nEvent.prototype = {\n /**\n * The type of this event.\n * @type {string}\n */\n get type() {\n return pd(this).event.type\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n */\n get target() {\n return pd(this).eventTarget\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n */\n get currentTarget() {\n return pd(this).currentTarget\n },\n\n /**\n * @returns {EventTarget[]} The composed path of this event.\n */\n composedPath() {\n const currentTarget = pd(this).currentTarget\n if (currentTarget == null) {\n return []\n }\n return [currentTarget]\n },\n\n /**\n * Constant of NONE.\n * @type {number}\n */\n get NONE() {\n return 0\n },\n\n /**\n * Constant of CAPTURING_PHASE.\n * @type {number}\n */\n get CAPTURING_PHASE() {\n return 1\n },\n\n /**\n * Constant of AT_TARGET.\n * @type {number}\n */\n get AT_TARGET() {\n return 2\n },\n\n /**\n * Constant of BUBBLING_PHASE.\n * @type {number}\n */\n get BUBBLING_PHASE() {\n return 3\n },\n\n /**\n * The target of this event.\n * @type {number}\n */\n get eventPhase() {\n return pd(this).eventPhase\n },\n\n /**\n * Stop event bubbling.\n * @returns {void}\n */\n stopPropagation() {\n const data = pd(this)\n\n data.stopped = true\n if (typeof data.event.stopPropagation === \"function\") {\n data.event.stopPropagation()\n }\n },\n\n /**\n * Stop event bubbling.\n * @returns {void}\n */\n stopImmediatePropagation() {\n const data = pd(this)\n\n data.stopped = true\n data.immediateStopped = true\n if (typeof data.event.stopImmediatePropagation === \"function\") {\n data.event.stopImmediatePropagation()\n }\n },\n\n /**\n * The flag to be bubbling.\n * @type {boolean}\n */\n get bubbles() {\n return Boolean(pd(this).event.bubbles)\n },\n\n /**\n * The flag to be cancelable.\n * @type {boolean}\n */\n get cancelable() {\n return Boolean(pd(this).event.cancelable)\n },\n\n /**\n * Cancel this event.\n * @returns {void}\n */\n preventDefault() {\n setCancelFlag(pd(this))\n },\n\n /**\n * The flag to indicate cancellation state.\n * @type {boolean}\n */\n get defaultPrevented() {\n return pd(this).canceled\n },\n\n /**\n * The flag to be composed.\n * @type {boolean}\n */\n get composed() {\n return Boolean(pd(this).event.composed)\n },\n\n /**\n * The unix time of this event.\n * @type {number}\n */\n get timeStamp() {\n return pd(this).timeStamp\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n * @deprecated\n */\n get srcElement() {\n return pd(this).eventTarget\n },\n\n /**\n * The flag to stop event bubbling.\n * @type {boolean}\n * @deprecated\n */\n get cancelBubble() {\n return pd(this).stopped\n },\n set cancelBubble(value) {\n if (!value) {\n return\n }\n const data = pd(this)\n\n data.stopped = true\n if (typeof data.event.cancelBubble === \"boolean\") {\n data.event.cancelBubble = true\n }\n },\n\n /**\n * The flag to indicate cancellation state.\n * @type {boolean}\n * @deprecated\n */\n get returnValue() {\n return !pd(this).canceled\n },\n set returnValue(value) {\n if (!value) {\n setCancelFlag(pd(this))\n }\n },\n\n /**\n * Initialize this event object. But do nothing under event dispatching.\n * @param {string} type The event type.\n * @param {boolean} [bubbles=false] The flag to be possible to bubble up.\n * @param {boolean} [cancelable=false] The flag to be possible to cancel.\n * @deprecated\n */\n initEvent() {\n // Do nothing.\n },\n}\n\n// `constructor` is not enumerable.\nObject.defineProperty(Event.prototype, \"constructor\", {\n value: Event,\n configurable: true,\n writable: true,\n})\n\n// Ensure `event instanceof window.Event` is `true`.\nif (typeof window !== \"undefined\" && typeof window.Event !== \"undefined\") {\n Object.setPrototypeOf(Event.prototype, window.Event.prototype)\n\n // Make association for wrappers.\n wrappers.set(window.Event.prototype, Event)\n}\n\n/**\n * Get the property descriptor to redirect a given property.\n * @param {string} key Property name to define property descriptor.\n * @returns {PropertyDescriptor} The property descriptor to redirect the property.\n * @private\n */\nfunction defineRedirectDescriptor(key) {\n return {\n get() {\n return pd(this).event[key]\n },\n set(value) {\n pd(this).event[key] = value\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Get the property descriptor to call a given method property.\n * @param {string} key Property name to define property descriptor.\n * @returns {PropertyDescriptor} The property descriptor to call the method property.\n * @private\n */\nfunction defineCallDescriptor(key) {\n return {\n value() {\n const event = pd(this).event\n return event[key].apply(event, arguments)\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Define new wrapper class.\n * @param {Function} BaseEvent The base wrapper class.\n * @param {Object} proto The prototype of the original event.\n * @returns {Function} The defined wrapper class.\n * @private\n */\nfunction defineWrapper(BaseEvent, proto) {\n const keys = Object.keys(proto)\n if (keys.length === 0) {\n return BaseEvent\n }\n\n /** CustomEvent */\n function CustomEvent(eventTarget, event) {\n BaseEvent.call(this, eventTarget, event)\n }\n\n CustomEvent.prototype = Object.create(BaseEvent.prototype, {\n constructor: { value: CustomEvent, configurable: true, writable: true },\n })\n\n // Define accessors.\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i]\n if (!(key in BaseEvent.prototype)) {\n const descriptor = Object.getOwnPropertyDescriptor(proto, key)\n const isFunc = typeof descriptor.value === \"function\"\n Object.defineProperty(\n CustomEvent.prototype,\n key,\n isFunc\n ? defineCallDescriptor(key)\n : defineRedirectDescriptor(key)\n )\n }\n }\n\n return CustomEvent\n}\n\n/**\n * Get the wrapper class of a given prototype.\n * @param {Object} proto The prototype of the original event to get its wrapper.\n * @returns {Function} The wrapper class.\n * @private\n */\nfunction getWrapper(proto) {\n if (proto == null || proto === Object.prototype) {\n return Event\n }\n\n let wrapper = wrappers.get(proto)\n if (wrapper == null) {\n wrapper = defineWrapper(getWrapper(Object.getPrototypeOf(proto)), proto)\n wrappers.set(proto, wrapper)\n }\n return wrapper\n}\n\n/**\n * Wrap a given event to management a dispatching.\n * @param {EventTarget} eventTarget The event target of this dispatching.\n * @param {Object} event The event to wrap.\n * @returns {Event} The wrapper instance.\n * @private\n */\nexport function wrapEvent(eventTarget, event) {\n const Wrapper = getWrapper(Object.getPrototypeOf(event))\n return new Wrapper(eventTarget, event)\n}\n\n/**\n * Get the immediateStopped flag of a given event.\n * @param {Event} event The event to get.\n * @returns {boolean} The flag to stop propagation immediately.\n * @private\n */\nexport function isStopped(event) {\n return pd(event).immediateStopped\n}\n\n/**\n * Set the current event phase of a given event.\n * @param {Event} event The event to set current target.\n * @param {number} eventPhase New event phase.\n * @returns {void}\n * @private\n */\nexport function setEventPhase(event, eventPhase) {\n pd(event).eventPhase = eventPhase\n}\n\n/**\n * Set the current target of a given event.\n * @param {Event} event The event to set current target.\n * @param {EventTarget|null} currentTarget New current target.\n * @returns {void}\n * @private\n */\nexport function setCurrentTarget(event, currentTarget) {\n pd(event).currentTarget = currentTarget\n}\n\n/**\n * Set a passive listener of a given event.\n * @param {Event} event The event to set current target.\n * @param {Function|null} passiveListener New passive listener.\n * @returns {void}\n * @private\n */\nexport function setPassiveListener(event, passiveListener) {\n pd(event).passiveListener = passiveListener\n}\n","import {\n isStopped,\n setCurrentTarget,\n setEventPhase,\n setPassiveListener,\n wrapEvent,\n} from \"./event.mjs\"\n\n/**\n * @typedef {object} ListenerNode\n * @property {Function} listener\n * @property {1|2|3} listenerType\n * @property {boolean} passive\n * @property {boolean} once\n * @property {ListenerNode|null} next\n * @private\n */\n\n/**\n * @type {WeakMap<object, Map<string, ListenerNode>>}\n * @private\n */\nconst listenersMap = new WeakMap()\n\n// Listener types\nconst CAPTURE = 1\nconst BUBBLE = 2\nconst ATTRIBUTE = 3\n\n/**\n * Check whether a given value is an object or not.\n * @param {any} x The value to check.\n * @returns {boolean} `true` if the value is an object.\n */\nfunction isObject(x) {\n return x !== null && typeof x === \"object\" //eslint-disable-line no-restricted-syntax\n}\n\n/**\n * Get listeners.\n * @param {EventTarget} eventTarget The event target to get.\n * @returns {Map<string, ListenerNode>} The listeners.\n * @private\n */\nfunction getListeners(eventTarget) {\n const listeners = listenersMap.get(eventTarget)\n if (listeners == null) {\n throw new TypeError(\n \"'this' is expected an EventTarget object, but got another value.\"\n )\n }\n return listeners\n}\n\n/**\n * Get the property descriptor for the event attribute of a given event.\n * @param {string} eventName The event name to get property descriptor.\n * @returns {PropertyDescriptor} The property descriptor.\n * @private\n */\nfunction defineEventAttributeDescriptor(eventName) {\n return {\n get() {\n const listeners = getListeners(this)\n let node = listeners.get(eventName)\n while (node != null) {\n if (node.listenerType === ATTRIBUTE) {\n return node.listener\n }\n node = node.next\n }\n return null\n },\n\n set(listener) {\n if (typeof listener !== \"function\" && !isObject(listener)) {\n listener = null // eslint-disable-line no-param-reassign\n }\n const listeners = getListeners(this)\n\n // Traverse to the tail while removing old value.\n let prev = null\n let node = listeners.get(eventName)\n while (node != null) {\n if (node.listenerType === ATTRIBUTE) {\n // Remove old value.\n if (prev !== null) {\n prev.next = node.next\n } else if (node.next !== null) {\n listeners.set(eventName, node.next)\n } else {\n listeners.delete(eventName)\n }\n } else {\n prev = node\n }\n\n node = node.next\n }\n\n // Add new value.\n if (listener !== null) {\n const newNode = {\n listener,\n listenerType: ATTRIBUTE,\n passive: false,\n once: false,\n next: null,\n }\n if (prev === null) {\n listeners.set(eventName, newNode)\n } else {\n prev.next = newNode\n }\n }\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Define an event attribute (e.g. `eventTarget.onclick`).\n * @param {Object} eventTargetPrototype The event target prototype to define an event attrbite.\n * @param {string} eventName The event name to define.\n * @returns {void}\n */\nfunction defineEventAttribute(eventTargetPrototype, eventName) {\n Object.defineProperty(\n eventTargetPrototype,\n `on${eventName}`,\n defineEventAttributeDescriptor(eventName)\n )\n}\n\n/**\n * Define a custom EventTarget with event attributes.\n * @param {string[]} eventNames Event names for event attributes.\n * @returns {EventTarget} The custom EventTarget.\n * @private\n */\nfunction defineCustomEventTarget(eventNames) {\n /** CustomEventTarget */\n function CustomEventTarget() {\n EventTarget.call(this)\n }\n\n CustomEventTarget.prototype = Object.create(EventTarget.prototype, {\n constructor: {\n value: CustomEventTarget,\n configurable: true,\n writable: true,\n },\n })\n\n for (let i = 0; i < eventNames.length; ++i) {\n defineEventAttribute(CustomEventTarget.prototype, eventNames[i])\n }\n\n return CustomEventTarget\n}\n\n/**\n * EventTarget.\n *\n * - This is constructor if no arguments.\n * - This is a function which returns a CustomEventTarget constructor if there are arguments.\n *\n * For example:\n *\n * class A extends EventTarget {}\n * class B extends EventTarget(\"message\") {}\n * class C extends EventTarget(\"message\", \"error\") {}\n * class D extends EventTarget([\"message\", \"error\"]) {}\n */\nfunction EventTarget() {\n /*eslint-disable consistent-return */\n if (this instanceof EventTarget) {\n listenersMap.set(this, new Map())\n return\n }\n if (arguments.length === 1 && Array.isArray(arguments[0])) {\n return defineCustomEventTarget(arguments[0])\n }\n if (arguments.length > 0) {\n const types = new Array(arguments.length)\n for (let i = 0; i < arguments.length; ++i) {\n types[i] = arguments[i]\n }\n return defineCustomEventTarget(types)\n }\n throw new TypeError(\"Cannot call a class as a function\")\n /*eslint-enable consistent-return */\n}\n\n// Should be enumerable, but class methods are not enumerable.\nEventTarget.prototype = {\n /**\n * Add a given listener to this event target.\n * @param {string} eventName The event name to add.\n * @param {Function} listener The listener to add.\n * @param {boolean|{capture?:boolean,passive?:boolean,once?:boolean}} [options] The options for this listener.\n * @returns {void}\n */\n addEventListener(eventName, listener, options) {\n if (listener == null) {\n return\n }\n if (typeof listener !== \"function\" && !isObject(listener)) {\n throw new TypeError(\"'listener' should be a function or an object.\")\n }\n\n const listeners = getListeners(this)\n const optionsIsObj = isObject(options)\n const capture = optionsIsObj\n ? Boolean(options.capture)\n : Boolean(options)\n const listenerType = capture ? CAPTURE : BUBBLE\n const newNode = {\n listener,\n listenerType,\n passive: optionsIsObj && Boolean(options.passive),\n once: optionsIsObj && Boolean(options.once),\n next: null,\n }\n\n // Set it as the first node if the first node is null.\n let node = listeners.get(eventName)\n if (node === undefined) {\n listeners.set(eventName, newNode)\n return\n }\n\n // Traverse to the tail while checking duplication..\n let prev = null\n while (node != null) {\n if (\n node.listener === listener &&\n node.listenerType === listenerType\n ) {\n // Should ignore duplication.\n return\n }\n prev = node\n node = node.next\n }\n\n // Add it.\n prev.next = newNode\n },\n\n /**\n * Remove a given listener from this event target.\n * @param {string} eventName The event name to remove.\n * @param {Function} listener The listener to remove.\n * @param {boolean|{capture?:boolean,passive?:boolean,once?:boolean}} [options] The options for this listener.\n * @returns {void}\n */\n removeEventListener(eventName, listener, options) {\n if (listener == null) {\n return\n }\n\n const listeners = getListeners(this)\n const capture = isObject(options)\n ? Boolean(options.capture)\n : Boolean(options)\n const listenerType = capture ? CAPTURE : BUBBLE\n\n let prev = null\n let node = listeners.get(eventName)\n while (node != null) {\n if (\n node.listener === listener &&\n node.listenerType === listenerType\n ) {\n if (prev !== null) {\n prev.next = node.next\n } else if (node.next !== null) {\n listeners.set(eventName, node.next)\n } else {\n listeners.delete(eventName)\n }\n return\n }\n\n prev = node\n node = node.next\n }\n },\n\n /**\n * Dispatch a given event.\n * @param {Event|{type:string}} event The event to dispatch.\n * @returns {boolean} `false` if canceled.\n */\n dispatchEvent(event) {\n if (event == null || typeof event.type !== \"string\") {\n throw new TypeError('\"event.type\" should be a string.')\n }\n\n // If listeners aren't registered, terminate.\n const listeners = getListeners(this)\n const eventName = event.type\n let node = listeners.get(eventName)\n if (node == null) {\n return true\n }\n\n // Since we cannot rewrite several properties, so wrap object.\n const wrappedEvent = wrapEvent(this, event)\n\n // This doesn't process capturing phase and bubbling phase.\n // This isn't participating in a tree.\n let prev = null\n while (node != null) {\n // Remove this listener if it's once\n if (node.once) {\n if (prev !== null) {\n prev.next = node.next\n } else if (node.next !== null) {\n listeners.set(eventName, node.next)\n } else {\n listeners.delete(eventName)\n }\n } else {\n prev = node\n }\n\n // Call this listener\n setPassiveListener(\n wrappedEvent,\n node.passive ? node.listener : null\n )\n if (typeof node.listener === \"function\") {\n try {\n node.listener.call(this, wrappedEvent)\n } catch (err) {\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(err)\n }\n }\n } else if (\n node.listenerType !== ATTRIBUTE &&\n typeof node.listener.handleEvent === \"function\"\n ) {\n node.listener.handleEvent(wrappedEvent)\n }\n\n // Break if `event.stopImmediatePropagation` was called.\n if (isStopped(wrappedEvent)) {\n break\n }\n\n node = node.next\n }\n setPassiveListener(wrappedEvent, null)\n setEventPhase(wrappedEvent, 0)\n setCurrentTarget(wrappedEvent, null)\n\n return !wrappedEvent.defaultPrevented\n },\n}\n\n// `constructor` is not enumerable.\nObject.defineProperty(EventTarget.prototype, \"constructor\", {\n value: EventTarget,\n configurable: true,\n writable: true,\n})\n\n// Ensure `eventTarget instanceof window.EventTarget` is `true`.\nif (\n typeof window !== \"undefined\" &&\n typeof window.EventTarget !== \"undefined\"\n) {\n Object.setPrototypeOf(EventTarget.prototype, window.EventTarget.prototype)\n}\n\nexport { defineEventAttribute, EventTarget }\nexport default EventTarget\n","import {\n // Event,\n EventTarget,\n // Type,\n defineEventAttribute,\n} from \"event-target-shim\"\n\n// Known Limitation\n// Use `any` because the type of `AbortSignal` in `lib.dom.d.ts` is wrong and\n// to make assignable our `AbortSignal` into that.\n// https://github.com/Microsoft/TSJS-lib-generator/pull/623\ntype Events = {\n abort: any // Event & Type<\"abort\">\n}\ntype EventAttributes = {\n onabort: any // Event & Type<\"abort\">\n}\n\n/**\n * The signal class.\n * @see https://dom.spec.whatwg.org/#abortsignal\n */\nexport default class AbortSignal extends EventTarget<Events, EventAttributes> {\n /**\n * AbortSignal cannot be constructed directly.\n */\n public constructor() {\n super()\n throw new TypeError(\"AbortSignal cannot be constructed directly\")\n }\n\n /**\n * Returns `true` if this `AbortSignal`'s `AbortController` has signaled to abort, and `false` otherwise.\n */\n public get aborted(): boolean {\n const aborted = abortedFlags.get(this)\n if (typeof aborted !== \"boolean\") {\n throw new TypeError(\n `Expected 'this' to be an 'AbortSignal' object, but got ${\n this === null ? \"null\" : typeof this\n }`,\n )\n }\n return aborted\n }\n}\ndefineEventAttribute(AbortSignal.prototype, \"abort\")\n\n/**\n * Create an AbortSignal object.\n */\nexport function createAbortSignal(): AbortSignal {\n const signal = Object.create(AbortSignal.prototype)\n EventTarget.call(signal)\n abortedFlags.set(signal, false)\n return signal\n}\n\n/**\n * Abort a given signal.\n */\nexport function abortSignal(signal: AbortSignal): void {\n if (abortedFlags.get(signal) !== false) {\n return\n }\n\n abortedFlags.set(signal, true)\n signal.dispatchEvent<\"abort\">({ type: \"abort\" })\n}\n\n/**\n * Aborted flag for each instances.\n */\nconst abortedFlags = new WeakMap<AbortSignal, boolean>()\n\n// Properties should be enumerable.\nObject.defineProperties(AbortSignal.prototype, {\n aborted: { enumerable: true },\n})\n\n// `toString()` should return `\"[object AbortSignal]\"`\nif (typeof Symbol === \"function\" && typeof Symbol.toStringTag === \"symbol\") {\n Object.defineProperty(AbortSignal.prototype, Symbol.toStringTag, {\n configurable: true,\n value: \"AbortSignal\",\n })\n}\n","import AbortSignal, { abortSignal, createAbortSignal } from \"./abort-signal\"\n\n/**\n * The AbortController.\n * @see https://dom.spec.whatwg.org/#abortcontroller\n */\nexport default class AbortController {\n /**\n * Initialize this controller.\n */\n public constructor() {\n signals.set(this, createAbortSignal())\n }\n\n /**\n * Returns the `AbortSignal` object associated with this object.\n */\n public get signal(): AbortSignal {\n return getSignal(this)\n }\n\n /**\n * Abort and signal to any observers that the associated activity is to be aborted.\n */\n public abort(): void {\n abortSignal(getSignal(this))\n }\n}\n\n/**\n * Associated signals.\n */\nconst signals = new WeakMap<AbortController, AbortSignal>()\n\n/**\n * Get the associated signal of a given controller.\n */\nfunction getSignal(controller: AbortController): AbortSignal {\n const signal = signals.get(controller)\n if (signal == null) {\n throw new TypeError(\n `Expected 'this' to be an 'AbortController' object, but got ${\n controller === null ? \"null\" : typeof controller\n }`,\n )\n }\n return signal\n}\n\n// Properties should be enumerable.\nObject.defineProperties(AbortController.prototype, {\n signal: { enumerable: true },\n abort: { enumerable: true },\n})\n\nif (typeof Symbol === \"function\" && typeof Symbol.toStringTag === \"symbol\") {\n Object.defineProperty(AbortController.prototype, Symbol.toStringTag, {\n configurable: true,\n value: \"AbortController\",\n })\n}\n\nexport { AbortController, AbortSignal }\n","'use strict'\n\nconst bufferModule = require('buffer')\nconst { kResistStopPropagation, SymbolDispose } = require('./primordials')\nconst AbortSignal = globalThis.AbortSignal || require('abort-controller').AbortSignal\nconst AbortController = globalThis.AbortController || require('abort-controller').AbortController\nconst AsyncFunction = Object.getPrototypeOf(async function () {}).constructor\nconst Blob = globalThis.Blob || bufferModule.Blob\n/* eslint-disable indent */\nconst isBlob =\n typeof Blob !== 'undefined'\n ? function isBlob(b) {\n // eslint-disable-next-line indent\n return b instanceof Blob\n }\n : function isBlob(b) {\n return false\n }\n/* eslint-enable indent */\n\nconst validateAbortSignal = (signal, name) => {\n if (signal !== undefined && (signal === null || typeof signal !== 'object' || !('aborted' in signal))) {\n throw new ERR_INVALID_ARG_TYPE(name, 'AbortSignal', signal)\n }\n}\nconst validateFunction = (value, name) => {\n if (typeof value !== 'function') throw new ERR_INVALID_ARG_TYPE(name, 'Function', value)\n}\n\n// This is a simplified version of AggregateError\nclass AggregateError extends Error {\n constructor(errors) {\n if (!Array.isArray(errors)) {\n throw new TypeError(`Expected input to be an Array, got ${typeof errors}`)\n }\n let message = ''\n for (let i = 0; i < errors.length; i++) {\n message += ` ${errors[i].stack}\\n`\n }\n super(message)\n this.name = 'AggregateError'\n this.errors = errors\n }\n}\nmodule.exports = {\n AggregateError,\n kEmptyObject: Object.freeze({}),\n once(callback) {\n let called = false\n return function (...args) {\n if (called) {\n return\n }\n called = true\n callback.apply(this, args)\n }\n },\n createDeferredPromise: function () {\n let resolve\n let reject\n\n // eslint-disable-next-line promise/param-names\n const promise = new Promise((res, rej) => {\n resolve = res\n reject = rej\n })\n return {\n promise,\n resolve,\n reject\n }\n },\n promisify(fn) {\n return new Promise((resolve, reject) => {\n fn((err, ...args) => {\n if (err) {\n return reject(err)\n }\n return resolve(...args)\n })\n })\n },\n debuglog() {\n return function () {}\n },\n format(format, ...args) {\n // Simplified version of https://nodejs.org/api/util.html#utilformatformat-args\n return format.replace(/%([sdifj])/g, function (...[_unused, type]) {\n const replacement = args.shift()\n if (type === 'f') {\n return replacement.toFixed(6)\n } else if (type === 'j') {\n return JSON.stringify(replacement)\n } else if (type === 's' && typeof replacement === 'object') {\n const ctor = replacement.constructor !== Object ? replacement.constructor.name : ''\n return `${ctor} {}`.trim()\n } else {\n return replacement.toString()\n }\n })\n },\n inspect(value) {\n // Vastly simplified version of https://nodejs.org/api/util.html#utilinspectobject-options\n switch (typeof value) {\n case 'string':\n if (value.includes(\"'\")) {\n if (!value.includes('\"')) {\n return `\"${value}\"`\n } else if (!value.includes('`') && !value.includes('${')) {\n return `\\`${value}\\``\n }\n }\n return `'${value}'`\n case 'number':\n if (isNaN(value)) {\n return 'NaN'\n } else if (Object.is(value, -0)) {\n return String(value)\n }\n return value\n case 'bigint':\n return `${String(value)}n`\n case 'boolean':\n case 'undefined':\n return String(value)\n case 'object':\n return '{}'\n }\n },\n types: {\n isAsyncFunction(fn) {\n return fn instanceof AsyncFunction\n },\n isArrayBufferView(arr) {\n return ArrayBuffer.isView(arr)\n }\n },\n isBlob,\n deprecate(fn, message) {\n return fn\n },\n addAbortListener:\n require('events').addAbortListener ||\n function addAbortListener(signal, listener) {\n if (signal === undefined) {\n throw new ERR_INVALID_ARG_TYPE('signal', 'AbortSignal', signal)\n }\n validateAbortSignal(signal, 'signal')\n validateFunction(listener, 'listener')\n let removeEventListener\n if (signal.aborted) {\n queueMicrotask(() => listener())\n } else {\n signal.addEventListener('abort', listener, {\n __proto__: null,\n once: true,\n [kResistStopPropagation]: true\n })\n removeEventListener = () => {\n signal.removeEventListener('abort', listener)\n }\n }\n return {\n __proto__: null,\n [SymbolDispose]() {\n var _removeEventListener\n ;(_removeEventListener = removeEventListener) === null || _removeEventListener === undefined\n ? undefined\n : _removeEventListener()\n }\n }\n },\n AbortSignalAny:\n AbortSignal.any ||\n function AbortSignalAny(signals) {\n // Fast path if there is only one signal.\n if (signals.length === 1) {\n return signals[0]\n }\n const ac = new AbortController()\n const abort = () => ac.abort()\n signals.forEach((signal) => {\n validateAbortSignal(signal, 'signals')\n signal.addEventListener('abort', abort, {\n once: true\n })\n })\n ac.signal.addEventListener(\n 'abort',\n () => {\n signals.forEach((signal) => signal.removeEventListener('abort', abort))\n },\n {\n once: true\n }\n )\n return ac.signal\n }\n}\nmodule.exports.promisify.custom = Symbol.for('nodejs.util.promisify.custom')\n","'use strict'\n\nconst { format, inspect, AggregateError: CustomAggregateError } = require('./util')\n\n/*\n This file is a reduced and adapted version of the main lib/internal/errors.js file defined at\n\n https://github.com/nodejs/node/blob/master/lib/internal/errors.js\n\n Don't try to replace with the original file and keep it up to date (starting from E(...) definitions)\n with the upstream file.\n*/\n\nconst AggregateError = globalThis.AggregateError || CustomAggregateError\nconst kIsNodeError = Symbol('kIsNodeError')\nconst kTypes = [\n 'string',\n 'function',\n 'number',\n 'object',\n // Accept 'Function' and 'Object' as alternative to the lower cased version.\n 'Function',\n 'Object',\n 'boolean',\n 'bigint',\n 'symbol'\n]\nconst classRegExp = /^([A-Z][a-z0-9]*)+$/\nconst nodeInternalPrefix = '__node_internal_'\nconst codes = {}\nfunction assert(value, message) {\n if (!value) {\n throw new codes.ERR_INTERNAL_ASSERTION(message)\n }\n}\n\n// Only use this for integers! Decimal numbers do not work with this function.\nfunction addNumericalSeparator(val) {\n let res = ''\n let i = val.length\n const start = val[0] === '-' ? 1 : 0\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`\n }\n return `${val.slice(0, i)}${res}`\n}\nfunction getMessage(key, msg, args) {\n if (typeof msg === 'function') {\n assert(\n msg.length <= args.length,\n // Default options do not count.\n `Code: ${key}; The provided arguments length (${args.length}) does not match the required ones (${msg.length}).`\n )\n return msg(...args)\n }\n const expectedLength = (msg.match(/%[dfijoOs]/g) || []).length\n assert(\n expectedLength === args.length,\n `Code: ${key}; The provided arguments length (${args.length}) does not match the required ones (${expectedLength}).`\n )\n if (args.length === 0) {\n return msg\n }\n return format(msg, ...args)\n}\nfunction E(code, message, Base) {\n if (!Base) {\n Base = Error\n }\n class NodeError extends Base {\n constructor(...args) {\n super(getMessage(code, message, args))\n }\n toString() {\n return `${this.name} [${code}]: ${this.message}`\n }\n }\n Object.defineProperties(NodeError.prototype, {\n name: {\n value: Base.name,\n writable: true,\n enumerable: false,\n configurable: true\n },\n toString: {\n value() {\n return `${this.name} [${code}]: ${this.message}`\n },\n writable: true,\n enumerable: false,\n configurable: true\n }\n })\n NodeError.prototype.code = code\n NodeError.prototype[kIsNodeError] = true\n codes[code] = NodeError\n}\nfunction hideStackFrames(fn) {\n // We rename the functions that will be hidden to cut off the stacktrace\n // at the outermost one\n const hidden = nodeInternalPrefix + fn.name\n Object.defineProperty(fn, 'name', {\n value: hidden\n })\n return fn\n}\nfunction aggregateTwoErrors(innerError, outerError) {\n if (innerError && outerError && innerError !== outerError) {\n if (Array.isArray(outerError.errors)) {\n // If `outerError` is already an `AggregateError`.\n outerError.errors.push(innerError)\n return outerError\n }\n const err = new AggregateError([outerError, innerError], outerError.message)\n err.code = outerError.code\n return err\n }\n return innerError || outerError\n}\nclass AbortError extends Error {\n constructor(message = 'The operation was aborted', options = undefined) {\n if (options !== undefined && typeof options !== 'object') {\n throw new codes.ERR_INVALID_ARG_TYPE('options', 'Object', options)\n }\n super(message, options)\n this.code = 'ABORT_ERR'\n this.name = 'AbortError'\n }\n}\nE('ERR_ASSERTION', '%s', Error)\nE(\n 'ERR_INVALID_ARG_TYPE',\n (name, expected, actual) => {\n assert(typeof name === 'string', \"'name' must be a string\")\n if (!Array.isArray(expected)) {\n expected = [expected]\n }\n let msg = 'The '\n if (name.endsWith(' argument')) {\n // For cases like 'first argument'\n msg += `${name} `\n } else {\n msg += `\"${name}\" ${name.includes('.') ? 'property' : 'argument'} `\n }\n msg += 'must be '\n const types = []\n const instances = []\n const other = []\n for (const value of expected) {\n assert(typeof value === 'string', 'All expected entries have to be of type string')\n if (kTypes.includes(value)) {\n types.push(value.toLowerCase())\n } else if (classRegExp.test(value)) {\n instances.push(value)\n } else {\n assert(value !== 'object', 'The value \"object\" should be written as \"Object\"')\n other.push(value)\n }\n }\n\n // Special handle `object` in case other instances are allowed to outline\n // the differences between each other.\n if (instances.length > 0) {\n const pos = types.indexOf('object')\n if (pos !== -1) {\n types.splice(types, pos, 1)\n instances.push('Object')\n }\n }\n if (types.length > 0) {\n switch (types.length) {\n case 1:\n msg += `of type ${types[0]}`\n break\n case 2:\n msg += `one of type ${types[0]} or ${types[1]}`\n break\n default: {\n const last = types.pop()\n msg += `one of type ${types.join(', ')}, or ${last}`\n }\n }\n if (instances.length > 0 || other.length > 0) {\n msg += ' or '\n }\n }\n if (instances.length > 0) {\n switch (instances.length) {\n case 1:\n msg += `an instance of ${instances[0]}`\n break\n case 2:\n msg += `an instance of ${instances[0]} or ${instances[1]}`\n break\n default: {\n const last = instances.pop()\n msg += `an instance of ${instances.join(', ')}, or ${last}`\n }\n }\n if (other.length > 0) {\n msg += ' or '\n }\n }\n switch (other.length) {\n case 0:\n break\n case 1:\n if (other[0].toLowerCase() !== other[0]) {\n msg += 'an '\n }\n msg += `${other[0]}`\n break\n case 2:\n msg += `one of ${other[0]} or ${other[1]}`\n break\n default: {\n const last = other.pop()\n msg += `one of ${other.join(', ')}, or ${last}`\n }\n }\n if (actual == null) {\n msg += `. Received ${actual}`\n } else if (typeof actual === 'function' && actual.name) {\n msg += `. Received function ${actual.name}`\n } else if (typeof actual === 'object') {\n var _actual$constructor\n if (\n (_actual$constructor = actual.constructor) !== null &&\n _actual$constructor !== undefined &&\n _actual$constructor.name\n ) {\n msg += `. Received an instance of ${actual.constructor.name}`\n } else {\n const inspected = inspect(actual, {\n depth: -1\n })\n msg += `. Received ${inspected}`\n }\n } else {\n let inspected = inspect(actual, {\n colors: false\n })\n if (inspected.length > 25) {\n inspected = `${inspected.slice(0, 25)}...`\n }\n msg += `. Received type ${typeof actual} (${inspected})`\n }\n return msg\n },\n TypeError\n)\nE(\n 'ERR_INVALID_ARG_VALUE',\n (name, value, reason = 'is invalid') => {\n let inspected = inspect(value)\n if (inspected.length > 128) {\n inspected = inspected.slice(0, 128) + '...'\n }\n const type = name.includes('.') ? 'property' : 'argument'\n return `The ${type} '${name}' ${reason}. Received ${inspected}`\n },\n TypeError\n)\nE(\n 'ERR_INVALID_RETURN_VALUE',\n (input, name, value) => {\n var _value$constructor\n const type =\n value !== null &&\n value !== undefined &&\n (_value$constructor = value.constructor) !== null &&\n _value$constructor !== undefined &&\n _value$constructor.name\n ? `instance of ${value.constructor.name}`\n : `type ${typeof value}`\n return `Expected ${input} to be returned from the \"${name}\"` + ` function but got ${type}.`\n },\n TypeError\n)\nE(\n 'ERR_MISSING_ARGS',\n (...args) => {\n assert(args.length > 0, 'At least one arg needs to be specified')\n let msg\n const len = args.length\n args = (Array.isArray(args) ? args : [args]).map((a) => `\"${a}\"`).join(' or ')\n switch (len) {\n case 1:\n msg += `The ${args[0]} argument`\n break\n case 2:\n msg += `The ${args[0]} and ${args[1]} arguments`\n break\n default:\n {\n const last = args.pop()\n msg += `The ${args.join(', ')}, and ${last} arguments`\n }\n break\n }\n return `${msg} must be specified`\n },\n TypeError\n)\nE(\n 'ERR_OUT_OF_RANGE',\n (str, range, input) => {\n assert(range, 'Missing \"range\" argument')\n let received\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input))\n } else if (typeof input === 'bigint') {\n received = String(input)\n if (input > 2n ** 32n || input < -(2n ** 32n)) {\n received = addNumericalSeparator(received)\n }\n received += 'n'\n } else {\n received = inspect(input)\n }\n return `The value of \"${str}\" is out of range. It must be ${range}. Received ${received}`\n },\n RangeError\n)\nE('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times', Error)\nE('ERR_METHOD_NOT_IMPLEMENTED', 'The %s method is not implemented', Error)\nE('ERR_STREAM_ALREADY_FINISHED', 'Cannot call %s after a stream was finished', Error)\nE('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable', Error)\nE('ERR_STREAM_DESTROYED', 'Cannot call %s after a stream was destroyed', Error)\nE('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError)\nE('ERR_STREAM_PREMATURE_CLOSE', 'Premature close', Error)\nE('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF', Error)\nE('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event', Error)\nE('ERR_STREAM_WRITE_AFTER_END', 'write after end', Error)\nE('ERR_UNKNOWN_ENCODING', 'Unknown encoding: %s', TypeError)\nmodule.exports = {\n AbortError,\n aggregateTwoErrors: hideStackFrames(aggregateTwoErrors),\n hideStackFrames,\n codes\n}\n","/* eslint jsdoc/require-jsdoc: \"error\" */\n\n'use strict'\n\nconst {\n ArrayIsArray,\n ArrayPrototypeIncludes,\n ArrayPrototypeJoin,\n ArrayPrototypeMap,\n NumberIsInteger,\n NumberIsNaN,\n NumberMAX_SAFE_INTEGER,\n NumberMIN_SAFE_INTEGER,\n NumberParseInt,\n ObjectPrototypeHasOwnProperty,\n RegExpPrototypeExec,\n String,\n StringPrototypeToUpperCase,\n StringPrototypeTrim\n} = require('../ours/primordials')\nconst {\n hideStackFrames,\n codes: { ERR_SOCKET_BAD_PORT, ERR_INVALID_ARG_TYPE, ERR_INVALID_ARG_VALUE, ERR_OUT_OF_RANGE, ERR_UNKNOWN_SIGNAL }\n} = require('../ours/errors')\nconst { normalizeEncoding } = require('../ours/util')\nconst { isAsyncFunction, isArrayBufferView } = require('../ours/util').types\nconst signals = {}\n\n/**\n * @param {*} value\n * @returns {boolean}\n */\nfunction isInt32(value) {\n return value === (value | 0)\n}\n\n/**\n * @param {*} value\n * @returns {boolean}\n */\nfunction isUint32(value) {\n return value === value >>> 0\n}\nconst octalReg = /^[0-7]+$/\nconst modeDesc = 'must be a 32-bit unsigned integer or an octal string'\n\n/**\n * Parse and validate values that will be converted into mode_t (the S_*\n * constants). Only valid numbers and octal strings are allowed. They could be\n * converted to 32-bit unsigned integers or non-negative signed integers in the\n * C++ land, but any value higher than 0o777 will result in platform-specific\n * behaviors.\n * @param {*} value Values to be validated\n * @param {string} name Name of the argument\n * @param {number} [def] If specified, will be returned for invalid values\n * @returns {number}\n */\nfunction parseFileMode(value, name, def) {\n if (typeof value === 'undefined') {\n value = def\n }\n if (typeof value === 'string') {\n if (RegExpPrototypeExec(octalReg, value) === null) {\n throw new ERR_INVALID_ARG_VALUE(name, value, modeDesc)\n }\n value = NumberParseInt(value, 8)\n }\n validateUint32(value, name)\n return value\n}\n\n/**\n * @callback validateInteger\n * @param {*} value\n * @param {string} name\n * @param {number} [min]\n * @param {number} [max]\n * @returns {asserts value is number}\n */\n\n/** @type {validateInteger} */\nconst validateInteger = hideStackFrames((value, name, min = NumberMIN_SAFE_INTEGER, max = NumberMAX_SAFE_INTEGER) => {\n if (typeof value !== 'number') throw new ERR_INVALID_ARG_TYPE(name, 'number', value)\n if (!NumberIsInteger(value)) throw new ERR_OUT_OF_RANGE(name, 'an integer', value)\n if (value < min || value > max) throw new ERR_OUT_OF_RANGE(name, `>= ${min} && <= ${max}`, value)\n})\n\n/**\n * @callback validateInt32\n * @param {*} value\n * @param {string} name\n * @param {number} [min]\n * @param {number} [max]\n * @returns {asserts value is number}\n */\n\n/** @type {validateInt32} */\nconst validateInt32 = hideStackFrames((value, name, min = -2147483648, max = 2147483647) => {\n // The defaults for min and max correspond to the limits of 32-bit integers.\n if (typeof value !== 'number') {\n throw new ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n if (!NumberIsInteger(value)) {\n throw new ERR_OUT_OF_RANGE(name, 'an integer', value)\n }\n if (value < min || value > max) {\n throw new ERR_OUT_OF_RANGE(name, `>= ${min} && <= ${max}`, value)\n }\n})\n\n/**\n * @callback validateUint32\n * @param {*} value\n * @param {string} name\n * @param {number|boolean} [positive=false]\n * @returns {asserts value is number}\n */\n\n/** @type {validateUint32} */\nconst validateUint32 = hideStackFrames((value, name, positive = false) => {\n if (typeof value !== 'number') {\n throw new ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n if (!NumberIsInteger(value)) {\n throw new ERR_OUT_OF_RANGE(name, 'an integer', value)\n }\n const min = positive ? 1 : 0\n // 2 ** 32 === 4294967296\n const max = 4294967295\n if (value < min || value > max) {\n throw new ERR_OUT_OF_RANGE(name, `>= ${min} && <= ${max}`, value)\n }\n})\n\n/**\n * @callback validateString\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is string}\n */\n\n/** @type {validateString} */\nfunction validateString(value, name) {\n if (typeof value !== 'string') throw new ERR_INVALID_ARG_TYPE(name, 'string', value)\n}\n\n/**\n * @callback validateNumber\n * @param {*} value\n * @param {string} name\n * @param {number} [min]\n * @param {number} [max]\n * @returns {asserts value is number}\n */\n\n/** @type {validateNumber} */\nfunction validateNumber(value, name, min = undefined, max) {\n if (typeof value !== 'number') throw new ERR_INVALID_ARG_TYPE(name, 'number', value)\n if (\n (min != null && value < min) ||\n (max != null && value > max) ||\n ((min != null || max != null) && NumberIsNaN(value))\n ) {\n throw new ERR_OUT_OF_RANGE(\n name,\n `${min != null ? `>= ${min}` : ''}${min != null && max != null ? ' && ' : ''}${max != null ? `<= ${max}` : ''}`,\n value\n )\n }\n}\n\n/**\n * @callback validateOneOf\n * @template T\n * @param {T} value\n * @param {string} name\n * @param {T[]} oneOf\n */\n\n/** @type {validateOneOf} */\nconst validateOneOf = hideStackFrames((value, name, oneOf) => {\n if (!ArrayPrototypeIncludes(oneOf, value)) {\n const allowed = ArrayPrototypeJoin(\n ArrayPrototypeMap(oneOf, (v) => (typeof v === 'string' ? `'${v}'` : String(v))),\n ', '\n )\n const reason = 'must be one of: ' + allowed\n throw new ERR_INVALID_ARG_VALUE(name, value, reason)\n }\n})\n\n/**\n * @callback validateBoolean\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is boolean}\n */\n\n/** @type {validateBoolean} */\nfunction validateBoolean(value, name) {\n if (typeof value !== 'boolean') throw new ERR_INVALID_ARG_TYPE(name, 'boolean', value)\n}\n\n/**\n * @param {any} options\n * @param {string} key\n * @param {boolean} defaultValue\n * @returns {boolean}\n */\nfunction getOwnPropertyValueOrDefault(options, key, defaultValue) {\n return options == null || !ObjectPrototypeHasOwnProperty(options, key) ? defaultValue : options[key]\n}\n\n/**\n * @callback validateObject\n * @param {*} value\n * @param {string} name\n * @param {{\n * allowArray?: boolean,\n * allowFunction?: boolean,\n * nullable?: boolean\n * }} [options]\n */\n\n/** @type {validateObject} */\nconst validateObject = hideStackFrames((value, name, options = null) => {\n const allowArray = getOwnPropertyValueOrDefault(options, 'allowArray', false)\n const allowFunction = getOwnPropertyValueOrDefault(options, 'allowFunction', false)\n const nullable = getOwnPropertyValueOrDefault(options, 'nullable', false)\n if (\n (!nullable && value === null) ||\n (!allowArray && ArrayIsArray(value)) ||\n (typeof value !== 'object' && (!allowFunction || typeof value !== 'function'))\n ) {\n throw new ERR_INVALID_ARG_TYPE(name, 'Object', value)\n }\n})\n\n/**\n * @callback validateDictionary - We are using the Web IDL Standard definition\n * of \"dictionary\" here, which means any value\n * whose Type is either Undefined, Null, or\n * Object (which includes functions).\n * @param {*} value\n * @param {string} name\n * @see https://webidl.spec.whatwg.org/#es-dictionary\n * @see https://tc39.es/ecma262/#table-typeof-operator-results\n */\n\n/** @type {validateDictionary} */\nconst validateDictionary = hideStackFrames((value, name) => {\n if (value != null && typeof value !== 'object' && typeof value !== 'function') {\n throw new ERR_INVALID_ARG_TYPE(name, 'a dictionary', value)\n }\n})\n\n/**\n * @callback validateArray\n * @param {*} value\n * @param {string} name\n * @param {number} [minLength]\n * @returns {asserts value is any[]}\n */\n\n/** @type {validateArray} */\nconst validateArray = hideStackFrames((value, name, minLength = 0) => {\n if (!ArrayIsArray(value)) {\n throw new ERR_INVALID_ARG_TYPE(name, 'Array', value)\n }\n if (value.length < minLength) {\n const reason = `must be longer than ${minLength}`\n throw new ERR_INVALID_ARG_VALUE(name, value, reason)\n }\n})\n\n/**\n * @callback validateStringArray\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is string[]}\n */\n\n/** @type {validateStringArray} */\nfunction validateStringArray(value, name) {\n validateArray(value, name)\n for (let i = 0; i < value.length; i++) {\n validateString(value[i], `${name}[${i}]`)\n }\n}\n\n/**\n * @callback validateBooleanArray\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is boolean[]}\n */\n\n/** @type {validateBooleanArray} */\nfunction validateBooleanArray(value, name) {\n validateArray(value, name)\n for (let i = 0; i < value.length; i++) {\n validateBoolean(value[i], `${name}[${i}]`)\n }\n}\n\n/**\n * @callback validateAbortSignalArray\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is AbortSignal[]}\n */\n\n/** @type {validateAbortSignalArray} */\nfunction validateAbortSignalArray(value, name) {\n validateArray(value, name)\n for (let i = 0; i < value.length; i++) {\n const signal = value[i]\n const indexedName = `${name}[${i}]`\n if (signal == null) {\n throw new ERR_INVALID_ARG_TYPE(indexedName, 'AbortSignal', signal)\n }\n validateAbortSignal(signal, indexedName)\n }\n}\n\n/**\n * @param {*} signal\n * @param {string} [name='signal']\n * @returns {asserts signal is keyof signals}\n */\nfunction validateSignalName(signal, name = 'signal') {\n validateString(signal, name)\n if (signals[signal] === undefined) {\n if (signals[StringPrototypeToUpperCase(signal)] !== undefined) {\n throw new ERR_UNKNOWN_SIGNAL(signal + ' (signals must use all capital letters)')\n }\n throw new ERR_UNKNOWN_SIGNAL(signal)\n }\n}\n\n/**\n * @callback validateBuffer\n * @param {*} buffer\n * @param {string} [name='buffer']\n * @returns {asserts buffer is ArrayBufferView}\n */\n\n/** @type {validateBuffer} */\nconst validateBuffer = hideStackFrames((buffer, name = 'buffer') => {\n if (!isArrayBufferView(buffer)) {\n throw new ERR_INVALID_ARG_TYPE(name, ['Buffer', 'TypedArray', 'DataView'], buffer)\n }\n})\n\n/**\n * @param {string} data\n * @param {string} encoding\n */\nfunction validateEncoding(data, encoding) {\n const normalizedEncoding = normalizeEncoding(encoding)\n const length = data.length\n if (normalizedEncoding === 'hex' && length % 2 !== 0) {\n throw new ERR_INVALID_ARG_VALUE('encoding', encoding, `is invalid for data of length ${length}`)\n }\n}\n\n/**\n * Check that the port number is not NaN when coerced to a number,\n * is an integer and that it falls within the legal range of port numbers.\n * @param {*} port\n * @param {string} [name='Port']\n * @param {boolean} [allowZero=true]\n * @returns {number}\n */\nfunction validatePort(port, name = 'Port', allowZero = true) {\n if (\n (typeof port !== 'number' && typeof port !== 'string') ||\n (typeof port === 'string' && StringPrototypeTrim(port).length === 0) ||\n +port !== +port >>> 0 ||\n port > 0xffff ||\n (port === 0 && !allowZero)\n ) {\n throw new ERR_SOCKET_BAD_PORT(name, port, allowZero)\n }\n return port | 0\n}\n\n/**\n * @callback validateAbortSignal\n * @param {*} signal\n * @param {string} name\n */\n\n/** @type {validateAbortSignal} */\nconst validateAbortSignal = hideStackFrames((signal, name) => {\n if (signal !== undefined && (signal === null || typeof signal !== 'object' || !('aborted' in signal))) {\n throw new ERR_INVALID_ARG_TYPE(name, 'AbortSignal', signal)\n }\n})\n\n/**\n * @callback validateFunction\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is Function}\n */\n\n/** @type {validateFunction} */\nconst validateFunction = hideStackFrames((value, name) => {\n if (typeof value !== 'function') throw new ERR_INVALID_ARG_TYPE(name, 'Function', value)\n})\n\n/**\n * @callback validatePlainFunction\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is Function}\n */\n\n/** @type {validatePlainFunction} */\nconst validatePlainFunction = hideStackFrames((value, name) => {\n if (typeof value !== 'function' || isAsyncFunction(value)) throw new ERR_INVALID_ARG_TYPE(name, 'Function', value)\n})\n\n/**\n * @callback validateUndefined\n * @param {*} value\n * @param {string} name\n * @returns {asserts value is undefined}\n */\n\n/** @type {validateUndefined} */\nconst validateUndefined = hideStackFrames((value, name) => {\n if (value !== undefined) throw new ERR_INVALID_ARG_TYPE(name, 'undefined', value)\n})\n\n/**\n * @template T\n * @param {T} value\n * @param {string} name\n * @param {T[]} union\n */\nfunction validateUnion(value, name, union) {\n if (!ArrayPrototypeIncludes(union, value)) {\n throw new ERR_INVALID_ARG_TYPE(name, `('${ArrayPrototypeJoin(union, '|')}')`, value)\n }\n}\n\n/*\n The rules for the Link header field are described here:\n https://www.rfc-editor.org/rfc/rfc8288.html#section-3\n\n This regex validates any string surrounded by angle brackets\n (not necessarily a valid URI reference) followed by zero or more\n link-params separated by semicolons.\n*/\nconst linkValueRegExp = /^(?:<[^>]*>)(?:\\s*;\\s*[^;\"\\s]+(?:=(\")?[^;\"\\s]*\\1)?)*$/\n\n/**\n * @param {any} value\n * @param {string} name\n */\nfunction validateLinkHeaderFormat(value, name) {\n if (typeof value === 'undefined' || !RegExpPrototypeExec(linkValueRegExp, value)) {\n throw new ERR_INVALID_ARG_VALUE(\n name,\n value,\n 'must be an array or string of format \"</styles.css>; rel=preload; as=style\"'\n )\n }\n}\n\n/**\n * @param {any} hints\n * @return {string}\n */\nfunction validateLinkHeaderValue(hints) {\n if (typeof hints === 'string') {\n validateLinkHeaderFormat(hints, 'hints')\n return hints\n } else if (ArrayIsArray(hints)) {\n const hintsLength = hints.length\n let result = ''\n if (hintsLength === 0) {\n return result\n }\n for (let i = 0; i < hintsLength; i++) {\n const link = hints[i]\n validateLinkHeaderFormat(link, 'hints')\n result += link\n if (i !== hintsLength - 1) {\n result += ', '\n }\n }\n return result\n }\n throw new ERR_INVALID_ARG_VALUE(\n 'hints',\n hints,\n 'must be an array or string of format \"</styles.css>; rel=preload; as=style\"'\n )\n}\nmodule.exports = {\n isInt32,\n isUint32,\n parseFileMode,\n validateArray,\n validateStringArray,\n validateBooleanArray,\n validateAbortSignalArray,\n validateBoolean,\n validateBuffer,\n validateDictionary,\n validateEncoding,\n validateFunction,\n validateInt32,\n validateInteger,\n validateNumber,\n validateObject,\n validateOneOf,\n validatePlainFunction,\n validatePort,\n validateSignalName,\n validateString,\n validateUint32,\n validateUndefined,\n validateUnion,\n validateAbortSignal,\n validateLinkHeaderValue\n}\n","// for now just expose the builtin process global from node.js\nmodule.exports = global.process;\n","'use strict'\n\nconst { SymbolAsyncIterator, SymbolIterator, SymbolFor } = require('../../ours/primordials')\n\n// We need to use SymbolFor to make these globally available\n// for interopt with readable-stream, i.e. readable-stream\n// and node core needs to be able to read/write private state\n// from each other for proper interoperability.\nconst kIsDestroyed = SymbolFor('nodejs.stream.destroyed')\nconst kIsErrored = SymbolFor('nodejs.stream.errored')\nconst kIsReadable = SymbolFor('nodejs.stream.readable')\nconst kIsWritable = SymbolFor('nodejs.stream.writable')\nconst kIsDisturbed = SymbolFor('nodejs.stream.disturbed')\nconst kIsClosedPromise = SymbolFor('nodejs.webstream.isClosedPromise')\nconst kControllerErrorFunction = SymbolFor('nodejs.webstream.controllerErrorFunction')\nfunction isReadableNodeStream(obj, strict = false) {\n var _obj$_readableState\n return !!(\n (\n obj &&\n typeof obj.pipe === 'function' &&\n typeof obj.on === 'function' &&\n (!strict || (typeof obj.pause === 'function' && typeof obj.resume === 'function')) &&\n (!obj._writableState ||\n ((_obj$_readableState = obj._readableState) === null || _obj$_readableState === undefined\n ? undefined\n : _obj$_readableState.readable) !== false) &&\n // Duplex\n (!obj._writableState || obj._readableState)\n ) // Writable has .pipe.\n )\n}\n\nfunction isWritableNodeStream(obj) {\n var _obj$_writableState\n return !!(\n (\n obj &&\n typeof obj.write === 'function' &&\n typeof obj.on === 'function' &&\n (!obj._readableState ||\n ((_obj$_writableState = obj._writableState) === null || _obj$_writableState === undefined\n ? undefined\n : _obj$_writableState.writable) !== false)\n ) // Duplex\n )\n}\n\nfunction isDuplexNodeStream(obj) {\n return !!(\n obj &&\n typeof obj.pipe === 'function' &&\n obj._readableState &&\n typeof obj.on === 'function' &&\n typeof obj.write === 'function'\n )\n}\nfunction isNodeStream(obj) {\n return (\n obj &&\n (obj._readableState ||\n obj._writableState ||\n (typeof obj.write === 'function' && typeof obj.on === 'function') ||\n (typeof obj.pipe === 'function' && typeof obj.on === 'function'))\n )\n}\nfunction isReadableStream(obj) {\n return !!(\n obj &&\n !isNodeStream(obj) &&\n typeof obj.pipeThrough === 'function' &&\n typeof obj.getReader === 'function' &&\n typeof obj.cancel === 'function'\n )\n}\nfunction isWritableStream(obj) {\n return !!(obj && !isNodeStream(obj) && typeof obj.getWriter === 'function' && typeof obj.abort === 'function')\n}\nfunction isTransformStream(obj) {\n return !!(obj && !isNodeStream(obj) && typeof obj.readable === 'object' && typeof obj.writable === 'object')\n}\nfunction isWebStream(obj) {\n return isReadableStream(obj) || isWritableStream(obj) || isTransformStream(obj)\n}\nfunction isIterable(obj, isAsync) {\n if (obj == null) return false\n if (isAsync === true) return typeof obj[SymbolAsyncIterator] === 'function'\n if (isAsync === false) return typeof obj[SymbolIterator] === 'function'\n return typeof obj[SymbolAsyncIterator] === 'function' || typeof obj[SymbolIterator] === 'function'\n}\nfunction isDestroyed(stream) {\n if (!isNodeStream(stream)) return null\n const wState = stream._writableState\n const rState = stream._readableState\n const state = wState || rState\n return !!(stream.destroyed || stream[kIsDestroyed] || (state !== null && state !== undefined && state.destroyed))\n}\n\n// Have been end():d.\nfunction isWritableEnded(stream) {\n if (!isWritableNodeStream(stream)) return null\n if (stream.writableEnded === true) return true\n const wState = stream._writableState\n if (wState !== null && wState !== undefined && wState.errored) return false\n if (typeof (wState === null || wState === undefined ? undefined : wState.ended) !== 'boolean') return null\n return wState.ended\n}\n\n// Have emitted 'finish'.\nfunction isWritableFinished(stream, strict) {\n if (!isWritableNodeStream(stream)) return null\n if (stream.writableFinished === true) return true\n const wState = stream._writableState\n if (wState !== null && wState !== undefined && wState.errored) return false\n if (typeof (wState === null || wState === undefined ? undefined : wState.finished) !== 'boolean') return null\n return !!(wState.finished || (strict === false && wState.ended === true && wState.length === 0))\n}\n\n// Have been push(null):d.\nfunction isReadableEnded(stream) {\n if (!isReadableNodeStream(stream)) return null\n if (stream.readableEnded === true) return true\n const rState = stream._readableState\n if (!rState || rState.errored) return false\n if (typeof (rState === null || rState === undefined ? undefined : rState.ended) !== 'boolean') return null\n return rState.ended\n}\n\n// Have emitted 'end'.\nfunction isReadableFinished(stream, strict) {\n if (!isReadableNodeStream(stream)) return null\n const rState = stream._readableState\n if (rState !== null && rState !== undefined && rState.errored) return false\n if (typeof (rState === null || rState === undefined ? undefined : rState.endEmitted) !== 'boolean') return null\n return !!(rState.endEmitted || (strict === false && rState.ended === true && rState.length === 0))\n}\nfunction isReadable(stream) {\n if (stream && stream[kIsReadable] != null) return stream[kIsReadable]\n if (typeof (stream === null || stream === undefined ? undefined : stream.readable) !== 'boolean') return null\n if (isDestroyed(stream)) return false\n return isReadableNodeStream(stream) && stream.readable && !isReadableFinished(stream)\n}\nfunction isWritable(stream) {\n if (stream && stream[kIsWritable] != null) return stream[kIsWritable]\n if (typeof (stream === null || stream === undefined ? undefined : stream.writable) !== 'boolean') return null\n if (isDestroyed(stream)) return false\n return isWritableNodeStream(stream) && stream.writable && !isWritableEnded(stream)\n}\nfunction isFinished(stream, opts) {\n if (!isNodeStream(stream)) {\n return null\n }\n if (isDestroyed(stream)) {\n return true\n }\n if ((opts === null || opts === undefined ? undefined : opts.readable) !== false && isReadable(stream)) {\n return false\n }\n if ((opts === null || opts === undefined ? undefined : opts.writable) !== false && isWritable(stream)) {\n return false\n }\n return true\n}\nfunction isWritableErrored(stream) {\n var _stream$_writableStat, _stream$_writableStat2\n if (!isNodeStream(stream)) {\n return null\n }\n if (stream.writableErrored) {\n return stream.writableErrored\n }\n return (_stream$_writableStat =\n (_stream$_writableStat2 = stream._writableState) === null || _stream$_writableStat2 === undefined\n ? undefined\n : _stream$_writableStat2.errored) !== null && _stream$_writableStat !== undefined\n ? _stream$_writableStat\n : null\n}\nfunction isReadableErrored(stream) {\n var _stream$_readableStat, _stream$_readableStat2\n if (!isNodeStream(stream)) {\n return null\n }\n if (stream.readableErrored) {\n return stream.readableErrored\n }\n return (_stream$_readableStat =\n (_stream$_readableStat2 = stream._readableState) === null || _stream$_readableStat2 === undefined\n ? undefined\n : _stream$_readableStat2.errored) !== null && _stream$_readableStat !== undefined\n ? _stream$_readableStat\n : null\n}\nfunction isClosed(stream) {\n if (!isNodeStream(stream)) {\n return null\n }\n if (typeof stream.closed === 'boolean') {\n return stream.closed\n }\n const wState = stream._writableState\n const rState = stream._readableState\n if (\n typeof (wState === null || wState === undefined ? undefined : wState.closed) === 'boolean' ||\n typeof (rState === null || rState === undefined ? undefined : rState.closed) === 'boolean'\n ) {\n return (\n (wState === null || wState === undefined ? undefined : wState.closed) ||\n (rState === null || rState === undefined ? undefined : rState.closed)\n )\n }\n if (typeof stream._closed === 'boolean' && isOutgoingMessage(stream)) {\n return stream._closed\n }\n return null\n}\nfunction isOutgoingMessage(stream) {\n return (\n typeof stream._closed === 'boolean' &&\n typeof stream._defaultKeepAlive === 'boolean' &&\n typeof stream._removedConnection === 'boolean' &&\n typeof stream._removedContLen === 'boolean'\n )\n}\nfunction isServerResponse(stream) {\n return typeof stream._sent100 === 'boolean' && isOutgoingMessage(stream)\n}\nfunction isServerRequest(stream) {\n var _stream$req\n return (\n typeof stream._consuming === 'boolean' &&\n typeof stream._dumped === 'boolean' &&\n ((_stream$req = stream.req) === null || _stream$req === undefined ? undefined : _stream$req.upgradeOrConnect) ===\n undefined\n )\n}\nfunction willEmitClose(stream) {\n if (!isNodeStream(stream)) return null\n const wState = stream._writableState\n const rState = stream._readableState\n const state = wState || rState\n return (\n (!state && isServerResponse(stream)) || !!(state && state.autoDestroy && state.emitClose && state.closed === false)\n )\n}\nfunction isDisturbed(stream) {\n var _stream$kIsDisturbed\n return !!(\n stream &&\n ((_stream$kIsDisturbed = stream[kIsDisturbed]) !== null && _stream$kIsDisturbed !== undefined\n ? _stream$kIsDisturbed\n : stream.readableDidRead || stream.readableAborted)\n )\n}\nfunction isErrored(stream) {\n var _ref,\n _ref2,\n _ref3,\n _ref4,\n _ref5,\n _stream$kIsErrored,\n _stream$_readableStat3,\n _stream$_writableStat3,\n _stream$_readableStat4,\n _stream$_writableStat4\n return !!(\n stream &&\n ((_ref =\n (_ref2 =\n (_ref3 =\n (_ref4 =\n (_ref5 =\n (_stream$kIsErrored = stream[kIsErrored]) !== null && _stream$kIsErrored !== undefined\n ? _stream$kIsErrored\n : stream.readableErrored) !== null && _ref5 !== undefined\n ? _ref5\n : stream.writableErrored) !== null && _ref4 !== undefined\n ? _ref4\n : (_stream$_readableStat3 = stream._readableState) === null || _stream$_readableStat3 === undefined\n ? undefined\n : _stream$_readableStat3.errorEmitted) !== null && _ref3 !== undefined\n ? _ref3\n : (_stream$_writableStat3 = stream._writableState) === null || _stream$_writableStat3 === undefined\n ? undefined\n : _stream$_writableStat3.errorEmitted) !== null && _ref2 !== undefined\n ? _ref2\n : (_stream$_readableStat4 = stream._readableState) === null || _stream$_readableStat4 === undefined\n ? undefined\n : _stream$_readableStat4.errored) !== null && _ref !== undefined\n ? _ref\n : (_stream$_writableStat4 = stream._writableState) === null || _stream$_writableStat4 === undefined\n ? undefined\n : _stream$_writableStat4.errored)\n )\n}\nmodule.exports = {\n isDestroyed,\n kIsDestroyed,\n isDisturbed,\n kIsDisturbed,\n isErrored,\n kIsErrored,\n isReadable,\n kIsReadable,\n kIsClosedPromise,\n kControllerErrorFunction,\n kIsWritable,\n isClosed,\n isDuplexNodeStream,\n isFinished,\n isIterable,\n isReadableNodeStream,\n isReadableStream,\n isReadableEnded,\n isReadableFinished,\n isReadableErrored,\n isNodeStream,\n isWebStream,\n isWritable,\n isWritableNodeStream,\n isWritableStream,\n isWritableEnded,\n isWritableFinished,\n isWritableErrored,\n isServerRequest,\n isServerResponse,\n willEmitClose,\n isTransformStream\n}\n","/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n;('use strict')\nconst { AbortError, codes } = require('../../ours/errors')\nconst { ERR_INVALID_ARG_TYPE, ERR_STREAM_PREMATURE_CLOSE } = codes\nconst { kEmptyObject, once } = require('../../ours/util')\nconst { validateAbortSignal, validateFunction, validateObject, validateBoolean } = require('../validators')\nconst { Promise, PromisePrototypeThen, SymbolDispose } = require('../../ours/primordials')\nconst {\n isClosed,\n isReadable,\n isReadableNodeStream,\n isReadableStream,\n isReadableFinished,\n isReadableErrored,\n isWritable,\n isWritableNodeStream,\n isWritableStream,\n isWritableFinished,\n isWritableErrored,\n isNodeStream,\n willEmitClose: _willEmitClose,\n kIsClosedPromise\n} = require('./utils')\nlet addAbortListener\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function'\n}\nconst nop = () => {}\nfunction eos(stream, options, callback) {\n var _options$readable, _options$writable\n if (arguments.length === 2) {\n callback = options\n options = kEmptyObject\n } else if (options == null) {\n options = kEmptyObject\n } else {\n validateObject(options, 'options')\n }\n validateFunction(callback, 'callback')\n validateAbortSignal(options.signal, 'options.signal')\n callback = once(callback)\n if (isReadableStream(stream) || isWritableStream(stream)) {\n return eosWeb(stream, options, callback)\n }\n if (!isNodeStream(stream)) {\n throw new ERR_INVALID_ARG_TYPE('stream', ['ReadableStream', 'WritableStream', 'Stream'], stream)\n }\n const readable =\n (_options$readable = options.readable) !== null && _options$readable !== undefined\n ? _options$readable\n : isReadableNodeStream(stream)\n const writable =\n (_options$writable = options.writable) !== null && _options$writable !== undefined\n ? _options$writable\n : isWritableNodeStream(stream)\n const wState = stream._writableState\n const rState = stream._readableState\n const onlegacyfinish = () => {\n if (!stream.writable) {\n onfinish()\n }\n }\n\n // TODO (ronag): Improve soft detection to include core modules and\n // common ecosystem modules that do properly emit 'close' but fail\n // this generic check.\n let willEmitClose =\n _willEmitClose(stream) && isReadableNodeStream(stream) === readable && isWritableNodeStream(stream) === writable\n let writableFinished = isWritableFinished(stream, false)\n const onfinish = () => {\n writableFinished = true\n // Stream should not be destroyed here. If it is that\n // means that user space is doing something differently and\n // we cannot trust willEmitClose.\n if (stream.destroyed) {\n willEmitClose = false\n }\n if (willEmitClose && (!stream.readable || readable)) {\n return\n }\n if (!readable || readableFinished) {\n callback.call(stream)\n }\n }\n let readableFinished = isReadableFinished(stream, false)\n const onend = () => {\n readableFinished = true\n // Stream should not be destroyed here. If it is that\n // means that user space is doing something differently and\n // we cannot trust willEmitClose.\n if (stream.destroyed) {\n willEmitClose = false\n }\n if (willEmitClose && (!stream.writable || writable)) {\n return\n }\n if (!writable || writableFinished) {\n callback.call(stream)\n }\n }\n const onerror = (err) => {\n callback.call(stream, err)\n }\n let closed = isClosed(stream)\n const onclose = () => {\n closed = true\n const errored = isWritableErrored(stream) || isReadableErrored(stream)\n if (errored && typeof errored !== 'boolean') {\n return callback.call(stream, errored)\n }\n if (readable && !readableFinished && isReadableNodeStream(stream, true)) {\n if (!isReadableFinished(stream, false)) return callback.call(stream, new ERR_STREAM_PREMATURE_CLOSE())\n }\n if (writable && !writableFinished) {\n if (!isWritableFinished(stream, false)) return callback.call(stream, new ERR_STREAM_PREMATURE_CLOSE())\n }\n callback.call(stream)\n }\n const onclosed = () => {\n closed = true\n const errored = isWritableErrored(stream) || isReadableErrored(stream)\n if (errored && typeof errored !== 'boolean') {\n return callback.call(stream, errored)\n }\n callback.call(stream)\n }\n const onrequest = () => {\n stream.req.on('finish', onfinish)\n }\n if (isRequest(stream)) {\n stream.on('complete', onfinish)\n if (!willEmitClose) {\n stream.on('abort', onclose)\n }\n if (stream.req) {\n onrequest()\n } else {\n stream.on('request', onrequest)\n }\n } else if (writable && !wState) {\n // legacy streams\n stream.on('end', onlegacyfinish)\n stream.on('close', onlegacyfinish)\n }\n\n // Not all streams will emit 'close' after 'aborted'.\n if (!willEmitClose && typeof stream.aborted === 'boolean') {\n stream.on('aborted', onclose)\n }\n stream.on('end', onend)\n stream.on('finish', onfinish)\n if (options.error !== false) {\n stream.on('error', onerror)\n }\n stream.on('close', onclose)\n if (closed) {\n process.nextTick(onclose)\n } else if (\n (wState !== null && wState !== undefined && wState.errorEmitted) ||\n (rState !== null && rState !== undefined && rState.errorEmitted)\n ) {\n if (!willEmitClose) {\n process.nextTick(onclosed)\n }\n } else if (\n !readable &&\n (!willEmitClose || isReadable(stream)) &&\n (writableFinished || isWritable(stream) === false)\n ) {\n process.nextTick(onclosed)\n } else if (\n !writable &&\n (!willEmitClose || isWritable(stream)) &&\n (readableFinished || isReadable(stream) === false)\n ) {\n process.nextTick(onclosed)\n } else if (rState && stream.req && stream.aborted) {\n process.nextTick(onclosed)\n }\n const cleanup = () => {\n callback = nop\n stream.removeListener('aborted', onclose)\n stream.removeListener('complete', onfinish)\n stream.removeListener('abort', onclose)\n stream.removeListener('request', onrequest)\n if (stream.req) stream.req.removeListener('finish', onfinish)\n stream.removeListener('end', onlegacyfinish)\n stream.removeListener('close', onlegacyfinish)\n stream.removeListener('finish', onfinish)\n stream.removeListener('end', onend)\n stream.removeListener('error', onerror)\n stream.removeListener('close', onclose)\n }\n if (options.signal && !closed) {\n const abort = () => {\n // Keep it because cleanup removes it.\n const endCallback = callback\n cleanup()\n endCallback.call(\n stream,\n new AbortError(undefined, {\n cause: options.signal.reason\n })\n )\n }\n if (options.signal.aborted) {\n process.nextTick(abort)\n } else {\n addAbortListener = addAbortListener || require('../../ours/util').addAbortListener\n const disposable = addAbortListener(options.signal, abort)\n const originalCallback = callback\n callback = once((...args) => {\n disposable[SymbolDispose]()\n originalCallback.apply(stream, args)\n })\n }\n }\n return cleanup\n}\nfunction eosWeb(stream, options, callback) {\n let isAborted = false\n let abort = nop\n if (options.signal) {\n abort = () => {\n isAborted = true\n callback.call(\n stream,\n new AbortError(undefined, {\n cause: options.signal.reason\n })\n )\n }\n if (options.signal.aborted) {\n process.nextTick(abort)\n } else {\n addAbortListener = addAbortListener || require('../../ours/util').addAbortListener\n const disposable = addAbortListener(options.signal, abort)\n const originalCallback = callback\n callback = once((...args) => {\n disposable[SymbolDispose]()\n originalCallback.apply(stream, args)\n })\n }\n }\n const resolverFn = (...args) => {\n if (!isAborted) {\n process.nextTick(() => callback.apply(stream, args))\n }\n }\n PromisePrototypeThen(stream[kIsClosedPromise].promise, resolverFn, resolverFn)\n return nop\n}\nfunction finished(stream, opts) {\n var _opts\n let autoCleanup = false\n if (opts === null) {\n opts = kEmptyObject\n }\n if ((_opts = opts) !== null && _opts !== undefined && _opts.cleanup) {\n validateBoolean(opts.cleanup, 'cleanup')\n autoCleanup = opts.cleanup\n }\n return new Promise((resolve, reject) => {\n const cleanup = eos(stream, opts, (err) => {\n if (autoCleanup) {\n cleanup()\n }\n if (err) {\n reject(err)\n } else {\n resolve()\n }\n })\n })\n}\nmodule.exports = eos\nmodule.exports.finished = finished\n","'use strict'\n\n/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n\nconst {\n aggregateTwoErrors,\n codes: { ERR_MULTIPLE_CALLBACK },\n AbortError\n} = require('../../ours/errors')\nconst { Symbol } = require('../../ours/primordials')\nconst { kIsDestroyed, isDestroyed, isFinished, isServerRequest } = require('./utils')\nconst kDestroy = Symbol('kDestroy')\nconst kConstruct = Symbol('kConstruct')\nfunction checkError(err, w, r) {\n if (err) {\n // Avoid V8 leak, https://github.com/nodejs/node/pull/34103#issuecomment-652002364\n err.stack // eslint-disable-line no-unused-expressions\n\n if (w && !w.errored) {\n w.errored = err\n }\n if (r && !r.errored) {\n r.errored = err\n }\n }\n}\n\n// Backwards compat. cb() is undocumented and unused in core but\n// unfortunately might be used by modules.\nfunction destroy(err, cb) {\n const r = this._readableState\n const w = this._writableState\n // With duplex streams we use the writable side for state.\n const s = w || r\n if ((w !== null && w !== undefined && w.destroyed) || (r !== null && r !== undefined && r.destroyed)) {\n if (typeof cb === 'function') {\n cb()\n }\n return this\n }\n\n // We set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n checkError(err, w, r)\n if (w) {\n w.destroyed = true\n }\n if (r) {\n r.destroyed = true\n }\n\n // If still constructing then defer calling _destroy.\n if (!s.constructed) {\n this.once(kDestroy, function (er) {\n _destroy(this, aggregateTwoErrors(er, err), cb)\n })\n } else {\n _destroy(this, err, cb)\n }\n return this\n}\nfunction _destroy(self, err, cb) {\n let called = false\n function onDestroy(err) {\n if (called) {\n return\n }\n called = true\n const r = self._readableState\n const w = self._writableState\n checkError(err, w, r)\n if (w) {\n w.closed = true\n }\n if (r) {\n r.closed = true\n }\n if (typeof cb === 'function') {\n cb(err)\n }\n if (err) {\n process.nextTick(emitErrorCloseNT, self, err)\n } else {\n process.nextTick(emitCloseNT, self)\n }\n }\n try {\n self._destroy(err || null, onDestroy)\n } catch (err) {\n onDestroy(err)\n }\n}\nfunction emitErrorCloseNT(self, err) {\n emitErrorNT(self, err)\n emitCloseNT(self)\n}\nfunction emitCloseNT(self) {\n const r = self._readableState\n const w = self._writableState\n if (w) {\n w.closeEmitted = true\n }\n if (r) {\n r.closeEmitted = true\n }\n if ((w !== null && w !== undefined && w.emitClose) || (r !== null && r !== undefined && r.emitClose)) {\n self.emit('close')\n }\n}\nfunction emitErrorNT(self, err) {\n const r = self._readableState\n const w = self._writableState\n if ((w !== null && w !== undefined && w.errorEmitted) || (r !== null && r !== undefined && r.errorEmitted)) {\n return\n }\n if (w) {\n w.errorEmitted = true\n }\n if (r) {\n r.errorEmitted = true\n }\n self.emit('error', err)\n}\nfunction undestroy() {\n const r = this._readableState\n const w = this._writableState\n if (r) {\n r.constructed = true\n r.closed = false\n r.closeEmitted = false\n r.destroyed = false\n r.errored = null\n r.errorEmitted = false\n r.reading = false\n r.ended = r.readable === false\n r.endEmitted = r.readable === false\n }\n if (w) {\n w.constructed = true\n w.destroyed = false\n w.closed = false\n w.closeEmitted = false\n w.errored = null\n w.errorEmitted = false\n w.finalCalled = false\n w.prefinished = false\n w.ended = w.writable === false\n w.ending = w.writable === false\n w.finished = w.writable === false\n }\n}\nfunction errorOrDestroy(stream, err, sync) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n const r = stream._readableState\n const w = stream._writableState\n if ((w !== null && w !== undefined && w.destroyed) || (r !== null && r !== undefined && r.destroyed)) {\n return this\n }\n if ((r !== null && r !== undefined && r.autoDestroy) || (w !== null && w !== undefined && w.autoDestroy))\n stream.destroy(err)\n else if (err) {\n // Avoid V8 leak, https://github.com/nodejs/node/pull/34103#issuecomment-652002364\n err.stack // eslint-disable-line no-unused-expressions\n\n if (w && !w.errored) {\n w.errored = err\n }\n if (r && !r.errored) {\n r.errored = err\n }\n if (sync) {\n process.nextTick(emitErrorNT, stream, err)\n } else {\n emitErrorNT(stream, err)\n }\n }\n}\nfunction construct(stream, cb) {\n if (typeof stream._construct !== 'function') {\n return\n }\n const r = stream._readableState\n const w = stream._writableState\n if (r) {\n r.constructed = false\n }\n if (w) {\n w.constructed = false\n }\n stream.once(kConstruct, cb)\n if (stream.listenerCount(kConstruct) > 1) {\n // Duplex\n return\n }\n process.nextTick(constructNT, stream)\n}\nfunction constructNT(stream) {\n let called = false\n function onConstruct(err) {\n if (called) {\n errorOrDestroy(stream, err !== null && err !== undefined ? err : new ERR_MULTIPLE_CALLBACK())\n return\n }\n called = true\n const r = stream._readableState\n const w = stream._writableState\n const s = w || r\n if (r) {\n r.constructed = true\n }\n if (w) {\n w.constructed = true\n }\n if (s.destroyed) {\n stream.emit(kDestroy, err)\n } else if (err) {\n errorOrDestroy(stream, err, true)\n } else {\n process.nextTick(emitConstructNT, stream)\n }\n }\n try {\n stream._construct((err) => {\n process.nextTick(onConstruct, err)\n })\n } catch (err) {\n process.nextTick(onConstruct, err)\n }\n}\nfunction emitConstructNT(stream) {\n stream.emit(kConstruct)\n}\nfunction isRequest(stream) {\n return (stream === null || stream === undefined ? undefined : stream.setHeader) && typeof stream.abort === 'function'\n}\nfunction emitCloseLegacy(stream) {\n stream.emit('close')\n}\nfunction emitErrorCloseLegacy(stream, err) {\n stream.emit('error', err)\n process.nextTick(emitCloseLegacy, stream)\n}\n\n// Normalize destroy for legacy.\nfunction destroyer(stream, err) {\n if (!stream || isDestroyed(stream)) {\n return\n }\n if (!err && !isFinished(stream)) {\n err = new AbortError()\n }\n\n // TODO: Remove isRequest branches.\n if (isServerRequest(stream)) {\n stream.socket = null\n stream.destroy(err)\n } else if (isRequest(stream)) {\n stream.abort()\n } else if (isRequest(stream.req)) {\n stream.req.abort()\n } else if (typeof stream.destroy === 'function') {\n stream.destroy(err)\n } else if (typeof stream.close === 'function') {\n // TODO: Don't lose err?\n stream.close()\n } else if (err) {\n process.nextTick(emitErrorCloseLegacy, stream, err)\n } else {\n process.nextTick(emitCloseLegacy, stream)\n }\n if (!stream.destroyed) {\n stream[kIsDestroyed] = true\n }\n}\nmodule.exports = {\n construct,\n destroyer,\n destroy,\n undestroy,\n errorOrDestroy\n}\n","'use strict'\n\nconst { ArrayIsArray, ObjectSetPrototypeOf } = require('../../ours/primordials')\nconst { EventEmitter: EE } = require('events')\nfunction Stream(opts) {\n EE.call(this, opts)\n}\nObjectSetPrototypeOf(Stream.prototype, EE.prototype)\nObjectSetPrototypeOf(Stream, EE)\nStream.prototype.pipe = function (dest, options) {\n const source = this\n function ondata(chunk) {\n if (dest.writable && dest.write(chunk) === false && source.pause) {\n source.pause()\n }\n }\n source.on('data', ondata)\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume()\n }\n }\n dest.on('drain', ondrain)\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend)\n source.on('close', onclose)\n }\n let didOnEnd = false\n function onend() {\n if (didOnEnd) return\n didOnEnd = true\n dest.end()\n }\n function onclose() {\n if (didOnEnd) return\n didOnEnd = true\n if (typeof dest.destroy === 'function') dest.destroy()\n }\n\n // Don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup()\n if (EE.listenerCount(this, 'error') === 0) {\n this.emit('error', er)\n }\n }\n prependListener(source, 'error', onerror)\n prependListener(dest, 'error', onerror)\n\n // Remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata)\n dest.removeListener('drain', ondrain)\n source.removeListener('end', onend)\n source.removeListener('close', onclose)\n source.removeListener('error', onerror)\n dest.removeListener('error', onerror)\n source.removeListener('end', cleanup)\n source.removeListener('close', cleanup)\n dest.removeListener('close', cleanup)\n }\n source.on('end', cleanup)\n source.on('close', cleanup)\n dest.on('close', cleanup)\n dest.emit('pipe', source)\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest\n}\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn)\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn)\n else if (ArrayIsArray(emitter._events[event])) emitter._events[event].unshift(fn)\n else emitter._events[event] = [fn, emitter._events[event]]\n}\nmodule.exports = {\n Stream,\n prependListener\n}\n","'use strict'\n\nconst { SymbolDispose } = require('../../ours/primordials')\nconst { AbortError, codes } = require('../../ours/errors')\nconst { isNodeStream, isWebStream, kControllerErrorFunction } = require('./utils')\nconst eos = require('./end-of-stream')\nconst { ERR_INVALID_ARG_TYPE } = codes\nlet addAbortListener\n\n// This method is inlined here for readable-stream\n// It also does not allow for signal to not exist on the stream\n// https://github.com/nodejs/node/pull/36061#discussion_r533718029\nconst validateAbortSignal = (signal, name) => {\n if (typeof signal !== 'object' || !('aborted' in signal)) {\n throw new ERR_INVALID_ARG_TYPE(name, 'AbortSignal', signal)\n }\n}\nmodule.exports.addAbortSignal = function addAbortSignal(signal, stream) {\n validateAbortSignal(signal, 'signal')\n if (!isNodeStream(stream) && !isWebStream(stream)) {\n throw new ERR_INVALID_ARG_TYPE('stream', ['ReadableStream', 'WritableStream', 'Stream'], stream)\n }\n return module.exports.addAbortSignalNoValidate(signal, stream)\n}\nmodule.exports.addAbortSignalNoValidate = function (signal, stream) {\n if (typeof signal !== 'object' || !('aborted' in signal)) {\n return stream\n }\n const onAbort = isNodeStream(stream)\n ? () => {\n stream.destroy(\n new AbortError(undefined, {\n cause: signal.reason\n })\n )\n }\n : () => {\n stream[kControllerErrorFunction](\n new AbortError(undefined, {\n cause: signal.reason\n })\n )\n }\n if (signal.aborted) {\n onAbort()\n } else {\n addAbortListener = addAbortListener || require('../../ours/util').addAbortListener\n const disposable = addAbortListener(signal, onAbort)\n eos(stream, disposable[SymbolDispose])\n }\n return stream\n}\n","'use strict'\n\nconst { StringPrototypeSlice, SymbolIterator, TypedArrayPrototypeSet, Uint8Array } = require('../../ours/primordials')\nconst { Buffer } = require('buffer')\nconst { inspect } = require('../../ours/util')\nmodule.exports = class BufferList {\n constructor() {\n this.head = null\n this.tail = null\n this.length = 0\n }\n push(v) {\n const entry = {\n data: v,\n next: null\n }\n if (this.length > 0) this.tail.next = entry\n else this.head = entry\n this.tail = entry\n ++this.length\n }\n unshift(v) {\n const entry = {\n data: v,\n next: this.head\n }\n if (this.length === 0) this.tail = entry\n this.head = entry\n ++this.length\n }\n shift() {\n if (this.length === 0) return\n const ret = this.head.data\n if (this.length === 1) this.head = this.tail = null\n else this.head = this.head.next\n --this.length\n return ret\n }\n clear() {\n this.head = this.tail = null\n this.length = 0\n }\n join(s) {\n if (this.length === 0) return ''\n let p = this.head\n let ret = '' + p.data\n while ((p = p.next) !== null) ret += s + p.data\n return ret\n }\n concat(n) {\n if (this.length === 0) return Buffer.alloc(0)\n const ret = Buffer.allocUnsafe(n >>> 0)\n let p = this.head\n let i = 0\n while (p) {\n TypedArrayPrototypeSet(ret, p.data, i)\n i += p.data.length\n p = p.next\n }\n return ret\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n consume(n, hasStrings) {\n const data = this.head.data\n if (n < data.length) {\n // `slice` is the same for buffers and strings.\n const slice = data.slice(0, n)\n this.head.data = data.slice(n)\n return slice\n }\n if (n === data.length) {\n // First chunk is a perfect match.\n return this.shift()\n }\n // Result spans more than one buffer.\n return hasStrings ? this._getString(n) : this._getBuffer(n)\n }\n first() {\n return this.head.data\n }\n *[SymbolIterator]() {\n for (let p = this.head; p; p = p.next) {\n yield p.data\n }\n }\n\n // Consumes a specified amount of characters from the buffered data.\n _getString(n) {\n let ret = ''\n let p = this.head\n let c = 0\n do {\n const str = p.data\n if (n > str.length) {\n ret += str\n n -= str.length\n } else {\n if (n === str.length) {\n ret += str\n ++c\n if (p.next) this.head = p.next\n else this.head = this.tail = null\n } else {\n ret += StringPrototypeSlice(str, 0, n)\n this.head = p\n p.data = StringPrototypeSlice(str, n)\n }\n break\n }\n ++c\n } while ((p = p.next) !== null)\n this.length -= c\n return ret\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n _getBuffer(n) {\n const ret = Buffer.allocUnsafe(n)\n const retLen = n\n let p = this.head\n let c = 0\n do {\n const buf = p.data\n if (n > buf.length) {\n TypedArrayPrototypeSet(ret, buf, retLen - n)\n n -= buf.length\n } else {\n if (n === buf.length) {\n TypedArrayPrototypeSet(ret, buf, retLen - n)\n ++c\n if (p.next) this.head = p.next\n else this.head = this.tail = null\n } else {\n TypedArrayPrototypeSet(ret, new Uint8Array(buf.buffer, buf.byteOffset, n), retLen - n)\n this.head = p\n p.data = buf.slice(n)\n }\n break\n }\n ++c\n } while ((p = p.next) !== null)\n this.length -= c\n return ret\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n [Symbol.for('nodejs.util.inspect.custom')](_, options) {\n return inspect(this, {\n ...options,\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n })\n }\n}\n","'use strict'\n\nconst { MathFloor, NumberIsInteger } = require('../../ours/primordials')\nconst { validateInteger } = require('../validators')\nconst { ERR_INVALID_ARG_VALUE } = require('../../ours/errors').codes\nlet defaultHighWaterMarkBytes = 16 * 1024\nlet defaultHighWaterMarkObjectMode = 16\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null\n}\nfunction getDefaultHighWaterMark(objectMode) {\n return objectMode ? defaultHighWaterMarkObjectMode : defaultHighWaterMarkBytes\n}\nfunction setDefaultHighWaterMark(objectMode, value) {\n validateInteger(value, 'value', 0)\n if (objectMode) {\n defaultHighWaterMarkObjectMode = value\n } else {\n defaultHighWaterMarkBytes = value\n }\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n const hwm = highWaterMarkFrom(options, isDuplex, duplexKey)\n if (hwm != null) {\n if (!NumberIsInteger(hwm) || hwm < 0) {\n const name = isDuplex ? `options.${duplexKey}` : 'options.highWaterMark'\n throw new ERR_INVALID_ARG_VALUE(name, hwm)\n }\n return MathFloor(hwm)\n }\n\n // Default value\n return getDefaultHighWaterMark(state.objectMode)\n}\nmodule.exports = {\n getHighWaterMark,\n getDefaultHighWaterMark,\n setDefaultHighWaterMark\n}\n","'use strict'\n\n/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n\nconst { PromisePrototypeThen, SymbolAsyncIterator, SymbolIterator } = require('../../ours/primordials')\nconst { Buffer } = require('buffer')\nconst { ERR_INVALID_ARG_TYPE, ERR_STREAM_NULL_VALUES } = require('../../ours/errors').codes\nfunction from(Readable, iterable, opts) {\n let iterator\n if (typeof iterable === 'string' || iterable instanceof Buffer) {\n return new Readable({\n objectMode: true,\n ...opts,\n read() {\n this.push(iterable)\n this.push(null)\n }\n })\n }\n let isAsync\n if (iterable && iterable[SymbolAsyncIterator]) {\n isAsync = true\n iterator = iterable[SymbolAsyncIterator]()\n } else if (iterable && iterable[SymbolIterator]) {\n isAsync = false\n iterator = iterable[SymbolIterator]()\n } else {\n throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable)\n }\n const readable = new Readable({\n objectMode: true,\n highWaterMark: 1,\n // TODO(ronag): What options should be allowed?\n ...opts\n })\n\n // Flag to protect against _read\n // being called before last iteration completion.\n let reading = false\n readable._read = function () {\n if (!reading) {\n reading = true\n next()\n }\n }\n readable._destroy = function (error, cb) {\n PromisePrototypeThen(\n close(error),\n () => process.nextTick(cb, error),\n // nextTick is here in case cb throws\n (e) => process.nextTick(cb, e || error)\n )\n }\n async function close(error) {\n const hadError = error !== undefined && error !== null\n const hasThrow = typeof iterator.throw === 'function'\n if (hadError && hasThrow) {\n const { value, done } = await iterator.throw(error)\n await value\n if (done) {\n return\n }\n }\n if (typeof iterator.return === 'function') {\n const { value } = await iterator.return()\n await value\n }\n }\n async function next() {\n for (;;) {\n try {\n const { value, done } = isAsync ? await iterator.next() : iterator.next()\n if (done) {\n readable.push(null)\n } else {\n const res = value && typeof value.then === 'function' ? await value : value\n if (res === null) {\n reading = false\n throw new ERR_STREAM_NULL_VALUES()\n } else if (readable.push(res)) {\n continue\n } else {\n reading = false\n }\n }\n } catch (err) {\n readable.destroy(err)\n }\n break\n }\n }\n return readable\n}\nmodule.exports = from\n","/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n;('use strict')\nconst {\n ArrayPrototypeIndexOf,\n NumberIsInteger,\n NumberIsNaN,\n NumberParseInt,\n ObjectDefineProperties,\n ObjectKeys,\n ObjectSetPrototypeOf,\n Promise,\n SafeSet,\n SymbolAsyncDispose,\n SymbolAsyncIterator,\n Symbol\n} = require('../../ours/primordials')\nmodule.exports = Readable\nReadable.ReadableState = ReadableState\nconst { EventEmitter: EE } = require('events')\nconst { Stream, prependListener } = require('./legacy')\nconst { Buffer } = require('buffer')\nconst { addAbortSignal } = require('./add-abort-signal')\nconst eos = require('./end-of-stream')\nlet debug = require('../../ours/util').debuglog('stream', (fn) => {\n debug = fn\n})\nconst BufferList = require('./buffer_list')\nconst destroyImpl = require('./destroy')\nconst { getHighWaterMark, getDefaultHighWaterMark } = require('./state')\nconst {\n aggregateTwoErrors,\n codes: {\n ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED,\n ERR_OUT_OF_RANGE,\n ERR_STREAM_PUSH_AFTER_EOF,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT\n },\n AbortError\n} = require('../../ours/errors')\nconst { validateObject } = require('../validators')\nconst kPaused = Symbol('kPaused')\nconst { StringDecoder } = require('string_decoder')\nconst from = require('./from')\nObjectSetPrototypeOf(Readable.prototype, Stream.prototype)\nObjectSetPrototypeOf(Readable, Stream)\nconst nop = () => {}\nconst { errorOrDestroy } = destroyImpl\nconst kObjectMode = 1 << 0\nconst kEnded = 1 << 1\nconst kEndEmitted = 1 << 2\nconst kReading = 1 << 3\nconst kConstructed = 1 << 4\nconst kSync = 1 << 5\nconst kNeedReadable = 1 << 6\nconst kEmittedReadable = 1 << 7\nconst kReadableListening = 1 << 8\nconst kResumeScheduled = 1 << 9\nconst kErrorEmitted = 1 << 10\nconst kEmitClose = 1 << 11\nconst kAutoDestroy = 1 << 12\nconst kDestroyed = 1 << 13\nconst kClosed = 1 << 14\nconst kCloseEmitted = 1 << 15\nconst kMultiAwaitDrain = 1 << 16\nconst kReadingMore = 1 << 17\nconst kDataEmitted = 1 << 18\n\n// TODO(benjamingr) it is likely slower to do it this way than with free functions\nfunction makeBitMapDescriptor(bit) {\n return {\n enumerable: false,\n get() {\n return (this.state & bit) !== 0\n },\n set(value) {\n if (value) this.state |= bit\n else this.state &= ~bit\n }\n }\n}\nObjectDefineProperties(ReadableState.prototype, {\n objectMode: makeBitMapDescriptor(kObjectMode),\n ended: makeBitMapDescriptor(kEnded),\n endEmitted: makeBitMapDescriptor(kEndEmitted),\n reading: makeBitMapDescriptor(kReading),\n // Stream is still being constructed and cannot be\n // destroyed until construction finished or failed.\n // Async construction is opt in, therefore we start as\n // constructed.\n constructed: makeBitMapDescriptor(kConstructed),\n // A flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n sync: makeBitMapDescriptor(kSync),\n // Whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n needReadable: makeBitMapDescriptor(kNeedReadable),\n emittedReadable: makeBitMapDescriptor(kEmittedReadable),\n readableListening: makeBitMapDescriptor(kReadableListening),\n resumeScheduled: makeBitMapDescriptor(kResumeScheduled),\n // True if the error was already emitted and should not be thrown again.\n errorEmitted: makeBitMapDescriptor(kErrorEmitted),\n emitClose: makeBitMapDescriptor(kEmitClose),\n autoDestroy: makeBitMapDescriptor(kAutoDestroy),\n // Has it been destroyed.\n destroyed: makeBitMapDescriptor(kDestroyed),\n // Indicates whether the stream has finished destroying.\n closed: makeBitMapDescriptor(kClosed),\n // True if close has been emitted or would have been emitted\n // depending on emitClose.\n closeEmitted: makeBitMapDescriptor(kCloseEmitted),\n multiAwaitDrain: makeBitMapDescriptor(kMultiAwaitDrain),\n // If true, a maybeReadMore has been scheduled.\n readingMore: makeBitMapDescriptor(kReadingMore),\n dataEmitted: makeBitMapDescriptor(kDataEmitted)\n})\nfunction ReadableState(options, stream, isDuplex) {\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof require('./duplex')\n\n // Bit map field to store ReadableState more effciently with 1 bit per field\n // instead of a V8 slot per field.\n this.state = kEmitClose | kAutoDestroy | kConstructed | kSync\n // Object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away.\n if (options && options.objectMode) this.state |= kObjectMode\n if (isDuplex && options && options.readableObjectMode) this.state |= kObjectMode\n\n // The point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = options\n ? getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex)\n : getDefaultHighWaterMark(false)\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift().\n this.buffer = new BufferList()\n this.length = 0\n this.pipes = []\n this.flowing = null\n this[kPaused] = null\n\n // Should close be emitted on destroy. Defaults to true.\n if (options && options.emitClose === false) this.state &= ~kEmitClose\n\n // Should .destroy() be called after 'end' (and potentially 'finish').\n if (options && options.autoDestroy === false) this.state &= ~kAutoDestroy\n\n // Indicates whether the stream has errored. When true no further\n // _read calls, 'data' or 'readable' events should occur. This is needed\n // since when autoDestroy is disabled we need a way to tell whether the\n // stream has failed.\n this.errored = null\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = (options && options.defaultEncoding) || 'utf8'\n\n // Ref the piped dest which we need a drain event on it\n // type: null | Writable | Set<Writable>.\n this.awaitDrainWriters = null\n this.decoder = null\n this.encoding = null\n if (options && options.encoding) {\n this.decoder = new StringDecoder(options.encoding)\n this.encoding = options.encoding\n }\n}\nfunction Readable(options) {\n if (!(this instanceof Readable)) return new Readable(options)\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5.\n const isDuplex = this instanceof require('./duplex')\n this._readableState = new ReadableState(options, this, isDuplex)\n if (options) {\n if (typeof options.read === 'function') this._read = options.read\n if (typeof options.destroy === 'function') this._destroy = options.destroy\n if (typeof options.construct === 'function') this._construct = options.construct\n if (options.signal && !isDuplex) addAbortSignal(options.signal, this)\n }\n Stream.call(this, options)\n destroyImpl.construct(this, () => {\n if (this._readableState.needReadable) {\n maybeReadMore(this, this._readableState)\n }\n })\n}\nReadable.prototype.destroy = destroyImpl.destroy\nReadable.prototype._undestroy = destroyImpl.undestroy\nReadable.prototype._destroy = function (err, cb) {\n cb(err)\n}\nReadable.prototype[EE.captureRejectionSymbol] = function (err) {\n this.destroy(err)\n}\nReadable.prototype[SymbolAsyncDispose] = function () {\n let error\n if (!this.destroyed) {\n error = this.readableEnded ? null : new AbortError()\n this.destroy(error)\n }\n return new Promise((resolve, reject) => eos(this, (err) => (err && err !== error ? reject(err) : resolve(null))))\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n return readableAddChunk(this, chunk, encoding, false)\n}\n\n// Unshift should *always* be something directly out of read().\nReadable.prototype.unshift = function (chunk, encoding) {\n return readableAddChunk(this, chunk, encoding, true)\n}\nfunction readableAddChunk(stream, chunk, encoding, addToFront) {\n debug('readableAddChunk', chunk)\n const state = stream._readableState\n let err\n if ((state.state & kObjectMode) === 0) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding\n if (state.encoding !== encoding) {\n if (addToFront && state.encoding) {\n // When unshifting, if state.encoding is set, we have to save\n // the string in the BufferList with the state encoding.\n chunk = Buffer.from(chunk, encoding).toString(state.encoding)\n } else {\n chunk = Buffer.from(chunk, encoding)\n encoding = ''\n }\n }\n } else if (chunk instanceof Buffer) {\n encoding = ''\n } else if (Stream._isUint8Array(chunk)) {\n chunk = Stream._uint8ArrayToBuffer(chunk)\n encoding = ''\n } else if (chunk != null) {\n err = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk)\n }\n }\n if (err) {\n errorOrDestroy(stream, err)\n } else if (chunk === null) {\n state.state &= ~kReading\n onEofChunk(stream, state)\n } else if ((state.state & kObjectMode) !== 0 || (chunk && chunk.length > 0)) {\n if (addToFront) {\n if ((state.state & kEndEmitted) !== 0) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT())\n else if (state.destroyed || state.errored) return false\n else addChunk(stream, state, chunk, true)\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF())\n } else if (state.destroyed || state.errored) {\n return false\n } else {\n state.state &= ~kReading\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk)\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false)\n else maybeReadMore(stream, state)\n } else {\n addChunk(stream, state, chunk, false)\n }\n }\n } else if (!addToFront) {\n state.state &= ~kReading\n maybeReadMore(stream, state)\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0)\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync && stream.listenerCount('data') > 0) {\n // Use the guard to avoid creating `Set()` repeatedly\n // when we have multiple pipes.\n if ((state.state & kMultiAwaitDrain) !== 0) {\n state.awaitDrainWriters.clear()\n } else {\n state.awaitDrainWriters = null\n }\n state.dataEmitted = true\n stream.emit('data', chunk)\n } else {\n // Update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length\n if (addToFront) state.buffer.unshift(chunk)\n else state.buffer.push(chunk)\n if ((state.state & kNeedReadable) !== 0) emitReadable(stream)\n }\n maybeReadMore(stream, state)\n}\nReadable.prototype.isPaused = function () {\n const state = this._readableState\n return state[kPaused] === true || state.flowing === false\n}\n\n// Backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n const decoder = new StringDecoder(enc)\n this._readableState.decoder = decoder\n // If setEncoding(null), decoder.encoding equals utf8.\n this._readableState.encoding = this._readableState.decoder.encoding\n const buffer = this._readableState.buffer\n // Iterate over current buffer to convert already stored Buffers:\n let content = ''\n for (const data of buffer) {\n content += decoder.write(data)\n }\n buffer.clear()\n if (content !== '') buffer.push(content)\n this._readableState.length = content.length\n return this\n}\n\n// Don't raise the hwm > 1GB.\nconst MAX_HWM = 0x40000000\nfunction computeNewHighWaterMark(n) {\n if (n > MAX_HWM) {\n throw new ERR_OUT_OF_RANGE('size', '<= 1GiB', n)\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts.\n n--\n n |= n >>> 1\n n |= n >>> 2\n n |= n >>> 4\n n |= n >>> 8\n n |= n >>> 16\n n++\n }\n return n\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || (state.length === 0 && state.ended)) return 0\n if ((state.state & kObjectMode) !== 0) return 1\n if (NumberIsNaN(n)) {\n // Only flow one buffer at a time.\n if (state.flowing && state.length) return state.buffer.first().length\n return state.length\n }\n if (n <= state.length) return n\n return state.ended ? state.length : 0\n}\n\n// You can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n)\n // Same as parseInt(undefined, 10), however V8 7.3 performance regressed\n // in this scenario, so we are doing it manually.\n if (n === undefined) {\n n = NaN\n } else if (!NumberIsInteger(n)) {\n n = NumberParseInt(n, 10)\n }\n const state = this._readableState\n const nOrig = n\n\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n)\n if (n !== 0) state.state &= ~kEmittedReadable\n\n // If we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (\n n === 0 &&\n state.needReadable &&\n ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)\n ) {\n debug('read: emitReadable', state.length, state.ended)\n if (state.length === 0 && state.ended) endReadable(this)\n else emitReadable(this)\n return null\n }\n n = howMuchToRead(n, state)\n\n // If we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this)\n return null\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n let doRead = (state.state & kNeedReadable) !== 0\n debug('need readable', doRead)\n\n // If we currently have less than the highWaterMark, then also read some.\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true\n debug('length less than watermark', doRead)\n }\n\n // However, if we've ended, then there's no point, if we're already\n // reading, then it's unnecessary, if we're constructing we have to wait,\n // and if we're destroyed or errored, then it's not allowed,\n if (state.ended || state.reading || state.destroyed || state.errored || !state.constructed) {\n doRead = false\n debug('reading, ended or constructing', doRead)\n } else if (doRead) {\n debug('do read')\n state.state |= kReading | kSync\n // If the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.state |= kNeedReadable\n\n // Call internal read method\n try {\n this._read(state.highWaterMark)\n } catch (err) {\n errorOrDestroy(this, err)\n }\n state.state &= ~kSync\n\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state)\n }\n let ret\n if (n > 0) ret = fromList(n, state)\n else ret = null\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark\n n = 0\n } else {\n state.length -= n\n if (state.multiAwaitDrain) {\n state.awaitDrainWriters.clear()\n } else {\n state.awaitDrainWriters = null\n }\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this)\n }\n if (ret !== null && !state.errorEmitted && !state.closeEmitted) {\n state.dataEmitted = true\n this.emit('data', ret)\n }\n return ret\n}\nfunction onEofChunk(stream, state) {\n debug('onEofChunk')\n if (state.ended) return\n if (state.decoder) {\n const chunk = state.decoder.end()\n if (chunk && chunk.length) {\n state.buffer.push(chunk)\n state.length += state.objectMode ? 1 : chunk.length\n }\n }\n state.ended = true\n if (state.sync) {\n // If we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call.\n emitReadable(stream)\n } else {\n // Emit 'readable' now to make sure it gets picked up.\n state.needReadable = false\n state.emittedReadable = true\n // We have to emit readable now that we are EOF. Modules\n // in the ecosystem (e.g. dicer) rely on this event being sync.\n emitReadable_(stream)\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n const state = stream._readableState\n debug('emitReadable', state.needReadable, state.emittedReadable)\n state.needReadable = false\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing)\n state.emittedReadable = true\n process.nextTick(emitReadable_, stream)\n }\n}\nfunction emitReadable_(stream) {\n const state = stream._readableState\n debug('emitReadable_', state.destroyed, state.length, state.ended)\n if (!state.destroyed && !state.errored && (state.length || state.ended)) {\n stream.emit('readable')\n state.emittedReadable = false\n }\n\n // The stream needs another readable event if:\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark\n flow(stream)\n}\n\n// At this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore && state.constructed) {\n state.readingMore = true\n process.nextTick(maybeReadMore_, stream, state)\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (\n !state.reading &&\n !state.ended &&\n (state.length < state.highWaterMark || (state.flowing && state.length === 0))\n ) {\n const len = state.length\n debug('maybeReadMore read 0')\n stream.read(0)\n if (len === state.length)\n // Didn't get any data, stop spinning.\n break\n }\n state.readingMore = false\n}\n\n// Abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n throw new ERR_METHOD_NOT_IMPLEMENTED('_read()')\n}\nReadable.prototype.pipe = function (dest, pipeOpts) {\n const src = this\n const state = this._readableState\n if (state.pipes.length === 1) {\n if (!state.multiAwaitDrain) {\n state.multiAwaitDrain = true\n state.awaitDrainWriters = new SafeSet(state.awaitDrainWriters ? [state.awaitDrainWriters] : [])\n }\n }\n state.pipes.push(dest)\n debug('pipe count=%d opts=%j', state.pipes.length, pipeOpts)\n const doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr\n const endFn = doEnd ? onend : unpipe\n if (state.endEmitted) process.nextTick(endFn)\n else src.once('end', endFn)\n dest.on('unpipe', onunpipe)\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe')\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true\n cleanup()\n }\n }\n }\n function onend() {\n debug('onend')\n dest.end()\n }\n let ondrain\n let cleanedUp = false\n function cleanup() {\n debug('cleanup')\n // Cleanup event handlers once the pipe is broken.\n dest.removeListener('close', onclose)\n dest.removeListener('finish', onfinish)\n if (ondrain) {\n dest.removeListener('drain', ondrain)\n }\n dest.removeListener('error', onerror)\n dest.removeListener('unpipe', onunpipe)\n src.removeListener('end', onend)\n src.removeListener('end', unpipe)\n src.removeListener('data', ondata)\n cleanedUp = true\n\n // If the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (ondrain && state.awaitDrainWriters && (!dest._writableState || dest._writableState.needDrain)) ondrain()\n }\n function pause() {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if (!cleanedUp) {\n if (state.pipes.length === 1 && state.pipes[0] === dest) {\n debug('false write response, pause', 0)\n state.awaitDrainWriters = dest\n state.multiAwaitDrain = false\n } else if (state.pipes.length > 1 && state.pipes.includes(dest)) {\n debug('false write response, pause', state.awaitDrainWriters.size)\n state.awaitDrainWriters.add(dest)\n }\n src.pause()\n }\n if (!ondrain) {\n // When the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n ondrain = pipeOnDrain(src, dest)\n dest.on('drain', ondrain)\n }\n }\n src.on('data', ondata)\n function ondata(chunk) {\n debug('ondata')\n const ret = dest.write(chunk)\n debug('dest.write', ret)\n if (ret === false) {\n pause()\n }\n }\n\n // If the dest has an error, then stop piping into it.\n // However, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er)\n unpipe()\n dest.removeListener('error', onerror)\n if (dest.listenerCount('error') === 0) {\n const s = dest._writableState || dest._readableState\n if (s && !s.errorEmitted) {\n // User incorrectly emitted 'error' directly on the stream.\n errorOrDestroy(dest, er)\n } else {\n dest.emit('error', er)\n }\n }\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror)\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish)\n unpipe()\n }\n dest.once('close', onclose)\n function onfinish() {\n debug('onfinish')\n dest.removeListener('close', onclose)\n unpipe()\n }\n dest.once('finish', onfinish)\n function unpipe() {\n debug('unpipe')\n src.unpipe(dest)\n }\n\n // Tell the dest that it's being piped to.\n dest.emit('pipe', src)\n\n // Start the flow if it hasn't been started already.\n\n if (dest.writableNeedDrain === true) {\n pause()\n } else if (!state.flowing) {\n debug('pipe resume')\n src.resume()\n }\n return dest\n}\nfunction pipeOnDrain(src, dest) {\n return function pipeOnDrainFunctionResult() {\n const state = src._readableState\n\n // `ondrain` will call directly,\n // `this` maybe not a reference to dest,\n // so we use the real dest here.\n if (state.awaitDrainWriters === dest) {\n debug('pipeOnDrain', 1)\n state.awaitDrainWriters = null\n } else if (state.multiAwaitDrain) {\n debug('pipeOnDrain', state.awaitDrainWriters.size)\n state.awaitDrainWriters.delete(dest)\n }\n if ((!state.awaitDrainWriters || state.awaitDrainWriters.size === 0) && src.listenerCount('data')) {\n src.resume()\n }\n }\n}\nReadable.prototype.unpipe = function (dest) {\n const state = this._readableState\n const unpipeInfo = {\n hasUnpiped: false\n }\n\n // If we're not piping anywhere, then do nothing.\n if (state.pipes.length === 0) return this\n if (!dest) {\n // remove all.\n const dests = state.pipes\n state.pipes = []\n this.pause()\n for (let i = 0; i < dests.length; i++)\n dests[i].emit('unpipe', this, {\n hasUnpiped: false\n })\n return this\n }\n\n // Try to find the right one.\n const index = ArrayPrototypeIndexOf(state.pipes, dest)\n if (index === -1) return this\n state.pipes.splice(index, 1)\n if (state.pipes.length === 0) this.pause()\n dest.emit('unpipe', this, unpipeInfo)\n return this\n}\n\n// Set up data events if they are asked for\n// Ensure readable listeners eventually get something.\nReadable.prototype.on = function (ev, fn) {\n const res = Stream.prototype.on.call(this, ev, fn)\n const state = this._readableState\n if (ev === 'data') {\n // Update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0\n\n // Try start flowing on next tick if stream isn't explicitly paused.\n if (state.flowing !== false) this.resume()\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true\n state.flowing = false\n state.emittedReadable = false\n debug('on readable', state.length, state.reading)\n if (state.length) {\n emitReadable(this)\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this)\n }\n }\n }\n return res\n}\nReadable.prototype.addListener = Readable.prototype.on\nReadable.prototype.removeListener = function (ev, fn) {\n const res = Stream.prototype.removeListener.call(this, ev, fn)\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this)\n }\n return res\n}\nReadable.prototype.off = Readable.prototype.removeListener\nReadable.prototype.removeAllListeners = function (ev) {\n const res = Stream.prototype.removeAllListeners.apply(this, arguments)\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this)\n }\n return res\n}\nfunction updateReadableListening(self) {\n const state = self._readableState\n state.readableListening = self.listenerCount('readable') > 0\n if (state.resumeScheduled && state[kPaused] === false) {\n // Flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true\n\n // Crude way to check if we should resume.\n } else if (self.listenerCount('data') > 0) {\n self.resume()\n } else if (!state.readableListening) {\n state.flowing = null\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0')\n self.read(0)\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n const state = this._readableState\n if (!state.flowing) {\n debug('resume')\n // We flow only if there is no one listening\n // for readable, but we still have to call\n // resume().\n state.flowing = !state.readableListening\n resume(this, state)\n }\n state[kPaused] = false\n return this\n}\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true\n process.nextTick(resume_, stream, state)\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading)\n if (!state.reading) {\n stream.read(0)\n }\n state.resumeScheduled = false\n stream.emit('resume')\n flow(stream)\n if (state.flowing && !state.reading) stream.read(0)\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing)\n if (this._readableState.flowing !== false) {\n debug('pause')\n this._readableState.flowing = false\n this.emit('pause')\n }\n this._readableState[kPaused] = true\n return this\n}\nfunction flow(stream) {\n const state = stream._readableState\n debug('flow', state.flowing)\n while (state.flowing && stream.read() !== null);\n}\n\n// Wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n let paused = false\n\n // TODO (ronag): Should this.destroy(err) emit\n // 'error' on the wrapped stream? Would require\n // a static factory method, e.g. Readable.wrap(stream).\n\n stream.on('data', (chunk) => {\n if (!this.push(chunk) && stream.pause) {\n paused = true\n stream.pause()\n }\n })\n stream.on('end', () => {\n this.push(null)\n })\n stream.on('error', (err) => {\n errorOrDestroy(this, err)\n })\n stream.on('close', () => {\n this.destroy()\n })\n stream.on('destroy', () => {\n this.destroy()\n })\n this._read = () => {\n if (paused && stream.resume) {\n paused = false\n stream.resume()\n }\n }\n\n // Proxy all the other methods. Important when wrapping filters and duplexes.\n const streamKeys = ObjectKeys(stream)\n for (let j = 1; j < streamKeys.length; j++) {\n const i = streamKeys[j]\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = stream[i].bind(stream)\n }\n }\n return this\n}\nReadable.prototype[SymbolAsyncIterator] = function () {\n return streamToAsyncIterator(this)\n}\nReadable.prototype.iterator = function (options) {\n if (options !== undefined) {\n validateObject(options, 'options')\n }\n return streamToAsyncIterator(this, options)\n}\nfunction streamToAsyncIterator(stream, options) {\n if (typeof stream.read !== 'function') {\n stream = Readable.wrap(stream, {\n objectMode: true\n })\n }\n const iter = createAsyncIterator(stream, options)\n iter.stream = stream\n return iter\n}\nasync function* createAsyncIterator(stream, options) {\n let callback = nop\n function next(resolve) {\n if (this === stream) {\n callback()\n callback = nop\n } else {\n callback = resolve\n }\n }\n stream.on('readable', next)\n let error\n const cleanup = eos(\n stream,\n {\n writable: false\n },\n (err) => {\n error = err ? aggregateTwoErrors(error, err) : null\n callback()\n callback = nop\n }\n )\n try {\n while (true) {\n const chunk = stream.destroyed ? null : stream.read()\n if (chunk !== null) {\n yield chunk\n } else if (error) {\n throw error\n } else if (error === null) {\n return\n } else {\n await new Promise(next)\n }\n }\n } catch (err) {\n error = aggregateTwoErrors(error, err)\n throw error\n } finally {\n if (\n (error || (options === null || options === undefined ? undefined : options.destroyOnReturn) !== false) &&\n (error === undefined || stream._readableState.autoDestroy)\n ) {\n destroyImpl.destroyer(stream, null)\n } else {\n stream.off('readable', next)\n cleanup()\n }\n }\n}\n\n// Making it explicit these properties are not enumerable\n// because otherwise some prototype manipulation in\n// userland will fail.\nObjectDefineProperties(Readable.prototype, {\n readable: {\n __proto__: null,\n get() {\n const r = this._readableState\n // r.readable === false means that this is part of a Duplex stream\n // where the readable side was disabled upon construction.\n // Compat. The user might manually disable readable side through\n // deprecated setter.\n return !!r && r.readable !== false && !r.destroyed && !r.errorEmitted && !r.endEmitted\n },\n set(val) {\n // Backwards compat.\n if (this._readableState) {\n this._readableState.readable = !!val\n }\n }\n },\n readableDidRead: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return this._readableState.dataEmitted\n }\n },\n readableAborted: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return !!(\n this._readableState.readable !== false &&\n (this._readableState.destroyed || this._readableState.errored) &&\n !this._readableState.endEmitted\n )\n }\n },\n readableHighWaterMark: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return this._readableState.highWaterMark\n }\n },\n readableBuffer: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return this._readableState && this._readableState.buffer\n }\n },\n readableFlowing: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return this._readableState.flowing\n },\n set: function (state) {\n if (this._readableState) {\n this._readableState.flowing = state\n }\n }\n },\n readableLength: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState.length\n }\n },\n readableObjectMode: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState ? this._readableState.objectMode : false\n }\n },\n readableEncoding: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState ? this._readableState.encoding : null\n }\n },\n errored: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState ? this._readableState.errored : null\n }\n },\n closed: {\n __proto__: null,\n get() {\n return this._readableState ? this._readableState.closed : false\n }\n },\n destroyed: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState ? this._readableState.destroyed : false\n },\n set(value) {\n // We ignore the value if the stream\n // has not been initialized yet.\n if (!this._readableState) {\n return\n }\n\n // Backward compatibility, the user is explicitly\n // managing destroyed.\n this._readableState.destroyed = value\n }\n },\n readableEnded: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._readableState ? this._readableState.endEmitted : false\n }\n }\n})\nObjectDefineProperties(ReadableState.prototype, {\n // Legacy getter for `pipesCount`.\n pipesCount: {\n __proto__: null,\n get() {\n return this.pipes.length\n }\n },\n // Legacy property for `paused`.\n paused: {\n __proto__: null,\n get() {\n return this[kPaused] !== false\n },\n set(value) {\n this[kPaused] = !!value\n }\n }\n})\n\n// Exposed for testing purposes only.\nReadable._fromList = fromList\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered.\n if (state.length === 0) return null\n let ret\n if (state.objectMode) ret = state.buffer.shift()\n else if (!n || n >= state.length) {\n // Read it all, truncate the list.\n if (state.decoder) ret = state.buffer.join('')\n else if (state.buffer.length === 1) ret = state.buffer.first()\n else ret = state.buffer.concat(state.length)\n state.buffer.clear()\n } else {\n // read part of list.\n ret = state.buffer.consume(n, state.decoder)\n }\n return ret\n}\nfunction endReadable(stream) {\n const state = stream._readableState\n debug('endReadable', state.endEmitted)\n if (!state.endEmitted) {\n state.ended = true\n process.nextTick(endReadableNT, state, stream)\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length)\n\n // Check that we didn't get one last unshift.\n if (!state.errored && !state.closeEmitted && !state.endEmitted && state.length === 0) {\n state.endEmitted = true\n stream.emit('end')\n if (stream.writable && stream.allowHalfOpen === false) {\n process.nextTick(endWritableNT, stream)\n } else if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well.\n const wState = stream._writableState\n const autoDestroy =\n !wState ||\n (wState.autoDestroy &&\n // We don't expect the writable to ever 'finish'\n // if writable is explicitly set to false.\n (wState.finished || wState.writable === false))\n if (autoDestroy) {\n stream.destroy()\n }\n }\n }\n}\nfunction endWritableNT(stream) {\n const writable = stream.writable && !stream.writableEnded && !stream.destroyed\n if (writable) {\n stream.end()\n }\n}\nReadable.from = function (iterable, opts) {\n return from(Readable, iterable, opts)\n}\nlet webStreamsAdapters\n\n// Lazy to avoid circular references\nfunction lazyWebStreams() {\n if (webStreamsAdapters === undefined) webStreamsAdapters = {}\n return webStreamsAdapters\n}\nReadable.fromWeb = function (readableStream, options) {\n return lazyWebStreams().newStreamReadableFromReadableStream(readableStream, options)\n}\nReadable.toWeb = function (streamReadable, options) {\n return lazyWebStreams().newReadableStreamFromStreamReadable(streamReadable, options)\n}\nReadable.wrap = function (src, options) {\n var _ref, _src$readableObjectMo\n return new Readable({\n objectMode:\n (_ref =\n (_src$readableObjectMo = src.readableObjectMode) !== null && _src$readableObjectMo !== undefined\n ? _src$readableObjectMo\n : src.objectMode) !== null && _ref !== undefined\n ? _ref\n : true,\n ...options,\n destroy(err, callback) {\n destroyImpl.destroyer(src, err)\n callback(err)\n }\n }).wrap(src)\n}\n","/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n;('use strict')\nconst {\n ArrayPrototypeSlice,\n Error,\n FunctionPrototypeSymbolHasInstance,\n ObjectDefineProperty,\n ObjectDefineProperties,\n ObjectSetPrototypeOf,\n StringPrototypeToLowerCase,\n Symbol,\n SymbolHasInstance\n} = require('../../ours/primordials')\nmodule.exports = Writable\nWritable.WritableState = WritableState\nconst { EventEmitter: EE } = require('events')\nconst Stream = require('./legacy').Stream\nconst { Buffer } = require('buffer')\nconst destroyImpl = require('./destroy')\nconst { addAbortSignal } = require('./add-abort-signal')\nconst { getHighWaterMark, getDefaultHighWaterMark } = require('./state')\nconst {\n ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED,\n ERR_STREAM_ALREADY_FINISHED,\n ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING\n} = require('../../ours/errors').codes\nconst { errorOrDestroy } = destroyImpl\nObjectSetPrototypeOf(Writable.prototype, Stream.prototype)\nObjectSetPrototypeOf(Writable, Stream)\nfunction nop() {}\nconst kOnFinished = Symbol('kOnFinished')\nfunction WritableState(options, stream, isDuplex) {\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof require('./duplex')\n\n // Object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!(options && options.objectMode)\n if (isDuplex) this.objectMode = this.objectMode || !!(options && options.writableObjectMode)\n\n // The point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write().\n this.highWaterMark = options\n ? getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex)\n : getDefaultHighWaterMark(false)\n\n // if _final has been called.\n this.finalCalled = false\n\n // drain event flag.\n this.needDrain = false\n // At the start of calling end()\n this.ending = false\n // When end() has been called, and returned.\n this.ended = false\n // When 'finish' is emitted.\n this.finished = false\n\n // Has it been destroyed\n this.destroyed = false\n\n // Should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n const noDecode = !!(options && options.decodeStrings === false)\n this.decodeStrings = !noDecode\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = (options && options.defaultEncoding) || 'utf8'\n\n // Not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0\n\n // A flag to see when we're in the middle of a write.\n this.writing = false\n\n // When true all writes will be buffered until .uncork() call.\n this.corked = 0\n\n // A flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true\n\n // A flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false\n\n // The callback that's passed to _write(chunk, cb).\n this.onwrite = onwrite.bind(undefined, stream)\n\n // The callback that the user supplies to write(chunk, encoding, cb).\n this.writecb = null\n\n // The amount that is being written when _write is called.\n this.writelen = 0\n\n // Storage for data passed to the afterWrite() callback in case of\n // synchronous _write() completion.\n this.afterWriteTickInfo = null\n resetBuffer(this)\n\n // Number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted.\n this.pendingcb = 0\n\n // Stream is still being constructed and cannot be\n // destroyed until construction finished or failed.\n // Async construction is opt in, therefore we start as\n // constructed.\n this.constructed = true\n\n // Emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams.\n this.prefinished = false\n\n // True if the error was already emitted and should not be thrown again.\n this.errorEmitted = false\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = !options || options.emitClose !== false\n\n // Should .destroy() be called after 'finish' (and potentially 'end').\n this.autoDestroy = !options || options.autoDestroy !== false\n\n // Indicates whether the stream has errored. When true all write() calls\n // should return false. This is needed since when autoDestroy\n // is disabled we need a way to tell whether the stream has failed.\n this.errored = null\n\n // Indicates whether the stream has finished destroying.\n this.closed = false\n\n // True if close has been emitted or would have been emitted\n // depending on emitClose.\n this.closeEmitted = false\n this[kOnFinished] = []\n}\nfunction resetBuffer(state) {\n state.buffered = []\n state.bufferedIndex = 0\n state.allBuffers = true\n state.allNoop = true\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n return ArrayPrototypeSlice(this.buffered, this.bufferedIndex)\n}\nObjectDefineProperty(WritableState.prototype, 'bufferedRequestCount', {\n __proto__: null,\n get() {\n return this.buffered.length - this.bufferedIndex\n }\n})\nfunction Writable(options) {\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5.\n const isDuplex = this instanceof require('./duplex')\n if (!isDuplex && !FunctionPrototypeSymbolHasInstance(Writable, this)) return new Writable(options)\n this._writableState = new WritableState(options, this, isDuplex)\n if (options) {\n if (typeof options.write === 'function') this._write = options.write\n if (typeof options.writev === 'function') this._writev = options.writev\n if (typeof options.destroy === 'function') this._destroy = options.destroy\n if (typeof options.final === 'function') this._final = options.final\n if (typeof options.construct === 'function') this._construct = options.construct\n if (options.signal) addAbortSignal(options.signal, this)\n }\n Stream.call(this, options)\n destroyImpl.construct(this, () => {\n const state = this._writableState\n if (!state.writing) {\n clearBuffer(this, state)\n }\n finishMaybe(this, state)\n })\n}\nObjectDefineProperty(Writable, SymbolHasInstance, {\n __proto__: null,\n value: function (object) {\n if (FunctionPrototypeSymbolHasInstance(this, object)) return true\n if (this !== Writable) return false\n return object && object._writableState instanceof WritableState\n }\n})\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE())\n}\nfunction _write(stream, chunk, encoding, cb) {\n const state = stream._writableState\n if (typeof encoding === 'function') {\n cb = encoding\n encoding = state.defaultEncoding\n } else {\n if (!encoding) encoding = state.defaultEncoding\n else if (encoding !== 'buffer' && !Buffer.isEncoding(encoding)) throw new ERR_UNKNOWN_ENCODING(encoding)\n if (typeof cb !== 'function') cb = nop\n }\n if (chunk === null) {\n throw new ERR_STREAM_NULL_VALUES()\n } else if (!state.objectMode) {\n if (typeof chunk === 'string') {\n if (state.decodeStrings !== false) {\n chunk = Buffer.from(chunk, encoding)\n encoding = 'buffer'\n }\n } else if (chunk instanceof Buffer) {\n encoding = 'buffer'\n } else if (Stream._isUint8Array(chunk)) {\n chunk = Stream._uint8ArrayToBuffer(chunk)\n encoding = 'buffer'\n } else {\n throw new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk)\n }\n }\n let err\n if (state.ending) {\n err = new ERR_STREAM_WRITE_AFTER_END()\n } else if (state.destroyed) {\n err = new ERR_STREAM_DESTROYED('write')\n }\n if (err) {\n process.nextTick(cb, err)\n errorOrDestroy(stream, err, true)\n return err\n }\n state.pendingcb++\n return writeOrBuffer(stream, state, chunk, encoding, cb)\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n return _write(this, chunk, encoding, cb) === true\n}\nWritable.prototype.cork = function () {\n this._writableState.corked++\n}\nWritable.prototype.uncork = function () {\n const state = this._writableState\n if (state.corked) {\n state.corked--\n if (!state.writing) clearBuffer(this, state)\n }\n}\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = StringPrototypeToLowerCase(encoding)\n if (!Buffer.isEncoding(encoding)) throw new ERR_UNKNOWN_ENCODING(encoding)\n this._writableState.defaultEncoding = encoding\n return this\n}\n\n// If we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, callback) {\n const len = state.objectMode ? 1 : chunk.length\n state.length += len\n\n // stream._write resets state.length\n const ret = state.length < state.highWaterMark\n // We must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true\n if (state.writing || state.corked || state.errored || !state.constructed) {\n state.buffered.push({\n chunk,\n encoding,\n callback\n })\n if (state.allBuffers && encoding !== 'buffer') {\n state.allBuffers = false\n }\n if (state.allNoop && callback !== nop) {\n state.allNoop = false\n }\n } else {\n state.writelen = len\n state.writecb = callback\n state.writing = true\n state.sync = true\n stream._write(chunk, encoding, state.onwrite)\n state.sync = false\n }\n\n // Return false if errored or destroyed in order to break\n // any synchronous while(stream.write(data)) loops.\n return ret && !state.errored && !state.destroyed\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len\n state.writecb = cb\n state.writing = true\n state.sync = true\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'))\n else if (writev) stream._writev(chunk, state.onwrite)\n else stream._write(chunk, encoding, state.onwrite)\n state.sync = false\n}\nfunction onwriteError(stream, state, er, cb) {\n --state.pendingcb\n cb(er)\n // Ensure callbacks are invoked even when autoDestroy is\n // not enabled. Passing `er` here doesn't make sense since\n // it's related to one specific write, not to the buffered\n // writes.\n errorBuffer(state)\n // This can emit error, but error must always follow cb.\n errorOrDestroy(stream, er)\n}\nfunction onwrite(stream, er) {\n const state = stream._writableState\n const sync = state.sync\n const cb = state.writecb\n if (typeof cb !== 'function') {\n errorOrDestroy(stream, new ERR_MULTIPLE_CALLBACK())\n return\n }\n state.writing = false\n state.writecb = null\n state.length -= state.writelen\n state.writelen = 0\n if (er) {\n // Avoid V8 leak, https://github.com/nodejs/node/pull/34103#issuecomment-652002364\n er.stack // eslint-disable-line no-unused-expressions\n\n if (!state.errored) {\n state.errored = er\n }\n\n // In case of duplex streams we need to notify the readable side of the\n // error.\n if (stream._readableState && !stream._readableState.errored) {\n stream._readableState.errored = er\n }\n if (sync) {\n process.nextTick(onwriteError, stream, state, er, cb)\n } else {\n onwriteError(stream, state, er, cb)\n }\n } else {\n if (state.buffered.length > state.bufferedIndex) {\n clearBuffer(stream, state)\n }\n if (sync) {\n // It is a common case that the callback passed to .write() is always\n // the same. In that case, we do not schedule a new nextTick(), but\n // rather just increase a counter, to improve performance and avoid\n // memory allocations.\n if (state.afterWriteTickInfo !== null && state.afterWriteTickInfo.cb === cb) {\n state.afterWriteTickInfo.count++\n } else {\n state.afterWriteTickInfo = {\n count: 1,\n cb,\n stream,\n state\n }\n process.nextTick(afterWriteTick, state.afterWriteTickInfo)\n }\n } else {\n afterWrite(stream, state, 1, cb)\n }\n }\n}\nfunction afterWriteTick({ stream, state, count, cb }) {\n state.afterWriteTickInfo = null\n return afterWrite(stream, state, count, cb)\n}\nfunction afterWrite(stream, state, count, cb) {\n const needDrain = !state.ending && !stream.destroyed && state.length === 0 && state.needDrain\n if (needDrain) {\n state.needDrain = false\n stream.emit('drain')\n }\n while (count-- > 0) {\n state.pendingcb--\n cb()\n }\n if (state.destroyed) {\n errorBuffer(state)\n }\n finishMaybe(stream, state)\n}\n\n// If there's something in the buffer waiting, then invoke callbacks.\nfunction errorBuffer(state) {\n if (state.writing) {\n return\n }\n for (let n = state.bufferedIndex; n < state.buffered.length; ++n) {\n var _state$errored\n const { chunk, callback } = state.buffered[n]\n const len = state.objectMode ? 1 : chunk.length\n state.length -= len\n callback(\n (_state$errored = state.errored) !== null && _state$errored !== undefined\n ? _state$errored\n : new ERR_STREAM_DESTROYED('write')\n )\n }\n const onfinishCallbacks = state[kOnFinished].splice(0)\n for (let i = 0; i < onfinishCallbacks.length; i++) {\n var _state$errored2\n onfinishCallbacks[i](\n (_state$errored2 = state.errored) !== null && _state$errored2 !== undefined\n ? _state$errored2\n : new ERR_STREAM_DESTROYED('end')\n )\n }\n resetBuffer(state)\n}\n\n// If there's something in the buffer waiting, then process it.\nfunction clearBuffer(stream, state) {\n if (state.corked || state.bufferProcessing || state.destroyed || !state.constructed) {\n return\n }\n const { buffered, bufferedIndex, objectMode } = state\n const bufferedLength = buffered.length - bufferedIndex\n if (!bufferedLength) {\n return\n }\n let i = bufferedIndex\n state.bufferProcessing = true\n if (bufferedLength > 1 && stream._writev) {\n state.pendingcb -= bufferedLength - 1\n const callback = state.allNoop\n ? nop\n : (err) => {\n for (let n = i; n < buffered.length; ++n) {\n buffered[n].callback(err)\n }\n }\n // Make a copy of `buffered` if it's going to be used by `callback` above,\n // since `doWrite` will mutate the array.\n const chunks = state.allNoop && i === 0 ? buffered : ArrayPrototypeSlice(buffered, i)\n chunks.allBuffers = state.allBuffers\n doWrite(stream, state, true, state.length, chunks, '', callback)\n resetBuffer(state)\n } else {\n do {\n const { chunk, encoding, callback } = buffered[i]\n buffered[i++] = null\n const len = objectMode ? 1 : chunk.length\n doWrite(stream, state, false, len, chunk, encoding, callback)\n } while (i < buffered.length && !state.writing)\n if (i === buffered.length) {\n resetBuffer(state)\n } else if (i > 256) {\n buffered.splice(0, i)\n state.bufferedIndex = 0\n } else {\n state.bufferedIndex = i\n }\n }\n state.bufferProcessing = false\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n if (this._writev) {\n this._writev(\n [\n {\n chunk,\n encoding\n }\n ],\n cb\n )\n } else {\n throw new ERR_METHOD_NOT_IMPLEMENTED('_write()')\n }\n}\nWritable.prototype._writev = null\nWritable.prototype.end = function (chunk, encoding, cb) {\n const state = this._writableState\n if (typeof chunk === 'function') {\n cb = chunk\n chunk = null\n encoding = null\n } else if (typeof encoding === 'function') {\n cb = encoding\n encoding = null\n }\n let err\n if (chunk !== null && chunk !== undefined) {\n const ret = _write(this, chunk, encoding)\n if (ret instanceof Error) {\n err = ret\n }\n }\n\n // .end() fully uncorks.\n if (state.corked) {\n state.corked = 1\n this.uncork()\n }\n if (err) {\n // Do nothing...\n } else if (!state.errored && !state.ending) {\n // This is forgiving in terms of unnecessary calls to end() and can hide\n // logic errors. However, usually such errors are harmless and causing a\n // hard error can be disproportionately destructive. It is not always\n // trivial for the user to determine whether end() needs to be called\n // or not.\n\n state.ending = true\n finishMaybe(this, state, true)\n state.ended = true\n } else if (state.finished) {\n err = new ERR_STREAM_ALREADY_FINISHED('end')\n } else if (state.destroyed) {\n err = new ERR_STREAM_DESTROYED('end')\n }\n if (typeof cb === 'function') {\n if (err || state.finished) {\n process.nextTick(cb, err)\n } else {\n state[kOnFinished].push(cb)\n }\n }\n return this\n}\nfunction needFinish(state) {\n return (\n state.ending &&\n !state.destroyed &&\n state.constructed &&\n state.length === 0 &&\n !state.errored &&\n state.buffered.length === 0 &&\n !state.finished &&\n !state.writing &&\n !state.errorEmitted &&\n !state.closeEmitted\n )\n}\nfunction callFinal(stream, state) {\n let called = false\n function onFinish(err) {\n if (called) {\n errorOrDestroy(stream, err !== null && err !== undefined ? err : ERR_MULTIPLE_CALLBACK())\n return\n }\n called = true\n state.pendingcb--\n if (err) {\n const onfinishCallbacks = state[kOnFinished].splice(0)\n for (let i = 0; i < onfinishCallbacks.length; i++) {\n onfinishCallbacks[i](err)\n }\n errorOrDestroy(stream, err, state.sync)\n } else if (needFinish(state)) {\n state.prefinished = true\n stream.emit('prefinish')\n // Backwards compat. Don't check state.sync here.\n // Some streams assume 'finish' will be emitted\n // asynchronously relative to _final callback.\n state.pendingcb++\n process.nextTick(finish, stream, state)\n }\n }\n state.sync = true\n state.pendingcb++\n try {\n stream._final(onFinish)\n } catch (err) {\n onFinish(err)\n }\n state.sync = false\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.finalCalled = true\n callFinal(stream, state)\n } else {\n state.prefinished = true\n stream.emit('prefinish')\n }\n }\n}\nfunction finishMaybe(stream, state, sync) {\n if (needFinish(state)) {\n prefinish(stream, state)\n if (state.pendingcb === 0) {\n if (sync) {\n state.pendingcb++\n process.nextTick(\n (stream, state) => {\n if (needFinish(state)) {\n finish(stream, state)\n } else {\n state.pendingcb--\n }\n },\n stream,\n state\n )\n } else if (needFinish(state)) {\n state.pendingcb++\n finish(stream, state)\n }\n }\n }\n}\nfunction finish(stream, state) {\n state.pendingcb--\n state.finished = true\n const onfinishCallbacks = state[kOnFinished].splice(0)\n for (let i = 0; i < onfinishCallbacks.length; i++) {\n onfinishCallbacks[i]()\n }\n stream.emit('finish')\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well.\n const rState = stream._readableState\n const autoDestroy =\n !rState ||\n (rState.autoDestroy &&\n // We don't expect the readable to ever 'end'\n // if readable is explicitly set to false.\n (rState.endEmitted || rState.readable === false))\n if (autoDestroy) {\n stream.destroy()\n }\n }\n}\nObjectDefineProperties(Writable.prototype, {\n closed: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.closed : false\n }\n },\n destroyed: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.destroyed : false\n },\n set(value) {\n // Backward compatibility, the user is explicitly managing destroyed.\n if (this._writableState) {\n this._writableState.destroyed = value\n }\n }\n },\n writable: {\n __proto__: null,\n get() {\n const w = this._writableState\n // w.writable === false means that this is part of a Duplex stream\n // where the writable side was disabled upon construction.\n // Compat. The user might manually disable writable side through\n // deprecated setter.\n return !!w && w.writable !== false && !w.destroyed && !w.errored && !w.ending && !w.ended\n },\n set(val) {\n // Backwards compatible.\n if (this._writableState) {\n this._writableState.writable = !!val\n }\n }\n },\n writableFinished: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.finished : false\n }\n },\n writableObjectMode: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.objectMode : false\n }\n },\n writableBuffer: {\n __proto__: null,\n get() {\n return this._writableState && this._writableState.getBuffer()\n }\n },\n writableEnded: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.ending : false\n }\n },\n writableNeedDrain: {\n __proto__: null,\n get() {\n const wState = this._writableState\n if (!wState) return false\n return !wState.destroyed && !wState.ending && wState.needDrain\n }\n },\n writableHighWaterMark: {\n __proto__: null,\n get() {\n return this._writableState && this._writableState.highWaterMark\n }\n },\n writableCorked: {\n __proto__: null,\n get() {\n return this._writableState ? this._writableState.corked : 0\n }\n },\n writableLength: {\n __proto__: null,\n get() {\n return this._writableState && this._writableState.length\n }\n },\n errored: {\n __proto__: null,\n enumerable: false,\n get() {\n return this._writableState ? this._writableState.errored : null\n }\n },\n writableAborted: {\n __proto__: null,\n enumerable: false,\n get: function () {\n return !!(\n this._writableState.writable !== false &&\n (this._writableState.destroyed || this._writableState.errored) &&\n !this._writableState.finished\n )\n }\n }\n})\nconst destroy = destroyImpl.destroy\nWritable.prototype.destroy = function (err, cb) {\n const state = this._writableState\n\n // Invoke pending callbacks.\n if (!state.destroyed && (state.bufferedIndex < state.buffered.length || state[kOnFinished].length)) {\n process.nextTick(errorBuffer, state)\n }\n destroy.call(this, err, cb)\n return this\n}\nWritable.prototype._undestroy = destroyImpl.undestroy\nWritable.prototype._destroy = function (err, cb) {\n cb(err)\n}\nWritable.prototype[EE.captureRejectionSymbol] = function (err) {\n this.destroy(err)\n}\nlet webStreamsAdapters\n\n// Lazy to avoid circular references\nfunction lazyWebStreams() {\n if (webStreamsAdapters === undefined) webStreamsAdapters = {}\n return webStreamsAdapters\n}\nWritable.fromWeb = function (writableStream, options) {\n return lazyWebStreams().newStreamWritableFromWritableStream(writableStream, options)\n}\nWritable.toWeb = function (streamWritable) {\n return lazyWebStreams().newWritableStreamFromStreamWritable(streamWritable)\n}\n","/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n\n;('use strict')\nconst bufferModule = require('buffer')\nconst {\n isReadable,\n isWritable,\n isIterable,\n isNodeStream,\n isReadableNodeStream,\n isWritableNodeStream,\n isDuplexNodeStream,\n isReadableStream,\n isWritableStream\n} = require('./utils')\nconst eos = require('./end-of-stream')\nconst {\n AbortError,\n codes: { ERR_INVALID_ARG_TYPE, ERR_INVALID_RETURN_VALUE }\n} = require('../../ours/errors')\nconst { destroyer } = require('./destroy')\nconst Duplex = require('./duplex')\nconst Readable = require('./readable')\nconst Writable = require('./writable')\nconst { createDeferredPromise } = require('../../ours/util')\nconst from = require('./from')\nconst Blob = globalThis.Blob || bufferModule.Blob\nconst isBlob =\n typeof Blob !== 'undefined'\n ? function isBlob(b) {\n return b instanceof Blob\n }\n : function isBlob(b) {\n return false\n }\nconst AbortController = globalThis.AbortController || require('abort-controller').AbortController\nconst { FunctionPrototypeCall } = require('../../ours/primordials')\n\n// This is needed for pre node 17.\nclass Duplexify extends Duplex {\n constructor(options) {\n super(options)\n\n // https://github.com/nodejs/node/pull/34385\n\n if ((options === null || options === undefined ? undefined : options.readable) === false) {\n this._readableState.readable = false\n this._readableState.ended = true\n this._readableState.endEmitted = true\n }\n if ((options === null || options === undefined ? undefined : options.writable) === false) {\n this._writableState.writable = false\n this._writableState.ending = true\n this._writableState.ended = true\n this._writableState.finished = true\n }\n }\n}\nmodule.exports = function duplexify(body, name) {\n if (isDuplexNodeStream(body)) {\n return body\n }\n if (isReadableNodeStream(body)) {\n return _duplexify({\n readable: body\n })\n }\n if (isWritableNodeStream(body)) {\n return _duplexify({\n writable: body\n })\n }\n if (isNodeStream(body)) {\n return _duplexify({\n writable: false,\n readable: false\n })\n }\n if (isReadableStream(body)) {\n return _duplexify({\n readable: Readable.fromWeb(body)\n })\n }\n if (isWritableStream(body)) {\n return _duplexify({\n writable: Writable.fromWeb(body)\n })\n }\n if (typeof body === 'function') {\n const { value, write, final, destroy } = fromAsyncGen(body)\n if (isIterable(value)) {\n return from(Duplexify, value, {\n // TODO (ronag): highWaterMark?\n objectMode: true,\n write,\n final,\n destroy\n })\n }\n const then = value === null || value === undefined ? undefined : value.then\n if (typeof then === 'function') {\n let d\n const promise = FunctionPrototypeCall(\n then,\n value,\n (val) => {\n if (val != null) {\n throw new ERR_INVALID_RETURN_VALUE('nully', 'body', val)\n }\n },\n (err) => {\n destroyer(d, err)\n }\n )\n return (d = new Duplexify({\n // TODO (ronag): highWaterMark?\n objectMode: true,\n readable: false,\n write,\n final(cb) {\n final(async () => {\n try {\n await promise\n process.nextTick(cb, null)\n } catch (err) {\n process.nextTick(cb, err)\n }\n })\n },\n destroy\n }))\n }\n throw new ERR_INVALID_RETURN_VALUE('Iterable, AsyncIterable or AsyncFunction', name, value)\n }\n if (isBlob(body)) {\n return duplexify(body.arrayBuffer())\n }\n if (isIterable(body)) {\n return from(Duplexify, body, {\n // TODO (ronag): highWaterMark?\n objectMode: true,\n writable: false\n })\n }\n if (\n isReadableStream(body === null || body === undefined ? undefined : body.readable) &&\n isWritableStream(body === null || body === undefined ? undefined : body.writable)\n ) {\n return Duplexify.fromWeb(body)\n }\n if (\n typeof (body === null || body === undefined ? undefined : body.writable) === 'object' ||\n typeof (body === null || body === undefined ? undefined : body.readable) === 'object'\n ) {\n const readable =\n body !== null && body !== undefined && body.readable\n ? isReadableNodeStream(body === null || body === undefined ? undefined : body.readable)\n ? body === null || body === undefined\n ? undefined\n : body.readable\n : duplexify(body.readable)\n : undefined\n const writable =\n body !== null && body !== undefined && body.writable\n ? isWritableNodeStream(body === null || body === undefined ? undefined : body.writable)\n ? body === null || body === undefined\n ? undefined\n : body.writable\n : duplexify(body.writable)\n : undefined\n return _duplexify({\n readable,\n writable\n })\n }\n const then = body === null || body === undefined ? undefined : body.then\n if (typeof then === 'function') {\n let d\n FunctionPrototypeCall(\n then,\n body,\n (val) => {\n if (val != null) {\n d.push(val)\n }\n d.push(null)\n },\n (err) => {\n destroyer(d, err)\n }\n )\n return (d = new Duplexify({\n objectMode: true,\n writable: false,\n read() {}\n }))\n }\n throw new ERR_INVALID_ARG_TYPE(\n name,\n [\n 'Blob',\n 'ReadableStream',\n 'WritableStream',\n 'Stream',\n 'Iterable',\n 'AsyncIterable',\n 'Function',\n '{ readable, writable } pair',\n 'Promise'\n ],\n body\n )\n}\nfunction fromAsyncGen(fn) {\n let { promise, resolve } = createDeferredPromise()\n const ac = new AbortController()\n const signal = ac.signal\n const value = fn(\n (async function* () {\n while (true) {\n const _promise = promise\n promise = null\n const { chunk, done, cb } = await _promise\n process.nextTick(cb)\n if (done) return\n if (signal.aborted)\n throw new AbortError(undefined, {\n cause: signal.reason\n })\n ;({ promise, resolve } = createDeferredPromise())\n yield chunk\n }\n })(),\n {\n signal\n }\n )\n return {\n value,\n write(chunk, encoding, cb) {\n const _resolve = resolve\n resolve = null\n _resolve({\n chunk,\n done: false,\n cb\n })\n },\n final(cb) {\n const _resolve = resolve\n resolve = null\n _resolve({\n done: true,\n cb\n })\n },\n destroy(err, cb) {\n ac.abort()\n cb(err)\n }\n }\n}\nfunction _duplexify(pair) {\n const r = pair.readable && typeof pair.readable.read !== 'function' ? Readable.wrap(pair.readable) : pair.readable\n const w = pair.writable\n let readable = !!isReadable(r)\n let writable = !!isWritable(w)\n let ondrain\n let onfinish\n let onreadable\n let onclose\n let d\n function onfinished(err) {\n const cb = onclose\n onclose = null\n if (cb) {\n cb(err)\n } else if (err) {\n d.destroy(err)\n }\n }\n\n // TODO(ronag): Avoid double buffering.\n // Implement Writable/Readable/Duplex traits.\n // See, https://github.com/nodejs/node/pull/33515.\n d = new Duplexify({\n // TODO (ronag): highWaterMark?\n readableObjectMode: !!(r !== null && r !== undefined && r.readableObjectMode),\n writableObjectMode: !!(w !== null && w !== undefined && w.writableObjectMode),\n readable,\n writable\n })\n if (writable) {\n eos(w, (err) => {\n writable = false\n if (err) {\n destroyer(r, err)\n }\n onfinished(err)\n })\n d._write = function (chunk, encoding, callback) {\n if (w.write(chunk, encoding)) {\n callback()\n } else {\n ondrain = callback\n }\n }\n d._final = function (callback) {\n w.end()\n onfinish = callback\n }\n w.on('drain', function () {\n if (ondrain) {\n const cb = ondrain\n ondrain = null\n cb()\n }\n })\n w.on('finish', function () {\n if (onfinish) {\n const cb = onfinish\n onfinish = null\n cb()\n }\n })\n }\n if (readable) {\n eos(r, (err) => {\n readable = false\n if (err) {\n destroyer(r, err)\n }\n onfinished(err)\n })\n r.on('readable', function () {\n if (onreadable) {\n const cb = onreadable\n onreadable = null\n cb()\n }\n })\n r.on('end', function () {\n d.push(null)\n })\n d._read = function () {\n while (true) {\n const buf = r.read()\n if (buf === null) {\n onreadable = d._read\n return\n }\n if (!d.push(buf)) {\n return\n }\n }\n }\n }\n d._destroy = function (err, callback) {\n if (!err && onclose !== null) {\n err = new AbortError()\n }\n onreadable = null\n ondrain = null\n onfinish = null\n if (onclose === null) {\n callback(err)\n } else {\n onclose = callback\n destroyer(w, err)\n destroyer(r, err)\n }\n }\n return d\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototype inheritance, this class\n// prototypically inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict'\n\nconst {\n ObjectDefineProperties,\n ObjectGetOwnPropertyDescriptor,\n ObjectKeys,\n ObjectSetPrototypeOf\n} = require('../../ours/primordials')\nmodule.exports = Duplex\nconst Readable = require('./readable')\nconst Writable = require('./writable')\nObjectSetPrototypeOf(Duplex.prototype, Readable.prototype)\nObjectSetPrototypeOf(Duplex, Readable)\n{\n const keys = ObjectKeys(Writable.prototype)\n // Allow the keys array to be GC'ed.\n for (let i = 0; i < keys.length; i++) {\n const method = keys[i]\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options)\n Readable.call(this, options)\n Writable.call(this, options)\n if (options) {\n this.allowHalfOpen = options.allowHalfOpen !== false\n if (options.readable === false) {\n this._readableState.readable = false\n this._readableState.ended = true\n this._readableState.endEmitted = true\n }\n if (options.writable === false) {\n this._writableState.writable = false\n this._writableState.ending = true\n this._writableState.ended = true\n this._writableState.finished = true\n }\n } else {\n this.allowHalfOpen = true\n }\n}\nObjectDefineProperties(Duplex.prototype, {\n writable: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writable')\n },\n writableHighWaterMark: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableHighWaterMark')\n },\n writableObjectMode: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableObjectMode')\n },\n writableBuffer: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableBuffer')\n },\n writableLength: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableLength')\n },\n writableFinished: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableFinished')\n },\n writableCorked: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableCorked')\n },\n writableEnded: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableEnded')\n },\n writableNeedDrain: {\n __proto__: null,\n ...ObjectGetOwnPropertyDescriptor(Writable.prototype, 'writableNeedDrain')\n },\n destroyed: {\n __proto__: null,\n get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false\n }\n return this._readableState.destroyed && this._writableState.destroyed\n },\n set(value) {\n // Backward compatibility, the user is explicitly\n // managing destroyed.\n if (this._readableState && this._writableState) {\n this._readableState.destroyed = value\n this._writableState.destroyed = value\n }\n }\n }\n})\nlet webStreamsAdapters\n\n// Lazy to avoid circular references\nfunction lazyWebStreams() {\n if (webStreamsAdapters === undefined) webStreamsAdapters = {}\n return webStreamsAdapters\n}\nDuplex.fromWeb = function (pair, options) {\n return lazyWebStreams().newStreamDuplexFromReadableWritablePair(pair, options)\n}\nDuplex.toWeb = function (duplex) {\n return lazyWebStreams().newReadableWritablePairFromDuplex(duplex)\n}\nlet duplexify\nDuplex.from = function (body) {\n if (!duplexify) {\n duplexify = require('./duplexify')\n }\n return duplexify(body, 'body')\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict'\n\nconst { ObjectSetPrototypeOf, Symbol } = require('../../ours/primordials')\nmodule.exports = Transform\nconst { ERR_METHOD_NOT_IMPLEMENTED } = require('../../ours/errors').codes\nconst Duplex = require('./duplex')\nconst { getHighWaterMark } = require('./state')\nObjectSetPrototypeOf(Transform.prototype, Duplex.prototype)\nObjectSetPrototypeOf(Transform, Duplex)\nconst kCallback = Symbol('kCallback')\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options)\n\n // TODO (ronag): This should preferably always be\n // applied but would be semver-major. Or even better;\n // make Transform a Readable with the Writable interface.\n const readableHighWaterMark = options ? getHighWaterMark(this, options, 'readableHighWaterMark', true) : null\n if (readableHighWaterMark === 0) {\n // A Duplex will buffer both on the writable and readable side while\n // a Transform just wants to buffer hwm number of elements. To avoid\n // buffering twice we disable buffering on the writable side.\n options = {\n ...options,\n highWaterMark: null,\n readableHighWaterMark,\n // TODO (ronag): 0 is not optimal since we have\n // a \"bug\" where we check needDrain before calling _write and not after.\n // Refs: https://github.com/nodejs/node/pull/32887\n // Refs: https://github.com/nodejs/node/pull/35941\n writableHighWaterMark: options.writableHighWaterMark || 0\n }\n }\n Duplex.call(this, options)\n\n // We have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false\n this[kCallback] = null\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform\n if (typeof options.flush === 'function') this._flush = options.flush\n }\n\n // When the writable side finishes, then flush out anything remaining.\n // Backwards compat. Some Transform streams incorrectly implement _final\n // instead of or in addition to _flush. By using 'prefinish' instead of\n // implementing _final we continue supporting this unfortunate use case.\n this.on('prefinish', prefinish)\n}\nfunction final(cb) {\n if (typeof this._flush === 'function' && !this.destroyed) {\n this._flush((er, data) => {\n if (er) {\n if (cb) {\n cb(er)\n } else {\n this.destroy(er)\n }\n return\n }\n if (data != null) {\n this.push(data)\n }\n this.push(null)\n if (cb) {\n cb()\n }\n })\n } else {\n this.push(null)\n if (cb) {\n cb()\n }\n }\n}\nfunction prefinish() {\n if (this._final !== final) {\n final.call(this)\n }\n}\nTransform.prototype._final = final\nTransform.prototype._transform = function (chunk, encoding, callback) {\n throw new ERR_METHOD_NOT_IMPLEMENTED('_transform()')\n}\nTransform.prototype._write = function (chunk, encoding, callback) {\n const rState = this._readableState\n const wState = this._writableState\n const length = rState.length\n this._transform(chunk, encoding, (err, val) => {\n if (err) {\n callback(err)\n return\n }\n if (val != null) {\n this.push(val)\n }\n if (\n wState.ended ||\n // Backwards compat.\n length === rState.length ||\n // Backwards compat.\n rState.length < rState.highWaterMark\n ) {\n callback()\n } else {\n this[kCallback] = callback\n }\n })\n}\nTransform.prototype._read = function () {\n if (this[kCallback]) {\n const callback = this[kCallback]\n this[kCallback] = null\n callback()\n }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict'\n\nconst { ObjectSetPrototypeOf } = require('../../ours/primordials')\nmodule.exports = PassThrough\nconst Transform = require('./transform')\nObjectSetPrototypeOf(PassThrough.prototype, Transform.prototype)\nObjectSetPrototypeOf(PassThrough, Transform)\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options)\n Transform.call(this, options)\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk)\n}\n","/* replacement start */\n\nconst process = require('process/')\n\n/* replacement end */\n// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n;('use strict')\nconst { ArrayIsArray, Promise, SymbolAsyncIterator, SymbolDispose } = require('../../ours/primordials')\nconst eos = require('./end-of-stream')\nconst { once } = require('../../ours/util')\nconst destroyImpl = require('./destroy')\nconst Duplex = require('./duplex')\nconst {\n aggregateTwoErrors,\n codes: {\n ERR_INVALID_ARG_TYPE,\n ERR_INVALID_RETURN_VALUE,\n ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED,\n ERR_STREAM_PREMATURE_CLOSE\n },\n AbortError\n} = require('../../ours/errors')\nconst { validateFunction, validateAbortSignal } = require('../validators')\nconst {\n isIterable,\n isReadable,\n isReadableNodeStream,\n isNodeStream,\n isTransformStream,\n isWebStream,\n isReadableStream,\n isReadableFinished\n} = require('./utils')\nconst AbortController = globalThis.AbortController || require('abort-controller').AbortController\nlet PassThrough\nlet Readable\nlet addAbortListener\nfunction destroyer(stream, reading, writing) {\n let finished = false\n stream.on('close', () => {\n finished = true\n })\n const cleanup = eos(\n stream,\n {\n readable: reading,\n writable: writing\n },\n (err) => {\n finished = !err\n }\n )\n return {\n destroy: (err) => {\n if (finished) return\n finished = true\n destroyImpl.destroyer(stream, err || new ERR_STREAM_DESTROYED('pipe'))\n },\n cleanup\n }\n}\nfunction popCallback(streams) {\n // Streams should never be an empty array. It should always contain at least\n // a single stream. Therefore optimize for the average case instead of\n // checking for length === 0 as well.\n validateFunction(streams[streams.length - 1], 'streams[stream.length - 1]')\n return streams.pop()\n}\nfunction makeAsyncIterable(val) {\n if (isIterable(val)) {\n return val\n } else if (isReadableNodeStream(val)) {\n // Legacy streams are not Iterable.\n return fromReadable(val)\n }\n throw new ERR_INVALID_ARG_TYPE('val', ['Readable', 'Iterable', 'AsyncIterable'], val)\n}\nasync function* fromReadable(val) {\n if (!Readable) {\n Readable = require('./readable')\n }\n yield* Readable.prototype[SymbolAsyncIterator].call(val)\n}\nasync function pumpToNode(iterable, writable, finish, { end }) {\n let error\n let onresolve = null\n const resume = (err) => {\n if (err) {\n error = err\n }\n if (onresolve) {\n const callback = onresolve\n onresolve = null\n callback()\n }\n }\n const wait = () =>\n new Promise((resolve, reject) => {\n if (error) {\n reject(error)\n } else {\n onresolve = () => {\n if (error) {\n reject(error)\n } else {\n resolve()\n }\n }\n }\n })\n writable.on('drain', resume)\n const cleanup = eos(\n writable,\n {\n readable: false\n },\n resume\n )\n try {\n if (writable.writableNeedDrain) {\n await wait()\n }\n for await (const chunk of iterable) {\n if (!writable.write(chunk)) {\n await wait()\n }\n }\n if (end) {\n writable.end()\n await wait()\n }\n finish()\n } catch (err) {\n finish(error !== err ? aggregateTwoErrors(error, err) : err)\n } finally {\n cleanup()\n writable.off('drain', resume)\n }\n}\nasync function pumpToWeb(readable, writable, finish, { end }) {\n if (isTransformStream(writable)) {\n writable = writable.writable\n }\n // https://streams.spec.whatwg.org/#example-manual-write-with-backpressure\n const writer = writable.getWriter()\n try {\n for await (const chunk of readable) {\n await writer.ready\n writer.write(chunk).catch(() => {})\n }\n await writer.ready\n if (end) {\n await writer.close()\n }\n finish()\n } catch (err) {\n try {\n await writer.abort(err)\n finish(err)\n } catch (err) {\n finish(err)\n }\n }\n}\nfunction pipeline(...streams) {\n return pipelineImpl(streams, once(popCallback(streams)))\n}\nfunction pipelineImpl(streams, callback, opts) {\n if (streams.length === 1 && ArrayIsArray(streams[0])) {\n streams = streams[0]\n }\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams')\n }\n const ac = new AbortController()\n const signal = ac.signal\n const outerSignal = opts === null || opts === undefined ? undefined : opts.signal\n\n // Need to cleanup event listeners if last stream is readable\n // https://github.com/nodejs/node/issues/35452\n const lastStreamCleanup = []\n validateAbortSignal(outerSignal, 'options.signal')\n function abort() {\n finishImpl(new AbortError())\n }\n addAbortListener = addAbortListener || require('../../ours/util').addAbortListener\n let disposable\n if (outerSignal) {\n disposable = addAbortListener(outerSignal, abort)\n }\n let error\n let value\n const destroys = []\n let finishCount = 0\n function finish(err) {\n finishImpl(err, --finishCount === 0)\n }\n function finishImpl(err, final) {\n var _disposable\n if (err && (!error || error.code === 'ERR_STREAM_PREMATURE_CLOSE')) {\n error = err\n }\n if (!error && !final) {\n return\n }\n while (destroys.length) {\n destroys.shift()(error)\n }\n ;(_disposable = disposable) === null || _disposable === undefined ? undefined : _disposable[SymbolDispose]()\n ac.abort()\n if (final) {\n if (!error) {\n lastStreamCleanup.forEach((fn) => fn())\n }\n process.nextTick(callback, error, value)\n }\n }\n let ret\n for (let i = 0; i < streams.length; i++) {\n const stream = streams[i]\n const reading = i < streams.length - 1\n const writing = i > 0\n const end = reading || (opts === null || opts === undefined ? undefined : opts.end) !== false\n const isLastStream = i === streams.length - 1\n if (isNodeStream(stream)) {\n if (end) {\n const { destroy, cleanup } = destroyer(stream, reading, writing)\n destroys.push(destroy)\n if (isReadable(stream) && isLastStream) {\n lastStreamCleanup.push(cleanup)\n }\n }\n\n // Catch stream errors that occur after pipe/pump has completed.\n function onError(err) {\n if (err && err.name !== 'AbortError' && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n finish(err)\n }\n }\n stream.on('error', onError)\n if (isReadable(stream) && isLastStream) {\n lastStreamCleanup.push(() => {\n stream.removeListener('error', onError)\n })\n }\n }\n if (i === 0) {\n if (typeof stream === 'function') {\n ret = stream({\n signal\n })\n if (!isIterable(ret)) {\n throw new ERR_INVALID_RETURN_VALUE('Iterable, AsyncIterable or Stream', 'source', ret)\n }\n } else if (isIterable(stream) || isReadableNodeStream(stream) || isTransformStream(stream)) {\n ret = stream\n } else {\n ret = Duplex.from(stream)\n }\n } else if (typeof stream === 'function') {\n if (isTransformStream(ret)) {\n var _ret\n ret = makeAsyncIterable((_ret = ret) === null || _ret === undefined ? undefined : _ret.readable)\n } else {\n ret = makeAsyncIterable(ret)\n }\n ret = stream(ret, {\n signal\n })\n if (reading) {\n if (!isIterable(ret, true)) {\n throw new ERR_INVALID_RETURN_VALUE('AsyncIterable', `transform[${i - 1}]`, ret)\n }\n } else {\n var _ret2\n if (!PassThrough) {\n PassThrough = require('./passthrough')\n }\n\n // If the last argument to pipeline is not a stream\n // we must create a proxy stream so that pipeline(...)\n // always returns a stream which can be further\n // composed through `.pipe(stream)`.\n\n const pt = new PassThrough({\n objectMode: true\n })\n\n // Handle Promises/A+ spec, `then` could be a getter that throws on\n // second use.\n const then = (_ret2 = ret) === null || _ret2 === undefined ? undefined : _ret2.then\n if (typeof then === 'function') {\n finishCount++\n then.call(\n ret,\n (val) => {\n value = val\n if (val != null) {\n pt.write(val)\n }\n if (end) {\n pt.end()\n }\n process.nextTick(finish)\n },\n (err) => {\n pt.destroy(err)\n process.nextTick(finish, err)\n }\n )\n } else if (isIterable(ret, true)) {\n finishCount++\n pumpToNode(ret, pt, finish, {\n end\n })\n } else if (isReadableStream(ret) || isTransformStream(ret)) {\n const toRead = ret.readable || ret\n finishCount++\n pumpToNode(toRead, pt, finish, {\n end\n })\n } else {\n throw new ERR_INVALID_RETURN_VALUE('AsyncIterable or Promise', 'destination', ret)\n }\n ret = pt\n const { destroy, cleanup } = destroyer(ret, false, true)\n destroys.push(destroy)\n if (isLastStream) {\n lastStreamCleanup.push(cleanup)\n }\n }\n } else if (isNodeStream(stream)) {\n if (isReadableNodeStream(ret)) {\n finishCount += 2\n const cleanup = pipe(ret, stream, finish, {\n end\n })\n if (isReadable(stream) && isLastStream) {\n lastStreamCleanup.push(cleanup)\n }\n } else if (isTransformStream(ret) || isReadableStream(ret)) {\n const toRead = ret.readable || ret\n finishCount++\n pumpToNode(toRead, stream, finish, {\n end\n })\n } else if (isIterable(ret)) {\n finishCount++\n pumpToNode(ret, stream, finish, {\n end\n })\n } else {\n throw new ERR_INVALID_ARG_TYPE(\n 'val',\n ['Readable', 'Iterable', 'AsyncIterable', 'ReadableStream', 'TransformStream'],\n ret\n )\n }\n ret = stream\n } else if (isWebStream(stream)) {\n if (isReadableNodeStream(ret)) {\n finishCount++\n pumpToWeb(makeAsyncIterable(ret), stream, finish, {\n end\n })\n } else if (isReadableStream(ret) || isIterable(ret)) {\n finishCount++\n pumpToWeb(ret, stream, finish, {\n end\n })\n } else if (isTransformStream(ret)) {\n finishCount++\n pumpToWeb(ret.readable, stream, finish, {\n end\n })\n } else {\n throw new ERR_INVALID_ARG_TYPE(\n 'val',\n ['Readable', 'Iterable', 'AsyncIterable', 'ReadableStream', 'TransformStream'],\n ret\n )\n }\n ret = stream\n } else {\n ret = Duplex.from(stream)\n }\n }\n if (\n (signal !== null && signal !== undefined && signal.aborted) ||\n (outerSignal !== null && outerSignal !== undefined && outerSignal.aborted)\n ) {\n process.nextTick(abort)\n }\n return ret\n}\nfunction pipe(src, dst, finish, { end }) {\n let ended = false\n dst.on('close', () => {\n if (!ended) {\n // Finish if the destination closes before the source has completed.\n finish(new ERR_STREAM_PREMATURE_CLOSE())\n }\n })\n src.pipe(dst, {\n end: false\n }) // If end is true we already will have a listener to end dst.\n\n if (end) {\n // Compat. Before node v10.12.0 stdio used to throw an error so\n // pipe() did/does not end() stdio destinations.\n // Now they allow it but \"secretly\" don't close the underlying fd.\n\n function endFn() {\n ended = true\n dst.end()\n }\n if (isReadableFinished(src)) {\n // End the destination if the source has already ended.\n process.nextTick(endFn)\n } else {\n src.once('end', endFn)\n }\n } else {\n finish()\n }\n eos(\n src,\n {\n readable: true,\n writable: false\n },\n (err) => {\n const rState = src._readableState\n if (\n err &&\n err.code === 'ERR_STREAM_PREMATURE_CLOSE' &&\n rState &&\n rState.ended &&\n !rState.errored &&\n !rState.errorEmitted\n ) {\n // Some readable streams will emit 'close' before 'end'. However, since\n // this is on the readable side 'end' should still be emitted if the\n // stream has been ended and no error emitted. This should be allowed in\n // favor of backwards compatibility. Since the stream is piped to a\n // destination this should not result in any observable difference.\n // We don't need to check if this is a writable premature close since\n // eos will only fail with premature close on the reading side for\n // duplex streams.\n src.once('end', finish).once('error', finish)\n } else {\n finish(err)\n }\n }\n )\n return eos(\n dst,\n {\n readable: false,\n writable: true\n },\n finish\n )\n}\nmodule.exports = {\n pipelineImpl,\n pipeline\n}\n","'use strict'\n\nconst { pipeline } = require('./pipeline')\nconst Duplex = require('./duplex')\nconst { destroyer } = require('./destroy')\nconst {\n isNodeStream,\n isReadable,\n isWritable,\n isWebStream,\n isTransformStream,\n isWritableStream,\n isReadableStream\n} = require('./utils')\nconst {\n AbortError,\n codes: { ERR_INVALID_ARG_VALUE, ERR_MISSING_ARGS }\n} = require('../../ours/errors')\nconst eos = require('./end-of-stream')\nmodule.exports = function compose(...streams) {\n if (streams.length === 0) {\n throw new ERR_MISSING_ARGS('streams')\n }\n if (streams.length === 1) {\n return Duplex.from(streams[0])\n }\n const orgStreams = [...streams]\n if (typeof streams[0] === 'function') {\n streams[0] = Duplex.from(streams[0])\n }\n if (typeof streams[streams.length - 1] === 'function') {\n const idx = streams.length - 1\n streams[idx] = Duplex.from(streams[idx])\n }\n for (let n = 0; n < streams.length; ++n) {\n if (!isNodeStream(streams[n]) && !isWebStream(streams[n])) {\n // TODO(ronag): Add checks for non streams.\n continue\n }\n if (\n n < streams.length - 1 &&\n !(isReadable(streams[n]) || isReadableStream(streams[n]) || isTransformStream(streams[n]))\n ) {\n throw new ERR_INVALID_ARG_VALUE(`streams[${n}]`, orgStreams[n], 'must be readable')\n }\n if (n > 0 && !(isWritable(streams[n]) || isWritableStream(streams[n]) || isTransformStream(streams[n]))) {\n throw new ERR_INVALID_ARG_VALUE(`streams[${n}]`, orgStreams[n], 'must be writable')\n }\n }\n let ondrain\n let onfinish\n let onreadable\n let onclose\n let d\n function onfinished(err) {\n const cb = onclose\n onclose = null\n if (cb) {\n cb(err)\n } else if (err) {\n d.destroy(err)\n } else if (!readable && !writable) {\n d.destroy()\n }\n }\n const head = streams[0]\n const tail = pipeline(streams, onfinished)\n const writable = !!(isWritable(head) || isWritableStream(head) || isTransformStream(head))\n const readable = !!(isReadable(tail) || isReadableStream(tail) || isTransformStream(tail))\n\n // TODO(ronag): Avoid double buffering.\n // Implement Writable/Readable/Duplex traits.\n // See, https://github.com/nodejs/node/pull/33515.\n d = new Duplex({\n // TODO (ronag): highWaterMark?\n writableObjectMode: !!(head !== null && head !== undefined && head.writableObjectMode),\n readableObjectMode: !!(tail !== null && tail !== undefined && tail.readableObjectMode),\n writable,\n readable\n })\n if (writable) {\n if (isNodeStream(head)) {\n d._write = function (chunk, encoding, callback) {\n if (head.write(chunk, encoding)) {\n callback()\n } else {\n ondrain = callback\n }\n }\n d._final = function (callback) {\n head.end()\n onfinish = callback\n }\n head.on('drain', function () {\n if (ondrain) {\n const cb = ondrain\n ondrain = null\n cb()\n }\n })\n } else if (isWebStream(head)) {\n const writable = isTransformStream(head) ? head.writable : head\n const writer = writable.getWriter()\n d._write = async function (chunk, encoding, callback) {\n try {\n await writer.ready\n writer.write(chunk).catch(() => {})\n callback()\n } catch (err) {\n callback(err)\n }\n }\n d._final = async function (callback) {\n try {\n await writer.ready\n writer.close().catch(() => {})\n onfinish = callback\n } catch (err) {\n callback(err)\n }\n }\n }\n const toRead = isTransformStream(tail) ? tail.readable : tail\n eos(toRead, () => {\n if (onfinish) {\n const cb = onfinish\n onfinish = null\n cb()\n }\n })\n }\n if (readable) {\n if (isNodeStream(tail)) {\n tail.on('readable', function () {\n if (onreadable) {\n const cb = onreadable\n onreadable = null\n cb()\n }\n })\n tail.on('end', function () {\n d.push(null)\n })\n d._read = function () {\n while (true) {\n const buf = tail.read()\n if (buf === null) {\n onreadable = d._read\n return\n }\n if (!d.push(buf)) {\n return\n }\n }\n }\n } else if (isWebStream(tail)) {\n const readable = isTransformStream(tail) ? tail.readable : tail\n const reader = readable.getReader()\n d._read = async function () {\n while (true) {\n try {\n const { value, done } = await reader.read()\n if (!d.push(value)) {\n return\n }\n if (done) {\n d.push(null)\n return\n }\n } catch {\n return\n }\n }\n }\n }\n }\n d._destroy = function (err, callback) {\n if (!err && onclose !== null) {\n err = new AbortError()\n }\n onreadable = null\n ondrain = null\n onfinish = null\n if (onclose === null) {\n callback(err)\n } else {\n onclose = callback\n if (isNodeStream(tail)) {\n destroyer(tail, err)\n }\n }\n }\n return d\n}\n","'use strict'\n\nconst AbortController = globalThis.AbortController || require('abort-controller').AbortController\nconst {\n codes: { ERR_INVALID_ARG_VALUE, ERR_INVALID_ARG_TYPE, ERR_MISSING_ARGS, ERR_OUT_OF_RANGE },\n AbortError\n} = require('../../ours/errors')\nconst { validateAbortSignal, validateInteger, validateObject } = require('../validators')\nconst kWeakHandler = require('../../ours/primordials').Symbol('kWeak')\nconst kResistStopPropagation = require('../../ours/primordials').Symbol('kResistStopPropagation')\nconst { finished } = require('./end-of-stream')\nconst staticCompose = require('./compose')\nconst { addAbortSignalNoValidate } = require('./add-abort-signal')\nconst { isWritable, isNodeStream } = require('./utils')\nconst { deprecate } = require('../../ours/util')\nconst {\n ArrayPrototypePush,\n Boolean,\n MathFloor,\n Number,\n NumberIsNaN,\n Promise,\n PromiseReject,\n PromiseResolve,\n PromisePrototypeThen,\n Symbol\n} = require('../../ours/primordials')\nconst kEmpty = Symbol('kEmpty')\nconst kEof = Symbol('kEof')\nfunction compose(stream, options) {\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n if (isNodeStream(stream) && !isWritable(stream)) {\n throw new ERR_INVALID_ARG_VALUE('stream', stream, 'must be writable')\n }\n const composedStream = staticCompose(this, stream)\n if (options !== null && options !== undefined && options.signal) {\n // Not validating as we already validated before\n addAbortSignalNoValidate(options.signal, composedStream)\n }\n return composedStream\n}\nfunction map(fn, options) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', ['Function', 'AsyncFunction'], fn)\n }\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n let concurrency = 1\n if ((options === null || options === undefined ? undefined : options.concurrency) != null) {\n concurrency = MathFloor(options.concurrency)\n }\n let highWaterMark = concurrency - 1\n if ((options === null || options === undefined ? undefined : options.highWaterMark) != null) {\n highWaterMark = MathFloor(options.highWaterMark)\n }\n validateInteger(concurrency, 'options.concurrency', 1)\n validateInteger(highWaterMark, 'options.highWaterMark', 0)\n highWaterMark += concurrency\n return async function* map() {\n const signal = require('../../ours/util').AbortSignalAny(\n [options === null || options === undefined ? undefined : options.signal].filter(Boolean)\n )\n const stream = this\n const queue = []\n const signalOpt = {\n signal\n }\n let next\n let resume\n let done = false\n let cnt = 0\n function onCatch() {\n done = true\n afterItemProcessed()\n }\n function afterItemProcessed() {\n cnt -= 1\n maybeResume()\n }\n function maybeResume() {\n if (resume && !done && cnt < concurrency && queue.length < highWaterMark) {\n resume()\n resume = null\n }\n }\n async function pump() {\n try {\n for await (let val of stream) {\n if (done) {\n return\n }\n if (signal.aborted) {\n throw new AbortError()\n }\n try {\n val = fn(val, signalOpt)\n if (val === kEmpty) {\n continue\n }\n val = PromiseResolve(val)\n } catch (err) {\n val = PromiseReject(err)\n }\n cnt += 1\n PromisePrototypeThen(val, afterItemProcessed, onCatch)\n queue.push(val)\n if (next) {\n next()\n next = null\n }\n if (!done && (queue.length >= highWaterMark || cnt >= concurrency)) {\n await new Promise((resolve) => {\n resume = resolve\n })\n }\n }\n queue.push(kEof)\n } catch (err) {\n const val = PromiseReject(err)\n PromisePrototypeThen(val, afterItemProcessed, onCatch)\n queue.push(val)\n } finally {\n done = true\n if (next) {\n next()\n next = null\n }\n }\n }\n pump()\n try {\n while (true) {\n while (queue.length > 0) {\n const val = await queue[0]\n if (val === kEof) {\n return\n }\n if (signal.aborted) {\n throw new AbortError()\n }\n if (val !== kEmpty) {\n yield val\n }\n queue.shift()\n maybeResume()\n }\n await new Promise((resolve) => {\n next = resolve\n })\n }\n } finally {\n done = true\n if (resume) {\n resume()\n resume = null\n }\n }\n }.call(this)\n}\nfunction asIndexedPairs(options = undefined) {\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n return async function* asIndexedPairs() {\n let index = 0\n for await (const val of this) {\n var _options$signal\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal = options.signal) !== null &&\n _options$signal !== undefined &&\n _options$signal.aborted\n ) {\n throw new AbortError({\n cause: options.signal.reason\n })\n }\n yield [index++, val]\n }\n }.call(this)\n}\nasync function some(fn, options = undefined) {\n for await (const unused of filter.call(this, fn, options)) {\n return true\n }\n return false\n}\nasync function every(fn, options = undefined) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', ['Function', 'AsyncFunction'], fn)\n }\n // https://en.wikipedia.org/wiki/De_Morgan%27s_laws\n return !(await some.call(\n this,\n async (...args) => {\n return !(await fn(...args))\n },\n options\n ))\n}\nasync function find(fn, options) {\n for await (const result of filter.call(this, fn, options)) {\n return result\n }\n return undefined\n}\nasync function forEach(fn, options) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', ['Function', 'AsyncFunction'], fn)\n }\n async function forEachFn(value, options) {\n await fn(value, options)\n return kEmpty\n }\n // eslint-disable-next-line no-unused-vars\n for await (const unused of map.call(this, forEachFn, options));\n}\nfunction filter(fn, options) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', ['Function', 'AsyncFunction'], fn)\n }\n async function filterFn(value, options) {\n if (await fn(value, options)) {\n return value\n }\n return kEmpty\n }\n return map.call(this, filterFn, options)\n}\n\n// Specific to provide better error to reduce since the argument is only\n// missing if the stream has no items in it - but the code is still appropriate\nclass ReduceAwareErrMissingArgs extends ERR_MISSING_ARGS {\n constructor() {\n super('reduce')\n this.message = 'Reduce of an empty stream requires an initial value'\n }\n}\nasync function reduce(reducer, initialValue, options) {\n var _options$signal2\n if (typeof reducer !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('reducer', ['Function', 'AsyncFunction'], reducer)\n }\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n let hasInitialValue = arguments.length > 1\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal2 = options.signal) !== null &&\n _options$signal2 !== undefined &&\n _options$signal2.aborted\n ) {\n const err = new AbortError(undefined, {\n cause: options.signal.reason\n })\n this.once('error', () => {}) // The error is already propagated\n await finished(this.destroy(err))\n throw err\n }\n const ac = new AbortController()\n const signal = ac.signal\n if (options !== null && options !== undefined && options.signal) {\n const opts = {\n once: true,\n [kWeakHandler]: this,\n [kResistStopPropagation]: true\n }\n options.signal.addEventListener('abort', () => ac.abort(), opts)\n }\n let gotAnyItemFromStream = false\n try {\n for await (const value of this) {\n var _options$signal3\n gotAnyItemFromStream = true\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal3 = options.signal) !== null &&\n _options$signal3 !== undefined &&\n _options$signal3.aborted\n ) {\n throw new AbortError()\n }\n if (!hasInitialValue) {\n initialValue = value\n hasInitialValue = true\n } else {\n initialValue = await reducer(initialValue, value, {\n signal\n })\n }\n }\n if (!gotAnyItemFromStream && !hasInitialValue) {\n throw new ReduceAwareErrMissingArgs()\n }\n } finally {\n ac.abort()\n }\n return initialValue\n}\nasync function toArray(options) {\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n const result = []\n for await (const val of this) {\n var _options$signal4\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal4 = options.signal) !== null &&\n _options$signal4 !== undefined &&\n _options$signal4.aborted\n ) {\n throw new AbortError(undefined, {\n cause: options.signal.reason\n })\n }\n ArrayPrototypePush(result, val)\n }\n return result\n}\nfunction flatMap(fn, options) {\n const values = map.call(this, fn, options)\n return async function* flatMap() {\n for await (const val of values) {\n yield* val\n }\n }.call(this)\n}\nfunction toIntegerOrInfinity(number) {\n // We coerce here to align with the spec\n // https://github.com/tc39/proposal-iterator-helpers/issues/169\n number = Number(number)\n if (NumberIsNaN(number)) {\n return 0\n }\n if (number < 0) {\n throw new ERR_OUT_OF_RANGE('number', '>= 0', number)\n }\n return number\n}\nfunction drop(number, options = undefined) {\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n number = toIntegerOrInfinity(number)\n return async function* drop() {\n var _options$signal5\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal5 = options.signal) !== null &&\n _options$signal5 !== undefined &&\n _options$signal5.aborted\n ) {\n throw new AbortError()\n }\n for await (const val of this) {\n var _options$signal6\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal6 = options.signal) !== null &&\n _options$signal6 !== undefined &&\n _options$signal6.aborted\n ) {\n throw new AbortError()\n }\n if (number-- <= 0) {\n yield val\n }\n }\n }.call(this)\n}\nfunction take(number, options = undefined) {\n if (options != null) {\n validateObject(options, 'options')\n }\n if ((options === null || options === undefined ? undefined : options.signal) != null) {\n validateAbortSignal(options.signal, 'options.signal')\n }\n number = toIntegerOrInfinity(number)\n return async function* take() {\n var _options$signal7\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal7 = options.signal) !== null &&\n _options$signal7 !== undefined &&\n _options$signal7.aborted\n ) {\n throw new AbortError()\n }\n for await (const val of this) {\n var _options$signal8\n if (\n options !== null &&\n options !== undefined &&\n (_options$signal8 = options.signal) !== null &&\n _options$signal8 !== undefined &&\n _options$signal8.aborted\n ) {\n throw new AbortError()\n }\n if (number-- > 0) {\n yield val\n }\n\n // Don't get another item from iterator in case we reached the end\n if (number <= 0) {\n return\n }\n }\n }.call(this)\n}\nmodule.exports.streamReturningOperators = {\n asIndexedPairs: deprecate(asIndexedPairs, 'readable.asIndexedPairs will be removed in a future version.'),\n drop,\n filter,\n flatMap,\n map,\n take,\n compose\n}\nmodule.exports.promiseReturningOperators = {\n every,\n forEach,\n reduce,\n toArray,\n some,\n find\n}\n","'use strict'\n\nconst { ArrayPrototypePop, Promise } = require('../ours/primordials')\nconst { isIterable, isNodeStream, isWebStream } = require('../internal/streams/utils')\nconst { pipelineImpl: pl } = require('../internal/streams/pipeline')\nconst { finished } = require('../internal/streams/end-of-stream')\nrequire('../../lib/stream.js')\nfunction pipeline(...streams) {\n return new Promise((resolve, reject) => {\n let signal\n let end\n const lastArg = streams[streams.length - 1]\n if (\n lastArg &&\n typeof lastArg === 'object' &&\n !isNodeStream(lastArg) &&\n !isIterable(lastArg) &&\n !isWebStream(lastArg)\n ) {\n const options = ArrayPrototypePop(streams)\n signal = options.signal\n end = options.end\n }\n pl(\n streams,\n (err, value) => {\n if (err) {\n reject(err)\n } else {\n resolve(value)\n }\n },\n {\n signal,\n end\n }\n )\n })\n}\nmodule.exports = {\n finished,\n pipeline\n}\n","/* replacement start */\n\nconst { Buffer } = require('buffer')\n\n/* replacement end */\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n;('use strict')\nconst { ObjectDefineProperty, ObjectKeys, ReflectApply } = require('./ours/primordials')\nconst {\n promisify: { custom: customPromisify }\n} = require('./ours/util')\nconst { streamReturningOperators, promiseReturningOperators } = require('./internal/streams/operators')\nconst {\n codes: { ERR_ILLEGAL_CONSTRUCTOR }\n} = require('./ours/errors')\nconst compose = require('./internal/streams/compose')\nconst { setDefaultHighWaterMark, getDefaultHighWaterMark } = require('./internal/streams/state')\nconst { pipeline } = require('./internal/streams/pipeline')\nconst { destroyer } = require('./internal/streams/destroy')\nconst eos = require('./internal/streams/end-of-stream')\nconst internalBuffer = {}\nconst promises = require('./stream/promises')\nconst utils = require('./internal/streams/utils')\nconst Stream = (module.exports = require('./internal/streams/legacy').Stream)\nStream.isDestroyed = utils.isDestroyed\nStream.isDisturbed = utils.isDisturbed\nStream.isErrored = utils.isErrored\nStream.isReadable = utils.isReadable\nStream.isWritable = utils.isWritable\nStream.Readable = require('./internal/streams/readable')\nfor (const key of ObjectKeys(streamReturningOperators)) {\n const op = streamReturningOperators[key]\n function fn(...args) {\n if (new.target) {\n throw ERR_ILLEGAL_CONSTRUCTOR()\n }\n return Stream.Readable.from(ReflectApply(op, this, args))\n }\n ObjectDefineProperty(fn, 'name', {\n __proto__: null,\n value: op.name\n })\n ObjectDefineProperty(fn, 'length', {\n __proto__: null,\n value: op.length\n })\n ObjectDefineProperty(Stream.Readable.prototype, key, {\n __proto__: null,\n value: fn,\n enumerable: false,\n configurable: true,\n writable: true\n })\n}\nfor (const key of ObjectKeys(promiseReturningOperators)) {\n const op = promiseReturningOperators[key]\n function fn(...args) {\n if (new.target) {\n throw ERR_ILLEGAL_CONSTRUCTOR()\n }\n return ReflectApply(op, this, args)\n }\n ObjectDefineProperty(fn, 'name', {\n __proto__: null,\n value: op.name\n })\n ObjectDefineProperty(fn, 'length', {\n __proto__: null,\n value: op.length\n })\n ObjectDefineProperty(Stream.Readable.prototype, key, {\n __proto__: null,\n value: fn,\n enumerable: false,\n configurable: true,\n writable: true\n })\n}\nStream.Writable = require('./internal/streams/writable')\nStream.Duplex = require('./internal/streams/duplex')\nStream.Transform = require('./internal/streams/transform')\nStream.PassThrough = require('./internal/streams/passthrough')\nStream.pipeline = pipeline\nconst { addAbortSignal } = require('./internal/streams/add-abort-signal')\nStream.addAbortSignal = addAbortSignal\nStream.finished = eos\nStream.destroy = destroyer\nStream.compose = compose\nStream.setDefaultHighWaterMark = setDefaultHighWaterMark\nStream.getDefaultHighWaterMark = getDefaultHighWaterMark\nObjectDefineProperty(Stream, 'promises', {\n __proto__: null,\n configurable: true,\n enumerable: true,\n get() {\n return promises\n }\n})\nObjectDefineProperty(pipeline, customPromisify, {\n __proto__: null,\n enumerable: true,\n get() {\n return promises.pipeline\n }\n})\nObjectDefineProperty(eos, customPromisify, {\n __proto__: null,\n enumerable: true,\n get() {\n return promises.finished\n }\n})\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream\nStream._isUint8Array = function isUint8Array(value) {\n return value instanceof Uint8Array\n}\nStream._uint8ArrayToBuffer = function _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk.buffer, chunk.byteOffset, chunk.byteLength)\n}\n","'use strict'\n\nconst Stream = require('stream')\nif (Stream && process.env.READABLE_STREAM === 'disable') {\n const promises = Stream.promises\n\n // Explicit export naming is needed for ESM\n module.exports._uint8ArrayToBuffer = Stream._uint8ArrayToBuffer\n module.exports._isUint8Array = Stream._isUint8Array\n module.exports.isDisturbed = Stream.isDisturbed\n module.exports.isErrored = Stream.isErrored\n module.exports.isReadable = Stream.isReadable\n module.exports.Readable = Stream.Readable\n module.exports.Writable = Stream.Writable\n module.exports.Duplex = Stream.Duplex\n module.exports.Transform = Stream.Transform\n module.exports.PassThrough = Stream.PassThrough\n module.exports.addAbortSignal = Stream.addAbortSignal\n module.exports.finished = Stream.finished\n module.exports.destroy = Stream.destroy\n module.exports.pipeline = Stream.pipeline\n module.exports.compose = Stream.compose\n Object.defineProperty(Stream, 'promises', {\n configurable: true,\n enumerable: true,\n get() {\n return promises\n }\n })\n module.exports.Stream = Stream.Stream\n} else {\n const CustomStream = require('../stream')\n const promises = require('../stream/promises')\n const originalDestroy = CustomStream.Readable.destroy\n module.exports = CustomStream.Readable\n\n // Explicit export naming is needed for ESM\n module.exports._uint8ArrayToBuffer = CustomStream._uint8ArrayToBuffer\n module.exports._isUint8Array = CustomStream._isUint8Array\n module.exports.isDisturbed = CustomStream.isDisturbed\n module.exports.isErrored = CustomStream.isErrored\n module.exports.isReadable = CustomStream.isReadable\n module.exports.Readable = CustomStream.Readable\n module.exports.Writable = CustomStream.Writable\n module.exports.Duplex = CustomStream.Duplex\n module.exports.Transform = CustomStream.Transform\n module.exports.PassThrough = CustomStream.PassThrough\n module.exports.addAbortSignal = CustomStream.addAbortSignal\n module.exports.finished = CustomStream.finished\n module.exports.destroy = CustomStream.destroy\n module.exports.destroy = originalDestroy\n module.exports.pipeline = CustomStream.pipeline\n module.exports.compose = CustomStream.compose\n Object.defineProperty(CustomStream, 'promises', {\n configurable: true,\n enumerable: true,\n get() {\n return promises\n }\n })\n module.exports.Stream = CustomStream.Stream\n}\n\n// Allow default importing\nmodule.exports.default = module.exports\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","try {\n var util = require('util');\n /* istanbul ignore next */\n if (typeof util.inherits !== 'function') throw '';\n module.exports = util.inherits;\n} catch (e) {\n /* istanbul ignore next */\n module.exports = require('./inherits_browser.js');\n}\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst symbol = Symbol.for('BufferList')\n\nfunction BufferList (buf) {\n if (!(this instanceof BufferList)) {\n return new BufferList(buf)\n }\n\n BufferList._init.call(this, buf)\n}\n\nBufferList._init = function _init (buf) {\n Object.defineProperty(this, symbol, { value: true })\n\n this._bufs = []\n this.length = 0\n\n if (buf) {\n this.append(buf)\n }\n}\n\nBufferList.prototype._new = function _new (buf) {\n return new BufferList(buf)\n}\n\nBufferList.prototype._offset = function _offset (offset) {\n if (offset === 0) {\n return [0, 0]\n }\n\n let tot = 0\n\n for (let i = 0; i < this._bufs.length; i++) {\n const _t = tot + this._bufs[i].length\n if (offset < _t || i === this._bufs.length - 1) {\n return [i, offset - tot]\n }\n tot = _t\n }\n}\n\nBufferList.prototype._reverseOffset = function (blOffset) {\n const bufferId = blOffset[0]\n let offset = blOffset[1]\n\n for (let i = 0; i < bufferId; i++) {\n offset += this._bufs[i].length\n }\n\n return offset\n}\n\nBufferList.prototype.get = function get (index) {\n if (index > this.length || index < 0) {\n return undefined\n }\n\n const offset = this._offset(index)\n\n return this._bufs[offset[0]][offset[1]]\n}\n\nBufferList.prototype.slice = function slice (start, end) {\n if (typeof start === 'number' && start < 0) {\n start += this.length\n }\n\n if (typeof end === 'number' && end < 0) {\n end += this.length\n }\n\n return this.copy(null, 0, start, end)\n}\n\nBufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {\n if (typeof srcStart !== 'number' || srcStart < 0) {\n srcStart = 0\n }\n\n if (typeof srcEnd !== 'number' || srcEnd > this.length) {\n srcEnd = this.length\n }\n\n if (srcStart >= this.length) {\n return dst || Buffer.alloc(0)\n }\n\n if (srcEnd <= 0) {\n return dst || Buffer.alloc(0)\n }\n\n const copy = !!dst\n const off = this._offset(srcStart)\n const len = srcEnd - srcStart\n let bytes = len\n let bufoff = (copy && dstStart) || 0\n let start = off[1]\n\n // copy/slice everything\n if (srcStart === 0 && srcEnd === this.length) {\n if (!copy) {\n // slice, but full concat if multiple buffers\n return this._bufs.length === 1\n ? this._bufs[0]\n : Buffer.concat(this._bufs, this.length)\n }\n\n // copy, need to copy individual buffers\n for (let i = 0; i < this._bufs.length; i++) {\n this._bufs[i].copy(dst, bufoff)\n bufoff += this._bufs[i].length\n }\n\n return dst\n }\n\n // easy, cheap case where it's a subset of one of the buffers\n if (bytes <= this._bufs[off[0]].length - start) {\n return copy\n ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)\n : this._bufs[off[0]].slice(start, start + bytes)\n }\n\n if (!copy) {\n // a slice, we need something to copy in to\n dst = Buffer.allocUnsafe(len)\n }\n\n for (let i = off[0]; i < this._bufs.length; i++) {\n const l = this._bufs[i].length - start\n\n if (bytes > l) {\n this._bufs[i].copy(dst, bufoff, start)\n bufoff += l\n } else {\n this._bufs[i].copy(dst, bufoff, start, start + bytes)\n bufoff += l\n break\n }\n\n bytes -= l\n\n if (start) {\n start = 0\n }\n }\n\n // safeguard so that we don't return uninitialized memory\n if (dst.length > bufoff) return dst.slice(0, bufoff)\n\n return dst\n}\n\nBufferList.prototype.shallowSlice = function shallowSlice (start, end) {\n start = start || 0\n end = typeof end !== 'number' ? this.length : end\n\n if (start < 0) {\n start += this.length\n }\n\n if (end < 0) {\n end += this.length\n }\n\n if (start === end) {\n return this._new()\n }\n\n const startOffset = this._offset(start)\n const endOffset = this._offset(end)\n const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)\n\n if (endOffset[1] === 0) {\n buffers.pop()\n } else {\n buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])\n }\n\n if (startOffset[1] !== 0) {\n buffers[0] = buffers[0].slice(startOffset[1])\n }\n\n return this._new(buffers)\n}\n\nBufferList.prototype.toString = function toString (encoding, start, end) {\n return this.slice(start, end).toString(encoding)\n}\n\nBufferList.prototype.consume = function consume (bytes) {\n // first, normalize the argument, in accordance with how Buffer does it\n bytes = Math.trunc(bytes)\n // do nothing if not a positive number\n if (Number.isNaN(bytes) || bytes <= 0) return this\n\n while (this._bufs.length) {\n if (bytes >= this._bufs[0].length) {\n bytes -= this._bufs[0].length\n this.length -= this._bufs[0].length\n this._bufs.shift()\n } else {\n this._bufs[0] = this._bufs[0].slice(bytes)\n this.length -= bytes\n break\n }\n }\n\n return this\n}\n\nBufferList.prototype.duplicate = function duplicate () {\n const copy = this._new()\n\n for (let i = 0; i < this._bufs.length; i++) {\n copy.append(this._bufs[i])\n }\n\n return copy\n}\n\nBufferList.prototype.append = function append (buf) {\n if (buf == null) {\n return this\n }\n\n if (buf.buffer) {\n // append a view of the underlying ArrayBuffer\n this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))\n } else if (Array.isArray(buf)) {\n for (let i = 0; i < buf.length; i++) {\n this.append(buf[i])\n }\n } else if (this._isBufferList(buf)) {\n // unwrap argument into individual BufferLists\n for (let i = 0; i < buf._bufs.length; i++) {\n this.append(buf._bufs[i])\n }\n } else {\n // coerce number arguments to strings, since Buffer(number) does\n // uninitialized memory allocation\n if (typeof buf === 'number') {\n buf = buf.toString()\n }\n\n this._appendBuffer(Buffer.from(buf))\n }\n\n return this\n}\n\nBufferList.prototype._appendBuffer = function appendBuffer (buf) {\n this._bufs.push(buf)\n this.length += buf.length\n}\n\nBufferList.prototype.indexOf = function (search, offset, encoding) {\n if (encoding === undefined && typeof offset === 'string') {\n encoding = offset\n offset = undefined\n }\n\n if (typeof search === 'function' || Array.isArray(search)) {\n throw new TypeError('The \"value\" argument must be one of type string, Buffer, BufferList, or Uint8Array.')\n } else if (typeof search === 'number') {\n search = Buffer.from([search])\n } else if (typeof search === 'string') {\n search = Buffer.from(search, encoding)\n } else if (this._isBufferList(search)) {\n search = search.slice()\n } else if (Array.isArray(search.buffer)) {\n search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)\n } else if (!Buffer.isBuffer(search)) {\n search = Buffer.from(search)\n }\n\n offset = Number(offset || 0)\n\n if (isNaN(offset)) {\n offset = 0\n }\n\n if (offset < 0) {\n offset = this.length + offset\n }\n\n if (offset < 0) {\n offset = 0\n }\n\n if (search.length === 0) {\n return offset > this.length ? this.length : offset\n }\n\n const blOffset = this._offset(offset)\n let blIndex = blOffset[0] // index of which internal buffer we're working on\n let buffOffset = blOffset[1] // offset of the internal buffer we're working on\n\n // scan over each buffer\n for (; blIndex < this._bufs.length; blIndex++) {\n const buff = this._bufs[blIndex]\n\n while (buffOffset < buff.length) {\n const availableWindow = buff.length - buffOffset\n\n if (availableWindow >= search.length) {\n const nativeSearchResult = buff.indexOf(search, buffOffset)\n\n if (nativeSearchResult !== -1) {\n return this._reverseOffset([blIndex, nativeSearchResult])\n }\n\n buffOffset = buff.length - search.length + 1 // end of native search window\n } else {\n const revOffset = this._reverseOffset([blIndex, buffOffset])\n\n if (this._match(revOffset, search)) {\n return revOffset\n }\n\n buffOffset++\n }\n }\n\n buffOffset = 0\n }\n\n return -1\n}\n\nBufferList.prototype._match = function (offset, search) {\n if (this.length - offset < search.length) {\n return false\n }\n\n for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {\n if (this.get(offset + searchOffset) !== search[searchOffset]) {\n return false\n }\n }\n return true\n}\n\n;(function () {\n const methods = {\n readDoubleBE: 8,\n readDoubleLE: 8,\n readFloatBE: 4,\n readFloatLE: 4,\n readBigInt64BE: 8,\n readBigInt64LE: 8,\n readBigUInt64BE: 8,\n readBigUInt64LE: 8,\n readInt32BE: 4,\n readInt32LE: 4,\n readUInt32BE: 4,\n readUInt32LE: 4,\n readInt16BE: 2,\n readInt16LE: 2,\n readUInt16BE: 2,\n readUInt16LE: 2,\n readInt8: 1,\n readUInt8: 1,\n readIntBE: null,\n readIntLE: null,\n readUIntBE: null,\n readUIntLE: null\n }\n\n for (const m in methods) {\n (function (m) {\n if (methods[m] === null) {\n BufferList.prototype[m] = function (offset, byteLength) {\n return this.slice(offset, offset + byteLength)[m](0, byteLength)\n }\n } else {\n BufferList.prototype[m] = function (offset = 0) {\n return this.slice(offset, offset + methods[m])[m](0)\n }\n }\n }(m))\n }\n}())\n\n// Used internally by the class and also as an indicator of this object being\n// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser\n// environment because there could be multiple different copies of the\n// BufferList class and some `BufferList`s might be `BufferList`s.\nBufferList.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferList || BufferList.isBufferList(b)\n}\n\nBufferList.isBufferList = function isBufferList (b) {\n return b != null && b[symbol]\n}\n\nmodule.exports = BufferList\n","'use strict'\n\nconst DuplexStream = require('readable-stream').Duplex\nconst inherits = require('inherits')\nconst BufferList = require('./BufferList')\n\nfunction BufferListStream (callback) {\n if (!(this instanceof BufferListStream)) {\n return new BufferListStream(callback)\n }\n\n if (typeof callback === 'function') {\n this._callback = callback\n\n const piper = function piper (err) {\n if (this._callback) {\n this._callback(err)\n this._callback = null\n }\n }.bind(this)\n\n this.on('pipe', function onPipe (src) {\n src.on('error', piper)\n })\n this.on('unpipe', function onUnpipe (src) {\n src.removeListener('error', piper)\n })\n\n callback = null\n }\n\n BufferList._init.call(this, callback)\n DuplexStream.call(this)\n}\n\ninherits(BufferListStream, DuplexStream)\nObject.assign(BufferListStream.prototype, BufferList.prototype)\n\nBufferListStream.prototype._new = function _new (callback) {\n return new BufferListStream(callback)\n}\n\nBufferListStream.prototype._write = function _write (buf, encoding, callback) {\n this._appendBuffer(buf)\n\n if (typeof callback === 'function') {\n callback()\n }\n}\n\nBufferListStream.prototype._read = function _read (size) {\n if (!this.length) {\n return this.push(null)\n }\n\n size = Math.min(size, this.length)\n this.push(this.slice(0, size))\n this.consume(size)\n}\n\nBufferListStream.prototype.end = function end (chunk) {\n DuplexStream.prototype.end.call(this, chunk)\n\n if (this._callback) {\n this._callback(null, this.slice())\n this._callback = null\n }\n}\n\nBufferListStream.prototype._destroy = function _destroy (err, cb) {\n this._bufs.length = 0\n this.length = 0\n cb(err)\n}\n\nBufferListStream.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b)\n}\n\nBufferListStream.isBufferList = BufferList.isBufferList\n\nmodule.exports = BufferListStream\nmodule.exports.BufferListStream = BufferListStream\nmodule.exports.BufferList = BufferList\n","class Packet {\n constructor () {\n this.cmd = null\n this.retain = false\n this.qos = 0\n this.dup = false\n this.length = -1\n this.topic = null\n this.payload = null\n }\n}\n\nmodule.exports = Packet\n","/* Protocol - protocol constants */\nconst protocol = module.exports\nconst { Buffer } = require('buffer')\n\n/* Command code => mnemonic */\nprotocol.types = {\n 0: 'reserved',\n 1: 'connect',\n 2: 'connack',\n 3: 'publish',\n 4: 'puback',\n 5: 'pubrec',\n 6: 'pubrel',\n 7: 'pubcomp',\n 8: 'subscribe',\n 9: 'suback',\n 10: 'unsubscribe',\n 11: 'unsuback',\n 12: 'pingreq',\n 13: 'pingresp',\n 14: 'disconnect',\n 15: 'auth'\n}\n\nprotocol.requiredHeaderFlags = {\n 1: 0, // 'connect'\n 2: 0, // 'connack'\n 4: 0, // 'puback'\n 5: 0, // 'pubrec'\n 6: 2, // 'pubrel'\n 7: 0, // 'pubcomp'\n 8: 2, // 'subscribe'\n 9: 0, // 'suback'\n 10: 2, // 'unsubscribe'\n 11: 0, // 'unsuback'\n 12: 0, // 'pingreq'\n 13: 0, // 'pingresp'\n 14: 0, // 'disconnect'\n 15: 0 // 'auth'\n}\n\nprotocol.requiredHeaderFlagsErrors = {}\nfor (const k in protocol.requiredHeaderFlags) {\n const v = protocol.requiredHeaderFlags[k]\n protocol.requiredHeaderFlagsErrors[k] = 'Invalid header flag bits, must be 0x' + v.toString(16) + ' for ' + protocol.types[k] + ' packet'\n}\n\n/* Mnemonic => Command code */\nprotocol.codes = {}\nfor (const k in protocol.types) {\n const v = protocol.types[k]\n protocol.codes[v] = k\n}\n\n/* Header */\nprotocol.CMD_SHIFT = 4\nprotocol.CMD_MASK = 0xF0\nprotocol.DUP_MASK = 0x08\nprotocol.QOS_MASK = 0x03\nprotocol.QOS_SHIFT = 1\nprotocol.RETAIN_MASK = 0x01\n\n/* Length */\nprotocol.VARBYTEINT_MASK = 0x7F\nprotocol.VARBYTEINT_FIN_MASK = 0x80\nprotocol.VARBYTEINT_MAX = 268435455\n\n/* Connack */\nprotocol.SESSIONPRESENT_MASK = 0x01\nprotocol.SESSIONPRESENT_HEADER = Buffer.from([protocol.SESSIONPRESENT_MASK])\nprotocol.CONNACK_HEADER = Buffer.from([protocol.codes.connack << protocol.CMD_SHIFT])\n\n/* Connect */\nprotocol.USERNAME_MASK = 0x80\nprotocol.PASSWORD_MASK = 0x40\nprotocol.WILL_RETAIN_MASK = 0x20\nprotocol.WILL_QOS_MASK = 0x18\nprotocol.WILL_QOS_SHIFT = 3\nprotocol.WILL_FLAG_MASK = 0x04\nprotocol.CLEAN_SESSION_MASK = 0x02\nprotocol.CONNECT_HEADER = Buffer.from([protocol.codes.connect << protocol.CMD_SHIFT])\n\n/* Properties */\nprotocol.properties = {\n sessionExpiryInterval: 17,\n willDelayInterval: 24,\n receiveMaximum: 33,\n maximumPacketSize: 39,\n topicAliasMaximum: 34,\n requestResponseInformation: 25,\n requestProblemInformation: 23,\n userProperties: 38,\n authenticationMethod: 21,\n authenticationData: 22,\n payloadFormatIndicator: 1,\n messageExpiryInterval: 2,\n contentType: 3,\n responseTopic: 8,\n correlationData: 9,\n maximumQoS: 36,\n retainAvailable: 37,\n assignedClientIdentifier: 18,\n reasonString: 31,\n wildcardSubscriptionAvailable: 40,\n subscriptionIdentifiersAvailable: 41,\n sharedSubscriptionAvailable: 42,\n serverKeepAlive: 19,\n responseInformation: 26,\n serverReference: 28,\n topicAlias: 35,\n subscriptionIdentifier: 11\n}\nprotocol.propertiesCodes = {}\nfor (const prop in protocol.properties) {\n const id = protocol.properties[prop]\n protocol.propertiesCodes[id] = prop\n}\nprotocol.propertiesTypes = {\n sessionExpiryInterval: 'int32',\n willDelayInterval: 'int32',\n receiveMaximum: 'int16',\n maximumPacketSize: 'int32',\n topicAliasMaximum: 'int16',\n requestResponseInformation: 'byte',\n requestProblemInformation: 'byte',\n userProperties: 'pair',\n authenticationMethod: 'string',\n authenticationData: 'binary',\n payloadFormatIndicator: 'byte',\n messageExpiryInterval: 'int32',\n contentType: 'string',\n responseTopic: 'string',\n correlationData: 'binary',\n maximumQoS: 'int8',\n retainAvailable: 'byte',\n assignedClientIdentifier: 'string',\n reasonString: 'string',\n wildcardSubscriptionAvailable: 'byte',\n subscriptionIdentifiersAvailable: 'byte',\n sharedSubscriptionAvailable: 'byte',\n serverKeepAlive: 'int16',\n responseInformation: 'string',\n serverReference: 'string',\n topicAlias: 'int16',\n subscriptionIdentifier: 'var'\n}\n\nfunction genHeader (type) {\n return [0, 1, 2].map(qos => {\n return [0, 1].map(dup => {\n return [0, 1].map(retain => {\n const buf = Buffer.alloc(1)\n buf.writeUInt8(\n protocol.codes[type] << protocol.CMD_SHIFT |\n (dup ? protocol.DUP_MASK : 0) |\n qos << protocol.QOS_SHIFT | retain, 0, true)\n return buf\n })\n })\n })\n}\n\n/* Publish */\nprotocol.PUBLISH_HEADER = genHeader('publish')\n\n/* Subscribe */\nprotocol.SUBSCRIBE_HEADER = genHeader('subscribe')\nprotocol.SUBSCRIBE_OPTIONS_QOS_MASK = 0x03\nprotocol.SUBSCRIBE_OPTIONS_NL_MASK = 0x01\nprotocol.SUBSCRIBE_OPTIONS_NL_SHIFT = 2\nprotocol.SUBSCRIBE_OPTIONS_RAP_MASK = 0x01\nprotocol.SUBSCRIBE_OPTIONS_RAP_SHIFT = 3\nprotocol.SUBSCRIBE_OPTIONS_RH_MASK = 0x03\nprotocol.SUBSCRIBE_OPTIONS_RH_SHIFT = 4\nprotocol.SUBSCRIBE_OPTIONS_RH = [0x00, 0x10, 0x20]\nprotocol.SUBSCRIBE_OPTIONS_NL = 0x04\nprotocol.SUBSCRIBE_OPTIONS_RAP = 0x08\nprotocol.SUBSCRIBE_OPTIONS_QOS = [0x00, 0x01, 0x02]\n\n/* Unsubscribe */\nprotocol.UNSUBSCRIBE_HEADER = genHeader('unsubscribe')\n\n/* Confirmations */\nprotocol.ACKS = {\n unsuback: genHeader('unsuback'),\n puback: genHeader('puback'),\n pubcomp: genHeader('pubcomp'),\n pubrel: genHeader('pubrel'),\n pubrec: genHeader('pubrec')\n}\n\nprotocol.SUBACK_HEADER = Buffer.from([protocol.codes.suback << protocol.CMD_SHIFT])\n\n/* Protocol versions */\nprotocol.VERSION3 = Buffer.from([3])\nprotocol.VERSION4 = Buffer.from([4])\nprotocol.VERSION5 = Buffer.from([5])\nprotocol.VERSION131 = Buffer.from([131])\nprotocol.VERSION132 = Buffer.from([132])\n\n/* QoS */\nprotocol.QOS = [0, 1, 2].map(qos => {\n return Buffer.from([qos])\n})\n\n/* Empty packets */\nprotocol.EMPTY = {\n pingreq: Buffer.from([protocol.codes.pingreq << 4, 0]),\n pingresp: Buffer.from([protocol.codes.pingresp << 4, 0]),\n disconnect: Buffer.from([protocol.codes.disconnect << 4, 0])\n}\n\nprotocol.MQTT5_PUBACK_PUBREC_CODES = {\n 0x00: 'Success',\n 0x10: 'No matching subscribers',\n 0x80: 'Unspecified error',\n 0x83: 'Implementation specific error',\n 0x87: 'Not authorized',\n 0x90: 'Topic Name invalid',\n 0x91: 'Packet identifier in use',\n 0x97: 'Quota exceeded',\n 0x99: 'Payload format invalid'\n}\n\nprotocol.MQTT5_PUBREL_PUBCOMP_CODES = {\n 0x00: 'Success',\n 0x92: 'Packet Identifier not found'\n}\n\nprotocol.MQTT5_SUBACK_CODES = {\n 0x00: 'Granted QoS 0',\n 0x01: 'Granted QoS 1',\n 0x02: 'Granted QoS 2',\n 0x80: 'Unspecified error',\n 0x83: 'Implementation specific error',\n 0x87: 'Not authorized',\n 0x8F: 'Topic Filter invalid',\n 0x91: 'Packet Identifier in use',\n 0x97: 'Quota exceeded',\n 0x9E: 'Shared Subscriptions not supported',\n 0xA1: 'Subscription Identifiers not supported',\n 0xA2: 'Wildcard Subscriptions not supported'\n}\n\nprotocol.MQTT5_UNSUBACK_CODES = {\n 0x00: 'Success',\n 0x11: 'No subscription existed',\n 0x80: 'Unspecified error',\n 0x83: 'Implementation specific error',\n 0x87: 'Not authorized',\n 0x8F: 'Topic Filter invalid',\n 0x91: 'Packet Identifier in use'\n}\n\nprotocol.MQTT5_DISCONNECT_CODES = {\n 0x00: 'Normal disconnection',\n 0x04: 'Disconnect with Will Message',\n 0x80: 'Unspecified error',\n 0x81: 'Malformed Packet',\n 0x82: 'Protocol Error',\n 0x83: 'Implementation specific error',\n 0x87: 'Not authorized',\n 0x89: 'Server busy',\n 0x8B: 'Server shutting down',\n 0x8D: 'Keep Alive timeout',\n 0x8E: 'Session taken over',\n 0x8F: 'Topic Filter invalid',\n 0x90: 'Topic Name invalid',\n 0x93: 'Receive Maximum exceeded',\n 0x94: 'Topic Alias invalid',\n 0x95: 'Packet too large',\n 0x96: 'Message rate too high',\n 0x97: 'Quota exceeded',\n 0x98: 'Administrative action',\n 0x99: 'Payload format invalid',\n 0x9A: 'Retain not supported',\n 0x9B: 'QoS not supported',\n 0x9C: 'Use another server',\n 0x9D: 'Server moved',\n 0x9E: 'Shared Subscriptions not supported',\n 0x9F: 'Connection rate exceeded',\n 0xA0: 'Maximum connect time',\n 0xA1: 'Subscription Identifiers not supported',\n 0xA2: 'Wildcard Subscriptions not supported'\n}\n\nprotocol.MQTT5_AUTH_CODES = {\n 0x00: 'Success',\n 0x18: 'Continue authentication',\n 0x19: 'Re-authenticate'\n}\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.slice(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","'use strict';\n\nmodule.exports = (flag, argv = process.argv) => {\n\tconst prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--');\n\tconst position = argv.indexOf(prefix + flag);\n\tconst terminatorPosition = argv.indexOf('--');\n\treturn position !== -1 && (terminatorPosition === -1 || position < terminatorPosition);\n};\n","'use strict';\nconst os = require('os');\nconst tty = require('tty');\nconst hasFlag = require('has-flag');\n\nconst {env} = process;\n\nlet forceColor;\nif (hasFlag('no-color') ||\n\thasFlag('no-colors') ||\n\thasFlag('color=false') ||\n\thasFlag('color=never')) {\n\tforceColor = 0;\n} else if (hasFlag('color') ||\n\thasFlag('colors') ||\n\thasFlag('color=true') ||\n\thasFlag('color=always')) {\n\tforceColor = 1;\n}\n\nif ('FORCE_COLOR' in env) {\n\tif (env.FORCE_COLOR === 'true') {\n\t\tforceColor = 1;\n\t} else if (env.FORCE_COLOR === 'false') {\n\t\tforceColor = 0;\n\t} else {\n\t\tforceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3);\n\t}\n}\n\nfunction translateLevel(level) {\n\tif (level === 0) {\n\t\treturn false;\n\t}\n\n\treturn {\n\t\tlevel,\n\t\thasBasic: true,\n\t\thas256: level >= 2,\n\t\thas16m: level >= 3\n\t};\n}\n\nfunction supportsColor(haveStream, streamIsTTY) {\n\tif (forceColor === 0) {\n\t\treturn 0;\n\t}\n\n\tif (hasFlag('color=16m') ||\n\t\thasFlag('color=full') ||\n\t\thasFlag('color=truecolor')) {\n\t\treturn 3;\n\t}\n\n\tif (hasFlag('color=256')) {\n\t\treturn 2;\n\t}\n\n\tif (haveStream && !streamIsTTY && forceColor === undefined) {\n\t\treturn 0;\n\t}\n\n\tconst min = forceColor || 0;\n\n\tif (env.TERM === 'dumb') {\n\t\treturn min;\n\t}\n\n\tif (process.platform === 'win32') {\n\t\t// Windows 10 build 10586 is the first Windows release that supports 256 colors.\n\t\t// Windows 10 build 14931 is the first release that supports 16m/TrueColor.\n\t\tconst osRelease = os.release().split('.');\n\t\tif (\n\t\t\tNumber(osRelease[0]) >= 10 &&\n\t\t\tNumber(osRelease[2]) >= 10586\n\t\t) {\n\t\t\treturn Number(osRelease[2]) >= 14931 ? 3 : 2;\n\t\t}\n\n\t\treturn 1;\n\t}\n\n\tif ('CI' in env) {\n\t\tif (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') {\n\t\t\treturn 1;\n\t\t}\n\n\t\treturn min;\n\t}\n\n\tif ('TEAMCITY_VERSION' in env) {\n\t\treturn /^(9\\.(0*[1-9]\\d*)\\.|\\d{2,}\\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;\n\t}\n\n\tif (env.COLORTERM === 'truecolor') {\n\t\treturn 3;\n\t}\n\n\tif ('TERM_PROGRAM' in env) {\n\t\tconst version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);\n\n\t\tswitch (env.TERM_PROGRAM) {\n\t\t\tcase 'iTerm.app':\n\t\t\t\treturn version >= 3 ? 3 : 2;\n\t\t\tcase 'Apple_Terminal':\n\t\t\t\treturn 2;\n\t\t\t// No default\n\t\t}\n\t}\n\n\tif (/-256(color)?$/i.test(env.TERM)) {\n\t\treturn 2;\n\t}\n\n\tif (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {\n\t\treturn 1;\n\t}\n\n\tif ('COLORTERM' in env) {\n\t\treturn 1;\n\t}\n\n\treturn min;\n}\n\nfunction getSupportLevel(stream) {\n\tconst level = supportsColor(stream, stream && stream.isTTY);\n\treturn translateLevel(level);\n}\n\nmodule.exports = {\n\tsupportsColor: getSupportLevel,\n\tstdout: translateLevel(supportsColor(true, tty.isatty(1))),\n\tstderr: translateLevel(supportsColor(true, tty.isatty(2)))\n};\n","/**\n * Module dependencies.\n */\n\nconst tty = require('tty');\nconst util = require('util');\n\n/**\n * This is the Node.js implementation of `debug()`.\n */\n\nexports.init = init;\nexports.log = log;\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.destroy = util.deprecate(\n\t() => {},\n\t'Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.'\n);\n\n/**\n * Colors.\n */\n\nexports.colors = [6, 2, 3, 4, 5, 1];\n\ntry {\n\t// Optional dependency (as in, doesn't need to be installed, NOT like optionalDependencies in package.json)\n\t// eslint-disable-next-line import/no-extraneous-dependencies\n\tconst supportsColor = require('supports-color');\n\n\tif (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) {\n\t\texports.colors = [\n\t\t\t20,\n\t\t\t21,\n\t\t\t26,\n\t\t\t27,\n\t\t\t32,\n\t\t\t33,\n\t\t\t38,\n\t\t\t39,\n\t\t\t40,\n\t\t\t41,\n\t\t\t42,\n\t\t\t43,\n\t\t\t44,\n\t\t\t45,\n\t\t\t56,\n\t\t\t57,\n\t\t\t62,\n\t\t\t63,\n\t\t\t68,\n\t\t\t69,\n\t\t\t74,\n\t\t\t75,\n\t\t\t76,\n\t\t\t77,\n\t\t\t78,\n\t\t\t79,\n\t\t\t80,\n\t\t\t81,\n\t\t\t92,\n\t\t\t93,\n\t\t\t98,\n\t\t\t99,\n\t\t\t112,\n\t\t\t113,\n\t\t\t128,\n\t\t\t129,\n\t\t\t134,\n\t\t\t135,\n\t\t\t148,\n\t\t\t149,\n\t\t\t160,\n\t\t\t161,\n\t\t\t162,\n\t\t\t163,\n\t\t\t164,\n\t\t\t165,\n\t\t\t166,\n\t\t\t167,\n\t\t\t168,\n\t\t\t169,\n\t\t\t170,\n\t\t\t171,\n\t\t\t172,\n\t\t\t173,\n\t\t\t178,\n\t\t\t179,\n\t\t\t184,\n\t\t\t185,\n\t\t\t196,\n\t\t\t197,\n\t\t\t198,\n\t\t\t199,\n\t\t\t200,\n\t\t\t201,\n\t\t\t202,\n\t\t\t203,\n\t\t\t204,\n\t\t\t205,\n\t\t\t206,\n\t\t\t207,\n\t\t\t208,\n\t\t\t209,\n\t\t\t214,\n\t\t\t215,\n\t\t\t220,\n\t\t\t221\n\t\t];\n\t}\n} catch (error) {\n\t// Swallow - we only care if `supports-color` is available; it doesn't have to be.\n}\n\n/**\n * Build up the default `inspectOpts` object from the environment variables.\n *\n * $ DEBUG_COLORS=no DEBUG_DEPTH=10 DEBUG_SHOW_HIDDEN=enabled node script.js\n */\n\nexports.inspectOpts = Object.keys(process.env).filter(key => {\n\treturn /^debug_/i.test(key);\n}).reduce((obj, key) => {\n\t// Camel-case\n\tconst prop = key\n\t\t.substring(6)\n\t\t.toLowerCase()\n\t\t.replace(/_([a-z])/g, (_, k) => {\n\t\t\treturn k.toUpperCase();\n\t\t});\n\n\t// Coerce string value into JS value\n\tlet val = process.env[key];\n\tif (/^(yes|on|true|enabled)$/i.test(val)) {\n\t\tval = true;\n\t} else if (/^(no|off|false|disabled)$/i.test(val)) {\n\t\tval = false;\n\t} else if (val === 'null') {\n\t\tval = null;\n\t} else {\n\t\tval = Number(val);\n\t}\n\n\tobj[prop] = val;\n\treturn obj;\n}, {});\n\n/**\n * Is stdout a TTY? Colored output is enabled when `true`.\n */\n\nfunction useColors() {\n\treturn 'colors' in exports.inspectOpts ?\n\t\tBoolean(exports.inspectOpts.colors) :\n\t\ttty.isatty(process.stderr.fd);\n}\n\n/**\n * Adds ANSI color escape codes if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\tconst {namespace: name, useColors} = this;\n\n\tif (useColors) {\n\t\tconst c = this.color;\n\t\tconst colorCode = '\\u001B[3' + (c < 8 ? c : '8;5;' + c);\n\t\tconst prefix = ` ${colorCode};1m${name} \\u001B[0m`;\n\n\t\targs[0] = prefix + args[0].split('\\n').join('\\n' + prefix);\n\t\targs.push(colorCode + 'm+' + module.exports.humanize(this.diff) + '\\u001B[0m');\n\t} else {\n\t\targs[0] = getDate() + name + ' ' + args[0];\n\t}\n}\n\nfunction getDate() {\n\tif (exports.inspectOpts.hideDate) {\n\t\treturn '';\n\t}\n\treturn new Date().toISOString() + ' ';\n}\n\n/**\n * Invokes `util.formatWithOptions()` with the specified arguments and writes to stderr.\n */\n\nfunction log(...args) {\n\treturn process.stderr.write(util.formatWithOptions(exports.inspectOpts, ...args) + '\\n');\n}\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\tif (namespaces) {\n\t\tprocess.env.DEBUG = namespaces;\n\t} else {\n\t\t// If you set a process.env field to null or undefined, it gets cast to the\n\t\t// string 'null' or 'undefined'. Just delete instead.\n\t\tdelete process.env.DEBUG;\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\n\nfunction load() {\n\treturn process.env.DEBUG;\n}\n\n/**\n * Init logic for `debug` instances.\n *\n * Create a new `inspectOpts` object in case `useColors` is set\n * differently for a particular `debug` instance.\n */\n\nfunction init(debug) {\n\tdebug.inspectOpts = {};\n\n\tconst keys = Object.keys(exports.inspectOpts);\n\tfor (let i = 0; i < keys.length; i++) {\n\t\tdebug.inspectOpts[keys[i]] = exports.inspectOpts[keys[i]];\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %o to `util.inspect()`, all on a single line.\n */\n\nformatters.o = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts)\n\t\t.split('\\n')\n\t\t.map(str => str.trim())\n\t\t.join(' ');\n};\n\n/**\n * Map %O to `util.inspect()`, allowing multiple lines if needed.\n */\n\nformatters.O = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts);\n};\n","/**\n * Detect Electron renderer / nwjs process, which is node, but we should\n * treat as a browser.\n */\n\nif (typeof process === 'undefined' || process.type === 'renderer' || process.browser === true || process.__nwjs) {\n\tmodule.exports = require('./browser.js');\n} else {\n\tmodule.exports = require('./node.js');\n}\n","const bl = require('bl')\nconst { EventEmitter } = require('events')\nconst Packet = require('./packet')\nconst constants = require('./constants')\nconst debug = require('debug')('mqtt-packet:parser')\n\nclass Parser extends EventEmitter {\n constructor () {\n super()\n this.parser = this.constructor.parser\n }\n\n static parser (opt) {\n if (!(this instanceof Parser)) return (new Parser()).parser(opt)\n\n this.settings = opt || {}\n\n this._states = [\n '_parseHeader',\n '_parseLength',\n '_parsePayload',\n '_newPacket'\n ]\n\n this._resetState()\n return this\n }\n\n _resetState () {\n debug('_resetState: resetting packet, error, _list, and _stateCounter')\n this.packet = new Packet()\n this.error = null\n this._list = bl()\n this._stateCounter = 0\n }\n\n parse (buf) {\n if (this.error) this._resetState()\n\n this._list.append(buf)\n debug('parse: current state: %s', this._states[this._stateCounter])\n while ((this.packet.length !== -1 || this._list.length > 0) &&\n this[this._states[this._stateCounter]]() &&\n !this.error) {\n this._stateCounter++\n debug('parse: state complete. _stateCounter is now: %d', this._stateCounter)\n debug('parse: packet.length: %d, buffer list length: %d', this.packet.length, this._list.length)\n if (this._stateCounter >= this._states.length) this._stateCounter = 0\n }\n debug('parse: exited while loop. packet: %d, buffer list length: %d', this.packet.length, this._list.length)\n return this._list.length\n }\n\n _parseHeader () {\n // There is at least one byte in the buffer\n const zero = this._list.readUInt8(0)\n const cmdIndex = zero >> constants.CMD_SHIFT\n this.packet.cmd = constants.types[cmdIndex]\n const headerFlags = zero & 0xf\n const requiredHeaderFlags = constants.requiredHeaderFlags[cmdIndex]\n if (requiredHeaderFlags != null && headerFlags !== requiredHeaderFlags) {\n // Where a flag bit is marked as “Reserved” in Table 2.2 - Flag Bits, it is reserved for future use and MUST be set to the value listed in that table [MQTT-2.2.2-1]. If invalid flags are received, the receiver MUST close the Network Connection [MQTT-2.2.2-2]\n return this._emitError(new Error(constants.requiredHeaderFlagsErrors[cmdIndex]))\n }\n this.packet.retain = (zero & constants.RETAIN_MASK) !== 0\n this.packet.qos = (zero >> constants.QOS_SHIFT) & constants.QOS_MASK\n if (this.packet.qos > 2) {\n return this._emitError(new Error('Packet must not have both QoS bits set to 1'))\n }\n this.packet.dup = (zero & constants.DUP_MASK) !== 0\n debug('_parseHeader: packet: %o', this.packet)\n\n this._list.consume(1)\n\n return true\n }\n\n _parseLength () {\n // There is at least one byte in the list\n const result = this._parseVarByteNum(true)\n\n if (result) {\n this.packet.length = result.value\n this._list.consume(result.bytes)\n }\n debug('_parseLength %d', result.value)\n return !!result\n }\n\n _parsePayload () {\n debug('_parsePayload: payload %O', this._list)\n let result = false\n\n // Do we have a payload? Do we have enough data to complete the payload?\n // PINGs have no payload\n if (this.packet.length === 0 || this._list.length >= this.packet.length) {\n this._pos = 0\n\n switch (this.packet.cmd) {\n case 'connect':\n this._parseConnect()\n break\n case 'connack':\n this._parseConnack()\n break\n case 'publish':\n this._parsePublish()\n break\n case 'puback':\n case 'pubrec':\n case 'pubrel':\n case 'pubcomp':\n this._parseConfirmation()\n break\n case 'subscribe':\n this._parseSubscribe()\n break\n case 'suback':\n this._parseSuback()\n break\n case 'unsubscribe':\n this._parseUnsubscribe()\n break\n case 'unsuback':\n this._parseUnsuback()\n break\n case 'pingreq':\n case 'pingresp':\n // These are empty, nothing to do\n break\n case 'disconnect':\n this._parseDisconnect()\n break\n case 'auth':\n this._parseAuth()\n break\n default:\n this._emitError(new Error('Not supported'))\n }\n\n result = true\n }\n debug('_parsePayload complete result: %s', result)\n return result\n }\n\n _parseConnect () {\n debug('_parseConnect')\n let topic // Will topic\n let payload // Will payload\n let password // Password\n let username // Username\n const flags = {}\n const packet = this.packet\n\n // Parse protocolId\n const protocolId = this._parseString()\n\n if (protocolId === null) return this._emitError(new Error('Cannot parse protocolId'))\n if (protocolId !== 'MQTT' && protocolId !== 'MQIsdp') {\n return this._emitError(new Error('Invalid protocolId'))\n }\n\n packet.protocolId = protocolId\n\n // Parse constants version number\n if (this._pos >= this._list.length) return this._emitError(new Error('Packet too short'))\n\n packet.protocolVersion = this._list.readUInt8(this._pos)\n\n if (packet.protocolVersion >= 128) {\n packet.bridgeMode = true\n packet.protocolVersion = packet.protocolVersion - 128\n }\n\n if (packet.protocolVersion !== 3 && packet.protocolVersion !== 4 && packet.protocolVersion !== 5) {\n return this._emitError(new Error('Invalid protocol version'))\n }\n\n this._pos++\n\n if (this._pos >= this._list.length) {\n return this._emitError(new Error('Packet too short'))\n }\n\n if (this._list.readUInt8(this._pos) & 0x1) {\n // The Server MUST validate that the reserved flag in the CONNECT Control Packet is set to zero and disconnect the Client if it is not zero [MQTT-3.1.2-3]\n return this._emitError(new Error('Connect flag bit 0 must be 0, but got 1'))\n }\n // Parse connect flags\n flags.username = (this._list.readUInt8(this._pos) & constants.USERNAME_MASK)\n flags.password = (this._list.readUInt8(this._pos) & constants.PASSWORD_MASK)\n flags.will = (this._list.readUInt8(this._pos) & constants.WILL_FLAG_MASK)\n\n const willRetain = !!(this._list.readUInt8(this._pos) & constants.WILL_RETAIN_MASK)\n const willQos = (this._list.readUInt8(this._pos) &\n constants.WILL_QOS_MASK) >> constants.WILL_QOS_SHIFT\n\n if (flags.will) {\n packet.will = {}\n packet.will.retain = willRetain\n packet.will.qos = willQos\n } else {\n if (willRetain) {\n return this._emitError(new Error('Will Retain Flag must be set to zero when Will Flag is set to 0'))\n }\n if (willQos) {\n return this._emitError(new Error('Will QoS must be set to zero when Will Flag is set to 0'))\n }\n }\n\n packet.clean = (this._list.readUInt8(this._pos) & constants.CLEAN_SESSION_MASK) !== 0\n this._pos++\n\n // Parse keepalive\n packet.keepalive = this._parseNum()\n if (packet.keepalive === -1) return this._emitError(new Error('Packet too short'))\n\n // parse properties\n if (packet.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n // Parse clientId\n const clientId = this._parseString()\n if (clientId === null) return this._emitError(new Error('Packet too short'))\n packet.clientId = clientId\n debug('_parseConnect: packet.clientId: %s', packet.clientId)\n\n if (flags.will) {\n if (packet.protocolVersion === 5) {\n const willProperties = this._parseProperties()\n if (Object.getOwnPropertyNames(willProperties).length) {\n packet.will.properties = willProperties\n }\n }\n // Parse will topic\n topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse will topic'))\n packet.will.topic = topic\n debug('_parseConnect: packet.will.topic: %s', packet.will.topic)\n\n // Parse will payload\n payload = this._parseBuffer()\n if (payload === null) return this._emitError(new Error('Cannot parse will payload'))\n packet.will.payload = payload\n debug('_parseConnect: packet.will.paylaod: %s', packet.will.payload)\n }\n\n // Parse username\n if (flags.username) {\n username = this._parseString()\n if (username === null) return this._emitError(new Error('Cannot parse username'))\n packet.username = username\n debug('_parseConnect: packet.username: %s', packet.username)\n }\n\n // Parse password\n if (flags.password) {\n password = this._parseBuffer()\n if (password === null) return this._emitError(new Error('Cannot parse password'))\n packet.password = password\n }\n // need for right parse auth packet and self set up\n this.settings = packet\n debug('_parseConnect: complete')\n return packet\n }\n\n _parseConnack () {\n debug('_parseConnack')\n const packet = this.packet\n\n if (this._list.length < 1) return null\n const flags = this._list.readUInt8(this._pos++)\n if (flags > 1) {\n return this._emitError(new Error('Invalid connack flags, bits 7-1 must be set to 0'))\n }\n packet.sessionPresent = !!(flags & constants.SESSIONPRESENT_MASK)\n\n if (this.settings.protocolVersion === 5) {\n if (this._list.length >= 2) {\n packet.reasonCode = this._list.readUInt8(this._pos++)\n } else {\n packet.reasonCode = 0\n }\n } else {\n if (this._list.length < 2) return null\n packet.returnCode = this._list.readUInt8(this._pos++)\n }\n\n if (packet.returnCode === -1 || packet.reasonCode === -1) return this._emitError(new Error('Cannot parse return code'))\n // mqtt 5 properties\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n debug('_parseConnack: complete')\n }\n\n _parsePublish () {\n debug('_parsePublish')\n const packet = this.packet\n packet.topic = this._parseString()\n\n if (packet.topic === null) return this._emitError(new Error('Cannot parse topic'))\n\n // Parse messageId\n if (packet.qos > 0) if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n packet.payload = this._list.slice(this._pos, packet.length)\n debug('_parsePublish: payload from buffer list: %o', packet.payload)\n }\n\n _parseSubscribe () {\n debug('_parseSubscribe')\n const packet = this.packet\n let topic\n let options\n let qos\n let rh\n let rap\n let nl\n let subscription\n\n packet.subscriptions = []\n\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n if (packet.length <= 0) { return this._emitError(new Error('Malformed subscribe, no payload specified')) }\n\n while (this._pos < packet.length) {\n // Parse topic\n topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse topic'))\n if (this._pos >= packet.length) return this._emitError(new Error('Malformed Subscribe Payload'))\n\n options = this._parseByte()\n\n if (this.settings.protocolVersion === 5) {\n if (options & 0xc0) {\n return this._emitError(new Error('Invalid subscribe topic flag bits, bits 7-6 must be 0'))\n }\n } else {\n if (options & 0xfc) {\n return this._emitError(new Error('Invalid subscribe topic flag bits, bits 7-2 must be 0'))\n }\n }\n\n qos = options & constants.SUBSCRIBE_OPTIONS_QOS_MASK\n if (qos > 2) {\n return this._emitError(new Error('Invalid subscribe QoS, must be <= 2'))\n }\n nl = ((options >> constants.SUBSCRIBE_OPTIONS_NL_SHIFT) & constants.SUBSCRIBE_OPTIONS_NL_MASK) !== 0\n rap = ((options >> constants.SUBSCRIBE_OPTIONS_RAP_SHIFT) & constants.SUBSCRIBE_OPTIONS_RAP_MASK) !== 0\n rh = (options >> constants.SUBSCRIBE_OPTIONS_RH_SHIFT) & constants.SUBSCRIBE_OPTIONS_RH_MASK\n\n if (rh > 2) {\n return this._emitError(new Error('Invalid retain handling, must be <= 2'))\n }\n\n subscription = { topic, qos }\n\n // mqtt 5 options\n if (this.settings.protocolVersion === 5) {\n subscription.nl = nl\n subscription.rap = rap\n subscription.rh = rh\n } else if (this.settings.bridgeMode) {\n subscription.rh = 0\n subscription.rap = true\n subscription.nl = true\n }\n\n // Push pair to subscriptions\n debug('_parseSubscribe: push subscription `%s` to subscription', subscription)\n packet.subscriptions.push(subscription)\n }\n }\n\n _parseSuback () {\n debug('_parseSuback')\n const packet = this.packet\n this.packet.granted = []\n\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n if (packet.length <= 0) { return this._emitError(new Error('Malformed suback, no payload specified')) }\n\n // Parse granted QoSes\n while (this._pos < this.packet.length) {\n const code = this._list.readUInt8(this._pos++)\n if (this.settings.protocolVersion === 5) {\n if (!constants.MQTT5_SUBACK_CODES[code]) {\n return this._emitError(new Error('Invalid suback code'))\n }\n } else {\n if (code > 2 && code !== 0x80) {\n return this._emitError(new Error('Invalid suback QoS, must be 0, 1, 2 or 128'))\n }\n }\n this.packet.granted.push(code)\n }\n }\n\n _parseUnsubscribe () {\n debug('_parseUnsubscribe')\n const packet = this.packet\n\n packet.unsubscriptions = []\n\n // Parse messageId\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n if (packet.length <= 0) { return this._emitError(new Error('Malformed unsubscribe, no payload specified')) }\n\n while (this._pos < packet.length) {\n // Parse topic\n const topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse topic'))\n\n // Push topic to unsubscriptions\n debug('_parseUnsubscribe: push topic `%s` to unsubscriptions', topic)\n packet.unsubscriptions.push(topic)\n }\n }\n\n _parseUnsuback () {\n debug('_parseUnsuback')\n const packet = this.packet\n if (!this._parseMessageId()) return this._emitError(new Error('Cannot parse messageId'))\n\n if ((this.settings.protocolVersion === 3 ||\n this.settings.protocolVersion === 4) && packet.length !== 2) {\n return this._emitError(new Error('Malformed unsuback, payload length must be 2'))\n }\n if (packet.length <= 0) { return this._emitError(new Error('Malformed unsuback, no payload specified')) }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n // Parse granted QoSes\n packet.granted = []\n\n while (this._pos < this.packet.length) {\n const code = this._list.readUInt8(this._pos++)\n if (!constants.MQTT5_UNSUBACK_CODES[code]) {\n return this._emitError(new Error('Invalid unsuback code'))\n }\n this.packet.granted.push(code)\n }\n }\n }\n\n // parse packets like puback, pubrec, pubrel, pubcomp\n _parseConfirmation () {\n debug('_parseConfirmation: packet.cmd: `%s`', this.packet.cmd)\n const packet = this.packet\n\n this._parseMessageId()\n\n if (this.settings.protocolVersion === 5) {\n if (packet.length > 2) {\n // response code\n packet.reasonCode = this._parseByte()\n switch (this.packet.cmd) {\n case 'puback':\n case 'pubrec':\n if (!constants.MQTT5_PUBACK_PUBREC_CODES[packet.reasonCode]) {\n return this._emitError(new Error('Invalid ' + this.packet.cmd + ' reason code'))\n }\n break\n case 'pubrel':\n case 'pubcomp':\n if (!constants.MQTT5_PUBREL_PUBCOMP_CODES[packet.reasonCode]) {\n return this._emitError(new Error('Invalid ' + this.packet.cmd + ' reason code'))\n }\n break\n }\n debug('_parseConfirmation: packet.reasonCode `%d`', packet.reasonCode)\n } else {\n packet.reasonCode = 0\n }\n\n if (packet.length > 3) {\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n }\n\n return true\n }\n\n // parse disconnect packet\n _parseDisconnect () {\n const packet = this.packet\n debug('_parseDisconnect')\n\n if (this.settings.protocolVersion === 5) {\n // response code\n if (this._list.length > 0) {\n packet.reasonCode = this._parseByte()\n if (!constants.MQTT5_DISCONNECT_CODES[packet.reasonCode]) {\n this._emitError(new Error('Invalid disconnect reason code'))\n }\n } else {\n packet.reasonCode = 0\n }\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n debug('_parseDisconnect result: true')\n return true\n }\n\n // parse auth packet\n _parseAuth () {\n debug('_parseAuth')\n const packet = this.packet\n\n if (this.settings.protocolVersion !== 5) {\n return this._emitError(new Error('Not supported auth packet for this version MQTT'))\n }\n\n // response code\n packet.reasonCode = this._parseByte()\n if (!constants.MQTT5_AUTH_CODES[packet.reasonCode]) {\n return this._emitError(new Error('Invalid auth reason code'))\n }\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n\n debug('_parseAuth: result: true')\n return true\n }\n\n _parseMessageId () {\n const packet = this.packet\n\n packet.messageId = this._parseNum()\n\n if (packet.messageId === null) {\n this._emitError(new Error('Cannot parse messageId'))\n return false\n }\n\n debug('_parseMessageId: packet.messageId %d', packet.messageId)\n return true\n }\n\n _parseString (maybeBuffer) {\n const length = this._parseNum()\n const end = length + this._pos\n\n if (length === -1 || end > this._list.length || end > this.packet.length) return null\n\n const result = this._list.toString('utf8', this._pos, end)\n this._pos += length\n debug('_parseString: result: %s', result)\n return result\n }\n\n _parseStringPair () {\n debug('_parseStringPair')\n return {\n name: this._parseString(),\n value: this._parseString()\n }\n }\n\n _parseBuffer () {\n const length = this._parseNum()\n const end = length + this._pos\n\n if (length === -1 || end > this._list.length || end > this.packet.length) return null\n\n const result = this._list.slice(this._pos, end)\n\n this._pos += length\n debug('_parseBuffer: result: %o', result)\n return result\n }\n\n _parseNum () {\n if (this._list.length - this._pos < 2) return -1\n\n const result = this._list.readUInt16BE(this._pos)\n this._pos += 2\n debug('_parseNum: result: %s', result)\n return result\n }\n\n _parse4ByteNum () {\n if (this._list.length - this._pos < 4) return -1\n\n const result = this._list.readUInt32BE(this._pos)\n this._pos += 4\n debug('_parse4ByteNum: result: %s', result)\n return result\n }\n\n _parseVarByteNum (fullInfoFlag) {\n debug('_parseVarByteNum')\n const maxBytes = 4\n let bytes = 0\n let mul = 1\n let value = 0\n let result = false\n let current\n const padding = this._pos ? this._pos : 0\n\n while (bytes < maxBytes && (padding + bytes) < this._list.length) {\n current = this._list.readUInt8(padding + bytes++)\n value += mul * (current & constants.VARBYTEINT_MASK)\n mul *= 0x80\n\n if ((current & constants.VARBYTEINT_FIN_MASK) === 0) {\n result = true\n break\n }\n if (this._list.length <= bytes) {\n break\n }\n }\n\n if (!result && bytes === maxBytes && this._list.length >= bytes) {\n this._emitError(new Error('Invalid variable byte integer'))\n }\n\n if (padding) {\n this._pos += bytes\n }\n\n if (result) {\n if (fullInfoFlag) {\n result = { bytes, value }\n } else {\n result = value\n }\n } else {\n result = false\n }\n\n debug('_parseVarByteNum: result: %o', result)\n return result\n }\n\n _parseByte () {\n let result\n if (this._pos < this._list.length) {\n result = this._list.readUInt8(this._pos)\n this._pos++\n }\n debug('_parseByte: result: %o', result)\n return result\n }\n\n _parseByType (type) {\n debug('_parseByType: type: %s', type)\n switch (type) {\n case 'byte': {\n return this._parseByte() !== 0\n }\n case 'int8': {\n return this._parseByte()\n }\n case 'int16': {\n return this._parseNum()\n }\n case 'int32': {\n return this._parse4ByteNum()\n }\n case 'var': {\n return this._parseVarByteNum()\n }\n case 'string': {\n return this._parseString()\n }\n case 'pair': {\n return this._parseStringPair()\n }\n case 'binary': {\n return this._parseBuffer()\n }\n }\n }\n\n _parseProperties () {\n debug('_parseProperties')\n const length = this._parseVarByteNum()\n const start = this._pos\n const end = start + length\n const result = {}\n while (this._pos < end) {\n const type = this._parseByte()\n if (!type) {\n this._emitError(new Error('Cannot parse property code type'))\n return false\n }\n const name = constants.propertiesCodes[type]\n if (!name) {\n this._emitError(new Error('Unknown property'))\n return false\n }\n // user properties process\n if (name === 'userProperties') {\n if (!result[name]) {\n result[name] = Object.create(null)\n }\n const currentUserProperty = this._parseByType(constants.propertiesTypes[name])\n if (result[name][currentUserProperty.name]) {\n if (Array.isArray(result[name][currentUserProperty.name])) {\n result[name][currentUserProperty.name].push(currentUserProperty.value)\n } else {\n const currentValue = result[name][currentUserProperty.name]\n result[name][currentUserProperty.name] = [currentValue]\n result[name][currentUserProperty.name].push(currentUserProperty.value)\n }\n } else {\n result[name][currentUserProperty.name] = currentUserProperty.value\n }\n continue\n }\n if (result[name]) {\n if (Array.isArray(result[name])) {\n result[name].push(this._parseByType(constants.propertiesTypes[name]))\n } else {\n result[name] = [result[name]]\n result[name].push(this._parseByType(constants.propertiesTypes[name]))\n }\n } else {\n result[name] = this._parseByType(constants.propertiesTypes[name])\n }\n }\n return result\n }\n\n _newPacket () {\n debug('_newPacket')\n if (this.packet) {\n this._list.consume(this.packet.length)\n debug('_newPacket: parser emit packet: packet.cmd: %s, packet.payload: %s, packet.length: %d', this.packet.cmd, this.packet.payload, this.packet.length)\n this.emit('packet', this.packet)\n }\n debug('_newPacket: new packet')\n this.packet = new Packet()\n\n this._pos = 0\n\n return true\n }\n\n _emitError (err) {\n debug('_emitError', err)\n this.error = err\n this.emit('error', err)\n }\n}\n\nmodule.exports = Parser\n","const { Buffer } = require('buffer')\nconst max = 65536\nconst cache = {}\n\n// in node 6 Buffer.subarray returns a Uint8Array instead of a Buffer\n// later versions return a Buffer\n// alternative is Buffer.slice but that creates a new buffer\n// creating new buffers takes time\n// SubOk is only false on node < 8\nconst SubOk = Buffer.isBuffer(Buffer.from([1, 2]).subarray(0, 1))\n\nfunction generateBuffer (i) {\n const buffer = Buffer.allocUnsafe(2)\n buffer.writeUInt8(i >> 8, 0)\n buffer.writeUInt8(i & 0x00FF, 0 + 1)\n\n return buffer\n}\n\nfunction generateCache () {\n for (let i = 0; i < max; i++) {\n cache[i] = generateBuffer(i)\n }\n}\n\nfunction genBufVariableByteInt (num) {\n const maxLength = 4 // max 4 bytes\n let digit = 0\n let pos = 0\n const buffer = Buffer.allocUnsafe(maxLength)\n\n do {\n digit = num % 128 | 0\n num = num / 128 | 0\n if (num > 0) digit = digit | 0x80\n\n buffer.writeUInt8(digit, pos++)\n } while (num > 0 && pos < maxLength)\n\n if (num > 0) {\n pos = 0\n }\n\n return SubOk ? buffer.subarray(0, pos) : buffer.slice(0, pos)\n}\n\nfunction generate4ByteBuffer (num) {\n const buffer = Buffer.allocUnsafe(4)\n buffer.writeUInt32BE(num, 0)\n return buffer\n}\n\nmodule.exports = {\n cache,\n generateCache,\n generateNumber: generateBuffer,\n genBufVariableByteInt,\n generate4ByteBuffer\n}\n","'use strict';\n\nif (typeof process === 'undefined' ||\n !process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = { nextTick: nextTick };\n} else {\n module.exports = process\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n","const protocol = require('./constants')\nconst { Buffer } = require('buffer')\nconst empty = Buffer.allocUnsafe(0)\nconst zeroBuf = Buffer.from([0])\nconst numbers = require('./numbers')\nconst nextTick = require('process-nextick-args').nextTick\nconst debug = require('debug')('mqtt-packet:writeToStream')\n\nconst numCache = numbers.cache\nconst generateNumber = numbers.generateNumber\nconst generateCache = numbers.generateCache\nconst genBufVariableByteInt = numbers.genBufVariableByteInt\nconst generate4ByteBuffer = numbers.generate4ByteBuffer\nlet writeNumber = writeNumberCached\nlet toGenerate = true\n\nfunction generate (packet, stream, opts) {\n debug('generate called')\n if (stream.cork) {\n stream.cork()\n nextTick(uncork, stream)\n }\n\n if (toGenerate) {\n toGenerate = false\n generateCache()\n }\n debug('generate: packet.cmd: %s', packet.cmd)\n switch (packet.cmd) {\n case 'connect':\n return connect(packet, stream, opts)\n case 'connack':\n return connack(packet, stream, opts)\n case 'publish':\n return publish(packet, stream, opts)\n case 'puback':\n case 'pubrec':\n case 'pubrel':\n case 'pubcomp':\n return confirmation(packet, stream, opts)\n case 'subscribe':\n return subscribe(packet, stream, opts)\n case 'suback':\n return suback(packet, stream, opts)\n case 'unsubscribe':\n return unsubscribe(packet, stream, opts)\n case 'unsuback':\n return unsuback(packet, stream, opts)\n case 'pingreq':\n case 'pingresp':\n return emptyPacket(packet, stream, opts)\n case 'disconnect':\n return disconnect(packet, stream, opts)\n case 'auth':\n return auth(packet, stream, opts)\n default:\n stream.destroy(new Error('Unknown command'))\n return false\n }\n}\n/**\n * Controls numbers cache.\n * Set to \"false\" to allocate buffers on-the-flight instead of pre-generated cache\n */\nObject.defineProperty(generate, 'cacheNumbers', {\n get () {\n return writeNumber === writeNumberCached\n },\n set (value) {\n if (value) {\n if (!numCache || Object.keys(numCache).length === 0) toGenerate = true\n writeNumber = writeNumberCached\n } else {\n toGenerate = false\n writeNumber = writeNumberGenerated\n }\n }\n})\n\nfunction uncork (stream) {\n stream.uncork()\n}\n\nfunction connect (packet, stream, opts) {\n const settings = packet || {}\n const protocolId = settings.protocolId || 'MQTT'\n let protocolVersion = settings.protocolVersion || 4\n const will = settings.will\n let clean = settings.clean\n const keepalive = settings.keepalive || 0\n const clientId = settings.clientId || ''\n const username = settings.username\n const password = settings.password\n /* mqtt5 new oprions */\n const properties = settings.properties\n\n if (clean === undefined) clean = true\n\n let length = 0\n\n // Must be a string and non-falsy\n if (!protocolId ||\n (typeof protocolId !== 'string' && !Buffer.isBuffer(protocolId))) {\n stream.destroy(new Error('Invalid protocolId'))\n return false\n } else length += protocolId.length + 2\n\n // Must be 3 or 4 or 5\n if (protocolVersion !== 3 && protocolVersion !== 4 && protocolVersion !== 5) {\n stream.destroy(new Error('Invalid protocol version'))\n return false\n } else length += 1\n\n // ClientId might be omitted in 3.1.1 and 5, but only if cleanSession is set to 1\n if ((typeof clientId === 'string' || Buffer.isBuffer(clientId)) &&\n (clientId || protocolVersion >= 4) && (clientId || clean)) {\n length += Buffer.byteLength(clientId) + 2\n } else {\n if (protocolVersion < 4) {\n stream.destroy(new Error('clientId must be supplied before 3.1.1'))\n return false\n }\n if ((clean * 1) === 0) {\n stream.destroy(new Error('clientId must be given if cleanSession set to 0'))\n return false\n }\n }\n\n // Must be a two byte number\n if (typeof keepalive !== 'number' ||\n keepalive < 0 ||\n keepalive > 65535 ||\n keepalive % 1 !== 0) {\n stream.destroy(new Error('Invalid keepalive'))\n return false\n } else length += 2\n\n // Connect flags\n length += 1\n\n let propertiesData\n let willProperties\n\n // Properties\n if (protocolVersion === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // If will exists...\n if (will) {\n // It must be an object\n if (typeof will !== 'object') {\n stream.destroy(new Error('Invalid will'))\n return false\n }\n // It must have topic typeof string\n if (!will.topic || typeof will.topic !== 'string') {\n stream.destroy(new Error('Invalid will topic'))\n return false\n } else {\n length += Buffer.byteLength(will.topic) + 2\n }\n\n // Payload\n length += 2 // payload length\n if (will.payload) {\n if (will.payload.length >= 0) {\n if (typeof will.payload === 'string') {\n length += Buffer.byteLength(will.payload)\n } else {\n length += will.payload.length\n }\n } else {\n stream.destroy(new Error('Invalid will payload'))\n return false\n }\n }\n // will properties\n willProperties = {}\n if (protocolVersion === 5) {\n willProperties = getProperties(stream, will.properties)\n if (!willProperties) { return false }\n length += willProperties.length\n }\n }\n\n // Username\n let providedUsername = false\n if (username != null) {\n if (isStringOrBuffer(username)) {\n providedUsername = true\n length += Buffer.byteLength(username) + 2\n } else {\n stream.destroy(new Error('Invalid username'))\n return false\n }\n }\n\n // Password\n if (password != null) {\n if (!providedUsername) {\n stream.destroy(new Error('Username is required to use password'))\n return false\n }\n\n if (isStringOrBuffer(password)) {\n length += byteLength(password) + 2\n } else {\n stream.destroy(new Error('Invalid password'))\n return false\n }\n }\n\n // Generate header\n stream.write(protocol.CONNECT_HEADER)\n\n // Generate length\n writeVarByteInt(stream, length)\n\n // Generate protocol ID\n writeStringOrBuffer(stream, protocolId)\n\n if (settings.bridgeMode) {\n protocolVersion += 128\n }\n\n stream.write(\n protocolVersion === 131\n ? protocol.VERSION131\n : protocolVersion === 132\n ? protocol.VERSION132\n : protocolVersion === 4\n ? protocol.VERSION4\n : protocolVersion === 5\n ? protocol.VERSION5\n : protocol.VERSION3\n )\n\n // Connect flags\n let flags = 0\n flags |= (username != null) ? protocol.USERNAME_MASK : 0\n flags |= (password != null) ? protocol.PASSWORD_MASK : 0\n flags |= (will && will.retain) ? protocol.WILL_RETAIN_MASK : 0\n flags |= (will && will.qos) ? will.qos << protocol.WILL_QOS_SHIFT : 0\n flags |= will ? protocol.WILL_FLAG_MASK : 0\n flags |= clean ? protocol.CLEAN_SESSION_MASK : 0\n\n stream.write(Buffer.from([flags]))\n\n // Keepalive\n writeNumber(stream, keepalive)\n\n // Properties\n if (protocolVersion === 5) {\n propertiesData.write()\n }\n\n // Client ID\n writeStringOrBuffer(stream, clientId)\n\n // Will\n if (will) {\n if (protocolVersion === 5) {\n willProperties.write()\n }\n writeString(stream, will.topic)\n writeStringOrBuffer(stream, will.payload)\n }\n\n // Username and password\n if (username != null) {\n writeStringOrBuffer(stream, username)\n }\n if (password != null) {\n writeStringOrBuffer(stream, password)\n }\n // This is a small packet that happens only once on a stream\n // We assume the stream is always free to receive more data after this\n return true\n}\n\nfunction connack (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const rc = version === 5 ? settings.reasonCode : settings.returnCode\n const properties = settings.properties\n let length = 2 // length of rc and sessionHeader\n\n // Check return code\n if (typeof rc !== 'number') {\n stream.destroy(new Error('Invalid return code'))\n return false\n }\n // mqtt5 properties\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n stream.write(protocol.CONNACK_HEADER)\n // length\n writeVarByteInt(stream, length)\n stream.write(settings.sessionPresent ? protocol.SESSIONPRESENT_HEADER : zeroBuf)\n\n stream.write(Buffer.from([rc]))\n if (propertiesData != null) {\n propertiesData.write()\n }\n return true\n}\n\nfunction publish (packet, stream, opts) {\n debug('publish: packet: %o', packet)\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const qos = settings.qos || 0\n const retain = settings.retain ? protocol.RETAIN_MASK : 0\n const topic = settings.topic\n const payload = settings.payload || empty\n const id = settings.messageId\n const properties = settings.properties\n\n let length = 0\n\n // Topic must be a non-empty string or Buffer\n if (typeof topic === 'string') length += Buffer.byteLength(topic) + 2\n else if (Buffer.isBuffer(topic)) length += topic.length + 2\n else {\n stream.destroy(new Error('Invalid topic'))\n return false\n }\n\n // Get the payload length\n if (!Buffer.isBuffer(payload)) length += Buffer.byteLength(payload)\n else length += payload.length\n\n // Message ID must a number if qos > 0\n if (qos && typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n } else if (qos) length += 2\n\n // mqtt5 properties\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.PUBLISH_HEADER[qos][settings.dup ? 1 : 0][retain ? 1 : 0])\n\n // Remaining length\n writeVarByteInt(stream, length)\n\n // Topic\n writeNumber(stream, byteLength(topic))\n stream.write(topic)\n\n // Message ID\n if (qos > 0) writeNumber(stream, id)\n\n // Properties\n if (propertiesData != null) {\n propertiesData.write()\n }\n\n // Payload\n debug('publish: payload: %o', payload)\n return stream.write(payload)\n}\n\n/* Puback, pubrec, pubrel and pubcomp */\nfunction confirmation (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const type = settings.cmd || 'puback'\n const id = settings.messageId\n const dup = (settings.dup && type === 'pubrel') ? protocol.DUP_MASK : 0\n let qos = 0\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 3 : 2\n\n if (type === 'pubrel') qos = 1\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n // Confirm should not add empty property length with no properties (rfc 3.4.2.2.1)\n if (typeof properties === 'object') {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n }\n\n // Header\n stream.write(protocol.ACKS[type][qos][dup][0])\n\n // Length === 3 is only true of version === 5 and no properties; therefore if reasonCode === 0 we are allowed to skip both bytes - but if we write the reason code we also have to write property length [MQTT-3.4.2-1].\n if (length === 3) length += reasonCode !== 0 ? 1 : -1\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // reason code in header - but only if it couldn't be omitted - indicated by length !== 2.\n if (version === 5 && length !== 2) {\n stream.write(Buffer.from([reasonCode]))\n }\n\n // properties mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n } else {\n if (length === 4) {\n // we have no properties but have written a reason code - so we need to indicate empty properties by filling in a zero.\n stream.write(Buffer.from([0]))\n }\n }\n return true\n}\n\nfunction subscribe (packet, stream, opts) {\n debug('subscribe: packet: ')\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const id = settings.messageId\n const subs = settings.subscriptions\n const properties = settings.properties\n\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n } else length += 2\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Check subscriptions\n if (typeof subs === 'object' && subs.length) {\n for (let i = 0; i < subs.length; i += 1) {\n const itopic = subs[i].topic\n const iqos = subs[i].qos\n\n if (typeof itopic !== 'string') {\n stream.destroy(new Error('Invalid subscriptions - invalid topic'))\n return false\n }\n if (typeof iqos !== 'number') {\n stream.destroy(new Error('Invalid subscriptions - invalid qos'))\n return false\n }\n\n if (version === 5) {\n const nl = subs[i].nl || false\n if (typeof nl !== 'boolean') {\n stream.destroy(new Error('Invalid subscriptions - invalid No Local'))\n return false\n }\n const rap = subs[i].rap || false\n if (typeof rap !== 'boolean') {\n stream.destroy(new Error('Invalid subscriptions - invalid Retain as Published'))\n return false\n }\n const rh = subs[i].rh || 0\n if (typeof rh !== 'number' || rh > 2) {\n stream.destroy(new Error('Invalid subscriptions - invalid Retain Handling'))\n return false\n }\n }\n\n length += Buffer.byteLength(itopic) + 2 + 1\n }\n } else {\n stream.destroy(new Error('Invalid subscriptions'))\n return false\n }\n\n // Generate header\n debug('subscribe: writing to stream: %o', protocol.SUBSCRIBE_HEADER)\n stream.write(protocol.SUBSCRIBE_HEADER[1][dup ? 1 : 0][0])\n\n // Generate length\n writeVarByteInt(stream, length)\n\n // Generate message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n let result = true\n\n // Generate subs\n for (const sub of subs) {\n const jtopic = sub.topic\n const jqos = sub.qos\n const jnl = +sub.nl\n const jrap = +sub.rap\n const jrh = sub.rh\n let joptions\n\n // Write topic string\n writeString(stream, jtopic)\n\n // options process\n joptions = protocol.SUBSCRIBE_OPTIONS_QOS[jqos]\n if (version === 5) {\n joptions |= jnl ? protocol.SUBSCRIBE_OPTIONS_NL : 0\n joptions |= jrap ? protocol.SUBSCRIBE_OPTIONS_RAP : 0\n joptions |= jrh ? protocol.SUBSCRIBE_OPTIONS_RH[jrh] : 0\n }\n // Write options\n result = stream.write(Buffer.from([joptions]))\n }\n\n return result\n}\n\nfunction suback (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const granted = settings.granted\n const properties = settings.properties\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n } else length += 2\n\n // Check granted qos vector\n if (typeof granted === 'object' && granted.length) {\n for (let i = 0; i < granted.length; i += 1) {\n if (typeof granted[i] !== 'number') {\n stream.destroy(new Error('Invalid qos vector'))\n return false\n }\n length += 1\n }\n } else {\n stream.destroy(new Error('Invalid qos vector'))\n return false\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // header\n stream.write(protocol.SUBACK_HEADER)\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n return stream.write(Buffer.from(granted))\n}\n\nfunction unsubscribe (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const unsubs = settings.unsubscriptions\n const properties = settings.properties\n\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n } else {\n length += 2\n }\n // Check unsubs\n if (typeof unsubs === 'object' && unsubs.length) {\n for (let i = 0; i < unsubs.length; i += 1) {\n if (typeof unsubs[i] !== 'string') {\n stream.destroy(new Error('Invalid unsubscriptions'))\n return false\n }\n length += Buffer.byteLength(unsubs[i]) + 2\n }\n } else {\n stream.destroy(new Error('Invalid unsubscriptions'))\n return false\n }\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.UNSUBSCRIBE_HEADER[1][dup ? 1 : 0][0])\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n // Unsubs\n let result = true\n for (let j = 0; j < unsubs.length; j++) {\n result = writeString(stream, unsubs[j])\n }\n\n return result\n}\n\nfunction unsuback (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const granted = settings.granted\n const properties = settings.properties\n const type = settings.cmd\n const qos = 0\n\n let length = 2\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.destroy(new Error('Invalid messageId'))\n return false\n }\n\n // Check granted\n if (version === 5) {\n if (typeof granted === 'object' && granted.length) {\n for (let i = 0; i < granted.length; i += 1) {\n if (typeof granted[i] !== 'number') {\n stream.destroy(new Error('Invalid qos vector'))\n return false\n }\n length += 1\n }\n } else {\n stream.destroy(new Error('Invalid qos vector'))\n return false\n }\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.ACKS[type][qos][dup][0])\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n // payload\n if (version === 5) {\n stream.write(Buffer.from(granted))\n }\n return true\n}\n\nfunction emptyPacket (packet, stream, opts) {\n return stream.write(protocol.EMPTY[packet.cmd])\n}\n\nfunction disconnect (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 1 : 0\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(Buffer.from([protocol.codes.disconnect << 4]))\n\n // Length\n writeVarByteInt(stream, length)\n\n // reason code in header\n if (version === 5) {\n stream.write(Buffer.from([reasonCode]))\n }\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n return true\n}\n\nfunction auth (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 1 : 0\n\n if (version !== 5) stream.destroy(new Error('Invalid mqtt version for auth packet'))\n\n // properies mqtt 5\n const propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n\n // Header\n stream.write(Buffer.from([protocol.codes.auth << 4]))\n\n // Length\n writeVarByteInt(stream, length)\n\n // reason code in header\n stream.write(Buffer.from([reasonCode]))\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n return true\n}\n\n/**\n * writeVarByteInt - write an MQTT style variable byte integer to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <Number> length - length (>0)\n * @returns <Number> number of bytes written\n *\n * @api private\n */\n\nconst varByteIntCache = {}\nfunction writeVarByteInt (stream, num) {\n if (num > protocol.VARBYTEINT_MAX) {\n stream.destroy(new Error(`Invalid variable byte integer: ${num}`))\n return false\n }\n\n let buffer = varByteIntCache[num]\n\n if (!buffer) {\n buffer = genBufVariableByteInt(num)\n if (num < 16384) varByteIntCache[num] = buffer\n }\n debug('writeVarByteInt: writing to stream: %o', buffer)\n return stream.write(buffer)\n}\n\n/**\n * writeString - write a utf8 string to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> string - string to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\n\nfunction writeString (stream, string) {\n const strlen = Buffer.byteLength(string)\n writeNumber(stream, strlen)\n\n debug('writeString: %s', string)\n return stream.write(string, 'utf8')\n}\n\n/**\n * writeStringPair - write a utf8 string pairs to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <String> name - string name to write\n * @param <String> value - string value to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\nfunction writeStringPair (stream, name, value) {\n writeString(stream, name)\n writeString(stream, value)\n}\n\n/**\n * writeNumber - write a two byte number to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> number - number to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\nfunction writeNumberCached (stream, number) {\n debug('writeNumberCached: number: %d', number)\n debug('writeNumberCached: %o', numCache[number])\n return stream.write(numCache[number])\n}\nfunction writeNumberGenerated (stream, number) {\n const generatedNumber = generateNumber(number)\n debug('writeNumberGenerated: %o', generatedNumber)\n return stream.write(generatedNumber)\n}\nfunction write4ByteNumber (stream, number) {\n const generated4ByteBuffer = generate4ByteBuffer(number)\n debug('write4ByteNumber: %o', generated4ByteBuffer)\n return stream.write(generated4ByteBuffer)\n}\n/**\n * writeStringOrBuffer - write a String or Buffer with the its length prefix\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> toWrite - String or Buffer\n * @return <Number> number of bytes written\n */\nfunction writeStringOrBuffer (stream, toWrite) {\n if (typeof toWrite === 'string') {\n writeString(stream, toWrite)\n } else if (toWrite) {\n writeNumber(stream, toWrite.length)\n stream.write(toWrite)\n } else writeNumber(stream, 0)\n}\n\nfunction getProperties (stream, properties) {\n /* connect properties */\n if (typeof properties !== 'object' || properties.length != null) {\n return {\n length: 1,\n write () {\n writeProperties(stream, {}, 0)\n }\n }\n }\n let propertiesLength = 0\n function getLengthProperty (name, value) {\n const type = protocol.propertiesTypes[name]\n let length = 0\n switch (type) {\n case 'byte': {\n if (typeof value !== 'boolean') {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 1\n break\n }\n case 'int8': {\n if (typeof value !== 'number' || value < 0 || value > 0xff) {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 1\n break\n }\n case 'binary': {\n if (value && value === null) {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + Buffer.byteLength(value) + 2\n break\n }\n case 'int16': {\n if (typeof value !== 'number' || value < 0 || value > 0xffff) {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 2\n break\n }\n case 'int32': {\n if (typeof value !== 'number' || value < 0 || value > 0xffffffff) {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 4\n break\n }\n case 'var': {\n // var byte integer is max 24 bits packed in 32 bits\n if (typeof value !== 'number' || value < 0 || value > 0x0fffffff) {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + Buffer.byteLength(genBufVariableByteInt(value))\n break\n }\n case 'string': {\n if (typeof value !== 'string') {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 2 + Buffer.byteLength(value.toString())\n break\n }\n case 'pair': {\n if (typeof value !== 'object') {\n stream.destroy(new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += Object.getOwnPropertyNames(value).reduce((result, name) => {\n const currentValue = value[name]\n if (Array.isArray(currentValue)) {\n result += currentValue.reduce((currentLength, value) => {\n currentLength += 1 + 2 + Buffer.byteLength(name.toString()) + 2 + Buffer.byteLength(value.toString())\n return currentLength\n }, 0)\n } else {\n result += 1 + 2 + Buffer.byteLength(name.toString()) + 2 + Buffer.byteLength(value[name].toString())\n }\n return result\n }, 0)\n break\n }\n default: {\n stream.destroy(new Error(`Invalid property ${name}: ${value}`))\n return false\n }\n }\n return length\n }\n if (properties) {\n for (const propName in properties) {\n let propLength = 0\n let propValueLength = 0\n const propValue = properties[propName]\n if (Array.isArray(propValue)) {\n for (let valueIndex = 0; valueIndex < propValue.length; valueIndex++) {\n propValueLength = getLengthProperty(propName, propValue[valueIndex])\n if (!propValueLength) { return false }\n propLength += propValueLength\n }\n } else {\n propValueLength = getLengthProperty(propName, propValue)\n if (!propValueLength) { return false }\n propLength = propValueLength\n }\n if (!propLength) return false\n propertiesLength += propLength\n }\n }\n const propertiesLengthLength = Buffer.byteLength(genBufVariableByteInt(propertiesLength))\n\n return {\n length: propertiesLengthLength + propertiesLength,\n write () {\n writeProperties(stream, properties, propertiesLength)\n }\n }\n}\n\nfunction getPropertiesByMaximumPacketSize (stream, properties, opts, length) {\n const mayEmptyProps = ['reasonString', 'userProperties']\n const maximumPacketSize = opts && opts.properties && opts.properties.maximumPacketSize ? opts.properties.maximumPacketSize : 0\n\n let propertiesData = getProperties(stream, properties)\n if (maximumPacketSize) {\n while (length + propertiesData.length > maximumPacketSize) {\n const currentMayEmptyProp = mayEmptyProps.shift()\n if (currentMayEmptyProp && properties[currentMayEmptyProp]) {\n delete properties[currentMayEmptyProp]\n propertiesData = getProperties(stream, properties)\n } else {\n return false\n }\n }\n }\n return propertiesData\n}\n\nfunction writeProperty (stream, propName, value) {\n const type = protocol.propertiesTypes[propName]\n switch (type) {\n case 'byte': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n stream.write(Buffer.from([+value]))\n break\n }\n case 'int8': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n stream.write(Buffer.from([value]))\n break\n }\n case 'binary': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringOrBuffer(stream, value)\n break\n }\n case 'int16': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeNumber(stream, value)\n break\n }\n case 'int32': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n write4ByteNumber(stream, value)\n break\n }\n case 'var': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeVarByteInt(stream, value)\n break\n }\n case 'string': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeString(stream, value)\n break\n }\n case 'pair': {\n Object.getOwnPropertyNames(value).forEach(name => {\n const currentValue = value[name]\n if (Array.isArray(currentValue)) {\n currentValue.forEach(value => {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringPair(stream, name.toString(), value.toString())\n })\n } else {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringPair(stream, name.toString(), currentValue.toString())\n }\n })\n break\n }\n default: {\n stream.destroy(new Error(`Invalid property ${propName} value: ${value}`))\n return false\n }\n }\n}\n\nfunction writeProperties (stream, properties, propertiesLength) {\n /* write properties to stream */\n writeVarByteInt(stream, propertiesLength)\n for (const propName in properties) {\n if (Object.prototype.hasOwnProperty.call(properties, propName) && properties[propName] !== null) {\n const value = properties[propName]\n if (Array.isArray(value)) {\n for (let valueIndex = 0; valueIndex < value.length; valueIndex++) {\n writeProperty(stream, propName, value[valueIndex])\n }\n } else {\n writeProperty(stream, propName, value)\n }\n }\n }\n}\n\nfunction byteLength (bufOrString) {\n if (!bufOrString) return 0\n else if (bufOrString instanceof Buffer) return bufOrString.length\n else return Buffer.byteLength(bufOrString)\n}\n\nfunction isStringOrBuffer (field) {\n return typeof field === 'string' || field instanceof Buffer\n}\n\nmodule.exports = generate\n","const writeToStream = require('./writeToStream')\nconst { EventEmitter } = require('events')\nconst { Buffer } = require('buffer')\n\nfunction generate (packet, opts) {\n const stream = new Accumulator()\n writeToStream(packet, stream, opts)\n return stream.concat()\n}\n\nclass Accumulator extends EventEmitter {\n constructor () {\n super()\n this._array = new Array(20)\n this._i = 0\n }\n\n write (chunk) {\n this._array[this._i++] = chunk\n return true\n }\n\n concat () {\n let length = 0\n const lengths = new Array(this._array.length)\n const list = this._array\n let pos = 0\n let i\n\n for (i = 0; i < list.length && list[i] !== undefined; i++) {\n if (typeof list[i] !== 'string') lengths[i] = list[i].length\n else lengths[i] = Buffer.byteLength(list[i])\n\n length += lengths[i]\n }\n\n const result = Buffer.allocUnsafe(length)\n\n for (i = 0; i < list.length && list[i] !== undefined; i++) {\n if (typeof list[i] !== 'string') {\n list[i].copy(result, pos)\n pos += lengths[i]\n } else {\n result.write(list[i], pos)\n pos += lengths[i]\n }\n }\n\n return result\n }\n\n destroy (err) {\n if (err) this.emit('error', err)\n }\n}\n\nmodule.exports = generate\n","exports.parser = require('./parser').parser\nexports.generate = require('./generate')\nexports.writeToStream = require('./writeToStream')\n","export interface IMessageIdProvider {\n\t/**\n\t * Allocate the first vacant messageId. The messageId become occupied status.\n\t * @return {Number} - The first vacant messageId. If all messageIds are occupied, return null.\n\t */\n\tallocate(): number | null\n\n\t/**\n\t * Get the last allocated messageId.\n\t * @return {Number} - messageId.\n\t */\n\tgetLastAllocated(): number | null\n\n\t/**\n\t * Register the messageId. The messageId become occupied status.\n\t * If the messageId has already been occupied, then return false.\n\t * @param {number} num - The messageId to request use.\n\t * @return {boolean} - If `num` was not occupied, then return true, otherwise return false.\n\t */\n\tregister(num: number): boolean\n\n\t/**\n\t * Deallocate the messageId. The messageId become vacant status.\n\t * @param {Number} num - The messageId to deallocate. The messageId must be occupied status.\n\t * In other words, the messageId must be allocated by allocate() or\n\t * occupied by register().\n\t */\n\tdeallocate(num: number): void\n\n\t/**\n\t * Clear all occupied messageIds.\n\t * The all messageIds are set to vacant status.\n\t */\n\tclear(): void\n}\n\n/**\n * DefaultMessageAllocator constructor\n * @constructor\n */\nexport default class DefaultMessageIdProvider implements IMessageIdProvider {\n\tprivate nextId: number\n\n\tconstructor() {\n\t\t/**\n\t\t * MessageIDs starting with 1\n\t\t * ensure that nextId is min. 1, see https://github.com/mqttjs/MQTT.js/issues/810\n\t\t */\n\t\tthis.nextId = Math.max(1, Math.floor(Math.random() * 65535))\n\t}\n\n\t/**\n\t * allocate\n\t *\n\t * Get the next messageId.\n\t * @return unsigned int\n\t */\n\tallocate() {\n\t\t// id becomes current state of this.nextId and increments afterwards\n\t\tconst id = this.nextId++\n\t\t// Ensure 16 bit unsigned int (max 65535, nextId got one higher)\n\t\tif (this.nextId === 65536) {\n\t\t\tthis.nextId = 1\n\t\t}\n\t\treturn id\n\t}\n\n\t/**\n\t * getLastAllocated\n\t * Get the last allocated messageId.\n\t * @return unsigned int\n\t */\n\tgetLastAllocated() {\n\t\treturn this.nextId === 1 ? 65535 : this.nextId - 1\n\t}\n\n\t/**\n\t * register\n\t * Register messageId. If success return true, otherwise return false.\n\t * @param { unsigned int } - messageId to register,\n\t * @return boolean\n\t */\n\tregister(messageId: number) {\n\t\treturn true\n\t}\n\n\t/**\n\t * deallocate\n\t * Deallocate messageId.\n\t * @param { unsigned int } - messageId to deallocate,\n\t */\n\tdeallocate(messageId: number) {}\n\n\t/**\n\t * clear\n\t * Deallocate all messageIds.\n\t */\n\tclear() {}\n}\n","'use strict'\nmodule.exports = rfdc\n\nfunction copyBuffer (cur) {\n if (cur instanceof Buffer) {\n return Buffer.from(cur)\n }\n\n return new cur.constructor(cur.buffer.slice(), cur.byteOffset, cur.length)\n}\n\nfunction rfdc (opts) {\n opts = opts || {}\n if (opts.circles) return rfdcCircles(opts)\n\n const constructorHandlers = new Map()\n constructorHandlers.set(Date, (o) => new Date(o))\n constructorHandlers.set(Map, (o, fn) => new Map(cloneArray(Array.from(o), fn)))\n constructorHandlers.set(Set, (o, fn) => new Set(cloneArray(Array.from(o), fn)))\n if (opts.constructorHandlers) {\n for (const handler of opts.constructorHandlers) {\n constructorHandlers.set(handler[0], handler[1])\n }\n }\n\n let handler = null\n\n return opts.proto ? cloneProto : clone\n\n function cloneArray (a, fn) {\n const keys = Object.keys(a)\n const a2 = new Array(keys.length)\n for (let i = 0; i < keys.length; i++) {\n const k = keys[i]\n const cur = a[k]\n if (typeof cur !== 'object' || cur === null) {\n a2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n a2[k] = handler(cur, fn)\n } else if (ArrayBuffer.isView(cur)) {\n a2[k] = copyBuffer(cur)\n } else {\n a2[k] = fn(cur)\n }\n }\n return a2\n }\n\n function clone (o) {\n if (typeof o !== 'object' || o === null) return o\n if (Array.isArray(o)) return cloneArray(o, clone)\n if (o.constructor !== Object && (handler = constructorHandlers.get(o.constructor))) {\n return handler(o, clone)\n }\n const o2 = {}\n for (const k in o) {\n if (Object.hasOwnProperty.call(o, k) === false) continue\n const cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n o2[k] = handler(cur, clone)\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n o2[k] = clone(cur)\n }\n }\n return o2\n }\n\n function cloneProto (o) {\n if (typeof o !== 'object' || o === null) return o\n if (Array.isArray(o)) return cloneArray(o, cloneProto)\n if (o.constructor !== Object && (handler = constructorHandlers.get(o.constructor))) {\n return handler(o, cloneProto)\n }\n const o2 = {}\n for (const k in o) {\n const cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n o2[k] = handler(cur, cloneProto)\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n o2[k] = cloneProto(cur)\n }\n }\n return o2\n }\n}\n\nfunction rfdcCircles (opts) {\n const refs = []\n const refsNew = []\n\n const constructorHandlers = new Map()\n constructorHandlers.set(Date, (o) => new Date(o))\n constructorHandlers.set(Map, (o, fn) => new Map(cloneArray(Array.from(o), fn)))\n constructorHandlers.set(Set, (o, fn) => new Set(cloneArray(Array.from(o), fn)))\n if (opts.constructorHandlers) {\n for (const handler of opts.constructorHandlers) {\n constructorHandlers.set(handler[0], handler[1])\n }\n }\n\n let handler = null\n return opts.proto ? cloneProto : clone\n\n function cloneArray (a, fn) {\n const keys = Object.keys(a)\n const a2 = new Array(keys.length)\n for (let i = 0; i < keys.length; i++) {\n const k = keys[i]\n const cur = a[k]\n if (typeof cur !== 'object' || cur === null) {\n a2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n a2[k] = handler(cur, fn)\n } else if (ArrayBuffer.isView(cur)) {\n a2[k] = copyBuffer(cur)\n } else {\n const index = refs.indexOf(cur)\n if (index !== -1) {\n a2[k] = refsNew[index]\n } else {\n a2[k] = fn(cur)\n }\n }\n }\n return a2\n }\n\n function clone (o) {\n if (typeof o !== 'object' || o === null) return o\n if (Array.isArray(o)) return cloneArray(o, clone)\n if (o.constructor !== Object && (handler = constructorHandlers.get(o.constructor))) {\n return handler(o, clone)\n }\n const o2 = {}\n refs.push(o)\n refsNew.push(o2)\n for (const k in o) {\n if (Object.hasOwnProperty.call(o, k) === false) continue\n const cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n o2[k] = handler(cur, clone)\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n const i = refs.indexOf(cur)\n if (i !== -1) {\n o2[k] = refsNew[i]\n } else {\n o2[k] = clone(cur)\n }\n }\n }\n refs.pop()\n refsNew.pop()\n return o2\n }\n\n function cloneProto (o) {\n if (typeof o !== 'object' || o === null) return o\n if (Array.isArray(o)) return cloneArray(o, cloneProto)\n if (o.constructor !== Object && (handler = constructorHandlers.get(o.constructor))) {\n return handler(o, cloneProto)\n }\n const o2 = {}\n refs.push(o)\n refsNew.push(o2)\n for (const k in o) {\n const cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur.constructor !== Object && (handler = constructorHandlers.get(cur.constructor))) {\n o2[k] = handler(cur, cloneProto)\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n const i = refs.indexOf(cur)\n if (i !== -1) {\n o2[k] = refsNew[i]\n } else {\n o2[k] = cloneProto(cur)\n }\n }\n }\n refs.pop()\n refsNew.pop()\n return o2\n }\n}\n","'use strict'\n\nmodule.exports = require('./index.js')()\n","/**\n * Validate a topic to see if it's valid or not.\n * A topic is valid if it follow below rules:\n * - Rule #1: If any part of the topic is not `+` or `#`, then it must not contain `+` and '#'\n * - Rule #2: Part `#` must be located at the end of the mailbox\n *\n * @param {String} topic - A topic\n * @returns {Boolean} If the topic is valid, returns true. Otherwise, returns false.\n */\nexport function validateTopic(topic: string): boolean {\n\tconst parts = topic.split('/')\n\n\tfor (let i = 0; i < parts.length; i++) {\n\t\tif (parts[i] === '+') {\n\t\t\tcontinue\n\t\t}\n\n\t\tif (parts[i] === '#') {\n\t\t\t// for Rule #2\n\t\t\treturn i === parts.length - 1\n\t\t}\n\n\t\tif (parts[i].indexOf('+') !== -1 || parts[i].indexOf('#') !== -1) {\n\t\t\treturn false\n\t\t}\n\t}\n\n\treturn true\n}\n\n/**\n * Validate an array of topics to see if any of them is valid or not\n * @param {Array} topics - Array of topics\n * @returns {String} If the topics is valid, returns null. Otherwise, returns the invalid one\n */\nexport function validateTopics(topics: string[]): string {\n\tif (topics.length === 0) {\n\t\treturn 'empty_topic_list'\n\t}\n\tfor (let i = 0; i < topics.length; i++) {\n\t\tif (!validateTopic(topics[i])) {\n\t\t\treturn topics[i]\n\t\t}\n\t}\n\treturn null\n}\n","/**\n * Module dependencies\n */\nimport { Readable } from 'readable-stream'\nimport { Packet } from 'mqtt-packet'\nimport { DoneCallback } from './shared'\n\nconst streamsOpts = { objectMode: true }\nconst defaultStoreOptions = {\n\tclean: true,\n}\n\nexport interface IStoreOptions {\n\t/**\n\t * true, clear _inflights at close\n\t */\n\tclean?: boolean\n}\n\nexport type PacketCallback = (error?: Error, packet?: Packet) => void\n\nexport interface IStore {\n\t/**\n\t * Adds a packet to the store, a packet is\n\t * anything that has a messageId property.\n\t *\n\t */\n\tput(packet: Packet, cb: DoneCallback): IStore\n\n\t/**\n\t * Creates a stream with all the packets in the store\n\t *\n\t */\n\tcreateStream(): Readable\n\n\t/**\n\t * deletes a packet from the store.\n\t */\n\tdel(packet: Pick<Packet, 'messageId'>, cb: PacketCallback): IStore\n\n\t/**\n\t * get a packet from the store.\n\t */\n\tget(packet: Pick<Packet, 'messageId'>, cb: PacketCallback): IStore\n\n\t/**\n\t * Close the store\n\t */\n\tclose(cb: DoneCallback): void\n}\n\n/**\n * In-memory implementation of the message store\n * This can actually be saved into files.\n *\n * @param {Object} [options] - store options\n */\nexport default class Store implements IStore {\n\tprivate options: IStoreOptions\n\n\tprivate _inflights: Map<number, Packet>\n\n\tconstructor(options?: IStoreOptions) {\n\t\tthis.options = options || {}\n\n\t\t// Defaults\n\t\tthis.options = { ...defaultStoreOptions, ...options }\n\n\t\tthis._inflights = new Map()\n\t}\n\n\t/**\n\t * Adds a packet to the store, a packet is\n\t * anything that has a messageId property.\n\t *\n\t */\n\tput(packet: Packet, cb: DoneCallback) {\n\t\tthis._inflights.set(packet.messageId, packet)\n\n\t\tif (cb) {\n\t\t\tcb()\n\t\t}\n\n\t\treturn this\n\t}\n\n\t/**\n\t * Creates a stream with all the packets in the store\n\t *\n\t */\n\tcreateStream() {\n\t\tconst stream = new Readable(streamsOpts)\n\t\tconst values = []\n\t\tlet destroyed = false\n\t\tlet i = 0\n\n\t\tthis._inflights.forEach((value, key) => {\n\t\t\tvalues.push(value)\n\t\t})\n\n\t\tstream._read = () => {\n\t\t\tif (!destroyed && i < values.length) {\n\t\t\t\tstream.push(values[i++])\n\t\t\t} else {\n\t\t\t\tstream.push(null)\n\t\t\t}\n\t\t}\n\n\t\tstream.destroy = (err) => {\n\t\t\tif (destroyed) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tdestroyed = true\n\n\t\t\tsetTimeout(() => {\n\t\t\t\tstream.emit('close')\n\t\t\t}, 0)\n\n\t\t\treturn stream\n\t\t}\n\n\t\treturn stream\n\t}\n\n\t/**\n\t * deletes a packet from the store.\n\t */\n\tdel(packet: Pick<Packet, 'messageId'>, cb: PacketCallback) {\n\t\tconst toDelete = this._inflights.get(packet.messageId)\n\t\tif (toDelete) {\n\t\t\tthis._inflights.delete(packet.messageId)\n\t\t\tcb(null, toDelete)\n\t\t} else if (cb) {\n\t\t\tcb(new Error('missing packet'))\n\t\t}\n\n\t\treturn this\n\t}\n\n\t/**\n\t * get a packet from the store.\n\t */\n\tget(packet: Pick<Packet, 'messageId'>, cb: PacketCallback) {\n\t\tconst storedPacket = this._inflights.get(packet.messageId)\n\t\tif (storedPacket) {\n\t\t\tcb(null, storedPacket)\n\t\t} else if (cb) {\n\t\t\tcb(new Error('missing packet'))\n\t\t}\n\n\t\treturn this\n\t}\n\n\t/**\n\t * Close the store\n\t */\n\tclose(cb: DoneCallback) {\n\t\tif (this.options.clean) {\n\t\t\tthis._inflights = null\n\t\t}\n\t\tif (cb) {\n\t\t\tcb()\n\t\t}\n\t}\n}\n","import { IPublishPacket } from 'mqtt-packet'\nimport { PacketHandler } from '../shared'\n\nconst validReasonCodes = [0, 16, 128, 131, 135, 144, 145, 151, 153]\n\n/*\n those late 2 case should be rewrite to comply with coding style:\n\n case 1:\n case 0:\n // do not wait sending a puback\n // no callback passed\n if (1 === qos) {\n this._sendPacket({\n cmd: 'puback',\n messageId: messageId\n });\n }\n // emit the message event for both qos 1 and 0\n this.emit('message', topic, message, packet);\n this.handleMessage(packet, done);\n break;\n default:\n // do nothing but every switch mus have a default\n // log or throw an error about unknown qos\n break;\n\n for now i just suppressed the warnings\n */\nconst handlePublish: PacketHandler = (client, packet: IPublishPacket, done) => {\n\tclient.log('handlePublish: packet %o', packet)\n\tdone = typeof done !== 'undefined' ? done : client.noop\n\tlet topic = packet.topic.toString()\n\tconst message = packet.payload\n\tconst { qos } = packet\n\tconst { messageId } = packet\n\tconst { options } = client\n\tif (client.options.protocolVersion === 5) {\n\t\tlet alias: number\n\t\tif (packet.properties) {\n\t\t\talias = packet.properties.topicAlias\n\t\t}\n\t\tif (typeof alias !== 'undefined') {\n\t\t\tif (topic.length === 0) {\n\t\t\t\tif (alias > 0 && alias <= 0xffff) {\n\t\t\t\t\tconst gotTopic =\n\t\t\t\t\t\tclient['topicAliasRecv'].getTopicByAlias(alias)\n\t\t\t\t\tif (gotTopic) {\n\t\t\t\t\t\ttopic = gotTopic\n\t\t\t\t\t\tclient.log(\n\t\t\t\t\t\t\t'handlePublish :: topic complemented by alias. topic: %s - alias: %d',\n\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t)\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclient.log(\n\t\t\t\t\t\t\t'handlePublish :: unregistered topic alias. alias: %d',\n\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t)\n\t\t\t\t\t\tclient.emit(\n\t\t\t\t\t\t\t'error',\n\t\t\t\t\t\t\tnew Error('Received unregistered Topic Alias'),\n\t\t\t\t\t\t)\n\t\t\t\t\t\treturn\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tclient.log(\n\t\t\t\t\t\t'handlePublish :: topic alias out of range. alias: %d',\n\t\t\t\t\t\talias,\n\t\t\t\t\t)\n\t\t\t\t\tclient.emit(\n\t\t\t\t\t\t'error',\n\t\t\t\t\t\tnew Error('Received Topic Alias is out of range'),\n\t\t\t\t\t)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t} else if (client['topicAliasRecv'].put(topic, alias)) {\n\t\t\t\tclient.log(\n\t\t\t\t\t'handlePublish :: registered topic: %s - alias: %d',\n\t\t\t\t\ttopic,\n\t\t\t\t\talias,\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\tclient.log(\n\t\t\t\t\t'handlePublish :: topic alias out of range. alias: %d',\n\t\t\t\t\talias,\n\t\t\t\t)\n\t\t\t\tclient.emit(\n\t\t\t\t\t'error',\n\t\t\t\t\tnew Error('Received Topic Alias is out of range'),\n\t\t\t\t)\n\t\t\t\treturn\n\t\t\t}\n\t\t}\n\t}\n\tclient.log('handlePublish: qos %d', qos)\n\tswitch (qos) {\n\t\tcase 2: {\n\t\t\toptions.customHandleAcks(\n\t\t\t\ttopic,\n\t\t\t\tmessage as Buffer,\n\t\t\t\tpacket,\n\t\t\t\t(error, code) => {\n\t\t\t\t\tif (typeof error === 'number') {\n\t\t\t\t\t\tcode = error\n\t\t\t\t\t\terror = null\n\t\t\t\t\t}\n\t\t\t\t\tif (error) {\n\t\t\t\t\t\treturn client.emit('error', error as Error)\n\t\t\t\t\t}\n\t\t\t\t\tif (validReasonCodes.indexOf(code) === -1) {\n\t\t\t\t\t\treturn client.emit(\n\t\t\t\t\t\t\t'error',\n\t\t\t\t\t\t\tnew Error('Wrong reason code for pubrec'),\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t\tif (code) {\n\t\t\t\t\t\tclient['_sendPacket'](\n\t\t\t\t\t\t\t{ cmd: 'pubrec', messageId, reasonCode: code },\n\t\t\t\t\t\t\tdone,\n\t\t\t\t\t\t)\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclient.incomingStore.put(packet, () => {\n\t\t\t\t\t\t\tclient['_sendPacket'](\n\t\t\t\t\t\t\t\t{ cmd: 'pubrec', messageId },\n\t\t\t\t\t\t\t\tdone,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t)\n\t\t\tbreak\n\t\t}\n\t\tcase 1: {\n\t\t\t// emit the message event\n\t\t\toptions.customHandleAcks(\n\t\t\t\ttopic,\n\t\t\t\tmessage as Buffer,\n\t\t\t\tpacket,\n\t\t\t\t(error, code) => {\n\t\t\t\t\tif (typeof error === 'number') {\n\t\t\t\t\t\tcode = error\n\t\t\t\t\t\terror = null\n\t\t\t\t\t}\n\t\t\t\t\tif (error) {\n\t\t\t\t\t\treturn client.emit('error', error as Error)\n\t\t\t\t\t}\n\t\t\t\t\tif (validReasonCodes.indexOf(code) === -1) {\n\t\t\t\t\t\treturn client.emit(\n\t\t\t\t\t\t\t'error',\n\t\t\t\t\t\t\tnew Error('Wrong reason code for puback'),\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t\tif (!code) {\n\t\t\t\t\t\tclient.emit('message', topic, message as Buffer, packet)\n\t\t\t\t\t}\n\t\t\t\t\tclient.handleMessage(packet, (err) => {\n\t\t\t\t\t\tif (err) {\n\t\t\t\t\t\t\treturn done && done(err)\n\t\t\t\t\t\t}\n\t\t\t\t\t\tclient['_sendPacket'](\n\t\t\t\t\t\t\t{ cmd: 'puback', messageId, reasonCode: code },\n\t\t\t\t\t\t\tdone,\n\t\t\t\t\t\t)\n\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t)\n\t\t\tbreak\n\t\t}\n\t\tcase 0:\n\t\t\t// emit the message event\n\t\t\tclient.emit('message', topic, message as Buffer, packet)\n\t\t\tclient.handleMessage(packet, done)\n\t\t\tbreak\n\t\tdefault:\n\t\t\t// do nothing\n\t\t\tclient.log('handlePublish: unknown QoS. Doing nothing.')\n\t\t\t// log or throw an error about unknown qos\n\t\t\tbreak\n\t}\n}\n\nexport default handlePublish\n","{\n \"name\": \"mqtt\",\n \"description\": \"A library for the MQTT protocol\",\n \"version\": \"5.10.1\",\n \"contributors\": [\n \"Adam Rudd <adamvrr@gmail.com>\",\n \"Matteo Collina <matteo.collina@gmail.com> (https://github.com/mcollina)\",\n \"Siarhei Buntsevich <scarry0506@gmail.com> (https://github.com/scarry1992)\",\n \"Yoseph Maguire <yomaguir@microsoft.com> (https://github.com/YoDaMa)\",\n \"Daniel Lando <daniel.sorridi@gmail.com> (https://github.com/robertsLando)\"\n ],\n \"keywords\": [\n \"mqtt\",\n \"publish/subscribe\",\n \"publish\",\n \"subscribe\"\n ],\n \"license\": \"MIT\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/mqttjs/MQTT.js.git\"\n },\n \"main\": \"./build/index.js\",\n \"module\": \"./dist/mqtt.esm.js\",\n \"bin\": {\n \"mqtt_pub\": \"./build/bin/pub.js\",\n \"mqtt_sub\": \"./build/bin/sub.js\",\n \"mqtt\": \"./build/bin/mqtt.js\"\n },\n \"files\": [\n \"dist/\",\n \"CONTRIBUTING.md\",\n \"LICENSE.md\",\n \"help/\",\n \"build/\",\n \"src/\"\n ],\n \"exports\": {\n \".\": {\n \"browser\": {\n \"import\": \"./dist/mqtt.esm.js\",\n \"default\": \"./dist/mqtt.min.js\"\n },\n \"default\": \"./build/index.js\"\n },\n \"./package.json\": \"./package.json\",\n \"./*.map\": \"./build/*.js.map\",\n \"./dist/*\": \"./dist/*.js\",\n \"./*\": \"./build/*.js\"\n },\n \"types\": \"build/index.d.ts\",\n \"typesVersions\": {\n \"*\": {\n \"*\": [\n \"./build/index.d.ts\"\n ]\n }\n },\n \"scripts\": {\n \"lint\": \"eslint --ext .ts .\",\n \"lint-fix\": \"eslint --fix --ext .ts .\",\n \"build:ts\": \"rimraf build/ && tsc -p tsconfig.build.json\",\n \"build:browser\": \"node esbuild.js\",\n \"build\": \"npm run build:ts && npm run build:browser\",\n \"prepare\": \"npm run build\",\n \"unit-test:node\": \"node_modules/.bin/nyc node -r esbuild-register test/runTests.ts\",\n \"unit-test:browser\": \"wtr\",\n \"test:node\": \"npm run unit-test:node && codecov\",\n \"test:browser\": \"npm run build && npm run unit-test:browser\",\n \"test\": \"npm run test:node\",\n \"changelog\": \"conventional-changelog -p angular -i CHANGELOG.md -s && git add CHANGELOG.md\",\n \"changelog-init\": \"conventional-changelog -p angular -i CHANGELOG.md -s -r 0\",\n \"release\": \"read -p 'GITHUB_TOKEN: ' GITHUB_TOKEN && export GITHUB_TOKEN=$GITHUB_TOKEN && release-it\"\n },\n \"release-it\": {\n \"github\": {\n \"release\": true\n },\n \"git\": {\n \"tagName\": \"v${version}\",\n \"commitMessage\": \"chore(release): ${version}\"\n },\n \"hooks\": {\n \"before:init\": [\n \"npm run test\"\n ]\n },\n \"npm\": {\n \"publish\": true\n },\n \"plugins\": {\n \"@release-it/conventional-changelog\": {\n \"preset\": \"angular\",\n \"infile\": \"CHANGELOG.md\"\n }\n }\n },\n \"pre-commit\": [\n \"lint\"\n ],\n \"engines\": {\n \"node\": \">=16.0.0\"\n },\n \"browser\": {\n \"./mqtt.js\": \"./dist/mqtt.js\",\n \"fs\": false,\n \"tls\": false,\n \"net\": false\n },\n \"dependencies\": {\n \"@types/readable-stream\": \"^4.0.5\",\n \"@types/ws\": \"^8.5.9\",\n \"commist\": \"^3.2.0\",\n \"concat-stream\": \"^2.0.0\",\n \"debug\": \"^4.3.4\",\n \"help-me\": \"^5.0.0\",\n \"lru-cache\": \"^10.0.1\",\n \"minimist\": \"^1.2.8\",\n \"mqtt-packet\": \"^9.0.0\",\n \"number-allocator\": \"^1.0.14\",\n \"readable-stream\": \"^4.4.2\",\n \"reinterval\": \"^1.1.0\",\n \"rfdc\": \"^1.3.0\",\n \"split2\": \"^4.2.0\",\n \"worker-timers\": \"^7.1.4\",\n \"ws\": \"^8.17.1\"\n },\n \"devDependencies\": {\n \"@esm-bundle/chai\": \"^4.3.4-fix.0\",\n \"@release-it/conventional-changelog\": \"^7.0.2\",\n \"@types/chai\": \"^4.3.10\",\n \"@types/node\": \"^20.9.0\",\n \"@types/sinon\": \"^17.0.1\",\n \"@types/tape\": \"^5.6.4\",\n \"@typescript-eslint/eslint-plugin\": \"^6.10.0\",\n \"@typescript-eslint/parser\": \"^6.10.0\",\n \"@web/test-runner\": \"^0.18.0\",\n \"@web/test-runner-playwright\": \"^0.11.0\",\n \"aedes-cli\": \"^0.8.0\",\n \"chai\": \"^4.3.10\",\n \"chokidar\": \"^3.5.3\",\n \"codecov\": \"^3.8.2\",\n \"conventional-changelog-cli\": \"^4.1.0\",\n \"end-of-stream\": \"^1.4.4\",\n \"esbuild\": \"^0.19.5\",\n \"esbuild-plugin-polyfill-node\": \"^0.3.0\",\n \"esbuild-register\": \"^3.5.0\",\n \"eslint\": \"^8.53.0\",\n \"eslint-config-airbnb-base\": \"^15.0.0\",\n \"eslint-config-airbnb-typescript\": \"^17.1.0\",\n \"eslint-config-prettier\": \"^9.0.0\",\n \"eslint-plugin-import\": \"^2.29.0\",\n \"eslint-plugin-prettier\": \"^5.0.1\",\n \"global\": \"^4.4.0\",\n \"leaked-handles\": \"^5.2.0\",\n \"mkdirp\": \"^3.0.1\",\n \"mqtt-connection\": \"^4.1.0\",\n \"mqtt-level-store\": \"^3.1.0\",\n \"nyc\": \"^15.1.0\",\n \"pre-commit\": \"^1.2.2\",\n \"prettier\": \"^3.0.3\",\n \"release-it\": \"^16.2.1\",\n \"rimraf\": \"^5.0.5\",\n \"should\": \"^13.2.3\",\n \"sinon\": \"^17.0.1\",\n \"snazzy\": \"^9.0.0\",\n \"tape\": \"^5.7.2\",\n \"ts-node\": \"^10.9.1\",\n \"typescript\": \"^5.2.2\"\n }\n}\n","import type { Packet } from 'mqtt-packet'\nimport type { Duplex } from 'stream'\nimport type MqttClient from './client'\nimport type { IClientOptions } from './client'\n\nexport type DoneCallback = (error?: Error) => void\n\nexport type GenericCallback<T> = (error?: Error, result?: T) => void\n\nexport type VoidCallback = () => void\n\nexport type IStream = Duplex & {\n\t/** only set on browsers, it's a [WebSocket](https://developer.mozilla.org/en-US/docs/Web/API/WebSocket) */\n\tsocket?: any\n}\n\nexport type StreamBuilder = (\n\tclient: MqttClient,\n\topts?: IClientOptions,\n) => IStream\n\nexport type Callback = () => void\n\nexport type PacketHandler = (\n\tclient: MqttClient,\n\tpacket: Packet,\n\tdone?: DoneCallback,\n) => void\n\nexport type TimerVariant = 'auto' | 'worker' | 'native'\n\nexport class ErrorWithReasonCode extends Error {\n\tpublic code: number\n\n\tpublic constructor(message: string, code: number) {\n\t\tsuper(message)\n\t\tthis.code = code\n\n\t\t// We need to set the prototype explicitly\n\t\tObject.setPrototypeOf(this, ErrorWithReasonCode.prototype)\n\t\tObject.getPrototypeOf(this).name = 'ErrorWithReasonCode'\n\t}\n}\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport type Constructor<T = {}> = new (...args: any[]) => T\n\nexport function applyMixin(\n\ttarget: Constructor,\n\tmixin: Constructor,\n\tincludeConstructor = false,\n): void {\n\t// Figure out the inheritance chain of the mixin\n\tconst inheritanceChain: Constructor[] = [mixin]\n\t// eslint-disable-next-line no-constant-condition\n\twhile (true) {\n\t\tconst current = inheritanceChain[0]\n\t\tconst base = Object.getPrototypeOf(current)\n\t\tif (base?.prototype) {\n\t\t\tinheritanceChain.unshift(base)\n\t\t} else {\n\t\t\tbreak\n\t\t}\n\t}\n\tfor (const ctor of inheritanceChain) {\n\t\tfor (const prop of Object.getOwnPropertyNames(ctor.prototype)) {\n\t\t\t// Do not override the constructor\n\t\t\tif (includeConstructor || prop !== 'constructor') {\n\t\t\t\tObject.defineProperty(\n\t\t\t\t\ttarget.prototype,\n\t\t\t\t\tprop,\n\t\t\t\t\tObject.getOwnPropertyDescriptor(ctor.prototype, prop) ??\n\t\t\t\t\t\tObject.create(null),\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\t}\n}\nexport const nextTick =\n\ttypeof process?.nextTick === 'function'\n\t\t? process.nextTick\n\t\t: (callback: () => void) => {\n\t\t\t\tsetTimeout(callback, 0)\n\t\t }\n\n// eslint-disable-next-line @typescript-eslint/no-var-requires\nexport const MQTTJS_VERSION = require('../../package.json').version\n","// Other Socket Errors: EADDRINUSE, ECONNRESET, ENOTFOUND, ETIMEDOUT.\n\nimport { PacketHandler, ErrorWithReasonCode } from '../shared'\n\nexport const ReasonCodes = {\n\t0: '',\n\t1: 'Unacceptable protocol version',\n\t2: 'Identifier rejected',\n\t3: 'Server unavailable',\n\t4: 'Bad username or password',\n\t5: 'Not authorized',\n\t16: 'No matching subscribers',\n\t17: 'No subscription existed',\n\t128: 'Unspecified error',\n\t129: 'Malformed Packet',\n\t130: 'Protocol Error',\n\t131: 'Implementation specific error',\n\t132: 'Unsupported Protocol Version',\n\t133: 'Client Identifier not valid',\n\t134: 'Bad User Name or Password',\n\t135: 'Not authorized',\n\t136: 'Server unavailable',\n\t137: 'Server busy',\n\t138: 'Banned',\n\t139: 'Server shutting down',\n\t140: 'Bad authentication method',\n\t141: 'Keep Alive timeout',\n\t142: 'Session taken over',\n\t143: 'Topic Filter invalid',\n\t144: 'Topic Name invalid',\n\t145: 'Packet identifier in use',\n\t146: 'Packet Identifier not found',\n\t147: 'Receive Maximum exceeded',\n\t148: 'Topic Alias invalid',\n\t149: 'Packet too large',\n\t150: 'Message rate too high',\n\t151: 'Quota exceeded',\n\t152: 'Administrative action',\n\t153: 'Payload format invalid',\n\t154: 'Retain not supported',\n\t155: 'QoS not supported',\n\t156: 'Use another server',\n\t157: 'Server moved',\n\t158: 'Shared Subscriptions not supported',\n\t159: 'Connection rate exceeded',\n\t160: 'Maximum connect time',\n\t161: 'Subscription Identifiers not supported',\n\t162: 'Wildcard Subscriptions not supported',\n}\n\nconst handleAck: PacketHandler = (client, packet) => {\n\t/* eslint no-fallthrough: \"off\" */\n\tconst { messageId } = packet\n\tconst type = packet.cmd\n\tlet response = null\n\tconst cb = client.outgoing[messageId] ? client.outgoing[messageId].cb : null\n\tlet err = null\n\n\t// Checking `!cb` happens to work, but it's not technically \"correct\".\n\t//\n\t// Why? client code assumes client \"no callback\" is the same as client \"we're not\n\t// waiting for responses\" (puback, pubrec, pubcomp, suback, or unsuback).\n\t//\n\t// It would be better to check `if (!client.outgoing[messageId])` here, but\n\t// there's no reason to change it and risk (another) regression.\n\t//\n\t// The only reason client code works is becaues code in MqttClient.publish,\n\t// MqttClinet.subscribe, and MqttClient.unsubscribe ensures client we will\n\t// have a callback even if the user doesn't pass one in.)\n\tif (!cb) {\n\t\tclient.log('_handleAck :: Server sent an ack in error. Ignoring.')\n\t\t// Server sent an ack in error, ignore it.\n\t\treturn\n\t}\n\n\t// Process\n\tclient.log('_handleAck :: packet type', type)\n\tswitch (type) {\n\t\tcase 'pubcomp':\n\t\t// same thing as puback for QoS 2\n\t\tcase 'puback': {\n\t\t\tconst pubackRC = packet.reasonCode\n\t\t\t// Callback - we're done\n\t\t\tif (pubackRC && pubackRC > 0 && pubackRC !== 16) {\n\t\t\t\terr = new ErrorWithReasonCode(\n\t\t\t\t\t`Publish error: ${ReasonCodes[pubackRC]}`,\n\t\t\t\t\tpubackRC,\n\t\t\t\t)\n\t\t\t\tclient['_removeOutgoingAndStoreMessage'](messageId, () => {\n\t\t\t\t\tcb(err, packet)\n\t\t\t\t})\n\t\t\t} else {\n\t\t\t\tclient['_removeOutgoingAndStoreMessage'](messageId, cb)\n\t\t\t}\n\n\t\t\tbreak\n\t\t}\n\t\tcase 'pubrec': {\n\t\t\tresponse = {\n\t\t\t\tcmd: 'pubrel',\n\t\t\t\tqos: 2,\n\t\t\t\tmessageId,\n\t\t\t}\n\t\t\tconst pubrecRC = packet.reasonCode\n\n\t\t\tif (pubrecRC && pubrecRC > 0 && pubrecRC !== 16) {\n\t\t\t\terr = new ErrorWithReasonCode(\n\t\t\t\t\t`Publish error: ${ReasonCodes[pubrecRC]}`,\n\t\t\t\t\tpubrecRC,\n\t\t\t\t)\n\t\t\t\tclient['_removeOutgoingAndStoreMessage'](messageId, () => {\n\t\t\t\t\tcb(err, packet)\n\t\t\t\t})\n\t\t\t} else {\n\t\t\t\tclient['_sendPacket'](response)\n\t\t\t}\n\t\t\tbreak\n\t\t}\n\t\tcase 'suback': {\n\t\t\tdelete client.outgoing[messageId]\n\t\t\tclient.messageIdProvider.deallocate(messageId)\n\t\t\tconst granted = packet.granted as number[]\n\t\t\tfor (let grantedI = 0; grantedI < granted.length; grantedI++) {\n\t\t\t\tconst subackRC = granted[grantedI]\n\t\t\t\tif ((subackRC & 0x80) !== 0) {\n\t\t\t\t\terr = new Error(`Subscribe error: ${ReasonCodes[subackRC]}`)\n\t\t\t\t\terr.code = subackRC\n\n\t\t\t\t\t// suback with Failure status\n\t\t\t\t\tconst topics = client.messageIdToTopic[messageId]\n\t\t\t\t\tif (topics) {\n\t\t\t\t\t\ttopics.forEach((topic) => {\n\t\t\t\t\t\t\tdelete client['_resubscribeTopics'][topic]\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tdelete client.messageIdToTopic[messageId]\n\t\t\tclient['_invokeStoreProcessingQueue']()\n\t\t\tcb(err, packet)\n\t\t\tbreak\n\t\t}\n\t\tcase 'unsuback': {\n\t\t\tdelete client.outgoing[messageId]\n\t\t\tclient.messageIdProvider.deallocate(messageId)\n\t\t\tclient['_invokeStoreProcessingQueue']()\n\t\t\tcb(null, packet)\n\t\t\tbreak\n\t\t}\n\t\tdefault:\n\t\t\tclient.emit('error', new Error('unrecognized packet type'))\n\t}\n\n\tif (client.disconnecting && Object.keys(client.outgoing).length === 0) {\n\t\tclient.emit('outgoingEmpty')\n\t}\n}\n\nexport default handleAck\n","import { IAuthPacket } from 'mqtt-packet'\nimport { ErrorWithReasonCode, PacketHandler } from '../shared'\nimport { ReasonCodes } from './ack'\n\nconst handleAuth: PacketHandler = (\n\tclient,\n\tpacket: IAuthPacket & { returnCode: number },\n) => {\n\tconst { options } = client\n\tconst version = options.protocolVersion\n\tconst rc = version === 5 ? packet.reasonCode : packet.returnCode\n\n\tif (version !== 5) {\n\t\tconst err = new ErrorWithReasonCode(\n\t\t\t`Protocol error: Auth packets are only supported in MQTT 5. Your version:${version}`,\n\t\t\trc,\n\t\t)\n\t\tclient.emit('error', err)\n\t\treturn\n\t}\n\n\tclient.handleAuth(\n\t\tpacket,\n\t\t(err: ErrorWithReasonCode, packet2: IAuthPacket) => {\n\t\t\tif (err) {\n\t\t\t\tclient.emit('error', err)\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tif (rc === 24) {\n\t\t\t\tclient.reconnecting = false\n\t\t\t\tclient['_sendPacket'](packet2)\n\t\t\t} else {\n\t\t\t\tconst error = new ErrorWithReasonCode(\n\t\t\t\t\t`Connection refused: ${ReasonCodes[rc]}`,\n\t\t\t\t\trc,\n\t\t\t\t)\n\t\t\t\tclient.emit('error', error)\n\t\t\t}\n\t\t},\n\t)\n}\n\nexport default handleAuth\n","/**\n * @module LRUCache\n */\n\n// module-private names and types\ntype Perf = { now: () => number }\nconst perf: Perf =\n typeof performance === 'object' &&\n performance &&\n typeof performance.now === 'function'\n ? performance\n : Date\n\nconst warned = new Set<string>()\n\n// either a function or a class\ntype ForC = ((...a: any[]) => any) | { new (...a: any[]): any }\n\n/* c8 ignore start */\nconst PROCESS = (\n typeof process === 'object' && !!process ? process : {}\n) as { [k: string]: any }\n/* c8 ignore start */\n\nconst emitWarning = (\n msg: string,\n type: string,\n code: string,\n fn: ForC\n) => {\n typeof PROCESS.emitWarning === 'function'\n ? PROCESS.emitWarning(msg, type, code, fn)\n : console.error(`[${code}] ${type}: ${msg}`)\n}\n\nlet AC = globalThis.AbortController\nlet AS = globalThis.AbortSignal\n\n/* c8 ignore start */\nif (typeof AC === 'undefined') {\n //@ts-ignore\n AS = class AbortSignal {\n onabort?: (...a: any[]) => any\n _onabort: ((...a: any[]) => any)[] = []\n reason?: any\n aborted: boolean = false\n addEventListener(_: string, fn: (...a: any[]) => any) {\n this._onabort.push(fn)\n }\n }\n //@ts-ignore\n AC = class AbortController {\n constructor() {\n warnACPolyfill()\n }\n signal = new AS()\n abort(reason: any) {\n if (this.signal.aborted) return\n //@ts-ignore\n this.signal.reason = reason\n //@ts-ignore\n this.signal.aborted = true\n //@ts-ignore\n for (const fn of this.signal._onabort) {\n fn(reason)\n }\n this.signal.onabort?.(reason)\n }\n }\n let printACPolyfillWarning =\n PROCESS.env?.LRU_CACHE_IGNORE_AC_WARNING !== '1'\n const warnACPolyfill = () => {\n if (!printACPolyfillWarning) return\n printACPolyfillWarning = false\n emitWarning(\n 'AbortController is not defined. If using lru-cache in ' +\n 'node 14, load an AbortController polyfill from the ' +\n '`node-abort-controller` package. A minimal polyfill is ' +\n 'provided for use by LRUCache.fetch(), but it should not be ' +\n 'relied upon in other contexts (eg, passing it to other APIs that ' +\n 'use AbortController/AbortSignal might have undesirable effects). ' +\n 'You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.',\n 'NO_ABORT_CONTROLLER',\n 'ENOTSUP',\n warnACPolyfill\n )\n }\n}\n/* c8 ignore stop */\n\nconst shouldWarn = (code: string) => !warned.has(code)\n\nconst TYPE = Symbol('type')\nexport type PosInt = number & { [TYPE]: 'Positive Integer' }\nexport type Index = number & { [TYPE]: 'LRUCache Index' }\n\nconst isPosInt = (n: any): n is PosInt =>\n n && n === Math.floor(n) && n > 0 && isFinite(n)\n\nexport type UintArray = Uint8Array | Uint16Array | Uint32Array\nexport type NumberArray = UintArray | number[]\n\n/* c8 ignore start */\n// This is a little bit ridiculous, tbh.\n// The maximum array length is 2^32-1 or thereabouts on most JS impls.\n// And well before that point, you're caching the entire world, I mean,\n// that's ~32GB of just integers for the next/prev links, plus whatever\n// else to hold that many keys and values. Just filling the memory with\n// zeroes at init time is brutal when you get that big.\n// But why not be complete?\n// Maybe in the future, these limits will have expanded.\nconst getUintArray = (max: number) =>\n !isPosInt(max)\n ? null\n : max <= Math.pow(2, 8)\n ? Uint8Array\n : max <= Math.pow(2, 16)\n ? Uint16Array\n : max <= Math.pow(2, 32)\n ? Uint32Array\n : max <= Number.MAX_SAFE_INTEGER\n ? ZeroArray\n : null\n/* c8 ignore stop */\n\nclass ZeroArray extends Array<number> {\n constructor(size: number) {\n super(size)\n this.fill(0)\n }\n}\nexport type { ZeroArray }\nexport type { Stack }\n\nexport type StackLike = Stack | Index[]\nclass Stack {\n heap: NumberArray\n length: number\n // private constructor\n static #constructing: boolean = false\n static create(max: number): StackLike {\n const HeapCls = getUintArray(max)\n if (!HeapCls) return []\n Stack.#constructing = true\n const s = new Stack(max, HeapCls)\n Stack.#constructing = false\n return s\n }\n constructor(\n max: number,\n HeapCls: { new (n: number): NumberArray }\n ) {\n /* c8 ignore start */\n if (!Stack.#constructing) {\n throw new TypeError('instantiate Stack using Stack.create(n)')\n }\n /* c8 ignore stop */\n this.heap = new HeapCls(max)\n this.length = 0\n }\n push(n: Index) {\n this.heap[this.length++] = n\n }\n pop(): Index {\n return this.heap[--this.length] as Index\n }\n}\n\n/**\n * Promise representing an in-progress {@link LRUCache#fetch} call\n */\nexport type BackgroundFetch<V> = Promise<V | undefined> & {\n __returned: BackgroundFetch<V> | undefined\n __abortController: AbortController\n __staleWhileFetching: V | undefined\n}\n\nexport type DisposeTask<K, V> = [\n value: V,\n key: K,\n reason: LRUCache.DisposeReason\n]\n\nexport namespace LRUCache {\n /**\n * An integer greater than 0, reflecting the calculated size of items\n */\n export type Size = number\n\n /**\n * Integer greater than 0, representing some number of milliseconds, or the\n * time at which a TTL started counting from.\n */\n export type Milliseconds = number\n\n /**\n * An integer greater than 0, reflecting a number of items\n */\n export type Count = number\n\n /**\n * The reason why an item was removed from the cache, passed\n * to the {@link Disposer} methods.\n *\n * - `evict`: The item was evicted because it is the least recently used,\n * and the cache is full.\n * - `set`: A new value was set, overwriting the old value being disposed.\n * - `delete`: The item was explicitly deleted, either by calling\n * {@link LRUCache#delete}, {@link LRUCache#clear}, or\n * {@link LRUCache#set} with an undefined value.\n * - `expire`: The item was removed due to exceeding its TTL.\n * - `fetch`: A {@link OptionsBase#fetchMethod} operation returned\n * `undefined` or was aborted, causing the item to be deleted.\n */\n export type DisposeReason =\n | 'evict'\n | 'set'\n | 'delete'\n | 'expire'\n | 'fetch'\n /**\n * A method called upon item removal, passed as the\n * {@link OptionsBase.dispose} and/or\n * {@link OptionsBase.disposeAfter} options.\n */\n export type Disposer<K, V> = (\n value: V,\n key: K,\n reason: DisposeReason\n ) => void\n\n /**\n * A function that returns the effective calculated size\n * of an entry in the cache.\n */\n export type SizeCalculator<K, V> = (value: V, key: K) => Size\n\n /**\n * Options provided to the\n * {@link OptionsBase.fetchMethod} function.\n */\n export interface FetcherOptions<K, V, FC = unknown> {\n signal: AbortSignal\n options: FetcherFetchOptions<K, V, FC>\n /**\n * Object provided in the {@link FetchOptions.context} option to\n * {@link LRUCache#fetch}\n */\n context: FC\n }\n\n /**\n * Occasionally, it may be useful to track the internal behavior of the\n * cache, particularly for logging, debugging, or for behavior within the\n * `fetchMethod`. To do this, you can pass a `status` object to the\n * {@link LRUCache#fetch}, {@link LRUCache#get}, {@link LRUCache#set},\n * {@link LRUCache#memo}, and {@link LRUCache#has} methods.\n *\n * The `status` option should be a plain JavaScript object. The following\n * fields will be set on it appropriately, depending on the situation.\n */\n export interface Status<V> {\n /**\n * The status of a set() operation.\n *\n * - add: the item was not found in the cache, and was added\n * - update: the item was in the cache, with the same value provided\n * - replace: the item was in the cache, and replaced\n * - miss: the item was not added to the cache for some reason\n */\n set?: 'add' | 'update' | 'replace' | 'miss'\n\n /**\n * the ttl stored for the item, or undefined if ttls are not used.\n */\n ttl?: Milliseconds\n\n /**\n * the start time for the item, or undefined if ttls are not used.\n */\n start?: Milliseconds\n\n /**\n * The timestamp used for TTL calculation\n */\n now?: Milliseconds\n\n /**\n * the remaining ttl for the item, or undefined if ttls are not used.\n */\n remainingTTL?: Milliseconds\n\n /**\n * The calculated size for the item, if sizes are used.\n */\n entrySize?: Size\n\n /**\n * The total calculated size of the cache, if sizes are used.\n */\n totalCalculatedSize?: Size\n\n /**\n * A flag indicating that the item was not stored, due to exceeding the\n * {@link OptionsBase.maxEntrySize}\n */\n maxEntrySizeExceeded?: true\n\n /**\n * The old value, specified in the case of `set:'update'` or\n * `set:'replace'`\n */\n oldValue?: V\n\n /**\n * The results of a {@link LRUCache#has} operation\n *\n * - hit: the item was found in the cache\n * - stale: the item was found in the cache, but is stale\n * - miss: the item was not found in the cache\n */\n has?: 'hit' | 'stale' | 'miss'\n\n /**\n * The status of a {@link LRUCache#fetch} operation.\n * Note that this can change as the underlying fetch() moves through\n * various states.\n *\n * - inflight: there is another fetch() for this key which is in process\n * - get: there is no {@link OptionsBase.fetchMethod}, so\n * {@link LRUCache#get} was called.\n * - miss: the item is not in cache, and will be fetched.\n * - hit: the item is in the cache, and was resolved immediately.\n * - stale: the item is in the cache, but stale.\n * - refresh: the item is in the cache, and not stale, but\n * {@link FetchOptions.forceRefresh} was specified.\n */\n fetch?: 'get' | 'inflight' | 'miss' | 'hit' | 'stale' | 'refresh'\n\n /**\n * The {@link OptionsBase.fetchMethod} was called\n */\n fetchDispatched?: true\n\n /**\n * The cached value was updated after a successful call to\n * {@link OptionsBase.fetchMethod}\n */\n fetchUpdated?: true\n\n /**\n * The reason for a fetch() rejection. Either the error raised by the\n * {@link OptionsBase.fetchMethod}, or the reason for an\n * AbortSignal.\n */\n fetchError?: Error\n\n /**\n * The fetch received an abort signal\n */\n fetchAborted?: true\n\n /**\n * The abort signal received was ignored, and the fetch was allowed to\n * continue.\n */\n fetchAbortIgnored?: true\n\n /**\n * The fetchMethod promise resolved successfully\n */\n fetchResolved?: true\n\n /**\n * The fetchMethod promise was rejected\n */\n fetchRejected?: true\n\n /**\n * The status of a {@link LRUCache#get} operation.\n *\n * - fetching: The item is currently being fetched. If a previous value\n * is present and allowed, that will be returned.\n * - stale: The item is in the cache, and is stale.\n * - hit: the item is in the cache\n * - miss: the item is not in the cache\n */\n get?: 'stale' | 'hit' | 'miss'\n\n /**\n * A fetch or get operation returned a stale value.\n */\n returnedStale?: true\n }\n\n /**\n * options which override the options set in the LRUCache constructor\n * when calling {@link LRUCache#fetch}.\n *\n * This is the union of {@link GetOptions} and {@link SetOptions}, plus\n * {@link OptionsBase.noDeleteOnFetchRejection},\n * {@link OptionsBase.allowStaleOnFetchRejection},\n * {@link FetchOptions.forceRefresh}, and\n * {@link FetcherOptions.context}\n *\n * Any of these may be modified in the {@link OptionsBase.fetchMethod}\n * function, but the {@link GetOptions} fields will of course have no\n * effect, as the {@link LRUCache#get} call already happened by the time\n * the fetchMethod is called.\n */\n export interface FetcherFetchOptions<K, V, FC = unknown>\n extends Pick<\n OptionsBase<K, V, FC>,\n | 'allowStale'\n | 'updateAgeOnGet'\n | 'noDeleteOnStaleGet'\n | 'sizeCalculation'\n | 'ttl'\n | 'noDisposeOnSet'\n | 'noUpdateTTL'\n | 'noDeleteOnFetchRejection'\n | 'allowStaleOnFetchRejection'\n | 'ignoreFetchAbort'\n | 'allowStaleOnFetchAbort'\n > {\n status?: Status<V>\n size?: Size\n }\n\n /**\n * Options that may be passed to the {@link LRUCache#fetch} method.\n */\n export interface FetchOptions<K, V, FC>\n extends FetcherFetchOptions<K, V, FC> {\n /**\n * Set to true to force a re-load of the existing data, even if it\n * is not yet stale.\n */\n forceRefresh?: boolean\n /**\n * Context provided to the {@link OptionsBase.fetchMethod} as\n * the {@link FetcherOptions.context} param.\n *\n * If the FC type is specified as unknown (the default),\n * undefined or void, then this is optional. Otherwise, it will\n * be required.\n */\n context?: FC\n signal?: AbortSignal\n status?: Status<V>\n }\n /**\n * Options provided to {@link LRUCache#fetch} when the FC type is something\n * other than `unknown`, `undefined`, or `void`\n */\n export interface FetchOptionsWithContext<K, V, FC>\n extends FetchOptions<K, V, FC> {\n context: FC\n }\n /**\n * Options provided to {@link LRUCache#fetch} when the FC type is\n * `undefined` or `void`\n */\n export interface FetchOptionsNoContext<K, V>\n extends FetchOptions<K, V, undefined> {\n context?: undefined\n }\n\n export interface MemoOptions<K, V, FC = unknown>\n extends Pick<\n OptionsBase<K, V, FC>,\n | 'allowStale'\n | 'updateAgeOnGet'\n | 'noDeleteOnStaleGet'\n | 'sizeCalculation'\n | 'ttl'\n | 'noDisposeOnSet'\n | 'noUpdateTTL'\n | 'noDeleteOnFetchRejection'\n | 'allowStaleOnFetchRejection'\n | 'ignoreFetchAbort'\n | 'allowStaleOnFetchAbort'\n > {\n /**\n * Set to true to force a re-load of the existing data, even if it\n * is not yet stale.\n */\n forceRefresh?: boolean\n /**\n * Context provided to the {@link OptionsBase.memoMethod} as\n * the {@link MemoizerOptions.context} param.\n *\n * If the FC type is specified as unknown (the default),\n * undefined or void, then this is optional. Otherwise, it will\n * be required.\n */\n context?: FC\n status?: Status<V>\n }\n /**\n * Options provided to {@link LRUCache#memo} when the FC type is something\n * other than `unknown`, `undefined`, or `void`\n */\n export interface MemoOptionsWithContext<K, V, FC>\n extends MemoOptions<K, V, FC> {\n context: FC\n }\n /**\n * Options provided to {@link LRUCache#memo} when the FC type is\n * `undefined` or `void`\n */\n export interface MemoOptionsNoContext<K, V>\n extends MemoOptions<K, V, undefined> {\n context?: undefined\n }\n\n /**\n * Options provided to the\n * {@link OptionsBase.memoMethod} function.\n */\n export interface MemoizerOptions<K, V, FC = unknown> {\n options: MemoizerMemoOptions<K, V, FC>\n /**\n * Object provided in the {@link MemoOptions.context} option to\n * {@link LRUCache#memo}\n */\n context: FC\n }\n\n /**\n * options which override the options set in the LRUCache constructor\n * when calling {@link LRUCache#memo}.\n *\n * This is the union of {@link GetOptions} and {@link SetOptions}, plus\n * {@link MemoOptions.forceRefresh}, and\n * {@link MemoerOptions.context}\n *\n * Any of these may be modified in the {@link OptionsBase.memoMethod}\n * function, but the {@link GetOptions} fields will of course have no\n * effect, as the {@link LRUCache#get} call already happened by the time\n * the memoMethod is called.\n */\n export interface MemoizerMemoOptions<K, V, FC = unknown>\n extends Pick<\n OptionsBase<K, V, FC>,\n | 'allowStale'\n | 'updateAgeOnGet'\n | 'noDeleteOnStaleGet'\n | 'sizeCalculation'\n | 'ttl'\n | 'noDisposeOnSet'\n | 'noUpdateTTL'\n > {\n status?: Status<V>\n size?: Size\n start?: Milliseconds\n }\n\n /**\n * Options that may be passed to the {@link LRUCache#has} method.\n */\n export interface HasOptions<K, V, FC>\n extends Pick<OptionsBase<K, V, FC>, 'updateAgeOnHas'> {\n status?: Status<V>\n }\n\n /**\n * Options that may be passed to the {@link LRUCache#get} method.\n */\n export interface GetOptions<K, V, FC>\n extends Pick<\n OptionsBase<K, V, FC>,\n 'allowStale' | 'updateAgeOnGet' | 'noDeleteOnStaleGet'\n > {\n status?: Status<V>\n }\n\n /**\n * Options that may be passed to the {@link LRUCache#peek} method.\n */\n export interface PeekOptions<K, V, FC>\n extends Pick<OptionsBase<K, V, FC>, 'allowStale'> {}\n\n /**\n * Options that may be passed to the {@link LRUCache#set} method.\n */\n export interface SetOptions<K, V, FC>\n extends Pick<\n OptionsBase<K, V, FC>,\n 'sizeCalculation' | 'ttl' | 'noDisposeOnSet' | 'noUpdateTTL'\n > {\n /**\n * If size tracking is enabled, then setting an explicit size\n * in the {@link LRUCache#set} call will prevent calling the\n * {@link OptionsBase.sizeCalculation} function.\n */\n size?: Size\n /**\n * If TTL tracking is enabled, then setting an explicit start\n * time in the {@link LRUCache#set} call will override the\n * default time from `performance.now()` or `Date.now()`.\n *\n * Note that it must be a valid value for whichever time-tracking\n * method is in use.\n */\n start?: Milliseconds\n status?: Status<V>\n }\n\n /**\n * The type signature for the {@link OptionsBase.fetchMethod} option.\n */\n export type Fetcher<K, V, FC = unknown> = (\n key: K,\n staleValue: V | undefined,\n options: FetcherOptions<K, V, FC>\n ) => Promise<V | undefined | void> | V | undefined | void\n\n /**\n * the type signature for the {@link OptionsBase.memoMethod} option.\n */\n export type Memoizer<K, V, FC = unknown> = (\n key: K,\n staleValue: V | undefined,\n options: MemoizerOptions<K, V, FC>\n ) => V\n\n /**\n * Options which may be passed to the {@link LRUCache} constructor.\n *\n * Most of these may be overridden in the various options that use\n * them.\n *\n * Despite all being technically optional, the constructor requires that\n * a cache is at minimum limited by one or more of {@link OptionsBase.max},\n * {@link OptionsBase.ttl}, or {@link OptionsBase.maxSize}.\n *\n * If {@link OptionsBase.ttl} is used alone, then it is strongly advised\n * (and in fact required by the type definitions here) that the cache\n * also set {@link OptionsBase.ttlAutopurge}, to prevent potentially\n * unbounded storage.\n *\n * All options are also available on the {@link LRUCache} instance, making\n * it safe to pass an LRUCache instance as the options argumemnt to\n * make another empty cache of the same type.\n *\n * Some options are marked as read-only, because changing them after\n * instantiation is not safe. Changing any of the other options will of\n * course only have an effect on subsequent method calls.\n */\n export interface OptionsBase<K, V, FC> {\n /**\n * The maximum number of items to store in the cache before evicting\n * old entries. This is read-only on the {@link LRUCache} instance,\n * and may not be overridden.\n *\n * If set, then storage space will be pre-allocated at construction\n * time, and the cache will perform significantly faster.\n *\n * Note that significantly fewer items may be stored, if\n * {@link OptionsBase.maxSize} and/or {@link OptionsBase.ttl} are also\n * set.\n *\n * **It is strongly recommended to set a `max` to prevent unbounded growth\n * of the cache.**\n */\n max?: Count\n\n /**\n * Max time in milliseconds for items to live in cache before they are\n * considered stale. Note that stale items are NOT preemptively removed by\n * default, and MAY live in the cache, contributing to its LRU max, long\n * after they have expired, unless {@link OptionsBase.ttlAutopurge} is\n * set.\n *\n * If set to `0` (the default value), then that means \"do not track\n * TTL\", not \"expire immediately\".\n *\n * Also, as this cache is optimized for LRU/MRU operations, some of\n * the staleness/TTL checks will reduce performance, as they will incur\n * overhead by deleting items.\n *\n * This is not primarily a TTL cache, and does not make strong TTL\n * guarantees. There is no pre-emptive pruning of expired items, but you\n * _may_ set a TTL on the cache, and it will treat expired items as missing\n * when they are fetched, and delete them.\n *\n * Optional, but must be a non-negative integer in ms if specified.\n *\n * This may be overridden by passing an options object to `cache.set()`.\n *\n * At least one of `max`, `maxSize`, or `TTL` is required. This must be a\n * positive integer if set.\n *\n * Even if ttl tracking is enabled, **it is strongly recommended to set a\n * `max` to prevent unbounded growth of the cache.**\n *\n * If ttl tracking is enabled, and `max` and `maxSize` are not set,\n * and `ttlAutopurge` is not set, then a warning will be emitted\n * cautioning about the potential for unbounded memory consumption.\n * (The TypeScript definitions will also discourage this.)\n */\n ttl?: Milliseconds\n\n /**\n * Minimum amount of time in ms in which to check for staleness.\n * Defaults to 1, which means that the current time is checked\n * at most once per millisecond.\n *\n * Set to 0 to check the current time every time staleness is tested.\n * (This reduces performance, and is theoretically unnecessary.)\n *\n * Setting this to a higher value will improve performance somewhat\n * while using ttl tracking, albeit at the expense of keeping stale\n * items around a bit longer than their TTLs would indicate.\n *\n * @default 1\n */\n ttlResolution?: Milliseconds\n\n /**\n * Preemptively remove stale items from the cache.\n *\n * Note that this may *significantly* degrade performance, especially if\n * the cache is storing a large number of items. It is almost always best\n * to just leave the stale items in the cache, and let them fall out as new\n * items are added.\n *\n * Note that this means that {@link OptionsBase.allowStale} is a bit\n * pointless, as stale items will be deleted almost as soon as they\n * expire.\n *\n * Use with caution!\n */\n ttlAutopurge?: boolean\n\n /**\n * When using time-expiring entries with `ttl`, setting this to `true` will\n * make each item's age reset to 0 whenever it is retrieved from cache with\n * {@link LRUCache#get}, causing it to not expire. (It can still fall out\n * of cache based on recency of use, of course.)\n *\n * Has no effect if {@link OptionsBase.ttl} is not set.\n *\n * This may be overridden by passing an options object to `cache.get()`.\n */\n updateAgeOnGet?: boolean\n\n /**\n * When using time-expiring entries with `ttl`, setting this to `true` will\n * make each item's age reset to 0 whenever its presence in the cache is\n * checked with {@link LRUCache#has}, causing it to not expire. (It can\n * still fall out of cache based on recency of use, of course.)\n *\n * Has no effect if {@link OptionsBase.ttl} is not set.\n */\n updateAgeOnHas?: boolean\n\n /**\n * Allow {@link LRUCache#get} and {@link LRUCache#fetch} calls to return\n * stale data, if available.\n *\n * By default, if you set `ttl`, stale items will only be deleted from the\n * cache when you `get(key)`. That is, it's not preemptively pruning items,\n * unless {@link OptionsBase.ttlAutopurge} is set.\n *\n * If you set `allowStale:true`, it'll return the stale value *as well as*\n * deleting it. If you don't set this, then it'll return `undefined` when\n * you try to get a stale entry.\n *\n * Note that when a stale entry is fetched, _even if it is returned due to\n * `allowStale` being set_, it is removed from the cache immediately. You\n * can suppress this behavior by setting\n * {@link OptionsBase.noDeleteOnStaleGet}, either in the constructor, or in\n * the options provided to {@link LRUCache#get}.\n *\n * This may be overridden by passing an options object to `cache.get()`.\n * The `cache.has()` method will always return `false` for stale items.\n *\n * Only relevant if a ttl is set.\n */\n allowStale?: boolean\n\n /**\n * Function that is called on items when they are dropped from the\n * cache, as `dispose(value, key, reason)`.\n *\n * This can be handy if you want to close file descriptors or do\n * other cleanup tasks when items are no longer stored in the cache.\n *\n * **NOTE**: It is called _before_ the item has been fully removed\n * from the cache, so if you want to put it right back in, you need\n * to wait until the next tick. If you try to add it back in during\n * the `dispose()` function call, it will break things in subtle and\n * weird ways.\n *\n * Unlike several other options, this may _not_ be overridden by\n * passing an option to `set()`, for performance reasons.\n *\n * The `reason` will be one of the following strings, corresponding\n * to the reason for the item's deletion:\n *\n * - `evict` Item was evicted to make space for a new addition\n * - `set` Item was overwritten by a new value\n * - `expire` Item expired its TTL\n * - `fetch` Item was deleted due to a failed or aborted fetch, or a\n * fetchMethod returning `undefined.\n * - `delete` Item was removed by explicit `cache.delete(key)`,\n * `cache.clear()`, or `cache.set(key, undefined)`.\n */\n dispose?: Disposer<K, V>\n\n /**\n * The same as {@link OptionsBase.dispose}, but called *after* the entry\n * is completely removed and the cache is once again in a clean state.\n *\n * It is safe to add an item right back into the cache at this point.\n * However, note that it is *very* easy to inadvertently create infinite\n * recursion this way.\n */\n disposeAfter?: Disposer<K, V>\n\n /**\n * Set to true to suppress calling the\n * {@link OptionsBase.dispose} function if the entry key is\n * still accessible within the cache.\n *\n * This may be overridden by passing an options object to\n * {@link LRUCache#set}.\n *\n * Only relevant if `dispose` or `disposeAfter` are set.\n */\n noDisposeOnSet?: boolean\n\n /**\n * Boolean flag to tell the cache to not update the TTL when setting a new\n * value for an existing key (ie, when updating a value rather than\n * inserting a new value). Note that the TTL value is _always_ set (if\n * provided) when adding a new entry into the cache.\n *\n * Has no effect if a {@link OptionsBase.ttl} is not set.\n *\n * May be passed as an option to {@link LRUCache#set}.\n */\n noUpdateTTL?: boolean\n\n /**\n * Set to a positive integer to track the sizes of items added to the\n * cache, and automatically evict items in order to stay below this size.\n * Note that this may result in fewer than `max` items being stored.\n *\n * Attempting to add an item to the cache whose calculated size is greater\n * that this amount will be a no-op. The item will not be cached, and no\n * other items will be evicted.\n *\n * Optional, must be a positive integer if provided.\n *\n * Sets `maxEntrySize` to the same value, unless a different value is\n * provided for `maxEntrySize`.\n *\n * At least one of `max`, `maxSize`, or `TTL` is required. This must be a\n * positive integer if set.\n *\n * Even if size tracking is enabled, **it is strongly recommended to set a\n * `max` to prevent unbounded growth of the cache.**\n *\n * Note also that size tracking can negatively impact performance,\n * though for most cases, only minimally.\n */\n maxSize?: Size\n\n /**\n * The maximum allowed size for any single item in the cache.\n *\n * If a larger item is passed to {@link LRUCache#set} or returned by a\n * {@link OptionsBase.fetchMethod} or {@link OptionsBase.memoMethod}, then\n * it will not be stored in the cache.\n *\n * Attempting to add an item whose calculated size is greater than\n * this amount will not cache the item or evict any old items, but\n * WILL delete an existing value if one is already present.\n *\n * Optional, must be a positive integer if provided. Defaults to\n * the value of `maxSize` if provided.\n */\n maxEntrySize?: Size\n\n /**\n * A function that returns a number indicating the item's size.\n *\n * Requires {@link OptionsBase.maxSize} to be set.\n *\n * If not provided, and {@link OptionsBase.maxSize} or\n * {@link OptionsBase.maxEntrySize} are set, then all\n * {@link LRUCache#set} calls **must** provide an explicit\n * {@link SetOptions.size} or sizeCalculation param.\n */\n sizeCalculation?: SizeCalculator<K, V>\n\n /**\n * Method that provides the implementation for {@link LRUCache#fetch}\n *\n * ```ts\n * fetchMethod(key, staleValue, { signal, options, context })\n * ```\n *\n * If `fetchMethod` is not provided, then `cache.fetch(key)` is equivalent\n * to `Promise.resolve(cache.get(key))`.\n *\n * If at any time, `signal.aborted` is set to `true`, or if the\n * `signal.onabort` method is called, or if it emits an `'abort'` event\n * which you can listen to with `addEventListener`, then that means that\n * the fetch should be abandoned. This may be passed along to async\n * functions aware of AbortController/AbortSignal behavior.\n *\n * The `fetchMethod` should **only** return `undefined` or a Promise\n * resolving to `undefined` if the AbortController signaled an `abort`\n * event. In all other cases, it should return or resolve to a value\n * suitable for adding to the cache.\n *\n * The `options` object is a union of the options that may be provided to\n * `set()` and `get()`. If they are modified, then that will result in\n * modifying the settings to `cache.set()` when the value is resolved, and\n * in the case of\n * {@link OptionsBase.noDeleteOnFetchRejection} and\n * {@link OptionsBase.allowStaleOnFetchRejection}, the handling of\n * `fetchMethod` failures.\n *\n * For example, a DNS cache may update the TTL based on the value returned\n * from a remote DNS server by changing `options.ttl` in the `fetchMethod`.\n */\n fetchMethod?: Fetcher<K, V, FC>\n\n /**\n * Method that provides the implementation for {@link LRUCache#memo}\n */\n memoMethod?: Memoizer<K, V, FC>\n\n /**\n * Set to true to suppress the deletion of stale data when a\n * {@link OptionsBase.fetchMethod} returns a rejected promise.\n */\n noDeleteOnFetchRejection?: boolean\n\n /**\n * Do not delete stale items when they are retrieved with\n * {@link LRUCache#get}.\n *\n * Note that the `get` return value will still be `undefined`\n * unless {@link OptionsBase.allowStale} is true.\n *\n * When using time-expiring entries with `ttl`, by default stale\n * items will be removed from the cache when the key is accessed\n * with `cache.get()`.\n *\n * Setting this option will cause stale items to remain in the cache, until\n * they are explicitly deleted with `cache.delete(key)`, or retrieved with\n * `noDeleteOnStaleGet` set to `false`.\n *\n * This may be overridden by passing an options object to `cache.get()`.\n *\n * Only relevant if a ttl is used.\n */\n noDeleteOnStaleGet?: boolean\n\n /**\n * Set to true to allow returning stale data when a\n * {@link OptionsBase.fetchMethod} throws an error or returns a rejected\n * promise.\n *\n * This differs from using {@link OptionsBase.allowStale} in that stale\n * data will ONLY be returned in the case that the {@link LRUCache#fetch}\n * fails, not any other times.\n *\n * If a `fetchMethod` fails, and there is no stale value available, the\n * `fetch()` will resolve to `undefined`. Ie, all `fetchMethod` errors are\n * suppressed.\n *\n * Implies `noDeleteOnFetchRejection`.\n *\n * This may be set in calls to `fetch()`, or defaulted on the constructor,\n * or overridden by modifying the options object in the `fetchMethod`.\n */\n allowStaleOnFetchRejection?: boolean\n\n /**\n * Set to true to return a stale value from the cache when the\n * `AbortSignal` passed to the {@link OptionsBase.fetchMethod} dispatches\n * an `'abort'` event, whether user-triggered, or due to internal cache\n * behavior.\n *\n * Unless {@link OptionsBase.ignoreFetchAbort} is also set, the underlying\n * {@link OptionsBase.fetchMethod} will still be considered canceled, and\n * any value it returns will be ignored and not cached.\n *\n * Caveat: since fetches are aborted when a new value is explicitly\n * set in the cache, this can lead to fetch returning a stale value,\n * since that was the fallback value _at the moment the `fetch()` was\n * initiated_, even though the new updated value is now present in\n * the cache.\n *\n * For example:\n *\n * ```ts\n * const cache = new LRUCache<string, any>({\n * ttl: 100,\n * fetchMethod: async (url, oldValue, { signal }) => {\n * const res = await fetch(url, { signal })\n * return await res.json()\n * }\n * })\n * cache.set('https://example.com/', { some: 'data' })\n * // 100ms go by...\n * const result = cache.fetch('https://example.com/')\n * cache.set('https://example.com/', { other: 'thing' })\n * console.log(await result) // { some: 'data' }\n * console.log(cache.get('https://example.com/')) // { other: 'thing' }\n * ```\n */\n allowStaleOnFetchAbort?: boolean\n\n /**\n * Set to true to ignore the `abort` event emitted by the `AbortSignal`\n * object passed to {@link OptionsBase.fetchMethod}, and still cache the\n * resulting resolution value, as long as it is not `undefined`.\n *\n * When used on its own, this means aborted {@link LRUCache#fetch} calls\n * are not immediately resolved or rejected when they are aborted, and\n * instead take the full time to await.\n *\n * When used with {@link OptionsBase.allowStaleOnFetchAbort}, aborted\n * {@link LRUCache#fetch} calls will resolve immediately to their stale\n * cached value or `undefined`, and will continue to process and eventually\n * update the cache when they resolve, as long as the resulting value is\n * not `undefined`, thus supporting a \"return stale on timeout while\n * refreshing\" mechanism by passing `AbortSignal.timeout(n)` as the signal.\n *\n * For example:\n *\n * ```ts\n * const c = new LRUCache({\n * ttl: 100,\n * ignoreFetchAbort: true,\n * allowStaleOnFetchAbort: true,\n * fetchMethod: async (key, oldValue, { signal }) => {\n * // note: do NOT pass the signal to fetch()!\n * // let's say this fetch can take a long time.\n * const res = await fetch(`https://slow-backend-server/${key}`)\n * return await res.json()\n * },\n * })\n *\n * // this will return the stale value after 100ms, while still\n * // updating in the background for next time.\n * const val = await c.fetch('key', { signal: AbortSignal.timeout(100) })\n * ```\n *\n * **Note**: regardless of this setting, an `abort` event _is still\n * emitted on the `AbortSignal` object_, so may result in invalid results\n * when passed to other underlying APIs that use AbortSignals.\n *\n * This may be overridden in the {@link OptionsBase.fetchMethod} or the\n * call to {@link LRUCache#fetch}.\n */\n ignoreFetchAbort?: boolean\n }\n\n export interface OptionsMaxLimit<K, V, FC>\n extends OptionsBase<K, V, FC> {\n max: Count\n }\n export interface OptionsTTLLimit<K, V, FC>\n extends OptionsBase<K, V, FC> {\n ttl: Milliseconds\n ttlAutopurge: boolean\n }\n export interface OptionsSizeLimit<K, V, FC>\n extends OptionsBase<K, V, FC> {\n maxSize: Size\n }\n\n /**\n * The valid safe options for the {@link LRUCache} constructor\n */\n export type Options<K, V, FC> =\n | OptionsMaxLimit<K, V, FC>\n | OptionsSizeLimit<K, V, FC>\n | OptionsTTLLimit<K, V, FC>\n\n /**\n * Entry objects used by {@link LRUCache#load} and {@link LRUCache#dump},\n * and returned by {@link LRUCache#info}.\n */\n export interface Entry<V> {\n value: V\n ttl?: Milliseconds\n size?: Size\n start?: Milliseconds\n }\n}\n\n/**\n * Default export, the thing you're using this module to get.\n *\n * The `K` and `V` types define the key and value types, respectively. The\n * optional `FC` type defines the type of the `context` object passed to\n * `cache.fetch()` and `cache.memo()`.\n *\n * Keys and values **must not** be `null` or `undefined`.\n *\n * All properties from the options object (with the exception of `max`,\n * `maxSize`, `fetchMethod`, `memoMethod`, `dispose` and `disposeAfter`) are\n * added as normal public members. (The listed options are read-only getters.)\n *\n * Changing any of these will alter the defaults for subsequent method calls.\n */\nexport class LRUCache<K extends {}, V extends {}, FC = unknown>\n implements Map<K, V>\n{\n // options that cannot be changed without disaster\n readonly #max: LRUCache.Count\n readonly #maxSize: LRUCache.Size\n readonly #dispose?: LRUCache.Disposer<K, V>\n readonly #disposeAfter?: LRUCache.Disposer<K, V>\n readonly #fetchMethod?: LRUCache.Fetcher<K, V, FC>\n readonly #memoMethod?: LRUCache.Memoizer<K, V, FC>\n\n /**\n * {@link LRUCache.OptionsBase.ttl}\n */\n ttl: LRUCache.Milliseconds\n\n /**\n * {@link LRUCache.OptionsBase.ttlResolution}\n */\n ttlResolution: LRUCache.Milliseconds\n /**\n * {@link LRUCache.OptionsBase.ttlAutopurge}\n */\n ttlAutopurge: boolean\n /**\n * {@link LRUCache.OptionsBase.updateAgeOnGet}\n */\n updateAgeOnGet: boolean\n /**\n * {@link LRUCache.OptionsBase.updateAgeOnHas}\n */\n updateAgeOnHas: boolean\n /**\n * {@link LRUCache.OptionsBase.allowStale}\n */\n allowStale: boolean\n\n /**\n * {@link LRUCache.OptionsBase.noDisposeOnSet}\n */\n noDisposeOnSet: boolean\n /**\n * {@link LRUCache.OptionsBase.noUpdateTTL}\n */\n noUpdateTTL: boolean\n /**\n * {@link LRUCache.OptionsBase.maxEntrySize}\n */\n maxEntrySize: LRUCache.Size\n /**\n * {@link LRUCache.OptionsBase.sizeCalculation}\n */\n sizeCalculation?: LRUCache.SizeCalculator<K, V>\n /**\n * {@link LRUCache.OptionsBase.noDeleteOnFetchRejection}\n */\n noDeleteOnFetchRejection: boolean\n /**\n * {@link LRUCache.OptionsBase.noDeleteOnStaleGet}\n */\n noDeleteOnStaleGet: boolean\n /**\n * {@link LRUCache.OptionsBase.allowStaleOnFetchAbort}\n */\n allowStaleOnFetchAbort: boolean\n /**\n * {@link LRUCache.OptionsBase.allowStaleOnFetchRejection}\n */\n allowStaleOnFetchRejection: boolean\n /**\n * {@link LRUCache.OptionsBase.ignoreFetchAbort}\n */\n ignoreFetchAbort: boolean\n\n // computed properties\n #size: LRUCache.Count\n #calculatedSize: LRUCache.Size\n #keyMap: Map<K, Index>\n #keyList: (K | undefined)[]\n #valList: (V | BackgroundFetch<V> | undefined)[]\n #next: NumberArray\n #prev: NumberArray\n #head: Index\n #tail: Index\n #free: StackLike\n #disposed?: DisposeTask<K, V>[]\n #sizes?: ZeroArray\n #starts?: ZeroArray\n #ttls?: ZeroArray\n\n #hasDispose: boolean\n #hasFetchMethod: boolean\n #hasDisposeAfter: boolean\n\n /**\n * Do not call this method unless you need to inspect the\n * inner workings of the cache. If anything returned by this\n * object is modified in any way, strange breakage may occur.\n *\n * These fields are private for a reason!\n *\n * @internal\n */\n static unsafeExposeInternals<\n K extends {},\n V extends {},\n FC extends unknown = unknown\n >(c: LRUCache<K, V, FC>) {\n return {\n // properties\n starts: c.#starts,\n ttls: c.#ttls,\n sizes: c.#sizes,\n keyMap: c.#keyMap as Map<K, number>,\n keyList: c.#keyList,\n valList: c.#valList,\n next: c.#next,\n prev: c.#prev,\n get head() {\n return c.#head\n },\n get tail() {\n return c.#tail\n },\n free: c.#free,\n // methods\n isBackgroundFetch: (p: any) => c.#isBackgroundFetch(p),\n backgroundFetch: (\n k: K,\n index: number | undefined,\n options: LRUCache.FetchOptions<K, V, FC>,\n context: any\n ): BackgroundFetch<V> =>\n c.#backgroundFetch(\n k,\n index as Index | undefined,\n options,\n context\n ),\n moveToTail: (index: number): void =>\n c.#moveToTail(index as Index),\n indexes: (options?: { allowStale: boolean }) =>\n c.#indexes(options),\n rindexes: (options?: { allowStale: boolean }) =>\n c.#rindexes(options),\n isStale: (index: number | undefined) =>\n c.#isStale(index as Index),\n }\n }\n\n // Protected read-only members\n\n /**\n * {@link LRUCache.OptionsBase.max} (read-only)\n */\n get max(): LRUCache.Count {\n return this.#max\n }\n /**\n * {@link LRUCache.OptionsBase.maxSize} (read-only)\n */\n get maxSize(): LRUCache.Count {\n return this.#maxSize\n }\n /**\n * The total computed size of items in the cache (read-only)\n */\n get calculatedSize(): LRUCache.Size {\n return this.#calculatedSize\n }\n /**\n * The number of items stored in the cache (read-only)\n */\n get size(): LRUCache.Count {\n return this.#size\n }\n /**\n * {@link LRUCache.OptionsBase.fetchMethod} (read-only)\n */\n get fetchMethod(): LRUCache.Fetcher<K, V, FC> | undefined {\n return this.#fetchMethod\n }\n get memoMethod(): LRUCache.Memoizer<K, V, FC> | undefined {\n return this.#memoMethod\n }\n /**\n * {@link LRUCache.OptionsBase.dispose} (read-only)\n */\n get dispose() {\n return this.#dispose\n }\n /**\n * {@link LRUCache.OptionsBase.disposeAfter} (read-only)\n */\n get disposeAfter() {\n return this.#disposeAfter\n }\n\n constructor(\n options: LRUCache.Options<K, V, FC> | LRUCache<K, V, FC>\n ) {\n const {\n max = 0,\n ttl,\n ttlResolution = 1,\n ttlAutopurge,\n updateAgeOnGet,\n updateAgeOnHas,\n allowStale,\n dispose,\n disposeAfter,\n noDisposeOnSet,\n noUpdateTTL,\n maxSize = 0,\n maxEntrySize = 0,\n sizeCalculation,\n fetchMethod,\n memoMethod,\n noDeleteOnFetchRejection,\n noDeleteOnStaleGet,\n allowStaleOnFetchRejection,\n allowStaleOnFetchAbort,\n ignoreFetchAbort,\n } = options\n\n if (max !== 0 && !isPosInt(max)) {\n throw new TypeError('max option must be a nonnegative integer')\n }\n\n const UintArray = max ? getUintArray(max) : Array\n if (!UintArray) {\n throw new Error('invalid max value: ' + max)\n }\n\n this.#max = max\n this.#maxSize = maxSize\n this.maxEntrySize = maxEntrySize || this.#maxSize\n this.sizeCalculation = sizeCalculation\n if (this.sizeCalculation) {\n if (!this.#maxSize && !this.maxEntrySize) {\n throw new TypeError(\n 'cannot set sizeCalculation without setting maxSize or maxEntrySize'\n )\n }\n if (typeof this.sizeCalculation !== 'function') {\n throw new TypeError('sizeCalculation set to non-function')\n }\n }\n\n if (\n memoMethod !== undefined &&\n typeof memoMethod !== 'function'\n ) {\n throw new TypeError('memoMethod must be a function if defined')\n }\n this.#memoMethod = memoMethod\n\n if (\n fetchMethod !== undefined &&\n typeof fetchMethod !== 'function'\n ) {\n throw new TypeError(\n 'fetchMethod must be a function if specified'\n )\n }\n this.#fetchMethod = fetchMethod\n this.#hasFetchMethod = !!fetchMethod\n\n this.#keyMap = new Map()\n this.#keyList = new Array(max).fill(undefined)\n this.#valList = new Array(max).fill(undefined)\n this.#next = new UintArray(max)\n this.#prev = new UintArray(max)\n this.#head = 0 as Index\n this.#tail = 0 as Index\n this.#free = Stack.create(max)\n this.#size = 0\n this.#calculatedSize = 0\n\n if (typeof dispose === 'function') {\n this.#dispose = dispose\n }\n if (typeof disposeAfter === 'function') {\n this.#disposeAfter = disposeAfter\n this.#disposed = []\n } else {\n this.#disposeAfter = undefined\n this.#disposed = undefined\n }\n this.#hasDispose = !!this.#dispose\n this.#hasDisposeAfter = !!this.#disposeAfter\n\n this.noDisposeOnSet = !!noDisposeOnSet\n this.noUpdateTTL = !!noUpdateTTL\n this.noDeleteOnFetchRejection = !!noDeleteOnFetchRejection\n this.allowStaleOnFetchRejection = !!allowStaleOnFetchRejection\n this.allowStaleOnFetchAbort = !!allowStaleOnFetchAbort\n this.ignoreFetchAbort = !!ignoreFetchAbort\n\n // NB: maxEntrySize is set to maxSize if it's set\n if (this.maxEntrySize !== 0) {\n if (this.#maxSize !== 0) {\n if (!isPosInt(this.#maxSize)) {\n throw new TypeError(\n 'maxSize must be a positive integer if specified'\n )\n }\n }\n if (!isPosInt(this.maxEntrySize)) {\n throw new TypeError(\n 'maxEntrySize must be a positive integer if specified'\n )\n }\n this.#initializeSizeTracking()\n }\n\n this.allowStale = !!allowStale\n this.noDeleteOnStaleGet = !!noDeleteOnStaleGet\n this.updateAgeOnGet = !!updateAgeOnGet\n this.updateAgeOnHas = !!updateAgeOnHas\n this.ttlResolution =\n isPosInt(ttlResolution) || ttlResolution === 0\n ? ttlResolution\n : 1\n this.ttlAutopurge = !!ttlAutopurge\n this.ttl = ttl || 0\n if (this.ttl) {\n if (!isPosInt(this.ttl)) {\n throw new TypeError(\n 'ttl must be a positive integer if specified'\n )\n }\n this.#initializeTTLTracking()\n }\n\n // do not allow completely unbounded caches\n if (this.#max === 0 && this.ttl === 0 && this.#maxSize === 0) {\n throw new TypeError(\n 'At least one of max, maxSize, or ttl is required'\n )\n }\n if (!this.ttlAutopurge && !this.#max && !this.#maxSize) {\n const code = 'LRU_CACHE_UNBOUNDED'\n if (shouldWarn(code)) {\n warned.add(code)\n const msg =\n 'TTL caching without ttlAutopurge, max, or maxSize can ' +\n 'result in unbounded memory consumption.'\n emitWarning(msg, 'UnboundedCacheWarning', code, LRUCache)\n }\n }\n }\n\n /**\n * Return the number of ms left in the item's TTL. If item is not in cache,\n * returns `0`. Returns `Infinity` if item is in cache without a defined TTL.\n */\n getRemainingTTL(key: K) {\n return this.#keyMap.has(key) ? Infinity : 0\n }\n\n #initializeTTLTracking() {\n const ttls = new ZeroArray(this.#max)\n const starts = new ZeroArray(this.#max)\n this.#ttls = ttls\n this.#starts = starts\n\n this.#setItemTTL = (index, ttl, start = perf.now()) => {\n starts[index] = ttl !== 0 ? start : 0\n ttls[index] = ttl\n if (ttl !== 0 && this.ttlAutopurge) {\n const t = setTimeout(() => {\n if (this.#isStale(index)) {\n this.#delete(this.#keyList[index] as K, 'expire')\n }\n }, ttl + 1)\n // unref() not supported on all platforms\n /* c8 ignore start */\n if (t.unref) {\n t.unref()\n }\n /* c8 ignore stop */\n }\n }\n\n this.#updateItemAge = index => {\n starts[index] = ttls[index] !== 0 ? perf.now() : 0\n }\n\n this.#statusTTL = (status, index) => {\n if (ttls[index]) {\n const ttl = ttls[index]\n const start = starts[index]\n /* c8 ignore next */\n if (!ttl || !start) return\n status.ttl = ttl\n status.start = start\n status.now = cachedNow || getNow()\n const age = status.now - start\n status.remainingTTL = ttl - age\n }\n }\n\n // debounce calls to perf.now() to 1s so we're not hitting\n // that costly call repeatedly.\n let cachedNow = 0\n const getNow = () => {\n const n = perf.now()\n if (this.ttlResolution > 0) {\n cachedNow = n\n const t = setTimeout(\n () => (cachedNow = 0),\n this.ttlResolution\n )\n // not available on all platforms\n /* c8 ignore start */\n if (t.unref) {\n t.unref()\n }\n /* c8 ignore stop */\n }\n return n\n }\n\n this.getRemainingTTL = key => {\n const index = this.#keyMap.get(key)\n if (index === undefined) {\n return 0\n }\n const ttl = ttls[index]\n const start = starts[index]\n if (!ttl || !start) {\n return Infinity\n }\n const age = (cachedNow || getNow()) - start\n return ttl - age\n }\n\n this.#isStale = index => {\n const s = starts[index]\n const t = ttls[index]\n return !!t && !!s && (cachedNow || getNow()) - s > t\n }\n }\n\n // conditionally set private methods related to TTL\n #updateItemAge: (index: Index) => void = () => {}\n #statusTTL: (status: LRUCache.Status<V>, index: Index) => void =\n () => {}\n #setItemTTL: (\n index: Index,\n ttl: LRUCache.Milliseconds,\n start?: LRUCache.Milliseconds\n // ignore because we never call this if we're not already in TTL mode\n /* c8 ignore start */\n ) => void = () => {}\n /* c8 ignore stop */\n\n #isStale: (index: Index) => boolean = () => false\n\n #initializeSizeTracking() {\n const sizes = new ZeroArray(this.#max)\n this.#calculatedSize = 0\n this.#sizes = sizes\n this.#removeItemSize = index => {\n this.#calculatedSize -= sizes[index] as number\n sizes[index] = 0\n }\n this.#requireSize = (k, v, size, sizeCalculation) => {\n // provisionally accept background fetches.\n // actual value size will be checked when they return.\n if (this.#isBackgroundFetch(v)) {\n return 0\n }\n if (!isPosInt(size)) {\n if (sizeCalculation) {\n if (typeof sizeCalculation !== 'function') {\n throw new TypeError('sizeCalculation must be a function')\n }\n size = sizeCalculation(v, k)\n if (!isPosInt(size)) {\n throw new TypeError(\n 'sizeCalculation return invalid (expect positive integer)'\n )\n }\n } else {\n throw new TypeError(\n 'invalid size value (must be positive integer). ' +\n 'When maxSize or maxEntrySize is used, sizeCalculation ' +\n 'or size must be set.'\n )\n }\n }\n return size\n }\n this.#addItemSize = (\n index: Index,\n size: LRUCache.Size,\n status?: LRUCache.Status<V>\n ) => {\n sizes[index] = size\n if (this.#maxSize) {\n const maxSize = this.#maxSize - (sizes[index] as number)\n while (this.#calculatedSize > maxSize) {\n this.#evict(true)\n }\n }\n this.#calculatedSize += sizes[index] as number\n if (status) {\n status.entrySize = size\n status.totalCalculatedSize = this.#calculatedSize\n }\n }\n }\n\n #removeItemSize: (index: Index) => void = _i => {}\n #addItemSize: (\n index: Index,\n size: LRUCache.Size,\n status?: LRUCache.Status<V>\n ) => void = (_i, _s, _st) => {}\n #requireSize: (\n k: K,\n v: V | BackgroundFetch<V>,\n size?: LRUCache.Size,\n sizeCalculation?: LRUCache.SizeCalculator<K, V>\n ) => LRUCache.Size = (\n _k: K,\n _v: V | BackgroundFetch<V>,\n size?: LRUCache.Size,\n sizeCalculation?: LRUCache.SizeCalculator<K, V>\n ) => {\n if (size || sizeCalculation) {\n throw new TypeError(\n 'cannot set size without setting maxSize or maxEntrySize on cache'\n )\n }\n return 0\n };\n\n *#indexes({ allowStale = this.allowStale } = {}) {\n if (this.#size) {\n for (let i = this.#tail; true; ) {\n if (!this.#isValidIndex(i)) {\n break\n }\n if (allowStale || !this.#isStale(i)) {\n yield i\n }\n if (i === this.#head) {\n break\n } else {\n i = this.#prev[i] as Index\n }\n }\n }\n }\n\n *#rindexes({ allowStale = this.allowStale } = {}) {\n if (this.#size) {\n for (let i = this.#head; true; ) {\n if (!this.#isValidIndex(i)) {\n break\n }\n if (allowStale || !this.#isStale(i)) {\n yield i\n }\n if (i === this.#tail) {\n break\n } else {\n i = this.#next[i] as Index\n }\n }\n }\n }\n\n #isValidIndex(index: Index) {\n return (\n index !== undefined &&\n this.#keyMap.get(this.#keyList[index] as K) === index\n )\n }\n\n /**\n * Return a generator yielding `[key, value]` pairs,\n * in order from most recently used to least recently used.\n */\n *entries() {\n for (const i of this.#indexes()) {\n if (\n this.#valList[i] !== undefined &&\n this.#keyList[i] !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield [this.#keyList[i], this.#valList[i]] as [K, V]\n }\n }\n }\n\n /**\n * Inverse order version of {@link LRUCache.entries}\n *\n * Return a generator yielding `[key, value]` pairs,\n * in order from least recently used to most recently used.\n */\n *rentries() {\n for (const i of this.#rindexes()) {\n if (\n this.#valList[i] !== undefined &&\n this.#keyList[i] !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield [this.#keyList[i], this.#valList[i]]\n }\n }\n }\n\n /**\n * Return a generator yielding the keys in the cache,\n * in order from most recently used to least recently used.\n */\n *keys() {\n for (const i of this.#indexes()) {\n const k = this.#keyList[i]\n if (\n k !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield k\n }\n }\n }\n\n /**\n * Inverse order version of {@link LRUCache.keys}\n *\n * Return a generator yielding the keys in the cache,\n * in order from least recently used to most recently used.\n */\n *rkeys() {\n for (const i of this.#rindexes()) {\n const k = this.#keyList[i]\n if (\n k !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield k\n }\n }\n }\n\n /**\n * Return a generator yielding the values in the cache,\n * in order from most recently used to least recently used.\n */\n *values() {\n for (const i of this.#indexes()) {\n const v = this.#valList[i]\n if (\n v !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield this.#valList[i] as V\n }\n }\n }\n\n /**\n * Inverse order version of {@link LRUCache.values}\n *\n * Return a generator yielding the values in the cache,\n * in order from least recently used to most recently used.\n */\n *rvalues() {\n for (const i of this.#rindexes()) {\n const v = this.#valList[i]\n if (\n v !== undefined &&\n !this.#isBackgroundFetch(this.#valList[i])\n ) {\n yield this.#valList[i]\n }\n }\n }\n\n /**\n * Iterating over the cache itself yields the same results as\n * {@link LRUCache.entries}\n */\n [Symbol.iterator]() {\n return this.entries()\n }\n\n /**\n * A String value that is used in the creation of the default string\n * description of an object. Called by the built-in method\n * `Object.prototype.toString`.\n */\n [Symbol.toStringTag] = 'LRUCache'\n\n /**\n * Find a value for which the supplied fn method returns a truthy value,\n * similar to `Array.find()`. fn is called as `fn(value, key, cache)`.\n */\n find(\n fn: (v: V, k: K, self: LRUCache<K, V, FC>) => boolean,\n getOptions: LRUCache.GetOptions<K, V, FC> = {}\n ) {\n for (const i of this.#indexes()) {\n const v = this.#valList[i]\n const value = this.#isBackgroundFetch(v)\n ? v.__staleWhileFetching\n : v\n if (value === undefined) continue\n if (fn(value, this.#keyList[i] as K, this)) {\n return this.get(this.#keyList[i] as K, getOptions)\n }\n }\n }\n\n /**\n * Call the supplied function on each item in the cache, in order from most\n * recently used to least recently used.\n *\n * `fn` is called as `fn(value, key, cache)`.\n *\n * If `thisp` is provided, function will be called in the `this`-context of\n * the provided object, or the cache if no `thisp` object is provided.\n *\n * Does not update age or recenty of use, or iterate over stale values.\n */\n forEach(\n fn: (v: V, k: K, self: LRUCache<K, V, FC>) => any,\n thisp: any = this\n ) {\n for (const i of this.#indexes()) {\n const v = this.#valList[i]\n const value = this.#isBackgroundFetch(v)\n ? v.__staleWhileFetching\n : v\n if (value === undefined) continue\n fn.call(thisp, value, this.#keyList[i] as K, this)\n }\n }\n\n /**\n * The same as {@link LRUCache.forEach} but items are iterated over in\n * reverse order. (ie, less recently used items are iterated over first.)\n */\n rforEach(\n fn: (v: V, k: K, self: LRUCache<K, V, FC>) => any,\n thisp: any = this\n ) {\n for (const i of this.#rindexes()) {\n const v = this.#valList[i]\n const value = this.#isBackgroundFetch(v)\n ? v.__staleWhileFetching\n : v\n if (value === undefined) continue\n fn.call(thisp, value, this.#keyList[i] as K, this)\n }\n }\n\n /**\n * Delete any stale entries. Returns true if anything was removed,\n * false otherwise.\n */\n purgeStale() {\n let deleted = false\n for (const i of this.#rindexes({ allowStale: true })) {\n if (this.#isStale(i)) {\n this.#delete(this.#keyList[i] as K, 'expire')\n deleted = true\n }\n }\n return deleted\n }\n\n /**\n * Get the extended info about a given entry, to get its value, size, and\n * TTL info simultaneously. Returns `undefined` if the key is not present.\n *\n * Unlike {@link LRUCache#dump}, which is designed to be portable and survive\n * serialization, the `start` value is always the current timestamp, and the\n * `ttl` is a calculated remaining time to live (negative if expired).\n *\n * Always returns stale values, if their info is found in the cache, so be\n * sure to check for expirations (ie, a negative {@link LRUCache.Entry#ttl})\n * if relevant.\n */\n info(key: K): LRUCache.Entry<V> | undefined {\n const i = this.#keyMap.get(key)\n if (i === undefined) return undefined\n const v = this.#valList[i]\n const value: V | undefined = this.#isBackgroundFetch(v)\n ? v.__staleWhileFetching\n : v\n if (value === undefined) return undefined\n const entry: LRUCache.Entry<V> = { value }\n if (this.#ttls && this.#starts) {\n const ttl = this.#ttls[i]\n const start = this.#starts[i]\n if (ttl && start) {\n const remain = ttl - (perf.now() - start)\n entry.ttl = remain\n entry.start = Date.now()\n }\n }\n if (this.#sizes) {\n entry.size = this.#sizes[i]\n }\n return entry\n }\n\n /**\n * Return an array of [key, {@link LRUCache.Entry}] tuples which can be\n * passed to {@link LRLUCache#load}.\n *\n * The `start` fields are calculated relative to a portable `Date.now()`\n * timestamp, even if `performance.now()` is available.\n *\n * Stale entries are always included in the `dump`, even if\n * {@link LRUCache.OptionsBase.allowStale} is false.\n *\n * Note: this returns an actual array, not a generator, so it can be more\n * easily passed around.\n */\n dump() {\n const arr: [K, LRUCache.Entry<V>][] = []\n for (const i of this.#indexes({ allowStale: true })) {\n const key = this.#keyList[i]\n const v = this.#valList[i]\n const value: V | undefined = this.#isBackgroundFetch(v)\n ? v.__staleWhileFetching\n : v\n if (value === undefined || key === undefined) continue\n const entry: LRUCache.Entry<V> = { value }\n if (this.#ttls && this.#starts) {\n entry.ttl = this.#ttls[i]\n // always dump the start relative to a portable timestamp\n // it's ok for this to be a bit slow, it's a rare operation.\n const age = perf.now() - (this.#starts[i] as number)\n entry.start = Math.floor(Date.now() - age)\n }\n if (this.#sizes) {\n entry.size = this.#sizes[i]\n }\n arr.unshift([key, entry])\n }\n return arr\n }\n\n /**\n * Reset the cache and load in the items in entries in the order listed.\n *\n * The shape of the resulting cache may be different if the same options are\n * not used in both caches.\n *\n * The `start` fields are assumed to be calculated relative to a portable\n * `Date.now()` timestamp, even if `performance.now()` is available.\n */\n load(arr: [K, LRUCache.Entry<V>][]) {\n this.clear()\n for (const [key, entry] of arr) {\n if (entry.start) {\n // entry.start is a portable timestamp, but we may be using\n // node's performance.now(), so calculate the offset, so that\n // we get the intended remaining TTL, no matter how long it's\n // been on ice.\n //\n // it's ok for this to be a bit slow, it's a rare operation.\n const age = Date.now() - entry.start\n entry.start = perf.now() - age\n }\n this.set(key, entry.value, entry)\n }\n }\n\n /**\n * Add a value to the cache.\n *\n * Note: if `undefined` is specified as a value, this is an alias for\n * {@link LRUCache#delete}\n *\n * Fields on the {@link LRUCache.SetOptions} options param will override\n * their corresponding values in the constructor options for the scope\n * of this single `set()` operation.\n *\n * If `start` is provided, then that will set the effective start\n * time for the TTL calculation. Note that this must be a previous\n * value of `performance.now()` if supported, or a previous value of\n * `Date.now()` if not.\n *\n * Options object may also include `size`, which will prevent\n * calling the `sizeCalculation` function and just use the specified\n * number if it is a positive integer, and `noDisposeOnSet` which\n * will prevent calling a `dispose` function in the case of\n * overwrites.\n *\n * If the `size` (or return value of `sizeCalculation`) for a given\n * entry is greater than `maxEntrySize`, then the item will not be\n * added to the cache.\n *\n * Will update the recency of the entry.\n *\n * If the value is `undefined`, then this is an alias for\n * `cache.delete(key)`. `undefined` is never stored in the cache.\n */\n set(\n k: K,\n v: V | BackgroundFetch<V> | undefined,\n setOptions: LRUCache.SetOptions<K, V, FC> = {}\n ) {\n if (v === undefined) {\n this.delete(k)\n return this\n }\n const {\n ttl = this.ttl,\n start,\n noDisposeOnSet = this.noDisposeOnSet,\n sizeCalculation = this.sizeCalculation,\n status,\n } = setOptions\n let { noUpdateTTL = this.noUpdateTTL } = setOptions\n\n const size = this.#requireSize(\n k,\n v,\n setOptions.size || 0,\n sizeCalculation\n )\n // if the item doesn't fit, don't do anything\n // NB: maxEntrySize set to maxSize by default\n if (this.maxEntrySize && size > this.maxEntrySize) {\n if (status) {\n status.set = 'miss'\n status.maxEntrySizeExceeded = true\n }\n // have to delete, in case something is there already.\n this.#delete(k, 'set')\n return this\n }\n let index = this.#size === 0 ? undefined : this.#keyMap.get(k)\n if (index === undefined) {\n // addition\n index = (\n this.#size === 0\n ? this.#tail\n : this.#free.length !== 0\n ? this.#free.pop()\n : this.#size === this.#max\n ? this.#evict(false)\n : this.#size\n ) as Index\n this.#keyList[index] = k\n this.#valList[index] = v\n this.#keyMap.set(k, index)\n this.#next[this.#tail] = index\n this.#prev[index] = this.#tail\n this.#tail = index\n this.#size++\n this.#addItemSize(index, size, status)\n if (status) status.set = 'add'\n noUpdateTTL = false\n } else {\n // update\n this.#moveToTail(index)\n const oldVal = this.#valList[index] as V | BackgroundFetch<V>\n if (v !== oldVal) {\n if (this.#hasFetchMethod && this.#isBackgroundFetch(oldVal)) {\n oldVal.__abortController.abort(new Error('replaced'))\n const { __staleWhileFetching: s } = oldVal\n if (s !== undefined && !noDisposeOnSet) {\n if (this.#hasDispose) {\n this.#dispose?.(s as V, k, 'set')\n }\n if (this.#hasDisposeAfter) {\n this.#disposed?.push([s as V, k, 'set'])\n }\n }\n } else if (!noDisposeOnSet) {\n if (this.#hasDispose) {\n this.#dispose?.(oldVal as V, k, 'set')\n }\n if (this.#hasDisposeAfter) {\n this.#disposed?.push([oldVal as V, k, 'set'])\n }\n }\n this.#removeItemSize(index)\n this.#addItemSize(index, size, status)\n this.#valList[index] = v\n if (status) {\n status.set = 'replace'\n const oldValue =\n oldVal && this.#isBackgroundFetch(oldVal)\n ? oldVal.__staleWhileFetching\n : oldVal\n if (oldValue !== undefined) status.oldValue = oldValue\n }\n } else if (status) {\n status.set = 'update'\n }\n }\n if (ttl !== 0 && !this.#ttls) {\n this.#initializeTTLTracking()\n }\n if (this.#ttls) {\n if (!noUpdateTTL) {\n this.#setItemTTL(index, ttl, start)\n }\n if (status) this.#statusTTL(status, index)\n }\n if (!noDisposeOnSet && this.#hasDisposeAfter && this.#disposed) {\n const dt = this.#disposed\n let task: DisposeTask<K, V> | undefined\n while ((task = dt?.shift())) {\n this.#disposeAfter?.(...task)\n }\n }\n return this\n }\n\n /**\n * Evict the least recently used item, returning its value or\n * `undefined` if cache is empty.\n */\n pop(): V | undefined {\n try {\n while (this.#size) {\n const val = this.#valList[this.#head]\n this.#evict(true)\n if (this.#isBackgroundFetch(val)) {\n if (val.__staleWhileFetching) {\n return val.__staleWhileFetching\n }\n } else if (val !== undefined) {\n return val\n }\n }\n } finally {\n if (this.#hasDisposeAfter && this.#disposed) {\n const dt = this.#disposed\n let task: DisposeTask<K, V> | undefined\n while ((task = dt?.shift())) {\n this.#disposeAfter?.(...task)\n }\n }\n }\n }\n\n #evict(free: boolean) {\n const head = this.#head\n const k = this.#keyList[head] as K\n const v = this.#valList[head] as V\n if (this.#hasFetchMethod && this.#isBackgroundFetch(v)) {\n v.__abortController.abort(new Error('evicted'))\n } else if (this.#hasDispose || this.#hasDisposeAfter) {\n if (this.#hasDispose) {\n this.#dispose?.(v, k, 'evict')\n }\n if (this.#hasDisposeAfter) {\n this.#disposed?.push([v, k, 'evict'])\n }\n }\n this.#removeItemSize(head)\n // if we aren't about to use the index, then null these out\n if (free) {\n this.#keyList[head] = undefined\n this.#valList[head] = undefined\n this.#free.push(head)\n }\n if (this.#size === 1) {\n this.#head = this.#tail = 0 as Index\n this.#free.length = 0\n } else {\n this.#head = this.#next[head] as Index\n }\n this.#keyMap.delete(k)\n this.#size--\n return head\n }\n\n /**\n * Check if a key is in the cache, without updating the recency of use.\n * Will return false if the item is stale, even though it is technically\n * in the cache.\n *\n * Check if a key is in the cache, without updating the recency of\n * use. Age is updated if {@link LRUCache.OptionsBase.updateAgeOnHas} is set\n * to `true` in either the options or the constructor.\n *\n * Will return `false` if the item is stale, even though it is technically in\n * the cache. The difference can be determined (if it matters) by using a\n * `status` argument, and inspecting the `has` field.\n *\n * Will not update item age unless\n * {@link LRUCache.OptionsBase.updateAgeOnHas} is set.\n */\n has(k: K, hasOptions: LRUCache.HasOptions<K, V, FC> = {}) {\n const { updateAgeOnHas = this.updateAgeOnHas, status } =\n hasOptions\n const index = this.#keyMap.get(k)\n if (index !== undefined) {\n const v = this.#valList[index]\n if (\n this.#isBackgroundFetch(v) &&\n v.__staleWhileFetching === undefined\n ) {\n return false\n }\n if (!this.#isStale(index)) {\n if (updateAgeOnHas) {\n this.#updateItemAge(index)\n }\n if (status) {\n status.has = 'hit'\n this.#statusTTL(status, index)\n }\n return true\n } else if (status) {\n status.has = 'stale'\n this.#statusTTL(status, index)\n }\n } else if (status) {\n status.has = 'miss'\n }\n return false\n }\n\n /**\n * Like {@link LRUCache#get} but doesn't update recency or delete stale\n * items.\n *\n * Returns `undefined` if the item is stale, unless\n * {@link LRUCache.OptionsBase.allowStale} is set.\n */\n peek(k: K, peekOptions: LRUCache.PeekOptions<K, V, FC> = {}) {\n const { allowStale = this.allowStale } = peekOptions\n const index = this.#keyMap.get(k)\n if (\n index === undefined ||\n (!allowStale && this.#isStale(index))\n ) {\n return\n }\n const v = this.#valList[index]\n // either stale and allowed, or forcing a refresh of non-stale value\n return this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n }\n\n #backgroundFetch(\n k: K,\n index: Index | undefined,\n options: LRUCache.FetchOptions<K, V, FC>,\n context: any\n ): BackgroundFetch<V> {\n const v = index === undefined ? undefined : this.#valList[index]\n if (this.#isBackgroundFetch(v)) {\n return v\n }\n\n const ac = new AC()\n const { signal } = options\n // when/if our AC signals, then stop listening to theirs.\n signal?.addEventListener('abort', () => ac.abort(signal.reason), {\n signal: ac.signal,\n })\n\n const fetchOpts = {\n signal: ac.signal,\n options,\n context,\n }\n\n const cb = (\n v: V | undefined,\n updateCache = false\n ): V | undefined => {\n const { aborted } = ac.signal\n const ignoreAbort = options.ignoreFetchAbort && v !== undefined\n if (options.status) {\n if (aborted && !updateCache) {\n options.status.fetchAborted = true\n options.status.fetchError = ac.signal.reason\n if (ignoreAbort) options.status.fetchAbortIgnored = true\n } else {\n options.status.fetchResolved = true\n }\n }\n if (aborted && !ignoreAbort && !updateCache) {\n return fetchFail(ac.signal.reason)\n }\n // either we didn't abort, and are still here, or we did, and ignored\n const bf = p as BackgroundFetch<V>\n if (this.#valList[index as Index] === p) {\n if (v === undefined) {\n if (bf.__staleWhileFetching) {\n this.#valList[index as Index] = bf.__staleWhileFetching\n } else {\n this.#delete(k, 'fetch')\n }\n } else {\n if (options.status) options.status.fetchUpdated = true\n this.set(k, v, fetchOpts.options)\n }\n }\n return v\n }\n\n const eb = (er: any) => {\n if (options.status) {\n options.status.fetchRejected = true\n options.status.fetchError = er\n }\n return fetchFail(er)\n }\n\n const fetchFail = (er: any): V | undefined => {\n const { aborted } = ac.signal\n const allowStaleAborted =\n aborted && options.allowStaleOnFetchAbort\n const allowStale =\n allowStaleAborted || options.allowStaleOnFetchRejection\n const noDelete = allowStale || options.noDeleteOnFetchRejection\n const bf = p as BackgroundFetch<V>\n if (this.#valList[index as Index] === p) {\n // if we allow stale on fetch rejections, then we need to ensure that\n // the stale value is not removed from the cache when the fetch fails.\n const del = !noDelete || bf.__staleWhileFetching === undefined\n if (del) {\n this.#delete(k, 'fetch')\n } else if (!allowStaleAborted) {\n // still replace the *promise* with the stale value,\n // since we are done with the promise at this point.\n // leave it untouched if we're still waiting for an\n // aborted background fetch that hasn't yet returned.\n this.#valList[index as Index] = bf.__staleWhileFetching\n }\n }\n if (allowStale) {\n if (options.status && bf.__staleWhileFetching !== undefined) {\n options.status.returnedStale = true\n }\n return bf.__staleWhileFetching\n } else if (bf.__returned === bf) {\n throw er\n }\n }\n\n const pcall = (\n res: (v: V | undefined) => void,\n rej: (e: any) => void\n ) => {\n const fmp = this.#fetchMethod?.(k, v, fetchOpts)\n if (fmp && fmp instanceof Promise) {\n fmp.then(v => res(v === undefined ? undefined : v), rej)\n }\n // ignored, we go until we finish, regardless.\n // defer check until we are actually aborting,\n // so fetchMethod can override.\n ac.signal.addEventListener('abort', () => {\n if (\n !options.ignoreFetchAbort ||\n options.allowStaleOnFetchAbort\n ) {\n res(undefined)\n // when it eventually resolves, update the cache.\n if (options.allowStaleOnFetchAbort) {\n res = v => cb(v, true)\n }\n }\n })\n }\n\n if (options.status) options.status.fetchDispatched = true\n const p = new Promise(pcall).then(cb, eb)\n const bf: BackgroundFetch<V> = Object.assign(p, {\n __abortController: ac,\n __staleWhileFetching: v,\n __returned: undefined,\n })\n\n if (index === undefined) {\n // internal, don't expose status.\n this.set(k, bf, { ...fetchOpts.options, status: undefined })\n index = this.#keyMap.get(k)\n } else {\n this.#valList[index] = bf\n }\n return bf\n }\n\n #isBackgroundFetch(p: any): p is BackgroundFetch<V> {\n if (!this.#hasFetchMethod) return false\n const b = p as BackgroundFetch<V>\n return (\n !!b &&\n b instanceof Promise &&\n b.hasOwnProperty('__staleWhileFetching') &&\n b.__abortController instanceof AC\n )\n }\n\n /**\n * Make an asynchronous cached fetch using the\n * {@link LRUCache.OptionsBase.fetchMethod} function.\n *\n * If the value is in the cache and not stale, then the returned\n * Promise resolves to the value.\n *\n * If not in the cache, or beyond its TTL staleness, then\n * `fetchMethod(key, staleValue, { options, signal, context })` is\n * called, and the value returned will be added to the cache once\n * resolved.\n *\n * If called with `allowStale`, and an asynchronous fetch is\n * currently in progress to reload a stale value, then the former\n * stale value will be returned.\n *\n * If called with `forceRefresh`, then the cached item will be\n * re-fetched, even if it is not stale. However, if `allowStale` is also\n * set, then the old value will still be returned. This is useful\n * in cases where you want to force a reload of a cached value. If\n * a background fetch is already in progress, then `forceRefresh`\n * has no effect.\n *\n * If multiple fetches for the same key are issued, then they will all be\n * coalesced into a single call to fetchMethod.\n *\n * Note that this means that handling options such as\n * {@link LRUCache.OptionsBase.allowStaleOnFetchAbort},\n * {@link LRUCache.FetchOptions.signal},\n * and {@link LRUCache.OptionsBase.allowStaleOnFetchRejection} will be\n * determined by the FIRST fetch() call for a given key.\n *\n * This is a known (fixable) shortcoming which will be addresed on when\n * someone complains about it, as the fix would involve added complexity and\n * may not be worth the costs for this edge case.\n *\n * If {@link LRUCache.OptionsBase.fetchMethod} is not specified, then this is\n * effectively an alias for `Promise.resolve(cache.get(key))`.\n *\n * When the fetch method resolves to a value, if the fetch has not\n * been aborted due to deletion, eviction, or being overwritten,\n * then it is added to the cache using the options provided.\n *\n * If the key is evicted or deleted before the `fetchMethod`\n * resolves, then the AbortSignal passed to the `fetchMethod` will\n * receive an `abort` event, and the promise returned by `fetch()`\n * will reject with the reason for the abort.\n *\n * If a `signal` is passed to the `fetch()` call, then aborting the\n * signal will abort the fetch and cause the `fetch()` promise to\n * reject with the reason provided.\n *\n * **Setting `context`**\n *\n * If an `FC` type is set to a type other than `unknown`, `void`, or\n * `undefined` in the {@link LRUCache} constructor, then all\n * calls to `cache.fetch()` _must_ provide a `context` option. If\n * set to `undefined` or `void`, then calls to fetch _must not_\n * provide a `context` option.\n *\n * The `context` param allows you to provide arbitrary data that\n * might be relevant in the course of fetching the data. It is only\n * relevant for the course of a single `fetch()` operation, and\n * discarded afterwards.\n *\n * **Note: `fetch()` calls are inflight-unique**\n *\n * If you call `fetch()` multiple times with the same key value,\n * then every call after the first will resolve on the same\n * promise<sup>1</sup>,\n * _even if they have different settings that would otherwise change\n * the behavior of the fetch_, such as `noDeleteOnFetchRejection`\n * or `ignoreFetchAbort`.\n *\n * In most cases, this is not a problem (in fact, only fetching\n * something once is what you probably want, if you're caching in\n * the first place). If you are changing the fetch() options\n * dramatically between runs, there's a good chance that you might\n * be trying to fit divergent semantics into a single object, and\n * would be better off with multiple cache instances.\n *\n * **1**: Ie, they're not the \"same Promise\", but they resolve at\n * the same time, because they're both waiting on the same\n * underlying fetchMethod response.\n */\n\n fetch(\n k: K,\n fetchOptions: unknown extends FC\n ? LRUCache.FetchOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.FetchOptionsNoContext<K, V>\n : LRUCache.FetchOptionsWithContext<K, V, FC>\n ): Promise<undefined | V>\n\n // this overload not allowed if context is required\n fetch(\n k: unknown extends FC\n ? K\n : FC extends undefined | void\n ? K\n : never,\n fetchOptions?: unknown extends FC\n ? LRUCache.FetchOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.FetchOptionsNoContext<K, V>\n : never\n ): Promise<undefined | V>\n\n async fetch(\n k: K,\n fetchOptions: LRUCache.FetchOptions<K, V, FC> = {}\n ): Promise<undefined | V> {\n const {\n // get options\n allowStale = this.allowStale,\n updateAgeOnGet = this.updateAgeOnGet,\n noDeleteOnStaleGet = this.noDeleteOnStaleGet,\n // set options\n ttl = this.ttl,\n noDisposeOnSet = this.noDisposeOnSet,\n size = 0,\n sizeCalculation = this.sizeCalculation,\n noUpdateTTL = this.noUpdateTTL,\n // fetch exclusive options\n noDeleteOnFetchRejection = this.noDeleteOnFetchRejection,\n allowStaleOnFetchRejection = this.allowStaleOnFetchRejection,\n ignoreFetchAbort = this.ignoreFetchAbort,\n allowStaleOnFetchAbort = this.allowStaleOnFetchAbort,\n context,\n forceRefresh = false,\n status,\n signal,\n } = fetchOptions\n\n if (!this.#hasFetchMethod) {\n if (status) status.fetch = 'get'\n return this.get(k, {\n allowStale,\n updateAgeOnGet,\n noDeleteOnStaleGet,\n status,\n })\n }\n\n const options = {\n allowStale,\n updateAgeOnGet,\n noDeleteOnStaleGet,\n ttl,\n noDisposeOnSet,\n size,\n sizeCalculation,\n noUpdateTTL,\n noDeleteOnFetchRejection,\n allowStaleOnFetchRejection,\n allowStaleOnFetchAbort,\n ignoreFetchAbort,\n status,\n signal,\n }\n\n let index = this.#keyMap.get(k)\n if (index === undefined) {\n if (status) status.fetch = 'miss'\n const p = this.#backgroundFetch(k, index, options, context)\n return (p.__returned = p)\n } else {\n // in cache, maybe already fetching\n const v = this.#valList[index]\n if (this.#isBackgroundFetch(v)) {\n const stale =\n allowStale && v.__staleWhileFetching !== undefined\n if (status) {\n status.fetch = 'inflight'\n if (stale) status.returnedStale = true\n }\n return stale ? v.__staleWhileFetching : (v.__returned = v)\n }\n\n // if we force a refresh, that means do NOT serve the cached value,\n // unless we are already in the process of refreshing the cache.\n const isStale = this.#isStale(index)\n if (!forceRefresh && !isStale) {\n if (status) status.fetch = 'hit'\n this.#moveToTail(index)\n if (updateAgeOnGet) {\n this.#updateItemAge(index)\n }\n if (status) this.#statusTTL(status, index)\n return v\n }\n\n // ok, it is stale or a forced refresh, and not already fetching.\n // refresh the cache.\n const p = this.#backgroundFetch(k, index, options, context)\n const hasStale = p.__staleWhileFetching !== undefined\n const staleVal = hasStale && allowStale\n if (status) {\n status.fetch = isStale ? 'stale' : 'refresh'\n if (staleVal && isStale) status.returnedStale = true\n }\n return staleVal ? p.__staleWhileFetching : (p.__returned = p)\n }\n }\n\n /**\n * In some cases, `cache.fetch()` may resolve to `undefined`, either because\n * a {@link LRUCache.OptionsBase#fetchMethod} was not provided (turning\n * `cache.fetch(k)` into just an async wrapper around `cache.get(k)`) or\n * because `ignoreFetchAbort` was specified (either to the constructor or\n * in the {@link LRUCache.FetchOptions}). Also, the\n * {@link OptionsBase.fetchMethod} may return `undefined` or `void`, making\n * the test even more complicated.\n *\n * Because inferring the cases where `undefined` might be returned are so\n * cumbersome, but testing for `undefined` can also be annoying, this method\n * can be used, which will reject if `this.fetch()` resolves to undefined.\n */\n forceFetch(\n k: K,\n fetchOptions: unknown extends FC\n ? LRUCache.FetchOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.FetchOptionsNoContext<K, V>\n : LRUCache.FetchOptionsWithContext<K, V, FC>\n ): Promise<V>\n // this overload not allowed if context is required\n forceFetch(\n k: unknown extends FC\n ? K\n : FC extends undefined | void\n ? K\n : never,\n fetchOptions?: unknown extends FC\n ? LRUCache.FetchOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.FetchOptionsNoContext<K, V>\n : never\n ): Promise<V>\n async forceFetch(\n k: K,\n fetchOptions: LRUCache.FetchOptions<K, V, FC> = {}\n ): Promise<V> {\n const v = await this.fetch(\n k,\n fetchOptions as unknown extends FC\n ? LRUCache.FetchOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.FetchOptionsNoContext<K, V>\n : LRUCache.FetchOptionsWithContext<K, V, FC>\n )\n if (v === undefined) throw new Error('fetch() returned undefined')\n return v\n }\n\n /**\n * If the key is found in the cache, then this is equivalent to\n * {@link LRUCache#get}. If not, in the cache, then calculate the value using\n * the {@link LRUCache.OptionsBase.memoMethod}, and add it to the cache.\n *\n * If an `FC` type is set to a type other than `unknown`, `void`, or\n * `undefined` in the LRUCache constructor, then all calls to `cache.memo()`\n * _must_ provide a `context` option. If set to `undefined` or `void`, then\n * calls to memo _must not_ provide a `context` option.\n *\n * The `context` param allows you to provide arbitrary data that might be\n * relevant in the course of fetching the data. It is only relevant for the\n * course of a single `memo()` operation, and discarded afterwards.\n */\n memo(\n k: K,\n memoOptions: unknown extends FC\n ? LRUCache.MemoOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.MemoOptionsNoContext<K, V>\n : LRUCache.MemoOptionsWithContext<K, V, FC>\n ): V\n // this overload not allowed if context is required\n memo(\n k: unknown extends FC\n ? K\n : FC extends undefined | void\n ? K\n : never,\n memoOptions?: unknown extends FC\n ? LRUCache.MemoOptions<K, V, FC>\n : FC extends undefined | void\n ? LRUCache.MemoOptionsNoContext<K, V>\n : never\n ): V\n memo(k: K, memoOptions: LRUCache.MemoOptions<K, V, FC> = {}) {\n const memoMethod = this.#memoMethod\n if (!memoMethod) {\n throw new Error('no memoMethod provided to constructor')\n }\n const { context, forceRefresh, ...options } = memoOptions\n const v = this.get(k, options)\n if (!forceRefresh && v !== undefined) return v\n const vv = memoMethod(k, v, {\n options,\n context,\n } as LRUCache.MemoizerOptions<K, V, FC>)\n this.set(k, vv, options)\n return vv\n }\n\n /**\n * Return a value from the cache. Will update the recency of the cache\n * entry found.\n *\n * If the key is not found, get() will return `undefined`.\n */\n get(k: K, getOptions: LRUCache.GetOptions<K, V, FC> = {}) {\n const {\n allowStale = this.allowStale,\n updateAgeOnGet = this.updateAgeOnGet,\n noDeleteOnStaleGet = this.noDeleteOnStaleGet,\n status,\n } = getOptions\n const index = this.#keyMap.get(k)\n if (index !== undefined) {\n const value = this.#valList[index]\n const fetching = this.#isBackgroundFetch(value)\n if (status) this.#statusTTL(status, index)\n if (this.#isStale(index)) {\n if (status) status.get = 'stale'\n // delete only if not an in-flight background fetch\n if (!fetching) {\n if (!noDeleteOnStaleGet) {\n this.#delete(k, 'expire')\n }\n if (status && allowStale) status.returnedStale = true\n return allowStale ? value : undefined\n } else {\n if (\n status &&\n allowStale &&\n value.__staleWhileFetching !== undefined\n ) {\n status.returnedStale = true\n }\n return allowStale ? value.__staleWhileFetching : undefined\n }\n } else {\n if (status) status.get = 'hit'\n // if we're currently fetching it, we don't actually have it yet\n // it's not stale, which means this isn't a staleWhileRefetching.\n // If it's not stale, and fetching, AND has a __staleWhileFetching\n // value, then that means the user fetched with {forceRefresh:true},\n // so it's safe to return that value.\n if (fetching) {\n return value.__staleWhileFetching\n }\n this.#moveToTail(index)\n if (updateAgeOnGet) {\n this.#updateItemAge(index)\n }\n return value\n }\n } else if (status) {\n status.get = 'miss'\n }\n }\n\n #connect(p: Index, n: Index) {\n this.#prev[n] = p\n this.#next[p] = n\n }\n\n #moveToTail(index: Index): void {\n // if tail already, nothing to do\n // if head, move head to next[index]\n // else\n // move next[prev[index]] to next[index] (head has no prev)\n // move prev[next[index]] to prev[index]\n // prev[index] = tail\n // next[tail] = index\n // tail = index\n if (index !== this.#tail) {\n if (index === this.#head) {\n this.#head = this.#next[index] as Index\n } else {\n this.#connect(\n this.#prev[index] as Index,\n this.#next[index] as Index\n )\n }\n this.#connect(this.#tail, index)\n this.#tail = index\n }\n }\n\n /**\n * Deletes a key out of the cache.\n *\n * Returns true if the key was deleted, false otherwise.\n */\n delete(k: K) {\n return this.#delete(k, 'delete')\n }\n\n #delete(k: K, reason: LRUCache.DisposeReason) {\n let deleted = false\n if (this.#size !== 0) {\n const index = this.#keyMap.get(k)\n if (index !== undefined) {\n deleted = true\n if (this.#size === 1) {\n this.#clear(reason)\n } else {\n this.#removeItemSize(index)\n const v = this.#valList[index]\n if (this.#isBackgroundFetch(v)) {\n v.__abortController.abort(new Error('deleted'))\n } else if (this.#hasDispose || this.#hasDisposeAfter) {\n if (this.#hasDispose) {\n this.#dispose?.(v as V, k, reason)\n }\n if (this.#hasDisposeAfter) {\n this.#disposed?.push([v as V, k, reason])\n }\n }\n this.#keyMap.delete(k)\n this.#keyList[index] = undefined\n this.#valList[index] = undefined\n if (index === this.#tail) {\n this.#tail = this.#prev[index] as Index\n } else if (index === this.#head) {\n this.#head = this.#next[index] as Index\n } else {\n const pi = this.#prev[index] as number\n this.#next[pi] = this.#next[index] as number\n const ni = this.#next[index] as number\n this.#prev[ni] = this.#prev[index] as number\n }\n this.#size--\n this.#free.push(index)\n }\n }\n }\n if (this.#hasDisposeAfter && this.#disposed?.length) {\n const dt = this.#disposed\n let task: DisposeTask<K, V> | undefined\n while ((task = dt?.shift())) {\n this.#disposeAfter?.(...task)\n }\n }\n return deleted\n }\n\n /**\n * Clear the cache entirely, throwing away all values.\n */\n clear() {\n return this.#clear('delete')\n }\n #clear(reason: LRUCache.DisposeReason) {\n for (const index of this.#rindexes({ allowStale: true })) {\n const v = this.#valList[index]\n if (this.#isBackgroundFetch(v)) {\n v.__abortController.abort(new Error('deleted'))\n } else {\n const k = this.#keyList[index]\n if (this.#hasDispose) {\n this.#dispose?.(v as V, k as K, reason)\n }\n if (this.#hasDisposeAfter) {\n this.#disposed?.push([v as V, k as K, reason])\n }\n }\n }\n\n this.#keyMap.clear()\n this.#valList.fill(undefined)\n this.#keyList.fill(undefined)\n if (this.#ttls && this.#starts) {\n this.#ttls.fill(0)\n this.#starts.fill(0)\n }\n if (this.#sizes) {\n this.#sizes.fill(0)\n }\n this.#head = 0 as Index\n this.#tail = 0 as Index\n this.#free.length = 0\n this.#calculatedSize = 0\n this.#size = 0\n if (this.#hasDisposeAfter && this.#disposed) {\n const dt = this.#disposed\n let task: DisposeTask<K, V> | undefined\n while ((task = dt?.shift())) {\n this.#disposeAfter?.(...task)\n }\n }\n }\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar ContainerIterator = /** @class */ (function () {\n /**\n * @internal\n */\n function ContainerIterator(iteratorType) {\n if (iteratorType === void 0) { iteratorType = 0 /* IteratorType.NORMAL */; }\n this.iteratorType = iteratorType;\n }\n /**\n * @param iter - The other iterator you want to compare.\n * @returns Whether this equals to obj.\n * @example\n * container.find(1).equals(container.end());\n */\n ContainerIterator.prototype.equals = function (iter) {\n return this._node === iter._node;\n };\n return ContainerIterator;\n}());\nexport { ContainerIterator };\nvar Base = /** @class */ (function () {\n function Base() {\n /**\n * @description Container's size.\n * @internal\n */\n this._length = 0;\n }\n Object.defineProperty(Base.prototype, \"length\", {\n /**\n * @returns The size of the container.\n * @example\n * const container = new Vector([1, 2]);\n * console.log(container.length); // 2\n */\n get: function () {\n return this._length;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * @returns The size of the container.\n * @example\n * const container = new Vector([1, 2]);\n * console.log(container.size()); // 2\n */\n Base.prototype.size = function () {\n return this._length;\n };\n /**\n * @returns Whether the container is empty.\n * @example\n * container.clear();\n * console.log(container.empty()); // true\n */\n Base.prototype.empty = function () {\n return this._length === 0;\n };\n return Base;\n}());\nexport { Base };\nvar Container = /** @class */ (function (_super) {\n __extends(Container, _super);\n function Container() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n return Container;\n}(Base));\nexport { Container };\n","/**\n * @description The iterator type including `NORMAL` and `REVERSE`.\n */\nexport const enum IteratorType {\n NORMAL = 0,\n REVERSE = 1\n}\n\nexport abstract class ContainerIterator<T> {\n /**\n * @description The container pointed to by the iterator.\n */\n abstract readonly container: Container<T>;\n /**\n * @internal\n */\n abstract _node: unknown;\n /**\n * @description Iterator's type.\n * @example\n * console.log(container.end().iteratorType === IteratorType.NORMAL); // true\n */\n readonly iteratorType: IteratorType;\n /**\n * @internal\n */\n protected constructor(iteratorType = IteratorType.NORMAL) {\n this.iteratorType = iteratorType;\n }\n /**\n * @param iter - The other iterator you want to compare.\n * @returns Whether this equals to obj.\n * @example\n * container.find(1).equals(container.end());\n */\n equals(iter: ContainerIterator<T>) {\n return this._node === iter._node;\n }\n /**\n * @description Pointers to element.\n * @returns The value of the pointer's element.\n * @example\n * const val = container.begin().pointer;\n */\n abstract get pointer(): T;\n /**\n * @description Set pointer's value (some containers are unavailable).\n * @param newValue - The new value you want to set.\n * @example\n * (<LinkList<number>>container).begin().pointer = 1;\n */\n abstract set pointer(newValue: T);\n /**\n * @description Move `this` iterator to pre.\n * @returns The iterator's self.\n * @example\n * const iter = container.find(1); // container = [0, 1]\n * const pre = iter.pre();\n * console.log(pre === iter); // true\n * console.log(pre.equals(iter)); // true\n * console.log(pre.pointer, iter.pointer); // 0, 0\n */\n abstract pre(): this;\n /**\n * @description Move `this` iterator to next.\n * @returns The iterator's self.\n * @example\n * const iter = container.find(1); // container = [1, 2]\n * const next = iter.next();\n * console.log(next === iter); // true\n * console.log(next.equals(iter)); // true\n * console.log(next.pointer, iter.pointer); // 2, 2\n */\n abstract next(): this;\n /**\n * @description Get a copy of itself.\n * @returns The copy of self.\n * @example\n * const iter = container.find(1); // container = [1, 2]\n * const next = iter.copy().next();\n * console.log(next === iter); // false\n * console.log(next.equals(iter)); // false\n * console.log(next.pointer, iter.pointer); // 2, 1\n */\n abstract copy(): ContainerIterator<T>;\n}\n\nexport abstract class Base {\n /**\n * @description Container's size.\n * @internal\n */\n protected _length = 0;\n /**\n * @returns The size of the container.\n * @example\n * const container = new Vector([1, 2]);\n * console.log(container.length); // 2\n */\n get length() {\n return this._length;\n }\n /**\n * @returns The size of the container.\n * @example\n * const container = new Vector([1, 2]);\n * console.log(container.size()); // 2\n */\n size() {\n return this._length;\n }\n /**\n * @returns Whether the container is empty.\n * @example\n * container.clear();\n * console.log(container.empty()); // true\n */\n empty() {\n return this._length === 0;\n }\n /**\n * @description Clear the container.\n * @example\n * container.clear();\n * console.log(container.empty()); // true\n */\n abstract clear(): void;\n}\n\nexport abstract class Container<T> extends Base {\n /**\n * @returns Iterator pointing to the beginning element.\n * @example\n * const begin = container.begin();\n * const end = container.end();\n * for (const it = begin; !it.equals(end); it.next()) {\n * doSomething(it.pointer);\n * }\n */\n abstract begin(): ContainerIterator<T>;\n /**\n * @returns Iterator pointing to the super end like c++.\n * @example\n * const begin = container.begin();\n * const end = container.end();\n * for (const it = begin; !it.equals(end); it.next()) {\n * doSomething(it.pointer);\n * }\n */\n abstract end(): ContainerIterator<T>;\n /**\n * @returns Iterator pointing to the end element.\n * @example\n * const rBegin = container.rBegin();\n * const rEnd = container.rEnd();\n * for (const it = rBegin; !it.equals(rEnd); it.next()) {\n * doSomething(it.pointer);\n * }\n */\n abstract rBegin(): ContainerIterator<T>;\n /**\n * @returns Iterator pointing to the super begin like c++.\n * @example\n * const rBegin = container.rBegin();\n * const rEnd = container.rEnd();\n * for (const it = rBegin; !it.equals(rEnd); it.next()) {\n * doSomething(it.pointer);\n * }\n */\n abstract rEnd(): ContainerIterator<T>;\n /**\n * @returns The first element of the container.\n */\n abstract front(): T | undefined;\n /**\n * @returns The last element of the container.\n */\n abstract back(): T | undefined;\n /**\n * @param element - The element you want to find.\n * @returns An iterator pointing to the element if found, or super end if not found.\n * @example\n * container.find(1).equals(container.end());\n */\n abstract find(element: T): ContainerIterator<T>;\n /**\n * @description Iterate over all elements in the container.\n * @param callback - Callback function like Array.forEach.\n * @example\n * container.forEach((element, index) => console.log(element, index));\n */\n abstract forEach(callback: (element: T, index: number, container: Container<T>) => void): void;\n /**\n * @description Gets the value of the element at the specified position.\n * @example\n * const val = container.getElementByPos(-1); // throw a RangeError\n */\n abstract getElementByPos(pos: number): T;\n /**\n * @description Removes the element at the specified position.\n * @param pos - The element's position you want to remove.\n * @returns The container length after erasing.\n * @example\n * container.eraseElementByPos(-1); // throw a RangeError\n */\n abstract eraseElementByPos(pos: number): number;\n /**\n * @description Removes element by iterator and move `iter` to next.\n * @param iter - The iterator you want to erase.\n * @returns The next iterator.\n * @example\n * container.eraseElementByIterator(container.begin());\n * container.eraseElementByIterator(container.end()); // throw a RangeError\n */\n abstract eraseElementByIterator(\n iter: ContainerIterator<T>\n ): ContainerIterator<T>;\n /**\n * @description Using for `for...of` syntax like Array.\n * @example\n * for (const element of container) {\n * console.log(element);\n * }\n */\n abstract [Symbol.iterator](): Generator<T, void>;\n}\n\n/**\n * @description The initial data type passed in when initializing the container.\n */\nexport type initContainer<T> = {\n size?: number | (() => number);\n length?: number;\n forEach: (callback: (el: T) => void) => void;\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Base } from \"../ContainerBase\";\nvar Stack = /** @class */ (function (_super) {\n __extends(Stack, _super);\n function Stack(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n /**\n * @internal\n */\n _this._stack = [];\n var self = _this;\n container.forEach(function (el) {\n self.push(el);\n });\n return _this;\n }\n Stack.prototype.clear = function () {\n this._length = 0;\n this._stack = [];\n };\n /**\n * @description Insert element to stack's end.\n * @description The element you want to push to the back.\n * @returns The container length after erasing.\n */\n Stack.prototype.push = function (element) {\n this._stack.push(element);\n this._length += 1;\n return this._length;\n };\n /**\n * @description Removes the end element.\n * @returns The element you popped.\n */\n Stack.prototype.pop = function () {\n if (this._length === 0)\n return;\n this._length -= 1;\n return this._stack.pop();\n };\n /**\n * @description Accesses the end element.\n * @returns The last element.\n */\n Stack.prototype.top = function () {\n return this._stack[this._length - 1];\n };\n return Stack;\n}(Base));\nexport default Stack;\n","import { Base, initContainer } from '@/container/ContainerBase';\n\nclass Stack<T> extends Base {\n /**\n * @internal\n */\n private _stack: T[] = [];\n constructor(container: initContainer<T> = []) {\n super();\n const self = this;\n container.forEach(function (el) {\n self.push(el);\n });\n }\n clear() {\n this._length = 0;\n this._stack = [];\n }\n /**\n * @description Insert element to stack's end.\n * @description The element you want to push to the back.\n * @returns The container length after erasing.\n */\n push(element: T) {\n this._stack.push(element);\n this._length += 1;\n return this._length;\n }\n /**\n * @description Removes the end element.\n * @returns The element you popped.\n */\n pop() {\n if (this._length === 0) return;\n this._length -= 1;\n return this._stack.pop();\n }\n /**\n * @description Accesses the end element.\n * @returns The last element.\n */\n top(): T | undefined {\n return this._stack[this._length - 1];\n }\n}\n\nexport default Stack;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Base } from \"../ContainerBase\";\nvar Queue = /** @class */ (function (_super) {\n __extends(Queue, _super);\n function Queue(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n /**\n * @internal\n */\n _this._first = 0;\n /**\n * @internal\n */\n _this._queue = [];\n var self = _this;\n container.forEach(function (el) {\n self.push(el);\n });\n return _this;\n }\n Queue.prototype.clear = function () {\n this._queue = [];\n this._length = this._first = 0;\n };\n /**\n * @description Inserts element to queue's end.\n * @param element - The element you want to push to the front.\n * @returns The container length after pushing.\n */\n Queue.prototype.push = function (element) {\n var capacity = this._queue.length;\n if ((this._first / capacity) > 0.5 /* QUEUE_CONSTANT.ALLOCATE_SIGMA */ &&\n (this._first + this._length) >= capacity &&\n capacity > 4096 /* QUEUE_CONSTANT.MIN_ALLOCATE_SIZE */) {\n var length_1 = this._length;\n for (var i = 0; i < length_1; ++i) {\n this._queue[i] = this._queue[this._first + i];\n }\n this._first = 0;\n this._queue[this._length] = element;\n }\n else\n this._queue[this._first + this._length] = element;\n return ++this._length;\n };\n /**\n * @description Removes the first element.\n * @returns The element you popped.\n */\n Queue.prototype.pop = function () {\n if (this._length === 0)\n return;\n var el = this._queue[this._first++];\n this._length -= 1;\n return el;\n };\n /**\n * @description Access the first element.\n * @returns The first element.\n */\n Queue.prototype.front = function () {\n if (this._length === 0)\n return;\n return this._queue[this._first];\n };\n return Queue;\n}(Base));\nexport default Queue;\n","import { Base, initContainer } from '@/container/ContainerBase';\n\nconst enum QUEUE_CONSTANT {\n ALLOCATE_SIGMA = 0.5,\n MIN_ALLOCATE_SIZE = (1 << 12)\n}\n\nclass Queue<T> extends Base {\n /**\n * @internal\n */\n private _first = 0;\n /**\n * @internal\n */\n private _queue: T[] = [];\n constructor(container: initContainer<T> = []) {\n super();\n const self = this;\n container.forEach(function (el) {\n self.push(el);\n });\n }\n clear() {\n this._queue = [];\n this._length = this._first = 0;\n }\n /**\n * @description Inserts element to queue's end.\n * @param element - The element you want to push to the front.\n * @returns The container length after pushing.\n */\n push(element: T) {\n const capacity = this._queue.length;\n if (\n (this._first / capacity) > QUEUE_CONSTANT.ALLOCATE_SIGMA &&\n (this._first + this._length) >= capacity &&\n capacity > QUEUE_CONSTANT.MIN_ALLOCATE_SIZE\n ) {\n const length = this._length;\n for (let i = 0; i < length; ++i) {\n this._queue[i] = this._queue[this._first + i];\n }\n this._first = 0;\n this._queue[this._length] = element;\n } else this._queue[this._first + this._length] = element;\n return ++this._length;\n }\n /**\n * @description Removes the first element.\n * @returns The element you popped.\n */\n pop() {\n if (this._length === 0) return;\n const el = this._queue[this._first++];\n this._length -= 1;\n return el;\n }\n /**\n * @description Access the first element.\n * @returns The first element.\n */\n front(): T | undefined {\n if (this._length === 0) return;\n return this._queue[this._first];\n }\n}\n\nexport default Queue;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nimport { Base } from \"../ContainerBase\";\nvar PriorityQueue = /** @class */ (function (_super) {\n __extends(PriorityQueue, _super);\n /**\n * @description PriorityQueue's constructor.\n * @param container - Initialize container, must have a forEach function.\n * @param cmp - Compare function.\n * @param copy - When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n * @example\n * new PriorityQueue();\n * new PriorityQueue([1, 2, 3]);\n * new PriorityQueue([1, 2, 3], (x, y) => x - y);\n * new PriorityQueue([1, 2, 3], (x, y) => x - y, false);\n */\n function PriorityQueue(container, cmp, copy) {\n if (container === void 0) { container = []; }\n if (cmp === void 0) { cmp = function (x, y) {\n if (x > y)\n return -1;\n if (x < y)\n return 1;\n return 0;\n }; }\n if (copy === void 0) { copy = true; }\n var _this = _super.call(this) || this;\n _this._cmp = cmp;\n if (Array.isArray(container)) {\n _this._priorityQueue = copy ? __spreadArray([], __read(container), false) : container;\n }\n else {\n _this._priorityQueue = [];\n var self_1 = _this;\n container.forEach(function (el) {\n self_1._priorityQueue.push(el);\n });\n }\n _this._length = _this._priorityQueue.length;\n var halfLength = _this._length >> 1;\n for (var parent_1 = (_this._length - 1) >> 1; parent_1 >= 0; --parent_1) {\n _this._pushDown(parent_1, halfLength);\n }\n return _this;\n }\n /**\n * @internal\n */\n PriorityQueue.prototype._pushUp = function (pos) {\n var item = this._priorityQueue[pos];\n while (pos > 0) {\n var parent_2 = (pos - 1) >> 1;\n var parentItem = this._priorityQueue[parent_2];\n if (this._cmp(parentItem, item) <= 0)\n break;\n this._priorityQueue[pos] = parentItem;\n pos = parent_2;\n }\n this._priorityQueue[pos] = item;\n };\n /**\n * @internal\n */\n PriorityQueue.prototype._pushDown = function (pos, halfLength) {\n var item = this._priorityQueue[pos];\n while (pos < halfLength) {\n var left = pos << 1 | 1;\n var right = left + 1;\n var minItem = this._priorityQueue[left];\n if (right < this._length &&\n this._cmp(minItem, this._priorityQueue[right]) > 0) {\n left = right;\n minItem = this._priorityQueue[right];\n }\n if (this._cmp(minItem, item) >= 0)\n break;\n this._priorityQueue[pos] = minItem;\n pos = left;\n }\n this._priorityQueue[pos] = item;\n };\n PriorityQueue.prototype.clear = function () {\n this._length = 0;\n this._priorityQueue.length = 0;\n };\n /**\n * @description Push element into a container in order.\n * @param item - The element you want to push.\n * @returns The size of heap after pushing.\n * @example\n * queue.push(1);\n */\n PriorityQueue.prototype.push = function (item) {\n this._priorityQueue.push(item);\n this._pushUp(this._length);\n this._length += 1;\n };\n /**\n * @description Removes the top element.\n * @returns The element you popped.\n * @example\n * queue.pop();\n */\n PriorityQueue.prototype.pop = function () {\n if (this._length === 0)\n return;\n var value = this._priorityQueue[0];\n var last = this._priorityQueue.pop();\n this._length -= 1;\n if (this._length) {\n this._priorityQueue[0] = last;\n this._pushDown(0, this._length >> 1);\n }\n return value;\n };\n /**\n * @description Accesses the top element.\n * @example\n * const top = queue.top();\n */\n PriorityQueue.prototype.top = function () {\n return this._priorityQueue[0];\n };\n /**\n * @description Check if element is in heap.\n * @param item - The item want to find.\n * @returns Whether element is in heap.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * console.log(que.find(obj)); // true\n */\n PriorityQueue.prototype.find = function (item) {\n return this._priorityQueue.indexOf(item) >= 0;\n };\n /**\n * @description Remove specified item from heap.\n * @param item - The item want to remove.\n * @returns Whether remove success.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * que.remove(obj);\n */\n PriorityQueue.prototype.remove = function (item) {\n var index = this._priorityQueue.indexOf(item);\n if (index < 0)\n return false;\n if (index === 0) {\n this.pop();\n }\n else if (index === this._length - 1) {\n this._priorityQueue.pop();\n this._length -= 1;\n }\n else {\n this._priorityQueue.splice(index, 1, this._priorityQueue.pop());\n this._length -= 1;\n this._pushUp(index);\n this._pushDown(index, this._length >> 1);\n }\n return true;\n };\n /**\n * @description Update item and it's pos in the heap.\n * @param item - The item want to update.\n * @returns Whether update success.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * obj.id = 2;\n * que.updateItem(obj);\n */\n PriorityQueue.prototype.updateItem = function (item) {\n var index = this._priorityQueue.indexOf(item);\n if (index < 0)\n return false;\n this._pushUp(index);\n this._pushDown(index, this._length >> 1);\n return true;\n };\n /**\n * @returns Return a copy array of heap.\n * @example\n * const arr = queue.toArray();\n */\n PriorityQueue.prototype.toArray = function () {\n return __spreadArray([], __read(this._priorityQueue), false);\n };\n return PriorityQueue;\n}(Base));\nexport default PriorityQueue;\n","import { Base, initContainer } from '@/container/ContainerBase';\n\nclass PriorityQueue<T> extends Base {\n /**\n * @internal\n */\n private readonly _priorityQueue: T[];\n /**\n * @internal\n */\n private readonly _cmp: (x: T, y: T) => number;\n /**\n * @description PriorityQueue's constructor.\n * @param container - Initialize container, must have a forEach function.\n * @param cmp - Compare function.\n * @param copy - When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n * @example\n * new PriorityQueue();\n * new PriorityQueue([1, 2, 3]);\n * new PriorityQueue([1, 2, 3], (x, y) => x - y);\n * new PriorityQueue([1, 2, 3], (x, y) => x - y, false);\n */\n constructor(\n container: initContainer<T> = [],\n cmp: (x: T, y: T) => number =\n function (x: T, y: T) {\n if (x > y) return -1;\n if (x < y) return 1;\n return 0;\n },\n copy = true\n ) {\n super();\n this._cmp = cmp;\n if (Array.isArray(container)) {\n this._priorityQueue = copy ? [...container] : container;\n } else {\n this._priorityQueue = [];\n const self = this;\n container.forEach(function (el) {\n self._priorityQueue.push(el);\n });\n }\n this._length = this._priorityQueue.length;\n const halfLength = this._length >> 1;\n for (let parent = (this._length - 1) >> 1; parent >= 0; --parent) {\n this._pushDown(parent, halfLength);\n }\n }\n /**\n * @internal\n */\n private _pushUp(pos: number) {\n const item = this._priorityQueue[pos];\n while (pos > 0) {\n const parent = (pos - 1) >> 1;\n const parentItem = this._priorityQueue[parent];\n if (this._cmp(parentItem, item) <= 0) break;\n this._priorityQueue[pos] = parentItem;\n pos = parent;\n }\n this._priorityQueue[pos] = item;\n }\n /**\n * @internal\n */\n private _pushDown(pos: number, halfLength: number) {\n const item = this._priorityQueue[pos];\n while (pos < halfLength) {\n let left = pos << 1 | 1;\n const right = left + 1;\n let minItem = this._priorityQueue[left];\n if (\n right < this._length &&\n this._cmp(minItem, this._priorityQueue[right]) > 0\n ) {\n left = right;\n minItem = this._priorityQueue[right];\n }\n if (this._cmp(minItem, item) >= 0) break;\n this._priorityQueue[pos] = minItem;\n pos = left;\n }\n this._priorityQueue[pos] = item;\n }\n clear() {\n this._length = 0;\n this._priorityQueue.length = 0;\n }\n /**\n * @description Push element into a container in order.\n * @param item - The element you want to push.\n * @returns The size of heap after pushing.\n * @example\n * queue.push(1);\n */\n push(item: T) {\n this._priorityQueue.push(item);\n this._pushUp(this._length);\n this._length += 1;\n }\n /**\n * @description Removes the top element.\n * @returns The element you popped.\n * @example\n * queue.pop();\n */\n pop() {\n if (this._length === 0) return;\n const value = this._priorityQueue[0];\n const last = this._priorityQueue.pop()!;\n this._length -= 1;\n if (this._length) {\n this._priorityQueue[0] = last;\n this._pushDown(0, this._length >> 1);\n }\n return value;\n }\n /**\n * @description Accesses the top element.\n * @example\n * const top = queue.top();\n */\n top(): T | undefined {\n return this._priorityQueue[0];\n }\n /**\n * @description Check if element is in heap.\n * @param item - The item want to find.\n * @returns Whether element is in heap.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * console.log(que.find(obj)); // true\n */\n find(item: T) {\n return this._priorityQueue.indexOf(item) >= 0;\n }\n /**\n * @description Remove specified item from heap.\n * @param item - The item want to remove.\n * @returns Whether remove success.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * que.remove(obj);\n */\n remove(item: T) {\n const index = this._priorityQueue.indexOf(item);\n if (index < 0) return false;\n if (index === 0) {\n this.pop();\n } else if (index === this._length - 1) {\n this._priorityQueue.pop();\n this._length -= 1;\n } else {\n this._priorityQueue.splice(index, 1, this._priorityQueue.pop()!);\n this._length -= 1;\n this._pushUp(index);\n this._pushDown(index, this._length >> 1);\n }\n return true;\n }\n /**\n * @description Update item and it's pos in the heap.\n * @param item - The item want to update.\n * @returns Whether update success.\n * @example\n * const que = new PriorityQueue([], (x, y) => x.id - y.id);\n * const obj = { id: 1 };\n * que.push(obj);\n * obj.id = 2;\n * que.updateItem(obj);\n */\n updateItem(item: T) {\n const index = this._priorityQueue.indexOf(item);\n if (index < 0) return false;\n this._pushUp(index);\n this._pushDown(index, this._length >> 1);\n return true;\n }\n /**\n * @returns Return a copy array of heap.\n * @example\n * const arr = queue.toArray();\n */\n toArray() {\n return [...this._priorityQueue];\n }\n}\n\nexport default PriorityQueue;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Container } from \"../../ContainerBase\";\nvar SequentialContainer = /** @class */ (function (_super) {\n __extends(SequentialContainer, _super);\n function SequentialContainer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n return SequentialContainer;\n}(Container));\nexport default SequentialContainer;\n","import { Container } from '@/container/ContainerBase';\n\nabstract class SequentialContainer<T> extends Container<T> {\n /**\n * @description Push the element to the back.\n * @param element - The element you want to push.\n * @returns The size of container after pushing.\n */\n abstract pushBack(element: T): number;\n /**\n * @description Removes the last element.\n * @returns The element you popped.\n */\n abstract popBack(): T | undefined;\n /**\n * @description Sets element by position.\n * @param pos - The position you want to change.\n * @param element - The element's value you want to update.\n * @example\n * container.setElementByPos(-1, 1); // throw a RangeError\n */\n abstract setElementByPos(pos: number, element: T): void;\n /**\n * @description Removes the elements of the specified value.\n * @param value - The value you want to remove.\n * @returns The size of container after erasing.\n * @example\n * container.eraseElementByValue(-1);\n */\n abstract eraseElementByValue(value: T): number;\n /**\n * @description Insert several elements after the specified position.\n * @param pos - The position you want to insert.\n * @param element - The element you want to insert.\n * @param num - The number of elements you want to insert (default 1).\n * @returns The size of container after inserting.\n * @example\n * const container = new Vector([1, 2, 3]);\n * container.insert(1, 4); // [1, 4, 2, 3]\n * container.insert(1, 5, 3); // [1, 5, 5, 5, 4, 2, 3]\n */\n abstract insert(pos: number, element: T, num?: number): number;\n /**\n * @description Reverses the container.\n * @example\n * const container = new Vector([1, 2, 3]);\n * container.reverse(); // [3, 2, 1]\n */\n abstract reverse(): void;\n /**\n * @description Removes the duplication of elements in the container.\n * @returns The size of container after inserting.\n * @example\n * const container = new Vector([1, 1, 3, 2, 2, 5, 5, 2]);\n * container.unique(); // [1, 3, 2, 5, 2]\n */\n abstract unique(): number;\n /**\n * @description Sort the container.\n * @param cmp - Comparison function to sort.\n * @example\n * const container = new Vector([3, 1, 10]);\n * container.sort(); // [1, 10, 3]\n * container.sort((x, y) => x - y); // [1, 3, 10]\n */\n abstract sort(cmp?: (x: T, y: T) => number): void;\n}\n\nexport default SequentialContainer;\n","/**\n * @description Throw an iterator access error.\n * @internal\n */\nexport function throwIteratorAccessError() {\n throw new RangeError('Iterator access denied!');\n}\n","/**\n * @description Throw an iterator access error.\n * @internal\n */\nexport function throwIteratorAccessError() {\n throw new RangeError('Iterator access denied!');\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { ContainerIterator } from \"../../ContainerBase\";\nimport { throwIteratorAccessError } from \"../../../utils/throwError\";\nvar RandomIterator = /** @class */ (function (_super) {\n __extends(RandomIterator, _super);\n /**\n * @internal\n */\n function RandomIterator(index, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this._node = index;\n if (_this.iteratorType === 0 /* IteratorType.NORMAL */) {\n _this.pre = function () {\n if (this._node === 0) {\n throwIteratorAccessError();\n }\n this._node -= 1;\n return this;\n };\n _this.next = function () {\n if (this._node === this.container.size()) {\n throwIteratorAccessError();\n }\n this._node += 1;\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this._node === this.container.size() - 1) {\n throwIteratorAccessError();\n }\n this._node += 1;\n return this;\n };\n _this.next = function () {\n if (this._node === -1) {\n throwIteratorAccessError();\n }\n this._node -= 1;\n return this;\n };\n }\n return _this;\n }\n Object.defineProperty(RandomIterator.prototype, \"pointer\", {\n get: function () {\n return this.container.getElementByPos(this._node);\n },\n set: function (newValue) {\n this.container.setElementByPos(this._node, newValue);\n },\n enumerable: false,\n configurable: true\n });\n return RandomIterator;\n}(ContainerIterator));\nexport { RandomIterator };\n","import { ContainerIterator, IteratorType } from '@/container/ContainerBase';\nimport SequentialContainer from '@/container/SequentialContainer/Base/index';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nexport abstract class RandomIterator<T> extends ContainerIterator<T> {\n abstract readonly container: SequentialContainer<T>;\n /**\n * @internal\n */\n _node: number;\n /**\n * @internal\n */\n protected constructor(\n index: number,\n iteratorType?: IteratorType\n ) {\n super(iteratorType);\n this._node = index;\n if (this.iteratorType === IteratorType.NORMAL) {\n this.pre = function () {\n if (this._node === 0) {\n throwIteratorAccessError();\n }\n this._node -= 1;\n return this;\n };\n this.next = function () {\n if (this._node === this.container.size()) {\n throwIteratorAccessError();\n }\n this._node += 1;\n return this;\n };\n } else {\n this.pre = function () {\n if (this._node === this.container.size() - 1) {\n throwIteratorAccessError();\n }\n this._node += 1;\n return this;\n };\n this.next = function () {\n if (this._node === -1) {\n throwIteratorAccessError();\n }\n this._node -= 1;\n return this;\n };\n }\n }\n get pointer() {\n return this.container.getElementByPos(this._node);\n }\n set pointer(newValue: T) {\n this.container.setElementByPos(this._node, newValue);\n }\n // @ts-ignore\n pre(): this;\n // @ts-ignore\n next(): this;\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport SequentialContainer from './Base';\nimport { RandomIterator } from \"./Base/RandomIterator\";\nimport $checkWithinAccessParams from \"../../utils/checkParams.macro\";\nvar VectorIterator = /** @class */ (function (_super) {\n __extends(VectorIterator, _super);\n function VectorIterator(node, container, iteratorType) {\n var _this = _super.call(this, node, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n VectorIterator.prototype.copy = function () {\n return new VectorIterator(this._node, this.container, this.iteratorType);\n };\n return VectorIterator;\n}(RandomIterator));\nvar Vector = /** @class */ (function (_super) {\n __extends(Vector, _super);\n /**\n * @param container - Initialize container, must have a forEach function.\n * @param copy - When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n */\n function Vector(container, copy) {\n if (container === void 0) { container = []; }\n if (copy === void 0) { copy = true; }\n var _this = _super.call(this) || this;\n if (Array.isArray(container)) {\n _this._vector = copy ? __spreadArray([], __read(container), false) : container;\n _this._length = container.length;\n }\n else {\n _this._vector = [];\n var self_1 = _this;\n container.forEach(function (el) {\n self_1.pushBack(el);\n });\n }\n return _this;\n }\n Vector.prototype.clear = function () {\n this._length = 0;\n this._vector.length = 0;\n };\n Vector.prototype.begin = function () {\n return new VectorIterator(0, this);\n };\n Vector.prototype.end = function () {\n return new VectorIterator(this._length, this);\n };\n Vector.prototype.rBegin = function () {\n return new VectorIterator(this._length - 1, this, 1 /* IteratorType.REVERSE */);\n };\n Vector.prototype.rEnd = function () {\n return new VectorIterator(-1, this, 1 /* IteratorType.REVERSE */);\n };\n Vector.prototype.front = function () {\n return this._vector[0];\n };\n Vector.prototype.back = function () {\n return this._vector[this._length - 1];\n };\n Vector.prototype.getElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n return this._vector[pos];\n };\n Vector.prototype.eraseElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n this._vector.splice(pos, 1);\n this._length -= 1;\n return this._length;\n };\n Vector.prototype.eraseElementByValue = function (value) {\n var index = 0;\n for (var i = 0; i < this._length; ++i) {\n if (this._vector[i] !== value) {\n this._vector[index++] = this._vector[i];\n }\n }\n this._length = this._vector.length = index;\n return this._length;\n };\n Vector.prototype.eraseElementByIterator = function (iter) {\n var _node = iter._node;\n iter = iter.next();\n this.eraseElementByPos(_node);\n return iter;\n };\n Vector.prototype.pushBack = function (element) {\n this._vector.push(element);\n this._length += 1;\n return this._length;\n };\n Vector.prototype.popBack = function () {\n if (this._length === 0)\n return;\n this._length -= 1;\n return this._vector.pop();\n };\n Vector.prototype.setElementByPos = function (pos, element) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n this._vector[pos] = element;\n };\n Vector.prototype.insert = function (pos, element, num) {\n var _a;\n if (num === void 0) { num = 1; }\n if (pos < 0 || pos > this._length) {\n throw new RangeError();\n }\n (_a = this._vector).splice.apply(_a, __spreadArray([pos, 0], __read(new Array(num).fill(element)), false));\n this._length += num;\n return this._length;\n };\n Vector.prototype.find = function (element) {\n for (var i = 0; i < this._length; ++i) {\n if (this._vector[i] === element) {\n return new VectorIterator(i, this);\n }\n }\n return this.end();\n };\n Vector.prototype.reverse = function () {\n this._vector.reverse();\n };\n Vector.prototype.unique = function () {\n var index = 1;\n for (var i = 1; i < this._length; ++i) {\n if (this._vector[i] !== this._vector[i - 1]) {\n this._vector[index++] = this._vector[i];\n }\n }\n this._length = this._vector.length = index;\n return this._length;\n };\n Vector.prototype.sort = function (cmp) {\n this._vector.sort(cmp);\n };\n Vector.prototype.forEach = function (callback) {\n for (var i = 0; i < this._length; ++i) {\n callback(this._vector[i], i, this);\n }\n };\n Vector.prototype[Symbol.iterator] = function () {\n return function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [5 /*yield**/, __values(this._vector)];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return Vector;\n}(SequentialContainer));\nexport default Vector;\n","import SequentialContainer from './Base';\nimport { initContainer, IteratorType } from '@/container/ContainerBase';\nimport { RandomIterator } from '@/container/SequentialContainer/Base/RandomIterator';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\n\nclass VectorIterator<T> extends RandomIterator<T> {\n container: Vector<T>;\n constructor(node: number, container: Vector<T>, iteratorType?: IteratorType) {\n super(node, iteratorType);\n this.container = container;\n }\n copy() {\n return new VectorIterator<T>(this._node, this.container, this.iteratorType);\n }\n // @ts-ignore\n equals(iter: VectorIterator<T>): boolean;\n}\n\nexport type { VectorIterator };\n\nclass Vector<T> extends SequentialContainer<T> {\n /**\n * @internal\n */\n private readonly _vector: T[];\n /**\n * @param container - Initialize container, must have a forEach function.\n * @param copy - When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n */\n constructor(container: initContainer<T> = [], copy = true) {\n super();\n if (Array.isArray(container)) {\n this._vector = copy ? [...container] : container;\n this._length = container.length;\n } else {\n this._vector = [];\n const self = this;\n container.forEach(function (el) {\n self.pushBack(el);\n });\n }\n }\n clear() {\n this._length = 0;\n this._vector.length = 0;\n }\n begin() {\n return new VectorIterator<T>(0, this);\n }\n end() {\n return new VectorIterator<T>(this._length, this);\n }\n rBegin() {\n return new VectorIterator<T>(this._length - 1, this, IteratorType.REVERSE);\n }\n rEnd() {\n return new VectorIterator<T>(-1, this, IteratorType.REVERSE);\n }\n front(): T | undefined {\n return this._vector[0];\n }\n back(): T | undefined {\n return this._vector[this._length - 1];\n }\n getElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n return this._vector[pos];\n }\n eraseElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n this._vector.splice(pos, 1);\n this._length -= 1;\n return this._length;\n }\n eraseElementByValue(value: T) {\n let index = 0;\n for (let i = 0; i < this._length; ++i) {\n if (this._vector[i] !== value) {\n this._vector[index++] = this._vector[i];\n }\n }\n this._length = this._vector.length = index;\n return this._length;\n }\n eraseElementByIterator(iter: VectorIterator<T>) {\n const _node = iter._node;\n iter = iter.next();\n this.eraseElementByPos(_node);\n return iter;\n }\n pushBack(element: T) {\n this._vector.push(element);\n this._length += 1;\n return this._length;\n }\n popBack() {\n if (this._length === 0) return;\n this._length -= 1;\n return this._vector.pop();\n }\n setElementByPos(pos: number, element: T) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n this._vector[pos] = element;\n }\n insert(pos: number, element: T, num = 1) {\n $checkWithinAccessParams!(pos, 0, this._length);\n this._vector.splice(pos, 0, ...new Array<T>(num).fill(element));\n this._length += num;\n return this._length;\n }\n find(element: T) {\n for (let i = 0; i < this._length; ++i) {\n if (this._vector[i] === element) {\n return new VectorIterator<T>(i, this);\n }\n }\n return this.end();\n }\n reverse() {\n this._vector.reverse();\n }\n unique() {\n let index = 1;\n for (let i = 1; i < this._length; ++i) {\n if (this._vector[i] !== this._vector[i - 1]) {\n this._vector[index++] = this._vector[i];\n }\n }\n this._length = this._vector.length = index;\n return this._length;\n }\n sort(cmp?: (x: T, y: T) => number) {\n this._vector.sort(cmp);\n }\n forEach(callback: (element: T, index: number, vector: Vector<T>) => void) {\n for (let i = 0; i < this._length; ++i) {\n callback(this._vector[i], i, this);\n }\n }\n [Symbol.iterator]() {\n return function * (this: Vector<T>) {\n yield * this._vector;\n }.bind(this)();\n }\n}\n\nexport default Vector;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nimport SequentialContainer from './Base';\nimport { ContainerIterator } from \"../ContainerBase\";\nimport $checkWithinAccessParams from \"../../utils/checkParams.macro\";\nimport { throwIteratorAccessError } from \"../../utils/throwError\";\nvar LinkListIterator = /** @class */ (function (_super) {\n __extends(LinkListIterator, _super);\n /**\n * @internal\n */\n function LinkListIterator(_node, _header, container, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this._node = _node;\n _this._header = _header;\n _this.container = container;\n if (_this.iteratorType === 0 /* IteratorType.NORMAL */) {\n _this.pre = function () {\n if (this._node._pre === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this._node._next === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n }\n return _this;\n }\n Object.defineProperty(LinkListIterator.prototype, \"pointer\", {\n get: function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._value;\n },\n set: function (newValue) {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node._value = newValue;\n },\n enumerable: false,\n configurable: true\n });\n LinkListIterator.prototype.copy = function () {\n return new LinkListIterator(this._node, this._header, this.container, this.iteratorType);\n };\n return LinkListIterator;\n}(ContainerIterator));\nvar LinkList = /** @class */ (function (_super) {\n __extends(LinkList, _super);\n function LinkList(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n _this._header = {};\n _this._head = _this._tail = _this._header._pre = _this._header._next = _this._header;\n var self = _this;\n container.forEach(function (el) {\n self.pushBack(el);\n });\n return _this;\n }\n /**\n * @internal\n */\n LinkList.prototype._eraseNode = function (node) {\n var _pre = node._pre, _next = node._next;\n _pre._next = _next;\n _next._pre = _pre;\n if (node === this._head) {\n this._head = _next;\n }\n if (node === this._tail) {\n this._tail = _pre;\n }\n this._length -= 1;\n };\n /**\n * @internal\n */\n LinkList.prototype._insertNode = function (value, pre) {\n var next = pre._next;\n var node = {\n _value: value,\n _pre: pre,\n _next: next\n };\n pre._next = node;\n next._pre = node;\n if (pre === this._header) {\n this._head = node;\n }\n if (next === this._header) {\n this._tail = node;\n }\n this._length += 1;\n };\n LinkList.prototype.clear = function () {\n this._length = 0;\n this._head = this._tail = this._header._pre = this._header._next = this._header;\n };\n LinkList.prototype.begin = function () {\n return new LinkListIterator(this._head, this._header, this);\n };\n LinkList.prototype.end = function () {\n return new LinkListIterator(this._header, this._header, this);\n };\n LinkList.prototype.rBegin = function () {\n return new LinkListIterator(this._tail, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n LinkList.prototype.rEnd = function () {\n return new LinkListIterator(this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n LinkList.prototype.front = function () {\n return this._head._value;\n };\n LinkList.prototype.back = function () {\n return this._tail._value;\n };\n LinkList.prototype.getElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n return curNode._value;\n };\n LinkList.prototype.eraseElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n this._eraseNode(curNode);\n return this._length;\n };\n LinkList.prototype.eraseElementByValue = function (_value) {\n var curNode = this._head;\n while (curNode !== this._header) {\n if (curNode._value === _value) {\n this._eraseNode(curNode);\n }\n curNode = curNode._next;\n }\n return this._length;\n };\n LinkList.prototype.eraseElementByIterator = function (iter) {\n var node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n iter = iter.next();\n this._eraseNode(node);\n return iter;\n };\n LinkList.prototype.pushBack = function (element) {\n this._insertNode(element, this._tail);\n return this._length;\n };\n LinkList.prototype.popBack = function () {\n if (this._length === 0)\n return;\n var value = this._tail._value;\n this._eraseNode(this._tail);\n return value;\n };\n /**\n * @description Push an element to the front.\n * @param element - The element you want to push.\n * @returns The size of queue after pushing.\n */\n LinkList.prototype.pushFront = function (element) {\n this._insertNode(element, this._header);\n return this._length;\n };\n /**\n * @description Removes the first element.\n * @returns The element you popped.\n */\n LinkList.prototype.popFront = function () {\n if (this._length === 0)\n return;\n var value = this._head._value;\n this._eraseNode(this._head);\n return value;\n };\n LinkList.prototype.setElementByPos = function (pos, element) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n curNode._value = element;\n };\n LinkList.prototype.insert = function (pos, element, num) {\n if (num === void 0) { num = 1; }\n if (pos < 0 || pos > this._length) {\n throw new RangeError();\n }\n if (num <= 0)\n return this._length;\n if (pos === 0) {\n while (num--)\n this.pushFront(element);\n }\n else if (pos === this._length) {\n while (num--)\n this.pushBack(element);\n }\n else {\n var curNode = this._head;\n for (var i = 1; i < pos; ++i) {\n curNode = curNode._next;\n }\n var next = curNode._next;\n this._length += num;\n while (num--) {\n curNode._next = {\n _value: element,\n _pre: curNode\n };\n curNode._next._pre = curNode;\n curNode = curNode._next;\n }\n curNode._next = next;\n next._pre = curNode;\n }\n return this._length;\n };\n LinkList.prototype.find = function (element) {\n var curNode = this._head;\n while (curNode !== this._header) {\n if (curNode._value === element) {\n return new LinkListIterator(curNode, this._header, this);\n }\n curNode = curNode._next;\n }\n return this.end();\n };\n LinkList.prototype.reverse = function () {\n if (this._length <= 1)\n return;\n var pHead = this._head;\n var pTail = this._tail;\n var cnt = 0;\n while ((cnt << 1) < this._length) {\n var tmp = pHead._value;\n pHead._value = pTail._value;\n pTail._value = tmp;\n pHead = pHead._next;\n pTail = pTail._pre;\n cnt += 1;\n }\n };\n LinkList.prototype.unique = function () {\n if (this._length <= 1) {\n return this._length;\n }\n var curNode = this._head;\n while (curNode !== this._header) {\n var tmpNode = curNode;\n while (tmpNode._next !== this._header &&\n tmpNode._value === tmpNode._next._value) {\n tmpNode = tmpNode._next;\n this._length -= 1;\n }\n curNode._next = tmpNode._next;\n curNode._next._pre = curNode;\n curNode = curNode._next;\n }\n return this._length;\n };\n LinkList.prototype.sort = function (cmp) {\n if (this._length <= 1)\n return;\n var arr = [];\n this.forEach(function (el) {\n arr.push(el);\n });\n arr.sort(cmp);\n var curNode = this._head;\n arr.forEach(function (element) {\n curNode._value = element;\n curNode = curNode._next;\n });\n };\n /**\n * @description Merges two sorted lists.\n * @param list - The other list you want to merge (must be sorted).\n * @returns The size of list after merging.\n * @example\n * const linkA = new LinkList([1, 3, 5]);\n * const linkB = new LinkList([2, 4, 6]);\n * linkA.merge(linkB); // [1, 2, 3, 4, 5];\n */\n LinkList.prototype.merge = function (list) {\n var self = this;\n if (this._length === 0) {\n list.forEach(function (el) {\n self.pushBack(el);\n });\n }\n else {\n var curNode_1 = this._head;\n list.forEach(function (el) {\n while (curNode_1 !== self._header &&\n curNode_1._value <= el) {\n curNode_1 = curNode_1._next;\n }\n self._insertNode(el, curNode_1._pre);\n });\n }\n return this._length;\n };\n LinkList.prototype.forEach = function (callback) {\n var curNode = this._head;\n var index = 0;\n while (curNode !== this._header) {\n callback(curNode._value, index++, this);\n curNode = curNode._next;\n }\n };\n LinkList.prototype[Symbol.iterator] = function () {\n return function () {\n var curNode;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (this._length === 0)\n return [2 /*return*/];\n curNode = this._head;\n _a.label = 1;\n case 1:\n if (!(curNode !== this._header)) return [3 /*break*/, 3];\n return [4 /*yield*/, curNode._value];\n case 2:\n _a.sent();\n curNode = curNode._next;\n return [3 /*break*/, 1];\n case 3: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return LinkList;\n}(SequentialContainer));\nexport default LinkList;\n","import SequentialContainer from './Base';\nimport { ContainerIterator, initContainer, IteratorType } from '@/container/ContainerBase';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\ntype LinkNode<T> = {\n _value: T;\n _pre: LinkNode<T>;\n _next: LinkNode<T>;\n}\n\nclass LinkListIterator<T> extends ContainerIterator<T> {\n readonly container: LinkList<T>;\n /**\n * @internal\n */\n _node: LinkNode<T>;\n /**\n * @internal\n */\n private readonly _header: LinkNode<T>;\n /**\n * @internal\n */\n constructor(\n _node: LinkNode<T>,\n _header: LinkNode<T>,\n container: LinkList<T>,\n iteratorType?: IteratorType\n ) {\n super(iteratorType);\n this._node = _node;\n this._header = _header;\n this.container = container;\n if (this.iteratorType === IteratorType.NORMAL) {\n this.pre = function () {\n if (this._node._pre === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n } else {\n this.pre = function () {\n if (this._node._next === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n }\n }\n get pointer() {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._value;\n }\n set pointer(newValue: T) {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node._value = newValue;\n }\n copy() {\n return new LinkListIterator<T>(this._node, this._header, this.container, this.iteratorType);\n }\n // @ts-ignore\n equals(iter: LinkListIterator<T>): boolean;\n // @ts-ignore\n pre(): this;\n // @ts-ignore\n next(): this;\n}\n\nexport type { LinkListIterator };\n\nclass LinkList<T> extends SequentialContainer<T> {\n /**\n * @internal\n */\n private _head: LinkNode<T>;\n /**\n * @internal\n */\n private _tail: LinkNode<T>;\n /**\n * @internal\n */\n private readonly _header: LinkNode<T>;\n constructor(container: initContainer<T> = []) {\n super();\n this._header = <LinkNode<T>>{};\n this._head = this._tail = this._header._pre = this._header._next = this._header;\n const self = this;\n container.forEach(function (el) {\n self.pushBack(el);\n });\n }\n /**\n * @internal\n */\n private _eraseNode(node: LinkNode<T>) {\n const { _pre, _next } = node;\n _pre._next = _next;\n _next._pre = _pre;\n if (node === this._head) {\n this._head = _next;\n }\n if (node === this._tail) {\n this._tail = _pre;\n }\n this._length -= 1;\n }\n /**\n * @internal\n */\n private _insertNode(value: T, pre: LinkNode<T>) {\n const next = pre._next;\n const node = {\n _value: value,\n _pre: pre,\n _next: next\n };\n pre._next = node;\n next._pre = node;\n if (pre === this._header) {\n this._head = node;\n }\n if (next === this._header) {\n this._tail = node;\n }\n this._length += 1;\n }\n clear() {\n this._length = 0;\n this._head = this._tail = this._header._pre = this._header._next = this._header;\n }\n begin() {\n return new LinkListIterator<T>(this._head, this._header, this);\n }\n end() {\n return new LinkListIterator<T>(this._header, this._header, this);\n }\n rBegin() {\n return new LinkListIterator<T>(this._tail, this._header, this, IteratorType.REVERSE);\n }\n rEnd() {\n return new LinkListIterator<T>(this._header, this._header, this, IteratorType.REVERSE);\n }\n front(): T | undefined {\n return this._head._value;\n }\n back(): T | undefined {\n return this._tail._value;\n }\n getElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n return curNode._value;\n }\n eraseElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n this._eraseNode(curNode);\n return this._length;\n }\n eraseElementByValue(_value: T) {\n let curNode = this._head;\n while (curNode !== this._header) {\n if (curNode._value === _value) {\n this._eraseNode(curNode);\n }\n curNode = curNode._next;\n }\n return this._length;\n }\n eraseElementByIterator(iter: LinkListIterator<T>) {\n const node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n iter = iter.next();\n this._eraseNode(node);\n return iter;\n }\n pushBack(element: T) {\n this._insertNode(element, this._tail);\n return this._length;\n }\n popBack() {\n if (this._length === 0) return;\n const value = this._tail._value;\n this._eraseNode(this._tail);\n return value;\n }\n /**\n * @description Push an element to the front.\n * @param element - The element you want to push.\n * @returns The size of queue after pushing.\n */\n pushFront(element: T) {\n this._insertNode(element, this._header);\n return this._length;\n }\n /**\n * @description Removes the first element.\n * @returns The element you popped.\n */\n popFront() {\n if (this._length === 0) return;\n const value = this._head._value;\n this._eraseNode(this._head);\n return value;\n }\n setElementByPos(pos: number, element: T) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let curNode = this._head;\n while (pos--) {\n curNode = curNode._next;\n }\n curNode._value = element;\n }\n insert(pos: number, element: T, num = 1) {\n $checkWithinAccessParams!(pos, 0, this._length);\n if (num <= 0) return this._length;\n if (pos === 0) {\n while (num--) this.pushFront(element);\n } else if (pos === this._length) {\n while (num--) this.pushBack(element);\n } else {\n let curNode = this._head;\n for (let i = 1; i < pos; ++i) {\n curNode = curNode._next;\n }\n const next = curNode._next;\n this._length += num;\n while (num--) {\n curNode._next = <LinkNode<T>>{\n _value: element,\n _pre: curNode\n };\n curNode._next._pre = curNode;\n curNode = curNode._next;\n }\n curNode._next = next;\n next._pre = curNode;\n }\n return this._length;\n }\n find(element: T) {\n let curNode = this._head;\n while (curNode !== this._header) {\n if (curNode._value === element) {\n return new LinkListIterator<T>(curNode, this._header, this);\n }\n curNode = curNode._next;\n }\n return this.end();\n }\n reverse() {\n if (this._length <= 1) return;\n let pHead = this._head;\n let pTail = this._tail;\n let cnt = 0;\n while ((cnt << 1) < this._length) {\n const tmp = pHead._value;\n pHead._value = pTail._value;\n pTail._value = tmp;\n pHead = pHead._next;\n pTail = pTail._pre;\n cnt += 1;\n }\n }\n unique() {\n if (this._length <= 1) {\n return this._length;\n }\n let curNode = this._head;\n while (curNode !== this._header) {\n let tmpNode = curNode;\n while (\n tmpNode._next !== this._header &&\n tmpNode._value === tmpNode._next._value\n ) {\n tmpNode = tmpNode._next;\n this._length -= 1;\n }\n curNode._next = tmpNode._next;\n curNode._next._pre = curNode;\n curNode = curNode._next;\n }\n return this._length;\n }\n sort(cmp?: (x: T, y: T) => number) {\n if (this._length <= 1) return;\n const arr: T[] = [];\n this.forEach(function (el) {\n arr.push(el);\n });\n arr.sort(cmp);\n let curNode: LinkNode<T> = this._head;\n arr.forEach(function (element) {\n curNode._value = element;\n curNode = curNode._next;\n });\n }\n /**\n * @description Merges two sorted lists.\n * @param list - The other list you want to merge (must be sorted).\n * @returns The size of list after merging.\n * @example\n * const linkA = new LinkList([1, 3, 5]);\n * const linkB = new LinkList([2, 4, 6]);\n * linkA.merge(linkB); // [1, 2, 3, 4, 5];\n */\n merge(list: LinkList<T>) {\n const self = this;\n if (this._length === 0) {\n list.forEach(function (el) {\n self.pushBack(el);\n });\n } else {\n let curNode = this._head;\n list.forEach(function (el) {\n while (\n curNode !== self._header &&\n curNode._value <= el\n ) {\n curNode = curNode._next;\n }\n self._insertNode(el, curNode._pre);\n });\n }\n return this._length;\n }\n forEach(callback: (element: T, index: number, list: LinkList<T>) => void) {\n let curNode = this._head;\n let index = 0;\n while (curNode !== this._header) {\n callback(curNode._value, index++, this);\n curNode = curNode._next;\n }\n }\n [Symbol.iterator]() {\n return function * (this: LinkList<T>) {\n if (this._length === 0) return;\n let curNode = this._head;\n while (curNode !== this._header) {\n yield curNode._value;\n curNode = curNode._next;\n }\n }.bind(this)();\n }\n}\n\nexport default LinkList;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nimport SequentialContainer from './Base';\nimport { RandomIterator } from \"./Base/RandomIterator\";\nimport $checkWithinAccessParams from \"../../utils/checkParams.macro\";\nimport $getContainerSize from \"../../utils/getContainerSize.macro\";\nvar DequeIterator = /** @class */ (function (_super) {\n __extends(DequeIterator, _super);\n function DequeIterator(node, container, iteratorType) {\n var _this = _super.call(this, node, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n DequeIterator.prototype.copy = function () {\n return new DequeIterator(this._node, this.container, this.iteratorType);\n };\n return DequeIterator;\n}(RandomIterator));\nvar Deque = /** @class */ (function (_super) {\n __extends(Deque, _super);\n function Deque(container, _bucketSize) {\n if (container === void 0) { container = []; }\n if (_bucketSize === void 0) { _bucketSize = (1 << 12); }\n var _this = _super.call(this) || this;\n /**\n * @internal\n */\n _this._first = 0;\n /**\n * @internal\n */\n _this._curFirst = 0;\n /**\n * @internal\n */\n _this._last = 0;\n /**\n * @internal\n */\n _this._curLast = 0;\n /**\n * @internal\n */\n _this._bucketNum = 0;\n /**\n * @internal\n */\n _this._map = [];\n var _length = (function () {\n if (typeof container.length === \"number\")\n return container.length;\n if (typeof container.size === \"number\")\n return container.size;\n if (typeof container.size === \"function\")\n return container.size();\n throw new TypeError(\"Cannot get the length or size of the container\");\n })();\n _this._bucketSize = _bucketSize;\n _this._bucketNum = Math.max(Math.ceil(_length / _this._bucketSize), 1);\n for (var i = 0; i < _this._bucketNum; ++i) {\n _this._map.push(new Array(_this._bucketSize));\n }\n var needBucketNum = Math.ceil(_length / _this._bucketSize);\n _this._first = _this._last = (_this._bucketNum >> 1) - (needBucketNum >> 1);\n _this._curFirst = _this._curLast = (_this._bucketSize - _length % _this._bucketSize) >> 1;\n var self = _this;\n container.forEach(function (element) {\n self.pushBack(element);\n });\n return _this;\n }\n /**\n * @description Growth the Deque.\n * @internal\n */\n Deque.prototype._reAllocate = function () {\n var newMap = [];\n var addBucketNum = Math.max(this._bucketNum >> 1, 1);\n for (var i = 0; i < addBucketNum; ++i) {\n newMap[i] = new Array(this._bucketSize);\n }\n for (var i = this._first; i < this._bucketNum; ++i) {\n newMap[newMap.length] = this._map[i];\n }\n for (var i = 0; i < this._last; ++i) {\n newMap[newMap.length] = this._map[i];\n }\n newMap[newMap.length] = __spreadArray([], __read(this._map[this._last]), false);\n this._first = addBucketNum;\n this._last = newMap.length - 1;\n for (var i = 0; i < addBucketNum; ++i) {\n newMap[newMap.length] = new Array(this._bucketSize);\n }\n this._map = newMap;\n this._bucketNum = newMap.length;\n };\n /**\n * @description Get the bucket position of the element and the pointer position by index.\n * @param pos - The element's index.\n * @internal\n */\n Deque.prototype._getElementIndex = function (pos) {\n var offset = this._curFirst + pos + 1;\n var offsetRemainder = offset % this._bucketSize;\n var curNodePointerIndex = offsetRemainder - 1;\n var curNodeBucketIndex = this._first + (offset - offsetRemainder) / this._bucketSize;\n if (offsetRemainder === 0)\n curNodeBucketIndex -= 1;\n curNodeBucketIndex %= this._bucketNum;\n if (curNodePointerIndex < 0)\n curNodePointerIndex += this._bucketSize;\n return { curNodeBucketIndex: curNodeBucketIndex, curNodePointerIndex: curNodePointerIndex };\n };\n Deque.prototype.clear = function () {\n this._map = [new Array(this._bucketSize)];\n this._bucketNum = 1;\n this._first = this._last = this._length = 0;\n this._curFirst = this._curLast = this._bucketSize >> 1;\n };\n Deque.prototype.begin = function () {\n return new DequeIterator(0, this);\n };\n Deque.prototype.end = function () {\n return new DequeIterator(this._length, this);\n };\n Deque.prototype.rBegin = function () {\n return new DequeIterator(this._length - 1, this, 1 /* IteratorType.REVERSE */);\n };\n Deque.prototype.rEnd = function () {\n return new DequeIterator(-1, this, 1 /* IteratorType.REVERSE */);\n };\n Deque.prototype.front = function () {\n if (this._length === 0)\n return;\n return this._map[this._first][this._curFirst];\n };\n Deque.prototype.back = function () {\n if (this._length === 0)\n return;\n return this._map[this._last][this._curLast];\n };\n Deque.prototype.pushBack = function (element) {\n if (this._length) {\n if (this._curLast < this._bucketSize - 1) {\n this._curLast += 1;\n }\n else if (this._last < this._bucketNum - 1) {\n this._last += 1;\n this._curLast = 0;\n }\n else {\n this._last = 0;\n this._curLast = 0;\n }\n if (this._last === this._first &&\n this._curLast === this._curFirst)\n this._reAllocate();\n }\n this._length += 1;\n this._map[this._last][this._curLast] = element;\n return this._length;\n };\n Deque.prototype.popBack = function () {\n if (this._length === 0)\n return;\n var value = this._map[this._last][this._curLast];\n if (this._length !== 1) {\n if (this._curLast > 0) {\n this._curLast -= 1;\n }\n else if (this._last > 0) {\n this._last -= 1;\n this._curLast = this._bucketSize - 1;\n }\n else {\n this._last = this._bucketNum - 1;\n this._curLast = this._bucketSize - 1;\n }\n }\n this._length -= 1;\n return value;\n };\n /**\n * @description Push the element to the front.\n * @param element - The element you want to push.\n * @returns The size of queue after pushing.\n */\n Deque.prototype.pushFront = function (element) {\n if (this._length) {\n if (this._curFirst > 0) {\n this._curFirst -= 1;\n }\n else if (this._first > 0) {\n this._first -= 1;\n this._curFirst = this._bucketSize - 1;\n }\n else {\n this._first = this._bucketNum - 1;\n this._curFirst = this._bucketSize - 1;\n }\n if (this._first === this._last &&\n this._curFirst === this._curLast)\n this._reAllocate();\n }\n this._length += 1;\n this._map[this._first][this._curFirst] = element;\n return this._length;\n };\n /**\n * @description Remove the _first element.\n * @returns The element you popped.\n */\n Deque.prototype.popFront = function () {\n if (this._length === 0)\n return;\n var value = this._map[this._first][this._curFirst];\n if (this._length !== 1) {\n if (this._curFirst < this._bucketSize - 1) {\n this._curFirst += 1;\n }\n else if (this._first < this._bucketNum - 1) {\n this._first += 1;\n this._curFirst = 0;\n }\n else {\n this._first = 0;\n this._curFirst = 0;\n }\n }\n this._length -= 1;\n return value;\n };\n Deque.prototype.getElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var _a = this._getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n return this._map[curNodeBucketIndex][curNodePointerIndex];\n };\n Deque.prototype.setElementByPos = function (pos, element) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var _a = this._getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n this._map[curNodeBucketIndex][curNodePointerIndex] = element;\n };\n Deque.prototype.insert = function (pos, element, num) {\n if (num === void 0) { num = 1; }\n if (pos < 0 || pos > this._length) {\n throw new RangeError();\n }\n if (pos === 0) {\n while (num--)\n this.pushFront(element);\n }\n else if (pos === this._length) {\n while (num--)\n this.pushBack(element);\n }\n else {\n var arr = [];\n for (var i = pos; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos - 1);\n for (var i = 0; i < num; ++i)\n this.pushBack(element);\n for (var i = 0; i < arr.length; ++i)\n this.pushBack(arr[i]);\n }\n return this._length;\n };\n /**\n * @description Remove all elements after the specified position (excluding the specified position).\n * @param pos - The previous position of the first removed element.\n * @returns The size of the container after cutting.\n * @example\n * deque.cut(1); // Then deque's size will be 2. deque -> [0, 1]\n */\n Deque.prototype.cut = function (pos) {\n if (pos < 0) {\n this.clear();\n return 0;\n }\n var _a = this._getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n this._last = curNodeBucketIndex;\n this._curLast = curNodePointerIndex;\n this._length = pos + 1;\n return this._length;\n };\n Deque.prototype.eraseElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n if (pos === 0)\n this.popFront();\n else if (pos === this._length - 1)\n this.popBack();\n else {\n var arr = [];\n for (var i = pos + 1; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos);\n this.popBack();\n var self_1 = this;\n arr.forEach(function (el) {\n self_1.pushBack(el);\n });\n }\n return this._length;\n };\n Deque.prototype.eraseElementByValue = function (value) {\n if (this._length === 0)\n return 0;\n var arr = [];\n for (var i = 0; i < this._length; ++i) {\n var element = this.getElementByPos(i);\n if (element !== value)\n arr.push(element);\n }\n var _length = arr.length;\n for (var i = 0; i < _length; ++i)\n this.setElementByPos(i, arr[i]);\n return this.cut(_length - 1);\n };\n Deque.prototype.eraseElementByIterator = function (iter) {\n var _node = iter._node;\n this.eraseElementByPos(_node);\n iter = iter.next();\n return iter;\n };\n Deque.prototype.find = function (element) {\n for (var i = 0; i < this._length; ++i) {\n if (this.getElementByPos(i) === element) {\n return new DequeIterator(i, this);\n }\n }\n return this.end();\n };\n Deque.prototype.reverse = function () {\n var l = 0;\n var r = this._length - 1;\n while (l < r) {\n var tmp = this.getElementByPos(l);\n this.setElementByPos(l, this.getElementByPos(r));\n this.setElementByPos(r, tmp);\n l += 1;\n r -= 1;\n }\n };\n Deque.prototype.unique = function () {\n if (this._length <= 1) {\n return this._length;\n }\n var index = 1;\n var pre = this.getElementByPos(0);\n for (var i = 1; i < this._length; ++i) {\n var cur = this.getElementByPos(i);\n if (cur !== pre) {\n pre = cur;\n this.setElementByPos(index++, cur);\n }\n }\n while (this._length > index)\n this.popBack();\n return this._length;\n };\n Deque.prototype.sort = function (cmp) {\n var arr = [];\n for (var i = 0; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n arr.sort(cmp);\n for (var i = 0; i < this._length; ++i)\n this.setElementByPos(i, arr[i]);\n };\n /**\n * @description Remove as much useless space as possible.\n */\n Deque.prototype.shrinkToFit = function () {\n if (this._length === 0)\n return;\n var arr = [];\n this.forEach(function (el) {\n arr.push(el);\n });\n this._bucketNum = Math.max(Math.ceil(this._length / this._bucketSize), 1);\n this._length = this._first = this._last = this._curFirst = this._curLast = 0;\n this._map = [];\n for (var i = 0; i < this._bucketNum; ++i) {\n this._map.push(new Array(this._bucketSize));\n }\n for (var i = 0; i < arr.length; ++i)\n this.pushBack(arr[i]);\n };\n Deque.prototype.forEach = function (callback) {\n for (var i = 0; i < this._length; ++i) {\n callback(this.getElementByPos(i), i, this);\n }\n };\n Deque.prototype[Symbol.iterator] = function () {\n return function () {\n var i;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n i = 0;\n _a.label = 1;\n case 1:\n if (!(i < this._length)) return [3 /*break*/, 4];\n return [4 /*yield*/, this.getElementByPos(i)];\n case 2:\n _a.sent();\n _a.label = 3;\n case 3:\n ++i;\n return [3 /*break*/, 1];\n case 4: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return Deque;\n}(SequentialContainer));\nexport default Deque;\n","import SequentialContainer from './Base';\nimport { IteratorType, initContainer } from '@/container/ContainerBase';\nimport { RandomIterator } from '@/container/SequentialContainer/Base/RandomIterator';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport $getContainerSize from '@/utils/getContainerSize.macro';\n\nclass DequeIterator<T> extends RandomIterator<T> {\n readonly container: Deque<T>;\n constructor(node: number, container: Deque<T>, iteratorType?: IteratorType) {\n super(node, iteratorType);\n this.container = container;\n }\n copy() {\n return new DequeIterator<T>(this._node, this.container, this.iteratorType);\n }\n // @ts-ignore\n equals(iter: DequeIterator<T>): boolean;\n}\n\nexport type { DequeIterator };\n\nclass Deque<T> extends SequentialContainer<T> {\n /**\n * @internal\n */\n private _first = 0;\n /**\n * @internal\n */\n private _curFirst = 0;\n /**\n * @internal\n */\n private _last = 0;\n /**\n * @internal\n */\n private _curLast = 0;\n /**\n * @internal\n */\n private _bucketNum = 0;\n /**\n * @internal\n */\n private readonly _bucketSize: number;\n /**\n * @internal\n */\n private _map: T[][] = [];\n constructor(container: initContainer<T> = [], _bucketSize = (1 << 12)) {\n super();\n const _length = $getContainerSize!(container);\n this._bucketSize = _bucketSize;\n this._bucketNum = Math.max(Math.ceil(_length / this._bucketSize), 1);\n for (let i = 0; i < this._bucketNum; ++i) {\n this._map.push(new Array(this._bucketSize));\n }\n const needBucketNum = Math.ceil(_length / this._bucketSize);\n this._first = this._last = (this._bucketNum >> 1) - (needBucketNum >> 1);\n this._curFirst = this._curLast = (this._bucketSize - _length % this._bucketSize) >> 1;\n const self = this;\n container.forEach(function (element) {\n self.pushBack(element);\n });\n }\n /**\n * @description Growth the Deque.\n * @internal\n */\n private _reAllocate() {\n const newMap = [];\n const addBucketNum = Math.max(this._bucketNum >> 1, 1);\n for (let i = 0; i < addBucketNum; ++i) {\n newMap[i] = new Array(this._bucketSize);\n }\n for (let i = this._first; i < this._bucketNum; ++i) {\n newMap[newMap.length] = this._map[i];\n }\n for (let i = 0; i < this._last; ++i) {\n newMap[newMap.length] = this._map[i];\n }\n newMap[newMap.length] = [...this._map[this._last]];\n this._first = addBucketNum;\n this._last = newMap.length - 1;\n for (let i = 0; i < addBucketNum; ++i) {\n newMap[newMap.length] = new Array(this._bucketSize);\n }\n this._map = newMap;\n this._bucketNum = newMap.length;\n }\n /**\n * @description Get the bucket position of the element and the pointer position by index.\n * @param pos - The element's index.\n * @internal\n */\n private _getElementIndex(pos: number) {\n const offset = this._curFirst + pos + 1;\n const offsetRemainder = offset % this._bucketSize;\n let curNodePointerIndex = offsetRemainder - 1;\n let curNodeBucketIndex = this._first + (offset - offsetRemainder) / this._bucketSize;\n if (offsetRemainder === 0) curNodeBucketIndex -= 1;\n curNodeBucketIndex %= this._bucketNum;\n if (curNodePointerIndex < 0) curNodePointerIndex += this._bucketSize;\n return { curNodeBucketIndex, curNodePointerIndex };\n }\n clear() {\n this._map = [new Array(this._bucketSize)];\n this._bucketNum = 1;\n this._first = this._last = this._length = 0;\n this._curFirst = this._curLast = this._bucketSize >> 1;\n }\n begin() {\n return new DequeIterator<T>(0, this);\n }\n end() {\n return new DequeIterator<T>(this._length, this);\n }\n rBegin() {\n return new DequeIterator<T>(this._length - 1, this, IteratorType.REVERSE);\n }\n rEnd() {\n return new DequeIterator<T>(-1, this, IteratorType.REVERSE);\n }\n front(): T | undefined {\n if (this._length === 0) return;\n return this._map[this._first][this._curFirst];\n }\n back(): T | undefined {\n if (this._length === 0) return;\n return this._map[this._last][this._curLast];\n }\n pushBack(element: T) {\n if (this._length) {\n if (this._curLast < this._bucketSize - 1) {\n this._curLast += 1;\n } else if (this._last < this._bucketNum - 1) {\n this._last += 1;\n this._curLast = 0;\n } else {\n this._last = 0;\n this._curLast = 0;\n }\n if (\n this._last === this._first &&\n this._curLast === this._curFirst\n ) this._reAllocate();\n }\n this._length += 1;\n this._map[this._last][this._curLast] = element;\n return this._length;\n }\n popBack() {\n if (this._length === 0) return;\n const value = this._map[this._last][this._curLast];\n if (this._length !== 1) {\n if (this._curLast > 0) {\n this._curLast -= 1;\n } else if (this._last > 0) {\n this._last -= 1;\n this._curLast = this._bucketSize - 1;\n } else {\n this._last = this._bucketNum - 1;\n this._curLast = this._bucketSize - 1;\n }\n }\n this._length -= 1;\n return value;\n }\n /**\n * @description Push the element to the front.\n * @param element - The element you want to push.\n * @returns The size of queue after pushing.\n */\n pushFront(element: T) {\n if (this._length) {\n if (this._curFirst > 0) {\n this._curFirst -= 1;\n } else if (this._first > 0) {\n this._first -= 1;\n this._curFirst = this._bucketSize - 1;\n } else {\n this._first = this._bucketNum - 1;\n this._curFirst = this._bucketSize - 1;\n }\n if (\n this._first === this._last &&\n this._curFirst === this._curLast\n ) this._reAllocate();\n }\n this._length += 1;\n this._map[this._first][this._curFirst] = element;\n return this._length;\n }\n /**\n * @description Remove the _first element.\n * @returns The element you popped.\n */\n popFront() {\n if (this._length === 0) return;\n const value = this._map[this._first][this._curFirst];\n if (this._length !== 1) {\n if (this._curFirst < this._bucketSize - 1) {\n this._curFirst += 1;\n } else if (this._first < this._bucketNum - 1) {\n this._first += 1;\n this._curFirst = 0;\n } else {\n this._first = 0;\n this._curFirst = 0;\n }\n }\n this._length -= 1;\n return value;\n }\n getElementByPos(pos: number): T {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n const {\n curNodeBucketIndex,\n curNodePointerIndex\n } = this._getElementIndex(pos);\n return this._map[curNodeBucketIndex][curNodePointerIndex]!;\n }\n setElementByPos(pos: number, element: T) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n const {\n curNodeBucketIndex,\n curNodePointerIndex\n } = this._getElementIndex(pos);\n this._map[curNodeBucketIndex][curNodePointerIndex] = element;\n }\n insert(pos: number, element: T, num = 1) {\n $checkWithinAccessParams!(pos, 0, this._length);\n if (pos === 0) {\n while (num--) this.pushFront(element);\n } else if (pos === this._length) {\n while (num--) this.pushBack(element);\n } else {\n const arr: T[] = [];\n for (let i = pos; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos - 1);\n for (let i = 0; i < num; ++i) this.pushBack(element);\n for (let i = 0; i < arr.length; ++i) this.pushBack(arr[i]);\n }\n return this._length;\n }\n /**\n * @description Remove all elements after the specified position (excluding the specified position).\n * @param pos - The previous position of the first removed element.\n * @returns The size of the container after cutting.\n * @example\n * deque.cut(1); // Then deque's size will be 2. deque -> [0, 1]\n */\n cut(pos: number) {\n if (pos < 0) {\n this.clear();\n return 0;\n }\n const {\n curNodeBucketIndex,\n curNodePointerIndex\n } = this._getElementIndex(pos);\n this._last = curNodeBucketIndex;\n this._curLast = curNodePointerIndex;\n this._length = pos + 1;\n return this._length;\n }\n eraseElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n if (pos === 0) this.popFront();\n else if (pos === this._length - 1) this.popBack();\n else {\n const arr = [];\n for (let i = pos + 1; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos);\n this.popBack();\n const self = this;\n arr.forEach(function (el) {\n self.pushBack(el);\n });\n }\n return this._length;\n }\n eraseElementByValue(value: T) {\n if (this._length === 0) return 0;\n const arr: T[] = [];\n for (let i = 0; i < this._length; ++i) {\n const element = this.getElementByPos(i);\n if (element !== value) arr.push(element);\n }\n const _length = arr.length;\n for (let i = 0; i < _length; ++i) this.setElementByPos(i, arr[i]);\n return this.cut(_length - 1);\n }\n eraseElementByIterator(iter: DequeIterator<T>) {\n const _node = iter._node;\n this.eraseElementByPos(_node);\n iter = iter.next();\n return iter;\n }\n find(element: T) {\n for (let i = 0; i < this._length; ++i) {\n if (this.getElementByPos(i) === element) {\n return new DequeIterator<T>(i, this);\n }\n }\n return this.end();\n }\n reverse() {\n let l = 0; let r = this._length - 1;\n while (l < r) {\n const tmp = this.getElementByPos(l);\n this.setElementByPos(l, this.getElementByPos(r));\n this.setElementByPos(r, tmp);\n l += 1;\n r -= 1;\n }\n }\n unique() {\n if (this._length <= 1) {\n return this._length;\n }\n let index = 1;\n let pre = this.getElementByPos(0);\n for (let i = 1; i < this._length; ++i) {\n const cur = this.getElementByPos(i);\n if (cur !== pre) {\n pre = cur;\n this.setElementByPos(index++, cur);\n }\n }\n while (this._length > index) this.popBack();\n return this._length;\n }\n sort(cmp?: (x: T, y: T) => number) {\n const arr: T[] = [];\n for (let i = 0; i < this._length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n arr.sort(cmp);\n for (let i = 0; i < this._length; ++i) this.setElementByPos(i, arr[i]);\n }\n /**\n * @description Remove as much useless space as possible.\n */\n shrinkToFit() {\n if (this._length === 0) return;\n const arr: T[] = [];\n this.forEach(function (el) {\n arr.push(el);\n });\n this._bucketNum = Math.max(Math.ceil(this._length / this._bucketSize), 1);\n this._length = this._first = this._last = this._curFirst = this._curLast = 0;\n this._map = [];\n for (let i = 0; i < this._bucketNum; ++i) {\n this._map.push(new Array(this._bucketSize));\n }\n for (let i = 0; i < arr.length; ++i) this.pushBack(arr[i]);\n }\n forEach(callback: (element: T, index: number, deque: Deque<T>) => void) {\n for (let i = 0; i < this._length; ++i) {\n callback(this.getElementByPos(i), i, this);\n }\n }\n [Symbol.iterator]() {\n return function * (this: Deque<T>) {\n for (let i = 0; i < this._length; ++i) {\n yield this.getElementByPos(i);\n }\n }.bind(this)();\n }\n}\n\nexport default Deque;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar TreeNode = /** @class */ (function () {\n function TreeNode(key, value) {\n this._color = 1 /* TreeNodeColor.RED */;\n this._key = undefined;\n this._value = undefined;\n this._left = undefined;\n this._right = undefined;\n this._parent = undefined;\n this._key = key;\n this._value = value;\n }\n /**\n * @description Get the pre node.\n * @returns TreeNode about the pre node.\n */\n TreeNode.prototype._pre = function () {\n var preNode = this;\n if (preNode._color === 1 /* TreeNodeColor.RED */ &&\n preNode._parent._parent === preNode) {\n preNode = preNode._right;\n }\n else if (preNode._left) {\n preNode = preNode._left;\n while (preNode._right) {\n preNode = preNode._right;\n }\n }\n else {\n var pre = preNode._parent;\n while (pre._left === preNode) {\n preNode = pre;\n pre = preNode._parent;\n }\n preNode = pre;\n }\n return preNode;\n };\n /**\n * @description Get the next node.\n * @returns TreeNode about the next node.\n */\n TreeNode.prototype._next = function () {\n var nextNode = this;\n if (nextNode._right) {\n nextNode = nextNode._right;\n while (nextNode._left) {\n nextNode = nextNode._left;\n }\n return nextNode;\n }\n else {\n var pre = nextNode._parent;\n while (pre._right === nextNode) {\n nextNode = pre;\n pre = nextNode._parent;\n }\n if (nextNode._right !== pre) {\n return pre;\n }\n else\n return nextNode;\n }\n };\n /**\n * @description Rotate left.\n * @returns TreeNode about moved to original position after rotation.\n */\n TreeNode.prototype._rotateLeft = function () {\n var PP = this._parent;\n var V = this._right;\n var R = V._left;\n if (PP._parent === this)\n PP._parent = V;\n else if (PP._left === this)\n PP._left = V;\n else\n PP._right = V;\n V._parent = PP;\n V._left = this;\n this._parent = V;\n this._right = R;\n if (R)\n R._parent = this;\n return V;\n };\n /**\n * @description Rotate right.\n * @returns TreeNode about moved to original position after rotation.\n */\n TreeNode.prototype._rotateRight = function () {\n var PP = this._parent;\n var F = this._left;\n var K = F._right;\n if (PP._parent === this)\n PP._parent = F;\n else if (PP._left === this)\n PP._left = F;\n else\n PP._right = F;\n F._parent = PP;\n F._right = this;\n this._parent = F;\n this._left = K;\n if (K)\n K._parent = this;\n return F;\n };\n return TreeNode;\n}());\nexport { TreeNode };\nvar TreeNodeEnableIndex = /** @class */ (function (_super) {\n __extends(TreeNodeEnableIndex, _super);\n function TreeNodeEnableIndex() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this._subTreeSize = 1;\n return _this;\n }\n /**\n * @description Rotate left and do recount.\n * @returns TreeNode about moved to original position after rotation.\n */\n TreeNodeEnableIndex.prototype._rotateLeft = function () {\n var parent = _super.prototype._rotateLeft.call(this);\n this._recount();\n parent._recount();\n return parent;\n };\n /**\n * @description Rotate right and do recount.\n * @returns TreeNode about moved to original position after rotation.\n */\n TreeNodeEnableIndex.prototype._rotateRight = function () {\n var parent = _super.prototype._rotateRight.call(this);\n this._recount();\n parent._recount();\n return parent;\n };\n TreeNodeEnableIndex.prototype._recount = function () {\n this._subTreeSize = 1;\n if (this._left) {\n this._subTreeSize += this._left._subTreeSize;\n }\n if (this._right) {\n this._subTreeSize += this._right._subTreeSize;\n }\n };\n return TreeNodeEnableIndex;\n}(TreeNode));\nexport { TreeNodeEnableIndex };\n","export const enum TreeNodeColor {\n RED = 1,\n BLACK = 0\n}\n\nexport class TreeNode<K, V> {\n _color = TreeNodeColor.RED;\n _key: K | undefined = undefined;\n _value: V | undefined = undefined;\n _left: TreeNode<K, V> | undefined = undefined;\n _right: TreeNode<K, V> | undefined = undefined;\n _parent: TreeNode<K, V> | undefined = undefined;\n constructor(key?: K, value?: V) {\n this._key = key;\n this._value = value;\n }\n /**\n * @description Get the pre node.\n * @returns TreeNode about the pre node.\n */\n _pre() {\n let preNode: TreeNode<K, V> = this;\n if (\n preNode._color === TreeNodeColor.RED &&\n preNode._parent!._parent === preNode\n ) {\n preNode = preNode._right!;\n } else if (preNode._left) {\n preNode = preNode._left;\n while (preNode._right) {\n preNode = preNode._right;\n }\n } else {\n let pre = preNode._parent!;\n while (pre._left === preNode) {\n preNode = pre;\n pre = preNode._parent!;\n }\n preNode = pre;\n }\n return preNode;\n }\n /**\n * @description Get the next node.\n * @returns TreeNode about the next node.\n */\n _next() {\n let nextNode: TreeNode<K, V> = this;\n if (nextNode._right) {\n nextNode = nextNode._right;\n while (nextNode._left) {\n nextNode = nextNode._left;\n }\n return nextNode;\n } else {\n let pre = nextNode._parent!;\n while (pre._right === nextNode) {\n nextNode = pre;\n pre = nextNode._parent!;\n }\n if (nextNode._right !== pre) {\n return pre;\n } else return nextNode;\n }\n }\n /**\n * @description Rotate left.\n * @returns TreeNode about moved to original position after rotation.\n */\n _rotateLeft() {\n const PP = this._parent!;\n const V = this._right!;\n const R = V._left;\n\n if (PP._parent === this) PP._parent = V;\n else if (PP._left === this) PP._left = V;\n else PP._right = V;\n\n V._parent = PP;\n V._left = this;\n\n this._parent = V;\n this._right = R;\n\n if (R) R._parent = this;\n\n return V;\n }\n /**\n * @description Rotate right.\n * @returns TreeNode about moved to original position after rotation.\n */\n _rotateRight() {\n const PP = this._parent!;\n const F = this._left!;\n const K = F._right;\n\n if (PP._parent === this) PP._parent = F;\n else if (PP._left === this) PP._left = F;\n else PP._right = F;\n\n F._parent = PP;\n F._right = this;\n\n this._parent = F;\n this._left = K;\n\n if (K) K._parent = this;\n\n return F;\n }\n}\n\nexport class TreeNodeEnableIndex<K, V> extends TreeNode<K, V> {\n _subTreeSize = 1;\n /**\n * @description Rotate left and do recount.\n * @returns TreeNode about moved to original position after rotation.\n */\n _rotateLeft() {\n const parent = super._rotateLeft() as TreeNodeEnableIndex<K, V>;\n this._recount();\n parent._recount();\n return parent;\n }\n /**\n * @description Rotate right and do recount.\n * @returns TreeNode about moved to original position after rotation.\n */\n _rotateRight() {\n const parent = super._rotateRight() as TreeNodeEnableIndex<K, V>;\n this._recount();\n parent._recount();\n return parent;\n }\n _recount() {\n this._subTreeSize = 1;\n if (this._left) {\n this._subTreeSize += (this._left as TreeNodeEnableIndex<K, V>)._subTreeSize;\n }\n if (this._right) {\n this._subTreeSize += (this._right as TreeNodeEnableIndex<K, V>)._subTreeSize;\n }\n }\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport { TreeNode, TreeNodeEnableIndex } from './TreeNode';\nimport { Container } from \"../../ContainerBase\";\nimport $checkWithinAccessParams from \"../../../utils/checkParams.macro\";\nimport { throwIteratorAccessError } from \"../../../utils/throwError\";\nvar TreeContainer = /** @class */ (function (_super) {\n __extends(TreeContainer, _super);\n /**\n * @internal\n */\n function TreeContainer(cmp, enableIndex) {\n if (cmp === void 0) { cmp = function (x, y) {\n if (x < y)\n return -1;\n if (x > y)\n return 1;\n return 0;\n }; }\n if (enableIndex === void 0) { enableIndex = false; }\n var _this = _super.call(this) || this;\n /**\n * @internal\n */\n _this._root = undefined;\n _this._cmp = cmp;\n if (enableIndex) {\n _this._TreeNodeClass = TreeNodeEnableIndex;\n _this._set = function (key, value, hint) {\n var curNode = this._preSet(key, value, hint);\n if (curNode) {\n var p = curNode._parent;\n while (p !== this._header) {\n p._subTreeSize += 1;\n p = p._parent;\n }\n var nodeList = this._insertNodeSelfBalance(curNode);\n if (nodeList) {\n var _a = nodeList, parentNode = _a.parentNode, grandParent = _a.grandParent, curNode_1 = _a.curNode;\n parentNode._recount();\n grandParent._recount();\n curNode_1._recount();\n }\n }\n return this._length;\n };\n _this._eraseNode = function (curNode) {\n var p = this._preEraseNode(curNode);\n while (p !== this._header) {\n p._subTreeSize -= 1;\n p = p._parent;\n }\n };\n }\n else {\n _this._TreeNodeClass = TreeNode;\n _this._set = function (key, value, hint) {\n var curNode = this._preSet(key, value, hint);\n if (curNode)\n this._insertNodeSelfBalance(curNode);\n return this._length;\n };\n _this._eraseNode = _this._preEraseNode;\n }\n _this._header = new _this._TreeNodeClass();\n return _this;\n }\n /**\n * @internal\n */\n TreeContainer.prototype._lowerBound = function (curNode, key) {\n var resNode = this._header;\n while (curNode) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult < 0) {\n curNode = curNode._right;\n }\n else if (cmpResult > 0) {\n resNode = curNode;\n curNode = curNode._left;\n }\n else\n return curNode;\n }\n return resNode;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._upperBound = function (curNode, key) {\n var resNode = this._header;\n while (curNode) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult <= 0) {\n curNode = curNode._right;\n }\n else {\n resNode = curNode;\n curNode = curNode._left;\n }\n }\n return resNode;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._reverseLowerBound = function (curNode, key) {\n var resNode = this._header;\n while (curNode) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode._right;\n }\n else if (cmpResult > 0) {\n curNode = curNode._left;\n }\n else\n return curNode;\n }\n return resNode;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._reverseUpperBound = function (curNode, key) {\n var resNode = this._header;\n while (curNode) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode._right;\n }\n else {\n curNode = curNode._left;\n }\n }\n return resNode;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._eraseNodeSelfBalance = function (curNode) {\n while (true) {\n var parentNode = curNode._parent;\n if (parentNode === this._header)\n return;\n if (curNode._color === 1 /* TreeNodeColor.RED */) {\n curNode._color = 0 /* TreeNodeColor.BLACK */;\n return;\n }\n if (curNode === parentNode._left) {\n var brother = parentNode._right;\n if (brother._color === 1 /* TreeNodeColor.RED */) {\n brother._color = 0 /* TreeNodeColor.BLACK */;\n parentNode._color = 1 /* TreeNodeColor.RED */;\n if (parentNode === this._root) {\n this._root = parentNode._rotateLeft();\n }\n else\n parentNode._rotateLeft();\n }\n else {\n if (brother._right && brother._right._color === 1 /* TreeNodeColor.RED */) {\n brother._color = parentNode._color;\n parentNode._color = 0 /* TreeNodeColor.BLACK */;\n brother._right._color = 0 /* TreeNodeColor.BLACK */;\n if (parentNode === this._root) {\n this._root = parentNode._rotateLeft();\n }\n else\n parentNode._rotateLeft();\n return;\n }\n else if (brother._left && brother._left._color === 1 /* TreeNodeColor.RED */) {\n brother._color = 1 /* TreeNodeColor.RED */;\n brother._left._color = 0 /* TreeNodeColor.BLACK */;\n brother._rotateRight();\n }\n else {\n brother._color = 1 /* TreeNodeColor.RED */;\n curNode = parentNode;\n }\n }\n }\n else {\n var brother = parentNode._left;\n if (brother._color === 1 /* TreeNodeColor.RED */) {\n brother._color = 0 /* TreeNodeColor.BLACK */;\n parentNode._color = 1 /* TreeNodeColor.RED */;\n if (parentNode === this._root) {\n this._root = parentNode._rotateRight();\n }\n else\n parentNode._rotateRight();\n }\n else {\n if (brother._left && brother._left._color === 1 /* TreeNodeColor.RED */) {\n brother._color = parentNode._color;\n parentNode._color = 0 /* TreeNodeColor.BLACK */;\n brother._left._color = 0 /* TreeNodeColor.BLACK */;\n if (parentNode === this._root) {\n this._root = parentNode._rotateRight();\n }\n else\n parentNode._rotateRight();\n return;\n }\n else if (brother._right && brother._right._color === 1 /* TreeNodeColor.RED */) {\n brother._color = 1 /* TreeNodeColor.RED */;\n brother._right._color = 0 /* TreeNodeColor.BLACK */;\n brother._rotateLeft();\n }\n else {\n brother._color = 1 /* TreeNodeColor.RED */;\n curNode = parentNode;\n }\n }\n }\n }\n };\n /**\n * @internal\n */\n TreeContainer.prototype._preEraseNode = function (curNode) {\n var _a, _b;\n if (this._length === 1) {\n this.clear();\n return this._header;\n }\n var swapNode = curNode;\n while (swapNode._left || swapNode._right) {\n if (swapNode._right) {\n swapNode = swapNode._right;\n while (swapNode._left)\n swapNode = swapNode._left;\n }\n else {\n swapNode = swapNode._left;\n }\n _a = __read([swapNode._key, curNode._key], 2), curNode._key = _a[0], swapNode._key = _a[1];\n _b = __read([swapNode._value, curNode._value], 2), curNode._value = _b[0], swapNode._value = _b[1];\n curNode = swapNode;\n }\n if (this._header._left === swapNode) {\n this._header._left = swapNode._parent;\n }\n else if (this._header._right === swapNode) {\n this._header._right = swapNode._parent;\n }\n this._eraseNodeSelfBalance(swapNode);\n var _parent = swapNode._parent;\n if (swapNode === _parent._left) {\n _parent._left = undefined;\n }\n else\n _parent._right = undefined;\n this._length -= 1;\n this._root._color = 0 /* TreeNodeColor.BLACK */;\n return _parent;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._inOrderTraversal = function (curNode, callback) {\n if (curNode === undefined)\n return false;\n var ifReturn = this._inOrderTraversal(curNode._left, callback);\n if (ifReturn)\n return true;\n if (callback(curNode))\n return true;\n return this._inOrderTraversal(curNode._right, callback);\n };\n /**\n * @internal\n */\n TreeContainer.prototype._insertNodeSelfBalance = function (curNode) {\n while (true) {\n var parentNode = curNode._parent;\n if (parentNode._color === 0 /* TreeNodeColor.BLACK */)\n return;\n var grandParent = parentNode._parent;\n if (parentNode === grandParent._left) {\n var uncle = grandParent._right;\n if (uncle && uncle._color === 1 /* TreeNodeColor.RED */) {\n uncle._color = parentNode._color = 0 /* TreeNodeColor.BLACK */;\n if (grandParent === this._root)\n return;\n grandParent._color = 1 /* TreeNodeColor.RED */;\n curNode = grandParent;\n continue;\n }\n else if (curNode === parentNode._right) {\n curNode._color = 0 /* TreeNodeColor.BLACK */;\n if (curNode._left)\n curNode._left._parent = parentNode;\n if (curNode._right)\n curNode._right._parent = grandParent;\n parentNode._right = curNode._left;\n grandParent._left = curNode._right;\n curNode._left = parentNode;\n curNode._right = grandParent;\n if (grandParent === this._root) {\n this._root = curNode;\n this._header._parent = curNode;\n }\n else {\n var GP = grandParent._parent;\n if (GP._left === grandParent) {\n GP._left = curNode;\n }\n else\n GP._right = curNode;\n }\n curNode._parent = grandParent._parent;\n parentNode._parent = curNode;\n grandParent._parent = curNode;\n grandParent._color = 1 /* TreeNodeColor.RED */;\n return { parentNode: parentNode, grandParent: grandParent, curNode: curNode };\n }\n else {\n parentNode._color = 0 /* TreeNodeColor.BLACK */;\n if (grandParent === this._root) {\n this._root = grandParent._rotateRight();\n }\n else\n grandParent._rotateRight();\n grandParent._color = 1 /* TreeNodeColor.RED */;\n }\n }\n else {\n var uncle = grandParent._left;\n if (uncle && uncle._color === 1 /* TreeNodeColor.RED */) {\n uncle._color = parentNode._color = 0 /* TreeNodeColor.BLACK */;\n if (grandParent === this._root)\n return;\n grandParent._color = 1 /* TreeNodeColor.RED */;\n curNode = grandParent;\n continue;\n }\n else if (curNode === parentNode._left) {\n curNode._color = 0 /* TreeNodeColor.BLACK */;\n if (curNode._left)\n curNode._left._parent = grandParent;\n if (curNode._right)\n curNode._right._parent = parentNode;\n grandParent._right = curNode._left;\n parentNode._left = curNode._right;\n curNode._left = grandParent;\n curNode._right = parentNode;\n if (grandParent === this._root) {\n this._root = curNode;\n this._header._parent = curNode;\n }\n else {\n var GP = grandParent._parent;\n if (GP._left === grandParent) {\n GP._left = curNode;\n }\n else\n GP._right = curNode;\n }\n curNode._parent = grandParent._parent;\n parentNode._parent = curNode;\n grandParent._parent = curNode;\n grandParent._color = 1 /* TreeNodeColor.RED */;\n return { parentNode: parentNode, grandParent: grandParent, curNode: curNode };\n }\n else {\n parentNode._color = 0 /* TreeNodeColor.BLACK */;\n if (grandParent === this._root) {\n this._root = grandParent._rotateLeft();\n }\n else\n grandParent._rotateLeft();\n grandParent._color = 1 /* TreeNodeColor.RED */;\n }\n }\n return;\n }\n };\n /**\n * @internal\n */\n TreeContainer.prototype._preSet = function (key, value, hint) {\n if (this._root === undefined) {\n this._length += 1;\n this._root = new this._TreeNodeClass(key, value);\n this._root._color = 0 /* TreeNodeColor.BLACK */;\n this._root._parent = this._header;\n this._header._parent = this._root;\n this._header._left = this._root;\n this._header._right = this._root;\n return;\n }\n var curNode;\n var minNode = this._header._left;\n var compareToMin = this._cmp(minNode._key, key);\n if (compareToMin === 0) {\n minNode._value = value;\n return;\n }\n else if (compareToMin > 0) {\n minNode._left = new this._TreeNodeClass(key, value);\n minNode._left._parent = minNode;\n curNode = minNode._left;\n this._header._left = curNode;\n }\n else {\n var maxNode = this._header._right;\n var compareToMax = this._cmp(maxNode._key, key);\n if (compareToMax === 0) {\n maxNode._value = value;\n return;\n }\n else if (compareToMax < 0) {\n maxNode._right = new this._TreeNodeClass(key, value);\n maxNode._right._parent = maxNode;\n curNode = maxNode._right;\n this._header._right = curNode;\n }\n else {\n if (hint !== undefined) {\n var iterNode = hint._node;\n if (iterNode !== this._header) {\n var iterCmpRes = this._cmp(iterNode._key, key);\n if (iterCmpRes === 0) {\n iterNode._value = value;\n return;\n }\n else /* istanbul ignore else */ if (iterCmpRes > 0) {\n var preNode = iterNode._pre();\n var preCmpRes = this._cmp(preNode._key, key);\n if (preCmpRes === 0) {\n preNode._value = value;\n return;\n }\n else if (preCmpRes < 0) {\n curNode = new this._TreeNodeClass(key, value);\n if (preNode._right === undefined) {\n preNode._right = curNode;\n curNode._parent = preNode;\n }\n else {\n iterNode._left = curNode;\n curNode._parent = iterNode;\n }\n }\n }\n }\n }\n if (curNode === undefined) {\n curNode = this._root;\n while (true) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult > 0) {\n if (curNode._left === undefined) {\n curNode._left = new this._TreeNodeClass(key, value);\n curNode._left._parent = curNode;\n curNode = curNode._left;\n break;\n }\n curNode = curNode._left;\n }\n else if (cmpResult < 0) {\n if (curNode._right === undefined) {\n curNode._right = new this._TreeNodeClass(key, value);\n curNode._right._parent = curNode;\n curNode = curNode._right;\n break;\n }\n curNode = curNode._right;\n }\n else {\n curNode._value = value;\n return;\n }\n }\n }\n }\n }\n this._length += 1;\n return curNode;\n };\n /**\n * @internal\n */\n TreeContainer.prototype._findElementNode = function (curNode, key) {\n while (curNode) {\n var cmpResult = this._cmp(curNode._key, key);\n if (cmpResult < 0) {\n curNode = curNode._right;\n }\n else if (cmpResult > 0) {\n curNode = curNode._left;\n }\n else\n return curNode;\n }\n return curNode || this._header;\n };\n TreeContainer.prototype.clear = function () {\n this._length = 0;\n this._root = undefined;\n this._header._parent = undefined;\n this._header._left = this._header._right = undefined;\n };\n /**\n * @description Update node's key by iterator.\n * @param iter - The iterator you want to change.\n * @param key - The key you want to update.\n * @returns Whether the modification is successful.\n * @example\n * const st = new orderedSet([1, 2, 5]);\n * const iter = st.find(2);\n * st.updateKeyByIterator(iter, 3); // then st will become [1, 3, 5]\n */\n TreeContainer.prototype.updateKeyByIterator = function (iter, key) {\n var node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n if (this._length === 1) {\n node._key = key;\n return true;\n }\n if (node === this._header._left) {\n if (this._cmp(node._next()._key, key) > 0) {\n node._key = key;\n return true;\n }\n return false;\n }\n if (node === this._header._right) {\n if (this._cmp(node._pre()._key, key) < 0) {\n node._key = key;\n return true;\n }\n return false;\n }\n var preKey = node._pre()._key;\n if (this._cmp(preKey, key) >= 0)\n return false;\n var nextKey = node._next()._key;\n if (this._cmp(nextKey, key) <= 0)\n return false;\n node._key = key;\n return true;\n };\n TreeContainer.prototype.eraseElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var index = 0;\n var self = this;\n this._inOrderTraversal(this._root, function (curNode) {\n if (pos === index) {\n self._eraseNode(curNode);\n return true;\n }\n index += 1;\n return false;\n });\n return this._length;\n };\n /**\n * @description Remove the element of the specified key.\n * @param key - The key you want to remove.\n * @returns Whether erase successfully.\n */\n TreeContainer.prototype.eraseElementByKey = function (key) {\n if (this._length === 0)\n return false;\n var curNode = this._findElementNode(this._root, key);\n if (curNode === this._header)\n return false;\n this._eraseNode(curNode);\n return true;\n };\n TreeContainer.prototype.eraseElementByIterator = function (iter) {\n var node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n var hasNoRight = node._right === undefined;\n var isNormal = iter.iteratorType === 0 /* IteratorType.NORMAL */;\n // For the normal iterator, the `next` node will be swapped to `this` node when has right.\n if (isNormal) {\n // So we should move it to next when it's right is null.\n if (hasNoRight)\n iter.next();\n }\n else {\n // For the reverse iterator, only when it doesn't have right and has left the `next` node will be swapped.\n // So when it has right, or it is a leaf node we should move it to `next`.\n if (!hasNoRight || node._left === undefined)\n iter.next();\n }\n this._eraseNode(node);\n return iter;\n };\n TreeContainer.prototype.forEach = function (callback) {\n var e_1, _a;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var element = _c.value;\n callback(element, index++, this);\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n };\n TreeContainer.prototype.getElementByPos = function (pos) {\n var e_2, _a;\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var res;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var element = _c.value;\n if (index === pos) {\n res = element;\n break;\n }\n index += 1;\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_2) throw e_2.error; }\n }\n return res;\n };\n /**\n * @description Get the height of the tree.\n * @returns Number about the height of the RB-tree.\n */\n TreeContainer.prototype.getHeight = function () {\n if (this._length === 0)\n return 0;\n var traversal = function (curNode) {\n if (!curNode)\n return 0;\n return Math.max(traversal(curNode._left), traversal(curNode._right)) + 1;\n };\n return traversal(this._root);\n };\n return TreeContainer;\n}(Container));\nexport default TreeContainer;\n","import type TreeIterator from './TreeIterator';\nimport { TreeNode, TreeNodeColor, TreeNodeEnableIndex } from './TreeNode';\nimport { Container, IteratorType } from '@/container/ContainerBase';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nabstract class TreeContainer<K, V> extends Container<K | [K, V]> {\n /**\n * @internal\n */\n protected _root: TreeNode<K, V> | undefined = undefined;\n /**\n * @internal\n */\n protected _header: TreeNode<K, V>;\n /**\n * @internal\n */\n protected readonly _cmp: (x: K, y: K) => number;\n /**\n * @internal\n */\n protected readonly _TreeNodeClass: typeof TreeNode | typeof TreeNodeEnableIndex;\n /**\n * @internal\n */\n protected readonly _eraseNode: (curNode: TreeNode<K, V>) => void;\n /**\n * @internal\n */\n protected _set: (key: K, value: V, hint?: TreeIterator<K, V>) => number;\n /**\n * @internal\n */\n protected constructor(\n cmp: (x: K, y: K) => number =\n function (x: K, y: K) {\n if (x < y) return -1;\n if (x > y) return 1;\n return 0;\n },\n enableIndex = false\n ) {\n super();\n this._cmp = cmp;\n if (enableIndex) {\n this._TreeNodeClass = TreeNodeEnableIndex;\n this._set = function (key, value, hint) {\n const curNode = this._preSet(key, value, hint);\n if (curNode) {\n let p = curNode._parent as TreeNodeEnableIndex<K, V>;\n while (p !== this._header) {\n p._subTreeSize += 1;\n p = p._parent as TreeNodeEnableIndex<K, V>;\n }\n const nodeList = this._insertNodeSelfBalance(curNode);\n if (nodeList) {\n const {\n parentNode,\n grandParent,\n curNode\n } = nodeList as unknown as Record<string, TreeNodeEnableIndex<K, V>>;\n parentNode._recount();\n grandParent._recount();\n curNode._recount();\n }\n }\n return this._length;\n };\n this._eraseNode = function (curNode) {\n let p = this._preEraseNode(curNode) as TreeNodeEnableIndex<K, V>;\n while (p !== this._header) {\n p._subTreeSize -= 1;\n p = p._parent as TreeNodeEnableIndex<K, V>;\n }\n };\n } else {\n this._TreeNodeClass = TreeNode;\n this._set = function (key, value, hint) {\n const curNode = this._preSet(key, value, hint);\n if (curNode) this._insertNodeSelfBalance(curNode);\n return this._length;\n };\n this._eraseNode = this._preEraseNode;\n }\n this._header = new this._TreeNodeClass();\n }\n /**\n * @internal\n */\n protected _lowerBound(curNode: TreeNode<K, V> | undefined, key: K) {\n let resNode = this._header;\n while (curNode) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult < 0) {\n curNode = curNode._right;\n } else if (cmpResult > 0) {\n resNode = curNode;\n curNode = curNode._left;\n } else return curNode;\n }\n return resNode;\n }\n /**\n * @internal\n */\n protected _upperBound(curNode: TreeNode<K, V> | undefined, key: K) {\n let resNode = this._header;\n while (curNode) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult <= 0) {\n curNode = curNode._right;\n } else {\n resNode = curNode;\n curNode = curNode._left;\n }\n }\n return resNode;\n }\n /**\n * @internal\n */\n protected _reverseLowerBound(curNode: TreeNode<K, V> | undefined, key: K) {\n let resNode = this._header;\n while (curNode) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode._right;\n } else if (cmpResult > 0) {\n curNode = curNode._left;\n } else return curNode;\n }\n return resNode;\n }\n /**\n * @internal\n */\n protected _reverseUpperBound(curNode: TreeNode<K, V> | undefined, key: K) {\n let resNode = this._header;\n while (curNode) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode._right;\n } else {\n curNode = curNode._left;\n }\n }\n return resNode;\n }\n /**\n * @internal\n */\n protected _eraseNodeSelfBalance(curNode: TreeNode<K, V>) {\n while (true) {\n const parentNode = curNode._parent!;\n if (parentNode === this._header) return;\n if (curNode._color === TreeNodeColor.RED) {\n curNode._color = TreeNodeColor.BLACK;\n return;\n }\n if (curNode === parentNode._left) {\n const brother = parentNode._right!;\n if (brother._color === TreeNodeColor.RED) {\n brother._color = TreeNodeColor.BLACK;\n parentNode._color = TreeNodeColor.RED;\n if (parentNode === this._root) {\n this._root = parentNode._rotateLeft();\n } else parentNode._rotateLeft();\n } else {\n if (brother._right && brother._right._color === TreeNodeColor.RED) {\n brother._color = parentNode._color;\n parentNode._color = TreeNodeColor.BLACK;\n brother._right._color = TreeNodeColor.BLACK;\n if (parentNode === this._root) {\n this._root = parentNode._rotateLeft();\n } else parentNode._rotateLeft();\n return;\n } else if (brother._left && brother._left._color === TreeNodeColor.RED) {\n brother._color = TreeNodeColor.RED;\n brother._left._color = TreeNodeColor.BLACK;\n brother._rotateRight();\n } else {\n brother._color = TreeNodeColor.RED;\n curNode = parentNode;\n }\n }\n } else {\n const brother = parentNode._left!;\n if (brother._color === TreeNodeColor.RED) {\n brother._color = TreeNodeColor.BLACK;\n parentNode._color = TreeNodeColor.RED;\n if (parentNode === this._root) {\n this._root = parentNode._rotateRight();\n } else parentNode._rotateRight();\n } else {\n if (brother._left && brother._left._color === TreeNodeColor.RED) {\n brother._color = parentNode._color;\n parentNode._color = TreeNodeColor.BLACK;\n brother._left._color = TreeNodeColor.BLACK;\n if (parentNode === this._root) {\n this._root = parentNode._rotateRight();\n } else parentNode._rotateRight();\n return;\n } else if (brother._right && brother._right._color === TreeNodeColor.RED) {\n brother._color = TreeNodeColor.RED;\n brother._right._color = TreeNodeColor.BLACK;\n brother._rotateLeft();\n } else {\n brother._color = TreeNodeColor.RED;\n curNode = parentNode;\n }\n }\n }\n }\n }\n /**\n * @internal\n */\n protected _preEraseNode(curNode: TreeNode<K, V>) {\n if (this._length === 1) {\n this.clear();\n return this._header;\n }\n let swapNode = curNode;\n while (swapNode._left || swapNode._right) {\n if (swapNode._right) {\n swapNode = swapNode._right;\n while (swapNode._left) swapNode = swapNode._left;\n } else {\n swapNode = swapNode._left!;\n }\n [curNode._key, swapNode._key] = [swapNode._key, curNode._key];\n [curNode._value, swapNode._value] = [swapNode._value, curNode._value];\n curNode = swapNode;\n }\n if (this._header._left === swapNode) {\n this._header._left = swapNode._parent;\n } else if (this._header._right === swapNode) {\n this._header._right = swapNode._parent;\n }\n this._eraseNodeSelfBalance(swapNode);\n const _parent = swapNode._parent!;\n if (swapNode === _parent._left) {\n _parent._left = undefined;\n } else _parent._right = undefined;\n this._length -= 1;\n this._root!._color = TreeNodeColor.BLACK;\n return _parent;\n }\n /**\n * @internal\n */\n protected _inOrderTraversal(\n curNode: TreeNode<K, V> | undefined,\n callback: (curNode: TreeNode<K, V>) => boolean\n ): boolean {\n if (curNode === undefined) return false;\n const ifReturn = this._inOrderTraversal(curNode._left, callback);\n if (ifReturn) return true;\n if (callback(curNode)) return true;\n return this._inOrderTraversal(curNode._right, callback);\n }\n /**\n * @internal\n */\n protected _insertNodeSelfBalance(curNode: TreeNode<K, V>) {\n while (true) {\n const parentNode = curNode._parent!;\n if (parentNode._color === TreeNodeColor.BLACK) return;\n const grandParent = parentNode._parent!;\n if (parentNode === grandParent._left) {\n const uncle = grandParent._right;\n if (uncle && uncle._color === TreeNodeColor.RED) {\n uncle._color = parentNode._color = TreeNodeColor.BLACK;\n if (grandParent === this._root) return;\n grandParent._color = TreeNodeColor.RED;\n curNode = grandParent;\n continue;\n } else if (curNode === parentNode._right) {\n curNode._color = TreeNodeColor.BLACK;\n if (curNode._left) curNode._left._parent = parentNode;\n if (curNode._right) curNode._right._parent = grandParent;\n parentNode._right = curNode._left;\n grandParent._left = curNode._right;\n curNode._left = parentNode;\n curNode._right = grandParent;\n if (grandParent === this._root) {\n this._root = curNode;\n this._header._parent = curNode;\n } else {\n const GP = grandParent._parent!;\n if (GP._left === grandParent) {\n GP._left = curNode;\n } else GP._right = curNode;\n }\n curNode._parent = grandParent._parent;\n parentNode._parent = curNode;\n grandParent._parent = curNode;\n grandParent._color = TreeNodeColor.RED;\n return { parentNode, grandParent, curNode };\n } else {\n parentNode._color = TreeNodeColor.BLACK;\n if (grandParent === this._root) {\n this._root = grandParent._rotateRight();\n } else grandParent._rotateRight();\n grandParent._color = TreeNodeColor.RED;\n }\n } else {\n const uncle = grandParent._left;\n if (uncle && uncle._color === TreeNodeColor.RED) {\n uncle._color = parentNode._color = TreeNodeColor.BLACK;\n if (grandParent === this._root) return;\n grandParent._color = TreeNodeColor.RED;\n curNode = grandParent;\n continue;\n } else if (curNode === parentNode._left) {\n curNode._color = TreeNodeColor.BLACK;\n if (curNode._left) curNode._left._parent = grandParent;\n if (curNode._right) curNode._right._parent = parentNode;\n grandParent._right = curNode._left;\n parentNode._left = curNode._right;\n curNode._left = grandParent;\n curNode._right = parentNode;\n if (grandParent === this._root) {\n this._root = curNode;\n this._header._parent = curNode;\n } else {\n const GP = grandParent._parent!;\n if (GP._left === grandParent) {\n GP._left = curNode;\n } else GP._right = curNode;\n }\n curNode._parent = grandParent._parent;\n parentNode._parent = curNode;\n grandParent._parent = curNode;\n grandParent._color = TreeNodeColor.RED;\n return { parentNode, grandParent, curNode };\n } else {\n parentNode._color = TreeNodeColor.BLACK;\n if (grandParent === this._root) {\n this._root = grandParent._rotateLeft();\n } else grandParent._rotateLeft();\n grandParent._color = TreeNodeColor.RED;\n }\n }\n return;\n }\n }\n /**\n * @internal\n */\n protected _preSet(key: K, value?: V, hint?: TreeIterator<K, V>) {\n if (this._root === undefined) {\n this._length += 1;\n this._root = new this._TreeNodeClass(key, value);\n this._root._color = TreeNodeColor.BLACK;\n this._root._parent = this._header;\n this._header._parent = this._root;\n this._header._left = this._root;\n this._header._right = this._root;\n return;\n }\n let curNode;\n const minNode = this._header._left!;\n const compareToMin = this._cmp(minNode._key!, key);\n if (compareToMin === 0) {\n minNode._value = value;\n return;\n } else if (compareToMin > 0) {\n minNode._left = new this._TreeNodeClass(key, value);\n minNode._left._parent = minNode;\n curNode = minNode._left;\n this._header._left = curNode;\n } else {\n const maxNode = this._header._right!;\n const compareToMax = this._cmp(maxNode._key!, key);\n if (compareToMax === 0) {\n maxNode._value = value;\n return;\n } else if (compareToMax < 0) {\n maxNode._right = new this._TreeNodeClass(key, value);\n maxNode._right._parent = maxNode;\n curNode = maxNode._right;\n this._header._right = curNode;\n } else {\n if (hint !== undefined) {\n const iterNode = hint._node;\n if (iterNode !== this._header) {\n const iterCmpRes = this._cmp(iterNode._key!, key);\n if (iterCmpRes === 0) {\n iterNode._value = value;\n return;\n } else /* istanbul ignore else */ if (iterCmpRes > 0) {\n const preNode = iterNode._pre();\n const preCmpRes = this._cmp(preNode._key!, key);\n if (preCmpRes === 0) {\n preNode._value = value;\n return;\n } else if (preCmpRes < 0) {\n curNode = new this._TreeNodeClass(key, value);\n if (preNode._right === undefined) {\n preNode._right = curNode;\n curNode._parent = preNode;\n } else {\n iterNode._left = curNode;\n curNode._parent = iterNode;\n }\n }\n }\n }\n }\n if (curNode === undefined) {\n curNode = this._root;\n while (true) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult > 0) {\n if (curNode._left === undefined) {\n curNode._left = new this._TreeNodeClass(key, value);\n curNode._left._parent = curNode;\n curNode = curNode._left;\n break;\n }\n curNode = curNode._left;\n } else if (cmpResult < 0) {\n if (curNode._right === undefined) {\n curNode._right = new this._TreeNodeClass(key, value);\n curNode._right._parent = curNode;\n curNode = curNode._right;\n break;\n }\n curNode = curNode._right;\n } else {\n curNode._value = value;\n return;\n }\n }\n }\n }\n }\n this._length += 1;\n return curNode;\n }\n /**\n * @internal\n */\n protected _findElementNode(curNode: TreeNode<K, V> | undefined, key: K) {\n while (curNode) {\n const cmpResult = this._cmp(curNode._key!, key);\n if (cmpResult < 0) {\n curNode = curNode._right;\n } else if (cmpResult > 0) {\n curNode = curNode._left;\n } else return curNode;\n }\n return curNode || this._header;\n }\n clear() {\n this._length = 0;\n this._root = undefined;\n this._header._parent = undefined;\n this._header._left = this._header._right = undefined;\n }\n /**\n * @description Update node's key by iterator.\n * @param iter - The iterator you want to change.\n * @param key - The key you want to update.\n * @returns Whether the modification is successful.\n * @example\n * const st = new orderedSet([1, 2, 5]);\n * const iter = st.find(2);\n * st.updateKeyByIterator(iter, 3); // then st will become [1, 3, 5]\n */\n updateKeyByIterator(iter: TreeIterator<K, V>, key: K): boolean {\n const node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n if (this._length === 1) {\n node._key = key;\n return true;\n }\n if (node === this._header._left) {\n if (this._cmp(node._next()._key!, key) > 0) {\n node._key = key;\n return true;\n }\n return false;\n }\n if (node === this._header._right) {\n if (this._cmp(node._pre()._key!, key) < 0) {\n node._key = key;\n return true;\n }\n return false;\n }\n const preKey = node._pre()._key!;\n if (this._cmp(preKey, key) >= 0) return false;\n const nextKey = node._next()._key!;\n if (this._cmp(nextKey, key) <= 0) return false;\n node._key = key;\n return true;\n }\n eraseElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let index = 0;\n const self = this;\n this._inOrderTraversal(\n this._root,\n function (curNode) {\n if (pos === index) {\n self._eraseNode(curNode);\n return true;\n }\n index += 1;\n return false;\n });\n return this._length;\n }\n /**\n * @description Remove the element of the specified key.\n * @param key - The key you want to remove.\n * @returns Whether erase successfully.\n */\n eraseElementByKey(key: K) {\n if (this._length === 0) return false;\n const curNode = this._findElementNode(this._root, key);\n if (curNode === this._header) return false;\n this._eraseNode(curNode);\n return true;\n }\n eraseElementByIterator(iter: TreeIterator<K, V>) {\n const node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n const hasNoRight = node._right === undefined;\n const isNormal = iter.iteratorType === IteratorType.NORMAL;\n // For the normal iterator, the `next` node will be swapped to `this` node when has right.\n if (isNormal) {\n // So we should move it to next when it's right is null.\n if (hasNoRight) iter.next();\n } else {\n // For the reverse iterator, only when it doesn't have right and has left the `next` node will be swapped.\n // So when it has right, or it is a leaf node we should move it to `next`.\n if (!hasNoRight || node._left === undefined) iter.next();\n }\n this._eraseNode(node);\n return iter;\n }\n forEach(callback: (element: K | [K, V], index: number, tree: TreeContainer<K, V>) => void) {\n let index = 0;\n for (const element of this) callback(element, index++, this);\n }\n getElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let res;\n let index = 0;\n for (const element of this) {\n if (index === pos) {\n res = element;\n break;\n }\n index += 1;\n }\n return <K | [K, V]>res;\n }\n /**\n * @description Get the height of the tree.\n * @returns Number about the height of the RB-tree.\n */\n getHeight() {\n if (this._length === 0) return 0;\n const traversal =\n function (curNode: TreeNode<K, V> | undefined): number {\n if (!curNode) return 0;\n return Math.max(traversal(curNode._left), traversal(curNode._right)) + 1;\n };\n return traversal(this._root);\n }\n /**\n * @param key - The given key you want to compare.\n * @returns An iterator to the first element less than the given key.\n */\n abstract reverseUpperBound(key: K): TreeIterator<K, V>;\n /**\n * @description Union the other tree to self.\n * @param other - The other tree container you want to merge.\n * @returns The size of the tree after union.\n */\n abstract union(other: TreeContainer<K, V>): number;\n /**\n * @param key - The given key you want to compare.\n * @returns An iterator to the first element not greater than the given key.\n */\n abstract reverseLowerBound(key: K): TreeIterator<K, V>;\n /**\n * @param key - The given key you want to compare.\n * @returns An iterator to the first element not less than the given key.\n */\n abstract lowerBound(key: K): TreeIterator<K, V>;\n /**\n * @param key - The given key you want to compare.\n * @returns An iterator to the first element greater than the given key.\n */\n abstract upperBound(key: K): TreeIterator<K, V>;\n}\n\nexport default TreeContainer;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { ContainerIterator } from \"../../ContainerBase\";\nimport { throwIteratorAccessError } from \"../../../utils/throwError\";\nvar TreeIterator = /** @class */ (function (_super) {\n __extends(TreeIterator, _super);\n /**\n * @internal\n */\n function TreeIterator(node, header, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this._node = node;\n _this._header = header;\n if (_this.iteratorType === 0 /* IteratorType.NORMAL */) {\n _this.pre = function () {\n if (this._node === this._header._left) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre();\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next();\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this._node === this._header._right) {\n throwIteratorAccessError();\n }\n this._node = this._node._next();\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre();\n return this;\n };\n }\n return _this;\n }\n Object.defineProperty(TreeIterator.prototype, \"index\", {\n /**\n * @description Get the sequential index of the iterator in the tree container.<br/>\n * <strong>Note:</strong>\n * This function only takes effect when the specified tree container `enableIndex = true`.\n * @returns The index subscript of the node in the tree.\n * @example\n * const st = new OrderedSet([1, 2, 3], true);\n * console.log(st.begin().next().index); // 1\n */\n get: function () {\n var _node = this._node;\n var root = this._header._parent;\n if (_node === this._header) {\n if (root) {\n return root._subTreeSize - 1;\n }\n return 0;\n }\n var index = 0;\n if (_node._left) {\n index += _node._left._subTreeSize;\n }\n while (_node !== root) {\n var _parent = _node._parent;\n if (_node === _parent._right) {\n index += 1;\n if (_parent._left) {\n index += _parent._left._subTreeSize;\n }\n }\n _node = _parent;\n }\n return index;\n },\n enumerable: false,\n configurable: true\n });\n return TreeIterator;\n}(ContainerIterator));\nexport default TreeIterator;\n","import { TreeNode } from './TreeNode';\nimport type { TreeNodeEnableIndex } from './TreeNode';\nimport { ContainerIterator, IteratorType } from '@/container/ContainerBase';\nimport TreeContainer from '@/container/TreeContainer/Base/index';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nabstract class TreeIterator<K, V> extends ContainerIterator<K | [K, V]> {\n abstract readonly container: TreeContainer<K, V>;\n /**\n * @internal\n */\n _node: TreeNode<K, V>;\n /**\n * @internal\n */\n protected _header: TreeNode<K, V>;\n /**\n * @internal\n */\n protected constructor(\n node: TreeNode<K, V>,\n header: TreeNode<K, V>,\n iteratorType?: IteratorType\n ) {\n super(iteratorType);\n this._node = node;\n this._header = header;\n if (this.iteratorType === IteratorType.NORMAL) {\n this.pre = function () {\n if (this._node === this._header._left) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre();\n return this;\n };\n\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next();\n return this;\n };\n } else {\n this.pre = function () {\n if (this._node === this._header._right) {\n throwIteratorAccessError();\n }\n this._node = this._node._next();\n return this;\n };\n\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre();\n return this;\n };\n }\n }\n /**\n * @description Get the sequential index of the iterator in the tree container.<br/>\n * <strong>Note:</strong>\n * This function only takes effect when the specified tree container `enableIndex = true`.\n * @returns The index subscript of the node in the tree.\n * @example\n * const st = new OrderedSet([1, 2, 3], true);\n * console.log(st.begin().next().index); // 1\n */\n get index() {\n let _node = this._node as TreeNodeEnableIndex<K, V>;\n const root = this._header._parent as TreeNodeEnableIndex<K, V>;\n if (_node === this._header) {\n if (root) {\n return root._subTreeSize - 1;\n }\n return 0;\n }\n let index = 0;\n if (_node._left) {\n index += (_node._left as TreeNodeEnableIndex<K, V>)._subTreeSize;\n }\n while (_node !== root) {\n const _parent = _node._parent as TreeNodeEnableIndex<K, V>;\n if (_node === _parent._right) {\n index += 1;\n if (_parent._left) {\n index += (_parent._left as TreeNodeEnableIndex<K, V>)._subTreeSize;\n }\n }\n _node = _parent;\n }\n return index;\n }\n // @ts-ignore\n pre(): this;\n // @ts-ignore\n next(): this;\n}\n\nexport default TreeIterator;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport TreeContainer from './Base';\nimport TreeIterator from './Base/TreeIterator';\nimport { throwIteratorAccessError } from \"../../utils/throwError\";\nvar OrderedSetIterator = /** @class */ (function (_super) {\n __extends(OrderedSetIterator, _super);\n function OrderedSetIterator(node, header, container, iteratorType) {\n var _this = _super.call(this, node, header, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n Object.defineProperty(OrderedSetIterator.prototype, \"pointer\", {\n get: function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._key;\n },\n enumerable: false,\n configurable: true\n });\n OrderedSetIterator.prototype.copy = function () {\n return new OrderedSetIterator(this._node, this._header, this.container, this.iteratorType);\n };\n return OrderedSetIterator;\n}(TreeIterator));\nvar OrderedSet = /** @class */ (function (_super) {\n __extends(OrderedSet, _super);\n /**\n * @param container - The initialization container.\n * @param cmp - The compare function.\n * @param enableIndex - Whether to enable iterator indexing function.\n * @example\n * new OrderedSet();\n * new OrderedSet([0, 1, 2]);\n * new OrderedSet([0, 1, 2], (x, y) => x - y);\n * new OrderedSet([0, 1, 2], (x, y) => x - y, true);\n */\n function OrderedSet(container, cmp, enableIndex) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, cmp, enableIndex) || this;\n var self = _this;\n container.forEach(function (el) {\n self.insert(el);\n });\n return _this;\n }\n /**\n * @internal\n */\n OrderedSet.prototype._iterationFunc = function (curNode) {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (curNode === undefined)\n return [2 /*return*/];\n return [5 /*yield**/, __values(this._iterationFunc(curNode._left))];\n case 1:\n _a.sent();\n return [4 /*yield*/, curNode._key];\n case 2:\n _a.sent();\n return [5 /*yield**/, __values(this._iterationFunc(curNode._right))];\n case 3:\n _a.sent();\n return [2 /*return*/];\n }\n });\n };\n OrderedSet.prototype.begin = function () {\n return new OrderedSetIterator(this._header._left || this._header, this._header, this);\n };\n OrderedSet.prototype.end = function () {\n return new OrderedSetIterator(this._header, this._header, this);\n };\n OrderedSet.prototype.rBegin = function () {\n return new OrderedSetIterator(this._header._right || this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n OrderedSet.prototype.rEnd = function () {\n return new OrderedSetIterator(this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n OrderedSet.prototype.front = function () {\n return this._header._left ? this._header._left._key : undefined;\n };\n OrderedSet.prototype.back = function () {\n return this._header._right ? this._header._right._key : undefined;\n };\n /**\n * @description Insert element to set.\n * @param key - The key want to insert.\n * @param hint - You can give an iterator hint to improve insertion efficiency.\n * @return The size of container after setting.\n * @example\n * const st = new OrderedSet([2, 4, 5]);\n * const iter = st.begin();\n * st.insert(1);\n * st.insert(3, iter); // give a hint will be faster.\n */\n OrderedSet.prototype.insert = function (key, hint) {\n return this._set(key, undefined, hint);\n };\n OrderedSet.prototype.find = function (element) {\n var resNode = this._findElementNode(this._root, element);\n return new OrderedSetIterator(resNode, this._header, this);\n };\n OrderedSet.prototype.lowerBound = function (key) {\n var resNode = this._lowerBound(this._root, key);\n return new OrderedSetIterator(resNode, this._header, this);\n };\n OrderedSet.prototype.upperBound = function (key) {\n var resNode = this._upperBound(this._root, key);\n return new OrderedSetIterator(resNode, this._header, this);\n };\n OrderedSet.prototype.reverseLowerBound = function (key) {\n var resNode = this._reverseLowerBound(this._root, key);\n return new OrderedSetIterator(resNode, this._header, this);\n };\n OrderedSet.prototype.reverseUpperBound = function (key) {\n var resNode = this._reverseUpperBound(this._root, key);\n return new OrderedSetIterator(resNode, this._header, this);\n };\n OrderedSet.prototype.union = function (other) {\n var self = this;\n other.forEach(function (el) {\n self.insert(el);\n });\n return this._length;\n };\n OrderedSet.prototype[Symbol.iterator] = function () {\n return this._iterationFunc(this._root);\n };\n return OrderedSet;\n}(TreeContainer));\nexport default OrderedSet;\n","import TreeContainer from './Base';\nimport TreeIterator from './Base/TreeIterator';\nimport { TreeNode } from './Base/TreeNode';\nimport { initContainer, IteratorType } from '@/container/ContainerBase';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nclass OrderedSetIterator<K> extends TreeIterator<K, undefined> {\n container: OrderedSet<K>;\n constructor(\n node: TreeNode<K, undefined>,\n header: TreeNode<K, undefined>,\n container: OrderedSet<K>,\n iteratorType?: IteratorType\n ) {\n super(node, header, iteratorType);\n this.container = container;\n }\n get pointer() {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._key!;\n }\n copy() {\n return new OrderedSetIterator<K>(\n this._node,\n this._header,\n this.container,\n this.iteratorType\n );\n }\n // @ts-ignore\n equals(iter: OrderedSetIterator<K>): boolean;\n}\n\nexport type { OrderedSetIterator };\n\nclass OrderedSet<K> extends TreeContainer<K, undefined> {\n /**\n * @param container - The initialization container.\n * @param cmp - The compare function.\n * @param enableIndex - Whether to enable iterator indexing function.\n * @example\n * new OrderedSet();\n * new OrderedSet([0, 1, 2]);\n * new OrderedSet([0, 1, 2], (x, y) => x - y);\n * new OrderedSet([0, 1, 2], (x, y) => x - y, true);\n */\n constructor(\n container: initContainer<K> = [],\n cmp?: (x: K, y: K) => number,\n enableIndex?: boolean\n ) {\n super(cmp, enableIndex);\n const self = this;\n container.forEach(function (el) {\n self.insert(el);\n });\n }\n /**\n * @internal\n */\n private * _iterationFunc(\n curNode: TreeNode<K, undefined> | undefined\n ): Generator<K, void> {\n if (curNode === undefined) return;\n yield * this._iterationFunc(curNode._left);\n yield curNode._key!;\n yield * this._iterationFunc(curNode._right);\n }\n begin() {\n return new OrderedSetIterator<K>(\n this._header._left || this._header,\n this._header,\n this\n );\n }\n end() {\n return new OrderedSetIterator<K>(this._header, this._header, this);\n }\n rBegin() {\n return new OrderedSetIterator<K>(\n this._header._right || this._header,\n this._header,\n this,\n IteratorType.REVERSE\n );\n }\n rEnd() {\n return new OrderedSetIterator<K>(this._header, this._header, this, IteratorType.REVERSE);\n }\n front() {\n return this._header._left ? this._header._left._key : undefined;\n }\n back() {\n return this._header._right ? this._header._right._key : undefined;\n }\n /**\n * @description Insert element to set.\n * @param key - The key want to insert.\n * @param hint - You can give an iterator hint to improve insertion efficiency.\n * @return The size of container after setting.\n * @example\n * const st = new OrderedSet([2, 4, 5]);\n * const iter = st.begin();\n * st.insert(1);\n * st.insert(3, iter); // give a hint will be faster.\n */\n insert(key: K, hint?: OrderedSetIterator<K>) {\n return this._set(key, undefined, hint);\n }\n find(element: K) {\n const resNode = this._findElementNode(this._root, element);\n return new OrderedSetIterator<K>(resNode, this._header, this);\n }\n lowerBound(key: K) {\n const resNode = this._lowerBound(this._root, key);\n return new OrderedSetIterator<K>(resNode, this._header, this);\n }\n upperBound(key: K) {\n const resNode = this._upperBound(this._root, key);\n return new OrderedSetIterator<K>(resNode, this._header, this);\n }\n reverseLowerBound(key: K) {\n const resNode = this._reverseLowerBound(this._root, key);\n return new OrderedSetIterator<K>(resNode, this._header, this);\n }\n reverseUpperBound(key: K) {\n const resNode = this._reverseUpperBound(this._root, key);\n return new OrderedSetIterator<K>(resNode, this._header, this);\n }\n union(other: OrderedSet<K>) {\n const self = this;\n other.forEach(function (el) {\n self.insert(el);\n });\n return this._length;\n }\n [Symbol.iterator]() {\n return this._iterationFunc(this._root);\n }\n // @ts-ignore\n eraseElementByIterator(iter: OrderedSetIterator<K>): OrderedSetIterator<K>;\n // @ts-ignore\n forEach(callback: (element: K, index: number, tree: OrderedSet<K>) => void): void;\n // @ts-ignore\n getElementByPos(pos: number): K;\n}\n\nexport default OrderedSet;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport TreeContainer from './Base';\nimport TreeIterator from './Base/TreeIterator';\nimport { throwIteratorAccessError } from \"../../utils/throwError\";\nvar OrderedMapIterator = /** @class */ (function (_super) {\n __extends(OrderedMapIterator, _super);\n function OrderedMapIterator(node, header, container, iteratorType) {\n var _this = _super.call(this, node, header, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n Object.defineProperty(OrderedMapIterator.prototype, \"pointer\", {\n get: function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n var self = this;\n return new Proxy([], {\n get: function (_, props) {\n if (props === '0')\n return self._node._key;\n else if (props === '1')\n return self._node._value;\n },\n set: function (_, props, newValue) {\n if (props !== '1') {\n throw new TypeError('props must be 1');\n }\n self._node._value = newValue;\n return true;\n }\n });\n },\n enumerable: false,\n configurable: true\n });\n OrderedMapIterator.prototype.copy = function () {\n return new OrderedMapIterator(this._node, this._header, this.container, this.iteratorType);\n };\n return OrderedMapIterator;\n}(TreeIterator));\nvar OrderedMap = /** @class */ (function (_super) {\n __extends(OrderedMap, _super);\n /**\n * @param container - The initialization container.\n * @param cmp - The compare function.\n * @param enableIndex - Whether to enable iterator indexing function.\n * @example\n * new OrderedMap();\n * new OrderedMap([[0, 1], [2, 1]]);\n * new OrderedMap([[0, 1], [2, 1]], (x, y) => x - y);\n * new OrderedMap([[0, 1], [2, 1]], (x, y) => x - y, true);\n */\n function OrderedMap(container, cmp, enableIndex) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, cmp, enableIndex) || this;\n var self = _this;\n container.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n return _this;\n }\n /**\n * @internal\n */\n OrderedMap.prototype._iterationFunc = function (curNode) {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (curNode === undefined)\n return [2 /*return*/];\n return [5 /*yield**/, __values(this._iterationFunc(curNode._left))];\n case 1:\n _a.sent();\n return [4 /*yield*/, [curNode._key, curNode._value]];\n case 2:\n _a.sent();\n return [5 /*yield**/, __values(this._iterationFunc(curNode._right))];\n case 3:\n _a.sent();\n return [2 /*return*/];\n }\n });\n };\n OrderedMap.prototype.begin = function () {\n return new OrderedMapIterator(this._header._left || this._header, this._header, this);\n };\n OrderedMap.prototype.end = function () {\n return new OrderedMapIterator(this._header, this._header, this);\n };\n OrderedMap.prototype.rBegin = function () {\n return new OrderedMapIterator(this._header._right || this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n OrderedMap.prototype.rEnd = function () {\n return new OrderedMapIterator(this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n OrderedMap.prototype.front = function () {\n if (this._length === 0)\n return;\n var minNode = this._header._left;\n return [minNode._key, minNode._value];\n };\n OrderedMap.prototype.back = function () {\n if (this._length === 0)\n return;\n var maxNode = this._header._right;\n return [maxNode._key, maxNode._value];\n };\n OrderedMap.prototype.lowerBound = function (key) {\n var resNode = this._lowerBound(this._root, key);\n return new OrderedMapIterator(resNode, this._header, this);\n };\n OrderedMap.prototype.upperBound = function (key) {\n var resNode = this._upperBound(this._root, key);\n return new OrderedMapIterator(resNode, this._header, this);\n };\n OrderedMap.prototype.reverseLowerBound = function (key) {\n var resNode = this._reverseLowerBound(this._root, key);\n return new OrderedMapIterator(resNode, this._header, this);\n };\n OrderedMap.prototype.reverseUpperBound = function (key) {\n var resNode = this._reverseUpperBound(this._root, key);\n return new OrderedMapIterator(resNode, this._header, this);\n };\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key - The key want to insert.\n * @param value - The value want to set.\n * @param hint - You can give an iterator hint to improve insertion efficiency.\n * @return The size of container after setting.\n * @example\n * const mp = new OrderedMap([[2, 0], [4, 0], [5, 0]]);\n * const iter = mp.begin();\n * mp.setElement(1, 0);\n * mp.setElement(3, 0, iter); // give a hint will be faster.\n */\n OrderedMap.prototype.setElement = function (key, value, hint) {\n return this._set(key, value, hint);\n };\n OrderedMap.prototype.find = function (key) {\n var curNode = this._findElementNode(this._root, key);\n return new OrderedMapIterator(curNode, this._header, this);\n };\n /**\n * @description Get the value of the element of the specified key.\n * @param key - The specified key you want to get.\n * @example\n * const val = container.getElementByKey(1);\n */\n OrderedMap.prototype.getElementByKey = function (key) {\n var curNode = this._findElementNode(this._root, key);\n return curNode._value;\n };\n OrderedMap.prototype.union = function (other) {\n var self = this;\n other.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n return this._length;\n };\n OrderedMap.prototype[Symbol.iterator] = function () {\n return this._iterationFunc(this._root);\n };\n return OrderedMap;\n}(TreeContainer));\nexport default OrderedMap;\n","import TreeContainer from './Base';\nimport TreeIterator from './Base/TreeIterator';\nimport { TreeNode } from './Base/TreeNode';\nimport { initContainer, IteratorType } from '@/container/ContainerBase';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nclass OrderedMapIterator<K, V> extends TreeIterator<K, V> {\n container: OrderedMap<K, V>;\n constructor(\n node: TreeNode<K, V>,\n header: TreeNode<K, V>,\n container: OrderedMap<K, V>,\n iteratorType?: IteratorType\n ) {\n super(node, header, iteratorType);\n this.container = container;\n }\n get pointer() {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n const self = this;\n return new Proxy(<[K, V]><unknown>[], {\n get(_, props: '0' | '1') {\n if (props === '0') return self._node._key;\n else if (props === '1') return self._node._value;\n },\n set(_, props: '1', newValue: V) {\n if (props !== '1') {\n throw new TypeError('props must be 1');\n }\n self._node._value = newValue;\n return true;\n }\n });\n }\n copy() {\n return new OrderedMapIterator<K, V>(\n this._node,\n this._header,\n this.container,\n this.iteratorType\n );\n }\n // @ts-ignore\n equals(iter: OrderedMapIterator<K, V>): boolean;\n}\n\nexport type { OrderedMapIterator };\n\nclass OrderedMap<K, V> extends TreeContainer<K, V> {\n /**\n * @param container - The initialization container.\n * @param cmp - The compare function.\n * @param enableIndex - Whether to enable iterator indexing function.\n * @example\n * new OrderedMap();\n * new OrderedMap([[0, 1], [2, 1]]);\n * new OrderedMap([[0, 1], [2, 1]], (x, y) => x - y);\n * new OrderedMap([[0, 1], [2, 1]], (x, y) => x - y, true);\n */\n constructor(\n container: initContainer<[K, V]> = [],\n cmp?: (x: K, y: K) => number,\n enableIndex?: boolean\n ) {\n super(cmp, enableIndex);\n const self = this;\n container.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n }\n /**\n * @internal\n */\n private * _iterationFunc(\n curNode: TreeNode<K, V> | undefined\n ): Generator<[K, V], void> {\n if (curNode === undefined) return;\n yield * this._iterationFunc(curNode._left);\n yield <[K, V]>[curNode._key, curNode._value];\n yield * this._iterationFunc(curNode._right);\n }\n begin() {\n return new OrderedMapIterator<K, V>(this._header._left || this._header, this._header, this);\n }\n end() {\n return new OrderedMapIterator<K, V>(this._header, this._header, this);\n }\n rBegin() {\n return new OrderedMapIterator<K, V>(\n this._header._right || this._header,\n this._header,\n this,\n IteratorType.REVERSE\n );\n }\n rEnd() {\n return new OrderedMapIterator<K, V>(this._header, this._header, this, IteratorType.REVERSE);\n }\n front() {\n if (this._length === 0) return;\n const minNode = this._header._left!;\n return <[K, V]>[minNode._key, minNode._value];\n }\n back() {\n if (this._length === 0) return;\n const maxNode = this._header._right!;\n return <[K, V]>[maxNode._key, maxNode._value];\n }\n lowerBound(key: K) {\n const resNode = this._lowerBound(this._root, key);\n return new OrderedMapIterator<K, V>(resNode, this._header, this);\n }\n upperBound(key: K) {\n const resNode = this._upperBound(this._root, key);\n return new OrderedMapIterator<K, V>(resNode, this._header, this);\n }\n reverseLowerBound(key: K) {\n const resNode = this._reverseLowerBound(this._root, key);\n return new OrderedMapIterator<K, V>(resNode, this._header, this);\n }\n reverseUpperBound(key: K) {\n const resNode = this._reverseUpperBound(this._root, key);\n return new OrderedMapIterator<K, V>(resNode, this._header, this);\n }\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key - The key want to insert.\n * @param value - The value want to set.\n * @param hint - You can give an iterator hint to improve insertion efficiency.\n * @return The size of container after setting.\n * @example\n * const mp = new OrderedMap([[2, 0], [4, 0], [5, 0]]);\n * const iter = mp.begin();\n * mp.setElement(1, 0);\n * mp.setElement(3, 0, iter); // give a hint will be faster.\n */\n setElement(key: K, value: V, hint?: OrderedMapIterator<K, V>) {\n return this._set(key, value, hint);\n }\n find(key: K) {\n const curNode = this._findElementNode(this._root, key);\n return new OrderedMapIterator<K, V>(curNode, this._header, this);\n }\n /**\n * @description Get the value of the element of the specified key.\n * @param key - The specified key you want to get.\n * @example\n * const val = container.getElementByKey(1);\n */\n getElementByKey(key: K) {\n const curNode = this._findElementNode(this._root, key);\n return curNode._value;\n }\n union(other: OrderedMap<K, V>) {\n const self = this;\n other.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n return this._length;\n }\n [Symbol.iterator]() {\n return this._iterationFunc(this._root);\n }\n // @ts-ignore\n eraseElementByIterator(iter: OrderedMapIterator<K, V>): OrderedMapIterator<K, V>;\n // @ts-ignore\n forEach(callback: (element: [K, V], index: number, map: OrderedMap<K, V>) => void): void;\n // @ts-ignore\n getElementByPos(pos: number): [K, V];\n}\n\nexport default OrderedMap;\n","/**\n * @description Determine whether the type of key is `object`.\n * @param key - The key want to check.\n * @returns Whether the type of key is `object`.\n * @internal\n */\nexport default function checkObject<T>(key: T) {\n const t = typeof key;\n return (t === 'object' && key !== null) || t === 'function';\n}\n","/**\n * @description Determine whether the type of key is `object`.\n * @param key - The key want to check.\n * @returns Whether the type of key is `object`.\n * @internal\n */\nexport default function checkObject(key) {\n var t = typeof key;\n return (t === 'object' && key !== null) || t === 'function';\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Container, ContainerIterator } from \"../../ContainerBase\";\nimport checkObject from \"../../../utils/checkObject\";\nimport $checkWithinAccessParams from \"../../../utils/checkParams.macro\";\nimport { throwIteratorAccessError } from \"../../../utils/throwError\";\nvar HashContainerIterator = /** @class */ (function (_super) {\n __extends(HashContainerIterator, _super);\n /**\n * @internal\n */\n function HashContainerIterator(node, header, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this._node = node;\n _this._header = header;\n if (_this.iteratorType === 0 /* IteratorType.NORMAL */) {\n _this.pre = function () {\n if (this._node._pre === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this._node._next === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n _this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n }\n return _this;\n }\n return HashContainerIterator;\n}(ContainerIterator));\nexport { HashContainerIterator };\nvar HashContainer = /** @class */ (function (_super) {\n __extends(HashContainer, _super);\n /**\n * @internal\n */\n function HashContainer() {\n var _this = _super.call(this) || this;\n /**\n * @internal\n */\n _this._objMap = [];\n /**\n * @internal\n */\n _this._originMap = {};\n /**\n * @description Unique symbol used to tag object.\n */\n _this.HASH_TAG = Symbol('@@HASH_TAG');\n Object.setPrototypeOf(_this._originMap, null);\n _this._header = {};\n _this._header._pre = _this._header._next = _this._head = _this._tail = _this._header;\n return _this;\n }\n /**\n * @internal\n */\n HashContainer.prototype._eraseNode = function (node) {\n var _pre = node._pre, _next = node._next;\n _pre._next = _next;\n _next._pre = _pre;\n if (node === this._head) {\n this._head = _next;\n }\n if (node === this._tail) {\n this._tail = _pre;\n }\n this._length -= 1;\n };\n /**\n * @internal\n */\n HashContainer.prototype._set = function (key, value, isObject) {\n if (isObject === undefined)\n isObject = checkObject(key);\n var newTail;\n if (isObject) {\n var index = key[this.HASH_TAG];\n if (index !== undefined) {\n this._objMap[index]._value = value;\n return this._length;\n }\n Object.defineProperty(key, this.HASH_TAG, {\n value: this._objMap.length,\n configurable: true\n });\n newTail = {\n _key: key,\n _value: value,\n _pre: this._tail,\n _next: this._header\n };\n this._objMap.push(newTail);\n }\n else {\n var node = this._originMap[key];\n if (node) {\n node._value = value;\n return this._length;\n }\n newTail = {\n _key: key,\n _value: value,\n _pre: this._tail,\n _next: this._header\n };\n this._originMap[key] = newTail;\n }\n if (this._length === 0) {\n this._head = newTail;\n this._header._next = newTail;\n }\n else {\n this._tail._next = newTail;\n }\n this._tail = newTail;\n this._header._pre = newTail;\n return ++this._length;\n };\n /**\n * @internal\n */\n HashContainer.prototype._findElementNode = function (key, isObject) {\n if (isObject === undefined)\n isObject = checkObject(key);\n if (isObject) {\n var index = key[this.HASH_TAG];\n if (index === undefined)\n return this._header;\n return this._objMap[index];\n }\n else {\n return this._originMap[key] || this._header;\n }\n };\n HashContainer.prototype.clear = function () {\n var HASH_TAG = this.HASH_TAG;\n this._objMap.forEach(function (el) {\n delete el._key[HASH_TAG];\n });\n this._objMap = [];\n this._originMap = {};\n Object.setPrototypeOf(this._originMap, null);\n this._length = 0;\n this._head = this._tail = this._header._pre = this._header._next = this._header;\n };\n /**\n * @description Remove the element of the specified key.\n * @param key - The key you want to remove.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns Whether erase successfully.\n */\n HashContainer.prototype.eraseElementByKey = function (key, isObject) {\n var node;\n if (isObject === undefined)\n isObject = checkObject(key);\n if (isObject) {\n var index = key[this.HASH_TAG];\n if (index === undefined)\n return false;\n delete key[this.HASH_TAG];\n node = this._objMap[index];\n delete this._objMap[index];\n }\n else {\n node = this._originMap[key];\n if (node === undefined)\n return false;\n delete this._originMap[key];\n }\n this._eraseNode(node);\n return true;\n };\n HashContainer.prototype.eraseElementByIterator = function (iter) {\n var node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n this._eraseNode(node);\n return iter.next();\n };\n HashContainer.prototype.eraseElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var node = this._head;\n while (pos--) {\n node = node._next;\n }\n this._eraseNode(node);\n return this._length;\n };\n return HashContainer;\n}(Container));\nexport { HashContainer };\n","import { Container, ContainerIterator, IteratorType } from '@/container/ContainerBase';\nimport checkObject from '@/utils/checkObject';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nexport type HashLinkNode<K, V> = {\n _key: K,\n _value: V,\n _pre: HashLinkNode<K, V>,\n _next: HashLinkNode<K, V>\n}\n\nexport abstract class HashContainerIterator<K, V> extends ContainerIterator<K | [K, V]> {\n abstract readonly container: HashContainer<K, V>;\n /**\n * @internal\n */\n _node: HashLinkNode<K, V>;\n /**\n * @internal\n */\n protected readonly _header: HashLinkNode<K, V>;\n /**\n * @internal\n */\n protected constructor(\n node: HashLinkNode<K, V>,\n header: HashLinkNode<K, V>,\n iteratorType?: IteratorType\n ) {\n super(iteratorType);\n this._node = node;\n this._header = header;\n if (this.iteratorType === IteratorType.NORMAL) {\n this.pre = function () {\n if (this._node._pre === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n } else {\n this.pre = function () {\n if (this._node._next === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._next;\n return this;\n };\n this.next = function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n this._node = this._node._pre;\n return this;\n };\n }\n }\n // @ts-ignore\n pre(): this;\n // @ts-ignore\n next(): this;\n}\n\nexport abstract class HashContainer<K, V> extends Container<K | [K, V]> {\n /**\n * @internal\n */\n protected _objMap: HashLinkNode<K, V>[] = [];\n /**\n * @internal\n */\n protected _originMap: Record<string, HashLinkNode<K, V>> = {};\n /**\n * @internal\n */\n protected _head: HashLinkNode<K, V>;\n /**\n * @internal\n */\n protected _tail: HashLinkNode<K, V>;\n /**\n * @internal\n */\n protected readonly _header: HashLinkNode<K, V>;\n /**\n * @description Unique symbol used to tag object.\n */\n readonly HASH_TAG = Symbol('@@HASH_TAG');\n /**\n * @internal\n */\n protected constructor() {\n super();\n Object.setPrototypeOf(this._originMap, null);\n this._header = <HashLinkNode<K, V>>{};\n this._header._pre = this._header._next = this._head = this._tail = this._header;\n }\n /**\n * @internal\n */\n protected _eraseNode(node: HashLinkNode<K, V>) {\n const { _pre, _next } = node;\n _pre._next = _next;\n _next._pre = _pre;\n if (node === this._head) {\n this._head = _next;\n }\n if (node === this._tail) {\n this._tail = _pre;\n }\n this._length -= 1;\n }\n /**\n * @internal\n */\n protected _set(key: K, value?: V, isObject?: boolean) {\n if (isObject === undefined) isObject = checkObject(key);\n let newTail;\n if (isObject) {\n const index = (<Record<symbol, number>><unknown>key)[this.HASH_TAG];\n if (index !== undefined) {\n this._objMap[<number>index]._value = <V>value;\n return this._length;\n }\n Object.defineProperty(key, this.HASH_TAG, {\n value: this._objMap.length,\n configurable: true\n });\n newTail = {\n _key: key,\n _value: <V>value,\n _pre: this._tail,\n _next: this._header\n };\n this._objMap.push(newTail);\n } else {\n const node = this._originMap[<string><unknown>key];\n if (node) {\n node._value = <V>value;\n return this._length;\n }\n newTail = {\n _key: key,\n _value: <V>value,\n _pre: this._tail,\n _next: this._header\n };\n this._originMap[<string><unknown>key] = newTail;\n }\n if (this._length === 0) {\n this._head = newTail;\n this._header._next = newTail;\n } else {\n this._tail._next = newTail;\n }\n this._tail = newTail;\n this._header._pre = newTail;\n return ++this._length;\n }\n /**\n * @internal\n */\n protected _findElementNode(key: K, isObject?: boolean) {\n if (isObject === undefined) isObject = checkObject(key);\n if (isObject) {\n const index = (<Record<symbol, number>><unknown>key)[this.HASH_TAG];\n if (index === undefined) return this._header;\n return this._objMap[index];\n } else {\n return this._originMap[<string><unknown>key] || this._header;\n }\n }\n clear() {\n const HASH_TAG = this.HASH_TAG;\n this._objMap.forEach(function (el) {\n delete (<Record<symbol, number>><unknown>el._key)[HASH_TAG];\n });\n this._objMap = [];\n this._originMap = {};\n Object.setPrototypeOf(this._originMap, null);\n this._length = 0;\n this._head = this._tail = this._header._pre = this._header._next = this._header;\n }\n /**\n * @description Remove the element of the specified key.\n * @param key - The key you want to remove.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns Whether erase successfully.\n */\n eraseElementByKey(key: K, isObject?: boolean) {\n let node;\n if (isObject === undefined) isObject = checkObject(key);\n if (isObject) {\n const index = (<Record<symbol, number>><unknown>key)[this.HASH_TAG];\n if (index === undefined) return false;\n delete (<Record<symbol, number>><unknown>key)[this.HASH_TAG];\n node = this._objMap[index];\n delete this._objMap[index];\n } else {\n node = this._originMap[<string><unknown>key];\n if (node === undefined) return false;\n delete this._originMap[<string><unknown>key];\n }\n this._eraseNode(node);\n return true;\n }\n eraseElementByIterator(iter: HashContainerIterator<K, V>) {\n const node = iter._node;\n if (node === this._header) {\n throwIteratorAccessError();\n }\n this._eraseNode(node);\n return iter.next();\n }\n eraseElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let node = this._head;\n while (pos--) {\n node = node._next;\n }\n this._eraseNode(node);\n return this._length;\n }\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nimport { HashContainer, HashContainerIterator } from \"./Base\";\nimport $checkWithinAccessParams from \"../../utils/checkParams.macro\";\nimport { throwIteratorAccessError } from \"../../utils/throwError\";\nvar HashSetIterator = /** @class */ (function (_super) {\n __extends(HashSetIterator, _super);\n function HashSetIterator(node, header, container, iteratorType) {\n var _this = _super.call(this, node, header, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n Object.defineProperty(HashSetIterator.prototype, \"pointer\", {\n get: function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._key;\n },\n enumerable: false,\n configurable: true\n });\n HashSetIterator.prototype.copy = function () {\n return new HashSetIterator(this._node, this._header, this.container, this.iteratorType);\n };\n return HashSetIterator;\n}(HashContainerIterator));\nvar HashSet = /** @class */ (function (_super) {\n __extends(HashSet, _super);\n function HashSet(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n var self = _this;\n container.forEach(function (el) {\n self.insert(el);\n });\n return _this;\n }\n HashSet.prototype.begin = function () {\n return new HashSetIterator(this._head, this._header, this);\n };\n HashSet.prototype.end = function () {\n return new HashSetIterator(this._header, this._header, this);\n };\n HashSet.prototype.rBegin = function () {\n return new HashSetIterator(this._tail, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n HashSet.prototype.rEnd = function () {\n return new HashSetIterator(this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n HashSet.prototype.front = function () {\n return this._head._key;\n };\n HashSet.prototype.back = function () {\n return this._tail._key;\n };\n /**\n * @description Insert element to set.\n * @param key - The key want to insert.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns The size of container after inserting.\n */\n HashSet.prototype.insert = function (key, isObject) {\n return this._set(key, undefined, isObject);\n };\n HashSet.prototype.getElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var node = this._head;\n while (pos--) {\n node = node._next;\n }\n return node._key;\n };\n /**\n * @description Check key if exist in container.\n * @param key - The element you want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns An iterator pointing to the element if found, or super end if not found.\n */\n HashSet.prototype.find = function (key, isObject) {\n var node = this._findElementNode(key, isObject);\n return new HashSetIterator(node, this._header, this);\n };\n HashSet.prototype.forEach = function (callback) {\n var index = 0;\n var node = this._head;\n while (node !== this._header) {\n callback(node._key, index++, this);\n node = node._next;\n }\n };\n HashSet.prototype[Symbol.iterator] = function () {\n return function () {\n var node;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n node = this._head;\n _a.label = 1;\n case 1:\n if (!(node !== this._header)) return [3 /*break*/, 3];\n return [4 /*yield*/, node._key];\n case 2:\n _a.sent();\n node = node._next;\n return [3 /*break*/, 1];\n case 3: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return HashSet;\n}(HashContainer));\nexport default HashSet;\n","import { initContainer, IteratorType } from '@/container/ContainerBase';\nimport { HashContainer, HashContainerIterator, HashLinkNode } from '@/container/HashContainer/Base';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nclass HashSetIterator<K> extends HashContainerIterator<K, undefined> {\n readonly container: HashSet<K>;\n constructor(\n node: HashLinkNode<K, undefined>,\n header: HashLinkNode<K, undefined>,\n container: HashSet<K>,\n iteratorType?: IteratorType\n ) {\n super(node, header, iteratorType);\n this.container = container;\n }\n get pointer() {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n return this._node._key;\n }\n copy() {\n return new HashSetIterator<K>(this._node, this._header, this.container, this.iteratorType);\n }\n // @ts-ignore\n equals(iter: HashSetIterator<K>): boolean;\n}\n\nexport type { HashSetIterator };\n\nclass HashSet<K> extends HashContainer<K, undefined> {\n constructor(container: initContainer<K> = []) {\n super();\n const self = this;\n container.forEach(function (el) {\n self.insert(el);\n });\n }\n begin() {\n return new HashSetIterator<K>(this._head, this._header, this);\n }\n end() {\n return new HashSetIterator<K>(this._header, this._header, this);\n }\n rBegin() {\n return new HashSetIterator<K>(this._tail, this._header, this, IteratorType.REVERSE);\n }\n rEnd() {\n return new HashSetIterator<K>(this._header, this._header, this, IteratorType.REVERSE);\n }\n front(): K | undefined {\n return this._head._key;\n }\n back(): K | undefined {\n return this._tail._key;\n }\n /**\n * @description Insert element to set.\n * @param key - The key want to insert.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns The size of container after inserting.\n */\n insert(key: K, isObject?: boolean) {\n return this._set(key, undefined, isObject);\n }\n getElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let node = this._head;\n while (pos--) {\n node = node._next;\n }\n return node._key;\n }\n /**\n * @description Check key if exist in container.\n * @param key - The element you want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns An iterator pointing to the element if found, or super end if not found.\n */\n find(key: K, isObject?: boolean) {\n const node = this._findElementNode(key, isObject);\n return new HashSetIterator<K>(node, this._header, this);\n }\n forEach(callback: (element: K, index: number, container: HashSet<K>) => void) {\n let index = 0;\n let node = this._head;\n while (node !== this._header) {\n callback(node._key, index++, this);\n node = node._next;\n }\n }\n [Symbol.iterator]() {\n return function * (this: HashSet<K>) {\n let node = this._head;\n while (node !== this._header) {\n yield node._key;\n node = node._next;\n }\n }.bind(this)();\n }\n}\n\nexport default HashSet;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nimport { HashContainer, HashContainerIterator } from \"./Base\";\nimport checkObject from \"../../utils/checkObject\";\nimport $checkWithinAccessParams from \"../../utils/checkParams.macro\";\nimport { throwIteratorAccessError } from \"../../utils/throwError\";\nvar HashMapIterator = /** @class */ (function (_super) {\n __extends(HashMapIterator, _super);\n function HashMapIterator(node, header, container, iteratorType) {\n var _this = _super.call(this, node, header, iteratorType) || this;\n _this.container = container;\n return _this;\n }\n Object.defineProperty(HashMapIterator.prototype, \"pointer\", {\n get: function () {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n var self = this;\n return new Proxy([], {\n get: function (_, props) {\n if (props === '0')\n return self._node._key;\n else if (props === '1')\n return self._node._value;\n },\n set: function (_, props, newValue) {\n if (props !== '1') {\n throw new TypeError('props must be 1');\n }\n self._node._value = newValue;\n return true;\n }\n });\n },\n enumerable: false,\n configurable: true\n });\n HashMapIterator.prototype.copy = function () {\n return new HashMapIterator(this._node, this._header, this.container, this.iteratorType);\n };\n return HashMapIterator;\n}(HashContainerIterator));\nvar HashMap = /** @class */ (function (_super) {\n __extends(HashMap, _super);\n function HashMap(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n var self = _this;\n container.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n return _this;\n }\n HashMap.prototype.begin = function () {\n return new HashMapIterator(this._head, this._header, this);\n };\n HashMap.prototype.end = function () {\n return new HashMapIterator(this._header, this._header, this);\n };\n HashMap.prototype.rBegin = function () {\n return new HashMapIterator(this._tail, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n HashMap.prototype.rEnd = function () {\n return new HashMapIterator(this._header, this._header, this, 1 /* IteratorType.REVERSE */);\n };\n HashMap.prototype.front = function () {\n if (this._length === 0)\n return;\n return [this._head._key, this._head._value];\n };\n HashMap.prototype.back = function () {\n if (this._length === 0)\n return;\n return [this._tail._key, this._tail._value];\n };\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key - The key want to insert.\n * @param value - The value want to set.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns The size of container after setting.\n */\n HashMap.prototype.setElement = function (key, value, isObject) {\n return this._set(key, value, isObject);\n };\n /**\n * @description Get the value of the element of the specified key.\n * @param key - The key want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @example\n * const val = container.getElementByKey(1);\n */\n HashMap.prototype.getElementByKey = function (key, isObject) {\n if (isObject === undefined)\n isObject = checkObject(key);\n if (isObject) {\n var index = key[this.HASH_TAG];\n return index !== undefined ? this._objMap[index]._value : undefined;\n }\n var node = this._originMap[key];\n return node ? node._value : undefined;\n };\n HashMap.prototype.getElementByPos = function (pos) {\n if (pos < 0 || pos > this._length - 1) {\n throw new RangeError();\n }\n var node = this._head;\n while (pos--) {\n node = node._next;\n }\n return [node._key, node._value];\n };\n /**\n * @description Check key if exist in container.\n * @param key - The element you want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns An iterator pointing to the element if found, or super end if not found.\n */\n HashMap.prototype.find = function (key, isObject) {\n var node = this._findElementNode(key, isObject);\n return new HashMapIterator(node, this._header, this);\n };\n HashMap.prototype.forEach = function (callback) {\n var index = 0;\n var node = this._head;\n while (node !== this._header) {\n callback([node._key, node._value], index++, this);\n node = node._next;\n }\n };\n HashMap.prototype[Symbol.iterator] = function () {\n return function () {\n var node;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n node = this._head;\n _a.label = 1;\n case 1:\n if (!(node !== this._header)) return [3 /*break*/, 3];\n return [4 /*yield*/, [node._key, node._value]];\n case 2:\n _a.sent();\n node = node._next;\n return [3 /*break*/, 1];\n case 3: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return HashMap;\n}(HashContainer));\nexport default HashMap;\n","import { initContainer, IteratorType } from '@/container/ContainerBase';\nimport { HashContainer, HashContainerIterator, HashLinkNode } from '@/container/HashContainer/Base';\nimport checkObject from '@/utils/checkObject';\nimport $checkWithinAccessParams from '@/utils/checkParams.macro';\nimport { throwIteratorAccessError } from '@/utils/throwError';\n\nclass HashMapIterator<K, V> extends HashContainerIterator<K, V> {\n readonly container: HashMap<K, V>;\n constructor(\n node: HashLinkNode<K, V>,\n header: HashLinkNode<K, V>,\n container: HashMap<K, V>,\n iteratorType?: IteratorType\n ) {\n super(node, header, iteratorType);\n this.container = container;\n }\n get pointer() {\n if (this._node === this._header) {\n throwIteratorAccessError();\n }\n const self = this;\n return new Proxy(<[K, V]><unknown>[], {\n get(_, props: '0' | '1') {\n if (props === '0') return self._node._key;\n else if (props === '1') return self._node._value;\n },\n set(_, props: '1', newValue: V) {\n if (props !== '1') {\n throw new TypeError('props must be 1');\n }\n self._node._value = newValue;\n return true;\n }\n });\n }\n copy() {\n return new HashMapIterator<K, V>(this._node, this._header, this.container, this.iteratorType);\n }\n // @ts-ignore\n equals(iter: HashMapIterator<K, V>): boolean;\n}\n\nexport type { HashMapIterator };\n\nclass HashMap<K, V> extends HashContainer<K, V> {\n constructor(container: initContainer<[K, V]> = []) {\n super();\n const self = this;\n container.forEach(function (el) {\n self.setElement(el[0], el[1]);\n });\n }\n begin() {\n return new HashMapIterator<K, V>(this._head, this._header, this);\n }\n end() {\n return new HashMapIterator<K, V>(this._header, this._header, this);\n }\n rBegin() {\n return new HashMapIterator<K, V>(this._tail, this._header, this, IteratorType.REVERSE);\n }\n rEnd() {\n return new HashMapIterator<K, V>(this._header, this._header, this, IteratorType.REVERSE);\n }\n front() {\n if (this._length === 0) return;\n return <[K, V]>[this._head._key, this._head._value];\n }\n back() {\n if (this._length === 0) return;\n return <[K, V]>[this._tail._key, this._tail._value];\n }\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key - The key want to insert.\n * @param value - The value want to set.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns The size of container after setting.\n */\n setElement(key: K, value: V, isObject?: boolean) {\n return this._set(key, value, isObject);\n }\n /**\n * @description Get the value of the element of the specified key.\n * @param key - The key want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @example\n * const val = container.getElementByKey(1);\n */\n getElementByKey(key: K, isObject?: boolean) {\n if (isObject === undefined) isObject = checkObject(key);\n if (isObject) {\n const index = (<Record<symbol, number>><unknown>key)[this.HASH_TAG];\n return index !== undefined ? this._objMap[index]._value : undefined;\n }\n const node = this._originMap[<string><unknown>key];\n return node ? node._value : undefined;\n }\n getElementByPos(pos: number) {\n $checkWithinAccessParams!(pos, 0, this._length - 1);\n let node = this._head;\n while (pos--) {\n node = node._next;\n }\n return <[K, V]>[node._key, node._value];\n }\n /**\n * @description Check key if exist in container.\n * @param key - The element you want to search.\n * @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>\n * If a `undefined` value is passed in, the type will be automatically judged.\n * @returns An iterator pointing to the element if found, or super end if not found.\n */\n find(key: K, isObject?: boolean) {\n const node = this._findElementNode(key, isObject);\n return new HashMapIterator<K, V>(node, this._header, this);\n }\n forEach(callback: (element: [K, V], index: number, hashMap: HashMap<K, V>) => void) {\n let index = 0;\n let node = this._head;\n while (node !== this._header) {\n callback(<[K, V]>[node._key, node._value], index++, this);\n node = node._next;\n }\n }\n [Symbol.iterator]() {\n return function * (this: HashMap<K, V>) {\n let node = this._head;\n while (node !== this._header) {\n yield <[K, V]>[node._key, node._value];\n node = node._next;\n }\n }.bind(this)();\n }\n}\n\nexport default HashMap;\n","// Copyright Takatoshi Kondo 2021\n//\n// Distributed under the MIT License\n\n'use strict'\n\nconst SortedSet = require('js-sdsl').OrderedSet\nconst debugTrace = require('debug')('number-allocator:trace')\nconst debugError = require('debug')('number-allocator:error')\n/**\n * Interval constructor\n * @constructor\n * @param {Number} low - The lowest value of the interval\n * @param {Number} high - The highest value of the interval\n */\nfunction Interval (low, high) {\n this.low = low\n this.high = high\n}\n\nInterval.prototype.equals = function (other) {\n return this.low === other.low && this.high === other.high\n}\n\nInterval.prototype.compare = function (other) {\n if (this.low < other.low && this.high < other.low) return -1\n if (other.low < this.low && other.high < this.low) return 1\n return 0\n}\n\n/**\n * NumberAllocator constructor.\n * The all numbers are set to vacant status.\n * Time Complexity O(1)\n * @constructor\n * @param {Number} min - The maximum number of allocatable. The number must be integer.\n * @param {Number} maxh - The minimum number of allocatable. The number must be integer.\n */\nfunction NumberAllocator (min, max) {\n if (!(this instanceof NumberAllocator)) {\n return new NumberAllocator(min, max)\n }\n\n this.min = min\n this.max = max\n\n this.ss = new SortedSet(\n [],\n (lhs, rhs) => {\n return lhs.compare(rhs)\n }\n )\n debugTrace('Create')\n this.clear()\n}\n\n/**\n * Get the first vacant number. The status of the number is not updated.\n * Time Complexity O(1)\n * @return {Number} - The first vacant number. If all numbers are occupied, return null.\n * When alloc() is called then the same value will be allocated.\n */\nNumberAllocator.prototype.firstVacant = function () {\n if (this.ss.size() === 0) return null\n return this.ss.front().low\n}\n\n/**\n * Allocate the first vacant number. The number become occupied status.\n * Time Complexity O(1)\n * @return {Number} - The first vacant number. If all numbers are occupied, return null.\n */\nNumberAllocator.prototype.alloc = function () {\n if (this.ss.size() === 0) {\n debugTrace('alloc():empty')\n return null\n }\n const it = this.ss.begin()\n const low = it.pointer.low\n const high = it.pointer.high\n const num = low\n if (num + 1 <= high) {\n // x|----|\n this.ss.updateKeyByIterator(it, new Interval(low + 1, high))\n } else {\n this.ss.eraseElementByPos(0)\n }\n debugTrace('alloc():' + num)\n return num\n}\n\n/**\n * Use the number. The number become occupied status.\n * If the number has already been occupied, then return false.\n * Time Complexity O(logN) : N is the number of intervals (not numbers)\n * @param {Number} num - The number to request use.\n * @return {Boolean} - If `num` was not occupied, then return true, otherwise return false.\n */\nNumberAllocator.prototype.use = function (num) {\n const key = new Interval(num, num)\n const it = this.ss.lowerBound(key)\n if (!it.equals(this.ss.end())) {\n const low = it.pointer.low\n const high = it.pointer.high\n if (it.pointer.equals(key)) {\n // |x|\n this.ss.eraseElementByIterator(it)\n debugTrace('use():' + num)\n return true\n }\n\n // x |-----|\n if (low > num) return false\n\n // |x----|\n if (low === num) {\n // x|----|\n this.ss.updateKeyByIterator(it, new Interval(low + 1, high))\n debugTrace('use():' + num)\n return true\n }\n\n // |----x|\n if (high === num) {\n // |----|x\n this.ss.updateKeyByIterator(it, new Interval(low, high - 1))\n debugTrace('use():' + num)\n return true\n }\n\n // |--x--|\n // x|--|\n this.ss.updateKeyByIterator(it, new Interval(num + 1, high))\n // |--|x|--|\n this.ss.insert(new Interval(low, num - 1))\n debugTrace('use():' + num)\n return true\n }\n\n debugTrace('use():failed')\n return false\n}\n\n/**\n * Deallocate the number. The number become vacant status.\n * Time Complexity O(logN) : N is the number of intervals (not numbers)\n * @param {Number} num - The number to deallocate. The number must be occupied status.\n * In other words, the number must be allocated by alloc() or occupied be use().\n */\nNumberAllocator.prototype.free = function (num) {\n if (num < this.min || num > this.max) {\n debugError('free():' + num + ' is out of range')\n return\n }\n const key = new Interval(num, num)\n const it = this.ss.upperBound(key)\n if (it.equals(this.ss.end())) {\n // ....v\n if (it.equals(this.ss.begin())) {\n // Insert new interval\n this.ss.insert(key)\n return\n }\n it.pre()\n const low = it.pointer.high\n const high = it.pointer.high\n if (high + 1 === num) {\n // Concat to left\n this.ss.updateKeyByIterator(it, new Interval(low, num))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n } else {\n if (it.equals(this.ss.begin())) {\n // v....\n if (num + 1 === it.pointer.low) {\n // Concat to right\n const high = it.pointer.high\n this.ss.updateKeyByIterator(it, new Interval(num, high))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n } else {\n // ..v..\n const rLow = it.pointer.low\n const rHigh = it.pointer.high\n it.pre()\n const lLow = it.pointer.low\n const lHigh = it.pointer.high\n if (lHigh + 1 === num) {\n if (num + 1 === rLow) {\n // Concat to left and right\n this.ss.eraseElementByIterator(it)\n this.ss.updateKeyByIterator(it, new Interval(lLow, rHigh))\n } else {\n // Concat to left\n this.ss.updateKeyByIterator(it, new Interval(lLow, num))\n }\n } else {\n if (num + 1 === rLow) {\n // Concat to right\n this.ss.eraseElementByIterator(it.next())\n this.ss.insert(new Interval(num, rHigh))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n }\n }\n }\n debugTrace('free():' + num)\n}\n\n/**\n * Clear all occupied numbers.\n * The all numbers are set to vacant status.\n * Time Complexity O(1)\n */\nNumberAllocator.prototype.clear = function () {\n debugTrace('clear()')\n this.ss.clear()\n this.ss.insert(new Interval(this.min, this.max))\n}\n\n/**\n * Get the number of intervals. Interval is internal structure of this library.\n * This function is for debugging.\n * Time Complexity O(1)\n * @return {Number} - The number of intervals.\n */\nNumberAllocator.prototype.intervalCount = function () {\n return this.ss.size()\n}\n\n/**\n * Dump the internal structor of the library.\n * This function is for debugging.\n * Time Complexity O(N) : N is the number of intervals (not numbers)\n */\nNumberAllocator.prototype.dump = function () {\n console.log('length:' + this.ss.size())\n for (const element of this.ss) {\n console.log(element)\n }\n}\n\nmodule.exports = NumberAllocator\n","// Copyright Takatoshi Kondo 2021\n//\n// Distributed under the MIT License\n\nconst NumberAllocator = require('./lib/number-allocator.js')\n\nmodule.exports.NumberAllocator = NumberAllocator\n","/**\n * Module dependencies\n */\nimport { LRUCache } from 'lru-cache'\nimport { NumberAllocator } from 'number-allocator'\n\n/**\n * Topic Alias sending manager\n * This holds both topic to alias and alias to topic map\n * @param {Number} [max] - topic alias maximum entries\n */\nexport default class TopicAliasSend {\n\tprivate aliasToTopic: LRUCache<number, string>\n\n\tprivate topicToAlias: Record<string, number>\n\n\tprivate max: number\n\n\tprivate numberAllocator: NumberAllocator\n\n\tpublic length: number\n\n\tconstructor(max: number) {\n\t\tif (max > 0) {\n\t\t\tthis.aliasToTopic = new LRUCache<number, string>({ max })\n\t\t\tthis.topicToAlias = {}\n\t\t\tthis.numberAllocator = new NumberAllocator(1, max)\n\t\t\tthis.max = max\n\t\t\tthis.length = 0\n\t\t}\n\t}\n\n\t/**\n\t * Insert or update topic - alias entry.\n\t * @param {String} [topic] - topic\n\t * @param {Number} [alias] - topic alias\n\t * @returns {Boolean} - if success return true otherwise false\n\t */\n\tput(topic: string, alias: number): boolean {\n\t\tif (alias === 0 || alias > this.max) {\n\t\t\treturn false\n\t\t}\n\t\tconst entry = this.aliasToTopic.get(alias)\n\t\tif (entry) {\n\t\t\tdelete this.topicToAlias[entry]\n\t\t}\n\t\tthis.aliasToTopic.set(alias, topic)\n\t\tthis.topicToAlias[topic] = alias\n\t\tthis.numberAllocator.use(alias)\n\t\tthis.length = this.aliasToTopic.size\n\t\treturn true\n\t}\n\n\t/**\n\t * Get topic by alias\n\t * @param {Number} [alias] - topic alias\n\t * @returns {String} - if mapped topic exists return topic, otherwise return undefined\n\t */\n\tgetTopicByAlias(alias: number): string {\n\t\treturn this.aliasToTopic.get(alias)\n\t}\n\n\t/**\n\t * Get topic by alias\n\t * @param {String} [topic] - topic\n\t * @returns {Number} - if mapped topic exists return topic alias, otherwise return undefined\n\t */\n\tgetAliasByTopic(topic: string): number | undefined {\n\t\tconst alias = this.topicToAlias[topic]\n\t\tif (typeof alias !== 'undefined') {\n\t\t\tthis.aliasToTopic.get(alias) // LRU update\n\t\t}\n\t\treturn alias\n\t}\n\n\t/**\n\t * Clear all entries\n\t */\n\tclear() {\n\t\tthis.aliasToTopic.clear()\n\t\tthis.topicToAlias = {}\n\t\tthis.numberAllocator.clear()\n\t\tthis.length = 0\n\t}\n\n\t/**\n\t * Get Least Recently Used (LRU) topic alias\n\t * @returns {Number} - if vacant alias exists then return it, otherwise then return LRU alias\n\t */\n\tgetLruAlias(): number {\n\t\tconst alias = this.numberAllocator.firstVacant()\n\t\tif (alias) return alias\n\t\t// get last alias (key) from LRU cache\n\t\treturn [...this.aliasToTopic.keys()][this.aliasToTopic.size - 1]\n\t}\n}\n","import { ReasonCodes } from './ack'\nimport TopicAliasSend from '../topic-alias-send'\nimport { ErrorWithReasonCode, PacketHandler } from '../shared'\nimport { IConnackPacket } from 'mqtt-packet'\n\nconst handleConnack: PacketHandler = (client, packet: IConnackPacket) => {\n\tclient.log('_handleConnack')\n\tconst { options } = client\n\tconst version = options.protocolVersion\n\tconst rc = version === 5 ? packet.reasonCode : packet.returnCode\n\n\tclearTimeout(client['connackTimer'])\n\tdelete client['topicAliasSend']\n\n\tif (packet.properties) {\n\t\tif (packet.properties.topicAliasMaximum) {\n\t\t\tif (packet.properties.topicAliasMaximum > 0xffff) {\n\t\t\t\tclient.emit(\n\t\t\t\t\t'error',\n\t\t\t\t\tnew Error('topicAliasMaximum from broker is out of range'),\n\t\t\t\t)\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (packet.properties.topicAliasMaximum > 0) {\n\t\t\t\tclient['topicAliasSend'] = new TopicAliasSend(\n\t\t\t\t\tpacket.properties.topicAliasMaximum,\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\t\tif (packet.properties.serverKeepAlive && options.keepalive) {\n\t\t\toptions.keepalive = packet.properties.serverKeepAlive\n\t\t}\n\n\t\tif (packet.properties.maximumPacketSize) {\n\t\t\tif (!options.properties) {\n\t\t\t\toptions.properties = {}\n\t\t\t}\n\t\t\toptions.properties.maximumPacketSize =\n\t\t\t\tpacket.properties.maximumPacketSize\n\t\t}\n\t}\n\n\tif (rc === 0) {\n\t\tclient.reconnecting = false\n\t\tclient['_onConnect'](packet)\n\t} else if (rc > 0) {\n\t\tconst err = new ErrorWithReasonCode(\n\t\t\t`Connection refused: ${ReasonCodes[rc]}`,\n\t\t\trc,\n\t\t)\n\t\tclient.emit('error', err)\n\t}\n}\n\nexport default handleConnack\n","import { IPubcompPacket, IPublishPacket, IPubrelPacket } from 'mqtt-packet'\nimport { PacketHandler } from '../shared'\n\nconst handlePubrel: PacketHandler = (client, packet: IPubrelPacket, done) => {\n\tclient.log('handling pubrel packet')\n\tconst callback = typeof done !== 'undefined' ? done : client.noop\n\tconst { messageId } = packet\n\n\tconst comp: IPubcompPacket = { cmd: 'pubcomp', messageId }\n\n\tclient.incomingStore.get(packet, (err, pub: IPublishPacket) => {\n\t\tif (!err) {\n\t\t\tclient.emit('message', pub.topic, pub.payload as Buffer, pub)\n\t\t\tclient.handleMessage(pub, (err2) => {\n\t\t\t\tif (err2) {\n\t\t\t\t\treturn callback(err2)\n\t\t\t\t}\n\t\t\t\tclient.incomingStore.del(pub, client.noop)\n\t\t\t\tclient['_sendPacket'](comp, callback)\n\t\t\t})\n\t\t} else {\n\t\t\tclient['_sendPacket'](comp, callback)\n\t\t}\n\t})\n}\n\nexport default handlePubrel\n","import handlePublish from './publish'\nimport handleAuth from './auth'\nimport handleConnack from './connack'\nimport handleAck from './ack'\nimport handlePubrel from './pubrel'\nimport { PacketHandler } from '../shared'\n\nconst handle: PacketHandler = (client, packet, done) => {\n\tconst { options } = client\n\n\tif (\n\t\toptions.protocolVersion === 5 &&\n\t\toptions.properties &&\n\t\toptions.properties.maximumPacketSize &&\n\t\toptions.properties.maximumPacketSize < packet.length\n\t) {\n\t\tclient.emit('error', new Error(`exceeding packets size ${packet.cmd}`))\n\t\tclient.end({\n\t\t\treasonCode: 149,\n\t\t\tproperties: { reasonString: 'Maximum packet size was exceeded' },\n\t\t})\n\t\treturn client\n\t}\n\n\tclient.log('_handlePacket :: emitting packetreceive')\n\tclient.emit('packetreceive', packet)\n\n\tswitch (packet.cmd) {\n\t\tcase 'publish':\n\t\t\t// DO NOT SHIFT PING HERE, this would lead to https://github.com/mqttjs/MQTT.js/issues/1861\n\t\t\thandlePublish(client, packet, done)\n\t\t\tbreak\n\t\tcase 'puback':\n\t\tcase 'pubrec':\n\t\tcase 'pubcomp':\n\t\tcase 'suback':\n\t\tcase 'unsuback':\n\t\t\tclient.reschedulePing()\n\t\t\thandleAck(client, packet)\n\t\t\tdone()\n\t\t\tbreak\n\t\tcase 'pubrel':\n\t\t\tclient.reschedulePing()\n\t\t\thandlePubrel(client, packet, done)\n\t\t\tbreak\n\t\tcase 'connack':\n\t\t\t// no need to reschedule ping here as keepalive manager is created after successll connect\n\t\t\t// (when onConnect is called at the end of handleConnack)\n\t\t\thandleConnack(client, packet)\n\t\t\tdone()\n\t\t\tbreak\n\t\tcase 'auth':\n\t\t\tclient.reschedulePing()\n\t\t\thandleAuth(client, packet)\n\t\t\tdone()\n\t\t\tbreak\n\t\tcase 'pingresp':\n\t\t\tclient.log('_handlePacket :: received pingresp')\n\t\t\tclient.reschedulePing(true)\n\t\t\tdone()\n\t\t\tbreak\n\t\tcase 'disconnect':\n\t\t\tclient.emit('disconnect', packet)\n\t\t\tdone()\n\t\t\tbreak\n\t\tdefault:\n\t\t\t// TODO: unknown packet received. Should we emit an error?\n\t\t\tclient.log('_handlePacket :: unknown command')\n\t\t\tdone()\n\t\t\tbreak\n\t}\n}\n\nexport default handle\n","import EventEmitter from 'events'\nimport { applyMixin } from './shared'\n\nexport type EventHandler =\n\t// Add more overloads as necessary\n\t| ((arg1: any, arg2: any, arg3: any, arg4: any) => void)\n\t| ((arg1: any, arg2: any, arg3: any) => void)\n\t| ((arg1: any, arg2: any) => void)\n\t| ((arg1: any) => void)\n\t| ((...args: any[]) => void)\n\nexport interface TypedEventEmitter<\n\tTEvents extends Record<keyof TEvents, EventHandler>,\n> {\n\ton<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\tonce<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\tprependListener<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\tprependOnceListener<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\n\tremoveListener<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\toff<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tcallback: TEvents[TEvent],\n\t): this\n\n\tremoveAllListeners(event?: keyof TEvents): this\n\n\temit<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\t...args: Parameters<TEvents[TEvent]>\n\t): boolean\n\n\tsetMaxListeners(n: number): this\n\tgetMaxListeners(): number\n\n\tlisteners<TEvent extends keyof TEvents>(\n\t\teventName: TEvent,\n\t): TEvents[TEvent][]\n\trawListeners<TEvent extends keyof TEvents>(\n\t\teventName: TEvent,\n\t): TEvents[TEvent][]\n\tlistenerCount<TEvent extends keyof TEvents>(\n\t\tevent: TEvent,\n\t\tlistener?: TEvents[TEvent],\n\t): number\n\n\teventNames(): Array<keyof TEvents>\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport class TypedEventEmitter<\n\tTEvents extends Record<keyof TEvents, EventHandler>,\n> {}\n\n// Make TypedEventEmitter inherit from EventEmitter without actually extending\napplyMixin(TypedEventEmitter, EventEmitter)\n","const isStandardBrowserEnv = () => {\n\t// window is only defined when it is a browser\n\tif (typeof window !== 'undefined') {\n\t\t// Is the process an electron application\n\t\t// check if we are in electron `renderer`\n\t\tconst electronRenderCheck =\n\t\t\ttypeof navigator !== 'undefined' &&\n\t\t\tnavigator.userAgent?.toLowerCase().indexOf(' electron/') > -1\n\t\tif (electronRenderCheck && process?.versions) {\n\t\t\tconst electronMainCheck = Object.prototype.hasOwnProperty.call(\n\t\t\t\tprocess.versions,\n\t\t\t\t'electron',\n\t\t\t)\n\t\t\t// Both electron checks are only true if the following webPreferences are set in the main electron BrowserWindow()\n\t\t\t// webPreferences: {\n\t\t\t// sandbox: false,\n\t\t\t// nodeIntegration: true\n\t\t\t// contextIsolation: false\n\t\t\t// }\n\t\t\treturn !electronMainCheck\n\t\t}\n\t\treturn typeof window.document !== 'undefined'\n\t}\n\t// return false if nothing is detected\n\treturn false\n}\n\nconst isWebWorkerEnv = () =>\n\tBoolean(\n\t\t// eslint-disable-next-line no-restricted-globals\n\t\ttypeof self === 'object' &&\n\t\t\t// eslint-disable-next-line no-restricted-globals\n\t\t\tself?.constructor?.name?.includes('WorkerGlobalScope'),\n\t)\n\nconst isReactNativeEnv = () =>\n\ttypeof navigator !== 'undefined' && navigator.product === 'ReactNative'\n\nconst isBrowser =\n\tisStandardBrowserEnv() || isWebWorkerEnv() || isReactNativeEnv()\n\nexport const isWebWorker = isWebWorkerEnv()\n\nexport const isReactNativeBrowser = isReactNativeEnv()\n\nexport default isBrowser\n","import { TAddUniqueNumberFactory } from '../types';\n\nexport const createAddUniqueNumber: TAddUniqueNumberFactory = (generateUniqueNumber) => {\n return (set) => {\n const number = generateUniqueNumber(set);\n\n set.add(number);\n\n return number;\n };\n};\n","import { TCacheFactory } from '../types';\n\nexport const createCache: TCacheFactory = (lastNumberWeakMap) => {\n return (collection, nextNumber) => {\n lastNumberWeakMap.set(collection, nextNumber);\n\n return nextNumber;\n };\n};\n","import { TGenerateUniqueNumberFactory } from '../types';\n\n/*\n * The value of the constant Number.MAX_SAFE_INTEGER equals (2 ** 53 - 1) but it\n * is fairly new.\n */\nconst MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER === undefined ? 9007199254740991 : Number.MAX_SAFE_INTEGER;\nconst TWO_TO_THE_POWER_OF_TWENTY_NINE = 536870912;\nconst TWO_TO_THE_POWER_OF_THIRTY = TWO_TO_THE_POWER_OF_TWENTY_NINE * 2;\n\nexport const createGenerateUniqueNumber: TGenerateUniqueNumberFactory = (cache, lastNumberWeakMap) => {\n return (collection) => {\n const lastNumber = lastNumberWeakMap.get(collection);\n\n /*\n * Let's try the cheapest algorithm first. It might fail to produce a new\n * number, but it is so cheap that it is okay to take the risk. Just\n * increase the last number by one or reset it to 0 if we reached the upper\n * bound of SMIs (which stands for small integers). When the last number is\n * unknown it is assumed that the collection contains zero based consecutive\n * numbers.\n */\n let nextNumber = lastNumber === undefined ? collection.size : lastNumber < TWO_TO_THE_POWER_OF_THIRTY ? lastNumber + 1 : 0;\n\n if (!collection.has(nextNumber)) {\n return cache(collection, nextNumber);\n }\n\n /*\n * If there are less than half of 2 ** 30 numbers stored in the collection,\n * the chance to generate a new random number in the range from 0 to 2 ** 30\n * is at least 50%. It's benifitial to use only SMIs because they perform\n * much better in any environment based on V8.\n */\n if (collection.size < TWO_TO_THE_POWER_OF_TWENTY_NINE) {\n while (collection.has(nextNumber)) {\n nextNumber = Math.floor(Math.random() * TWO_TO_THE_POWER_OF_THIRTY);\n }\n\n return cache(collection, nextNumber);\n }\n\n // Quickly check if there is a theoretical chance to generate a new number.\n if (collection.size > MAX_SAFE_INTEGER) {\n throw new Error('Congratulations, you created a collection of unique numbers which uses all available integers!');\n }\n\n // Otherwise use the full scale of safely usable integers.\n while (collection.has(nextNumber)) {\n nextNumber = Math.floor(Math.random() * MAX_SAFE_INTEGER);\n }\n\n return cache(collection, nextNumber);\n };\n};\n","export {};\n//# sourceMappingURL=add-unique-number-factory.js.map","export {};\n//# sourceMappingURL=add-unique-number-function.js.map","export {};\n//# sourceMappingURL=cache-factory.js.map","export {};\n//# sourceMappingURL=cache-function.js.map","export {};\n//# sourceMappingURL=generate-unique-number-factory.js.map","export {};\n//# sourceMappingURL=generate-unique-number-function.js.map","export * from './add-unique-number-factory';\nexport * from './add-unique-number-function';\nexport * from './cache-factory';\nexport * from './cache-function';\nexport * from './generate-unique-number-factory';\nexport * from './generate-unique-number-function';\n","import { createAddUniqueNumber } from './factories/add-unique-number';\nimport { createCache } from './factories/cache';\nimport { createGenerateUniqueNumber } from './factories/generate-unique-number';\n\n/*\n * @todo Explicitly referencing the barrel file seems to be necessary when enabling the\n * isolatedModules compiler option.\n */\nexport * from './types/index';\n\nconst LAST_NUMBER_WEAK_MAP = new WeakMap<Map<number, any> | Set<number>, number>();\n\nconst cache = createCache(LAST_NUMBER_WEAK_MAP);\nconst generateUniqueNumber = createGenerateUniqueNumber(cache, LAST_NUMBER_WEAK_MAP);\nconst addUniqueNumber = createAddUniqueNumber(generateUniqueNumber);\n\nexport { addUniqueNumber, generateUniqueNumber };\n","import { ICallNotification, TWorkerMessage } from 'worker-timers-worker';\n\nexport const isCallNotification = (message: TWorkerMessage): message is ICallNotification => {\n return (<ICallNotification>message).method !== undefined && (<ICallNotification>message).method === 'call';\n};\n","import { IClearResponse, TWorkerMessage } from 'worker-timers-worker';\n\nexport const isClearResponse = (message: TWorkerMessage): message is IClearResponse => {\n return (<IClearResponse>message).error === null && typeof message.id === 'number';\n};\n","import { generateUniqueNumber } from 'fast-unique-numbers';\nimport { IClearRequest, ISetNotification, IWorkerEvent, TTimerType } from 'worker-timers-worker';\nimport { isCallNotification } from './guards/call-notification';\nimport { isClearResponse } from './guards/clear-response';\n\nexport const load = (url: string) => {\n // Prefilling the Maps with a function indexed by zero is necessary to be compliant with the specification.\n const scheduledIntervalFunctions: Map<number, number | Function> = new Map([[0, () => {}]]); // tslint:disable-line no-empty\n const scheduledTimeoutFunctions: Map<number, number | Function> = new Map([[0, () => {}]]); // tslint:disable-line no-empty\n const unrespondedRequests: Map<number, { timerId: number; timerType: TTimerType }> = new Map();\n\n const worker = new Worker(url);\n\n worker.addEventListener('message', ({ data }: IWorkerEvent) => {\n if (isCallNotification(data)) {\n const {\n params: { timerId, timerType }\n } = data;\n\n if (timerType === 'interval') {\n const idOrFunc = scheduledIntervalFunctions.get(timerId);\n\n if (typeof idOrFunc === 'number') {\n const timerIdAndTimerType = unrespondedRequests.get(idOrFunc);\n\n if (\n timerIdAndTimerType === undefined ||\n timerIdAndTimerType.timerId !== timerId ||\n timerIdAndTimerType.timerType !== timerType\n ) {\n throw new Error('The timer is in an undefined state.');\n }\n } else if (typeof idOrFunc !== 'undefined') {\n idOrFunc();\n } else {\n throw new Error('The timer is in an undefined state.');\n }\n } else if (timerType === 'timeout') {\n const idOrFunc = scheduledTimeoutFunctions.get(timerId);\n\n if (typeof idOrFunc === 'number') {\n const timerIdAndTimerType = unrespondedRequests.get(idOrFunc);\n\n if (\n timerIdAndTimerType === undefined ||\n timerIdAndTimerType.timerId !== timerId ||\n timerIdAndTimerType.timerType !== timerType\n ) {\n throw new Error('The timer is in an undefined state.');\n }\n } else if (typeof idOrFunc !== 'undefined') {\n idOrFunc();\n\n // A timeout can be savely deleted because it is only called once.\n scheduledTimeoutFunctions.delete(timerId);\n } else {\n throw new Error('The timer is in an undefined state.');\n }\n }\n } else if (isClearResponse(data)) {\n const { id } = data;\n\n const timerIdAndTimerType = unrespondedRequests.get(id);\n\n if (timerIdAndTimerType === undefined) {\n throw new Error('The timer is in an undefined state.');\n }\n\n const { timerId, timerType } = timerIdAndTimerType;\n\n unrespondedRequests.delete(id);\n\n if (timerType === 'interval') {\n scheduledIntervalFunctions.delete(timerId);\n } else {\n scheduledTimeoutFunctions.delete(timerId);\n }\n } else {\n const {\n error: { message }\n } = data;\n\n throw new Error(message);\n }\n });\n\n const clearInterval = (timerId: number) => {\n const id = generateUniqueNumber(unrespondedRequests);\n\n unrespondedRequests.set(id, { timerId, timerType: 'interval' });\n scheduledIntervalFunctions.set(timerId, id);\n\n worker.postMessage(<IClearRequest>{\n id,\n method: 'clear',\n params: { timerId, timerType: 'interval' }\n });\n };\n\n const clearTimeout = (timerId: number) => {\n const id = generateUniqueNumber(unrespondedRequests);\n\n unrespondedRequests.set(id, { timerId, timerType: 'timeout' });\n scheduledTimeoutFunctions.set(timerId, id);\n\n worker.postMessage(<IClearRequest>{\n id,\n method: 'clear',\n params: { timerId, timerType: 'timeout' }\n });\n };\n\n const setInterval = (func: Function, delay = 0) => {\n const timerId = generateUniqueNumber(scheduledIntervalFunctions);\n\n scheduledIntervalFunctions.set(timerId, () => {\n func();\n\n // Doublecheck if the interval should still be rescheduled because it could have been cleared inside of func().\n if (typeof scheduledIntervalFunctions.get(timerId) === 'function') {\n worker.postMessage(<ISetNotification>{\n id: null,\n method: 'set',\n params: {\n delay,\n now: performance.now(),\n timerId,\n timerType: 'interval'\n }\n });\n }\n });\n\n worker.postMessage(<ISetNotification>{\n id: null,\n method: 'set',\n params: {\n delay,\n now: performance.now(),\n timerId,\n timerType: 'interval'\n }\n });\n\n return timerId;\n };\n\n const setTimeout = (func: Function, delay = 0) => {\n const timerId = generateUniqueNumber(scheduledTimeoutFunctions);\n\n scheduledTimeoutFunctions.set(timerId, func);\n\n worker.postMessage(<ISetNotification>{\n id: null,\n method: 'set',\n params: {\n delay,\n now: performance.now(),\n timerId,\n timerType: 'timeout'\n }\n });\n\n return timerId;\n };\n\n return {\n clearInterval,\n clearTimeout,\n setInterval,\n setTimeout\n };\n};\n","export const createLoadOrReturnBroker = <Broker>(loadBroker: (url: string) => Broker, worker: string) => {\n let broker: null | Broker = null;\n\n return () => {\n if (broker !== null) {\n return broker;\n }\n\n const blob = new Blob([worker], { type: 'application/javascript; charset=utf-8' });\n const url = URL.createObjectURL(blob);\n\n broker = loadBroker(url);\n\n // Bug #1: Edge up until v18 didn't like the URL to be revoked directly.\n setTimeout(() => URL.revokeObjectURL(url));\n\n return broker;\n };\n};\n","// This is the minified and stringified code of the worker-timers-worker package.\nexport const worker = `(()=>{\"use strict\";const e=new Map,t=new Map,r=(e,t)=>{let r,o;const i=performance.now();r=i,o=e-Math.max(0,i-t);return{expected:r+o,remainingDelay:o}},o=(e,t,r,i)=>{const s=performance.now();s>r?postMessage({id:null,method:\"call\",params:{timerId:t,timerType:i}}):e.set(t,setTimeout(o,r-s,e,t,r,i))};addEventListener(\"message\",(i=>{let{data:s}=i;try{if(\"clear\"===s.method){const{id:r,params:{timerId:o,timerType:i}}=s;if(\"interval\"===i)(t=>{const r=e.get(t);if(void 0===r)throw new Error('There is no interval scheduled with the given id \"'.concat(t,'\".'));clearTimeout(r),e.delete(t)})(o),postMessage({error:null,id:r});else{if(\"timeout\"!==i)throw new Error('The given type \"'.concat(i,'\" is not supported'));(e=>{const r=t.get(e);if(void 0===r)throw new Error('There is no timeout scheduled with the given id \"'.concat(e,'\".'));clearTimeout(r),t.delete(e)})(o),postMessage({error:null,id:r})}}else{if(\"set\"!==s.method)throw new Error('The given method \"'.concat(s.method,'\" is not supported'));{const{params:{delay:i,now:n,timerId:a,timerType:d}}=s;if(\"interval\"===d)((t,i,s)=>{const{expected:n,remainingDelay:a}=r(t,s);e.set(i,setTimeout(o,a,e,i,n,\"interval\"))})(i,a,n);else{if(\"timeout\"!==d)throw new Error('The given type \"'.concat(d,'\" is not supported'));((e,i,s)=>{const{expected:n,remainingDelay:a}=r(e,s);t.set(i,setTimeout(o,a,t,i,n,\"timeout\"))})(i,a,n)}}}}catch(e){postMessage({error:{message:e.message},id:s.id,result:null})}}))})();`; // tslint:disable-line:max-line-length\n","import { load } from 'worker-timers-broker';\nimport { createLoadOrReturnBroker } from './factories/load-or-return-broker';\nimport { worker } from './worker/worker';\n\nconst loadOrReturnBroker = createLoadOrReturnBroker(load, worker);\n\nexport const clearInterval: ReturnType<typeof load>['clearInterval'] = (timerId) => loadOrReturnBroker().clearInterval(timerId);\n\nexport const clearTimeout: ReturnType<typeof load>['clearTimeout'] = (timerId) => loadOrReturnBroker().clearTimeout(timerId);\n\nexport const setInterval: ReturnType<typeof load>['setInterval'] = (...args) => loadOrReturnBroker().setInterval(...args);\n\nexport const setTimeout: ReturnType<typeof load>['setTimeout'] = (...args) => loadOrReturnBroker().setTimeout(...args);\n","import isBrowser, { isWebWorker, isReactNativeBrowser } from './is-browser'\nimport { clearInterval as clearI, setInterval as setI } from 'worker-timers'\nimport type { TimerVariant } from './shared'\n\n// dont directly assign globals to class props otherwise this throws in web workers: Uncaught TypeError: Illegal invocation\n// See: https://stackoverflow.com/questions/9677985/uncaught-typeerror-illegal-invocation-in-chrome\n\nexport interface Timer {\n\tset: typeof setI\n\tclear: typeof clearI\n}\n\nconst workerTimer: Timer = {\n\tset: setI,\n\tclear: clearI,\n}\n\nconst nativeTimer: Timer = {\n\tset: (func, time) => setInterval(func, time),\n\tclear: (timerId) => clearInterval(timerId),\n}\n\nconst getTimer = (variant: TimerVariant): Timer => {\n\tswitch (variant) {\n\t\tcase 'native': {\n\t\t\treturn nativeTimer\n\t\t}\n\t\tcase 'worker': {\n\t\t\treturn workerTimer\n\t\t}\n\t\tcase 'auto':\n\t\tdefault: {\n\t\t\treturn isBrowser && !isWebWorker && !isReactNativeBrowser\n\t\t\t\t? workerTimer\n\t\t\t\t: nativeTimer\n\t\t}\n\t}\n}\n\nexport default getTimer\n","import type MqttClient from './client'\nimport getTimer, { type Timer } from './get-timer'\nimport type { TimerVariant } from './shared'\n\nexport default class KeepaliveManager {\n\tprivate _keepalive: number\n\n\tprivate timerId: number\n\n\tprivate timer: Timer\n\n\tprivate destroyed = false\n\n\tprivate counter: number\n\n\tprivate client: MqttClient\n\n\tprivate _keepaliveTimeoutTimestamp: number\n\n\tprivate _intervalEvery: number\n\n\t/** Timestamp of next keepalive timeout */\n\tget keepaliveTimeoutTimestamp() {\n\t\treturn this._keepaliveTimeoutTimestamp\n\t}\n\n\t/** Milliseconds of the actual interval */\n\tget intervalEvery() {\n\t\treturn this._intervalEvery\n\t}\n\n\tget keepalive() {\n\t\treturn this._keepalive\n\t}\n\n\tconstructor(client: MqttClient, variant: TimerVariant | Timer) {\n\t\tthis.client = client\n\t\tthis.timer =\n\t\t\ttypeof variant === 'object' &&\n\t\t\t'set' in variant &&\n\t\t\t'clear' in variant\n\t\t\t\t? variant\n\t\t\t\t: getTimer(variant)\n\t\tthis.setKeepalive(client.options.keepalive)\n\t}\n\n\tprivate clear() {\n\t\tif (this.timerId) {\n\t\t\tthis.timer.clear(this.timerId)\n\t\t\tthis.timerId = null\n\t\t}\n\t}\n\n\t/** Change the keepalive */\n\tsetKeepalive(value: number) {\n\t\t// keepalive is in seconds\n\t\tvalue *= 1000\n\n\t\tif (\n\t\t\t// eslint-disable-next-line no-restricted-globals\n\t\t\tisNaN(value) ||\n\t\t\tvalue <= 0 ||\n\t\t\tvalue > 2147483647\n\t\t) {\n\t\t\tthrow new Error(\n\t\t\t\t`Keepalive value must be an integer between 0 and 2147483647. Provided value is ${value}`,\n\t\t\t)\n\t\t}\n\n\t\tthis._keepalive = value\n\n\t\tthis.reschedule()\n\n\t\tthis.client['log'](`KeepaliveManager: set keepalive to ${value}ms`)\n\t}\n\n\tdestroy() {\n\t\tthis.clear()\n\t\tthis.destroyed = true\n\t}\n\n\treschedule() {\n\t\tif (this.destroyed) {\n\t\t\treturn\n\t\t}\n\n\t\tthis.clear()\n\t\tthis.counter = 0\n\n\t\t// https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/os/mqtt-v3.1.1-os.html#_Figure_3.5_Keep\n\t\tconst keepAliveTimeout = Math.ceil(this._keepalive * 1.5)\n\n\t\tthis._keepaliveTimeoutTimestamp = Date.now() + keepAliveTimeout\n\t\tthis._intervalEvery = Math.ceil(this._keepalive / 2)\n\n\t\tthis.timerId = this.timer.set(() => {\n\t\t\t// this should never happen, but just in case\n\t\t\tif (this.destroyed) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.counter += 1\n\n\t\t\t// after keepalive seconds, send a pingreq\n\t\t\tif (this.counter === 2) {\n\t\t\t\tthis.client.sendPing()\n\t\t\t} else if (this.counter > 2) {\n\t\t\t\tthis.client.onKeepaliveTimeout()\n\t\t\t}\n\t\t}, this._intervalEvery)\n\t}\n}\n","/**\n * Module dependencies\n */\nimport TopicAliasRecv from './topic-alias-recv'\nimport mqttPacket, {\n\tIAuthPacket,\n\tIConnackPacket,\n\tIDisconnectPacket,\n\tIPublishPacket,\n\tISubscribePacket,\n\tISubscription,\n\tIUnsubscribePacket,\n\tPacket,\n\tQoS,\n\tISubackPacket,\n\tIConnectPacket,\n} from 'mqtt-packet'\nimport DefaultMessageIdProvider, {\n\tIMessageIdProvider,\n} from './default-message-id-provider'\nimport { DuplexOptions, Writable } from 'readable-stream'\nimport clone from 'rfdc/default'\nimport * as validations from './validations'\nimport _debug from 'debug'\nimport Store, { IStore } from './store'\nimport handlePacket from './handlers'\nimport { ClientOptions } from 'ws'\nimport { ClientRequestArgs } from 'http'\nimport {\n\tDoneCallback,\n\tErrorWithReasonCode,\n\tGenericCallback,\n\tIStream,\n\tMQTTJS_VERSION,\n\tStreamBuilder,\n\tTimerVariant,\n\tVoidCallback,\n\tnextTick,\n} from './shared'\nimport TopicAliasSend from './topic-alias-send'\nimport { TypedEventEmitter } from './TypedEmitter'\nimport KeepaliveManager from './KeepaliveManager'\nimport isBrowser, { isWebWorker } from './is-browser'\nimport { Timer } from './get-timer'\n\nconst setImmediate =\n\tglobalThis.setImmediate ||\n\t(((...args: any[]) => {\n\t\tconst callback = args.shift()\n\t\tnextTick(() => {\n\t\t\tcallback(...args)\n\t\t})\n\t}) as typeof globalThis.setImmediate)\n\nconst defaultConnectOptions: IClientOptions = {\n\tkeepalive: 60,\n\treschedulePings: true,\n\tprotocolId: 'MQTT',\n\tprotocolVersion: 4,\n\treconnectPeriod: 1000,\n\tconnectTimeout: 30 * 1000,\n\tclean: true,\n\tresubscribe: true,\n\twriteCache: true,\n\ttimerVariant: 'auto',\n}\n\nexport type BaseMqttProtocol =\n\t| 'wss'\n\t| 'ws'\n\t| 'mqtt'\n\t| 'mqtts'\n\t| 'tcp'\n\t| 'ssl'\n\t| 'wx'\n\t| 'wxs'\n\t| 'ali'\n\t| 'alis'\n\n// create a type that allows all MqttProtocol + `+unix` string\nexport type MqttProtocolWithUnix = `${BaseMqttProtocol}+unix`\n\nexport type MqttProtocol = BaseMqttProtocol | MqttProtocolWithUnix\n\nexport type StorePutCallback = () => void\n\nexport interface ISecureClientOptions {\n\t/**\n\t * optional private keys in PEM format\n\t */\n\tkey?: string | string[] | Buffer | Buffer[] | any[]\n\tkeyPath?: string\n\t/**\n\t * optional cert chains in PEM format\n\t */\n\tcert?: string | string[] | Buffer | Buffer[]\n\tcertPath?: string\n\t/**\n\t * Optionally override the trusted CA certificates in PEM format\n\t */\n\tca?: string | string[] | Buffer | Buffer[]\n\tcaPaths?: string | string[]\n\n\trejectUnauthorized?: boolean\n\t/**\n\t * optional alpn's\n\t */\n\tALPNProtocols?: string[] | Buffer[] | Uint8Array[] | Buffer | Uint8Array\n}\n\nexport type AckHandler = (\n\ttopic: string,\n\tmessage: Buffer,\n\tpacket: any,\n\tcb: (error: Error | number, code?: number) => void,\n) => void\n\nexport interface IClientOptions extends ISecureClientOptions {\n\t/** CLIENT PROPERTIES */\n\n\t/** Encoding to use. Example 'binary' */\n\tencoding?: BufferEncoding\n\t/** Set browser buffer size. Default to 512KB */\n\tbrowserBufferSize?: number\n\t/** used in ws protocol to set `objectMode` */\n\tbinary?: boolean\n\t/** Used on ali protocol */\n\tmy?: any\n\t/** Manually call `connect` after creating client instance */\n\tmanualConnect?: boolean\n\t/** Custom auth packet properties */\n\tauthPacket?: Partial<IAuthPacket>\n\t/** Disable/Enable writeToStream.cacheNumbers */\n\twriteCache?: boolean\n\t/** Should be set to `host` */\n\tservername?: string\n\t/** The default protocol to use when using `servers` and no protocol is specified */\n\tdefaultProtocol?: MqttProtocol\n\t/** Support clientId passed in the query string of the url */\n\tquery?: Record<string, string>\n\t/** Auth string in the format <username>:<password> */\n\tauth?: string\n\t/** Custom ack handler */\n\tcustomHandleAcks?: AckHandler\n\t/** Broker port */\n\tport?: number\n\t/** Broker host. Does NOT include port */\n\thost?: string\n\t/** @deprecated use `host instead */\n\thostname?: string\n\t/** Set to true if the connection is to a unix socket */\n\tunixSocket?: boolean\n\t/** Websocket `path` added as suffix or Unix socket path when `unixSocket` option is true */\n\tpath?: string\n\t/** The `MqttProtocol` to use */\n\tprotocol?: MqttProtocol\n\n\t/** Websocket options */\n\twsOptions?: ClientOptions | ClientRequestArgs | DuplexOptions\n\n\t/**\n\t * 1000 milliseconds, interval between two reconnections\n\t */\n\treconnectPeriod?: number\n\t/**\n\t * 30 * 1000 milliseconds, time to wait before a CONNACK is received\n\t */\n\tconnectTimeout?: number\n\n\t/**\n\t * a Store for the incoming packets\n\t */\n\tincomingStore?: IStore\n\t/**\n\t * a Store for the outgoing packets\n\t */\n\toutgoingStore?: IStore\n\n\t/** Enable/Disable queue for QoS 0 packets */\n\tqueueQoSZero?: boolean\n\n\t/** Custom log function, default uses `debug` */\n\tlog?: (...args: any[]) => void\n\n\t/** automatically use topic alias */\n\tautoUseTopicAlias?: boolean\n\n\t/** automatically assign topic alias */\n\tautoAssignTopicAlias?: boolean\n\n\t/** Set to false to disable ping reschedule. When enabled ping messages are rescheduled on each message sent */\n\treschedulePings?: boolean\n\n\t/** List of broker servers. On each reconnect try the next server will be used */\n\tservers?: Array<{\n\t\thost: string\n\t\tport: number\n\t\tprotocol?:\n\t\t\t| 'wss'\n\t\t\t| 'ws'\n\t\t\t| 'mqtt'\n\t\t\t| 'mqtts'\n\t\t\t| 'tcp'\n\t\t\t| 'ssl'\n\t\t\t| 'wx'\n\t\t\t| 'wxs'\n\t}>\n\t/**\n\t * true, set to false to disable re-subscribe functionality\n\t */\n\tresubscribe?: boolean\n\n\t/** when defined this function will be called to transform the url string generated by MqttClient from provided options */\n\ttransformWsUrl?: (\n\t\turl: string,\n\t\toptions: IClientOptions,\n\t\tclient: MqttClient,\n\t) => string\n\n\t/** when defined this function will be called to create the Websocket instance, used to add custom protocols or websocket implementations */\n\tcreateWebsocket?: (\n\t\turl: string,\n\t\twebsocketSubProtocols: string[],\n\t\toptions: IClientOptions,\n\t) => any\n\n\t/** Custom message id provider */\n\tmessageIdProvider?: IMessageIdProvider\n\n\t/** When using websockets, this is the timeout used when writing to socket. Default 1000 (1s) */\n\tbrowserBufferTimeout?: number\n\n\t/**\n\t * When using websockets, this sets the `objectMode` option.\n\t * When in objectMode, streams can push Strings and Buffers\n\t * as well as any other JavaScript object.\n\t * Another major difference is that when in objectMode,\n\t * the internal buffering algorithm counts objects rather than bytes.\n\t * This means if we have a Transform stream with the highWaterMark option set to 5,\n\t * the stream will only buffer a maximum of 5 objects internally\n\t */\n\tobjectMode?: boolean\n\n\t/** CONNECT PACKET PROPERTIES */\n\n\t/**\n\t * 'mqttjs_' + Math.random().toString(16).substr(2, 8)\n\t */\n\tclientId?: string\n\t/**\n\t * 3=MQTT 3.1 4=MQTT 3.1.1 5=MQTT 5.0. Defaults to 4\n\t */\n\tprotocolVersion?: IConnectPacket['protocolVersion']\n\t/**\n\t * 'MQTT'\n\t */\n\tprotocolId?: IConnectPacket['protocolId']\n\t/**\n\t * true, set to false to receive QoS 1 and 2 messages while offline\n\t */\n\tclean?: boolean\n\t/**\n\t * 60 seconds, set to 0 to disable\n\t */\n\tkeepalive?: number\n\t/**\n\t * the username required by your broker, if any\n\t */\n\tusername?: string\n\t/**\n\t * the password required by your broker, if any\n\t */\n\tpassword?: Buffer | string\n\t/**\n\t * a message that will sent by the broker automatically when the client disconnect badly.\n\t */\n\twill?: IConnectPacket['will']\n\t/** see `connect` packet: https://github.com/mqttjs/mqtt-packet/blob/master/types/index.d.ts#L65 */\n\tproperties?: IConnectPacket['properties']\n\t/**\n\t * @description 'auto', set to 'native' or 'worker' if you're having issues with 'auto' detection\n\t * or pass a custom timer object\n\t */\n\ttimerVariant?: TimerVariant | Timer\n\t/**\n\t * false, set to true to force the use of native WebSocket if you're having issues with the detection\n\t */\n\tforceNativeWebSocket?: boolean\n}\n\nexport interface IClientPublishOptions {\n\t/**\n\t * the QoS\n\t */\n\tqos?: QoS\n\t/**\n\t * the retain flag\n\t */\n\tretain?: boolean\n\t/**\n\t * whether or not mark a message as duplicate\n\t */\n\tdup?: boolean\n\t/*\n\t * MQTT 5.0 properties object\n\t */\n\tproperties?: IPublishPacket['properties']\n\t/**\n\t * callback called when message is put into `outgoingStore`\n\t */\n\tcbStorePut?: StorePutCallback\n}\n\nexport interface IClientReconnectOptions {\n\t/**\n\t * a Store for the incoming packets\n\t */\n\tincomingStore?: Store\n\t/**\n\t * a Store for the outgoing packets\n\t */\n\toutgoingStore?: Store\n}\nexport interface IClientSubscribeProperties {\n\t/*\n\t * MQTT 5.0 properties object of subscribe\n\t * */\n\tproperties?: ISubscribePacket['properties']\n}\n\nexport interface IClientSubscribeOptions extends IClientSubscribeProperties {\n\t/**\n\t * the QoS\n\t */\n\tqos: QoS\n\t/*\n\t * no local flag\n\t * */\n\tnl?: boolean\n\t/*\n\t * Retain As Published flag\n\t * */\n\trap?: boolean\n\t/*\n\t * Retain Handling option\n\t * */\n\trh?: number\n}\nexport interface ISubscriptionRequest extends IClientSubscribeOptions {\n\t/**\n\t * is a subscribed to topic\n\t */\n\ttopic: string\n}\n\nexport interface ISubscriptionGrant\n\textends Omit<ISubscriptionRequest, 'qos' | 'properties'> {\n\t/**\n\t * is the granted qos level on it, may return 128 on error\n\t */\n\tqos: QoS | 128\n}\n\nexport type ISubscriptionMap = {\n\t/**\n\t * object which has topic names as object keys and as value the options, like {'test1': {qos: 0}, 'test2': {qos: 2}}.\n\t */\n\t[topic: string]: IClientSubscribeOptions\n} & {\n\tresubscribe?: boolean\n}\n\nexport interface IClientUnsubscribeProperties {\n\t/*\n\t * MQTT 5.0 properties object for unsubscribe\n\t * */\n\tproperties?: IUnsubscribePacket['properties']\n}\n\nexport { IConnackPacket, IDisconnectPacket, IPublishPacket, Packet }\nexport type OnConnectCallback = (packet: IConnackPacket) => void\nexport type OnDisconnectCallback = (packet: IDisconnectPacket) => void\nexport type ClientSubscribeCallback = (\n\terr: Error | null,\n\tgranted?: ISubscriptionGrant[],\n\tpacket?: ISubackPacket,\n) => void\nexport type OnMessageCallback = (\n\ttopic: string,\n\tpayload: Buffer,\n\tpacket: IPublishPacket,\n) => void\nexport type OnPacketCallback = (packet: Packet) => void\nexport type OnCloseCallback = () => void\nexport type OnErrorCallback = (error: Error | ErrorWithReasonCode) => void\nexport type PacketCallback = (\n\terror?: Error | ErrorWithReasonCode,\n\tpacket?: Packet,\n) => any\nexport type CloseCallback = (error?: Error) => void\n\nexport interface MqttClientEventCallbacks {\n\tconnect: OnConnectCallback\n\tmessage: OnMessageCallback\n\tpacketsend: OnPacketCallback\n\tpacketreceive: OnPacketCallback\n\tdisconnect: OnDisconnectCallback\n\terror: OnErrorCallback\n\tclose: OnCloseCallback\n\tend: VoidCallback\n\treconnect: VoidCallback\n\toffline: VoidCallback\n\toutgoingEmpty: VoidCallback\n}\n\n/**\n * MqttClient constructor\n *\n * @param {Stream} stream - stream\n * @param {Object} [options] - connection options\n * (see Connection#connect)\n */\nexport default class MqttClient extends TypedEventEmitter<MqttClientEventCallbacks> {\n\tpublic static VERSION = MQTTJS_VERSION\n\n\t/** Public fields */\n\n\t/** It's true when client is connected to broker */\n\tpublic connected: boolean\n\n\tpublic disconnecting: boolean\n\n\tpublic disconnected: boolean\n\n\tpublic reconnecting: boolean\n\n\tpublic incomingStore: IStore\n\n\tpublic outgoingStore: IStore\n\n\tpublic options: IClientOptions\n\n\tpublic queueQoSZero: boolean\n\n\tpublic _reconnectCount: number\n\n\tpublic log: (...args: any[]) => void\n\n\tpublic messageIdProvider: IMessageIdProvider\n\n\tpublic outgoing: Record<\n\t\tnumber,\n\t\t{ volatile: boolean; cb: (err: Error, packet?: Packet) => void }\n\t>\n\n\tpublic messageIdToTopic: Record<number, string[]>\n\n\tpublic noop: (error?: any) => void\n\n\tpublic keepaliveManager: KeepaliveManager\n\n\t/**\n\t * The connection to the Broker. In browsers env this also have `socket` property\n\t * set to the `WebSocket` instance.\n\t */\n\tpublic stream: IStream\n\n\tpublic queue: { packet: Packet; cb: PacketCallback }[]\n\n\t/* Private fields */\n\n\t/** Function used to build the stream */\n\tprivate streamBuilder: StreamBuilder\n\n\tprivate _resubscribeTopics: ISubscriptionMap\n\n\tprivate connackTimer: NodeJS.Timeout\n\n\tprivate reconnectTimer: NodeJS.Timeout\n\n\tprivate _storeProcessing: boolean\n\n\t/** keep a reference of packets that have been successfully processed from outgoing store */\n\tprivate _packetIdsDuringStoreProcessing: Record<number, boolean>\n\n\tprivate _storeProcessingQueue: {\n\t\tinvoke: () => any\n\t\tcbStorePut?: DoneCallback\n\t\tcallback: GenericCallback<any>\n\t}[]\n\n\tprivate _firstConnection: boolean\n\n\tprivate topicAliasRecv: TopicAliasRecv\n\n\tprivate topicAliasSend: TopicAliasSend\n\n\tprivate _deferredReconnect: () => void\n\n\tprivate connackPacket: IConnackPacket\n\n\tpublic static defaultId() {\n\t\treturn `mqttjs_${Math.random().toString(16).substr(2, 8)}`\n\t}\n\n\tconstructor(streamBuilder: StreamBuilder, options: IClientOptions) {\n\t\tsuper()\n\n\t\tthis.options = options || {}\n\n\t\t// Defaults\n\t\tfor (const k in defaultConnectOptions) {\n\t\t\tif (typeof this.options[k] === 'undefined') {\n\t\t\t\tthis.options[k] = defaultConnectOptions[k]\n\t\t\t} else {\n\t\t\t\tthis.options[k] = options[k]\n\t\t\t}\n\t\t}\n\n\t\tthis.log = this.options.log || _debug('mqttjs:client')\n\t\tthis.noop = this._noop.bind(this)\n\n\t\tthis.log('MqttClient :: version:', MqttClient.VERSION)\n\n\t\tif (isWebWorker) {\n\t\t\tthis.log('MqttClient :: environment', 'webworker')\n\t\t} else {\n\t\t\tthis.log(\n\t\t\t\t'MqttClient :: environment',\n\t\t\t\tisBrowser ? 'browser' : 'node',\n\t\t\t)\n\t\t}\n\n\t\tthis.log('MqttClient :: options.protocol', options.protocol)\n\t\tthis.log(\n\t\t\t'MqttClient :: options.protocolVersion',\n\t\t\toptions.protocolVersion,\n\t\t)\n\t\tthis.log('MqttClient :: options.username', options.username)\n\t\tthis.log('MqttClient :: options.keepalive', options.keepalive)\n\t\tthis.log(\n\t\t\t'MqttClient :: options.reconnectPeriod',\n\t\t\toptions.reconnectPeriod,\n\t\t)\n\t\tthis.log(\n\t\t\t'MqttClient :: options.rejectUnauthorized',\n\t\t\toptions.rejectUnauthorized,\n\t\t)\n\t\tthis.log(\n\t\t\t'MqttClient :: options.properties.topicAliasMaximum',\n\t\t\toptions.properties\n\t\t\t\t? options.properties.topicAliasMaximum\n\t\t\t\t: undefined,\n\t\t)\n\n\t\tthis.options.clientId =\n\t\t\ttypeof options.clientId === 'string'\n\t\t\t\t? options.clientId\n\t\t\t\t: MqttClient.defaultId()\n\n\t\tthis.log('MqttClient :: clientId', this.options.clientId)\n\n\t\tthis.options.customHandleAcks =\n\t\t\toptions.protocolVersion === 5 && options.customHandleAcks\n\t\t\t\t? options.customHandleAcks\n\t\t\t\t: (...args) => {\n\t\t\t\t\t\targs[3](null, 0)\n\t\t\t\t }\n\n\t\t// Disable pre-generated write cache if requested. Will allocate buffers on-the-fly instead. WARNING: This can affect write performance\n\t\tif (!this.options.writeCache) {\n\t\t\tmqttPacket.writeToStream.cacheNumbers = false\n\t\t}\n\n\t\tthis.streamBuilder = streamBuilder\n\n\t\tthis.messageIdProvider =\n\t\t\ttypeof this.options.messageIdProvider === 'undefined'\n\t\t\t\t? new DefaultMessageIdProvider()\n\t\t\t\t: this.options.messageIdProvider\n\n\t\t// Inflight message storages\n\t\tthis.outgoingStore = options.outgoingStore || new Store()\n\t\tthis.incomingStore = options.incomingStore || new Store()\n\n\t\t// Should QoS zero messages be queued when the connection is broken?\n\t\tthis.queueQoSZero =\n\t\t\toptions.queueQoSZero === undefined ? true : options.queueQoSZero\n\n\t\t// map of subscribed topics to support reconnection\n\t\tthis._resubscribeTopics = {}\n\n\t\t// map of a subscribe messageId and a topic\n\t\tthis.messageIdToTopic = {}\n\n\t\t// Keepalive manager, setup in _setupKeepaliveManager\n\t\tthis.keepaliveManager = null\n\t\t// Is the client connected?\n\t\tthis.connected = false\n\t\t// Are we disconnecting?\n\t\tthis.disconnecting = false\n\t\t// Are we reconnecting?\n\t\tthis.reconnecting = false\n\t\t// Packet queue\n\t\tthis.queue = []\n\t\t// connack timer\n\t\tthis.connackTimer = null\n\t\t// Reconnect timer\n\t\tthis.reconnectTimer = null\n\t\t// Is processing store?\n\t\tthis._storeProcessing = false\n\t\t// Packet Ids are put into the store during store processing\n\t\tthis._packetIdsDuringStoreProcessing = {}\n\t\t// Store processing queue\n\t\tthis._storeProcessingQueue = []\n\n\t\t// Inflight callbacks\n\t\tthis.outgoing = {}\n\n\t\t// True if connection is first time.\n\t\tthis._firstConnection = true\n\n\t\tif (options.properties && options.properties.topicAliasMaximum > 0) {\n\t\t\tif (options.properties.topicAliasMaximum > 0xffff) {\n\t\t\t\tthis.log(\n\t\t\t\t\t'MqttClient :: options.properties.topicAliasMaximum is out of range',\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\tthis.topicAliasRecv = new TopicAliasRecv(\n\t\t\t\t\toptions.properties.topicAliasMaximum,\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\n\t\t// Send queued packets\n\t\tthis.on('connect', () => {\n\t\t\tconst { queue } = this\n\n\t\t\tconst deliver = () => {\n\t\t\t\tconst entry = queue.shift()\n\t\t\t\tthis.log('deliver :: entry %o', entry)\n\t\t\t\tlet packet = null\n\n\t\t\t\tif (!entry) {\n\t\t\t\t\tthis._resubscribe()\n\t\t\t\t\treturn\n\t\t\t\t}\n\n\t\t\t\tpacket = entry.packet\n\t\t\t\tthis.log('deliver :: call _sendPacket for %o', packet)\n\t\t\t\tlet send = true\n\t\t\t\tif (packet.messageId && packet.messageId !== 0) {\n\t\t\t\t\tif (!this.messageIdProvider.register(packet.messageId)) {\n\t\t\t\t\t\tsend = false\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (send) {\n\t\t\t\t\tthis._sendPacket(packet, (err) => {\n\t\t\t\t\t\tif (entry.cb) {\n\t\t\t\t\t\t\tentry.cb(err)\n\t\t\t\t\t\t}\n\t\t\t\t\t\tdeliver()\n\t\t\t\t\t})\n\t\t\t\t} else {\n\t\t\t\t\tthis.log(\n\t\t\t\t\t\t'messageId: %d has already used. The message is skipped and removed.',\n\t\t\t\t\t\tpacket.messageId,\n\t\t\t\t\t)\n\t\t\t\t\tdeliver()\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.log('connect :: sending queued packets')\n\t\t\tdeliver()\n\t\t})\n\n\t\tthis.on('close', () => {\n\t\t\tthis.log('close :: connected set to `false`')\n\t\t\tthis.connected = false\n\n\t\t\tthis.log('close :: clearing connackTimer')\n\t\t\tclearTimeout(this.connackTimer)\n\n\t\t\tthis._destroyKeepaliveManager()\n\n\t\t\tif (this.topicAliasRecv) {\n\t\t\t\tthis.topicAliasRecv.clear()\n\t\t\t}\n\n\t\t\tthis.log('close :: calling _setupReconnect')\n\t\t\tthis._setupReconnect()\n\t\t})\n\n\t\tif (!this.options.manualConnect) {\n\t\t\tthis.log('MqttClient :: setting up stream')\n\t\t\tthis.connect()\n\t\t}\n\t}\n\n\t/**\n\t * @param packet the packet received by the broker\n\t * @return the auth packet to be returned to the broker\n\t * @api public\n\t */\n\tpublic handleAuth(packet: IAuthPacket, callback: PacketCallback) {\n\t\tcallback()\n\t}\n\n\t/**\n\t * Handle messages with backpressure support, one at a time.\n\t * Override at will.\n\t *\n\t * @param Packet packet the packet\n\t * @param Function callback call when finished\n\t * @api public\n\t */\n\tpublic handleMessage(packet: IPublishPacket, callback: DoneCallback) {\n\t\tcallback()\n\t}\n\n\t/**\n\t * _nextId\n\t * @return unsigned int\n\t */\n\tprivate _nextId() {\n\t\treturn this.messageIdProvider.allocate()\n\t}\n\n\t/**\n\t * getLastMessageId\n\t * @return unsigned int\n\t */\n\tpublic getLastMessageId() {\n\t\treturn this.messageIdProvider.getLastAllocated()\n\t}\n\n\t/**\n\t * Setup the event handlers in the inner stream, sends `connect` and `auth` packets\n\t */\n\tpublic connect() {\n\t\tconst writable = new Writable()\n\t\tconst parser = mqttPacket.parser(this.options)\n\n\t\tlet completeParse = null\n\t\tconst packets = []\n\n\t\tthis.log('connect :: calling method to clear reconnect')\n\t\tthis._clearReconnect()\n\n\t\tif (this.disconnected && !this.reconnecting) {\n\t\t\tthis.incomingStore = this.options.incomingStore || new Store()\n\t\t\tthis.outgoingStore = this.options.outgoingStore || new Store()\n\t\t\tthis.disconnecting = false\n\t\t\tthis.disconnected = false\n\t\t}\n\n\t\tthis.log(\n\t\t\t'connect :: using streamBuilder provided to client to create stream',\n\t\t)\n\t\tthis.stream = this.streamBuilder(this)\n\n\t\tparser.on('packet', (packet) => {\n\t\t\tthis.log('parser :: on packet push to packets array.')\n\t\t\tpackets.push(packet)\n\t\t})\n\n\t\tconst work = () => {\n\t\t\tthis.log('work :: getting next packet in queue')\n\t\t\tconst packet = packets.shift()\n\n\t\t\tif (packet) {\n\t\t\t\tthis.log('work :: packet pulled from queue')\n\t\t\t\thandlePacket(this, packet, nextTickWork)\n\t\t\t} else {\n\t\t\t\tthis.log('work :: no packets in queue')\n\t\t\t\tconst done = completeParse\n\t\t\t\tcompleteParse = null\n\t\t\t\tthis.log('work :: done flag is %s', !!done)\n\t\t\t\tif (done) done()\n\t\t\t}\n\t\t}\n\n\t\tconst nextTickWork = () => {\n\t\t\tif (packets.length) {\n\t\t\t\tnextTick(work)\n\t\t\t} else {\n\t\t\t\tconst done = completeParse\n\t\t\t\tcompleteParse = null\n\t\t\t\tdone()\n\t\t\t}\n\t\t}\n\n\t\twritable._write = (buf, enc, done) => {\n\t\t\tcompleteParse = done\n\t\t\tthis.log('writable stream :: parsing buffer')\n\t\t\tparser.parse(buf)\n\t\t\twork()\n\t\t}\n\n\t\tconst streamErrorHandler = (error) => {\n\t\t\tthis.log('streamErrorHandler :: error', error.message)\n\t\t\t// error.code will only be set on NodeJS env, browser don't allow to detect errors on sockets\n\t\t\t// also emitting errors on browsers seems to create issues\n\t\t\tif (error.code) {\n\t\t\t\t// handle error\n\t\t\t\tthis.log('streamErrorHandler :: emitting error')\n\t\t\t\tthis.emit('error', error)\n\t\t\t} else {\n\t\t\t\tthis.noop(error)\n\t\t\t}\n\t\t}\n\n\t\tthis.log('connect :: pipe stream to writable stream')\n\t\tthis.stream.pipe(writable)\n\n\t\t// Suppress connection errors\n\t\tthis.stream.on('error', streamErrorHandler)\n\n\t\t// Echo stream close\n\t\tthis.stream.on('close', () => {\n\t\t\tthis.log('(%s)stream :: on close', this.options.clientId)\n\t\t\tthis._flushVolatile()\n\t\t\tthis.log('stream: emit close to MqttClient')\n\t\t\tthis.emit('close')\n\t\t})\n\n\t\t// Send a connect packet\n\t\tthis.log('connect: sending packet `connect`')\n\n\t\tconst connectPacket: IConnectPacket = {\n\t\t\tcmd: 'connect',\n\t\t\tprotocolId: this.options.protocolId,\n\t\t\tprotocolVersion: this.options.protocolVersion,\n\t\t\tclean: this.options.clean,\n\t\t\tclientId: this.options.clientId,\n\t\t\tkeepalive: this.options.keepalive,\n\t\t\tusername: this.options.username,\n\t\t\tpassword: this.options.password as Buffer,\n\t\t\tproperties: this.options.properties,\n\t\t}\n\n\t\tif (this.options.will) {\n\t\t\tconnectPacket.will = {\n\t\t\t\t...this.options.will,\n\t\t\t\tpayload: this.options.will?.payload as Buffer,\n\t\t\t}\n\t\t}\n\n\t\tif (this.topicAliasRecv) {\n\t\t\tif (!connectPacket.properties) {\n\t\t\t\tconnectPacket.properties = {}\n\t\t\t}\n\t\t\tif (this.topicAliasRecv) {\n\t\t\t\tconnectPacket.properties.topicAliasMaximum =\n\t\t\t\t\tthis.topicAliasRecv.max\n\t\t\t}\n\t\t}\n\t\t// avoid message queue\n\t\tthis._writePacket(connectPacket)\n\n\t\t// Echo connection errors\n\t\tparser.on('error', this.emit.bind(this, 'error'))\n\n\t\t// auth\n\t\tif (this.options.properties) {\n\t\t\tif (\n\t\t\t\t!this.options.properties.authenticationMethod &&\n\t\t\t\tthis.options.properties.authenticationData\n\t\t\t) {\n\t\t\t\tthis.end(() =>\n\t\t\t\t\tthis.emit(\n\t\t\t\t\t\t'error',\n\t\t\t\t\t\tnew Error('Packet has no Authentication Method'),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\treturn this\n\t\t\t}\n\t\t\tif (\n\t\t\t\tthis.options.properties.authenticationMethod &&\n\t\t\t\tthis.options.authPacket &&\n\t\t\t\ttypeof this.options.authPacket === 'object'\n\t\t\t) {\n\t\t\t\tconst authPacket: IAuthPacket = {\n\t\t\t\t\tcmd: 'auth',\n\t\t\t\t\treasonCode: 0,\n\t\t\t\t\t...this.options.authPacket,\n\t\t\t\t}\n\t\t\t\tthis._writePacket(authPacket)\n\t\t\t}\n\t\t}\n\n\t\t// many drain listeners are needed for qos 1 callbacks if the connection is intermittent\n\t\tthis.stream.setMaxListeners(1000)\n\n\t\tclearTimeout(this.connackTimer)\n\t\tthis.connackTimer = setTimeout(() => {\n\t\t\tthis.log(\n\t\t\t\t'!!connectTimeout hit!! Calling _cleanUp with force `true`',\n\t\t\t)\n\t\t\tthis.emit('error', new Error('connack timeout'))\n\t\t\tthis._cleanUp(true)\n\t\t}, this.options.connectTimeout)\n\n\t\treturn this\n\t}\n\n\t/**\n\t * publish - publish <message> to <topic>\n\t *\n\t * @param {String} topic - topic to publish to\n\t * @param {String, Buffer} message - message to publish\n\t * @param {Object} [opts] - publish options, includes:\n\t * {Number} qos - qos level to publish on\n\t * {Boolean} retain - whether or not to retain the message\n\t * {Boolean} dup - whether or not mark a message as duplicate\n\t * {Function} cbStorePut - function(){} called when message is put into `outgoingStore`\n\t * @param {Function} [callback] - function(err){}\n\t * called when publish succeeds or fails\n\t * @returns {MqttClient} this - for chaining\n\t * @api public\n\t *\n\t * @example client.publish('topic', 'message');\n\t * @example\n\t * client.publish('topic', 'message', {qos: 1, retain: true, dup: true});\n\t * @example client.publish('topic', 'message', console.log);\n\t */\n\tpublic publish(topic: string, message: string | Buffer): MqttClient\n\tpublic publish(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t\tcallback?: PacketCallback,\n\t): MqttClient\n\tpublic publish(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t\topts?: IClientPublishOptions,\n\t\tcallback?: PacketCallback,\n\t): MqttClient\n\tpublic publish(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t\topts?: IClientPublishOptions | DoneCallback,\n\t\tcallback?: PacketCallback,\n\t): MqttClient {\n\t\tthis.log('publish :: message `%s` to topic `%s`', message, topic)\n\t\tconst { options } = this\n\n\t\t// .publish(topic, payload, cb);\n\t\tif (typeof opts === 'function') {\n\t\t\tcallback = opts as DoneCallback\n\t\t\topts = null\n\t\t}\n\n\t\topts = opts || {}\n\n\t\t// default opts\n\t\tconst defaultOpts: IClientPublishOptions = {\n\t\t\tqos: 0,\n\t\t\tretain: false,\n\t\t\tdup: false,\n\t\t}\n\t\topts = { ...defaultOpts, ...opts }\n\n\t\tconst { qos, retain, dup, properties, cbStorePut } = opts\n\n\t\tif (this._checkDisconnecting(callback)) {\n\t\t\treturn this\n\t\t}\n\n\t\tconst publishProc = () => {\n\t\t\tlet messageId = 0\n\t\t\tif (qos === 1 || qos === 2) {\n\t\t\t\tmessageId = this._nextId()\n\t\t\t\tif (messageId === null) {\n\t\t\t\t\tthis.log('No messageId left')\n\t\t\t\t\treturn false\n\t\t\t\t}\n\t\t\t}\n\t\t\tconst packet: IPublishPacket = {\n\t\t\t\tcmd: 'publish',\n\t\t\t\ttopic,\n\t\t\t\tpayload: message,\n\t\t\t\tqos,\n\t\t\t\tretain,\n\t\t\t\tmessageId,\n\t\t\t\tdup,\n\t\t\t}\n\n\t\t\tif (options.protocolVersion === 5) {\n\t\t\t\tpacket.properties = properties\n\t\t\t}\n\n\t\t\tthis.log('publish :: qos', qos)\n\t\t\tswitch (qos) {\n\t\t\t\tcase 1:\n\t\t\t\tcase 2:\n\t\t\t\t\t// Add to callbacks\n\t\t\t\t\tthis.outgoing[packet.messageId] = {\n\t\t\t\t\t\tvolatile: false,\n\t\t\t\t\t\tcb: callback || this.noop,\n\t\t\t\t\t}\n\t\t\t\t\tthis.log('MqttClient:publish: packet cmd: %s', packet.cmd)\n\t\t\t\t\tthis._sendPacket(packet, undefined, cbStorePut)\n\t\t\t\t\tbreak\n\t\t\t\tdefault:\n\t\t\t\t\tthis.log('MqttClient:publish: packet cmd: %s', packet.cmd)\n\t\t\t\t\tthis._sendPacket(packet, callback, cbStorePut)\n\t\t\t\t\tbreak\n\t\t\t}\n\t\t\treturn true\n\t\t}\n\n\t\tif (\n\t\t\tthis._storeProcessing ||\n\t\t\tthis._storeProcessingQueue.length > 0 ||\n\t\t\t!publishProc()\n\t\t) {\n\t\t\tthis._storeProcessingQueue.push({\n\t\t\t\tinvoke: publishProc,\n\t\t\t\tcbStorePut: opts.cbStorePut,\n\t\t\t\tcallback,\n\t\t\t})\n\t\t}\n\n\t\treturn this\n\t}\n\n\tpublic publishAsync(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t): Promise<Packet | undefined>\n\tpublic publishAsync(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t\topts?: IClientPublishOptions,\n\t): Promise<Packet | undefined>\n\tpublic publishAsync(\n\t\ttopic: string,\n\t\tmessage: string | Buffer,\n\t\topts?: IClientPublishOptions,\n\t): Promise<Packet | undefined> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.publish(topic, message, opts, (err, packet) => {\n\t\t\t\tif (err) {\n\t\t\t\t\treject(err)\n\t\t\t\t} else {\n\t\t\t\t\tresolve(packet)\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * subscribe - subscribe to <topic>\n\t *\n\t * @param {String, Array, Object} topic - topic(s) to subscribe to, supports objects in the form {'topic': qos}\n\t * @param {Object} [opts] - optional subscription options, includes:\n\t * {Number} qos - subscribe qos level\n\t * @param {Function} [callback] - function(err, granted){} where:\n\t * {Error} err - subscription error (none at the moment!)\n\t * {Array} granted - array of {topic: 't', qos: 0}\n\t * @returns {MqttClient} this - for chaining\n\t * @api public\n\t * @example client.subscribe('topic');\n\t * @example client.subscribe('topic', {qos: 1});\n\t * @example client.subscribe({'topic': {qos: 0}, 'topic2': {qos: 1}}, console.log);\n\t * @example client.subscribe('topic', console.log);\n\t */\n\tpublic subscribe(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t): MqttClient\n\tpublic subscribe(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\tcallback?: ClientSubscribeCallback,\n\t): MqttClient\n\tpublic subscribe(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\topts?: IClientSubscribeOptions | IClientSubscribeProperties,\n\t): MqttClient\n\tpublic subscribe(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\topts?: IClientSubscribeOptions | IClientSubscribeProperties,\n\t\tcallback?: ClientSubscribeCallback,\n\t): MqttClient\n\tpublic subscribe(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\topts?:\n\t\t\t| IClientSubscribeOptions\n\t\t\t| IClientSubscribeProperties\n\t\t\t| ClientSubscribeCallback,\n\t\tcallback?: ClientSubscribeCallback,\n\t): MqttClient {\n\t\tconst version = this.options.protocolVersion\n\n\t\tif (typeof opts === 'function') {\n\t\t\tcallback = opts\n\t\t}\n\n\t\tcallback = callback || this.noop\n\n\t\t// force re-subscribe on reconnect. This is only true\n\t\t// when provided `topicObject` is `this._resubscribeTopics`\n\t\tlet resubscribe = false\n\t\tlet topicsList = []\n\n\t\tif (typeof topicObject === 'string') {\n\t\t\ttopicObject = [topicObject]\n\t\t\ttopicsList = topicObject\n\t\t} else if (Array.isArray(topicObject)) {\n\t\t\ttopicsList = topicObject\n\t\t} else if (typeof topicObject === 'object') {\n\t\t\tresubscribe = topicObject.resubscribe\n\t\t\tdelete topicObject.resubscribe\n\t\t\ttopicsList = Object.keys(topicObject)\n\t\t}\n\n\t\t// validate topics\n\t\tconst invalidTopic = validations.validateTopics(topicsList)\n\t\tif (invalidTopic !== null) {\n\t\t\tsetImmediate(callback, new Error(`Invalid topic ${invalidTopic}`))\n\t\t\treturn this\n\t\t}\n\n\t\tif (this._checkDisconnecting(callback)) {\n\t\t\tthis.log('subscribe: discconecting true')\n\t\t\treturn this\n\t\t}\n\n\t\tconst defaultOpts: Partial<IClientSubscribeOptions> = {\n\t\t\tqos: 0,\n\t\t}\n\n\t\tif (version === 5) {\n\t\t\tdefaultOpts.nl = false\n\t\t\tdefaultOpts.rap = false\n\t\t\tdefaultOpts.rh = 0\n\t\t}\n\t\topts = { ...defaultOpts, ...opts } as IClientSubscribeOptions\n\n\t\tconst properties = opts.properties\n\n\t\tconst subs: ISubscriptionRequest[] = []\n\n\t\tconst parseSub = (\n\t\t\ttopic: string,\n\t\t\tsubOptions?: IClientSubscribeOptions,\n\t\t) => {\n\t\t\t// subOptions is defined only when providing a subs map, use opts otherwise\n\t\t\tsubOptions = (subOptions || opts) as IClientSubscribeOptions\n\t\t\tif (\n\t\t\t\t!Object.prototype.hasOwnProperty.call(\n\t\t\t\t\tthis._resubscribeTopics,\n\t\t\t\t\ttopic,\n\t\t\t\t) ||\n\t\t\t\tthis._resubscribeTopics[topic].qos < subOptions.qos ||\n\t\t\t\tresubscribe\n\t\t\t) {\n\t\t\t\tconst currentOpts: ISubscription & IClientSubscribeProperties =\n\t\t\t\t\t{\n\t\t\t\t\t\ttopic,\n\t\t\t\t\t\tqos: subOptions.qos,\n\t\t\t\t\t}\n\t\t\t\tif (version === 5) {\n\t\t\t\t\tcurrentOpts.nl = subOptions.nl\n\t\t\t\t\tcurrentOpts.rap = subOptions.rap\n\t\t\t\t\tcurrentOpts.rh = subOptions.rh\n\t\t\t\t\t// use opts.properties\n\t\t\t\t\tcurrentOpts.properties = properties\n\t\t\t\t}\n\t\t\t\tthis.log(\n\t\t\t\t\t'subscribe: pushing topic `%s` and qos `%s` to subs list',\n\t\t\t\t\tcurrentOpts.topic,\n\t\t\t\t\tcurrentOpts.qos,\n\t\t\t\t)\n\t\t\t\tsubs.push(currentOpts)\n\t\t\t}\n\t\t}\n\n\t\tif (Array.isArray(topicObject)) {\n\t\t\t// array of topics\n\t\t\ttopicObject.forEach((topic) => {\n\t\t\t\tthis.log('subscribe: array topic %s', topic)\n\t\t\t\tparseSub(topic)\n\t\t\t})\n\t\t} else {\n\t\t\t// object topic --> subOptions (no properties)\n\t\t\tObject.keys(topicObject).forEach((topic) => {\n\t\t\t\tthis.log(\n\t\t\t\t\t'subscribe: object topic %s, %o',\n\t\t\t\t\ttopic,\n\t\t\t\t\ttopicObject[topic],\n\t\t\t\t)\n\t\t\t\tparseSub(topic, topicObject[topic])\n\t\t\t})\n\t\t}\n\n\t\tif (!subs.length) {\n\t\t\tcallback(null, [])\n\t\t\treturn this\n\t\t}\n\n\t\tconst subscribeProc = () => {\n\t\t\tconst messageId = this._nextId()\n\t\t\tif (messageId === null) {\n\t\t\t\tthis.log('No messageId left')\n\t\t\t\treturn false\n\t\t\t}\n\n\t\t\tconst packet: ISubscribePacket = {\n\t\t\t\tcmd: 'subscribe',\n\t\t\t\tsubscriptions: subs,\n\t\t\t\t// qos: 1,\n\t\t\t\t// retain: false,\n\t\t\t\t// dup: false,\n\t\t\t\tmessageId,\n\t\t\t}\n\n\t\t\tif (properties) {\n\t\t\t\tpacket.properties = properties\n\t\t\t}\n\n\t\t\t// subscriptions to resubscribe to in case of disconnect\n\t\t\tif (this.options.resubscribe) {\n\t\t\t\tthis.log('subscribe :: resubscribe true')\n\t\t\t\tconst topics = []\n\t\t\t\tsubs.forEach((sub) => {\n\t\t\t\t\tif (this.options.reconnectPeriod > 0) {\n\t\t\t\t\t\tconst topic: IClientSubscribeOptions = { qos: sub.qos }\n\t\t\t\t\t\tif (version === 5) {\n\t\t\t\t\t\t\ttopic.nl = sub.nl || false\n\t\t\t\t\t\t\ttopic.rap = sub.rap || false\n\t\t\t\t\t\t\ttopic.rh = sub.rh || 0\n\t\t\t\t\t\t\ttopic.properties = sub.properties\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis._resubscribeTopics[sub.topic] = topic\n\t\t\t\t\t\ttopics.push(sub.topic)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t\tthis.messageIdToTopic[packet.messageId] = topics\n\t\t\t}\n\n\t\t\tthis.outgoing[packet.messageId] = {\n\t\t\t\tvolatile: true,\n\t\t\t\tcb(err, packet2: ISubackPacket) {\n\t\t\t\t\tif (!err) {\n\t\t\t\t\t\tconst { granted } = packet2\n\t\t\t\t\t\tfor (let i = 0; i < granted.length; i += 1) {\n\t\t\t\t\t\t\tsubs[i].qos = granted[i] as QoS\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tcallback(err, subs, packet2)\n\t\t\t\t},\n\t\t\t}\n\t\t\tthis.log('subscribe :: call _sendPacket')\n\t\t\tthis._sendPacket(packet)\n\t\t\treturn true\n\t\t}\n\n\t\tif (\n\t\t\tthis._storeProcessing ||\n\t\t\tthis._storeProcessingQueue.length > 0 ||\n\t\t\t!subscribeProc()\n\t\t) {\n\t\t\tthis._storeProcessingQueue.push({\n\t\t\t\tinvoke: subscribeProc,\n\t\t\t\tcallback,\n\t\t\t})\n\t\t}\n\n\t\treturn this\n\t}\n\n\tpublic subscribeAsync(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t): Promise<ISubscriptionGrant[]>\n\tpublic subscribeAsync(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\topts?: IClientSubscribeOptions | IClientSubscribeProperties,\n\t): Promise<ISubscriptionGrant[]>\n\tpublic subscribeAsync(\n\t\ttopicObject: string | string[] | ISubscriptionMap,\n\t\topts?: IClientSubscribeOptions | IClientSubscribeProperties,\n\t): Promise<ISubscriptionGrant[]> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.subscribe(topicObject, opts, (err, granted) => {\n\t\t\t\tif (err) {\n\t\t\t\t\treject(err)\n\t\t\t\t} else {\n\t\t\t\t\tresolve(granted)\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * unsubscribe - unsubscribe from topic(s)\n\t *\n\t * @param {String, Array} topic - topics to unsubscribe from\n\t * @param {Object} [opts] - optional subscription options, includes:\n\t * {Object} properties - properties of unsubscribe packet\n\t * @param {Function} [callback] - callback fired on unsuback\n\t * @returns {MqttClient} this - for chaining\n\t * @api public\n\t * @example client.unsubscribe('topic');\n\t * @example client.unsubscribe('topic', console.log);\n\t */\n\tpublic unsubscribe(topic: string | string[]): MqttClient\n\tpublic unsubscribe(\n\t\ttopic: string | string[],\n\t\topts?: IClientUnsubscribeProperties,\n\t): MqttClient\n\tpublic unsubscribe(\n\t\ttopic: string | string[],\n\t\tcallback?: PacketCallback,\n\t): MqttClient\n\tpublic unsubscribe(\n\t\ttopic: string | string[],\n\t\topts?: IClientUnsubscribeProperties,\n\t\tcallback?: PacketCallback,\n\t): MqttClient\n\tpublic unsubscribe(\n\t\ttopic: string | string[],\n\t\topts?: IClientUnsubscribeProperties | PacketCallback,\n\t\tcallback?: PacketCallback,\n\t): MqttClient {\n\t\tif (typeof topic === 'string') {\n\t\t\ttopic = [topic]\n\t\t}\n\n\t\tif (typeof opts === 'function') {\n\t\t\tcallback = opts\n\t\t}\n\n\t\tcallback = callback || this.noop\n\n\t\tconst invalidTopic = validations.validateTopics(topic)\n\t\tif (invalidTopic !== null) {\n\t\t\tsetImmediate(callback, new Error(`Invalid topic ${invalidTopic}`))\n\t\t\treturn this\n\t\t}\n\n\t\tif (this._checkDisconnecting(callback)) {\n\t\t\treturn this\n\t\t}\n\n\t\tconst unsubscribeProc = () => {\n\t\t\tconst messageId = this._nextId()\n\t\t\tif (messageId === null) {\n\t\t\t\tthis.log('No messageId left')\n\t\t\t\treturn false\n\t\t\t}\n\t\t\tconst packet: IUnsubscribePacket = {\n\t\t\t\tcmd: 'unsubscribe',\n\t\t\t\t// qos: 1,\n\t\t\t\tmessageId,\n\t\t\t\tunsubscriptions: [],\n\t\t\t}\n\n\t\t\tif (typeof topic === 'string') {\n\t\t\t\tpacket.unsubscriptions = [topic]\n\t\t\t} else if (Array.isArray(topic)) {\n\t\t\t\tpacket.unsubscriptions = topic\n\t\t\t}\n\n\t\t\tif (this.options.resubscribe) {\n\t\t\t\tpacket.unsubscriptions.forEach((topic2) => {\n\t\t\t\t\tdelete this._resubscribeTopics[topic2]\n\t\t\t\t})\n\t\t\t}\n\n\t\t\tif (typeof opts === 'object' && opts.properties) {\n\t\t\t\tpacket.properties = opts.properties\n\t\t\t}\n\n\t\t\tthis.outgoing[packet.messageId] = {\n\t\t\t\tvolatile: true,\n\t\t\t\tcb: callback,\n\t\t\t}\n\n\t\t\tthis.log('unsubscribe: call _sendPacket')\n\t\t\tthis._sendPacket(packet)\n\n\t\t\treturn true\n\t\t}\n\n\t\tif (\n\t\t\tthis._storeProcessing ||\n\t\t\tthis._storeProcessingQueue.length > 0 ||\n\t\t\t!unsubscribeProc()\n\t\t) {\n\t\t\tthis._storeProcessingQueue.push({\n\t\t\t\tinvoke: unsubscribeProc,\n\t\t\t\tcallback,\n\t\t\t})\n\t\t}\n\n\t\treturn this\n\t}\n\n\tpublic unsubscribeAsync(\n\t\ttopic: string | string[],\n\t): Promise<Packet | undefined>\n\tpublic unsubscribeAsync(\n\t\ttopic: string | string[],\n\t\topts?: IClientUnsubscribeProperties,\n\t): Promise<Packet | undefined>\n\tpublic unsubscribeAsync(\n\t\ttopic: string | string[],\n\t\topts?: IClientUnsubscribeProperties,\n\t): Promise<Packet | undefined> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.unsubscribe(topic, opts, (err, packet) => {\n\t\t\t\tif (err) {\n\t\t\t\t\treject(err)\n\t\t\t\t} else {\n\t\t\t\t\tresolve(packet)\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * end - close connection\n\t *\n\t * @returns {MqttClient} this - for chaining\n\t * @param {Boolean} force - do not wait for all in-flight messages to be acked\n\t * @param {Object} opts - added to the disconnect packet\n\t * @param {Function} cb - called when the client has been closed\n\t *\n\t * @api public\n\t */\n\tpublic end(cb?: DoneCallback): MqttClient\n\tpublic end(force?: boolean): MqttClient\n\tpublic end(opts?: Partial<IDisconnectPacket>, cb?: DoneCallback): MqttClient\n\tpublic end(force?: boolean, cb?: DoneCallback): MqttClient\n\tpublic end(\n\t\tforce?: boolean,\n\t\topts?: Partial<IDisconnectPacket>,\n\t\tcb?: DoneCallback,\n\t): MqttClient\n\tpublic end(\n\t\tforce?: boolean | Partial<IDisconnectPacket> | DoneCallback,\n\t\topts?: Partial<IDisconnectPacket> | DoneCallback,\n\t\tcb?: DoneCallback,\n\t): MqttClient {\n\t\tthis.log('end :: (%s)', this.options.clientId)\n\n\t\tif (force == null || typeof force !== 'boolean') {\n\t\t\tcb = cb || (opts as DoneCallback)\n\t\t\topts = force as Partial<IDisconnectPacket>\n\t\t\tforce = false\n\t\t}\n\n\t\tif (typeof opts !== 'object') {\n\t\t\tcb = cb || opts\n\t\t\topts = null\n\t\t}\n\n\t\tthis.log('end :: cb? %s', !!cb)\n\n\t\tif (!cb || typeof cb !== 'function') {\n\t\t\tcb = this.noop\n\t\t}\n\n\t\tconst closeStores = () => {\n\t\t\tthis.log('end :: closeStores: closing incoming and outgoing stores')\n\t\t\tthis.disconnected = true\n\t\t\tthis.incomingStore.close((e1) => {\n\t\t\t\tthis.outgoingStore.close((e2) => {\n\t\t\t\t\tthis.log('end :: closeStores: emitting end')\n\t\t\t\t\tthis.emit('end')\n\t\t\t\t\tif (cb) {\n\t\t\t\t\t\tconst err = e1 || e2\n\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t'end :: closeStores: invoking callback with args',\n\t\t\t\t\t\t)\n\t\t\t\t\t\tcb(err)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t\t\tif (this._deferredReconnect) {\n\t\t\t\tthis._deferredReconnect()\n\t\t\t} else if (\n\t\t\t\tthis.options.reconnectPeriod === 0 ||\n\t\t\t\tthis.options.manualConnect\n\t\t\t) {\n\t\t\t\tthis.disconnecting = false\n\t\t\t}\n\t\t}\n\n\t\tconst finish = () => {\n\t\t\t// defer closesStores of an I/O cycle,\n\t\t\t// just to make sure things are\n\t\t\t// ok for websockets\n\t\t\tthis.log(\n\t\t\t\t'end :: (%s) :: finish :: calling _cleanUp with force %s',\n\t\t\t\tthis.options.clientId,\n\t\t\t\tforce,\n\t\t\t)\n\t\t\tthis._cleanUp(\n\t\t\t\t<boolean>force,\n\t\t\t\t() => {\n\t\t\t\t\tthis.log(\n\t\t\t\t\t\t'end :: finish :: calling process.nextTick on closeStores',\n\t\t\t\t\t)\n\t\t\t\t\t// const boundProcess = nextTick.bind(null, closeStores)\n\t\t\t\t\tnextTick(closeStores)\n\t\t\t\t},\n\t\t\t\topts,\n\t\t\t)\n\t\t}\n\n\t\tif (this.disconnecting) {\n\t\t\tcb()\n\t\t\treturn this\n\t\t}\n\n\t\tthis._clearReconnect()\n\n\t\tthis.disconnecting = true\n\n\t\tif (!force && Object.keys(this.outgoing).length > 0) {\n\t\t\t// wait 10ms, just to be sure we received all of it\n\t\t\tthis.log(\n\t\t\t\t'end :: (%s) :: calling finish in 10ms once outgoing is empty',\n\t\t\t\tthis.options.clientId,\n\t\t\t)\n\t\t\tthis.once('outgoingEmpty', setTimeout.bind(null, finish, 10))\n\t\t} else {\n\t\t\tthis.log(\n\t\t\t\t'end :: (%s) :: immediately calling finish',\n\t\t\t\tthis.options.clientId,\n\t\t\t)\n\t\t\tfinish()\n\t\t}\n\n\t\treturn this\n\t}\n\n\tpublic endAsync(): Promise<void>\n\tpublic endAsync(force?: boolean): Promise<void>\n\tpublic endAsync(opts?: Partial<IDisconnectPacket>): Promise<void>\n\tpublic endAsync(\n\t\tforce?: boolean,\n\t\topts?: Partial<IDisconnectPacket>,\n\t): Promise<void>\n\tpublic endAsync(\n\t\tforce?: boolean | Partial<IDisconnectPacket>,\n\t\topts?: Partial<IDisconnectPacket>,\n\t): Promise<void> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.end(force as boolean, opts, (err) => {\n\t\t\t\tif (err) {\n\t\t\t\t\treject(err)\n\t\t\t\t} else {\n\t\t\t\t\tresolve()\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\t/**\n\t * removeOutgoingMessage - remove a message in outgoing store\n\t * the outgoing callback will be called withe Error('Message removed') if the message is removed\n\t *\n\t * @param {Number} messageId - messageId to remove message\n\t * @returns {MqttClient} this - for chaining\n\t * @api public\n\t *\n\t * @example client.removeOutgoingMessage(client.getLastAllocated());\n\t */\n\tpublic removeOutgoingMessage(messageId: number): MqttClient {\n\t\tif (this.outgoing[messageId]) {\n\t\t\tconst { cb } = this.outgoing[messageId]\n\t\t\tthis._removeOutgoingAndStoreMessage(messageId, () => {\n\t\t\t\tcb(new Error('Message removed'))\n\t\t\t})\n\t\t}\n\t\treturn this\n\t}\n\n\t/**\n\t * reconnect - connect again using the same options as connect()\n\t *\n\t * @param {Object} [opts] - optional reconnect options, includes:\n\t * {Store} incomingStore - a store for the incoming packets\n\t * {Store} outgoingStore - a store for the outgoing packets\n\t * if opts is not given, current stores are used\n\t * @returns {MqttClient} this - for chaining\n\t *\n\t * @api public\n\t */\n\tpublic reconnect(\n\t\topts?: Pick<IClientOptions, 'incomingStore' | 'outgoingStore'>,\n\t): MqttClient {\n\t\tthis.log('client reconnect')\n\t\tconst f = () => {\n\t\t\tif (opts) {\n\t\t\t\tthis.options.incomingStore = opts.incomingStore\n\t\t\t\tthis.options.outgoingStore = opts.outgoingStore\n\t\t\t} else {\n\t\t\t\tthis.options.incomingStore = null\n\t\t\t\tthis.options.outgoingStore = null\n\t\t\t}\n\t\t\tthis.incomingStore = this.options.incomingStore || new Store()\n\t\t\tthis.outgoingStore = this.options.outgoingStore || new Store()\n\t\t\tthis.disconnecting = false\n\t\t\tthis.disconnected = false\n\t\t\tthis._deferredReconnect = null\n\t\t\tthis._reconnect()\n\t\t}\n\n\t\tif (this.disconnecting && !this.disconnected) {\n\t\t\tthis._deferredReconnect = f\n\t\t} else {\n\t\t\tf()\n\t\t}\n\t\treturn this\n\t}\n\n\t/**\n\t * PRIVATE METHODS\n\t * =====================\n\t * */\n\n\t/**\n\t * Flush all outgoing messages marked as `volatile` in `outgoing` queue. Volatile messages\n\t * typically are subscription and unsubscription requests.\n\t */\n\tprivate _flushVolatile() {\n\t\tif (this.outgoing) {\n\t\t\tthis.log(\n\t\t\t\t'_flushVolatile :: deleting volatile messages from the queue and setting their callbacks as error function',\n\t\t\t)\n\t\t\tObject.keys(this.outgoing).forEach((messageId) => {\n\t\t\t\tif (\n\t\t\t\t\tthis.outgoing[messageId].volatile &&\n\t\t\t\t\ttypeof this.outgoing[messageId].cb === 'function'\n\t\t\t\t) {\n\t\t\t\t\tthis.outgoing[messageId].cb(new Error('Connection closed'))\n\t\t\t\t\tdelete this.outgoing[messageId]\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\t/**\n\t * Flush all outgoing messages\n\t */\n\tprivate _flush() {\n\t\tif (this.outgoing) {\n\t\t\tthis.log('_flush: queue exists? %b', !!this.outgoing)\n\t\t\tObject.keys(this.outgoing).forEach((messageId) => {\n\t\t\t\tif (typeof this.outgoing[messageId].cb === 'function') {\n\t\t\t\t\tthis.outgoing[messageId].cb(new Error('Connection closed'))\n\t\t\t\t\t// This is suspicious. Why do we only delete this if we have a callback?\n\t\t\t\t\t// If this is by-design, then adding no as callback would cause this to get deleted unintentionally.\n\t\t\t\t\tdelete this.outgoing[messageId]\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate _removeTopicAliasAndRecoverTopicName(packet: IPublishPacket) {\n\t\tlet alias: number | undefined\n\n\t\tif (packet.properties) {\n\t\t\talias = packet.properties.topicAlias\n\t\t}\n\n\t\tlet topic = packet.topic.toString()\n\n\t\tthis.log(\n\t\t\t'_removeTopicAliasAndRecoverTopicName :: alias %d, topic %o',\n\t\t\talias,\n\t\t\ttopic,\n\t\t)\n\n\t\tif (topic.length === 0) {\n\t\t\t// restore topic from alias\n\t\t\tif (typeof alias === 'undefined') {\n\t\t\t\treturn new Error('Unregistered Topic Alias')\n\t\t\t}\n\t\t\ttopic = this.topicAliasSend.getTopicByAlias(alias)\n\t\t\tif (typeof topic === 'undefined') {\n\t\t\t\treturn new Error('Unregistered Topic Alias')\n\t\t\t}\n\t\t\tpacket.topic = topic\n\t\t}\n\t\tif (alias) {\n\t\t\tdelete packet.properties.topicAlias\n\t\t}\n\t}\n\n\tprivate _checkDisconnecting(callback?: GenericCallback<any>) {\n\t\tif (this.disconnecting) {\n\t\t\tif (callback && callback !== this.noop) {\n\t\t\t\tcallback(new Error('client disconnecting'))\n\t\t\t} else {\n\t\t\t\tthis.emit('error', new Error('client disconnecting'))\n\t\t\t}\n\t\t}\n\t\treturn this.disconnecting\n\t}\n\n\t/**\n\t * _reconnect - implement reconnection\n\t * @api private\n\t */\n\tprivate _reconnect() {\n\t\tthis.log('_reconnect: emitting reconnect to client')\n\t\tthis.emit('reconnect')\n\t\tif (this.connected) {\n\t\t\tthis.end(() => {\n\t\t\t\tthis.connect()\n\t\t\t})\n\t\t\tthis.log('client already connected. disconnecting first.')\n\t\t} else {\n\t\t\tthis.log('_reconnect: calling connect')\n\t\t\tthis.connect()\n\t\t}\n\t}\n\n\t/**\n\t * _setupReconnect - setup reconnect timer\n\t */\n\tprivate _setupReconnect() {\n\t\tif (\n\t\t\t!this.disconnecting &&\n\t\t\t!this.reconnectTimer &&\n\t\t\tthis.options.reconnectPeriod > 0\n\t\t) {\n\t\t\tif (!this.reconnecting) {\n\t\t\t\tthis.log('_setupReconnect :: emit `offline` state')\n\t\t\t\tthis.emit('offline')\n\t\t\t\tthis.log('_setupReconnect :: set `reconnecting` to `true`')\n\t\t\t\tthis.reconnecting = true\n\t\t\t}\n\t\t\tthis.log(\n\t\t\t\t'_setupReconnect :: setting reconnectTimer for %d ms',\n\t\t\t\tthis.options.reconnectPeriod,\n\t\t\t)\n\t\t\tthis.reconnectTimer = setInterval(() => {\n\t\t\t\tthis.log('reconnectTimer :: reconnect triggered!')\n\t\t\t\tthis._reconnect()\n\t\t\t}, this.options.reconnectPeriod)\n\t\t} else {\n\t\t\tthis.log('_setupReconnect :: doing nothing...')\n\t\t}\n\t}\n\n\t/**\n\t * _clearReconnect - clear the reconnect timer\n\t */\n\tprivate _clearReconnect() {\n\t\tthis.log('_clearReconnect : clearing reconnect timer')\n\t\tif (this.reconnectTimer) {\n\t\t\tclearInterval(this.reconnectTimer)\n\t\t\tthis.reconnectTimer = null\n\t\t}\n\t}\n\n\t/**\n\t * _cleanUp - clean up on connection end\n\t * @api private\n\t */\n\tprivate _cleanUp(forced: boolean, done?: DoneCallback, opts = {}) {\n\t\tif (done) {\n\t\t\tthis.log('_cleanUp :: done callback provided for on stream close')\n\t\t\tthis.stream.on('close', done)\n\t\t}\n\n\t\tthis.log('_cleanUp :: forced? %s', forced)\n\t\tif (forced) {\n\t\t\tif (this.options.reconnectPeriod === 0 && this.options.clean) {\n\t\t\t\tthis._flush()\n\t\t\t}\n\t\t\tthis.log(\n\t\t\t\t'_cleanUp :: (%s) :: destroying stream',\n\t\t\t\tthis.options.clientId,\n\t\t\t)\n\t\t\tthis.stream.destroy()\n\t\t} else {\n\t\t\tconst packet: IDisconnectPacket = { cmd: 'disconnect', ...opts }\n\t\t\tthis.log(\n\t\t\t\t'_cleanUp :: (%s) :: call _sendPacket with disconnect packet',\n\t\t\t\tthis.options.clientId,\n\t\t\t)\n\t\t\tthis._sendPacket(packet, () => {\n\t\t\t\tthis.log(\n\t\t\t\t\t'_cleanUp :: (%s) :: destroying stream',\n\t\t\t\t\tthis.options.clientId,\n\t\t\t\t)\n\t\t\t\tsetImmediate(() => {\n\t\t\t\t\tthis.stream.end(() => {\n\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t'_cleanUp :: (%s) :: stream destroyed',\n\t\t\t\t\t\t\tthis.options.clientId,\n\t\t\t\t\t\t)\n\t\t\t\t\t\t// once stream is closed the 'close' event will fire and that will\n\t\t\t\t\t\t// emit client `close` event and call `done` callback if done is provided\n\t\t\t\t\t})\n\t\t\t\t})\n\t\t\t})\n\t\t}\n\n\t\tif (!this.disconnecting && !this.reconnecting) {\n\t\t\tthis.log(\n\t\t\t\t'_cleanUp :: client not disconnecting/reconnecting. Clearing and resetting reconnect.',\n\t\t\t)\n\t\t\tthis._clearReconnect()\n\t\t\tthis._setupReconnect()\n\t\t}\n\n\t\tthis._destroyKeepaliveManager()\n\n\t\tif (done && !this.connected) {\n\t\t\tthis.log(\n\t\t\t\t'_cleanUp :: (%s) :: removing stream `done` callback `close` listener',\n\t\t\t\tthis.options.clientId,\n\t\t\t)\n\t\t\tthis.stream.removeListener('close', done)\n\t\t\tdone()\n\t\t}\n\t}\n\n\tprivate _storeAndSend(\n\t\tpacket: Packet,\n\t\tcb: DoneCallback,\n\t\tcbStorePut: DoneCallback,\n\t) {\n\t\tthis.log(\n\t\t\t'storeAndSend :: store packet with cmd %s to outgoingStore',\n\t\t\tpacket.cmd,\n\t\t)\n\t\tlet storePacket = packet\n\t\tlet err: Error | undefined\n\t\tif (storePacket.cmd === 'publish') {\n\t\t\t// The original packet is for sending.\n\t\t\t// The cloned storePacket is for storing to resend on reconnect.\n\t\t\t// Topic Alias must not be used after disconnected.\n\t\t\tstorePacket = clone(packet)\n\t\t\terr = this._removeTopicAliasAndRecoverTopicName(\n\t\t\t\tstorePacket as IPublishPacket,\n\t\t\t)\n\t\t\tif (err) {\n\t\t\t\treturn cb && cb(err)\n\t\t\t}\n\t\t}\n\t\tthis.outgoingStore.put(storePacket, (err2) => {\n\t\t\tif (err2) {\n\t\t\t\treturn cb && cb(err2)\n\t\t\t}\n\t\t\tcbStorePut()\n\t\t\tthis._writePacket(packet, cb)\n\t\t})\n\t}\n\n\tprivate _applyTopicAlias(packet: Packet) {\n\t\tif (this.options.protocolVersion === 5) {\n\t\t\tif (packet.cmd === 'publish') {\n\t\t\t\tlet alias: number\n\t\t\t\tif (packet.properties) {\n\t\t\t\t\talias = packet.properties.topicAlias\n\t\t\t\t}\n\t\t\t\tconst topic = packet.topic.toString()\n\t\t\t\tif (this.topicAliasSend) {\n\t\t\t\t\tif (alias) {\n\t\t\t\t\t\tif (topic.length !== 0) {\n\t\t\t\t\t\t\t// register topic alias\n\t\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t\t'applyTopicAlias :: register topic: %s - alias: %d',\n\t\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\tif (!this.topicAliasSend.put(topic, alias)) {\n\t\t\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t\t\t'applyTopicAlias :: error out of range. topic: %s - alias: %d',\n\t\t\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\treturn new Error(\n\t\t\t\t\t\t\t\t\t'Sending Topic Alias out of range',\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t} else if (topic.length !== 0) {\n\t\t\t\t\t\tif (this.options.autoAssignTopicAlias) {\n\t\t\t\t\t\t\talias = this.topicAliasSend.getAliasByTopic(topic)\n\t\t\t\t\t\t\tif (alias) {\n\t\t\t\t\t\t\t\tpacket.topic = ''\n\t\t\t\t\t\t\t\tpacket.properties = {\n\t\t\t\t\t\t\t\t\t...packet.properties,\n\t\t\t\t\t\t\t\t\ttopicAlias: alias,\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t\t\t'applyTopicAlias :: auto assign(use) topic: %s - alias: %d',\n\t\t\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\talias = this.topicAliasSend.getLruAlias()\n\t\t\t\t\t\t\t\tthis.topicAliasSend.put(topic, alias)\n\t\t\t\t\t\t\t\tpacket.properties = {\n\t\t\t\t\t\t\t\t\t...packet.properties,\n\t\t\t\t\t\t\t\t\ttopicAlias: alias,\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t\t\t'applyTopicAlias :: auto assign topic: %s - alias: %d',\n\t\t\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else if (this.options.autoUseTopicAlias) {\n\t\t\t\t\t\t\talias = this.topicAliasSend.getAliasByTopic(topic)\n\t\t\t\t\t\t\tif (alias) {\n\t\t\t\t\t\t\t\tpacket.topic = ''\n\t\t\t\t\t\t\t\tpacket.properties = {\n\t\t\t\t\t\t\t\t\t...packet.properties,\n\t\t\t\t\t\t\t\t\ttopicAlias: alias,\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t\t\t'applyTopicAlias :: auto use topic: %s - alias: %d',\n\t\t\t\t\t\t\t\t\ttopic,\n\t\t\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else if (alias) {\n\t\t\t\t\tthis.log(\n\t\t\t\t\t\t'applyTopicAlias :: error out of range. topic: %s - alias: %d',\n\t\t\t\t\t\ttopic,\n\t\t\t\t\t\talias,\n\t\t\t\t\t)\n\t\t\t\t\treturn new Error('Sending Topic Alias out of range')\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate _noop(err?: Error) {\n\t\tthis.log('noop ::', err)\n\t}\n\n\t/** Writes the packet to stream and emits events */\n\tprivate _writePacket(packet: Packet, cb?: DoneCallback) {\n\t\tthis.log('_writePacket :: packet: %O', packet)\n\t\tthis.log('_writePacket :: emitting `packetsend`')\n\n\t\tthis.emit('packetsend', packet)\n\n\t\tthis.log('_writePacket :: writing to stream')\n\t\tconst result = mqttPacket.writeToStream(\n\t\t\tpacket,\n\t\t\tthis.stream,\n\t\t\tthis.options,\n\t\t)\n\t\tthis.log('_writePacket :: writeToStream result %s', result)\n\t\tif (!result && cb && cb !== this.noop) {\n\t\t\tthis.log(\n\t\t\t\t'_writePacket :: handle events on `drain` once through callback.',\n\t\t\t)\n\t\t\tthis.stream.once('drain', cb)\n\t\t} else if (cb) {\n\t\t\tthis.log('_writePacket :: invoking cb')\n\t\t\tcb()\n\t\t}\n\t}\n\n\t/**\n\t * _sendPacket - send or queue a packet\n\t * @param {Object} packet - packet options\n\t * @param {Function} cb - callback when the packet is sent\n\t * @param {Function} cbStorePut - called when message is put into outgoingStore\n\t * @param {Boolean} noStore - send without put to the store\n\t * @api private\n\t */\n\tprivate _sendPacket(\n\t\tpacket: Packet,\n\t\tcb?: DoneCallback,\n\t\tcbStorePut?: DoneCallback,\n\t\tnoStore?: boolean,\n\t) {\n\t\tthis.log('_sendPacket :: (%s) :: start', this.options.clientId)\n\t\tcbStorePut = cbStorePut || this.noop\n\t\tcb = cb || this.noop\n\n\t\tconst err = this._applyTopicAlias(packet)\n\t\tif (err) {\n\t\t\tcb(err)\n\t\t\treturn\n\t\t}\n\n\t\tif (!this.connected) {\n\t\t\t// allow auth packets to be sent while authenticating with the broker (mqtt5 enhanced auth)\n\t\t\tif (packet.cmd === 'auth') {\n\t\t\t\tthis._writePacket(packet, cb)\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tthis.log(\n\t\t\t\t'_sendPacket :: client not connected. Storing packet offline.',\n\t\t\t)\n\t\t\tthis._storePacket(packet, cb, cbStorePut)\n\t\t\treturn\n\t\t}\n\n\t\t// If \"noStore\" is true, the message is sent without being recorded in the store.\n\t\t// Messages that have not received puback or pubcomp remain in the store after disconnection\n\t\t// and are resent from the store upon reconnection.\n\t\t// For resend upon reconnection, \"noStore\" is set to true. This is because the message is already stored in the store.\n\t\t// This is to avoid interrupting other processes while recording to the store.\n\t\tif (noStore) {\n\t\t\tthis._writePacket(packet, cb)\n\t\t\treturn\n\t\t}\n\n\t\tswitch (packet.cmd) {\n\t\t\tcase 'publish':\n\t\t\t\tbreak\n\t\t\tcase 'pubrel':\n\t\t\t\tthis._storeAndSend(packet, cb, cbStorePut)\n\t\t\t\treturn\n\t\t\tdefault:\n\t\t\t\tthis._writePacket(packet, cb)\n\t\t\t\treturn\n\t\t}\n\n\t\tswitch (packet.qos) {\n\t\t\tcase 2:\n\t\t\tcase 1:\n\t\t\t\tthis._storeAndSend(packet, cb, cbStorePut)\n\t\t\t\tbreak\n\t\t\t/**\n\t\t\t * no need of case here since it will be caught by default\n\t\t\t * and jshint comply that before default it must be a break\n\t\t\t * anyway it will result in -1 evaluation\n\t\t\t */\n\t\t\tcase 0:\n\t\t\t/* falls through */\n\t\t\tdefault:\n\t\t\t\tthis._writePacket(packet, cb)\n\t\t\t\tbreak\n\t\t}\n\t\tthis.log('_sendPacket :: (%s) :: end', this.options.clientId)\n\t}\n\n\t/**\n\t * _storePacket - queue a packet\n\t * @param {Object} packet - packet options\n\t * @param {Function} cb - callback when the packet is sent\n\t * @param {Function} cbStorePut - called when message is put into outgoingStore\n\t * @api private\n\t */\n\tprivate _storePacket(\n\t\tpacket: Packet,\n\t\tcb: DoneCallback,\n\t\tcbStorePut: DoneCallback,\n\t) {\n\t\tthis.log('_storePacket :: packet: %o', packet)\n\t\tthis.log('_storePacket :: cb? %s', !!cb)\n\t\tcbStorePut = cbStorePut || this.noop\n\n\t\tlet storePacket = packet\n\t\tif (storePacket.cmd === 'publish') {\n\t\t\t// The original packet is for sending.\n\t\t\t// The cloned storePacket is for storing to resend on reconnect.\n\t\t\t// Topic Alias must not be used after disconnected.\n\t\t\tstorePacket = clone(packet)\n\t\t\tconst err = this._removeTopicAliasAndRecoverTopicName(\n\t\t\t\tstorePacket as IPublishPacket,\n\t\t\t)\n\t\t\tif (err) {\n\t\t\t\treturn cb && cb(err)\n\t\t\t}\n\t\t}\n\n\t\tconst qos = (storePacket as IPublishPacket).qos || 0\n\t\t// check that the packet is not a qos of 0, or that the command is not a publish\n\t\tif ((qos === 0 && this.queueQoSZero) || storePacket.cmd !== 'publish') {\n\t\t\tthis.queue.push({ packet: storePacket, cb })\n\t\t} else if (qos > 0) {\n\t\t\tcb = this.outgoing[storePacket.messageId]\n\t\t\t\t? this.outgoing[storePacket.messageId].cb\n\t\t\t\t: null\n\t\t\tthis.outgoingStore.put(storePacket, (err) => {\n\t\t\t\tif (err) {\n\t\t\t\t\treturn cb && cb(err)\n\t\t\t\t}\n\t\t\t\tcbStorePut()\n\t\t\t})\n\t\t} else if (cb) {\n\t\t\tcb(new Error('No connection to broker'))\n\t\t}\n\t}\n\n\t/**\n\t * _setupKeepaliveManager - setup the keepalive manager\n\t */\n\tprivate _setupKeepaliveManager() {\n\t\tthis.log(\n\t\t\t'_setupKeepaliveManager :: keepalive %d (seconds)',\n\t\t\tthis.options.keepalive,\n\t\t)\n\n\t\tif (!this.keepaliveManager && this.options.keepalive) {\n\t\t\tthis.keepaliveManager = new KeepaliveManager(\n\t\t\t\tthis,\n\t\t\t\tthis.options.timerVariant,\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate _destroyKeepaliveManager() {\n\t\tif (this.keepaliveManager) {\n\t\t\tthis.log('_destroyKeepaliveManager :: destroying keepalive manager')\n\t\t\tthis.keepaliveManager.destroy()\n\t\t\tthis.keepaliveManager = null\n\t\t}\n\t}\n\n\t/**\n\t * Reschedule the ping interval\n\t */\n\tpublic reschedulePing(force = false) {\n\t\tif (\n\t\t\tthis.keepaliveManager &&\n\t\t\tthis.options.keepalive &&\n\t\t\t(force || this.options.reschedulePings)\n\t\t) {\n\t\t\tthis._reschedulePing()\n\t\t}\n\t}\n\n\t/**\n\t * Mostly needed for test purposes\n\t */\n\tprivate _reschedulePing() {\n\t\tthis.log('_reschedulePing :: rescheduling ping')\n\t\tthis.keepaliveManager.reschedule()\n\t}\n\n\tpublic sendPing() {\n\t\tthis.log('_sendPing :: sending pingreq')\n\t\tthis._sendPacket({ cmd: 'pingreq' })\n\t}\n\n\tpublic onKeepaliveTimeout() {\n\t\tthis.emit('error', new Error('Keepalive timeout'))\n\t\tthis.log('onKeepaliveTimeout :: calling _cleanUp with force true')\n\t\tthis._cleanUp(true)\n\t}\n\n\t/**\n\t * _resubscribe\n\t * @api private\n\t */\n\tprivate _resubscribe() {\n\t\tthis.log('_resubscribe')\n\t\tconst _resubscribeTopicsKeys = Object.keys(this._resubscribeTopics)\n\t\tif (\n\t\t\t!this._firstConnection &&\n\t\t\t// Only resubscribe in case of clean connection or if the server does not have a stored session.\n\t\t\t// The Session Present flag is available since v3.1.1\n\t\t\t// https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/os/mqtt-v3.1.1-os.html#_Toc385349254\n\t\t\t(this.options.clean ||\n\t\t\t\t(this.options.protocolVersion >= 4 &&\n\t\t\t\t\t!this.connackPacket.sessionPresent)) &&\n\t\t\t_resubscribeTopicsKeys.length > 0\n\t\t) {\n\t\t\tif (this.options.resubscribe) {\n\t\t\t\tif (this.options.protocolVersion === 5) {\n\t\t\t\t\tthis.log('_resubscribe: protocolVersion 5')\n\t\t\t\t\tfor (\n\t\t\t\t\t\tlet topicI = 0;\n\t\t\t\t\t\ttopicI < _resubscribeTopicsKeys.length;\n\t\t\t\t\t\ttopicI++\n\t\t\t\t\t) {\n\t\t\t\t\t\tconst resubscribeTopic: ISubscriptionMap = {}\n\t\t\t\t\t\tresubscribeTopic[_resubscribeTopicsKeys[topicI]] =\n\t\t\t\t\t\t\tthis._resubscribeTopics[\n\t\t\t\t\t\t\t\t_resubscribeTopicsKeys[topicI]\n\t\t\t\t\t\t\t]\n\t\t\t\t\t\tresubscribeTopic.resubscribe = true\n\t\t\t\t\t\tthis.subscribe(resubscribeTopic, {\n\t\t\t\t\t\t\tproperties:\n\t\t\t\t\t\t\t\tresubscribeTopic[_resubscribeTopicsKeys[topicI]]\n\t\t\t\t\t\t\t\t\t.properties,\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tthis._resubscribeTopics.resubscribe = true\n\t\t\t\t\tthis.subscribe(this._resubscribeTopics)\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis._resubscribeTopics = {}\n\t\t\t}\n\t\t}\n\n\t\tthis._firstConnection = false\n\t}\n\n\t/**\n\t * _onConnect\n\t *\n\t * @api private\n\t */\n\tprivate _onConnect(packet: IConnackPacket) {\n\t\tif (this.disconnected) {\n\t\t\tthis.emit('connect', packet)\n\t\t\treturn\n\t\t}\n\n\t\tthis.connackPacket = packet\n\t\tthis.messageIdProvider.clear()\n\t\tthis._setupKeepaliveManager()\n\n\t\tthis.connected = true\n\n\t\t/** check if there are packets in outgoing store and stream them */\n\t\tconst startStreamProcess = () => {\n\t\t\tlet outStore = this.outgoingStore.createStream()\n\n\t\t\t/** destroy the outgoing store stream */\n\t\t\tconst remove = () => {\n\t\t\t\toutStore.destroy()\n\t\t\t\toutStore = null\n\t\t\t\tthis._flushStoreProcessingQueue()\n\t\t\t\tclearStoreProcessing()\n\t\t\t}\n\n\t\t\t/** stop store processing and clear packets id processed */\n\t\t\tconst clearStoreProcessing = () => {\n\t\t\t\tthis._storeProcessing = false\n\t\t\t\tthis._packetIdsDuringStoreProcessing = {}\n\t\t\t}\n\n\t\t\tthis.once('close', remove)\n\t\t\toutStore.on('error', (err) => {\n\t\t\t\tclearStoreProcessing()\n\t\t\t\tthis._flushStoreProcessingQueue()\n\t\t\t\tthis.removeListener('close', remove)\n\t\t\t\tthis.emit('error', err)\n\t\t\t})\n\n\t\t\t/** Read next packet in outgoing store and send it */\n\t\t\tconst storeDeliver = () => {\n\t\t\t\t// edge case, we wrapped this twice\n\t\t\t\tif (!outStore) {\n\t\t\t\t\treturn\n\t\t\t\t}\n\n\t\t\t\tconst packet2 = outStore.read(1)\n\n\t\t\t\tlet cb: PacketCallback\n\n\t\t\t\tif (!packet2) {\n\t\t\t\t\t// read when data is available in the future\n\t\t\t\t\toutStore.once('readable', storeDeliver)\n\t\t\t\t\treturn\n\t\t\t\t}\n\n\t\t\t\tthis._storeProcessing = true\n\n\t\t\t\t// Skip already processed store packets\n\t\t\t\tif (this._packetIdsDuringStoreProcessing[packet2.messageId]) {\n\t\t\t\t\tstoreDeliver()\n\t\t\t\t\treturn\n\t\t\t\t}\n\n\t\t\t\t// Avoid unnecessary stream read operations when disconnected\n\t\t\t\tif (!this.disconnecting && !this.reconnectTimer) {\n\t\t\t\t\tcb = this.outgoing[packet2.messageId]\n\t\t\t\t\t\t? this.outgoing[packet2.messageId].cb\n\t\t\t\t\t\t: null\n\t\t\t\t\tthis.outgoing[packet2.messageId] = {\n\t\t\t\t\t\tvolatile: false,\n\t\t\t\t\t\tcb(err, status) {\n\t\t\t\t\t\t\t// Ensure that the original callback passed in to publish gets invoked\n\t\t\t\t\t\t\tif (cb) {\n\t\t\t\t\t\t\t\tcb(err, status)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tstoreDeliver()\n\t\t\t\t\t\t},\n\t\t\t\t\t}\n\t\t\t\t\tthis._packetIdsDuringStoreProcessing[packet2.messageId] =\n\t\t\t\t\t\ttrue\n\t\t\t\t\tif (this.messageIdProvider.register(packet2.messageId)) {\n\t\t\t\t\t\tthis._sendPacket(packet2, undefined, undefined, true)\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.log(\n\t\t\t\t\t\t\t'messageId: %d has already used.',\n\t\t\t\t\t\t\tpacket2.messageId,\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t} else if (outStore.destroy) {\n\t\t\t\t\toutStore.destroy()\n\t\t\t\t}\n\t\t\t}\n\n\t\t\toutStore.on('end', () => {\n\t\t\t\tlet allProcessed = true\n\t\t\t\tfor (const id in this._packetIdsDuringStoreProcessing) {\n\t\t\t\t\tif (!this._packetIdsDuringStoreProcessing[id]) {\n\t\t\t\t\t\tallProcessed = false\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tthis.removeListener('close', remove)\n\t\t\t\tif (allProcessed) {\n\t\t\t\t\tclearStoreProcessing()\n\t\t\t\t\tthis._invokeAllStoreProcessingQueue()\n\t\t\t\t\tthis.emit('connect', packet)\n\t\t\t\t} else {\n\t\t\t\t\tstartStreamProcess()\n\t\t\t\t}\n\t\t\t})\n\t\t\tstoreDeliver()\n\t\t}\n\t\t// start flowing\n\t\tstartStreamProcess()\n\t}\n\n\tprivate _invokeStoreProcessingQueue() {\n\t\t// If _storeProcessing is true, the message is resending.\n\t\t// During resend, processing is skipped to prevent new messages from interrupting. #1635\n\t\tif (!this._storeProcessing && this._storeProcessingQueue.length > 0) {\n\t\t\tconst f = this._storeProcessingQueue[0]\n\t\t\tif (f && f.invoke()) {\n\t\t\t\tthis._storeProcessingQueue.shift()\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t\treturn false\n\t}\n\n\tprivate _invokeAllStoreProcessingQueue() {\n\t\twhile (this._invokeStoreProcessingQueue()) {\n\t\t\t/* empty */\n\t\t}\n\t}\n\n\tprivate _flushStoreProcessingQueue() {\n\t\tfor (const f of this._storeProcessingQueue) {\n\t\t\tif (f.cbStorePut) f.cbStorePut(new Error('Connection closed'))\n\t\t\tif (f.callback) f.callback(new Error('Connection closed'))\n\t\t}\n\t\tthis._storeProcessingQueue.splice(0)\n\t}\n\n\t/**\n\t * _removeOutgoingAndStoreMessage\n\t * @param {Number} messageId - messageId to remove message\n\t * @param {Function} cb - called when the message removed\n\t * @api private\n\t */\n\tprivate _removeOutgoingAndStoreMessage(\n\t\tmessageId: number,\n\t\tcb: PacketCallback,\n\t) {\n\t\tdelete this.outgoing[messageId]\n\t\tthis.outgoingStore.del({ messageId }, (err, packet) => {\n\t\t\tcb(err, packet)\n\t\t\tthis.messageIdProvider.deallocate(messageId)\n\t\t\tthis._invokeStoreProcessingQueue()\n\t\t})\n\t}\n}\n","import { NumberAllocator } from 'number-allocator'\nimport { IMessageIdProvider } from './default-message-id-provider'\n\n/**\n * UniqueMessageAllocator constructor\n * @constructor\n */\nexport default class UniqueMessageIdProvider implements IMessageIdProvider {\n\tprivate numberAllocator: NumberAllocator\n\n\tprivate lastId: number\n\n\tconstructor() {\n\t\tthis.numberAllocator = new NumberAllocator(1, 65535)\n\t}\n\n\t/**\n\t * allocate\n\t *\n\t * Get the next messageId.\n\t * @return if messageId is fully allocated then return null,\n\t * otherwise return the smallest usable unsigned int messageId.\n\t */\n\tallocate() {\n\t\tthis.lastId = this.numberAllocator.alloc()\n\t\treturn this.lastId\n\t}\n\n\t/**\n\t * getLastAllocated\n\t * Get the last allocated messageId.\n\t * @return unsigned int\n\t */\n\tgetLastAllocated() {\n\t\treturn this.lastId\n\t}\n\n\t/**\n\t * register\n\t * Register messageId. If success return true, otherwise return false.\n\t * @param { unsigned int } - messageId to register,\n\t * @return boolean\n\t */\n\tregister(messageId: number) {\n\t\treturn this.numberAllocator.use(messageId) as boolean\n\t}\n\n\t/**\n\t * deallocate\n\t * Deallocate messageId.\n\t * @param { unsigned int } - messageId to deallocate,\n\t */\n\tdeallocate(messageId: number) {\n\t\tthis.numberAllocator.free(messageId)\n\t}\n\n\t/**\n\t * clear\n\t * Deallocate all messageIds.\n\t */\n\tclear() {\n\t\tthis.numberAllocator.clear()\n\t}\n}\n","'use strict';\n\nconst BINARY_TYPES = ['nodebuffer', 'arraybuffer', 'fragments'];\nconst hasBlob = typeof Blob !== 'undefined';\n\nif (hasBlob) BINARY_TYPES.push('blob');\n\nmodule.exports = {\n BINARY_TYPES,\n EMPTY_BUFFER: Buffer.alloc(0),\n GUID: '258EAFA5-E914-47DA-95CA-C5AB0DC85B11',\n hasBlob,\n kForOnEventAttribute: Symbol('kIsForOnEventAttribute'),\n kListener: Symbol('kListener'),\n kStatusCode: Symbol('status-code'),\n kWebSocket: Symbol('websocket'),\n NOOP: () => {}\n};\n","'use strict';\n\nconst { EMPTY_BUFFER } = require('./constants');\n\nconst FastBuffer = Buffer[Symbol.species];\n\n/**\n * Merges an array of buffers into a new buffer.\n *\n * @param {Buffer[]} list The array of buffers to concat\n * @param {Number} totalLength The total length of buffers in the list\n * @return {Buffer} The resulting buffer\n * @public\n */\nfunction concat(list, totalLength) {\n if (list.length === 0) return EMPTY_BUFFER;\n if (list.length === 1) return list[0];\n\n const target = Buffer.allocUnsafe(totalLength);\n let offset = 0;\n\n for (let i = 0; i < list.length; i++) {\n const buf = list[i];\n target.set(buf, offset);\n offset += buf.length;\n }\n\n if (offset < totalLength) {\n return new FastBuffer(target.buffer, target.byteOffset, offset);\n }\n\n return target;\n}\n\n/**\n * Masks a buffer using the given mask.\n *\n * @param {Buffer} source The buffer to mask\n * @param {Buffer} mask The mask to use\n * @param {Buffer} output The buffer where to store the result\n * @param {Number} offset The offset at which to start writing\n * @param {Number} length The number of bytes to mask.\n * @public\n */\nfunction _mask(source, mask, output, offset, length) {\n for (let i = 0; i < length; i++) {\n output[offset + i] = source[i] ^ mask[i & 3];\n }\n}\n\n/**\n * Unmasks a buffer using the given mask.\n *\n * @param {Buffer} buffer The buffer to unmask\n * @param {Buffer} mask The mask to use\n * @public\n */\nfunction _unmask(buffer, mask) {\n for (let i = 0; i < buffer.length; i++) {\n buffer[i] ^= mask[i & 3];\n }\n}\n\n/**\n * Converts a buffer to an `ArrayBuffer`.\n *\n * @param {Buffer} buf The buffer to convert\n * @return {ArrayBuffer} Converted buffer\n * @public\n */\nfunction toArrayBuffer(buf) {\n if (buf.length === buf.buffer.byteLength) {\n return buf.buffer;\n }\n\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.length);\n}\n\n/**\n * Converts `data` to a `Buffer`.\n *\n * @param {*} data The data to convert\n * @return {Buffer} The buffer\n * @throws {TypeError}\n * @public\n */\nfunction toBuffer(data) {\n toBuffer.readOnly = true;\n\n if (Buffer.isBuffer(data)) return data;\n\n let buf;\n\n if (data instanceof ArrayBuffer) {\n buf = new FastBuffer(data);\n } else if (ArrayBuffer.isView(data)) {\n buf = new FastBuffer(data.buffer, data.byteOffset, data.byteLength);\n } else {\n buf = Buffer.from(data);\n toBuffer.readOnly = false;\n }\n\n return buf;\n}\n\nmodule.exports = {\n concat,\n mask: _mask,\n toArrayBuffer,\n toBuffer,\n unmask: _unmask\n};\n\n/* istanbul ignore else */\nif (!process.env.WS_NO_BUFFER_UTIL) {\n try {\n const bufferUtil = require('bufferutil');\n\n module.exports.mask = function (source, mask, output, offset, length) {\n if (length < 48) _mask(source, mask, output, offset, length);\n else bufferUtil.mask(source, mask, output, offset, length);\n };\n\n module.exports.unmask = function (buffer, mask) {\n if (buffer.length < 32) _unmask(buffer, mask);\n else bufferUtil.unmask(buffer, mask);\n };\n } catch (e) {\n // Continue regardless of the error.\n }\n}\n","'use strict';\n\nconst kDone = Symbol('kDone');\nconst kRun = Symbol('kRun');\n\n/**\n * A very simple job queue with adjustable concurrency. Adapted from\n * https://github.com/STRML/async-limiter\n */\nclass Limiter {\n /**\n * Creates a new `Limiter`.\n *\n * @param {Number} [concurrency=Infinity] The maximum number of jobs allowed\n * to run concurrently\n */\n constructor(concurrency) {\n this[kDone] = () => {\n this.pending--;\n this[kRun]();\n };\n this.concurrency = concurrency || Infinity;\n this.jobs = [];\n this.pending = 0;\n }\n\n /**\n * Adds a job to the queue.\n *\n * @param {Function} job The job to run\n * @public\n */\n add(job) {\n this.jobs.push(job);\n this[kRun]();\n }\n\n /**\n * Removes a job from the queue and runs it if possible.\n *\n * @private\n */\n [kRun]() {\n if (this.pending === this.concurrency) return;\n\n if (this.jobs.length) {\n const job = this.jobs.shift();\n\n this.pending++;\n job(this[kDone]);\n }\n }\n}\n\nmodule.exports = Limiter;\n","'use strict';\n\nconst zlib = require('zlib');\n\nconst bufferUtil = require('./buffer-util');\nconst Limiter = require('./limiter');\nconst { kStatusCode } = require('./constants');\n\nconst FastBuffer = Buffer[Symbol.species];\nconst TRAILER = Buffer.from([0x00, 0x00, 0xff, 0xff]);\nconst kPerMessageDeflate = Symbol('permessage-deflate');\nconst kTotalLength = Symbol('total-length');\nconst kCallback = Symbol('callback');\nconst kBuffers = Symbol('buffers');\nconst kError = Symbol('error');\n\n//\n// We limit zlib concurrency, which prevents severe memory fragmentation\n// as documented in https://github.com/nodejs/node/issues/8871#issuecomment-250915913\n// and https://github.com/websockets/ws/issues/1202\n//\n// Intentionally global; it's the global thread pool that's an issue.\n//\nlet zlibLimiter;\n\n/**\n * permessage-deflate implementation.\n */\nclass PerMessageDeflate {\n /**\n * Creates a PerMessageDeflate instance.\n *\n * @param {Object} [options] Configuration options\n * @param {(Boolean|Number)} [options.clientMaxWindowBits] Advertise support\n * for, or request, a custom client window size\n * @param {Boolean} [options.clientNoContextTakeover=false] Advertise/\n * acknowledge disabling of client context takeover\n * @param {Number} [options.concurrencyLimit=10] The number of concurrent\n * calls to zlib\n * @param {(Boolean|Number)} [options.serverMaxWindowBits] Request/confirm the\n * use of a custom server window size\n * @param {Boolean} [options.serverNoContextTakeover=false] Request/accept\n * disabling of server context takeover\n * @param {Number} [options.threshold=1024] Size (in bytes) below which\n * messages should not be compressed if context takeover is disabled\n * @param {Object} [options.zlibDeflateOptions] Options to pass to zlib on\n * deflate\n * @param {Object} [options.zlibInflateOptions] Options to pass to zlib on\n * inflate\n * @param {Boolean} [isServer=false] Create the instance in either server or\n * client mode\n * @param {Number} [maxPayload=0] The maximum allowed message length\n */\n constructor(options, isServer, maxPayload) {\n this._maxPayload = maxPayload | 0;\n this._options = options || {};\n this._threshold =\n this._options.threshold !== undefined ? this._options.threshold : 1024;\n this._isServer = !!isServer;\n this._deflate = null;\n this._inflate = null;\n\n this.params = null;\n\n if (!zlibLimiter) {\n const concurrency =\n this._options.concurrencyLimit !== undefined\n ? this._options.concurrencyLimit\n : 10;\n zlibLimiter = new Limiter(concurrency);\n }\n }\n\n /**\n * @type {String}\n */\n static get extensionName() {\n return 'permessage-deflate';\n }\n\n /**\n * Create an extension negotiation offer.\n *\n * @return {Object} Extension parameters\n * @public\n */\n offer() {\n const params = {};\n\n if (this._options.serverNoContextTakeover) {\n params.server_no_context_takeover = true;\n }\n if (this._options.clientNoContextTakeover) {\n params.client_no_context_takeover = true;\n }\n if (this._options.serverMaxWindowBits) {\n params.server_max_window_bits = this._options.serverMaxWindowBits;\n }\n if (this._options.clientMaxWindowBits) {\n params.client_max_window_bits = this._options.clientMaxWindowBits;\n } else if (this._options.clientMaxWindowBits == null) {\n params.client_max_window_bits = true;\n }\n\n return params;\n }\n\n /**\n * Accept an extension negotiation offer/response.\n *\n * @param {Array} configurations The extension negotiation offers/reponse\n * @return {Object} Accepted configuration\n * @public\n */\n accept(configurations) {\n configurations = this.normalizeParams(configurations);\n\n this.params = this._isServer\n ? this.acceptAsServer(configurations)\n : this.acceptAsClient(configurations);\n\n return this.params;\n }\n\n /**\n * Releases all resources used by the extension.\n *\n * @public\n */\n cleanup() {\n if (this._inflate) {\n this._inflate.close();\n this._inflate = null;\n }\n\n if (this._deflate) {\n const callback = this._deflate[kCallback];\n\n this._deflate.close();\n this._deflate = null;\n\n if (callback) {\n callback(\n new Error(\n 'The deflate stream was closed while data was being processed'\n )\n );\n }\n }\n }\n\n /**\n * Accept an extension negotiation offer.\n *\n * @param {Array} offers The extension negotiation offers\n * @return {Object} Accepted configuration\n * @private\n */\n acceptAsServer(offers) {\n const opts = this._options;\n const accepted = offers.find((params) => {\n if (\n (opts.serverNoContextTakeover === false &&\n params.server_no_context_takeover) ||\n (params.server_max_window_bits &&\n (opts.serverMaxWindowBits === false ||\n (typeof opts.serverMaxWindowBits === 'number' &&\n opts.serverMaxWindowBits > params.server_max_window_bits))) ||\n (typeof opts.clientMaxWindowBits === 'number' &&\n !params.client_max_window_bits)\n ) {\n return false;\n }\n\n return true;\n });\n\n if (!accepted) {\n throw new Error('None of the extension offers can be accepted');\n }\n\n if (opts.serverNoContextTakeover) {\n accepted.server_no_context_takeover = true;\n }\n if (opts.clientNoContextTakeover) {\n accepted.client_no_context_takeover = true;\n }\n if (typeof opts.serverMaxWindowBits === 'number') {\n accepted.server_max_window_bits = opts.serverMaxWindowBits;\n }\n if (typeof opts.clientMaxWindowBits === 'number') {\n accepted.client_max_window_bits = opts.clientMaxWindowBits;\n } else if (\n accepted.client_max_window_bits === true ||\n opts.clientMaxWindowBits === false\n ) {\n delete accepted.client_max_window_bits;\n }\n\n return accepted;\n }\n\n /**\n * Accept the extension negotiation response.\n *\n * @param {Array} response The extension negotiation response\n * @return {Object} Accepted configuration\n * @private\n */\n acceptAsClient(response) {\n const params = response[0];\n\n if (\n this._options.clientNoContextTakeover === false &&\n params.client_no_context_takeover\n ) {\n throw new Error('Unexpected parameter \"client_no_context_takeover\"');\n }\n\n if (!params.client_max_window_bits) {\n if (typeof this._options.clientMaxWindowBits === 'number') {\n params.client_max_window_bits = this._options.clientMaxWindowBits;\n }\n } else if (\n this._options.clientMaxWindowBits === false ||\n (typeof this._options.clientMaxWindowBits === 'number' &&\n params.client_max_window_bits > this._options.clientMaxWindowBits)\n ) {\n throw new Error(\n 'Unexpected or invalid parameter \"client_max_window_bits\"'\n );\n }\n\n return params;\n }\n\n /**\n * Normalize parameters.\n *\n * @param {Array} configurations The extension negotiation offers/reponse\n * @return {Array} The offers/response with normalized parameters\n * @private\n */\n normalizeParams(configurations) {\n configurations.forEach((params) => {\n Object.keys(params).forEach((key) => {\n let value = params[key];\n\n if (value.length > 1) {\n throw new Error(`Parameter \"${key}\" must have only a single value`);\n }\n\n value = value[0];\n\n if (key === 'client_max_window_bits') {\n if (value !== true) {\n const num = +value;\n if (!Number.isInteger(num) || num < 8 || num > 15) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n value = num;\n } else if (!this._isServer) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n } else if (key === 'server_max_window_bits') {\n const num = +value;\n if (!Number.isInteger(num) || num < 8 || num > 15) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n value = num;\n } else if (\n key === 'client_no_context_takeover' ||\n key === 'server_no_context_takeover'\n ) {\n if (value !== true) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n } else {\n throw new Error(`Unknown parameter \"${key}\"`);\n }\n\n params[key] = value;\n });\n });\n\n return configurations;\n }\n\n /**\n * Decompress data. Concurrency limited.\n *\n * @param {Buffer} data Compressed data\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @public\n */\n decompress(data, fin, callback) {\n zlibLimiter.add((done) => {\n this._decompress(data, fin, (err, result) => {\n done();\n callback(err, result);\n });\n });\n }\n\n /**\n * Compress data. Concurrency limited.\n *\n * @param {(Buffer|String)} data Data to compress\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @public\n */\n compress(data, fin, callback) {\n zlibLimiter.add((done) => {\n this._compress(data, fin, (err, result) => {\n done();\n callback(err, result);\n });\n });\n }\n\n /**\n * Decompress data.\n *\n * @param {Buffer} data Compressed data\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @private\n */\n _decompress(data, fin, callback) {\n const endpoint = this._isServer ? 'client' : 'server';\n\n if (!this._inflate) {\n const key = `${endpoint}_max_window_bits`;\n const windowBits =\n typeof this.params[key] !== 'number'\n ? zlib.Z_DEFAULT_WINDOWBITS\n : this.params[key];\n\n this._inflate = zlib.createInflateRaw({\n ...this._options.zlibInflateOptions,\n windowBits\n });\n this._inflate[kPerMessageDeflate] = this;\n this._inflate[kTotalLength] = 0;\n this._inflate[kBuffers] = [];\n this._inflate.on('error', inflateOnError);\n this._inflate.on('data', inflateOnData);\n }\n\n this._inflate[kCallback] = callback;\n\n this._inflate.write(data);\n if (fin) this._inflate.write(TRAILER);\n\n this._inflate.flush(() => {\n const err = this._inflate[kError];\n\n if (err) {\n this._inflate.close();\n this._inflate = null;\n callback(err);\n return;\n }\n\n const data = bufferUtil.concat(\n this._inflate[kBuffers],\n this._inflate[kTotalLength]\n );\n\n if (this._inflate._readableState.endEmitted) {\n this._inflate.close();\n this._inflate = null;\n } else {\n this._inflate[kTotalLength] = 0;\n this._inflate[kBuffers] = [];\n\n if (fin && this.params[`${endpoint}_no_context_takeover`]) {\n this._inflate.reset();\n }\n }\n\n callback(null, data);\n });\n }\n\n /**\n * Compress data.\n *\n * @param {(Buffer|String)} data Data to compress\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @private\n */\n _compress(data, fin, callback) {\n const endpoint = this._isServer ? 'server' : 'client';\n\n if (!this._deflate) {\n const key = `${endpoint}_max_window_bits`;\n const windowBits =\n typeof this.params[key] !== 'number'\n ? zlib.Z_DEFAULT_WINDOWBITS\n : this.params[key];\n\n this._deflate = zlib.createDeflateRaw({\n ...this._options.zlibDeflateOptions,\n windowBits\n });\n\n this._deflate[kTotalLength] = 0;\n this._deflate[kBuffers] = [];\n\n this._deflate.on('data', deflateOnData);\n }\n\n this._deflate[kCallback] = callback;\n\n this._deflate.write(data);\n this._deflate.flush(zlib.Z_SYNC_FLUSH, () => {\n if (!this._deflate) {\n //\n // The deflate stream was closed while data was being processed.\n //\n return;\n }\n\n let data = bufferUtil.concat(\n this._deflate[kBuffers],\n this._deflate[kTotalLength]\n );\n\n if (fin) {\n data = new FastBuffer(data.buffer, data.byteOffset, data.length - 4);\n }\n\n //\n // Ensure that the callback will not be called again in\n // `PerMessageDeflate#cleanup()`.\n //\n this._deflate[kCallback] = null;\n\n this._deflate[kTotalLength] = 0;\n this._deflate[kBuffers] = [];\n\n if (fin && this.params[`${endpoint}_no_context_takeover`]) {\n this._deflate.reset();\n }\n\n callback(null, data);\n });\n }\n}\n\nmodule.exports = PerMessageDeflate;\n\n/**\n * The listener of the `zlib.DeflateRaw` stream `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction deflateOnData(chunk) {\n this[kBuffers].push(chunk);\n this[kTotalLength] += chunk.length;\n}\n\n/**\n * The listener of the `zlib.InflateRaw` stream `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction inflateOnData(chunk) {\n this[kTotalLength] += chunk.length;\n\n if (\n this[kPerMessageDeflate]._maxPayload < 1 ||\n this[kTotalLength] <= this[kPerMessageDeflate]._maxPayload\n ) {\n this[kBuffers].push(chunk);\n return;\n }\n\n this[kError] = new RangeError('Max payload size exceeded');\n this[kError].code = 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH';\n this[kError][kStatusCode] = 1009;\n this.removeListener('data', inflateOnData);\n this.reset();\n}\n\n/**\n * The listener of the `zlib.InflateRaw` stream `'error'` event.\n *\n * @param {Error} err The emitted error\n * @private\n */\nfunction inflateOnError(err) {\n //\n // There is no need to call `Zlib#close()` as the handle is automatically\n // closed when an error is emitted.\n //\n this[kPerMessageDeflate]._inflate = null;\n err[kStatusCode] = 1007;\n this[kCallback](err);\n}\n","'use strict';\n\nconst { isUtf8 } = require('buffer');\n\nconst { hasBlob } = require('./constants');\n\n//\n// Allowed token characters:\n//\n// '!', '#', '$', '%', '&', ''', '*', '+', '-',\n// '.', 0-9, A-Z, '^', '_', '`', a-z, '|', '~'\n//\n// tokenChars[32] === 0 // ' '\n// tokenChars[33] === 1 // '!'\n// tokenChars[34] === 0 // '\"'\n// ...\n//\n// prettier-ignore\nconst tokenChars = [\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0 - 15\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16 - 31\n 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, // 32 - 47\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, // 48 - 63\n 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64 - 79\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, // 80 - 95\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96 - 111\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0 // 112 - 127\n];\n\n/**\n * Checks if a status code is allowed in a close frame.\n *\n * @param {Number} code The status code\n * @return {Boolean} `true` if the status code is valid, else `false`\n * @public\n */\nfunction isValidStatusCode(code) {\n return (\n (code >= 1000 &&\n code <= 1014 &&\n code !== 1004 &&\n code !== 1005 &&\n code !== 1006) ||\n (code >= 3000 && code <= 4999)\n );\n}\n\n/**\n * Checks if a given buffer contains only correct UTF-8.\n * Ported from https://www.cl.cam.ac.uk/%7Emgk25/ucs/utf8_check.c by\n * Markus Kuhn.\n *\n * @param {Buffer} buf The buffer to check\n * @return {Boolean} `true` if `buf` contains only correct UTF-8, else `false`\n * @public\n */\nfunction _isValidUTF8(buf) {\n const len = buf.length;\n let i = 0;\n\n while (i < len) {\n if ((buf[i] & 0x80) === 0) {\n // 0xxxxxxx\n i++;\n } else if ((buf[i] & 0xe0) === 0xc0) {\n // 110xxxxx 10xxxxxx\n if (\n i + 1 === len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i] & 0xfe) === 0xc0 // Overlong\n ) {\n return false;\n }\n\n i += 2;\n } else if ((buf[i] & 0xf0) === 0xe0) {\n // 1110xxxx 10xxxxxx 10xxxxxx\n if (\n i + 2 >= len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i + 2] & 0xc0) !== 0x80 ||\n (buf[i] === 0xe0 && (buf[i + 1] & 0xe0) === 0x80) || // Overlong\n (buf[i] === 0xed && (buf[i + 1] & 0xe0) === 0xa0) // Surrogate (U+D800 - U+DFFF)\n ) {\n return false;\n }\n\n i += 3;\n } else if ((buf[i] & 0xf8) === 0xf0) {\n // 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx\n if (\n i + 3 >= len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i + 2] & 0xc0) !== 0x80 ||\n (buf[i + 3] & 0xc0) !== 0x80 ||\n (buf[i] === 0xf0 && (buf[i + 1] & 0xf0) === 0x80) || // Overlong\n (buf[i] === 0xf4 && buf[i + 1] > 0x8f) ||\n buf[i] > 0xf4 // > U+10FFFF\n ) {\n return false;\n }\n\n i += 4;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Determines whether a value is a `Blob`.\n *\n * @param {*} value The value to be tested\n * @return {Boolean} `true` if `value` is a `Blob`, else `false`\n * @private\n */\nfunction isBlob(value) {\n return (\n hasBlob &&\n typeof value === 'object' &&\n typeof value.arrayBuffer === 'function' &&\n typeof value.type === 'string' &&\n typeof value.stream === 'function' &&\n (value[Symbol.toStringTag] === 'Blob' ||\n value[Symbol.toStringTag] === 'File')\n );\n}\n\nmodule.exports = {\n isBlob,\n isValidStatusCode,\n isValidUTF8: _isValidUTF8,\n tokenChars\n};\n\nif (isUtf8) {\n module.exports.isValidUTF8 = function (buf) {\n return buf.length < 24 ? _isValidUTF8(buf) : isUtf8(buf);\n };\n} /* istanbul ignore else */ else if (!process.env.WS_NO_UTF_8_VALIDATE) {\n try {\n const isValidUTF8 = require('utf-8-validate');\n\n module.exports.isValidUTF8 = function (buf) {\n return buf.length < 32 ? _isValidUTF8(buf) : isValidUTF8(buf);\n };\n } catch (e) {\n // Continue regardless of the error.\n }\n}\n","'use strict';\n\nconst { Writable } = require('stream');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst {\n BINARY_TYPES,\n EMPTY_BUFFER,\n kStatusCode,\n kWebSocket\n} = require('./constants');\nconst { concat, toArrayBuffer, unmask } = require('./buffer-util');\nconst { isValidStatusCode, isValidUTF8 } = require('./validation');\n\nconst FastBuffer = Buffer[Symbol.species];\n\nconst GET_INFO = 0;\nconst GET_PAYLOAD_LENGTH_16 = 1;\nconst GET_PAYLOAD_LENGTH_64 = 2;\nconst GET_MASK = 3;\nconst GET_DATA = 4;\nconst INFLATING = 5;\nconst DEFER_EVENT = 6;\n\n/**\n * HyBi Receiver implementation.\n *\n * @extends Writable\n */\nclass Receiver extends Writable {\n /**\n * Creates a Receiver instance.\n *\n * @param {Object} [options] Options object\n * @param {Boolean} [options.allowSynchronousEvents=true] Specifies whether\n * any of the `'message'`, `'ping'`, and `'pong'` events can be emitted\n * multiple times in the same tick\n * @param {String} [options.binaryType=nodebuffer] The type for binary data\n * @param {Object} [options.extensions] An object containing the negotiated\n * extensions\n * @param {Boolean} [options.isServer=false] Specifies whether to operate in\n * client or server mode\n * @param {Number} [options.maxPayload=0] The maximum allowed message length\n * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or\n * not to skip UTF-8 validation for text and close messages\n */\n constructor(options = {}) {\n super();\n\n this._allowSynchronousEvents =\n options.allowSynchronousEvents !== undefined\n ? options.allowSynchronousEvents\n : true;\n this._binaryType = options.binaryType || BINARY_TYPES[0];\n this._extensions = options.extensions || {};\n this._isServer = !!options.isServer;\n this._maxPayload = options.maxPayload | 0;\n this._skipUTF8Validation = !!options.skipUTF8Validation;\n this[kWebSocket] = undefined;\n\n this._bufferedBytes = 0;\n this._buffers = [];\n\n this._compressed = false;\n this._payloadLength = 0;\n this._mask = undefined;\n this._fragmented = 0;\n this._masked = false;\n this._fin = false;\n this._opcode = 0;\n\n this._totalPayloadLength = 0;\n this._messageLength = 0;\n this._fragments = [];\n\n this._errored = false;\n this._loop = false;\n this._state = GET_INFO;\n }\n\n /**\n * Implements `Writable.prototype._write()`.\n *\n * @param {Buffer} chunk The chunk of data to write\n * @param {String} encoding The character encoding of `chunk`\n * @param {Function} cb Callback\n * @private\n */\n _write(chunk, encoding, cb) {\n if (this._opcode === 0x08 && this._state == GET_INFO) return cb();\n\n this._bufferedBytes += chunk.length;\n this._buffers.push(chunk);\n this.startLoop(cb);\n }\n\n /**\n * Consumes `n` bytes from the buffered data.\n *\n * @param {Number} n The number of bytes to consume\n * @return {Buffer} The consumed bytes\n * @private\n */\n consume(n) {\n this._bufferedBytes -= n;\n\n if (n === this._buffers[0].length) return this._buffers.shift();\n\n if (n < this._buffers[0].length) {\n const buf = this._buffers[0];\n this._buffers[0] = new FastBuffer(\n buf.buffer,\n buf.byteOffset + n,\n buf.length - n\n );\n\n return new FastBuffer(buf.buffer, buf.byteOffset, n);\n }\n\n const dst = Buffer.allocUnsafe(n);\n\n do {\n const buf = this._buffers[0];\n const offset = dst.length - n;\n\n if (n >= buf.length) {\n dst.set(this._buffers.shift(), offset);\n } else {\n dst.set(new Uint8Array(buf.buffer, buf.byteOffset, n), offset);\n this._buffers[0] = new FastBuffer(\n buf.buffer,\n buf.byteOffset + n,\n buf.length - n\n );\n }\n\n n -= buf.length;\n } while (n > 0);\n\n return dst;\n }\n\n /**\n * Starts the parsing loop.\n *\n * @param {Function} cb Callback\n * @private\n */\n startLoop(cb) {\n this._loop = true;\n\n do {\n switch (this._state) {\n case GET_INFO:\n this.getInfo(cb);\n break;\n case GET_PAYLOAD_LENGTH_16:\n this.getPayloadLength16(cb);\n break;\n case GET_PAYLOAD_LENGTH_64:\n this.getPayloadLength64(cb);\n break;\n case GET_MASK:\n this.getMask();\n break;\n case GET_DATA:\n this.getData(cb);\n break;\n case INFLATING:\n case DEFER_EVENT:\n this._loop = false;\n return;\n }\n } while (this._loop);\n\n if (!this._errored) cb();\n }\n\n /**\n * Reads the first two bytes of a frame.\n *\n * @param {Function} cb Callback\n * @private\n */\n getInfo(cb) {\n if (this._bufferedBytes < 2) {\n this._loop = false;\n return;\n }\n\n const buf = this.consume(2);\n\n if ((buf[0] & 0x30) !== 0x00) {\n const error = this.createError(\n RangeError,\n 'RSV2 and RSV3 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_2_3'\n );\n\n cb(error);\n return;\n }\n\n const compressed = (buf[0] & 0x40) === 0x40;\n\n if (compressed && !this._extensions[PerMessageDeflate.extensionName]) {\n const error = this.createError(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n\n cb(error);\n return;\n }\n\n this._fin = (buf[0] & 0x80) === 0x80;\n this._opcode = buf[0] & 0x0f;\n this._payloadLength = buf[1] & 0x7f;\n\n if (this._opcode === 0x00) {\n if (compressed) {\n const error = this.createError(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n\n cb(error);\n return;\n }\n\n if (!this._fragmented) {\n const error = this.createError(\n RangeError,\n 'invalid opcode 0',\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n\n cb(error);\n return;\n }\n\n this._opcode = this._fragmented;\n } else if (this._opcode === 0x01 || this._opcode === 0x02) {\n if (this._fragmented) {\n const error = this.createError(\n RangeError,\n `invalid opcode ${this._opcode}`,\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n\n cb(error);\n return;\n }\n\n this._compressed = compressed;\n } else if (this._opcode > 0x07 && this._opcode < 0x0b) {\n if (!this._fin) {\n const error = this.createError(\n RangeError,\n 'FIN must be set',\n true,\n 1002,\n 'WS_ERR_EXPECTED_FIN'\n );\n\n cb(error);\n return;\n }\n\n if (compressed) {\n const error = this.createError(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n\n cb(error);\n return;\n }\n\n if (\n this._payloadLength > 0x7d ||\n (this._opcode === 0x08 && this._payloadLength === 1)\n ) {\n const error = this.createError(\n RangeError,\n `invalid payload length ${this._payloadLength}`,\n true,\n 1002,\n 'WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH'\n );\n\n cb(error);\n return;\n }\n } else {\n const error = this.createError(\n RangeError,\n `invalid opcode ${this._opcode}`,\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n\n cb(error);\n return;\n }\n\n if (!this._fin && !this._fragmented) this._fragmented = this._opcode;\n this._masked = (buf[1] & 0x80) === 0x80;\n\n if (this._isServer) {\n if (!this._masked) {\n const error = this.createError(\n RangeError,\n 'MASK must be set',\n true,\n 1002,\n 'WS_ERR_EXPECTED_MASK'\n );\n\n cb(error);\n return;\n }\n } else if (this._masked) {\n const error = this.createError(\n RangeError,\n 'MASK must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_MASK'\n );\n\n cb(error);\n return;\n }\n\n if (this._payloadLength === 126) this._state = GET_PAYLOAD_LENGTH_16;\n else if (this._payloadLength === 127) this._state = GET_PAYLOAD_LENGTH_64;\n else this.haveLength(cb);\n }\n\n /**\n * Gets extended payload length (7+16).\n *\n * @param {Function} cb Callback\n * @private\n */\n getPayloadLength16(cb) {\n if (this._bufferedBytes < 2) {\n this._loop = false;\n return;\n }\n\n this._payloadLength = this.consume(2).readUInt16BE(0);\n this.haveLength(cb);\n }\n\n /**\n * Gets extended payload length (7+64).\n *\n * @param {Function} cb Callback\n * @private\n */\n getPayloadLength64(cb) {\n if (this._bufferedBytes < 8) {\n this._loop = false;\n return;\n }\n\n const buf = this.consume(8);\n const num = buf.readUInt32BE(0);\n\n //\n // The maximum safe integer in JavaScript is 2^53 - 1. An error is returned\n // if payload length is greater than this number.\n //\n if (num > Math.pow(2, 53 - 32) - 1) {\n const error = this.createError(\n RangeError,\n 'Unsupported WebSocket frame: payload length > 2^53 - 1',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH'\n );\n\n cb(error);\n return;\n }\n\n this._payloadLength = num * Math.pow(2, 32) + buf.readUInt32BE(4);\n this.haveLength(cb);\n }\n\n /**\n * Payload length has been read.\n *\n * @param {Function} cb Callback\n * @private\n */\n haveLength(cb) {\n if (this._payloadLength && this._opcode < 0x08) {\n this._totalPayloadLength += this._payloadLength;\n if (this._totalPayloadLength > this._maxPayload && this._maxPayload > 0) {\n const error = this.createError(\n RangeError,\n 'Max payload size exceeded',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'\n );\n\n cb(error);\n return;\n }\n }\n\n if (this._masked) this._state = GET_MASK;\n else this._state = GET_DATA;\n }\n\n /**\n * Reads mask bytes.\n *\n * @private\n */\n getMask() {\n if (this._bufferedBytes < 4) {\n this._loop = false;\n return;\n }\n\n this._mask = this.consume(4);\n this._state = GET_DATA;\n }\n\n /**\n * Reads data bytes.\n *\n * @param {Function} cb Callback\n * @private\n */\n getData(cb) {\n let data = EMPTY_BUFFER;\n\n if (this._payloadLength) {\n if (this._bufferedBytes < this._payloadLength) {\n this._loop = false;\n return;\n }\n\n data = this.consume(this._payloadLength);\n\n if (\n this._masked &&\n (this._mask[0] | this._mask[1] | this._mask[2] | this._mask[3]) !== 0\n ) {\n unmask(data, this._mask);\n }\n }\n\n if (this._opcode > 0x07) {\n this.controlMessage(data, cb);\n return;\n }\n\n if (this._compressed) {\n this._state = INFLATING;\n this.decompress(data, cb);\n return;\n }\n\n if (data.length) {\n //\n // This message is not compressed so its length is the sum of the payload\n // length of all fragments.\n //\n this._messageLength = this._totalPayloadLength;\n this._fragments.push(data);\n }\n\n this.dataMessage(cb);\n }\n\n /**\n * Decompresses data.\n *\n * @param {Buffer} data Compressed data\n * @param {Function} cb Callback\n * @private\n */\n decompress(data, cb) {\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n\n perMessageDeflate.decompress(data, this._fin, (err, buf) => {\n if (err) return cb(err);\n\n if (buf.length) {\n this._messageLength += buf.length;\n if (this._messageLength > this._maxPayload && this._maxPayload > 0) {\n const error = this.createError(\n RangeError,\n 'Max payload size exceeded',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'\n );\n\n cb(error);\n return;\n }\n\n this._fragments.push(buf);\n }\n\n this.dataMessage(cb);\n if (this._state === GET_INFO) this.startLoop(cb);\n });\n }\n\n /**\n * Handles a data message.\n *\n * @param {Function} cb Callback\n * @private\n */\n dataMessage(cb) {\n if (!this._fin) {\n this._state = GET_INFO;\n return;\n }\n\n const messageLength = this._messageLength;\n const fragments = this._fragments;\n\n this._totalPayloadLength = 0;\n this._messageLength = 0;\n this._fragmented = 0;\n this._fragments = [];\n\n if (this._opcode === 2) {\n let data;\n\n if (this._binaryType === 'nodebuffer') {\n data = concat(fragments, messageLength);\n } else if (this._binaryType === 'arraybuffer') {\n data = toArrayBuffer(concat(fragments, messageLength));\n } else if (this._binaryType === 'blob') {\n data = new Blob(fragments);\n } else {\n data = fragments;\n }\n\n if (this._allowSynchronousEvents) {\n this.emit('message', data, true);\n this._state = GET_INFO;\n } else {\n this._state = DEFER_EVENT;\n setImmediate(() => {\n this.emit('message', data, true);\n this._state = GET_INFO;\n this.startLoop(cb);\n });\n }\n } else {\n const buf = concat(fragments, messageLength);\n\n if (!this._skipUTF8Validation && !isValidUTF8(buf)) {\n const error = this.createError(\n Error,\n 'invalid UTF-8 sequence',\n true,\n 1007,\n 'WS_ERR_INVALID_UTF8'\n );\n\n cb(error);\n return;\n }\n\n if (this._state === INFLATING || this._allowSynchronousEvents) {\n this.emit('message', buf, false);\n this._state = GET_INFO;\n } else {\n this._state = DEFER_EVENT;\n setImmediate(() => {\n this.emit('message', buf, false);\n this._state = GET_INFO;\n this.startLoop(cb);\n });\n }\n }\n }\n\n /**\n * Handles a control message.\n *\n * @param {Buffer} data Data to handle\n * @return {(Error|RangeError|undefined)} A possible error\n * @private\n */\n controlMessage(data, cb) {\n if (this._opcode === 0x08) {\n if (data.length === 0) {\n this._loop = false;\n this.emit('conclude', 1005, EMPTY_BUFFER);\n this.end();\n } else {\n const code = data.readUInt16BE(0);\n\n if (!isValidStatusCode(code)) {\n const error = this.createError(\n RangeError,\n `invalid status code ${code}`,\n true,\n 1002,\n 'WS_ERR_INVALID_CLOSE_CODE'\n );\n\n cb(error);\n return;\n }\n\n const buf = new FastBuffer(\n data.buffer,\n data.byteOffset + 2,\n data.length - 2\n );\n\n if (!this._skipUTF8Validation && !isValidUTF8(buf)) {\n const error = this.createError(\n Error,\n 'invalid UTF-8 sequence',\n true,\n 1007,\n 'WS_ERR_INVALID_UTF8'\n );\n\n cb(error);\n return;\n }\n\n this._loop = false;\n this.emit('conclude', code, buf);\n this.end();\n }\n\n this._state = GET_INFO;\n return;\n }\n\n if (this._allowSynchronousEvents) {\n this.emit(this._opcode === 0x09 ? 'ping' : 'pong', data);\n this._state = GET_INFO;\n } else {\n this._state = DEFER_EVENT;\n setImmediate(() => {\n this.emit(this._opcode === 0x09 ? 'ping' : 'pong', data);\n this._state = GET_INFO;\n this.startLoop(cb);\n });\n }\n }\n\n /**\n * Builds an error object.\n *\n * @param {function(new:Error|RangeError)} ErrorCtor The error constructor\n * @param {String} message The error message\n * @param {Boolean} prefix Specifies whether or not to add a default prefix to\n * `message`\n * @param {Number} statusCode The status code\n * @param {String} errorCode The exposed error code\n * @return {(Error|RangeError)} The error\n * @private\n */\n createError(ErrorCtor, message, prefix, statusCode, errorCode) {\n this._loop = false;\n this._errored = true;\n\n const err = new ErrorCtor(\n prefix ? `Invalid WebSocket frame: ${message}` : message\n );\n\n Error.captureStackTrace(err, this.createError);\n err.code = errorCode;\n err[kStatusCode] = statusCode;\n return err;\n }\n}\n\nmodule.exports = Receiver;\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^Duplex\" }] */\n\n'use strict';\n\nconst { Duplex } = require('stream');\nconst { randomFillSync } = require('crypto');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst { EMPTY_BUFFER, kWebSocket, NOOP } = require('./constants');\nconst { isBlob, isValidStatusCode } = require('./validation');\nconst { mask: applyMask, toBuffer } = require('./buffer-util');\n\nconst kByteLength = Symbol('kByteLength');\nconst maskBuffer = Buffer.alloc(4);\nconst RANDOM_POOL_SIZE = 8 * 1024;\nlet randomPool;\nlet randomPoolPointer = RANDOM_POOL_SIZE;\n\nconst DEFAULT = 0;\nconst DEFLATING = 1;\nconst GET_BLOB_DATA = 2;\n\n/**\n * HyBi Sender implementation.\n */\nclass Sender {\n /**\n * Creates a Sender instance.\n *\n * @param {Duplex} socket The connection socket\n * @param {Object} [extensions] An object containing the negotiated extensions\n * @param {Function} [generateMask] The function used to generate the masking\n * key\n */\n constructor(socket, extensions, generateMask) {\n this._extensions = extensions || {};\n\n if (generateMask) {\n this._generateMask = generateMask;\n this._maskBuffer = Buffer.alloc(4);\n }\n\n this._socket = socket;\n\n this._firstFragment = true;\n this._compress = false;\n\n this._bufferedBytes = 0;\n this._queue = [];\n this._state = DEFAULT;\n this.onerror = NOOP;\n this[kWebSocket] = undefined;\n }\n\n /**\n * Frames a piece of data according to the HyBi WebSocket protocol.\n *\n * @param {(Buffer|String)} data The data to frame\n * @param {Object} options Options object\n * @param {Boolean} [options.fin=false] Specifies whether or not to set the\n * FIN bit\n * @param {Function} [options.generateMask] The function used to generate the\n * masking key\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Buffer} [options.maskBuffer] The buffer used to store the masking\n * key\n * @param {Number} options.opcode The opcode\n * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be\n * modified\n * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the\n * RSV1 bit\n * @return {(Buffer|String)[]} The framed data\n * @public\n */\n static frame(data, options) {\n let mask;\n let merge = false;\n let offset = 2;\n let skipMasking = false;\n\n if (options.mask) {\n mask = options.maskBuffer || maskBuffer;\n\n if (options.generateMask) {\n options.generateMask(mask);\n } else {\n if (randomPoolPointer === RANDOM_POOL_SIZE) {\n /* istanbul ignore else */\n if (randomPool === undefined) {\n //\n // This is lazily initialized because server-sent frames must not\n // be masked so it may never be used.\n //\n randomPool = Buffer.alloc(RANDOM_POOL_SIZE);\n }\n\n randomFillSync(randomPool, 0, RANDOM_POOL_SIZE);\n randomPoolPointer = 0;\n }\n\n mask[0] = randomPool[randomPoolPointer++];\n mask[1] = randomPool[randomPoolPointer++];\n mask[2] = randomPool[randomPoolPointer++];\n mask[3] = randomPool[randomPoolPointer++];\n }\n\n skipMasking = (mask[0] | mask[1] | mask[2] | mask[3]) === 0;\n offset = 6;\n }\n\n let dataLength;\n\n if (typeof data === 'string') {\n if (\n (!options.mask || skipMasking) &&\n options[kByteLength] !== undefined\n ) {\n dataLength = options[kByteLength];\n } else {\n data = Buffer.from(data);\n dataLength = data.length;\n }\n } else {\n dataLength = data.length;\n merge = options.mask && options.readOnly && !skipMasking;\n }\n\n let payloadLength = dataLength;\n\n if (dataLength >= 65536) {\n offset += 8;\n payloadLength = 127;\n } else if (dataLength > 125) {\n offset += 2;\n payloadLength = 126;\n }\n\n const target = Buffer.allocUnsafe(merge ? dataLength + offset : offset);\n\n target[0] = options.fin ? options.opcode | 0x80 : options.opcode;\n if (options.rsv1) target[0] |= 0x40;\n\n target[1] = payloadLength;\n\n if (payloadLength === 126) {\n target.writeUInt16BE(dataLength, 2);\n } else if (payloadLength === 127) {\n target[2] = target[3] = 0;\n target.writeUIntBE(dataLength, 4, 6);\n }\n\n if (!options.mask) return [target, data];\n\n target[1] |= 0x80;\n target[offset - 4] = mask[0];\n target[offset - 3] = mask[1];\n target[offset - 2] = mask[2];\n target[offset - 1] = mask[3];\n\n if (skipMasking) return [target, data];\n\n if (merge) {\n applyMask(data, mask, target, offset, dataLength);\n return [target];\n }\n\n applyMask(data, mask, data, 0, dataLength);\n return [target, data];\n }\n\n /**\n * Sends a close message to the other peer.\n *\n * @param {Number} [code] The status code component of the body\n * @param {(String|Buffer)} [data] The message component of the body\n * @param {Boolean} [mask=false] Specifies whether or not to mask the message\n * @param {Function} [cb] Callback\n * @public\n */\n close(code, data, mask, cb) {\n let buf;\n\n if (code === undefined) {\n buf = EMPTY_BUFFER;\n } else if (typeof code !== 'number' || !isValidStatusCode(code)) {\n throw new TypeError('First argument must be a valid error code number');\n } else if (data === undefined || !data.length) {\n buf = Buffer.allocUnsafe(2);\n buf.writeUInt16BE(code, 0);\n } else {\n const length = Buffer.byteLength(data);\n\n if (length > 123) {\n throw new RangeError('The message must not be greater than 123 bytes');\n }\n\n buf = Buffer.allocUnsafe(2 + length);\n buf.writeUInt16BE(code, 0);\n\n if (typeof data === 'string') {\n buf.write(data, 2);\n } else {\n buf.set(data, 2);\n }\n }\n\n const options = {\n [kByteLength]: buf.length,\n fin: true,\n generateMask: this._generateMask,\n mask,\n maskBuffer: this._maskBuffer,\n opcode: 0x08,\n readOnly: false,\n rsv1: false\n };\n\n if (this._state !== DEFAULT) {\n this.enqueue([this.dispatch, buf, false, options, cb]);\n } else {\n this.sendFrame(Sender.frame(buf, options), cb);\n }\n }\n\n /**\n * Sends a ping message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback\n * @public\n */\n ping(data, mask, cb) {\n let byteLength;\n let readOnly;\n\n if (typeof data === 'string') {\n byteLength = Buffer.byteLength(data);\n readOnly = false;\n } else if (isBlob(data)) {\n byteLength = data.size;\n readOnly = false;\n } else {\n data = toBuffer(data);\n byteLength = data.length;\n readOnly = toBuffer.readOnly;\n }\n\n if (byteLength > 125) {\n throw new RangeError('The data size must not be greater than 125 bytes');\n }\n\n const options = {\n [kByteLength]: byteLength,\n fin: true,\n generateMask: this._generateMask,\n mask,\n maskBuffer: this._maskBuffer,\n opcode: 0x09,\n readOnly,\n rsv1: false\n };\n\n if (isBlob(data)) {\n if (this._state !== DEFAULT) {\n this.enqueue([this.getBlobData, data, false, options, cb]);\n } else {\n this.getBlobData(data, false, options, cb);\n }\n } else if (this._state !== DEFAULT) {\n this.enqueue([this.dispatch, data, false, options, cb]);\n } else {\n this.sendFrame(Sender.frame(data, options), cb);\n }\n }\n\n /**\n * Sends a pong message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback\n * @public\n */\n pong(data, mask, cb) {\n let byteLength;\n let readOnly;\n\n if (typeof data === 'string') {\n byteLength = Buffer.byteLength(data);\n readOnly = false;\n } else if (isBlob(data)) {\n byteLength = data.size;\n readOnly = false;\n } else {\n data = toBuffer(data);\n byteLength = data.length;\n readOnly = toBuffer.readOnly;\n }\n\n if (byteLength > 125) {\n throw new RangeError('The data size must not be greater than 125 bytes');\n }\n\n const options = {\n [kByteLength]: byteLength,\n fin: true,\n generateMask: this._generateMask,\n mask,\n maskBuffer: this._maskBuffer,\n opcode: 0x0a,\n readOnly,\n rsv1: false\n };\n\n if (isBlob(data)) {\n if (this._state !== DEFAULT) {\n this.enqueue([this.getBlobData, data, false, options, cb]);\n } else {\n this.getBlobData(data, false, options, cb);\n }\n } else if (this._state !== DEFAULT) {\n this.enqueue([this.dispatch, data, false, options, cb]);\n } else {\n this.sendFrame(Sender.frame(data, options), cb);\n }\n }\n\n /**\n * Sends a data message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Object} options Options object\n * @param {Boolean} [options.binary=false] Specifies whether `data` is binary\n * or text\n * @param {Boolean} [options.compress=false] Specifies whether or not to\n * compress `data`\n * @param {Boolean} [options.fin=false] Specifies whether the fragment is the\n * last one\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Function} [cb] Callback\n * @public\n */\n send(data, options, cb) {\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n let opcode = options.binary ? 2 : 1;\n let rsv1 = options.compress;\n\n let byteLength;\n let readOnly;\n\n if (typeof data === 'string') {\n byteLength = Buffer.byteLength(data);\n readOnly = false;\n } else if (isBlob(data)) {\n byteLength = data.size;\n readOnly = false;\n } else {\n data = toBuffer(data);\n byteLength = data.length;\n readOnly = toBuffer.readOnly;\n }\n\n if (this._firstFragment) {\n this._firstFragment = false;\n if (\n rsv1 &&\n perMessageDeflate &&\n perMessageDeflate.params[\n perMessageDeflate._isServer\n ? 'server_no_context_takeover'\n : 'client_no_context_takeover'\n ]\n ) {\n rsv1 = byteLength >= perMessageDeflate._threshold;\n }\n this._compress = rsv1;\n } else {\n rsv1 = false;\n opcode = 0;\n }\n\n if (options.fin) this._firstFragment = true;\n\n const opts = {\n [kByteLength]: byteLength,\n fin: options.fin,\n generateMask: this._generateMask,\n mask: options.mask,\n maskBuffer: this._maskBuffer,\n opcode,\n readOnly,\n rsv1\n };\n\n if (isBlob(data)) {\n if (this._state !== DEFAULT) {\n this.enqueue([this.getBlobData, data, this._compress, opts, cb]);\n } else {\n this.getBlobData(data, this._compress, opts, cb);\n }\n } else if (this._state !== DEFAULT) {\n this.enqueue([this.dispatch, data, this._compress, opts, cb]);\n } else {\n this.dispatch(data, this._compress, opts, cb);\n }\n }\n\n /**\n * Gets the contents of a blob as binary data.\n *\n * @param {Blob} blob The blob\n * @param {Boolean} [compress=false] Specifies whether or not to compress\n * the data\n * @param {Object} options Options object\n * @param {Boolean} [options.fin=false] Specifies whether or not to set the\n * FIN bit\n * @param {Function} [options.generateMask] The function used to generate the\n * masking key\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Buffer} [options.maskBuffer] The buffer used to store the masking\n * key\n * @param {Number} options.opcode The opcode\n * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be\n * modified\n * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the\n * RSV1 bit\n * @param {Function} [cb] Callback\n * @private\n */\n getBlobData(blob, compress, options, cb) {\n this._bufferedBytes += options[kByteLength];\n this._state = GET_BLOB_DATA;\n\n blob\n .arrayBuffer()\n .then((arrayBuffer) => {\n if (this._socket.destroyed) {\n const err = new Error(\n 'The socket was closed while the blob was being read'\n );\n\n //\n // `callCallbacks` is called in the next tick to ensure that errors\n // that might be thrown in the callbacks behave like errors thrown\n // outside the promise chain.\n //\n process.nextTick(callCallbacks, this, err, cb);\n return;\n }\n\n this._bufferedBytes -= options[kByteLength];\n const data = toBuffer(arrayBuffer);\n\n if (!compress) {\n this._state = DEFAULT;\n this.sendFrame(Sender.frame(data, options), cb);\n this.dequeue();\n } else {\n this.dispatch(data, compress, options, cb);\n }\n })\n .catch((err) => {\n //\n // `onError` is called in the next tick for the same reason that\n // `callCallbacks` above is.\n //\n process.nextTick(onError, this, err, cb);\n });\n }\n\n /**\n * Dispatches a message.\n *\n * @param {(Buffer|String)} data The message to send\n * @param {Boolean} [compress=false] Specifies whether or not to compress\n * `data`\n * @param {Object} options Options object\n * @param {Boolean} [options.fin=false] Specifies whether or not to set the\n * FIN bit\n * @param {Function} [options.generateMask] The function used to generate the\n * masking key\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Buffer} [options.maskBuffer] The buffer used to store the masking\n * key\n * @param {Number} options.opcode The opcode\n * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be\n * modified\n * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the\n * RSV1 bit\n * @param {Function} [cb] Callback\n * @private\n */\n dispatch(data, compress, options, cb) {\n if (!compress) {\n this.sendFrame(Sender.frame(data, options), cb);\n return;\n }\n\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n\n this._bufferedBytes += options[kByteLength];\n this._state = DEFLATING;\n perMessageDeflate.compress(data, options.fin, (_, buf) => {\n if (this._socket.destroyed) {\n const err = new Error(\n 'The socket was closed while data was being compressed'\n );\n\n callCallbacks(this, err, cb);\n return;\n }\n\n this._bufferedBytes -= options[kByteLength];\n this._state = DEFAULT;\n options.readOnly = false;\n this.sendFrame(Sender.frame(buf, options), cb);\n this.dequeue();\n });\n }\n\n /**\n * Executes queued send operations.\n *\n * @private\n */\n dequeue() {\n while (this._state === DEFAULT && this._queue.length) {\n const params = this._queue.shift();\n\n this._bufferedBytes -= params[3][kByteLength];\n Reflect.apply(params[0], this, params.slice(1));\n }\n }\n\n /**\n * Enqueues a send operation.\n *\n * @param {Array} params Send operation parameters.\n * @private\n */\n enqueue(params) {\n this._bufferedBytes += params[3][kByteLength];\n this._queue.push(params);\n }\n\n /**\n * Sends a frame.\n *\n * @param {Buffer[]} list The frame to send\n * @param {Function} [cb] Callback\n * @private\n */\n sendFrame(list, cb) {\n if (list.length === 2) {\n this._socket.cork();\n this._socket.write(list[0]);\n this._socket.write(list[1], cb);\n this._socket.uncork();\n } else {\n this._socket.write(list[0], cb);\n }\n }\n}\n\nmodule.exports = Sender;\n\n/**\n * Calls queued callbacks with an error.\n *\n * @param {Sender} sender The `Sender` instance\n * @param {Error} err The error to call the callbacks with\n * @param {Function} [cb] The first callback\n * @private\n */\nfunction callCallbacks(sender, err, cb) {\n if (typeof cb === 'function') cb(err);\n\n for (let i = 0; i < sender._queue.length; i++) {\n const params = sender._queue[i];\n const callback = params[params.length - 1];\n\n if (typeof callback === 'function') callback(err);\n }\n}\n\n/**\n * Handles a `Sender` error.\n *\n * @param {Sender} sender The `Sender` instance\n * @param {Error} err The error\n * @param {Function} [cb] The first pending callback\n * @private\n */\nfunction onError(sender, err, cb) {\n callCallbacks(sender, err, cb);\n sender.onerror(err);\n}\n","'use strict';\n\nconst { kForOnEventAttribute, kListener } = require('./constants');\n\nconst kCode = Symbol('kCode');\nconst kData = Symbol('kData');\nconst kError = Symbol('kError');\nconst kMessage = Symbol('kMessage');\nconst kReason = Symbol('kReason');\nconst kTarget = Symbol('kTarget');\nconst kType = Symbol('kType');\nconst kWasClean = Symbol('kWasClean');\n\n/**\n * Class representing an event.\n */\nclass Event {\n /**\n * Create a new `Event`.\n *\n * @param {String} type The name of the event\n * @throws {TypeError} If the `type` argument is not specified\n */\n constructor(type) {\n this[kTarget] = null;\n this[kType] = type;\n }\n\n /**\n * @type {*}\n */\n get target() {\n return this[kTarget];\n }\n\n /**\n * @type {String}\n */\n get type() {\n return this[kType];\n }\n}\n\nObject.defineProperty(Event.prototype, 'target', { enumerable: true });\nObject.defineProperty(Event.prototype, 'type', { enumerable: true });\n\n/**\n * Class representing a close event.\n *\n * @extends Event\n */\nclass CloseEvent extends Event {\n /**\n * Create a new `CloseEvent`.\n *\n * @param {String} type The name of the event\n * @param {Object} [options] A dictionary object that allows for setting\n * attributes via object members of the same name\n * @param {Number} [options.code=0] The status code explaining why the\n * connection was closed\n * @param {String} [options.reason=''] A human-readable string explaining why\n * the connection was closed\n * @param {Boolean} [options.wasClean=false] Indicates whether or not the\n * connection was cleanly closed\n */\n constructor(type, options = {}) {\n super(type);\n\n this[kCode] = options.code === undefined ? 0 : options.code;\n this[kReason] = options.reason === undefined ? '' : options.reason;\n this[kWasClean] = options.wasClean === undefined ? false : options.wasClean;\n }\n\n /**\n * @type {Number}\n */\n get code() {\n return this[kCode];\n }\n\n /**\n * @type {String}\n */\n get reason() {\n return this[kReason];\n }\n\n /**\n * @type {Boolean}\n */\n get wasClean() {\n return this[kWasClean];\n }\n}\n\nObject.defineProperty(CloseEvent.prototype, 'code', { enumerable: true });\nObject.defineProperty(CloseEvent.prototype, 'reason', { enumerable: true });\nObject.defineProperty(CloseEvent.prototype, 'wasClean', { enumerable: true });\n\n/**\n * Class representing an error event.\n *\n * @extends Event\n */\nclass ErrorEvent extends Event {\n /**\n * Create a new `ErrorEvent`.\n *\n * @param {String} type The name of the event\n * @param {Object} [options] A dictionary object that allows for setting\n * attributes via object members of the same name\n * @param {*} [options.error=null] The error that generated this event\n * @param {String} [options.message=''] The error message\n */\n constructor(type, options = {}) {\n super(type);\n\n this[kError] = options.error === undefined ? null : options.error;\n this[kMessage] = options.message === undefined ? '' : options.message;\n }\n\n /**\n * @type {*}\n */\n get error() {\n return this[kError];\n }\n\n /**\n * @type {String}\n */\n get message() {\n return this[kMessage];\n }\n}\n\nObject.defineProperty(ErrorEvent.prototype, 'error', { enumerable: true });\nObject.defineProperty(ErrorEvent.prototype, 'message', { enumerable: true });\n\n/**\n * Class representing a message event.\n *\n * @extends Event\n */\nclass MessageEvent extends Event {\n /**\n * Create a new `MessageEvent`.\n *\n * @param {String} type The name of the event\n * @param {Object} [options] A dictionary object that allows for setting\n * attributes via object members of the same name\n * @param {*} [options.data=null] The message content\n */\n constructor(type, options = {}) {\n super(type);\n\n this[kData] = options.data === undefined ? null : options.data;\n }\n\n /**\n * @type {*}\n */\n get data() {\n return this[kData];\n }\n}\n\nObject.defineProperty(MessageEvent.prototype, 'data', { enumerable: true });\n\n/**\n * This provides methods for emulating the `EventTarget` interface. It's not\n * meant to be used directly.\n *\n * @mixin\n */\nconst EventTarget = {\n /**\n * Register an event listener.\n *\n * @param {String} type A string representing the event type to listen for\n * @param {(Function|Object)} handler The listener to add\n * @param {Object} [options] An options object specifies characteristics about\n * the event listener\n * @param {Boolean} [options.once=false] A `Boolean` indicating that the\n * listener should be invoked at most once after being added. If `true`,\n * the listener would be automatically removed when invoked.\n * @public\n */\n addEventListener(type, handler, options = {}) {\n for (const listener of this.listeners(type)) {\n if (\n !options[kForOnEventAttribute] &&\n listener[kListener] === handler &&\n !listener[kForOnEventAttribute]\n ) {\n return;\n }\n }\n\n let wrapper;\n\n if (type === 'message') {\n wrapper = function onMessage(data, isBinary) {\n const event = new MessageEvent('message', {\n data: isBinary ? data : data.toString()\n });\n\n event[kTarget] = this;\n callListener(handler, this, event);\n };\n } else if (type === 'close') {\n wrapper = function onClose(code, message) {\n const event = new CloseEvent('close', {\n code,\n reason: message.toString(),\n wasClean: this._closeFrameReceived && this._closeFrameSent\n });\n\n event[kTarget] = this;\n callListener(handler, this, event);\n };\n } else if (type === 'error') {\n wrapper = function onError(error) {\n const event = new ErrorEvent('error', {\n error,\n message: error.message\n });\n\n event[kTarget] = this;\n callListener(handler, this, event);\n };\n } else if (type === 'open') {\n wrapper = function onOpen() {\n const event = new Event('open');\n\n event[kTarget] = this;\n callListener(handler, this, event);\n };\n } else {\n return;\n }\n\n wrapper[kForOnEventAttribute] = !!options[kForOnEventAttribute];\n wrapper[kListener] = handler;\n\n if (options.once) {\n this.once(type, wrapper);\n } else {\n this.on(type, wrapper);\n }\n },\n\n /**\n * Remove an event listener.\n *\n * @param {String} type A string representing the event type to remove\n * @param {(Function|Object)} handler The listener to remove\n * @public\n */\n removeEventListener(type, handler) {\n for (const listener of this.listeners(type)) {\n if (listener[kListener] === handler && !listener[kForOnEventAttribute]) {\n this.removeListener(type, listener);\n break;\n }\n }\n }\n};\n\nmodule.exports = {\n CloseEvent,\n ErrorEvent,\n Event,\n EventTarget,\n MessageEvent\n};\n\n/**\n * Call an event listener\n *\n * @param {(Function|Object)} listener The listener to call\n * @param {*} thisArg The value to use as `this`` when calling the listener\n * @param {Event} event The event to pass to the listener\n * @private\n */\nfunction callListener(listener, thisArg, event) {\n if (typeof listener === 'object' && listener.handleEvent) {\n listener.handleEvent.call(listener, event);\n } else {\n listener.call(thisArg, event);\n }\n}\n","'use strict';\n\nconst { tokenChars } = require('./validation');\n\n/**\n * Adds an offer to the map of extension offers or a parameter to the map of\n * parameters.\n *\n * @param {Object} dest The map of extension offers or parameters\n * @param {String} name The extension or parameter name\n * @param {(Object|Boolean|String)} elem The extension parameters or the\n * parameter value\n * @private\n */\nfunction push(dest, name, elem) {\n if (dest[name] === undefined) dest[name] = [elem];\n else dest[name].push(elem);\n}\n\n/**\n * Parses the `Sec-WebSocket-Extensions` header into an object.\n *\n * @param {String} header The field value of the header\n * @return {Object} The parsed object\n * @public\n */\nfunction parse(header) {\n const offers = Object.create(null);\n let params = Object.create(null);\n let mustUnescape = false;\n let isEscaping = false;\n let inQuotes = false;\n let extensionName;\n let paramName;\n let start = -1;\n let code = -1;\n let end = -1;\n let i = 0;\n\n for (; i < header.length; i++) {\n code = header.charCodeAt(i);\n\n if (extensionName === undefined) {\n if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (\n i !== 0 &&\n (code === 0x20 /* ' ' */ || code === 0x09) /* '\\t' */\n ) {\n if (end === -1 && start !== -1) end = i;\n } else if (code === 0x3b /* ';' */ || code === 0x2c /* ',' */) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n const name = header.slice(start, end);\n if (code === 0x2c) {\n push(offers, name, params);\n params = Object.create(null);\n } else {\n extensionName = name;\n }\n\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else if (paramName === undefined) {\n if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (code === 0x20 || code === 0x09) {\n if (end === -1 && start !== -1) end = i;\n } else if (code === 0x3b || code === 0x2c) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n push(params, header.slice(start, end), true);\n if (code === 0x2c) {\n push(offers, extensionName, params);\n params = Object.create(null);\n extensionName = undefined;\n }\n\n start = end = -1;\n } else if (code === 0x3d /* '=' */ && start !== -1 && end === -1) {\n paramName = header.slice(start, i);\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else {\n //\n // The value of a quoted-string after unescaping must conform to the\n // token ABNF, so only token characters are valid.\n // Ref: https://tools.ietf.org/html/rfc6455#section-9.1\n //\n if (isEscaping) {\n if (tokenChars[code] !== 1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n if (start === -1) start = i;\n else if (!mustUnescape) mustUnescape = true;\n isEscaping = false;\n } else if (inQuotes) {\n if (tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (code === 0x22 /* '\"' */ && start !== -1) {\n inQuotes = false;\n end = i;\n } else if (code === 0x5c /* '\\' */) {\n isEscaping = true;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else if (code === 0x22 && header.charCodeAt(i - 1) === 0x3d) {\n inQuotes = true;\n } else if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (start !== -1 && (code === 0x20 || code === 0x09)) {\n if (end === -1) end = i;\n } else if (code === 0x3b || code === 0x2c) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n let value = header.slice(start, end);\n if (mustUnescape) {\n value = value.replace(/\\\\/g, '');\n mustUnescape = false;\n }\n push(params, paramName, value);\n if (code === 0x2c) {\n push(offers, extensionName, params);\n params = Object.create(null);\n extensionName = undefined;\n }\n\n paramName = undefined;\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n }\n }\n\n if (start === -1 || inQuotes || code === 0x20 || code === 0x09) {\n throw new SyntaxError('Unexpected end of input');\n }\n\n if (end === -1) end = i;\n const token = header.slice(start, end);\n if (extensionName === undefined) {\n push(offers, token, params);\n } else {\n if (paramName === undefined) {\n push(params, token, true);\n } else if (mustUnescape) {\n push(params, paramName, token.replace(/\\\\/g, ''));\n } else {\n push(params, paramName, token);\n }\n push(offers, extensionName, params);\n }\n\n return offers;\n}\n\n/**\n * Builds the `Sec-WebSocket-Extensions` header field value.\n *\n * @param {Object} extensions The map of extensions and parameters to format\n * @return {String} A string representing the given object\n * @public\n */\nfunction format(extensions) {\n return Object.keys(extensions)\n .map((extension) => {\n let configurations = extensions[extension];\n if (!Array.isArray(configurations)) configurations = [configurations];\n return configurations\n .map((params) => {\n return [extension]\n .concat(\n Object.keys(params).map((k) => {\n let values = params[k];\n if (!Array.isArray(values)) values = [values];\n return values\n .map((v) => (v === true ? k : `${k}=${v}`))\n .join('; ');\n })\n )\n .join('; ');\n })\n .join(', ');\n })\n .join(', ');\n}\n\nmodule.exports = { format, parse };\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^Duplex|Readable$\", \"caughtErrors\": \"none\" }] */\n\n'use strict';\n\nconst EventEmitter = require('events');\nconst https = require('https');\nconst http = require('http');\nconst net = require('net');\nconst tls = require('tls');\nconst { randomBytes, createHash } = require('crypto');\nconst { Duplex, Readable } = require('stream');\nconst { URL } = require('url');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst Receiver = require('./receiver');\nconst Sender = require('./sender');\nconst { isBlob } = require('./validation');\n\nconst {\n BINARY_TYPES,\n EMPTY_BUFFER,\n GUID,\n kForOnEventAttribute,\n kListener,\n kStatusCode,\n kWebSocket,\n NOOP\n} = require('./constants');\nconst {\n EventTarget: { addEventListener, removeEventListener }\n} = require('./event-target');\nconst { format, parse } = require('./extension');\nconst { toBuffer } = require('./buffer-util');\n\nconst closeTimeout = 30 * 1000;\nconst kAborted = Symbol('kAborted');\nconst protocolVersions = [8, 13];\nconst readyStates = ['CONNECTING', 'OPEN', 'CLOSING', 'CLOSED'];\nconst subprotocolRegex = /^[!#$%&'*+\\-.0-9A-Z^_`|a-z~]+$/;\n\n/**\n * Class representing a WebSocket.\n *\n * @extends EventEmitter\n */\nclass WebSocket extends EventEmitter {\n /**\n * Create a new `WebSocket`.\n *\n * @param {(String|URL)} address The URL to which to connect\n * @param {(String|String[])} [protocols] The subprotocols\n * @param {Object} [options] Connection options\n */\n constructor(address, protocols, options) {\n super();\n\n this._binaryType = BINARY_TYPES[0];\n this._closeCode = 1006;\n this._closeFrameReceived = false;\n this._closeFrameSent = false;\n this._closeMessage = EMPTY_BUFFER;\n this._closeTimer = null;\n this._errorEmitted = false;\n this._extensions = {};\n this._paused = false;\n this._protocol = '';\n this._readyState = WebSocket.CONNECTING;\n this._receiver = null;\n this._sender = null;\n this._socket = null;\n\n if (address !== null) {\n this._bufferedAmount = 0;\n this._isServer = false;\n this._redirects = 0;\n\n if (protocols === undefined) {\n protocols = [];\n } else if (!Array.isArray(protocols)) {\n if (typeof protocols === 'object' && protocols !== null) {\n options = protocols;\n protocols = [];\n } else {\n protocols = [protocols];\n }\n }\n\n initAsClient(this, address, protocols, options);\n } else {\n this._autoPong = options.autoPong;\n this._isServer = true;\n }\n }\n\n /**\n * For historical reasons, the custom \"nodebuffer\" type is used by the default\n * instead of \"blob\".\n *\n * @type {String}\n */\n get binaryType() {\n return this._binaryType;\n }\n\n set binaryType(type) {\n if (!BINARY_TYPES.includes(type)) return;\n\n this._binaryType = type;\n\n //\n // Allow to change `binaryType` on the fly.\n //\n if (this._receiver) this._receiver._binaryType = type;\n }\n\n /**\n * @type {Number}\n */\n get bufferedAmount() {\n if (!this._socket) return this._bufferedAmount;\n\n return this._socket._writableState.length + this._sender._bufferedBytes;\n }\n\n /**\n * @type {String}\n */\n get extensions() {\n return Object.keys(this._extensions).join();\n }\n\n /**\n * @type {Boolean}\n */\n get isPaused() {\n return this._paused;\n }\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onclose() {\n return null;\n }\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onerror() {\n return null;\n }\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onopen() {\n return null;\n }\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onmessage() {\n return null;\n }\n\n /**\n * @type {String}\n */\n get protocol() {\n return this._protocol;\n }\n\n /**\n * @type {Number}\n */\n get readyState() {\n return this._readyState;\n }\n\n /**\n * @type {String}\n */\n get url() {\n return this._url;\n }\n\n /**\n * Set up the socket and the internal resources.\n *\n * @param {Duplex} socket The network socket between the server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Object} options Options object\n * @param {Boolean} [options.allowSynchronousEvents=false] Specifies whether\n * any of the `'message'`, `'ping'`, and `'pong'` events can be emitted\n * multiple times in the same tick\n * @param {Function} [options.generateMask] The function used to generate the\n * masking key\n * @param {Number} [options.maxPayload=0] The maximum allowed message size\n * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or\n * not to skip UTF-8 validation for text and close messages\n * @private\n */\n setSocket(socket, head, options) {\n const receiver = new Receiver({\n allowSynchronousEvents: options.allowSynchronousEvents,\n binaryType: this.binaryType,\n extensions: this._extensions,\n isServer: this._isServer,\n maxPayload: options.maxPayload,\n skipUTF8Validation: options.skipUTF8Validation\n });\n\n const sender = new Sender(socket, this._extensions, options.generateMask);\n\n this._receiver = receiver;\n this._sender = sender;\n this._socket = socket;\n\n receiver[kWebSocket] = this;\n sender[kWebSocket] = this;\n socket[kWebSocket] = this;\n\n receiver.on('conclude', receiverOnConclude);\n receiver.on('drain', receiverOnDrain);\n receiver.on('error', receiverOnError);\n receiver.on('message', receiverOnMessage);\n receiver.on('ping', receiverOnPing);\n receiver.on('pong', receiverOnPong);\n\n sender.onerror = senderOnError;\n\n //\n // These methods may not be available if `socket` is just a `Duplex`.\n //\n if (socket.setTimeout) socket.setTimeout(0);\n if (socket.setNoDelay) socket.setNoDelay();\n\n if (head.length > 0) socket.unshift(head);\n\n socket.on('close', socketOnClose);\n socket.on('data', socketOnData);\n socket.on('end', socketOnEnd);\n socket.on('error', socketOnError);\n\n this._readyState = WebSocket.OPEN;\n this.emit('open');\n }\n\n /**\n * Emit the `'close'` event.\n *\n * @private\n */\n emitClose() {\n if (!this._socket) {\n this._readyState = WebSocket.CLOSED;\n this.emit('close', this._closeCode, this._closeMessage);\n return;\n }\n\n if (this._extensions[PerMessageDeflate.extensionName]) {\n this._extensions[PerMessageDeflate.extensionName].cleanup();\n }\n\n this._receiver.removeAllListeners();\n this._readyState = WebSocket.CLOSED;\n this.emit('close', this._closeCode, this._closeMessage);\n }\n\n /**\n * Start a closing handshake.\n *\n * +----------+ +-----------+ +----------+\n * - - -|ws.close()|-->|close frame|-->|ws.close()|- - -\n * | +----------+ +-----------+ +----------+ |\n * +----------+ +-----------+ |\n * CLOSING |ws.close()|<--|close frame|<--+-----+ CLOSING\n * +----------+ +-----------+ |\n * | | | +---+ |\n * +------------------------+-->|fin| - - - -\n * | +---+ | +---+\n * - - - - -|fin|<---------------------+\n * +---+\n *\n * @param {Number} [code] Status code explaining why the connection is closing\n * @param {(String|Buffer)} [data] The reason why the connection is\n * closing\n * @public\n */\n close(code, data) {\n if (this.readyState === WebSocket.CLOSED) return;\n if (this.readyState === WebSocket.CONNECTING) {\n const msg = 'WebSocket was closed before the connection was established';\n abortHandshake(this, this._req, msg);\n return;\n }\n\n if (this.readyState === WebSocket.CLOSING) {\n if (\n this._closeFrameSent &&\n (this._closeFrameReceived || this._receiver._writableState.errorEmitted)\n ) {\n this._socket.end();\n }\n\n return;\n }\n\n this._readyState = WebSocket.CLOSING;\n this._sender.close(code, data, !this._isServer, (err) => {\n //\n // This error is handled by the `'error'` listener on the socket. We only\n // want to know if the close frame has been sent here.\n //\n if (err) return;\n\n this._closeFrameSent = true;\n\n if (\n this._closeFrameReceived ||\n this._receiver._writableState.errorEmitted\n ) {\n this._socket.end();\n }\n });\n\n setCloseTimer(this);\n }\n\n /**\n * Pause the socket.\n *\n * @public\n */\n pause() {\n if (\n this.readyState === WebSocket.CONNECTING ||\n this.readyState === WebSocket.CLOSED\n ) {\n return;\n }\n\n this._paused = true;\n this._socket.pause();\n }\n\n /**\n * Send a ping.\n *\n * @param {*} [data] The data to send\n * @param {Boolean} [mask] Indicates whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when the ping is sent\n * @public\n */\n ping(data, mask, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof data === 'function') {\n cb = data;\n data = mask = undefined;\n } else if (typeof mask === 'function') {\n cb = mask;\n mask = undefined;\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n if (mask === undefined) mask = !this._isServer;\n this._sender.ping(data || EMPTY_BUFFER, mask, cb);\n }\n\n /**\n * Send a pong.\n *\n * @param {*} [data] The data to send\n * @param {Boolean} [mask] Indicates whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when the pong is sent\n * @public\n */\n pong(data, mask, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof data === 'function') {\n cb = data;\n data = mask = undefined;\n } else if (typeof mask === 'function') {\n cb = mask;\n mask = undefined;\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n if (mask === undefined) mask = !this._isServer;\n this._sender.pong(data || EMPTY_BUFFER, mask, cb);\n }\n\n /**\n * Resume the socket.\n *\n * @public\n */\n resume() {\n if (\n this.readyState === WebSocket.CONNECTING ||\n this.readyState === WebSocket.CLOSED\n ) {\n return;\n }\n\n this._paused = false;\n if (!this._receiver._writableState.needDrain) this._socket.resume();\n }\n\n /**\n * Send a data message.\n *\n * @param {*} data The message to send\n * @param {Object} [options] Options object\n * @param {Boolean} [options.binary] Specifies whether `data` is binary or\n * text\n * @param {Boolean} [options.compress] Specifies whether or not to compress\n * `data`\n * @param {Boolean} [options.fin=true] Specifies whether the fragment is the\n * last one\n * @param {Boolean} [options.mask] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when data is written out\n * @public\n */\n send(data, options, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof options === 'function') {\n cb = options;\n options = {};\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n const opts = {\n binary: typeof data !== 'string',\n mask: !this._isServer,\n compress: true,\n fin: true,\n ...options\n };\n\n if (!this._extensions[PerMessageDeflate.extensionName]) {\n opts.compress = false;\n }\n\n this._sender.send(data || EMPTY_BUFFER, opts, cb);\n }\n\n /**\n * Forcibly close the connection.\n *\n * @public\n */\n terminate() {\n if (this.readyState === WebSocket.CLOSED) return;\n if (this.readyState === WebSocket.CONNECTING) {\n const msg = 'WebSocket was closed before the connection was established';\n abortHandshake(this, this._req, msg);\n return;\n }\n\n if (this._socket) {\n this._readyState = WebSocket.CLOSING;\n this._socket.destroy();\n }\n }\n}\n\n/**\n * @constant {Number} CONNECTING\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CONNECTING', {\n enumerable: true,\n value: readyStates.indexOf('CONNECTING')\n});\n\n/**\n * @constant {Number} CONNECTING\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CONNECTING', {\n enumerable: true,\n value: readyStates.indexOf('CONNECTING')\n});\n\n/**\n * @constant {Number} OPEN\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'OPEN', {\n enumerable: true,\n value: readyStates.indexOf('OPEN')\n});\n\n/**\n * @constant {Number} OPEN\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'OPEN', {\n enumerable: true,\n value: readyStates.indexOf('OPEN')\n});\n\n/**\n * @constant {Number} CLOSING\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CLOSING', {\n enumerable: true,\n value: readyStates.indexOf('CLOSING')\n});\n\n/**\n * @constant {Number} CLOSING\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CLOSING', {\n enumerable: true,\n value: readyStates.indexOf('CLOSING')\n});\n\n/**\n * @constant {Number} CLOSED\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CLOSED', {\n enumerable: true,\n value: readyStates.indexOf('CLOSED')\n});\n\n/**\n * @constant {Number} CLOSED\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CLOSED', {\n enumerable: true,\n value: readyStates.indexOf('CLOSED')\n});\n\n[\n 'binaryType',\n 'bufferedAmount',\n 'extensions',\n 'isPaused',\n 'protocol',\n 'readyState',\n 'url'\n].forEach((property) => {\n Object.defineProperty(WebSocket.prototype, property, { enumerable: true });\n});\n\n//\n// Add the `onopen`, `onerror`, `onclose`, and `onmessage` attributes.\n// See https://html.spec.whatwg.org/multipage/comms.html#the-websocket-interface\n//\n['open', 'error', 'close', 'message'].forEach((method) => {\n Object.defineProperty(WebSocket.prototype, `on${method}`, {\n enumerable: true,\n get() {\n for (const listener of this.listeners(method)) {\n if (listener[kForOnEventAttribute]) return listener[kListener];\n }\n\n return null;\n },\n set(handler) {\n for (const listener of this.listeners(method)) {\n if (listener[kForOnEventAttribute]) {\n this.removeListener(method, listener);\n break;\n }\n }\n\n if (typeof handler !== 'function') return;\n\n this.addEventListener(method, handler, {\n [kForOnEventAttribute]: true\n });\n }\n });\n});\n\nWebSocket.prototype.addEventListener = addEventListener;\nWebSocket.prototype.removeEventListener = removeEventListener;\n\nmodule.exports = WebSocket;\n\n/**\n * Initialize a WebSocket client.\n *\n * @param {WebSocket} websocket The client to initialize\n * @param {(String|URL)} address The URL to which to connect\n * @param {Array} protocols The subprotocols\n * @param {Object} [options] Connection options\n * @param {Boolean} [options.allowSynchronousEvents=true] Specifies whether any\n * of the `'message'`, `'ping'`, and `'pong'` events can be emitted multiple\n * times in the same tick\n * @param {Boolean} [options.autoPong=true] Specifies whether or not to\n * automatically send a pong in response to a ping\n * @param {Function} [options.finishRequest] A function which can be used to\n * customize the headers of each http request before it is sent\n * @param {Boolean} [options.followRedirects=false] Whether or not to follow\n * redirects\n * @param {Function} [options.generateMask] The function used to generate the\n * masking key\n * @param {Number} [options.handshakeTimeout] Timeout in milliseconds for the\n * handshake request\n * @param {Number} [options.maxPayload=104857600] The maximum allowed message\n * size\n * @param {Number} [options.maxRedirects=10] The maximum number of redirects\n * allowed\n * @param {String} [options.origin] Value of the `Origin` or\n * `Sec-WebSocket-Origin` header\n * @param {(Boolean|Object)} [options.perMessageDeflate=true] Enable/disable\n * permessage-deflate\n * @param {Number} [options.protocolVersion=13] Value of the\n * `Sec-WebSocket-Version` header\n * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or\n * not to skip UTF-8 validation for text and close messages\n * @private\n */\nfunction initAsClient(websocket, address, protocols, options) {\n const opts = {\n allowSynchronousEvents: true,\n autoPong: true,\n protocolVersion: protocolVersions[1],\n maxPayload: 100 * 1024 * 1024,\n skipUTF8Validation: false,\n perMessageDeflate: true,\n followRedirects: false,\n maxRedirects: 10,\n ...options,\n socketPath: undefined,\n hostname: undefined,\n protocol: undefined,\n timeout: undefined,\n method: 'GET',\n host: undefined,\n path: undefined,\n port: undefined\n };\n\n websocket._autoPong = opts.autoPong;\n\n if (!protocolVersions.includes(opts.protocolVersion)) {\n throw new RangeError(\n `Unsupported protocol version: ${opts.protocolVersion} ` +\n `(supported versions: ${protocolVersions.join(', ')})`\n );\n }\n\n let parsedUrl;\n\n if (address instanceof URL) {\n parsedUrl = address;\n } else {\n try {\n parsedUrl = new URL(address);\n } catch (e) {\n throw new SyntaxError(`Invalid URL: ${address}`);\n }\n }\n\n if (parsedUrl.protocol === 'http:') {\n parsedUrl.protocol = 'ws:';\n } else if (parsedUrl.protocol === 'https:') {\n parsedUrl.protocol = 'wss:';\n }\n\n websocket._url = parsedUrl.href;\n\n const isSecure = parsedUrl.protocol === 'wss:';\n const isIpcUrl = parsedUrl.protocol === 'ws+unix:';\n let invalidUrlMessage;\n\n if (parsedUrl.protocol !== 'ws:' && !isSecure && !isIpcUrl) {\n invalidUrlMessage =\n 'The URL\\'s protocol must be one of \"ws:\", \"wss:\", ' +\n '\"http:\", \"https\", or \"ws+unix:\"';\n } else if (isIpcUrl && !parsedUrl.pathname) {\n invalidUrlMessage = \"The URL's pathname is empty\";\n } else if (parsedUrl.hash) {\n invalidUrlMessage = 'The URL contains a fragment identifier';\n }\n\n if (invalidUrlMessage) {\n const err = new SyntaxError(invalidUrlMessage);\n\n if (websocket._redirects === 0) {\n throw err;\n } else {\n emitErrorAndClose(websocket, err);\n return;\n }\n }\n\n const defaultPort = isSecure ? 443 : 80;\n const key = randomBytes(16).toString('base64');\n const request = isSecure ? https.request : http.request;\n const protocolSet = new Set();\n let perMessageDeflate;\n\n opts.createConnection =\n opts.createConnection || (isSecure ? tlsConnect : netConnect);\n opts.defaultPort = opts.defaultPort || defaultPort;\n opts.port = parsedUrl.port || defaultPort;\n opts.host = parsedUrl.hostname.startsWith('[')\n ? parsedUrl.hostname.slice(1, -1)\n : parsedUrl.hostname;\n opts.headers = {\n ...opts.headers,\n 'Sec-WebSocket-Version': opts.protocolVersion,\n 'Sec-WebSocket-Key': key,\n Connection: 'Upgrade',\n Upgrade: 'websocket'\n };\n opts.path = parsedUrl.pathname + parsedUrl.search;\n opts.timeout = opts.handshakeTimeout;\n\n if (opts.perMessageDeflate) {\n perMessageDeflate = new PerMessageDeflate(\n opts.perMessageDeflate !== true ? opts.perMessageDeflate : {},\n false,\n opts.maxPayload\n );\n opts.headers['Sec-WebSocket-Extensions'] = format({\n [PerMessageDeflate.extensionName]: perMessageDeflate.offer()\n });\n }\n if (protocols.length) {\n for (const protocol of protocols) {\n if (\n typeof protocol !== 'string' ||\n !subprotocolRegex.test(protocol) ||\n protocolSet.has(protocol)\n ) {\n throw new SyntaxError(\n 'An invalid or duplicated subprotocol was specified'\n );\n }\n\n protocolSet.add(protocol);\n }\n\n opts.headers['Sec-WebSocket-Protocol'] = protocols.join(',');\n }\n if (opts.origin) {\n if (opts.protocolVersion < 13) {\n opts.headers['Sec-WebSocket-Origin'] = opts.origin;\n } else {\n opts.headers.Origin = opts.origin;\n }\n }\n if (parsedUrl.username || parsedUrl.password) {\n opts.auth = `${parsedUrl.username}:${parsedUrl.password}`;\n }\n\n if (isIpcUrl) {\n const parts = opts.path.split(':');\n\n opts.socketPath = parts[0];\n opts.path = parts[1];\n }\n\n let req;\n\n if (opts.followRedirects) {\n if (websocket._redirects === 0) {\n websocket._originalIpc = isIpcUrl;\n websocket._originalSecure = isSecure;\n websocket._originalHostOrSocketPath = isIpcUrl\n ? opts.socketPath\n : parsedUrl.host;\n\n const headers = options && options.headers;\n\n //\n // Shallow copy the user provided options so that headers can be changed\n // without mutating the original object.\n //\n options = { ...options, headers: {} };\n\n if (headers) {\n for (const [key, value] of Object.entries(headers)) {\n options.headers[key.toLowerCase()] = value;\n }\n }\n } else if (websocket.listenerCount('redirect') === 0) {\n const isSameHost = isIpcUrl\n ? websocket._originalIpc\n ? opts.socketPath === websocket._originalHostOrSocketPath\n : false\n : websocket._originalIpc\n ? false\n : parsedUrl.host === websocket._originalHostOrSocketPath;\n\n if (!isSameHost || (websocket._originalSecure && !isSecure)) {\n //\n // Match curl 7.77.0 behavior and drop the following headers. These\n // headers are also dropped when following a redirect to a subdomain.\n //\n delete opts.headers.authorization;\n delete opts.headers.cookie;\n\n if (!isSameHost) delete opts.headers.host;\n\n opts.auth = undefined;\n }\n }\n\n //\n // Match curl 7.77.0 behavior and make the first `Authorization` header win.\n // If the `Authorization` header is set, then there is nothing to do as it\n // will take precedence.\n //\n if (opts.auth && !options.headers.authorization) {\n options.headers.authorization =\n 'Basic ' + Buffer.from(opts.auth).toString('base64');\n }\n\n req = websocket._req = request(opts);\n\n if (websocket._redirects) {\n //\n // Unlike what is done for the `'upgrade'` event, no early exit is\n // triggered here if the user calls `websocket.close()` or\n // `websocket.terminate()` from a listener of the `'redirect'` event. This\n // is because the user can also call `request.destroy()` with an error\n // before calling `websocket.close()` or `websocket.terminate()` and this\n // would result in an error being emitted on the `request` object with no\n // `'error'` event listeners attached.\n //\n websocket.emit('redirect', websocket.url, req);\n }\n } else {\n req = websocket._req = request(opts);\n }\n\n if (opts.timeout) {\n req.on('timeout', () => {\n abortHandshake(websocket, req, 'Opening handshake has timed out');\n });\n }\n\n req.on('error', (err) => {\n if (req === null || req[kAborted]) return;\n\n req = websocket._req = null;\n emitErrorAndClose(websocket, err);\n });\n\n req.on('response', (res) => {\n const location = res.headers.location;\n const statusCode = res.statusCode;\n\n if (\n location &&\n opts.followRedirects &&\n statusCode >= 300 &&\n statusCode < 400\n ) {\n if (++websocket._redirects > opts.maxRedirects) {\n abortHandshake(websocket, req, 'Maximum redirects exceeded');\n return;\n }\n\n req.abort();\n\n let addr;\n\n try {\n addr = new URL(location, address);\n } catch (e) {\n const err = new SyntaxError(`Invalid URL: ${location}`);\n emitErrorAndClose(websocket, err);\n return;\n }\n\n initAsClient(websocket, addr, protocols, options);\n } else if (!websocket.emit('unexpected-response', req, res)) {\n abortHandshake(\n websocket,\n req,\n `Unexpected server response: ${res.statusCode}`\n );\n }\n });\n\n req.on('upgrade', (res, socket, head) => {\n websocket.emit('upgrade', res);\n\n //\n // The user may have closed the connection from a listener of the\n // `'upgrade'` event.\n //\n if (websocket.readyState !== WebSocket.CONNECTING) return;\n\n req = websocket._req = null;\n\n const upgrade = res.headers.upgrade;\n\n if (upgrade === undefined || upgrade.toLowerCase() !== 'websocket') {\n abortHandshake(websocket, socket, 'Invalid Upgrade header');\n return;\n }\n\n const digest = createHash('sha1')\n .update(key + GUID)\n .digest('base64');\n\n if (res.headers['sec-websocket-accept'] !== digest) {\n abortHandshake(websocket, socket, 'Invalid Sec-WebSocket-Accept header');\n return;\n }\n\n const serverProt = res.headers['sec-websocket-protocol'];\n let protError;\n\n if (serverProt !== undefined) {\n if (!protocolSet.size) {\n protError = 'Server sent a subprotocol but none was requested';\n } else if (!protocolSet.has(serverProt)) {\n protError = 'Server sent an invalid subprotocol';\n }\n } else if (protocolSet.size) {\n protError = 'Server sent no subprotocol';\n }\n\n if (protError) {\n abortHandshake(websocket, socket, protError);\n return;\n }\n\n if (serverProt) websocket._protocol = serverProt;\n\n const secWebSocketExtensions = res.headers['sec-websocket-extensions'];\n\n if (secWebSocketExtensions !== undefined) {\n if (!perMessageDeflate) {\n const message =\n 'Server sent a Sec-WebSocket-Extensions header but no extension ' +\n 'was requested';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n let extensions;\n\n try {\n extensions = parse(secWebSocketExtensions);\n } catch (err) {\n const message = 'Invalid Sec-WebSocket-Extensions header';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n const extensionNames = Object.keys(extensions);\n\n if (\n extensionNames.length !== 1 ||\n extensionNames[0] !== PerMessageDeflate.extensionName\n ) {\n const message = 'Server indicated an extension that was not requested';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n try {\n perMessageDeflate.accept(extensions[PerMessageDeflate.extensionName]);\n } catch (err) {\n const message = 'Invalid Sec-WebSocket-Extensions header';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n websocket._extensions[PerMessageDeflate.extensionName] =\n perMessageDeflate;\n }\n\n websocket.setSocket(socket, head, {\n allowSynchronousEvents: opts.allowSynchronousEvents,\n generateMask: opts.generateMask,\n maxPayload: opts.maxPayload,\n skipUTF8Validation: opts.skipUTF8Validation\n });\n });\n\n if (opts.finishRequest) {\n opts.finishRequest(req, websocket);\n } else {\n req.end();\n }\n}\n\n/**\n * Emit the `'error'` and `'close'` events.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {Error} The error to emit\n * @private\n */\nfunction emitErrorAndClose(websocket, err) {\n websocket._readyState = WebSocket.CLOSING;\n //\n // The following assignment is practically useless and is done only for\n // consistency.\n //\n websocket._errorEmitted = true;\n websocket.emit('error', err);\n websocket.emitClose();\n}\n\n/**\n * Create a `net.Socket` and initiate a connection.\n *\n * @param {Object} options Connection options\n * @return {net.Socket} The newly created socket used to start the connection\n * @private\n */\nfunction netConnect(options) {\n options.path = options.socketPath;\n return net.connect(options);\n}\n\n/**\n * Create a `tls.TLSSocket` and initiate a connection.\n *\n * @param {Object} options Connection options\n * @return {tls.TLSSocket} The newly created socket used to start the connection\n * @private\n */\nfunction tlsConnect(options) {\n options.path = undefined;\n\n if (!options.servername && options.servername !== '') {\n options.servername = net.isIP(options.host) ? '' : options.host;\n }\n\n return tls.connect(options);\n}\n\n/**\n * Abort the handshake and emit an error.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {(http.ClientRequest|net.Socket|tls.Socket)} stream The request to\n * abort or the socket to destroy\n * @param {String} message The error message\n * @private\n */\nfunction abortHandshake(websocket, stream, message) {\n websocket._readyState = WebSocket.CLOSING;\n\n const err = new Error(message);\n Error.captureStackTrace(err, abortHandshake);\n\n if (stream.setHeader) {\n stream[kAborted] = true;\n stream.abort();\n\n if (stream.socket && !stream.socket.destroyed) {\n //\n // On Node.js >= 14.3.0 `request.abort()` does not destroy the socket if\n // called after the request completed. See\n // https://github.com/websockets/ws/issues/1869.\n //\n stream.socket.destroy();\n }\n\n process.nextTick(emitErrorAndClose, websocket, err);\n } else {\n stream.destroy(err);\n stream.once('error', websocket.emit.bind(websocket, 'error'));\n stream.once('close', websocket.emitClose.bind(websocket));\n }\n}\n\n/**\n * Handle cases where the `ping()`, `pong()`, or `send()` methods are called\n * when the `readyState` attribute is `CLOSING` or `CLOSED`.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {*} [data] The data to send\n * @param {Function} [cb] Callback\n * @private\n */\nfunction sendAfterClose(websocket, data, cb) {\n if (data) {\n const length = isBlob(data) ? data.size : toBuffer(data).length;\n\n //\n // The `_bufferedAmount` property is used only when the peer is a client and\n // the opening handshake fails. Under these circumstances, in fact, the\n // `setSocket()` method is not called, so the `_socket` and `_sender`\n // properties are set to `null`.\n //\n if (websocket._socket) websocket._sender._bufferedBytes += length;\n else websocket._bufferedAmount += length;\n }\n\n if (cb) {\n const err = new Error(\n `WebSocket is not open: readyState ${websocket.readyState} ` +\n `(${readyStates[websocket.readyState]})`\n );\n process.nextTick(cb, err);\n }\n}\n\n/**\n * The listener of the `Receiver` `'conclude'` event.\n *\n * @param {Number} code The status code\n * @param {Buffer} reason The reason for closing\n * @private\n */\nfunction receiverOnConclude(code, reason) {\n const websocket = this[kWebSocket];\n\n websocket._closeFrameReceived = true;\n websocket._closeMessage = reason;\n websocket._closeCode = code;\n\n if (websocket._socket[kWebSocket] === undefined) return;\n\n websocket._socket.removeListener('data', socketOnData);\n process.nextTick(resume, websocket._socket);\n\n if (code === 1005) websocket.close();\n else websocket.close(code, reason);\n}\n\n/**\n * The listener of the `Receiver` `'drain'` event.\n *\n * @private\n */\nfunction receiverOnDrain() {\n const websocket = this[kWebSocket];\n\n if (!websocket.isPaused) websocket._socket.resume();\n}\n\n/**\n * The listener of the `Receiver` `'error'` event.\n *\n * @param {(RangeError|Error)} err The emitted error\n * @private\n */\nfunction receiverOnError(err) {\n const websocket = this[kWebSocket];\n\n if (websocket._socket[kWebSocket] !== undefined) {\n websocket._socket.removeListener('data', socketOnData);\n\n //\n // On Node.js < 14.0.0 the `'error'` event is emitted synchronously. See\n // https://github.com/websockets/ws/issues/1940.\n //\n process.nextTick(resume, websocket._socket);\n\n websocket.close(err[kStatusCode]);\n }\n\n if (!websocket._errorEmitted) {\n websocket._errorEmitted = true;\n websocket.emit('error', err);\n }\n}\n\n/**\n * The listener of the `Receiver` `'finish'` event.\n *\n * @private\n */\nfunction receiverOnFinish() {\n this[kWebSocket].emitClose();\n}\n\n/**\n * The listener of the `Receiver` `'message'` event.\n *\n * @param {Buffer|ArrayBuffer|Buffer[])} data The message\n * @param {Boolean} isBinary Specifies whether the message is binary or not\n * @private\n */\nfunction receiverOnMessage(data, isBinary) {\n this[kWebSocket].emit('message', data, isBinary);\n}\n\n/**\n * The listener of the `Receiver` `'ping'` event.\n *\n * @param {Buffer} data The data included in the ping frame\n * @private\n */\nfunction receiverOnPing(data) {\n const websocket = this[kWebSocket];\n\n if (websocket._autoPong) websocket.pong(data, !this._isServer, NOOP);\n websocket.emit('ping', data);\n}\n\n/**\n * The listener of the `Receiver` `'pong'` event.\n *\n * @param {Buffer} data The data included in the pong frame\n * @private\n */\nfunction receiverOnPong(data) {\n this[kWebSocket].emit('pong', data);\n}\n\n/**\n * Resume a readable stream\n *\n * @param {Readable} stream The readable stream\n * @private\n */\nfunction resume(stream) {\n stream.resume();\n}\n\n/**\n * The `Sender` error event handler.\n *\n * @param {Error} The error\n * @private\n */\nfunction senderOnError(err) {\n const websocket = this[kWebSocket];\n\n if (websocket.readyState === WebSocket.CLOSED) return;\n if (websocket.readyState === WebSocket.OPEN) {\n websocket._readyState = WebSocket.CLOSING;\n setCloseTimer(websocket);\n }\n\n //\n // `socket.end()` is used instead of `socket.destroy()` to allow the other\n // peer to finish sending queued data. There is no need to set a timer here\n // because `CLOSING` means that it is already set or not needed.\n //\n this._socket.end();\n\n if (!websocket._errorEmitted) {\n websocket._errorEmitted = true;\n websocket.emit('error', err);\n }\n}\n\n/**\n * Set a timer to destroy the underlying raw socket of a WebSocket.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @private\n */\nfunction setCloseTimer(websocket) {\n websocket._closeTimer = setTimeout(\n websocket._socket.destroy.bind(websocket._socket),\n closeTimeout\n );\n}\n\n/**\n * The listener of the socket `'close'` event.\n *\n * @private\n */\nfunction socketOnClose() {\n const websocket = this[kWebSocket];\n\n this.removeListener('close', socketOnClose);\n this.removeListener('data', socketOnData);\n this.removeListener('end', socketOnEnd);\n\n websocket._readyState = WebSocket.CLOSING;\n\n let chunk;\n\n //\n // The close frame might not have been received or the `'end'` event emitted,\n // for example, if the socket was destroyed due to an error. Ensure that the\n // `receiver` stream is closed after writing any remaining buffered data to\n // it. If the readable side of the socket is in flowing mode then there is no\n // buffered data as everything has been already written and `readable.read()`\n // will return `null`. If instead, the socket is paused, any possible buffered\n // data will be read as a single chunk.\n //\n if (\n !this._readableState.endEmitted &&\n !websocket._closeFrameReceived &&\n !websocket._receiver._writableState.errorEmitted &&\n (chunk = websocket._socket.read()) !== null\n ) {\n websocket._receiver.write(chunk);\n }\n\n websocket._receiver.end();\n\n this[kWebSocket] = undefined;\n\n clearTimeout(websocket._closeTimer);\n\n if (\n websocket._receiver._writableState.finished ||\n websocket._receiver._writableState.errorEmitted\n ) {\n websocket.emitClose();\n } else {\n websocket._receiver.on('error', receiverOnFinish);\n websocket._receiver.on('finish', receiverOnFinish);\n }\n}\n\n/**\n * The listener of the socket `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction socketOnData(chunk) {\n if (!this[kWebSocket]._receiver.write(chunk)) {\n this.pause();\n }\n}\n\n/**\n * The listener of the socket `'end'` event.\n *\n * @private\n */\nfunction socketOnEnd() {\n const websocket = this[kWebSocket];\n\n websocket._readyState = WebSocket.CLOSING;\n websocket._receiver.end();\n this.end();\n}\n\n/**\n * The listener of the socket `'error'` event.\n *\n * @private\n */\nfunction socketOnError() {\n const websocket = this[kWebSocket];\n\n this.removeListener('error', socketOnError);\n this.on('error', NOOP);\n\n if (websocket) {\n websocket._readyState = WebSocket.CLOSING;\n this.destroy();\n }\n}\n","'use strict';\n\nconst { Duplex } = require('stream');\n\n/**\n * Emits the `'close'` event on a stream.\n *\n * @param {Duplex} stream The stream.\n * @private\n */\nfunction emitClose(stream) {\n stream.emit('close');\n}\n\n/**\n * The listener of the `'end'` event.\n *\n * @private\n */\nfunction duplexOnEnd() {\n if (!this.destroyed && this._writableState.finished) {\n this.destroy();\n }\n}\n\n/**\n * The listener of the `'error'` event.\n *\n * @param {Error} err The error\n * @private\n */\nfunction duplexOnError(err) {\n this.removeListener('error', duplexOnError);\n this.destroy();\n if (this.listenerCount('error') === 0) {\n // Do not suppress the throwing behavior.\n this.emit('error', err);\n }\n}\n\n/**\n * Wraps a `WebSocket` in a duplex stream.\n *\n * @param {WebSocket} ws The `WebSocket` to wrap\n * @param {Object} [options] The options for the `Duplex` constructor\n * @return {Duplex} The duplex stream\n * @public\n */\nfunction createWebSocketStream(ws, options) {\n let terminateOnDestroy = true;\n\n const duplex = new Duplex({\n ...options,\n autoDestroy: false,\n emitClose: false,\n objectMode: false,\n writableObjectMode: false\n });\n\n ws.on('message', function message(msg, isBinary) {\n const data =\n !isBinary && duplex._readableState.objectMode ? msg.toString() : msg;\n\n if (!duplex.push(data)) ws.pause();\n });\n\n ws.once('error', function error(err) {\n if (duplex.destroyed) return;\n\n // Prevent `ws.terminate()` from being called by `duplex._destroy()`.\n //\n // - If the `'error'` event is emitted before the `'open'` event, then\n // `ws.terminate()` is a noop as no socket is assigned.\n // - Otherwise, the error is re-emitted by the listener of the `'error'`\n // event of the `Receiver` object. The listener already closes the\n // connection by calling `ws.close()`. This allows a close frame to be\n // sent to the other peer. If `ws.terminate()` is called right after this,\n // then the close frame might not be sent.\n terminateOnDestroy = false;\n duplex.destroy(err);\n });\n\n ws.once('close', function close() {\n if (duplex.destroyed) return;\n\n duplex.push(null);\n });\n\n duplex._destroy = function (err, callback) {\n if (ws.readyState === ws.CLOSED) {\n callback(err);\n process.nextTick(emitClose, duplex);\n return;\n }\n\n let called = false;\n\n ws.once('error', function error(err) {\n called = true;\n callback(err);\n });\n\n ws.once('close', function close() {\n if (!called) callback(err);\n process.nextTick(emitClose, duplex);\n });\n\n if (terminateOnDestroy) ws.terminate();\n };\n\n duplex._final = function (callback) {\n if (ws.readyState === ws.CONNECTING) {\n ws.once('open', function open() {\n duplex._final(callback);\n });\n return;\n }\n\n // If the value of the `_socket` property is `null` it means that `ws` is a\n // client websocket and the handshake failed. In fact, when this happens, a\n // socket is never assigned to the websocket. Wait for the `'error'` event\n // that will be emitted by the websocket.\n if (ws._socket === null) return;\n\n if (ws._socket._writableState.finished) {\n callback();\n if (duplex._readableState.endEmitted) duplex.destroy();\n } else {\n ws._socket.once('finish', function finish() {\n // `duplex` is not destroyed here because the `'end'` event will be\n // emitted on `duplex` after this `'finish'` event. The EOF signaling\n // `null` chunk is, in fact, pushed when the websocket emits `'close'`.\n callback();\n });\n ws.close();\n }\n };\n\n duplex._read = function () {\n if (ws.isPaused) ws.resume();\n };\n\n duplex._write = function (chunk, encoding, callback) {\n if (ws.readyState === ws.CONNECTING) {\n ws.once('open', function open() {\n duplex._write(chunk, encoding, callback);\n });\n return;\n }\n\n ws.send(chunk, callback);\n };\n\n duplex.on('end', duplexOnEnd);\n duplex.on('error', duplexOnError);\n return duplex;\n}\n\nmodule.exports = createWebSocketStream;\n","'use strict';\n\nconst { tokenChars } = require('./validation');\n\n/**\n * Parses the `Sec-WebSocket-Protocol` header into a set of subprotocol names.\n *\n * @param {String} header The field value of the header\n * @return {Set} The subprotocol names\n * @public\n */\nfunction parse(header) {\n const protocols = new Set();\n let start = -1;\n let end = -1;\n let i = 0;\n\n for (i; i < header.length; i++) {\n const code = header.charCodeAt(i);\n\n if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (\n i !== 0 &&\n (code === 0x20 /* ' ' */ || code === 0x09) /* '\\t' */\n ) {\n if (end === -1 && start !== -1) end = i;\n } else if (code === 0x2c /* ',' */) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n\n const protocol = header.slice(start, end);\n\n if (protocols.has(protocol)) {\n throw new SyntaxError(`The \"${protocol}\" subprotocol is duplicated`);\n }\n\n protocols.add(protocol);\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n }\n\n if (start === -1 || end !== -1) {\n throw new SyntaxError('Unexpected end of input');\n }\n\n const protocol = header.slice(start, i);\n\n if (protocols.has(protocol)) {\n throw new SyntaxError(`The \"${protocol}\" subprotocol is duplicated`);\n }\n\n protocols.add(protocol);\n return protocols;\n}\n\nmodule.exports = { parse };\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^Duplex$\", \"caughtErrors\": \"none\" }] */\n\n'use strict';\n\nconst EventEmitter = require('events');\nconst http = require('http');\nconst { Duplex } = require('stream');\nconst { createHash } = require('crypto');\n\nconst extension = require('./extension');\nconst PerMessageDeflate = require('./permessage-deflate');\nconst subprotocol = require('./subprotocol');\nconst WebSocket = require('./websocket');\nconst { GUID, kWebSocket } = require('./constants');\n\nconst keyRegex = /^[+/0-9A-Za-z]{22}==$/;\n\nconst RUNNING = 0;\nconst CLOSING = 1;\nconst CLOSED = 2;\n\n/**\n * Class representing a WebSocket server.\n *\n * @extends EventEmitter\n */\nclass WebSocketServer extends EventEmitter {\n /**\n * Create a `WebSocketServer` instance.\n *\n * @param {Object} options Configuration options\n * @param {Boolean} [options.allowSynchronousEvents=true] Specifies whether\n * any of the `'message'`, `'ping'`, and `'pong'` events can be emitted\n * multiple times in the same tick\n * @param {Boolean} [options.autoPong=true] Specifies whether or not to\n * automatically send a pong in response to a ping\n * @param {Number} [options.backlog=511] The maximum length of the queue of\n * pending connections\n * @param {Boolean} [options.clientTracking=true] Specifies whether or not to\n * track clients\n * @param {Function} [options.handleProtocols] A hook to handle protocols\n * @param {String} [options.host] The hostname where to bind the server\n * @param {Number} [options.maxPayload=104857600] The maximum allowed message\n * size\n * @param {Boolean} [options.noServer=false] Enable no server mode\n * @param {String} [options.path] Accept only connections matching this path\n * @param {(Boolean|Object)} [options.perMessageDeflate=false] Enable/disable\n * permessage-deflate\n * @param {Number} [options.port] The port where to bind the server\n * @param {(http.Server|https.Server)} [options.server] A pre-created HTTP/S\n * server to use\n * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or\n * not to skip UTF-8 validation for text and close messages\n * @param {Function} [options.verifyClient] A hook to reject connections\n * @param {Function} [options.WebSocket=WebSocket] Specifies the `WebSocket`\n * class to use. It must be the `WebSocket` class or class that extends it\n * @param {Function} [callback] A listener for the `listening` event\n */\n constructor(options, callback) {\n super();\n\n options = {\n allowSynchronousEvents: true,\n autoPong: true,\n maxPayload: 100 * 1024 * 1024,\n skipUTF8Validation: false,\n perMessageDeflate: false,\n handleProtocols: null,\n clientTracking: true,\n verifyClient: null,\n noServer: false,\n backlog: null, // use default (511 as implemented in net.js)\n server: null,\n host: null,\n path: null,\n port: null,\n WebSocket,\n ...options\n };\n\n if (\n (options.port == null && !options.server && !options.noServer) ||\n (options.port != null && (options.server || options.noServer)) ||\n (options.server && options.noServer)\n ) {\n throw new TypeError(\n 'One and only one of the \"port\", \"server\", or \"noServer\" options ' +\n 'must be specified'\n );\n }\n\n if (options.port != null) {\n this._server = http.createServer((req, res) => {\n const body = http.STATUS_CODES[426];\n\n res.writeHead(426, {\n 'Content-Length': body.length,\n 'Content-Type': 'text/plain'\n });\n res.end(body);\n });\n this._server.listen(\n options.port,\n options.host,\n options.backlog,\n callback\n );\n } else if (options.server) {\n this._server = options.server;\n }\n\n if (this._server) {\n const emitConnection = this.emit.bind(this, 'connection');\n\n this._removeListeners = addListeners(this._server, {\n listening: this.emit.bind(this, 'listening'),\n error: this.emit.bind(this, 'error'),\n upgrade: (req, socket, head) => {\n this.handleUpgrade(req, socket, head, emitConnection);\n }\n });\n }\n\n if (options.perMessageDeflate === true) options.perMessageDeflate = {};\n if (options.clientTracking) {\n this.clients = new Set();\n this._shouldEmitClose = false;\n }\n\n this.options = options;\n this._state = RUNNING;\n }\n\n /**\n * Returns the bound address, the address family name, and port of the server\n * as reported by the operating system if listening on an IP socket.\n * If the server is listening on a pipe or UNIX domain socket, the name is\n * returned as a string.\n *\n * @return {(Object|String|null)} The address of the server\n * @public\n */\n address() {\n if (this.options.noServer) {\n throw new Error('The server is operating in \"noServer\" mode');\n }\n\n if (!this._server) return null;\n return this._server.address();\n }\n\n /**\n * Stop the server from accepting new connections and emit the `'close'` event\n * when all existing connections are closed.\n *\n * @param {Function} [cb] A one-time listener for the `'close'` event\n * @public\n */\n close(cb) {\n if (this._state === CLOSED) {\n if (cb) {\n this.once('close', () => {\n cb(new Error('The server is not running'));\n });\n }\n\n process.nextTick(emitClose, this);\n return;\n }\n\n if (cb) this.once('close', cb);\n\n if (this._state === CLOSING) return;\n this._state = CLOSING;\n\n if (this.options.noServer || this.options.server) {\n if (this._server) {\n this._removeListeners();\n this._removeListeners = this._server = null;\n }\n\n if (this.clients) {\n if (!this.clients.size) {\n process.nextTick(emitClose, this);\n } else {\n this._shouldEmitClose = true;\n }\n } else {\n process.nextTick(emitClose, this);\n }\n } else {\n const server = this._server;\n\n this._removeListeners();\n this._removeListeners = this._server = null;\n\n //\n // The HTTP/S server was created internally. Close it, and rely on its\n // `'close'` event.\n //\n server.close(() => {\n emitClose(this);\n });\n }\n }\n\n /**\n * See if a given request should be handled by this server instance.\n *\n * @param {http.IncomingMessage} req Request object to inspect\n * @return {Boolean} `true` if the request is valid, else `false`\n * @public\n */\n shouldHandle(req) {\n if (this.options.path) {\n const index = req.url.indexOf('?');\n const pathname = index !== -1 ? req.url.slice(0, index) : req.url;\n\n if (pathname !== this.options.path) return false;\n }\n\n return true;\n }\n\n /**\n * Handle a HTTP Upgrade request.\n *\n * @param {http.IncomingMessage} req The request object\n * @param {Duplex} socket The network socket between the server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Function} cb Callback\n * @public\n */\n handleUpgrade(req, socket, head, cb) {\n socket.on('error', socketOnError);\n\n const key = req.headers['sec-websocket-key'];\n const upgrade = req.headers.upgrade;\n const version = +req.headers['sec-websocket-version'];\n\n if (req.method !== 'GET') {\n const message = 'Invalid HTTP method';\n abortHandshakeOrEmitwsClientError(this, req, socket, 405, message);\n return;\n }\n\n if (upgrade === undefined || upgrade.toLowerCase() !== 'websocket') {\n const message = 'Invalid Upgrade header';\n abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);\n return;\n }\n\n if (key === undefined || !keyRegex.test(key)) {\n const message = 'Missing or invalid Sec-WebSocket-Key header';\n abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);\n return;\n }\n\n if (version !== 8 && version !== 13) {\n const message = 'Missing or invalid Sec-WebSocket-Version header';\n abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);\n return;\n }\n\n if (!this.shouldHandle(req)) {\n abortHandshake(socket, 400);\n return;\n }\n\n const secWebSocketProtocol = req.headers['sec-websocket-protocol'];\n let protocols = new Set();\n\n if (secWebSocketProtocol !== undefined) {\n try {\n protocols = subprotocol.parse(secWebSocketProtocol);\n } catch (err) {\n const message = 'Invalid Sec-WebSocket-Protocol header';\n abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);\n return;\n }\n }\n\n const secWebSocketExtensions = req.headers['sec-websocket-extensions'];\n const extensions = {};\n\n if (\n this.options.perMessageDeflate &&\n secWebSocketExtensions !== undefined\n ) {\n const perMessageDeflate = new PerMessageDeflate(\n this.options.perMessageDeflate,\n true,\n this.options.maxPayload\n );\n\n try {\n const offers = extension.parse(secWebSocketExtensions);\n\n if (offers[PerMessageDeflate.extensionName]) {\n perMessageDeflate.accept(offers[PerMessageDeflate.extensionName]);\n extensions[PerMessageDeflate.extensionName] = perMessageDeflate;\n }\n } catch (err) {\n const message =\n 'Invalid or unacceptable Sec-WebSocket-Extensions header';\n abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);\n return;\n }\n }\n\n //\n // Optionally call external client verification handler.\n //\n if (this.options.verifyClient) {\n const info = {\n origin:\n req.headers[`${version === 8 ? 'sec-websocket-origin' : 'origin'}`],\n secure: !!(req.socket.authorized || req.socket.encrypted),\n req\n };\n\n if (this.options.verifyClient.length === 2) {\n this.options.verifyClient(info, (verified, code, message, headers) => {\n if (!verified) {\n return abortHandshake(socket, code || 401, message, headers);\n }\n\n this.completeUpgrade(\n extensions,\n key,\n protocols,\n req,\n socket,\n head,\n cb\n );\n });\n return;\n }\n\n if (!this.options.verifyClient(info)) return abortHandshake(socket, 401);\n }\n\n this.completeUpgrade(extensions, key, protocols, req, socket, head, cb);\n }\n\n /**\n * Upgrade the connection to WebSocket.\n *\n * @param {Object} extensions The accepted extensions\n * @param {String} key The value of the `Sec-WebSocket-Key` header\n * @param {Set} protocols The subprotocols\n * @param {http.IncomingMessage} req The request object\n * @param {Duplex} socket The network socket between the server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Function} cb Callback\n * @throws {Error} If called more than once with the same socket\n * @private\n */\n completeUpgrade(extensions, key, protocols, req, socket, head, cb) {\n //\n // Destroy the socket if the client has already sent a FIN packet.\n //\n if (!socket.readable || !socket.writable) return socket.destroy();\n\n if (socket[kWebSocket]) {\n throw new Error(\n 'server.handleUpgrade() was called more than once with the same ' +\n 'socket, possibly due to a misconfiguration'\n );\n }\n\n if (this._state > RUNNING) return abortHandshake(socket, 503);\n\n const digest = createHash('sha1')\n .update(key + GUID)\n .digest('base64');\n\n const headers = [\n 'HTTP/1.1 101 Switching Protocols',\n 'Upgrade: websocket',\n 'Connection: Upgrade',\n `Sec-WebSocket-Accept: ${digest}`\n ];\n\n const ws = new this.options.WebSocket(null, undefined, this.options);\n\n if (protocols.size) {\n //\n // Optionally call external protocol selection handler.\n //\n const protocol = this.options.handleProtocols\n ? this.options.handleProtocols(protocols, req)\n : protocols.values().next().value;\n\n if (protocol) {\n headers.push(`Sec-WebSocket-Protocol: ${protocol}`);\n ws._protocol = protocol;\n }\n }\n\n if (extensions[PerMessageDeflate.extensionName]) {\n const params = extensions[PerMessageDeflate.extensionName].params;\n const value = extension.format({\n [PerMessageDeflate.extensionName]: [params]\n });\n headers.push(`Sec-WebSocket-Extensions: ${value}`);\n ws._extensions = extensions;\n }\n\n //\n // Allow external modification/inspection of handshake headers.\n //\n this.emit('headers', headers, req);\n\n socket.write(headers.concat('\\r\\n').join('\\r\\n'));\n socket.removeListener('error', socketOnError);\n\n ws.setSocket(socket, head, {\n allowSynchronousEvents: this.options.allowSynchronousEvents,\n maxPayload: this.options.maxPayload,\n skipUTF8Validation: this.options.skipUTF8Validation\n });\n\n if (this.clients) {\n this.clients.add(ws);\n ws.on('close', () => {\n this.clients.delete(ws);\n\n if (this._shouldEmitClose && !this.clients.size) {\n process.nextTick(emitClose, this);\n }\n });\n }\n\n cb(ws, req);\n }\n}\n\nmodule.exports = WebSocketServer;\n\n/**\n * Add event listeners on an `EventEmitter` using a map of <event, listener>\n * pairs.\n *\n * @param {EventEmitter} server The event emitter\n * @param {Object.<String, Function>} map The listeners to add\n * @return {Function} A function that will remove the added listeners when\n * called\n * @private\n */\nfunction addListeners(server, map) {\n for (const event of Object.keys(map)) server.on(event, map[event]);\n\n return function removeListeners() {\n for (const event of Object.keys(map)) {\n server.removeListener(event, map[event]);\n }\n };\n}\n\n/**\n * Emit a `'close'` event on an `EventEmitter`.\n *\n * @param {EventEmitter} server The event emitter\n * @private\n */\nfunction emitClose(server) {\n server._state = CLOSED;\n server.emit('close');\n}\n\n/**\n * Handle socket errors.\n *\n * @private\n */\nfunction socketOnError() {\n this.destroy();\n}\n\n/**\n * Close the connection when preconditions are not fulfilled.\n *\n * @param {Duplex} socket The socket of the upgrade request\n * @param {Number} code The HTTP response status code\n * @param {String} [message] The HTTP response body\n * @param {Object} [headers] Additional HTTP response headers\n * @private\n */\nfunction abortHandshake(socket, code, message, headers) {\n //\n // The socket is writable unless the user destroyed or ended it before calling\n // `server.handleUpgrade()` or in the `verifyClient` function, which is a user\n // error. Handling this does not make much sense as the worst that can happen\n // is that some of the data written by the user might be discarded due to the\n // call to `socket.end()` below, which triggers an `'error'` event that in\n // turn causes the socket to be destroyed.\n //\n message = message || http.STATUS_CODES[code];\n headers = {\n Connection: 'close',\n 'Content-Type': 'text/html',\n 'Content-Length': Buffer.byteLength(message),\n ...headers\n };\n\n socket.once('finish', socket.destroy);\n\n socket.end(\n `HTTP/1.1 ${code} ${http.STATUS_CODES[code]}\\r\\n` +\n Object.keys(headers)\n .map((h) => `${h}: ${headers[h]}`)\n .join('\\r\\n') +\n '\\r\\n\\r\\n' +\n message\n );\n}\n\n/**\n * Emit a `'wsClientError'` event on a `WebSocketServer` if there is at least\n * one listener for it, otherwise call `abortHandshake()`.\n *\n * @param {WebSocketServer} server The WebSocket server\n * @param {http.IncomingMessage} req The request object\n * @param {Duplex} socket The socket of the upgrade request\n * @param {Number} code The HTTP response status code\n * @param {String} message The HTTP response body\n * @private\n */\nfunction abortHandshakeOrEmitwsClientError(server, req, socket, code, message) {\n if (server.listenerCount('wsClientError')) {\n const err = new Error(message);\n Error.captureStackTrace(err, abortHandshakeOrEmitwsClientError);\n\n server.emit('wsClientError', err, socket, req);\n } else {\n abortHandshake(socket, code, message);\n }\n}\n","'use strict';\n\nconst WebSocket = require('./lib/websocket');\n\nWebSocket.createWebSocketStream = require('./lib/stream');\nWebSocket.Server = require('./lib/websocket-server');\nWebSocket.Receiver = require('./lib/receiver');\nWebSocket.Sender = require('./lib/sender');\n\nWebSocket.WebSocket = WebSocket;\nWebSocket.WebSocketServer = WebSocket.Server;\n\nmodule.exports = WebSocket;\n","import { Duplex, Transform } from 'readable-stream'\nimport { Buffer } from 'buffer'\nimport { IClientOptions } from './client'\n\n/**\n * Utils writev function for browser, ensure to write Buffers to socket (convert strings).\n */\nexport function writev(\n\tchunks: { chunk: any; encoding: string }[],\n\tcb: (err?: Error) => void,\n) {\n\tconst buffers = new Array(chunks.length)\n\tfor (let i = 0; i < chunks.length; i++) {\n\t\tif (typeof chunks[i].chunk === 'string') {\n\t\t\tbuffers[i] = Buffer.from(chunks[i].chunk, 'utf8')\n\t\t} else {\n\t\t\tbuffers[i] = chunks[i].chunk\n\t\t}\n\t}\n\n\tthis._write(Buffer.concat(buffers), 'binary', cb)\n}\n\n/**\n * How this works:\n * - `socket` is the `WebSocket` instance, the connection to our broker.\n * - `proxy` is a `Transform`, it ensure data written to the `socket` is a `Buffer`.\n * This class buffers the data written to the `proxy` (so then to `socket`) until the `socket` is ready.\n * The stream returned from this class, will be passed to the `MqttClient`.\n */\nexport class BufferedDuplex extends Duplex {\n\tpublic socket: WebSocket\n\n\tprivate proxy: Transform\n\n\tprivate isSocketOpen: boolean\n\n\tprivate writeQueue: Array<{\n\t\tchunk: any\n\t\tencoding: string\n\t\tcb: (err?: Error) => void\n\t}>\n\n\tconstructor(opts: IClientOptions, proxy: Transform, socket: WebSocket) {\n\t\tsuper({\n\t\t\tobjectMode: true,\n\t\t})\n\t\tthis.proxy = proxy\n\t\tthis.socket = socket\n\t\tthis.writeQueue = []\n\n\t\tif (!opts.objectMode) {\n\t\t\tthis._writev = writev.bind(this)\n\t\t}\n\n\t\tthis.isSocketOpen = false\n\n\t\tthis.proxy.on('data', (chunk) => {\n\t\t\tif (!this.destroyed) {\n\t\t\t\tthis.push(chunk)\n\t\t\t}\n\t\t})\n\t}\n\n\t_read(size?: number): void {\n\t\tthis.proxy.read(size)\n\t}\n\n\t_write(chunk: any, encoding: string, cb: (err?: Error) => void) {\n\t\tif (!this.isSocketOpen) {\n\t\t\t// Buffer the data in a queue\n\t\t\tthis.writeQueue.push({ chunk, encoding, cb })\n\t\t} else {\n\t\t\tthis.writeToProxy(chunk, encoding, cb)\n\t\t}\n\t}\n\n\t_final(callback: (error?: Error) => void): void {\n\t\tthis.writeQueue = []\n\t\tthis.proxy.end(callback)\n\t}\n\n\t_destroy(err: Error, callback: (error: Error) => void): void {\n\t\tthis.writeQueue = []\n\t\t// do not pass error here otherwise we should listen for `error` event on proxy to prevent uncaught exception\n\t\tthis.proxy.destroy()\n\t\tcallback(err)\n\t}\n\n\t/** Method to call when socket is ready to stop buffering writes */\n\tsocketReady() {\n\t\tthis.emit('connect')\n\t\tthis.isSocketOpen = true\n\t\tthis.processWriteQueue()\n\t}\n\n\tprivate writeToProxy(\n\t\tchunk: any,\n\t\tencoding: string,\n\t\tcb: (err?: Error) => void,\n\t) {\n\t\tif (this.proxy.write(chunk, encoding) === false) {\n\t\t\tthis.proxy.once('drain', cb)\n\t\t} else {\n\t\t\tcb()\n\t\t}\n\t}\n\n\tprivate processWriteQueue() {\n\t\twhile (this.writeQueue.length > 0) {\n\t\t\tconst { chunk, encoding, cb } = this.writeQueue.shift()!\n\t\t\tthis.writeToProxy(chunk, encoding, cb)\n\t\t}\n\t}\n}\n","import { StreamBuilder } from '../shared'\nimport { Buffer } from 'buffer'\nimport Ws, { ClientOptions } from 'ws'\nimport _debug from 'debug'\nimport { DuplexOptions, Transform } from 'readable-stream'\nimport isBrowser from '../is-browser'\nimport MqttClient, { IClientOptions } from '../client'\nimport { BufferedDuplex, writev } from '../BufferedDuplex'\n\nconst debug = _debug('mqttjs:ws')\n\nconst WSS_OPTIONS = [\n\t'rejectUnauthorized',\n\t'ca',\n\t'cert',\n\t'key',\n\t'pfx',\n\t'passphrase',\n]\n\nfunction buildUrl(opts: IClientOptions, client: MqttClient) {\n\tlet url = `${opts.protocol}://${opts.hostname}:${opts.port}${opts.path}`\n\tif (typeof opts.transformWsUrl === 'function') {\n\t\turl = opts.transformWsUrl(url, opts, client)\n\t}\n\treturn url\n}\n\nfunction setDefaultOpts(opts: IClientOptions) {\n\tconst options = opts\n\n\tif (!opts.port) {\n\t\tif (opts.protocol === 'wss') {\n\t\t\toptions.port = 443\n\t\t} else {\n\t\t\toptions.port = 80\n\t\t}\n\t}\n\n\tif (!opts.path) {\n\t\toptions.path = '/'\n\t}\n\n\tif (!opts.wsOptions) {\n\t\toptions.wsOptions = {}\n\t}\n\tif (!isBrowser && !opts.forceNativeWebSocket && opts.protocol === 'wss') {\n\t\t// Add cert/key/ca etc options\n\t\tWSS_OPTIONS.forEach((prop) => {\n\t\t\tif (\n\t\t\t\tObject.prototype.hasOwnProperty.call(opts, prop) &&\n\t\t\t\t!Object.prototype.hasOwnProperty.call(opts.wsOptions, prop)\n\t\t\t) {\n\t\t\t\toptions.wsOptions[prop] = opts[prop]\n\t\t\t}\n\t\t})\n\t}\n\n\treturn options\n}\n\nfunction setDefaultBrowserOpts(opts: IClientOptions) {\n\tconst options = setDefaultOpts(opts)\n\n\tif (!options.hostname) {\n\t\toptions.hostname = options.host\n\t}\n\n\tif (!options.hostname) {\n\t\t// Throwing an error in a Web Worker if no `hostname` is given, because we\n\t\t// can not determine the `hostname` automatically. If connecting to\n\t\t// localhost, please supply the `hostname` as an argument.\n\t\tif (typeof document === 'undefined') {\n\t\t\tthrow new Error('Could not determine host. Specify host manually.')\n\t\t}\n\t\tconst parsed = new URL(document.URL)\n\t\toptions.hostname = parsed.hostname\n\n\t\tif (!options.port) {\n\t\t\toptions.port = Number(parsed.port)\n\t\t}\n\t}\n\n\t// objectMode should be defined for logic\n\tif (options.objectMode === undefined) {\n\t\toptions.objectMode = !(\n\t\t\toptions.binary === true || options.binary === undefined\n\t\t)\n\t}\n\n\treturn options\n}\n\nfunction createWebSocket(\n\tclient: MqttClient,\n\turl: string,\n\topts: IClientOptions,\n) {\n\tdebug('createWebSocket')\n\tdebug(`protocol: ${opts.protocolId} ${opts.protocolVersion}`)\n\tconst websocketSubProtocol =\n\t\topts.protocolId === 'MQIsdp' && opts.protocolVersion === 3\n\t\t\t? 'mqttv3.1'\n\t\t\t: 'mqtt'\n\n\tdebug(\n\t\t`creating new Websocket for url: ${url} and protocol: ${websocketSubProtocol}`,\n\t)\n\tlet socket: Ws\n\tif (opts.createWebsocket) {\n\t\tsocket = opts.createWebsocket(url, [websocketSubProtocol], opts)\n\t} else {\n\t\tsocket = new Ws(\n\t\t\turl,\n\t\t\t[websocketSubProtocol],\n\t\t\topts.wsOptions as ClientOptions,\n\t\t)\n\t}\n\treturn socket\n}\n\n/* istanbul ignore next */\nfunction createBrowserWebSocket(client: MqttClient, opts: IClientOptions) {\n\tconst websocketSubProtocol =\n\t\topts.protocolId === 'MQIsdp' && opts.protocolVersion === 3\n\t\t\t? 'mqttv3.1'\n\t\t\t: 'mqtt'\n\n\tconst url = buildUrl(opts, client)\n\tlet socket: WebSocket\n\tif (opts.createWebsocket) {\n\t\tsocket = opts.createWebsocket(url, [websocketSubProtocol], opts)\n\t} else {\n\t\tsocket = new WebSocket(url, [websocketSubProtocol])\n\t}\n\tsocket.binaryType = 'arraybuffer'\n\treturn socket\n}\n\nconst streamBuilder: StreamBuilder = (client, opts) => {\n\tdebug('streamBuilder')\n\tconst options = setDefaultOpts(opts)\n\n\toptions.hostname = options.hostname || options.host || 'localhost'\n\n\tconst url = buildUrl(options, client)\n\tconst socket = createWebSocket(client, url, options)\n\tconst webSocketStream = Ws.createWebSocketStream(\n\t\tsocket,\n\t\toptions.wsOptions as DuplexOptions,\n\t)\n\n\twebSocketStream['url'] = url\n\tsocket.on('close', () => {\n\t\twebSocketStream.destroy()\n\t})\n\treturn webSocketStream\n}\n\n/* istanbul ignore next */\nconst browserStreamBuilder: StreamBuilder = (client, opts) => {\n\tdebug('browserStreamBuilder')\n\tlet stream: BufferedDuplex | (Transform & { socket?: WebSocket })\n\tconst options = setDefaultBrowserOpts(opts)\n\t// sets the maximum socket buffer size before throttling\n\tconst bufferSize = options.browserBufferSize || 1024 * 512\n\n\tconst bufferTimeout = opts.browserBufferTimeout || 1000\n\n\tconst coerceToBuffer = !opts.objectMode\n\n\t// the websocket connection\n\tconst socket = createBrowserWebSocket(client, opts)\n\n\t// the proxy is a transform stream that forwards data to the socket\n\t// it ensures data written to socket is a Buffer\n\tconst proxy = buildProxy(opts, socketWriteBrowser, socketEndBrowser)\n\n\tif (!opts.objectMode) {\n\t\tproxy._writev = writev.bind(proxy)\n\t}\n\tproxy.on('close', () => {\n\t\tsocket.close()\n\t})\n\n\tconst eventListenerSupport = typeof socket.addEventListener !== 'undefined'\n\n\t// was already open when passed in\n\tif (socket.readyState === socket.OPEN) {\n\t\tstream = proxy\n\t\tstream.socket = socket\n\t} else {\n\t\t// socket is not open. Use this to buffer writes until it is opened\n\t\tstream = new BufferedDuplex(opts, proxy, socket)\n\n\t\tif (eventListenerSupport) {\n\t\t\tsocket.addEventListener('open', onOpen)\n\t\t} else {\n\t\t\tsocket.onopen = onOpen\n\t\t}\n\t}\n\n\tif (eventListenerSupport) {\n\t\tsocket.addEventListener('close', onClose)\n\t\tsocket.addEventListener('error', onError)\n\t\tsocket.addEventListener('message', onMessage)\n\t} else {\n\t\tsocket.onclose = onClose\n\t\tsocket.onerror = onError\n\t\tsocket.onmessage = onMessage\n\t}\n\n\t// methods for browserStreamBuilder\n\n\tfunction buildProxy(\n\t\tpOptions: IClientOptions,\n\t\tsocketWrite: typeof socketWriteBrowser,\n\t\tsocketEnd: typeof socketEndBrowser,\n\t) {\n\t\tconst _proxy = new Transform({\n\t\t\tobjectMode: pOptions.objectMode,\n\t\t})\n\n\t\t_proxy._write = socketWrite\n\t\t_proxy._flush = socketEnd\n\n\t\treturn _proxy\n\t}\n\n\tfunction onOpen() {\n\t\tdebug('WebSocket onOpen')\n\t\tif (stream instanceof BufferedDuplex) {\n\t\t\tstream.socketReady()\n\t\t}\n\t}\n\n\t/**\n\t * https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/close_event\n\t */\n\tfunction onClose(event: CloseEvent) {\n\t\tdebug('WebSocket onClose', event)\n\t\tstream.end()\n\t\tstream.destroy()\n\t}\n\n\t/**\n\t * https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/error_event\n\t */\n\tfunction onError(err: Event) {\n\t\tdebug('WebSocket onError', err)\n\t\tconst error = new Error('WebSocket error')\n\t\terror['event'] = err\n\t\tstream.destroy(error)\n\t}\n\n\t/**\n\t * https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/message_event\n\t */\n\tasync function onMessage(event: MessageEvent) {\n\t\tlet { data } = event\n\t\tif (data instanceof ArrayBuffer) data = Buffer.from(data)\n\t\telse if (data instanceof Blob)\n\t\t\tdata = Buffer.from(await new Response(data).arrayBuffer())\n\t\telse data = Buffer.from(data as string, 'utf8')\n\t\tif (proxy && !proxy.destroyed) {\n\t\t\tproxy.push(data)\n\t\t}\n\t}\n\n\tfunction socketWriteBrowser(\n\t\tchunk: any,\n\t\tenc: string,\n\t\tnext: (err?: Error) => void,\n\t) {\n\t\tif (socket.bufferedAmount > bufferSize) {\n\t\t\t// throttle data until buffered amount is reduced.\n\t\t\tsetTimeout(socketWriteBrowser, bufferTimeout, chunk, enc, next)\n\t\t\treturn\n\t\t}\n\n\t\tif (coerceToBuffer && typeof chunk === 'string') {\n\t\t\tchunk = Buffer.from(chunk, 'utf8')\n\t\t}\n\n\t\ttry {\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/send (note this doesn't have a cb as second arg)\n\t\t\tsocket.send(chunk)\n\t\t} catch (err) {\n\t\t\treturn next(err)\n\t\t}\n\n\t\tnext()\n\t}\n\n\tfunction socketEndBrowser(done: (error?: Error, data?: any) => void) {\n\t\tsocket.close()\n\t\tdone()\n\t}\n\n\t// end methods for browserStreamBuilder\n\n\treturn stream\n}\n\nexport { browserStreamBuilder, streamBuilder }\n","import { StreamBuilder } from '../shared'\n\nimport net from 'net'\nimport _debug from 'debug'\n\nconst debug = _debug('mqttjs:tcp')\n/*\n variables port and host can be removed since\n you have all required information in opts object\n*/\nconst buildStream: StreamBuilder = (client, opts) => {\n\topts.port = opts.port || 1883\n\topts.hostname = opts.hostname || opts.host || 'localhost'\n\n\tconst { port, path } = opts\n\tconst host = opts.hostname\n\n\tdebug('port %d and host %s', port, host)\n\treturn net.createConnection({ port, host, path })\n}\n\nexport default buildStream\n","import tls from 'tls'\nimport net from 'net'\nimport _debug from 'debug'\nimport { StreamBuilder } from '../shared'\n\nconst debug = _debug('mqttjs:tls')\n\nconst buildStream: StreamBuilder = (client, opts) => {\n\topts.port = opts.port || 8883\n\topts.host = opts.hostname || opts.host || 'localhost'\n\n\tif (net.isIP(opts.host) === 0) {\n\t\topts.servername = opts.host\n\t}\n\n\topts.rejectUnauthorized = opts.rejectUnauthorized !== false\n\n\tdelete opts.path\n\n\tdebug(\n\t\t'port %d host %s rejectUnauthorized %b',\n\t\topts.port,\n\t\topts.host,\n\t\topts.rejectUnauthorized,\n\t)\n\n\tconst connection = tls.connect(opts)\n\tconnection.on('secureConnect', () => {\n\t\tif (opts.rejectUnauthorized && !connection.authorized) {\n\t\t\tconnection.emit('error', new Error('TLS not authorized'))\n\t\t} else {\n\t\t\tconnection.removeListener('error', handleTLSerrors)\n\t\t}\n\t})\n\n\tfunction handleTLSerrors(err: Error) {\n\t\t// How can I get verify this error is a tls error?\n\t\tif (opts.rejectUnauthorized) {\n\t\t\tclient.emit('error', err)\n\t\t}\n\n\t\t// close this connection to match the behaviour of net\n\t\t// otherwise all we get is an error from the connection\n\t\t// and close event doesn't fire. This is a work around\n\t\t// to enable the reconnect code to work the same as with\n\t\t// net.createConnection\n\t\tconnection.end()\n\t}\n\n\tconnection.on('error', handleTLSerrors)\n\treturn connection\n}\n\nexport default buildStream\n","import { StreamBuilder } from '../shared'\n\nimport { Buffer } from 'buffer'\nimport { Transform } from 'readable-stream'\nimport MqttClient, { IClientOptions } from '../client'\nimport { BufferedDuplex } from '../BufferedDuplex'\n\n/* global wx */\nlet socketTask: any\nlet proxy: Transform\nlet stream: BufferedDuplex\n\ndeclare global {\n\tconst wx: any\n}\n\nfunction buildProxy() {\n\tconst _proxy = new Transform()\n\t_proxy._write = (chunk, encoding, next) => {\n\t\tsocketTask.send({\n\t\t\tdata: chunk.buffer,\n\t\t\tsuccess() {\n\t\t\t\tnext()\n\t\t\t},\n\t\t\tfail(errMsg) {\n\t\t\t\tnext(new Error(errMsg))\n\t\t\t},\n\t\t})\n\t}\n\t_proxy._flush = (done) => {\n\t\tsocketTask.close({\n\t\t\tsuccess() {\n\t\t\t\tdone()\n\t\t\t},\n\t\t})\n\t}\n\n\treturn _proxy\n}\n\nfunction setDefaultOpts(opts) {\n\tif (!opts.hostname) {\n\t\topts.hostname = 'localhost'\n\t}\n\tif (!opts.path) {\n\t\topts.path = '/'\n\t}\n\n\tif (!opts.wsOptions) {\n\t\topts.wsOptions = {}\n\t}\n}\n\nfunction buildUrl(opts: IClientOptions, client: MqttClient) {\n\tconst protocol = opts.protocol === 'wxs' ? 'wss' : 'ws'\n\tlet url = `${protocol}://${opts.hostname}${opts.path}`\n\tif (opts.port && opts.port !== 80 && opts.port !== 443) {\n\t\turl = `${protocol}://${opts.hostname}:${opts.port}${opts.path}`\n\t}\n\tif (typeof opts.transformWsUrl === 'function') {\n\t\turl = opts.transformWsUrl(url, opts, client)\n\t}\n\treturn url\n}\n\nfunction bindEventHandler() {\n\tsocketTask.onOpen(() => {\n\t\tstream.socketReady()\n\t})\n\n\tsocketTask.onMessage((res) => {\n\t\tlet { data } = res\n\n\t\tif (data instanceof ArrayBuffer) data = Buffer.from(data)\n\t\telse data = Buffer.from(data, 'utf8')\n\t\tproxy.push(data)\n\t})\n\n\tsocketTask.onClose(() => {\n\t\tstream.emit('close')\n\t\tstream.end()\n\t\tstream.destroy()\n\t})\n\n\tsocketTask.onError((error) => {\n\t\tconst err = new Error(error.errMsg)\n\t\tstream.destroy(err)\n\t})\n}\n\nconst buildStream: StreamBuilder = (client, opts) => {\n\topts.hostname = opts.hostname || opts.host\n\n\tif (!opts.hostname) {\n\t\tthrow new Error('Could not determine host. Specify host manually.')\n\t}\n\n\tconst websocketSubProtocol =\n\t\topts.protocolId === 'MQIsdp' && opts.protocolVersion === 3\n\t\t\t? 'mqttv3.1'\n\t\t\t: 'mqtt'\n\n\tsetDefaultOpts(opts)\n\n\tconst url = buildUrl(opts, client)\n\t// https://github.com/wechat-miniprogram/api-typings/blob/master/types/wx/lib.wx.api.d.ts#L20984\n\tsocketTask = wx.connectSocket({\n\t\turl,\n\t\tprotocols: [websocketSubProtocol],\n\t})\n\n\tproxy = buildProxy()\n\tstream = new BufferedDuplex(opts, proxy, socketTask)\n\tstream._destroy = (err, cb) => {\n\t\tsocketTask.close({\n\t\t\tsuccess() {\n\t\t\t\tif (cb) cb(err)\n\t\t\t},\n\t\t})\n\t}\n\n\tconst destroyRef = stream.destroy\n\tstream.destroy = (err, cb) => {\n\t\tstream.destroy = destroyRef\n\n\t\tsetTimeout(() => {\n\t\t\tsocketTask.close({\n\t\t\t\tfail() {\n\t\t\t\t\tstream._destroy(err, cb)\n\t\t\t\t},\n\t\t\t})\n\t\t}, 0)\n\n\t\treturn stream\n\t}\n\n\tbindEventHandler()\n\n\treturn stream\n}\n\nexport default buildStream\n","import { Buffer } from 'buffer'\nimport { Transform } from 'readable-stream'\nimport { StreamBuilder } from '../shared'\nimport MqttClient, { IClientOptions } from '../client'\nimport { BufferedDuplex } from '../BufferedDuplex'\n\nlet my: any\nlet proxy: Transform\nlet stream: BufferedDuplex\nlet isInitialized = false\n\nfunction buildProxy() {\n\tconst _proxy = new Transform()\n\t_proxy._write = (chunk, encoding, next) => {\n\t\tmy.sendSocketMessage({\n\t\t\tdata: chunk.buffer,\n\t\t\tsuccess() {\n\t\t\t\tnext()\n\t\t\t},\n\t\t\tfail() {\n\t\t\t\tnext(new Error())\n\t\t\t},\n\t\t})\n\t}\n\t_proxy._flush = (done) => {\n\t\tmy.closeSocket({\n\t\t\tsuccess() {\n\t\t\t\tdone()\n\t\t\t},\n\t\t})\n\t}\n\n\treturn _proxy\n}\n\nfunction setDefaultOpts(opts: IClientOptions) {\n\tif (!opts.hostname) {\n\t\topts.hostname = 'localhost'\n\t}\n\tif (!opts.path) {\n\t\topts.path = '/'\n\t}\n\n\tif (!opts.wsOptions) {\n\t\topts.wsOptions = {}\n\t}\n}\n\nfunction buildUrl(opts: IClientOptions, client: MqttClient) {\n\tconst protocol = opts.protocol === 'alis' ? 'wss' : 'ws'\n\tlet url = `${protocol}://${opts.hostname}${opts.path}`\n\tif (opts.port && opts.port !== 80 && opts.port !== 443) {\n\t\turl = `${protocol}://${opts.hostname}:${opts.port}${opts.path}`\n\t}\n\tif (typeof opts.transformWsUrl === 'function') {\n\t\turl = opts.transformWsUrl(url, opts, client)\n\t}\n\treturn url\n}\n\nfunction bindEventHandler() {\n\tif (isInitialized) return\n\n\tisInitialized = true\n\n\tmy.onSocketOpen(() => {\n\t\tstream.socketReady()\n\t})\n\n\tmy.onSocketMessage((res) => {\n\t\tif (typeof res.data === 'string') {\n\t\t\tconst buffer = Buffer.from(res.data, 'base64')\n\t\t\tproxy.push(buffer)\n\t\t} else {\n\t\t\tconst reader = new FileReader()\n\t\t\treader.addEventListener('load', () => {\n\t\t\t\tlet data = reader.result\n\n\t\t\t\tif (data instanceof ArrayBuffer) data = Buffer.from(data)\n\t\t\t\telse data = Buffer.from(data, 'utf8')\n\t\t\t\tproxy.push(data)\n\t\t\t})\n\t\t\treader.readAsArrayBuffer(res.data)\n\t\t}\n\t})\n\n\tmy.onSocketClose(() => {\n\t\tstream.end()\n\t\tstream.destroy()\n\t})\n\n\tmy.onSocketError((err) => {\n\t\tstream.destroy(err)\n\t})\n}\n\nconst buildStream: StreamBuilder = (client, opts) => {\n\topts.hostname = opts.hostname || opts.host\n\n\tif (!opts.hostname) {\n\t\tthrow new Error('Could not determine host. Specify host manually.')\n\t}\n\n\tconst websocketSubProtocol =\n\t\topts.protocolId === 'MQIsdp' && opts.protocolVersion === 3\n\t\t\t? 'mqttv3.1'\n\t\t\t: 'mqtt'\n\n\tsetDefaultOpts(opts)\n\n\tconst url = buildUrl(opts, client)\n\tmy = opts.my\n\t// https://miniprogram.alipay.com/docs/miniprogram/mpdev/api_network_connectsocket\n\tmy.connectSocket({\n\t\turl,\n\t\tprotocols: websocketSubProtocol,\n\t})\n\n\tproxy = buildProxy()\n\tstream = new BufferedDuplex(opts, proxy, my)\n\n\tbindEventHandler()\n\n\treturn stream\n}\n\nexport default buildStream\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport _debug from 'debug'\nimport url from 'url'\nimport MqttClient, {\n\tIClientOptions,\n\tMqttClientEventCallbacks,\n\tMqttProtocol,\n} from '../client'\nimport isBrowser from '../is-browser'\nimport { StreamBuilder } from '../shared'\n\n// Handling the process.nextTick is not a function error in react-native applications.\nif (typeof process?.nextTick !== 'function') {\n\tprocess.nextTick = setImmediate\n}\n\nconst debug = _debug('mqttjs')\n\nlet protocols: Record<string, StreamBuilder> = null\n\n/**\n * Parse the auth attribute and merge username and password in the options object.\n *\n * @param {Object} [opts] option object\n */\nfunction parseAuthOptions(opts: IClientOptions) {\n\tlet matches: RegExpMatchArray | null\n\tif (opts.auth) {\n\t\tmatches = opts.auth.match(/^(.+):(.+)$/)\n\t\tif (matches) {\n\t\t\topts.username = matches[1]\n\t\t\topts.password = matches[2]\n\t\t} else {\n\t\t\topts.username = opts.auth\n\t\t}\n\t}\n}\n\n/**\n * connect - connect to an MQTT broker.\n */\nfunction connect(brokerUrl: string): MqttClient\nfunction connect(opts: IClientOptions): MqttClient\nfunction connect(brokerUrl: string, opts?: IClientOptions): MqttClient\nfunction connect(\n\tbrokerUrl: string | IClientOptions,\n\topts?: IClientOptions,\n): MqttClient {\n\tdebug('connecting to an MQTT broker...')\n\tif (typeof brokerUrl === 'object' && !opts) {\n\t\topts = brokerUrl\n\t\tbrokerUrl = ''\n\t}\n\n\topts = opts || {}\n\n\t// try to parse the broker url\n\tif (brokerUrl && typeof brokerUrl === 'string') {\n\t\t// eslint-disable-next-line\n\t\tconst parsedUrl = url.parse(brokerUrl, true)\n\t\tconst parsedOptions: Partial<IClientOptions> = {}\n\n\t\tif (parsedUrl.port != null) {\n\t\t\t// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n\t\t\t// @ts-ignore\n\t\t\tparsedOptions.port = Number(parsedUrl.port)\n\t\t}\n\n\t\tparsedOptions.host = parsedUrl.hostname\n\t\tparsedOptions.query = parsedUrl.query as Record<string, string>\n\t\tparsedOptions.auth = parsedUrl.auth\n\t\tparsedOptions.protocol = parsedUrl.protocol as MqttProtocol\n\t\tparsedOptions.path = parsedUrl.path\n\n\t\tparsedOptions.protocol = parsedOptions.protocol?.replace(\n\t\t\t/:$/,\n\t\t\t'',\n\t\t) as MqttProtocol\n\n\t\topts = { ...parsedOptions, ...opts }\n\n\t\t// when parsing an url expect the protocol to be set\n\t\tif (!opts.protocol) {\n\t\t\tthrow new Error('Missing protocol')\n\t\t}\n\t}\n\n\topts.unixSocket = opts.unixSocket || opts.protocol?.includes('+unix')\n\n\tif (opts.unixSocket) {\n\t\topts.protocol = opts.protocol.replace('+unix', '') as MqttProtocol\n\t} else if (\n\t\t!opts.protocol?.startsWith('ws') &&\n\t\t!opts.protocol?.startsWith('wx')\n\t) {\n\t\t// consider path only with ws protocol or unix socket\n\t\t// url.parse could return path (for example when url ends with a `/`)\n\t\t// that could break the connection. See https://github.com/mqttjs/MQTT.js/pull/1874\n\t\tdelete opts.path\n\t}\n\n\t// merge in the auth options if supplied\n\tparseAuthOptions(opts)\n\n\t// support clientId passed in the query string of the url\n\tif (opts.query && typeof opts.query.clientId === 'string') {\n\t\topts.clientId = opts.query.clientId\n\t}\n\n\tif (opts.cert && opts.key) {\n\t\tif (opts.protocol) {\n\t\t\tif (['mqtts', 'wss', 'wxs', 'alis'].indexOf(opts.protocol) === -1) {\n\t\t\t\tswitch (opts.protocol) {\n\t\t\t\t\tcase 'mqtt':\n\t\t\t\t\t\topts.protocol = 'mqtts'\n\t\t\t\t\t\tbreak\n\t\t\t\t\tcase 'ws':\n\t\t\t\t\t\topts.protocol = 'wss'\n\t\t\t\t\t\tbreak\n\t\t\t\t\tcase 'wx':\n\t\t\t\t\t\topts.protocol = 'wxs'\n\t\t\t\t\t\tbreak\n\t\t\t\t\tcase 'ali':\n\t\t\t\t\t\topts.protocol = 'alis'\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`Unknown protocol for secure connection: \"${opts.protocol}\"!`,\n\t\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\t// A cert and key was provided, however no protocol was specified, so we will throw an error.\n\t\t\tthrow new Error('Missing secure protocol key')\n\t\t}\n\t}\n\n\t// only loads the protocols once\n\tif (!protocols) {\n\t\tprotocols = {}\n\t\tif (!isBrowser && !opts.forceNativeWebSocket) {\n\t\t\tprotocols.ws = require('./ws').streamBuilder\n\t\t\tprotocols.wss = require('./ws').streamBuilder\n\n\t\t\tprotocols.mqtt = require('./tcp').default\n\t\t\tprotocols.tcp = require('./tcp').default\n\t\t\tprotocols.ssl = require('./tls').default\n\t\t\tprotocols.tls = protocols.ssl\n\t\t\tprotocols.mqtts = require('./tls').default\n\t\t} else {\n\t\t\tprotocols.ws = require('./ws').browserStreamBuilder\n\t\t\tprotocols.wss = require('./ws').browserStreamBuilder\n\n\t\t\tprotocols.wx = require('./wx').default\n\t\t\tprotocols.wxs = require('./wx').default\n\n\t\t\tprotocols.ali = require('./ali').default\n\t\t\tprotocols.alis = require('./ali').default\n\t\t}\n\t}\n\n\tif (!protocols[opts.protocol]) {\n\t\tconst isSecure = ['mqtts', 'wss'].indexOf(opts.protocol) !== -1\n\t\t// returns the first available protocol based on available protocols (that depends on environment)\n\t\t// if no protocol is specified this will return mqtt on node and ws on browser\n\t\t// if secure it will return mqtts on node and wss on browser\n\t\topts.protocol = [\n\t\t\t'mqtt',\n\t\t\t'mqtts',\n\t\t\t'ws',\n\t\t\t'wss',\n\t\t\t'wx',\n\t\t\t'wxs',\n\t\t\t'ali',\n\t\t\t'alis',\n\t\t].filter((key, index) => {\n\t\t\tif (isSecure && index % 2 === 0) {\n\t\t\t\t// Skip insecure protocols when requesting a secure one.\n\t\t\t\treturn false\n\t\t\t}\n\t\t\treturn typeof protocols[key] === 'function'\n\t\t})[0] as MqttProtocol\n\t}\n\n\tif (opts.clean === false && !opts.clientId) {\n\t\tthrow new Error('Missing clientId for unclean clients')\n\t}\n\n\tif (opts.protocol) {\n\t\topts.defaultProtocol = opts.protocol\n\t}\n\n\tfunction wrapper(client: MqttClient) {\n\t\tif (opts.servers) {\n\t\t\tif (\n\t\t\t\t!client._reconnectCount ||\n\t\t\t\tclient._reconnectCount === opts.servers.length\n\t\t\t) {\n\t\t\t\tclient._reconnectCount = 0\n\t\t\t}\n\n\t\t\topts.host = opts.servers[client._reconnectCount].host\n\t\t\topts.port = opts.servers[client._reconnectCount].port\n\t\t\topts.protocol = !opts.servers[client._reconnectCount].protocol\n\t\t\t\t? opts.defaultProtocol\n\t\t\t\t: opts.servers[client._reconnectCount].protocol\n\t\t\topts.hostname = opts.host\n\n\t\t\tclient._reconnectCount++\n\t\t}\n\n\t\tdebug('calling streambuilder for', opts.protocol)\n\t\treturn protocols[opts.protocol](client, opts)\n\t}\n\tconst client = new MqttClient(wrapper, opts)\n\tclient.on('error', () => {\n\t\t/* Automatically set up client error handling */\n\t})\n\n\treturn client\n}\n\nfunction connectAsync(brokerUrl: string): Promise<MqttClient>\nfunction connectAsync(opts: IClientOptions): Promise<MqttClient>\nfunction connectAsync(\n\tbrokerUrl: string,\n\topts?: IClientOptions,\n): Promise<MqttClient>\nfunction connectAsync(\n\tbrokerUrl: string,\n\topts: IClientOptions,\n\tallowRetries: boolean,\n): Promise<MqttClient>\nfunction connectAsync(\n\tbrokerUrl: string | IClientOptions,\n\topts?: IClientOptions,\n\tallowRetries = true,\n): Promise<MqttClient> {\n\treturn new Promise((resolve, reject) => {\n\t\tconst client = connect(brokerUrl as string, opts)\n\n\t\tconst promiseResolutionListeners: Partial<MqttClientEventCallbacks> = {\n\t\t\tconnect: (connack) => {\n\t\t\t\tremovePromiseResolutionListeners()\n\t\t\t\tresolve(client) // Resolve on connect\n\t\t\t},\n\t\t\tend: () => {\n\t\t\t\tremovePromiseResolutionListeners()\n\t\t\t\tresolve(client) // Resolve on end\n\t\t\t},\n\t\t\terror: (err) => {\n\t\t\t\tremovePromiseResolutionListeners()\n\t\t\t\tclient.end()\n\t\t\t\treject(err) // Reject on error\n\t\t\t},\n\t\t}\n\n\t\t// If retries are not allowed, reject on close\n\t\tif (allowRetries === false) {\n\t\t\tpromiseResolutionListeners.close = () => {\n\t\t\t\tpromiseResolutionListeners.error(\n\t\t\t\t\tnew Error(\"Couldn't connect to server\"),\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\n\t\t// Remove listeners added to client by this promise\n\t\tfunction removePromiseResolutionListeners() {\n\t\t\tObject.keys(promiseResolutionListeners).forEach((eventName) => {\n\t\t\t\tclient.off(\n\t\t\t\t\teventName as keyof MqttClientEventCallbacks,\n\t\t\t\t\tpromiseResolutionListeners[eventName],\n\t\t\t\t)\n\t\t\t})\n\t\t}\n\n\t\t// Add listeners to client\n\t\tObject.keys(promiseResolutionListeners).forEach((eventName) => {\n\t\t\tclient.on(\n\t\t\t\teventName as keyof MqttClientEventCallbacks,\n\t\t\t\tpromiseResolutionListeners[eventName],\n\t\t\t)\n\t\t})\n\t})\n}\n\nexport default connect\nexport { connectAsync }\n","/*\n * Copyright (c) 2015-2015 MQTT.js contributors.\n * Copyright (c) 2011-2014 Adam Rudd.\n *\n * See LICENSE for more information\n */\nimport MqttClient from './lib/client'\nimport DefaultMessageIdProvider from './lib/default-message-id-provider'\nimport UniqueMessageIdProvider from './lib/unique-message-id-provider'\nimport Store, { IStore } from './lib/store'\nimport connect, { connectAsync } from './lib/connect'\nimport KeepaliveManager from './lib/KeepaliveManager'\n\nexport const Client = MqttClient\nexport {\n\tconnect,\n\tconnectAsync,\n\tMqttClient,\n\tStore,\n\tDefaultMessageIdProvider,\n\tUniqueMessageIdProvider,\n\tIStore,\n\tKeepaliveManager,\n}\nexport * from './lib/client'\nexport * from './lib/shared'\nexport { ReasonCodes } from './lib/handlers/ack'\nexport type { Timer } from './lib/get-timer'\n","import * as mqtt from './mqtt'\n\nexport default mqtt\nexport * from './mqtt'\n","'use strict'\n\n// **************************************************************\n// * Code initially copied/adapted from \"pony-cause\" npm module *\n// * Please upstream improvements there *\n// **************************************************************\n\nconst isErrorLike = (err) => {\n return err && typeof err.message === 'string'\n}\n\n/**\n * @param {Error|{ cause?: unknown|(()=>err)}} err\n * @returns {Error|Object|undefined}\n */\nconst getErrorCause = (err) => {\n if (!err) return\n\n /** @type {unknown} */\n // @ts-ignore\n const cause = err.cause\n\n // VError / NError style causes\n if (typeof cause === 'function') {\n // @ts-ignore\n const causeResult = err.cause()\n\n return isErrorLike(causeResult)\n ? causeResult\n : undefined\n } else {\n return isErrorLike(cause)\n ? cause\n : undefined\n }\n}\n\n/**\n * Internal method that keeps a track of which error we have already added, to avoid circular recursion\n *\n * @private\n * @param {Error} err\n * @param {Set<Error>} seen\n * @returns {string}\n */\nconst _stackWithCauses = (err, seen) => {\n if (!isErrorLike(err)) return ''\n\n const stack = err.stack || ''\n\n // Ensure we don't go circular or crazily deep\n if (seen.has(err)) {\n return stack + '\\ncauses have become circular...'\n }\n\n const cause = getErrorCause(err)\n\n if (cause) {\n seen.add(err)\n return (stack + '\\ncaused by: ' + _stackWithCauses(cause, seen))\n } else {\n return stack\n }\n}\n\n/**\n * @param {Error} err\n * @returns {string}\n */\nconst stackWithCauses = (err) => _stackWithCauses(err, new Set())\n\n/**\n * Internal method that keeps a track of which error we have already added, to avoid circular recursion\n *\n * @private\n * @param {Error} err\n * @param {Set<Error>} seen\n * @param {boolean} [skip]\n * @returns {string}\n */\nconst _messageWithCauses = (err, seen, skip) => {\n if (!isErrorLike(err)) return ''\n\n const message = skip ? '' : (err.message || '')\n\n // Ensure we don't go circular or crazily deep\n if (seen.has(err)) {\n return message + ': ...'\n }\n\n const cause = getErrorCause(err)\n\n if (cause) {\n seen.add(err)\n\n // @ts-ignore\n const skipIfVErrorStyleCause = typeof err.cause === 'function'\n\n return (message +\n (skipIfVErrorStyleCause ? '' : ': ') +\n _messageWithCauses(cause, seen, skipIfVErrorStyleCause))\n } else {\n return message\n }\n}\n\n/**\n * @param {Error} err\n * @returns {string}\n */\nconst messageWithCauses = (err) => _messageWithCauses(err, new Set())\n\nmodule.exports = {\n isErrorLike,\n getErrorCause,\n stackWithCauses,\n messageWithCauses\n}\n","'use strict'\n\nconst seen = Symbol('circular-ref-tag')\nconst rawSymbol = Symbol('pino-raw-err-ref')\n\nconst pinoErrProto = Object.create({}, {\n type: {\n enumerable: true,\n writable: true,\n value: undefined\n },\n message: {\n enumerable: true,\n writable: true,\n value: undefined\n },\n stack: {\n enumerable: true,\n writable: true,\n value: undefined\n },\n aggregateErrors: {\n enumerable: true,\n writable: true,\n value: undefined\n },\n raw: {\n enumerable: false,\n get: function () {\n return this[rawSymbol]\n },\n set: function (val) {\n this[rawSymbol] = val\n }\n }\n})\nObject.defineProperty(pinoErrProto, rawSymbol, {\n writable: true,\n value: {}\n})\n\nmodule.exports = {\n pinoErrProto,\n pinoErrorSymbols: {\n seen,\n rawSymbol\n }\n}\n","'use strict'\n\nmodule.exports = errSerializer\n\nconst { messageWithCauses, stackWithCauses, isErrorLike } = require('./err-helpers')\nconst { pinoErrProto, pinoErrorSymbols } = require('./err-proto')\nconst { seen } = pinoErrorSymbols\n\nconst { toString } = Object.prototype\n\nfunction errSerializer (err) {\n if (!isErrorLike(err)) {\n return err\n }\n\n err[seen] = undefined // tag to prevent re-looking at this\n const _err = Object.create(pinoErrProto)\n _err.type = toString.call(err.constructor) === '[object Function]'\n ? err.constructor.name\n : err.name\n _err.message = messageWithCauses(err)\n _err.stack = stackWithCauses(err)\n\n if (Array.isArray(err.errors)) {\n _err.aggregateErrors = err.errors.map(err => errSerializer(err))\n }\n\n for (const key in err) {\n if (_err[key] === undefined) {\n const val = err[key]\n if (isErrorLike(val)) {\n // We append cause messages and stacks to _err, therefore skipping causes here\n if (key !== 'cause' && !Object.prototype.hasOwnProperty.call(val, seen)) {\n _err[key] = errSerializer(val)\n }\n } else {\n _err[key] = val\n }\n }\n }\n\n delete err[seen] // clean up tag in case err is serialized again later\n _err.raw = err\n return _err\n}\n","'use strict'\n\nmodule.exports = errWithCauseSerializer\n\nconst { isErrorLike } = require('./err-helpers')\nconst { pinoErrProto, pinoErrorSymbols } = require('./err-proto')\nconst { seen } = pinoErrorSymbols\n\nconst { toString } = Object.prototype\n\nfunction errWithCauseSerializer (err) {\n if (!isErrorLike(err)) {\n return err\n }\n\n err[seen] = undefined // tag to prevent re-looking at this\n const _err = Object.create(pinoErrProto)\n _err.type = toString.call(err.constructor) === '[object Function]'\n ? err.constructor.name\n : err.name\n _err.message = err.message\n _err.stack = err.stack\n\n if (Array.isArray(err.errors)) {\n _err.aggregateErrors = err.errors.map(err => errWithCauseSerializer(err))\n }\n\n if (isErrorLike(err.cause) && !Object.prototype.hasOwnProperty.call(err.cause, seen)) {\n _err.cause = errWithCauseSerializer(err.cause)\n }\n\n for (const key in err) {\n if (_err[key] === undefined) {\n const val = err[key]\n if (isErrorLike(val)) {\n if (!Object.prototype.hasOwnProperty.call(val, seen)) {\n _err[key] = errWithCauseSerializer(val)\n }\n } else {\n _err[key] = val\n }\n }\n }\n\n delete err[seen] // clean up tag in case err is serialized again later\n _err.raw = err\n return _err\n}\n","'use strict'\n\nmodule.exports = {\n mapHttpRequest,\n reqSerializer\n}\n\nconst rawSymbol = Symbol('pino-raw-req-ref')\nconst pinoReqProto = Object.create({}, {\n id: {\n enumerable: true,\n writable: true,\n value: ''\n },\n method: {\n enumerable: true,\n writable: true,\n value: ''\n },\n url: {\n enumerable: true,\n writable: true,\n value: ''\n },\n query: {\n enumerable: true,\n writable: true,\n value: ''\n },\n params: {\n enumerable: true,\n writable: true,\n value: ''\n },\n headers: {\n enumerable: true,\n writable: true,\n value: {}\n },\n remoteAddress: {\n enumerable: true,\n writable: true,\n value: ''\n },\n remotePort: {\n enumerable: true,\n writable: true,\n value: ''\n },\n raw: {\n enumerable: false,\n get: function () {\n return this[rawSymbol]\n },\n set: function (val) {\n this[rawSymbol] = val\n }\n }\n})\nObject.defineProperty(pinoReqProto, rawSymbol, {\n writable: true,\n value: {}\n})\n\nfunction reqSerializer (req) {\n // req.info is for hapi compat.\n const connection = req.info || req.socket\n const _req = Object.create(pinoReqProto)\n _req.id = (typeof req.id === 'function' ? req.id() : (req.id || (req.info ? req.info.id : undefined)))\n _req.method = req.method\n // req.originalUrl is for expressjs compat.\n if (req.originalUrl) {\n _req.url = req.originalUrl\n } else {\n const path = req.path\n // path for safe hapi compat.\n _req.url = typeof path === 'string' ? path : (req.url ? req.url.path || req.url : undefined)\n }\n\n if (req.query) {\n _req.query = req.query\n }\n\n if (req.params) {\n _req.params = req.params\n }\n\n _req.headers = req.headers\n _req.remoteAddress = connection && connection.remoteAddress\n _req.remotePort = connection && connection.remotePort\n // req.raw is for hapi compat/equivalence\n _req.raw = req.raw || req\n return _req\n}\n\nfunction mapHttpRequest (req) {\n return {\n req: reqSerializer(req)\n }\n}\n","'use strict'\n\nmodule.exports = {\n mapHttpResponse,\n resSerializer\n}\n\nconst rawSymbol = Symbol('pino-raw-res-ref')\nconst pinoResProto = Object.create({}, {\n statusCode: {\n enumerable: true,\n writable: true,\n value: 0\n },\n headers: {\n enumerable: true,\n writable: true,\n value: ''\n },\n raw: {\n enumerable: false,\n get: function () {\n return this[rawSymbol]\n },\n set: function (val) {\n this[rawSymbol] = val\n }\n }\n})\nObject.defineProperty(pinoResProto, rawSymbol, {\n writable: true,\n value: {}\n})\n\nfunction resSerializer (res) {\n const _res = Object.create(pinoResProto)\n _res.statusCode = res.headersSent ? res.statusCode : null\n _res.headers = res.getHeaders ? res.getHeaders() : res._headers\n _res.raw = res\n return _res\n}\n\nfunction mapHttpResponse (res) {\n return {\n res: resSerializer(res)\n }\n}\n","'use strict'\n\nconst errSerializer = require('./lib/err')\nconst errWithCauseSerializer = require('./lib/err-with-cause')\nconst reqSerializers = require('./lib/req')\nconst resSerializers = require('./lib/res')\n\nmodule.exports = {\n err: errSerializer,\n errWithCause: errWithCauseSerializer,\n mapHttpRequest: reqSerializers.mapHttpRequest,\n mapHttpResponse: resSerializers.mapHttpResponse,\n req: reqSerializers.reqSerializer,\n res: resSerializers.resSerializer,\n\n wrapErrorSerializer: function wrapErrorSerializer (customSerializer) {\n if (customSerializer === errSerializer) return customSerializer\n return function wrapErrSerializer (err) {\n return customSerializer(errSerializer(err))\n }\n },\n\n wrapRequestSerializer: function wrapRequestSerializer (customSerializer) {\n if (customSerializer === reqSerializers.reqSerializer) return customSerializer\n return function wrappedReqSerializer (req) {\n return customSerializer(reqSerializers.reqSerializer(req))\n }\n },\n\n wrapResponseSerializer: function wrapResponseSerializer (customSerializer) {\n if (customSerializer === resSerializers.resSerializer) return customSerializer\n return function wrappedResSerializer (res) {\n return customSerializer(resSerializers.resSerializer(res))\n }\n }\n}\n","'use strict'\n\nfunction noOpPrepareStackTrace (_, stack) {\n return stack\n}\n\nmodule.exports = function getCallers () {\n const originalPrepare = Error.prepareStackTrace\n Error.prepareStackTrace = noOpPrepareStackTrace\n const stack = new Error().stack\n Error.prepareStackTrace = originalPrepare\n\n if (!Array.isArray(stack)) {\n return undefined\n }\n\n const entries = stack.slice(2)\n\n const fileNames = []\n\n for (const entry of entries) {\n if (!entry) {\n continue\n }\n\n fileNames.push(entry.getFileName())\n }\n\n return fileNames\n}\n","'use strict'\n\nmodule.exports = validator\n\nfunction validator (opts = {}) {\n const {\n ERR_PATHS_MUST_BE_STRINGS = () => 'fast-redact - Paths must be (non-empty) strings',\n ERR_INVALID_PATH = (s) => `fast-redact – Invalid path (${s})`\n } = opts\n\n return function validate ({ paths }) {\n paths.forEach((s) => {\n if (typeof s !== 'string') {\n throw Error(ERR_PATHS_MUST_BE_STRINGS())\n }\n try {\n if (/〇/.test(s)) throw Error()\n const expr = (s[0] === '[' ? '' : '.') + s.replace(/^\\*/, '〇').replace(/\\.\\*/g, '.〇').replace(/\\[\\*\\]/g, '[〇]')\n if (/\\n|\\r|;/.test(expr)) throw Error()\n if (/\\/\\*/.test(expr)) throw Error()\n /* eslint-disable-next-line */\n Function(`\n 'use strict'\n const o = new Proxy({}, { get: () => o, set: () => { throw Error() } });\n const 〇 = null;\n o${expr}\n if ([o${expr}].length !== 1) throw Error()`)()\n } catch (e) {\n throw Error(ERR_INVALID_PATH(s))\n }\n })\n }\n}\n","'use strict'\n\nmodule.exports = /[^.[\\]]+|\\[((?:.)*?)\\]/g\n\n/*\nRegular expression explanation:\n\nAlt 1: /[^.[\\]]+/ - Match one or more characters that are *not* a dot (.)\n opening square bracket ([) or closing square bracket (])\n\nAlt 2: /\\[((?:.)*?)\\]/ - If the char IS dot or square bracket, then create a capture\n group (which will be capture group $1) that matches anything\n within square brackets. Expansion is lazy so it will\n stop matching as soon as the first closing bracket is met `]`\n (rather than continuing to match until the final closing bracket).\n*/\n","'use strict'\n\nconst rx = require('./rx')\n\nmodule.exports = parse\n\nfunction parse ({ paths }) {\n const wildcards = []\n var wcLen = 0\n const secret = paths.reduce(function (o, strPath, ix) {\n var path = strPath.match(rx).map((p) => p.replace(/'|\"|`/g, ''))\n const leadingBracket = strPath[0] === '['\n path = path.map((p) => {\n if (p[0] === '[') return p.substr(1, p.length - 2)\n else return p\n })\n const star = path.indexOf('*')\n if (star > -1) {\n const before = path.slice(0, star)\n const beforeStr = before.join('.')\n const after = path.slice(star + 1, path.length)\n const nested = after.length > 0\n wcLen++\n wildcards.push({\n before,\n beforeStr,\n after,\n nested\n })\n } else {\n o[strPath] = {\n path: path,\n val: undefined,\n precensored: false,\n circle: '',\n escPath: JSON.stringify(strPath),\n leadingBracket: leadingBracket\n }\n }\n return o\n }, {})\n\n return { wildcards, wcLen, secret }\n}\n","'use strict'\n\nconst rx = require('./rx')\n\nmodule.exports = redactor\n\nfunction redactor ({ secret, serialize, wcLen, strict, isCensorFct, censorFctTakesPath }, state) {\n /* eslint-disable-next-line */\n const redact = Function('o', `\n if (typeof o !== 'object' || o == null) {\n ${strictImpl(strict, serialize)}\n }\n const { censor, secret } = this\n const originalSecret = {}\n const secretKeys = Object.keys(secret)\n for (var i = 0; i < secretKeys.length; i++) {\n originalSecret[secretKeys[i]] = secret[secretKeys[i]]\n }\n\n ${redactTmpl(secret, isCensorFct, censorFctTakesPath)}\n this.compileRestore()\n ${dynamicRedactTmpl(wcLen > 0, isCensorFct, censorFctTakesPath)}\n this.secret = originalSecret\n ${resultTmpl(serialize)}\n `).bind(state)\n\n redact.state = state\n\n if (serialize === false) {\n redact.restore = (o) => state.restore(o)\n }\n\n return redact\n}\n\nfunction redactTmpl (secret, isCensorFct, censorFctTakesPath) {\n return Object.keys(secret).map((path) => {\n const { escPath, leadingBracket, path: arrPath } = secret[path]\n const skip = leadingBracket ? 1 : 0\n const delim = leadingBracket ? '' : '.'\n const hops = []\n var match\n while ((match = rx.exec(path)) !== null) {\n const [ , ix ] = match\n const { index, input } = match\n if (index > skip) hops.push(input.substring(0, index - (ix ? 0 : 1)))\n }\n var existence = hops.map((p) => `o${delim}${p}`).join(' && ')\n if (existence.length === 0) existence += `o${delim}${path} != null`\n else existence += ` && o${delim}${path} != null`\n\n const circularDetection = `\n switch (true) {\n ${hops.reverse().map((p) => `\n case o${delim}${p} === censor:\n secret[${escPath}].circle = ${JSON.stringify(p)}\n break\n `).join('\\n')}\n }\n `\n\n const censorArgs = censorFctTakesPath\n ? `val, ${JSON.stringify(arrPath)}`\n : `val`\n\n return `\n if (${existence}) {\n const val = o${delim}${path}\n if (val === censor) {\n secret[${escPath}].precensored = true\n } else {\n secret[${escPath}].val = val\n o${delim}${path} = ${isCensorFct ? `censor(${censorArgs})` : 'censor'}\n ${circularDetection}\n }\n }\n `\n }).join('\\n')\n}\n\nfunction dynamicRedactTmpl (hasWildcards, isCensorFct, censorFctTakesPath) {\n return hasWildcards === true ? `\n {\n const { wildcards, wcLen, groupRedact, nestedRedact } = this\n for (var i = 0; i < wcLen; i++) {\n const { before, beforeStr, after, nested } = wildcards[i]\n if (nested === true) {\n secret[beforeStr] = secret[beforeStr] || []\n nestedRedact(secret[beforeStr], o, before, after, censor, ${isCensorFct}, ${censorFctTakesPath})\n } else secret[beforeStr] = groupRedact(o, before, censor, ${isCensorFct}, ${censorFctTakesPath})\n }\n }\n ` : ''\n}\n\nfunction resultTmpl (serialize) {\n return serialize === false ? `return o` : `\n var s = this.serialize(o)\n this.restore(o)\n return s\n `\n}\n\nfunction strictImpl (strict, serialize) {\n return strict === true\n ? `throw Error('fast-redact: primitives cannot be redacted')`\n : serialize === false ? `return o` : `return this.serialize(o)`\n}\n","'use strict'\n\nmodule.exports = {\n groupRedact,\n groupRestore,\n nestedRedact,\n nestedRestore\n}\n\nfunction groupRestore ({ keys, values, target }) {\n if (target == null || typeof target === 'string') return\n const length = keys.length\n for (var i = 0; i < length; i++) {\n const k = keys[i]\n target[k] = values[i]\n }\n}\n\nfunction groupRedact (o, path, censor, isCensorFct, censorFctTakesPath) {\n const target = get(o, path)\n if (target == null || typeof target === 'string') return { keys: null, values: null, target, flat: true }\n const keys = Object.keys(target)\n const keysLength = keys.length\n const pathLength = path.length\n const pathWithKey = censorFctTakesPath ? [...path] : undefined\n const values = new Array(keysLength)\n\n for (var i = 0; i < keysLength; i++) {\n const key = keys[i]\n values[i] = target[key]\n\n if (censorFctTakesPath) {\n pathWithKey[pathLength] = key\n target[key] = censor(target[key], pathWithKey)\n } else if (isCensorFct) {\n target[key] = censor(target[key])\n } else {\n target[key] = censor\n }\n }\n return { keys, values, target, flat: true }\n}\n\n/**\n * @param {RestoreInstruction[]} instructions a set of instructions for restoring values to objects\n */\nfunction nestedRestore (instructions) {\n for (let i = 0; i < instructions.length; i++) {\n const { target, path, value } = instructions[i]\n let current = target\n for (let i = path.length - 1; i > 0; i--) {\n current = current[path[i]]\n }\n current[path[0]] = value\n }\n}\n\nfunction nestedRedact (store, o, path, ns, censor, isCensorFct, censorFctTakesPath) {\n const target = get(o, path)\n if (target == null) return\n const keys = Object.keys(target)\n const keysLength = keys.length\n for (var i = 0; i < keysLength; i++) {\n const key = keys[i]\n specialSet(store, target, key, path, ns, censor, isCensorFct, censorFctTakesPath)\n }\n return store\n}\n\nfunction has (obj, prop) {\n return obj !== undefined && obj !== null\n ? ('hasOwn' in Object ? Object.hasOwn(obj, prop) : Object.prototype.hasOwnProperty.call(obj, prop))\n : false\n}\n\nfunction specialSet (store, o, k, path, afterPath, censor, isCensorFct, censorFctTakesPath) {\n const afterPathLen = afterPath.length\n const lastPathIndex = afterPathLen - 1\n const originalKey = k\n var i = -1\n var n\n var nv\n var ov\n var oov = null\n var wc = null\n var kIsWc\n var wcov\n var consecutive = false\n var level = 0\n // need to track depth of the `redactPath` tree\n var depth = 0\n var redactPathCurrent = tree()\n ov = n = o[k]\n if (typeof n !== 'object') return\n while (n != null && ++i < afterPathLen) {\n depth += 1\n k = afterPath[i]\n oov = ov\n if (k !== '*' && !wc && !(typeof n === 'object' && k in n)) {\n break\n }\n if (k === '*') {\n if (wc === '*') {\n consecutive = true\n }\n wc = k\n if (i !== lastPathIndex) {\n continue\n }\n }\n if (wc) {\n const wcKeys = Object.keys(n)\n for (var j = 0; j < wcKeys.length; j++) {\n const wck = wcKeys[j]\n wcov = n[wck]\n kIsWc = k === '*'\n if (consecutive) {\n redactPathCurrent = node(redactPathCurrent, wck, depth)\n level = i\n ov = iterateNthLevel(wcov, level - 1, k, path, afterPath, censor, isCensorFct, censorFctTakesPath, originalKey, n, nv, ov, kIsWc, wck, i, lastPathIndex, redactPathCurrent, store, o[originalKey], depth + 1)\n } else {\n if (kIsWc || (typeof wcov === 'object' && wcov !== null && k in wcov)) {\n if (kIsWc) {\n ov = wcov\n } else {\n ov = wcov[k]\n }\n nv = (i !== lastPathIndex)\n ? ov\n : (isCensorFct\n ? (censorFctTakesPath ? censor(ov, [...path, originalKey, ...afterPath]) : censor(ov))\n : censor)\n if (kIsWc) {\n const rv = restoreInstr(node(redactPathCurrent, wck, depth), ov, o[originalKey])\n store.push(rv)\n n[wck] = nv\n } else {\n if (wcov[k] === nv) {\n // pass\n } else if ((nv === undefined && censor !== undefined) || (has(wcov, k) && nv === ov)) {\n redactPathCurrent = node(redactPathCurrent, wck, depth)\n } else {\n redactPathCurrent = node(redactPathCurrent, wck, depth)\n const rv = restoreInstr(node(redactPathCurrent, k, depth + 1), ov, o[originalKey])\n store.push(rv)\n wcov[k] = nv\n }\n }\n }\n }\n }\n wc = null\n } else {\n ov = n[k]\n redactPathCurrent = node(redactPathCurrent, k, depth)\n nv = (i !== lastPathIndex)\n ? ov\n : (isCensorFct\n ? (censorFctTakesPath ? censor(ov, [...path, originalKey, ...afterPath]) : censor(ov))\n : censor)\n if ((has(n, k) && nv === ov) || (nv === undefined && censor !== undefined)) {\n // pass\n } else {\n const rv = restoreInstr(redactPathCurrent, ov, o[originalKey])\n store.push(rv)\n n[k] = nv\n }\n n = n[k]\n }\n if (typeof n !== 'object') break\n // prevent circular structure, see https://github.com/pinojs/pino/issues/1513\n if (ov === oov || typeof ov === 'undefined') {\n // pass\n }\n }\n}\n\nfunction get (o, p) {\n var i = -1\n var l = p.length\n var n = o\n while (n != null && ++i < l) {\n n = n[p[i]]\n }\n return n\n}\n\nfunction iterateNthLevel (wcov, level, k, path, afterPath, censor, isCensorFct, censorFctTakesPath, originalKey, n, nv, ov, kIsWc, wck, i, lastPathIndex, redactPathCurrent, store, parent, depth) {\n if (level === 0) {\n if (kIsWc || (typeof wcov === 'object' && wcov !== null && k in wcov)) {\n if (kIsWc) {\n ov = wcov\n } else {\n ov = wcov[k]\n }\n nv = (i !== lastPathIndex)\n ? ov\n : (isCensorFct\n ? (censorFctTakesPath ? censor(ov, [...path, originalKey, ...afterPath]) : censor(ov))\n : censor)\n if (kIsWc) {\n const rv = restoreInstr(redactPathCurrent, ov, parent)\n store.push(rv)\n n[wck] = nv\n } else {\n if (wcov[k] === nv) {\n // pass\n } else if ((nv === undefined && censor !== undefined) || (has(wcov, k) && nv === ov)) {\n // pass\n } else {\n const rv = restoreInstr(node(redactPathCurrent, k, depth + 1), ov, parent)\n store.push(rv)\n wcov[k] = nv\n }\n }\n }\n }\n for (const key in wcov) {\n if (typeof wcov[key] === 'object') {\n redactPathCurrent = node(redactPathCurrent, key, depth)\n iterateNthLevel(wcov[key], level - 1, k, path, afterPath, censor, isCensorFct, censorFctTakesPath, originalKey, n, nv, ov, kIsWc, wck, i, lastPathIndex, redactPathCurrent, store, parent, depth + 1)\n }\n }\n}\n\n/**\n * @typedef {object} TreeNode\n * @prop {TreeNode} [parent] reference to the parent of this node in the tree, or `null` if there is no parent\n * @prop {string} key the key that this node represents (key here being part of the path being redacted\n * @prop {TreeNode[]} children the child nodes of this node\n * @prop {number} depth the depth of this node in the tree\n */\n\n/**\n * instantiate a new, empty tree\n * @returns {TreeNode}\n */\nfunction tree () {\n return { parent: null, key: null, children: [], depth: 0 }\n}\n\n/**\n * creates a new node in the tree, attaching it as a child of the provided parent node\n * if the specified depth matches the parent depth, adds the new node as a _sibling_ of the parent instead\n * @param {TreeNode} parent the parent node to add a new node to (if the parent depth matches the provided `depth` value, will instead add as a sibling of this\n * @param {string} key the key that the new node represents (key here being part of the path being redacted)\n * @param {number} depth the depth of the new node in the tree - used to determing whether to add the new node as a child or sibling of the provided `parent` node\n * @returns {TreeNode} a reference to the newly created node in the tree\n */\nfunction node (parent, key, depth) {\n if (parent.depth === depth) {\n return node(parent.parent, key, depth)\n }\n\n var child = {\n parent,\n key,\n depth,\n children: []\n }\n\n parent.children.push(child)\n\n return child\n}\n\n/**\n * @typedef {object} RestoreInstruction\n * @prop {string[]} path a reverse-order path that can be used to find the correct insertion point to restore a `value` for the given `parent` object\n * @prop {*} value the value to restore\n * @prop {object} target the object to restore the `value` in\n */\n\n/**\n * create a restore instruction for the given redactPath node\n * generates a path in reverse order by walking up the redactPath tree\n * @param {TreeNode} node a tree node that should be at the bottom of the redact path (i.e. have no children) - this will be used to walk up the redact path tree to construct the path needed to restore\n * @param {*} value the value to restore\n * @param {object} target a reference to the parent object to apply the restore instruction to\n * @returns {RestoreInstruction} an instruction used to restore a nested value for a specific object\n */\nfunction restoreInstr (node, value, target) {\n let current = node\n const path = []\n do {\n path.push(current.key)\n current = current.parent\n } while (current.parent != null)\n\n return { path, value, target }\n}\n","'use strict'\n\nconst { groupRestore, nestedRestore } = require('./modifiers')\n\nmodule.exports = restorer\n\nfunction restorer () {\n return function compileRestore () {\n if (this.restore) {\n this.restore.state.secret = this.secret\n return\n }\n const { secret, wcLen } = this\n const paths = Object.keys(secret)\n const resetters = resetTmpl(secret, paths)\n const hasWildcards = wcLen > 0\n const state = hasWildcards ? { secret, groupRestore, nestedRestore } : { secret }\n /* eslint-disable-next-line */\n this.restore = Function(\n 'o',\n restoreTmpl(resetters, paths, hasWildcards)\n ).bind(state)\n this.restore.state = state\n }\n}\n\n/**\n * Mutates the original object to be censored by restoring its original values\n * prior to censoring.\n *\n * @param {object} secret Compiled object describing which target fields should\n * be censored and the field states.\n * @param {string[]} paths The list of paths to censor as provided at\n * initialization time.\n *\n * @returns {string} String of JavaScript to be used by `Function()`. The\n * string compiles to the function that does the work in the description.\n */\nfunction resetTmpl (secret, paths) {\n return paths.map((path) => {\n const { circle, escPath, leadingBracket } = secret[path]\n const delim = leadingBracket ? '' : '.'\n const reset = circle\n ? `o.${circle} = secret[${escPath}].val`\n : `o${delim}${path} = secret[${escPath}].val`\n const clear = `secret[${escPath}].val = undefined`\n return `\n if (secret[${escPath}].val !== undefined) {\n try { ${reset} } catch (e) {}\n ${clear}\n }\n `\n }).join('')\n}\n\n/**\n * Creates the body of the restore function\n *\n * Restoration of the redacted object happens\n * backwards, in reverse order of redactions,\n * so that repeated redactions on the same object\n * property can be eventually rolled back to the\n * original value.\n *\n * This way dynamic redactions are restored first,\n * starting from the last one working backwards and\n * followed by the static ones.\n *\n * @returns {string} the body of the restore function\n */\nfunction restoreTmpl (resetters, paths, hasWildcards) {\n const dynamicReset = hasWildcards === true ? `\n const keys = Object.keys(secret)\n const len = keys.length\n for (var i = len - 1; i >= ${paths.length}; i--) {\n const k = keys[i]\n const o = secret[k]\n if (o) {\n if (o.flat === true) this.groupRestore(o)\n else this.nestedRestore(o)\n secret[k] = null\n }\n }\n ` : ''\n\n return `\n const secret = this.secret\n ${dynamicReset}\n ${resetters}\n return o\n `\n}\n","'use strict'\n\nmodule.exports = state\n\nfunction state (o) {\n const {\n secret,\n censor,\n compileRestore,\n serialize,\n groupRedact,\n nestedRedact,\n wildcards,\n wcLen\n } = o\n const builder = [{ secret, censor, compileRestore }]\n if (serialize !== false) builder.push({ serialize })\n if (wcLen > 0) builder.push({ groupRedact, nestedRedact, wildcards, wcLen })\n return Object.assign(...builder)\n}\n","'use strict'\n\nconst validator = require('./lib/validator')\nconst parse = require('./lib/parse')\nconst redactor = require('./lib/redactor')\nconst restorer = require('./lib/restorer')\nconst { groupRedact, nestedRedact } = require('./lib/modifiers')\nconst state = require('./lib/state')\nconst rx = require('./lib/rx')\nconst validate = validator()\nconst noop = (o) => o\nnoop.restore = noop\n\nconst DEFAULT_CENSOR = '[REDACTED]'\nfastRedact.rx = rx\nfastRedact.validator = validator\n\nmodule.exports = fastRedact\n\nfunction fastRedact (opts = {}) {\n const paths = Array.from(new Set(opts.paths || []))\n const serialize = 'serialize' in opts ? (\n opts.serialize === false ? opts.serialize\n : (typeof opts.serialize === 'function' ? opts.serialize : JSON.stringify)\n ) : JSON.stringify\n const remove = opts.remove\n if (remove === true && serialize !== JSON.stringify) {\n throw Error('fast-redact – remove option may only be set when serializer is JSON.stringify')\n }\n const censor = remove === true\n ? undefined\n : 'censor' in opts ? opts.censor : DEFAULT_CENSOR\n\n const isCensorFct = typeof censor === 'function'\n const censorFctTakesPath = isCensorFct && censor.length > 1\n\n if (paths.length === 0) return serialize || noop\n\n validate({ paths, serialize, censor })\n\n const { wildcards, wcLen, secret } = parse({ paths, censor })\n\n const compileRestore = restorer()\n const strict = 'strict' in opts ? opts.strict : true\n\n return redactor({ secret, wcLen, serialize, strict, isCensorFct, censorFctTakesPath }, state({\n secret,\n censor,\n compileRestore,\n serialize,\n groupRedact,\n nestedRedact,\n wildcards,\n wcLen\n }))\n}\n","'use strict'\n\nconst setLevelSym = Symbol('pino.setLevel')\nconst getLevelSym = Symbol('pino.getLevel')\nconst levelValSym = Symbol('pino.levelVal')\nconst levelCompSym = Symbol('pino.levelComp')\nconst useLevelLabelsSym = Symbol('pino.useLevelLabels')\nconst useOnlyCustomLevelsSym = Symbol('pino.useOnlyCustomLevels')\nconst mixinSym = Symbol('pino.mixin')\n\nconst lsCacheSym = Symbol('pino.lsCache')\nconst chindingsSym = Symbol('pino.chindings')\n\nconst asJsonSym = Symbol('pino.asJson')\nconst writeSym = Symbol('pino.write')\nconst redactFmtSym = Symbol('pino.redactFmt')\n\nconst timeSym = Symbol('pino.time')\nconst timeSliceIndexSym = Symbol('pino.timeSliceIndex')\nconst streamSym = Symbol('pino.stream')\nconst stringifySym = Symbol('pino.stringify')\nconst stringifySafeSym = Symbol('pino.stringifySafe')\nconst stringifiersSym = Symbol('pino.stringifiers')\nconst endSym = Symbol('pino.end')\nconst formatOptsSym = Symbol('pino.formatOpts')\nconst messageKeySym = Symbol('pino.messageKey')\nconst errorKeySym = Symbol('pino.errorKey')\nconst nestedKeySym = Symbol('pino.nestedKey')\nconst nestedKeyStrSym = Symbol('pino.nestedKeyStr')\nconst mixinMergeStrategySym = Symbol('pino.mixinMergeStrategy')\nconst msgPrefixSym = Symbol('pino.msgPrefix')\n\nconst wildcardFirstSym = Symbol('pino.wildcardFirst')\n\n// public symbols, no need to use the same pino\n// version for these\nconst serializersSym = Symbol.for('pino.serializers')\nconst formattersSym = Symbol.for('pino.formatters')\nconst hooksSym = Symbol.for('pino.hooks')\nconst needsMetadataGsym = Symbol.for('pino.metadata')\n\nmodule.exports = {\n setLevelSym,\n getLevelSym,\n levelValSym,\n levelCompSym,\n useLevelLabelsSym,\n mixinSym,\n lsCacheSym,\n chindingsSym,\n asJsonSym,\n writeSym,\n serializersSym,\n redactFmtSym,\n timeSym,\n timeSliceIndexSym,\n streamSym,\n stringifySym,\n stringifySafeSym,\n stringifiersSym,\n endSym,\n formatOptsSym,\n messageKeySym,\n errorKeySym,\n nestedKeySym,\n wildcardFirstSym,\n needsMetadataGsym,\n useOnlyCustomLevelsSym,\n formattersSym,\n hooksSym,\n nestedKeyStrSym,\n mixinMergeStrategySym,\n msgPrefixSym\n}\n","'use strict'\n\nconst fastRedact = require('fast-redact')\nconst { redactFmtSym, wildcardFirstSym } = require('./symbols')\nconst { rx, validator } = fastRedact\n\nconst validate = validator({\n ERR_PATHS_MUST_BE_STRINGS: () => 'pino – redacted paths must be strings',\n ERR_INVALID_PATH: (s) => `pino – redact paths array contains an invalid path (${s})`\n})\n\nconst CENSOR = '[Redacted]'\nconst strict = false // TODO should this be configurable?\n\nfunction redaction (opts, serialize) {\n const { paths, censor } = handle(opts)\n\n const shape = paths.reduce((o, str) => {\n rx.lastIndex = 0\n const first = rx.exec(str)\n const next = rx.exec(str)\n\n // ns is the top-level path segment, brackets + quoting removed.\n let ns = first[1] !== undefined\n ? first[1].replace(/^(?:\"|'|`)(.*)(?:\"|'|`)$/, '$1')\n : first[0]\n\n if (ns === '*') {\n ns = wildcardFirstSym\n }\n\n // top level key:\n if (next === null) {\n o[ns] = null\n return o\n }\n\n // path with at least two segments:\n // if ns is already redacted at the top level, ignore lower level redactions\n if (o[ns] === null) {\n return o\n }\n\n const { index } = next\n const nextPath = `${str.substr(index, str.length - 1)}`\n\n o[ns] = o[ns] || []\n\n // shape is a mix of paths beginning with literal values and wildcard\n // paths [ \"a.b.c\", \"*.b.z\" ] should reduce to a shape of\n // { \"a\": [ \"b.c\", \"b.z\" ], *: [ \"b.z\" ] }\n // note: \"b.z\" is in both \"a\" and * arrays because \"a\" matches the wildcard.\n // (* entry has wildcardFirstSym as key)\n if (ns !== wildcardFirstSym && o[ns].length === 0) {\n // first time ns's get all '*' redactions so far\n o[ns].push(...(o[wildcardFirstSym] || []))\n }\n\n if (ns === wildcardFirstSym) {\n // new * path gets added to all previously registered literal ns's.\n Object.keys(o).forEach(function (k) {\n if (o[k]) {\n o[k].push(nextPath)\n }\n })\n }\n\n o[ns].push(nextPath)\n return o\n }, {})\n\n // the redactor assigned to the format symbol key\n // provides top level redaction for instances where\n // an object is interpolated into the msg string\n const result = {\n [redactFmtSym]: fastRedact({ paths, censor, serialize, strict })\n }\n\n const topCensor = (...args) => {\n return typeof censor === 'function' ? serialize(censor(...args)) : serialize(censor)\n }\n\n return [...Object.keys(shape), ...Object.getOwnPropertySymbols(shape)].reduce((o, k) => {\n // top level key:\n if (shape[k] === null) {\n o[k] = (value) => topCensor(value, [k])\n } else {\n const wrappedCensor = typeof censor === 'function'\n ? (value, path) => {\n return censor(value, [k, ...path])\n }\n : censor\n o[k] = fastRedact({\n paths: shape[k],\n censor: wrappedCensor,\n serialize,\n strict\n })\n }\n return o\n }, result)\n}\n\nfunction handle (opts) {\n if (Array.isArray(opts)) {\n opts = { paths: opts, censor: CENSOR }\n validate(opts)\n return opts\n }\n let { paths, censor = CENSOR, remove } = opts\n if (Array.isArray(paths) === false) { throw Error('pino – redact must contain an array of strings') }\n if (remove === true) censor = undefined\n validate({ paths, censor })\n\n return { paths, censor }\n}\n\nmodule.exports = redaction\n","'use strict'\n\nconst nullTime = () => ''\n\nconst epochTime = () => `,\"time\":${Date.now()}`\n\nconst unixTime = () => `,\"time\":${Math.round(Date.now() / 1000.0)}`\n\nconst isoTime = () => `,\"time\":\"${new Date(Date.now()).toISOString()}\"` // using Date.now() for testability\n\nmodule.exports = { nullTime, epochTime, unixTime, isoTime }\n","'use strict'\nfunction tryStringify (o) {\n try { return JSON.stringify(o) } catch(e) { return '\"[Circular]\"' }\n}\n\nmodule.exports = format\n\nfunction format(f, args, opts) {\n var ss = (opts && opts.stringify) || tryStringify\n var offset = 1\n if (typeof f === 'object' && f !== null) {\n var len = args.length + offset\n if (len === 1) return f\n var objects = new Array(len)\n objects[0] = ss(f)\n for (var index = 1; index < len; index++) {\n objects[index] = ss(args[index])\n }\n return objects.join(' ')\n }\n if (typeof f !== 'string') {\n return f\n }\n var argLen = args.length\n if (argLen === 0) return f\n var str = ''\n var a = 1 - offset\n var lastPos = -1\n var flen = (f && f.length) || 0\n for (var i = 0; i < flen;) {\n if (f.charCodeAt(i) === 37 && i + 1 < flen) {\n lastPos = lastPos > -1 ? lastPos : 0\n switch (f.charCodeAt(i + 1)) {\n case 100: // 'd'\n case 102: // 'f'\n if (a >= argLen)\n break\n if (args[a] == null) break\n if (lastPos < i)\n str += f.slice(lastPos, i)\n str += Number(args[a])\n lastPos = i + 2\n i++\n break\n case 105: // 'i'\n if (a >= argLen)\n break\n if (args[a] == null) break\n if (lastPos < i)\n str += f.slice(lastPos, i)\n str += Math.floor(Number(args[a]))\n lastPos = i + 2\n i++\n break\n case 79: // 'O'\n case 111: // 'o'\n case 106: // 'j'\n if (a >= argLen)\n break\n if (args[a] === undefined) break\n if (lastPos < i)\n str += f.slice(lastPos, i)\n var type = typeof args[a]\n if (type === 'string') {\n str += '\\'' + args[a] + '\\''\n lastPos = i + 2\n i++\n break\n }\n if (type === 'function') {\n str += args[a].name || '<anonymous>'\n lastPos = i + 2\n i++\n break\n }\n str += ss(args[a])\n lastPos = i + 2\n i++\n break\n case 115: // 's'\n if (a >= argLen)\n break\n if (lastPos < i)\n str += f.slice(lastPos, i)\n str += String(args[a])\n lastPos = i + 2\n i++\n break\n case 37: // '%'\n if (lastPos < i)\n str += f.slice(lastPos, i)\n str += '%'\n lastPos = i + 2\n i++\n a--\n break\n }\n ++a\n }\n ++i\n }\n if (lastPos === -1)\n return f\n else if (lastPos < flen) {\n str += f.slice(lastPos)\n }\n\n return str\n}\n","'use strict'\n\n/* global SharedArrayBuffer, Atomics */\n\nif (typeof SharedArrayBuffer !== 'undefined' && typeof Atomics !== 'undefined') {\n const nil = new Int32Array(new SharedArrayBuffer(4))\n\n function sleep (ms) {\n // also filters out NaN, non-number types, including empty strings, but allows bigints\n const valid = ms > 0 && ms < Infinity \n if (valid === false) {\n if (typeof ms !== 'number' && typeof ms !== 'bigint') {\n throw TypeError('sleep: ms must be a number')\n }\n throw RangeError('sleep: ms must be a number that is greater than 0 but less than Infinity')\n }\n\n Atomics.wait(nil, 0, 0, Number(ms))\n }\n module.exports = sleep\n} else {\n\n function sleep (ms) {\n // also filters out NaN, non-number types, including empty strings, but allows bigints\n const valid = ms > 0 && ms < Infinity \n if (valid === false) {\n if (typeof ms !== 'number' && typeof ms !== 'bigint') {\n throw TypeError('sleep: ms must be a number')\n }\n throw RangeError('sleep: ms must be a number that is greater than 0 but less than Infinity')\n }\n const target = Date.now() + Number(ms)\n while (target > Date.now()){}\n }\n\n module.exports = sleep\n\n}\n","'use strict'\n\nconst fs = require('fs')\nconst EventEmitter = require('events')\nconst inherits = require('util').inherits\nconst path = require('path')\nconst sleep = require('atomic-sleep')\nconst assert = require('assert')\n\nconst BUSY_WRITE_TIMEOUT = 100\nconst kEmptyBuffer = Buffer.allocUnsafe(0)\n\n// 16 KB. Don't write more than docker buffer size.\n// https://github.com/moby/moby/blob/513ec73831269947d38a644c278ce3cac36783b2/daemon/logger/copier.go#L13\nconst MAX_WRITE = 16 * 1024\n\nconst kContentModeBuffer = 'buffer'\nconst kContentModeUtf8 = 'utf8'\n\nconst [major, minor] = (process.versions.node || '0.0').split('.').map(Number)\nconst kCopyBuffer = major >= 22 && minor >= 7\n\nfunction openFile (file, sonic) {\n sonic._opening = true\n sonic._writing = true\n sonic._asyncDrainScheduled = false\n\n // NOTE: 'error' and 'ready' events emitted below only relevant when sonic.sync===false\n // for sync mode, there is no way to add a listener that will receive these\n\n function fileOpened (err, fd) {\n if (err) {\n sonic._reopening = false\n sonic._writing = false\n sonic._opening = false\n\n if (sonic.sync) {\n process.nextTick(() => {\n if (sonic.listenerCount('error') > 0) {\n sonic.emit('error', err)\n }\n })\n } else {\n sonic.emit('error', err)\n }\n return\n }\n\n const reopening = sonic._reopening\n\n sonic.fd = fd\n sonic.file = file\n sonic._reopening = false\n sonic._opening = false\n sonic._writing = false\n\n if (sonic.sync) {\n process.nextTick(() => sonic.emit('ready'))\n } else {\n sonic.emit('ready')\n }\n\n if (sonic.destroyed) {\n return\n }\n\n // start\n if ((!sonic._writing && sonic._len > sonic.minLength) || sonic._flushPending) {\n sonic._actualWrite()\n } else if (reopening) {\n process.nextTick(() => sonic.emit('drain'))\n }\n }\n\n const flags = sonic.append ? 'a' : 'w'\n const mode = sonic.mode\n\n if (sonic.sync) {\n try {\n if (sonic.mkdir) fs.mkdirSync(path.dirname(file), { recursive: true })\n const fd = fs.openSync(file, flags, mode)\n fileOpened(null, fd)\n } catch (err) {\n fileOpened(err)\n throw err\n }\n } else if (sonic.mkdir) {\n fs.mkdir(path.dirname(file), { recursive: true }, (err) => {\n if (err) return fileOpened(err)\n fs.open(file, flags, mode, fileOpened)\n })\n } else {\n fs.open(file, flags, mode, fileOpened)\n }\n}\n\nfunction SonicBoom (opts) {\n if (!(this instanceof SonicBoom)) {\n return new SonicBoom(opts)\n }\n\n let { fd, dest, minLength, maxLength, maxWrite, periodicFlush, sync, append = true, mkdir, retryEAGAIN, fsync, contentMode, mode } = opts || {}\n\n fd = fd || dest\n\n this._len = 0\n this.fd = -1\n this._bufs = []\n this._lens = []\n this._writing = false\n this._ending = false\n this._reopening = false\n this._asyncDrainScheduled = false\n this._flushPending = false\n this._hwm = Math.max(minLength || 0, 16387)\n this.file = null\n this.destroyed = false\n this.minLength = minLength || 0\n this.maxLength = maxLength || 0\n this.maxWrite = maxWrite || MAX_WRITE\n this._periodicFlush = periodicFlush || 0\n this._periodicFlushTimer = undefined\n this.sync = sync || false\n this.writable = true\n this._fsync = fsync || false\n this.append = append || false\n this.mode = mode\n this.retryEAGAIN = retryEAGAIN || (() => true)\n this.mkdir = mkdir || false\n\n let fsWriteSync\n let fsWrite\n if (contentMode === kContentModeBuffer) {\n this._writingBuf = kEmptyBuffer\n this.write = writeBuffer\n this.flush = flushBuffer\n this.flushSync = flushBufferSync\n this._actualWrite = actualWriteBuffer\n fsWriteSync = () => fs.writeSync(this.fd, this._writingBuf)\n fsWrite = () => fs.write(this.fd, this._writingBuf, this.release)\n } else if (contentMode === undefined || contentMode === kContentModeUtf8) {\n this._writingBuf = ''\n this.write = write\n this.flush = flush\n this.flushSync = flushSync\n this._actualWrite = actualWrite\n fsWriteSync = () => fs.writeSync(this.fd, this._writingBuf, 'utf8')\n fsWrite = () => fs.write(this.fd, this._writingBuf, 'utf8', this.release)\n } else {\n throw new Error(`SonicBoom supports \"${kContentModeUtf8}\" and \"${kContentModeBuffer}\", but passed ${contentMode}`)\n }\n\n if (typeof fd === 'number') {\n this.fd = fd\n process.nextTick(() => this.emit('ready'))\n } else if (typeof fd === 'string') {\n openFile(fd, this)\n } else {\n throw new Error('SonicBoom supports only file descriptors and files')\n }\n if (this.minLength >= this.maxWrite) {\n throw new Error(`minLength should be smaller than maxWrite (${this.maxWrite})`)\n }\n\n this.release = (err, n) => {\n if (err) {\n if ((err.code === 'EAGAIN' || err.code === 'EBUSY') && this.retryEAGAIN(err, this._writingBuf.length, this._len - this._writingBuf.length)) {\n if (this.sync) {\n // This error code should not happen in sync mode, because it is\n // not using the underlining operating system asynchronous functions.\n // However it happens, and so we handle it.\n // Ref: https://github.com/pinojs/pino/issues/783\n try {\n sleep(BUSY_WRITE_TIMEOUT)\n this.release(undefined, 0)\n } catch (err) {\n this.release(err)\n }\n } else {\n // Let's give the destination some time to process the chunk.\n setTimeout(fsWrite, BUSY_WRITE_TIMEOUT)\n }\n } else {\n this._writing = false\n\n this.emit('error', err)\n }\n return\n }\n\n this.emit('write', n)\n const releasedBufObj = releaseWritingBuf(this._writingBuf, this._len, n)\n this._len = releasedBufObj.len\n this._writingBuf = releasedBufObj.writingBuf\n\n if (this._writingBuf.length) {\n if (!this.sync) {\n fsWrite()\n return\n }\n\n try {\n do {\n const n = fsWriteSync()\n const releasedBufObj = releaseWritingBuf(this._writingBuf, this._len, n)\n this._len = releasedBufObj.len\n this._writingBuf = releasedBufObj.writingBuf\n } while (this._writingBuf.length)\n } catch (err) {\n this.release(err)\n return\n }\n }\n\n if (this._fsync) {\n fs.fsyncSync(this.fd)\n }\n\n const len = this._len\n if (this._reopening) {\n this._writing = false\n this._reopening = false\n this.reopen()\n } else if (len > this.minLength) {\n this._actualWrite()\n } else if (this._ending) {\n if (len > 0) {\n this._actualWrite()\n } else {\n this._writing = false\n actualClose(this)\n }\n } else {\n this._writing = false\n if (this.sync) {\n if (!this._asyncDrainScheduled) {\n this._asyncDrainScheduled = true\n process.nextTick(emitDrain, this)\n }\n } else {\n this.emit('drain')\n }\n }\n }\n\n this.on('newListener', function (name) {\n if (name === 'drain') {\n this._asyncDrainScheduled = false\n }\n })\n\n if (this._periodicFlush !== 0) {\n this._periodicFlushTimer = setInterval(() => this.flush(null), this._periodicFlush)\n this._periodicFlushTimer.unref()\n }\n}\n\n/**\n * Release the writingBuf after fs.write n bytes data\n * @param {string | Buffer} writingBuf - currently writing buffer, usually be instance._writingBuf.\n * @param {number} len - currently buffer length, usually be instance._len.\n * @param {number} n - number of bytes fs already written\n * @returns {{writingBuf: string | Buffer, len: number}} released writingBuf and length\n */\nfunction releaseWritingBuf (writingBuf, len, n) {\n // if Buffer.byteLength is equal to n, that means writingBuf contains no multi-byte character\n if (typeof writingBuf === 'string' && Buffer.byteLength(writingBuf) !== n) {\n // Since the fs.write callback parameter `n` means how many bytes the passed of string\n // We calculate the original string length for avoiding the multi-byte character issue\n n = Buffer.from(writingBuf).subarray(0, n).toString().length\n }\n len = Math.max(len - n, 0)\n writingBuf = writingBuf.slice(n)\n return { writingBuf, len }\n}\n\nfunction emitDrain (sonic) {\n const hasListeners = sonic.listenerCount('drain') > 0\n if (!hasListeners) return\n sonic._asyncDrainScheduled = false\n sonic.emit('drain')\n}\n\ninherits(SonicBoom, EventEmitter)\n\nfunction mergeBuf (bufs, len) {\n if (bufs.length === 0) {\n return kEmptyBuffer\n }\n\n if (bufs.length === 1) {\n return bufs[0]\n }\n\n return Buffer.concat(bufs, len)\n}\n\nfunction write (data) {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n const len = this._len + data.length\n const bufs = this._bufs\n\n if (this.maxLength && len > this.maxLength) {\n this.emit('drop', data)\n return this._len < this._hwm\n }\n\n if (\n bufs.length === 0 ||\n bufs[bufs.length - 1].length + data.length > this.maxWrite\n ) {\n bufs.push('' + data)\n } else {\n bufs[bufs.length - 1] += data\n }\n\n this._len = len\n\n if (!this._writing && this._len >= this.minLength) {\n this._actualWrite()\n }\n\n return this._len < this._hwm\n}\n\nfunction writeBuffer (data) {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n const len = this._len + data.length\n const bufs = this._bufs\n const lens = this._lens\n\n if (this.maxLength && len > this.maxLength) {\n this.emit('drop', data)\n return this._len < this._hwm\n }\n\n if (\n bufs.length === 0 ||\n lens[lens.length - 1] + data.length > this.maxWrite\n ) {\n bufs.push([data])\n lens.push(data.length)\n } else {\n bufs[bufs.length - 1].push(data)\n lens[lens.length - 1] += data.length\n }\n\n this._len = len\n\n if (!this._writing && this._len >= this.minLength) {\n this._actualWrite()\n }\n\n return this._len < this._hwm\n}\n\nfunction callFlushCallbackOnDrain (cb) {\n this._flushPending = true\n const onDrain = () => {\n // only if _fsync is false to avoid double fsync\n if (!this._fsync) {\n try {\n fs.fsync(this.fd, (err) => {\n this._flushPending = false\n cb(err)\n })\n } catch (err) {\n cb(err)\n }\n } else {\n this._flushPending = false\n cb()\n }\n this.off('error', onError)\n }\n const onError = (err) => {\n this._flushPending = false\n cb(err)\n this.off('drain', onDrain)\n }\n\n this.once('drain', onDrain)\n this.once('error', onError)\n}\n\nfunction flush (cb) {\n if (cb != null && typeof cb !== 'function') {\n throw new Error('flush cb must be a function')\n }\n\n if (this.destroyed) {\n const error = new Error('SonicBoom destroyed')\n if (cb) {\n cb(error)\n return\n }\n\n throw error\n }\n\n if (this.minLength <= 0) {\n cb?.()\n return\n }\n\n if (cb) {\n callFlushCallbackOnDrain.call(this, cb)\n }\n\n if (this._writing) {\n return\n }\n\n if (this._bufs.length === 0) {\n this._bufs.push('')\n }\n\n this._actualWrite()\n}\n\nfunction flushBuffer (cb) {\n if (cb != null && typeof cb !== 'function') {\n throw new Error('flush cb must be a function')\n }\n\n if (this.destroyed) {\n const error = new Error('SonicBoom destroyed')\n if (cb) {\n cb(error)\n return\n }\n\n throw error\n }\n\n if (this.minLength <= 0) {\n cb?.()\n return\n }\n\n if (cb) {\n callFlushCallbackOnDrain.call(this, cb)\n }\n\n if (this._writing) {\n return\n }\n\n if (this._bufs.length === 0) {\n this._bufs.push([])\n this._lens.push(0)\n }\n\n this._actualWrite()\n}\n\nSonicBoom.prototype.reopen = function (file) {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n if (this._opening) {\n this.once('ready', () => {\n this.reopen(file)\n })\n return\n }\n\n if (this._ending) {\n return\n }\n\n if (!this.file) {\n throw new Error('Unable to reopen a file descriptor, you must pass a file to SonicBoom')\n }\n\n if (file) {\n this.file = file\n }\n this._reopening = true\n\n if (this._writing) {\n return\n }\n\n const fd = this.fd\n this.once('ready', () => {\n if (fd !== this.fd) {\n fs.close(fd, (err) => {\n if (err) {\n return this.emit('error', err)\n }\n })\n }\n })\n\n openFile(this.file, this)\n}\n\nSonicBoom.prototype.end = function () {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n if (this._opening) {\n this.once('ready', () => {\n this.end()\n })\n return\n }\n\n if (this._ending) {\n return\n }\n\n this._ending = true\n\n if (this._writing) {\n return\n }\n\n if (this._len > 0 && this.fd >= 0) {\n this._actualWrite()\n } else {\n actualClose(this)\n }\n}\n\nfunction flushSync () {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n if (this.fd < 0) {\n throw new Error('sonic boom is not ready yet')\n }\n\n if (!this._writing && this._writingBuf.length > 0) {\n this._bufs.unshift(this._writingBuf)\n this._writingBuf = ''\n }\n\n let buf = ''\n while (this._bufs.length || buf) {\n if (buf.length <= 0) {\n buf = this._bufs[0]\n }\n try {\n const n = fs.writeSync(this.fd, buf, 'utf8')\n const releasedBufObj = releaseWritingBuf(buf, this._len, n)\n buf = releasedBufObj.writingBuf\n this._len = releasedBufObj.len\n if (buf.length <= 0) {\n this._bufs.shift()\n }\n } catch (err) {\n const shouldRetry = err.code === 'EAGAIN' || err.code === 'EBUSY'\n if (shouldRetry && !this.retryEAGAIN(err, buf.length, this._len - buf.length)) {\n throw err\n }\n\n sleep(BUSY_WRITE_TIMEOUT)\n }\n }\n\n try {\n fs.fsyncSync(this.fd)\n } catch {\n // Skip the error. The fd might not support fsync.\n }\n}\n\nfunction flushBufferSync () {\n if (this.destroyed) {\n throw new Error('SonicBoom destroyed')\n }\n\n if (this.fd < 0) {\n throw new Error('sonic boom is not ready yet')\n }\n\n if (!this._writing && this._writingBuf.length > 0) {\n this._bufs.unshift([this._writingBuf])\n this._writingBuf = kEmptyBuffer\n }\n\n let buf = kEmptyBuffer\n while (this._bufs.length || buf.length) {\n if (buf.length <= 0) {\n buf = mergeBuf(this._bufs[0], this._lens[0])\n }\n try {\n const n = fs.writeSync(this.fd, buf)\n buf = buf.subarray(n)\n this._len = Math.max(this._len - n, 0)\n if (buf.length <= 0) {\n this._bufs.shift()\n this._lens.shift()\n }\n } catch (err) {\n const shouldRetry = err.code === 'EAGAIN' || err.code === 'EBUSY'\n if (shouldRetry && !this.retryEAGAIN(err, buf.length, this._len - buf.length)) {\n throw err\n }\n\n sleep(BUSY_WRITE_TIMEOUT)\n }\n }\n}\n\nSonicBoom.prototype.destroy = function () {\n if (this.destroyed) {\n return\n }\n actualClose(this)\n}\n\nfunction actualWrite () {\n const release = this.release\n this._writing = true\n this._writingBuf = this._writingBuf || this._bufs.shift() || ''\n\n if (this.sync) {\n try {\n const written = fs.writeSync(this.fd, this._writingBuf, 'utf8')\n release(null, written)\n } catch (err) {\n release(err)\n }\n } else {\n fs.write(this.fd, this._writingBuf, 'utf8', release)\n }\n}\n\nfunction actualWriteBuffer () {\n const release = this.release\n this._writing = true\n this._writingBuf = this._writingBuf.length ? this._writingBuf : mergeBuf(this._bufs.shift(), this._lens.shift())\n\n if (this.sync) {\n try {\n const written = fs.writeSync(this.fd, this._writingBuf)\n release(null, written)\n } catch (err) {\n release(err)\n }\n } else {\n // fs.write will need to copy string to buffer anyway so\n // we do it here to avoid the overhead of calculating the buffer size\n // in releaseWritingBuf.\n if (kCopyBuffer) {\n this._writingBuf = Buffer.from(this._writingBuf)\n }\n fs.write(this.fd, this._writingBuf, release)\n }\n}\n\nfunction actualClose (sonic) {\n if (sonic.fd === -1) {\n sonic.once('ready', actualClose.bind(null, sonic))\n return\n }\n\n if (sonic._periodicFlushTimer !== undefined) {\n clearInterval(sonic._periodicFlushTimer)\n }\n\n sonic.destroyed = true\n sonic._bufs = []\n sonic._lens = []\n\n assert(typeof sonic.fd === 'number', `sonic.fd must be a number, got ${typeof sonic.fd}`)\n try {\n fs.fsync(sonic.fd, closeWrapped)\n } catch {\n }\n\n function closeWrapped () {\n // We skip errors in fsync\n\n if (sonic.fd !== 1 && sonic.fd !== 2) {\n fs.close(sonic.fd, done)\n } else {\n done()\n }\n }\n\n function done (err) {\n if (err) {\n sonic.emit('error', err)\n return\n }\n\n if (sonic._ending && !sonic._writing) {\n sonic.emit('finish')\n }\n sonic.emit('close')\n }\n}\n\n/**\n * These export configurations enable JS and TS developers\n * to consumer SonicBoom in whatever way best suits their needs.\n * Some examples of supported import syntax includes:\n * - `const SonicBoom = require('SonicBoom')`\n * - `const { SonicBoom } = require('SonicBoom')`\n * - `import * as SonicBoom from 'SonicBoom'`\n * - `import { SonicBoom } from 'SonicBoom'`\n * - `import SonicBoom from 'SonicBoom'`\n */\nSonicBoom.SonicBoom = SonicBoom\nSonicBoom.default = SonicBoom\nmodule.exports = SonicBoom\n","'use strict'\n\nconst refs = {\n exit: [],\n beforeExit: []\n}\nconst functions = {\n exit: onExit,\n beforeExit: onBeforeExit\n}\n\nlet registry\n\nfunction ensureRegistry () {\n if (registry === undefined) {\n registry = new FinalizationRegistry(clear)\n }\n}\n\nfunction install (event) {\n if (refs[event].length > 0) {\n return\n }\n\n process.on(event, functions[event])\n}\n\nfunction uninstall (event) {\n if (refs[event].length > 0) {\n return\n }\n process.removeListener(event, functions[event])\n if (refs.exit.length === 0 && refs.beforeExit.length === 0) {\n registry = undefined\n }\n}\n\nfunction onExit () {\n callRefs('exit')\n}\n\nfunction onBeforeExit () {\n callRefs('beforeExit')\n}\n\nfunction callRefs (event) {\n for (const ref of refs[event]) {\n const obj = ref.deref()\n const fn = ref.fn\n\n // This should always happen, however GC is\n // undeterministic so it might not happen.\n /* istanbul ignore else */\n if (obj !== undefined) {\n fn(obj, event)\n }\n }\n refs[event] = []\n}\n\nfunction clear (ref) {\n for (const event of ['exit', 'beforeExit']) {\n const index = refs[event].indexOf(ref)\n refs[event].splice(index, index + 1)\n uninstall(event)\n }\n}\n\nfunction _register (event, obj, fn) {\n if (obj === undefined) {\n throw new Error('the object can\\'t be undefined')\n }\n install(event)\n const ref = new WeakRef(obj)\n ref.fn = fn\n\n ensureRegistry()\n registry.register(obj, ref)\n refs[event].push(ref)\n}\n\nfunction register (obj, fn) {\n _register('exit', obj, fn)\n}\n\nfunction registerBeforeExit (obj, fn) {\n _register('beforeExit', obj, fn)\n}\n\nfunction unregister (obj) {\n if (registry === undefined) {\n return\n }\n registry.unregister(obj)\n for (const event of ['exit', 'beforeExit']) {\n refs[event] = refs[event].filter((ref) => {\n const _obj = ref.deref()\n return _obj && _obj !== obj\n })\n uninstall(event)\n }\n}\n\nmodule.exports = {\n register,\n registerBeforeExit,\n unregister\n}\n","{\n \"name\": \"thread-stream\",\n \"version\": \"3.1.0\",\n \"description\": \"A streaming way to send data to a Node.js Worker Thread\",\n \"main\": \"index.js\",\n \"types\": \"index.d.ts\",\n \"dependencies\": {\n \"real-require\": \"^0.2.0\"\n },\n \"devDependencies\": {\n \"@types/node\": \"^20.1.0\",\n \"@types/tap\": \"^15.0.0\",\n \"@yao-pkg/pkg\": \"^5.11.5\",\n \"desm\": \"^1.3.0\",\n \"fastbench\": \"^1.0.1\",\n \"husky\": \"^9.0.6\",\n \"pino-elasticsearch\": \"^8.0.0\",\n \"sonic-boom\": \"^4.0.1\",\n \"standard\": \"^17.0.0\",\n \"tap\": \"^16.2.0\",\n \"ts-node\": \"^10.8.0\",\n \"typescript\": \"^5.3.2\",\n \"why-is-node-running\": \"^2.2.2\"\n },\n \"scripts\": {\n \"build\": \"tsc --noEmit\",\n \"test\": \"standard && npm run build && npm run transpile && tap \\\"test/**/*.test.*js\\\" && tap --ts test/*.test.*ts\",\n \"test:ci\": \"standard && npm run transpile && npm run test:ci:js && npm run test:ci:ts\",\n \"test:ci:js\": \"tap --no-check-coverage --timeout=120 --coverage-report=lcovonly \\\"test/**/*.test.*js\\\"\",\n \"test:ci:ts\": \"tap --ts --no-check-coverage --coverage-report=lcovonly \\\"test/**/*.test.*ts\\\"\",\n \"test:yarn\": \"npm run transpile && tap \\\"test/**/*.test.js\\\" --no-check-coverage\",\n \"transpile\": \"sh ./test/ts/transpile.sh\",\n \"prepare\": \"husky install\"\n },\n \"standard\": {\n \"ignore\": [\n \"test/ts/**/*\",\n \"test/syntax-error.mjs\"\n ]\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/mcollina/thread-stream.git\"\n },\n \"keywords\": [\n \"worker\",\n \"thread\",\n \"threads\",\n \"stream\"\n ],\n \"author\": \"Matteo Collina <hello@matteocollina.com>\",\n \"license\": \"MIT\",\n \"bugs\": {\n \"url\": \"https://github.com/mcollina/thread-stream/issues\"\n },\n \"homepage\": \"https://github.com/mcollina/thread-stream#readme\"\n}\n","'use strict'\n\nconst MAX_TIMEOUT = 1000\n\nfunction wait (state, index, expected, timeout, done) {\n const max = Date.now() + timeout\n let current = Atomics.load(state, index)\n if (current === expected) {\n done(null, 'ok')\n return\n }\n let prior = current\n const check = (backoff) => {\n if (Date.now() > max) {\n done(null, 'timed-out')\n } else {\n setTimeout(() => {\n prior = current\n current = Atomics.load(state, index)\n if (current === prior) {\n check(backoff >= MAX_TIMEOUT ? MAX_TIMEOUT : backoff * 2)\n } else {\n if (current === expected) done(null, 'ok')\n else done(null, 'not-equal')\n }\n }, backoff)\n }\n }\n check(1)\n}\n\n// let waitDiffCount = 0\nfunction waitDiff (state, index, expected, timeout, done) {\n // const id = waitDiffCount++\n // process._rawDebug(`>>> waitDiff ${id}`)\n const max = Date.now() + timeout\n let current = Atomics.load(state, index)\n if (current !== expected) {\n done(null, 'ok')\n return\n }\n const check = (backoff) => {\n // process._rawDebug(`${id} ${index} current ${current} expected ${expected}`)\n // process._rawDebug('' + backoff)\n if (Date.now() > max) {\n done(null, 'timed-out')\n } else {\n setTimeout(() => {\n current = Atomics.load(state, index)\n if (current !== expected) {\n done(null, 'ok')\n } else {\n check(backoff >= MAX_TIMEOUT ? MAX_TIMEOUT : backoff * 2)\n }\n }, backoff)\n }\n }\n check(1)\n}\n\nmodule.exports = { wait, waitDiff }\n","'use strict'\n\nconst WRITE_INDEX = 4\nconst READ_INDEX = 8\n\nmodule.exports = {\n WRITE_INDEX,\n READ_INDEX\n}\n","'use strict'\n\nconst { version } = require('./package.json')\nconst { EventEmitter } = require('events')\nconst { Worker } = require('worker_threads')\nconst { join } = require('path')\nconst { pathToFileURL } = require('url')\nconst { wait } = require('./lib/wait')\nconst {\n WRITE_INDEX,\n READ_INDEX\n} = require('./lib/indexes')\nconst buffer = require('buffer')\nconst assert = require('assert')\n\nconst kImpl = Symbol('kImpl')\n\n// V8 limit for string size\nconst MAX_STRING = buffer.constants.MAX_STRING_LENGTH\n\nclass FakeWeakRef {\n constructor (value) {\n this._value = value\n }\n\n deref () {\n return this._value\n }\n}\n\nclass FakeFinalizationRegistry {\n register () {}\n\n unregister () {}\n}\n\n// Currently using FinalizationRegistry with code coverage breaks the world\n// Ref: https://github.com/nodejs/node/issues/49344\nconst FinalizationRegistry = process.env.NODE_V8_COVERAGE ? FakeFinalizationRegistry : global.FinalizationRegistry || FakeFinalizationRegistry\nconst WeakRef = process.env.NODE_V8_COVERAGE ? FakeWeakRef : global.WeakRef || FakeWeakRef\n\nconst registry = new FinalizationRegistry((worker) => {\n if (worker.exited) {\n return\n }\n worker.terminate()\n})\n\nfunction createWorker (stream, opts) {\n const { filename, workerData } = opts\n\n const bundlerOverrides = '__bundlerPathsOverrides' in globalThis ? globalThis.__bundlerPathsOverrides : {}\n const toExecute = bundlerOverrides['thread-stream-worker'] || join(__dirname, 'lib', 'worker.js')\n\n const worker = new Worker(toExecute, {\n ...opts.workerOpts,\n trackUnmanagedFds: false,\n workerData: {\n filename: filename.indexOf('file://') === 0\n ? filename\n : pathToFileURL(filename).href,\n dataBuf: stream[kImpl].dataBuf,\n stateBuf: stream[kImpl].stateBuf,\n workerData: {\n $context: {\n threadStreamVersion: version\n },\n ...workerData\n }\n }\n })\n\n // We keep a strong reference for now,\n // we need to start writing first\n worker.stream = new FakeWeakRef(stream)\n\n worker.on('message', onWorkerMessage)\n worker.on('exit', onWorkerExit)\n registry.register(stream, worker)\n\n return worker\n}\n\nfunction drain (stream) {\n assert(!stream[kImpl].sync)\n if (stream[kImpl].needDrain) {\n stream[kImpl].needDrain = false\n stream.emit('drain')\n }\n}\n\nfunction nextFlush (stream) {\n const writeIndex = Atomics.load(stream[kImpl].state, WRITE_INDEX)\n let leftover = stream[kImpl].data.length - writeIndex\n\n if (leftover > 0) {\n if (stream[kImpl].buf.length === 0) {\n stream[kImpl].flushing = false\n\n if (stream[kImpl].ending) {\n end(stream)\n } else if (stream[kImpl].needDrain) {\n process.nextTick(drain, stream)\n }\n\n return\n }\n\n let toWrite = stream[kImpl].buf.slice(0, leftover)\n let toWriteBytes = Buffer.byteLength(toWrite)\n if (toWriteBytes <= leftover) {\n stream[kImpl].buf = stream[kImpl].buf.slice(leftover)\n // process._rawDebug('writing ' + toWrite.length)\n write(stream, toWrite, nextFlush.bind(null, stream))\n } else {\n // multi-byte utf-8\n stream.flush(() => {\n // err is already handled in flush()\n if (stream.destroyed) {\n return\n }\n\n Atomics.store(stream[kImpl].state, READ_INDEX, 0)\n Atomics.store(stream[kImpl].state, WRITE_INDEX, 0)\n\n // Find a toWrite length that fits the buffer\n // it must exists as the buffer is at least 4 bytes length\n // and the max utf-8 length for a char is 4 bytes.\n while (toWriteBytes > stream[kImpl].data.length) {\n leftover = leftover / 2\n toWrite = stream[kImpl].buf.slice(0, leftover)\n toWriteBytes = Buffer.byteLength(toWrite)\n }\n stream[kImpl].buf = stream[kImpl].buf.slice(leftover)\n write(stream, toWrite, nextFlush.bind(null, stream))\n })\n }\n } else if (leftover === 0) {\n if (writeIndex === 0 && stream[kImpl].buf.length === 0) {\n // we had a flushSync in the meanwhile\n return\n }\n stream.flush(() => {\n Atomics.store(stream[kImpl].state, READ_INDEX, 0)\n Atomics.store(stream[kImpl].state, WRITE_INDEX, 0)\n nextFlush(stream)\n })\n } else {\n // This should never happen\n destroy(stream, new Error('overwritten'))\n }\n}\n\nfunction onWorkerMessage (msg) {\n const stream = this.stream.deref()\n if (stream === undefined) {\n this.exited = true\n // Terminate the worker.\n this.terminate()\n return\n }\n\n switch (msg.code) {\n case 'READY':\n // Replace the FakeWeakRef with a\n // proper one.\n this.stream = new WeakRef(stream)\n\n stream.flush(() => {\n stream[kImpl].ready = true\n stream.emit('ready')\n })\n break\n case 'ERROR':\n destroy(stream, msg.err)\n break\n case 'EVENT':\n if (Array.isArray(msg.args)) {\n stream.emit(msg.name, ...msg.args)\n } else {\n stream.emit(msg.name, msg.args)\n }\n break\n case 'WARNING':\n process.emitWarning(msg.err)\n break\n default:\n destroy(stream, new Error('this should not happen: ' + msg.code))\n }\n}\n\nfunction onWorkerExit (code) {\n const stream = this.stream.deref()\n if (stream === undefined) {\n // Nothing to do, the worker already exit\n return\n }\n registry.unregister(stream)\n stream.worker.exited = true\n stream.worker.off('exit', onWorkerExit)\n destroy(stream, code !== 0 ? new Error('the worker thread exited') : null)\n}\n\nclass ThreadStream extends EventEmitter {\n constructor (opts = {}) {\n super()\n\n if (opts.bufferSize < 4) {\n throw new Error('bufferSize must at least fit a 4-byte utf-8 char')\n }\n\n this[kImpl] = {}\n this[kImpl].stateBuf = new SharedArrayBuffer(128)\n this[kImpl].state = new Int32Array(this[kImpl].stateBuf)\n this[kImpl].dataBuf = new SharedArrayBuffer(opts.bufferSize || 4 * 1024 * 1024)\n this[kImpl].data = Buffer.from(this[kImpl].dataBuf)\n this[kImpl].sync = opts.sync || false\n this[kImpl].ending = false\n this[kImpl].ended = false\n this[kImpl].needDrain = false\n this[kImpl].destroyed = false\n this[kImpl].flushing = false\n this[kImpl].ready = false\n this[kImpl].finished = false\n this[kImpl].errored = null\n this[kImpl].closed = false\n this[kImpl].buf = ''\n\n // TODO (fix): Make private?\n this.worker = createWorker(this, opts) // TODO (fix): make private\n this.on('message', (message, transferList) => {\n this.worker.postMessage(message, transferList)\n })\n }\n\n write (data) {\n if (this[kImpl].destroyed) {\n error(this, new Error('the worker has exited'))\n return false\n }\n\n if (this[kImpl].ending) {\n error(this, new Error('the worker is ending'))\n return false\n }\n\n if (this[kImpl].flushing && this[kImpl].buf.length + data.length >= MAX_STRING) {\n try {\n writeSync(this)\n this[kImpl].flushing = true\n } catch (err) {\n destroy(this, err)\n return false\n }\n }\n\n this[kImpl].buf += data\n\n if (this[kImpl].sync) {\n try {\n writeSync(this)\n return true\n } catch (err) {\n destroy(this, err)\n return false\n }\n }\n\n if (!this[kImpl].flushing) {\n this[kImpl].flushing = true\n setImmediate(nextFlush, this)\n }\n\n this[kImpl].needDrain = this[kImpl].data.length - this[kImpl].buf.length - Atomics.load(this[kImpl].state, WRITE_INDEX) <= 0\n return !this[kImpl].needDrain\n }\n\n end () {\n if (this[kImpl].destroyed) {\n return\n }\n\n this[kImpl].ending = true\n end(this)\n }\n\n flush (cb) {\n if (this[kImpl].destroyed) {\n if (typeof cb === 'function') {\n process.nextTick(cb, new Error('the worker has exited'))\n }\n return\n }\n\n // TODO write all .buf\n const writeIndex = Atomics.load(this[kImpl].state, WRITE_INDEX)\n // process._rawDebug(`(flush) readIndex (${Atomics.load(this.state, READ_INDEX)}) writeIndex (${Atomics.load(this.state, WRITE_INDEX)})`)\n wait(this[kImpl].state, READ_INDEX, writeIndex, Infinity, (err, res) => {\n if (err) {\n destroy(this, err)\n process.nextTick(cb, err)\n return\n }\n if (res === 'not-equal') {\n // TODO handle deadlock\n this.flush(cb)\n return\n }\n process.nextTick(cb)\n })\n }\n\n flushSync () {\n if (this[kImpl].destroyed) {\n return\n }\n\n writeSync(this)\n flushSync(this)\n }\n\n unref () {\n this.worker.unref()\n }\n\n ref () {\n this.worker.ref()\n }\n\n get ready () {\n return this[kImpl].ready\n }\n\n get destroyed () {\n return this[kImpl].destroyed\n }\n\n get closed () {\n return this[kImpl].closed\n }\n\n get writable () {\n return !this[kImpl].destroyed && !this[kImpl].ending\n }\n\n get writableEnded () {\n return this[kImpl].ending\n }\n\n get writableFinished () {\n return this[kImpl].finished\n }\n\n get writableNeedDrain () {\n return this[kImpl].needDrain\n }\n\n get writableObjectMode () {\n return false\n }\n\n get writableErrored () {\n return this[kImpl].errored\n }\n}\n\nfunction error (stream, err) {\n setImmediate(() => {\n stream.emit('error', err)\n })\n}\n\nfunction destroy (stream, err) {\n if (stream[kImpl].destroyed) {\n return\n }\n stream[kImpl].destroyed = true\n\n if (err) {\n stream[kImpl].errored = err\n error(stream, err)\n }\n\n if (!stream.worker.exited) {\n stream.worker.terminate()\n .catch(() => {})\n .then(() => {\n stream[kImpl].closed = true\n stream.emit('close')\n })\n } else {\n setImmediate(() => {\n stream[kImpl].closed = true\n stream.emit('close')\n })\n }\n}\n\nfunction write (stream, data, cb) {\n // data is smaller than the shared buffer length\n const current = Atomics.load(stream[kImpl].state, WRITE_INDEX)\n const length = Buffer.byteLength(data)\n stream[kImpl].data.write(data, current)\n Atomics.store(stream[kImpl].state, WRITE_INDEX, current + length)\n Atomics.notify(stream[kImpl].state, WRITE_INDEX)\n cb()\n return true\n}\n\nfunction end (stream) {\n if (stream[kImpl].ended || !stream[kImpl].ending || stream[kImpl].flushing) {\n return\n }\n stream[kImpl].ended = true\n\n try {\n stream.flushSync()\n\n let readIndex = Atomics.load(stream[kImpl].state, READ_INDEX)\n\n // process._rawDebug('writing index')\n Atomics.store(stream[kImpl].state, WRITE_INDEX, -1)\n // process._rawDebug(`(end) readIndex (${Atomics.load(stream.state, READ_INDEX)}) writeIndex (${Atomics.load(stream.state, WRITE_INDEX)})`)\n Atomics.notify(stream[kImpl].state, WRITE_INDEX)\n\n // Wait for the process to complete\n let spins = 0\n while (readIndex !== -1) {\n // process._rawDebug(`read = ${read}`)\n Atomics.wait(stream[kImpl].state, READ_INDEX, readIndex, 1000)\n readIndex = Atomics.load(stream[kImpl].state, READ_INDEX)\n\n if (readIndex === -2) {\n destroy(stream, new Error('end() failed'))\n return\n }\n\n if (++spins === 10) {\n destroy(stream, new Error('end() took too long (10s)'))\n return\n }\n }\n\n process.nextTick(() => {\n stream[kImpl].finished = true\n stream.emit('finish')\n })\n } catch (err) {\n destroy(stream, err)\n }\n // process._rawDebug('end finished...')\n}\n\nfunction writeSync (stream) {\n const cb = () => {\n if (stream[kImpl].ending) {\n end(stream)\n } else if (stream[kImpl].needDrain) {\n process.nextTick(drain, stream)\n }\n }\n stream[kImpl].flushing = false\n\n while (stream[kImpl].buf.length !== 0) {\n const writeIndex = Atomics.load(stream[kImpl].state, WRITE_INDEX)\n let leftover = stream[kImpl].data.length - writeIndex\n if (leftover === 0) {\n flushSync(stream)\n Atomics.store(stream[kImpl].state, READ_INDEX, 0)\n Atomics.store(stream[kImpl].state, WRITE_INDEX, 0)\n continue\n } else if (leftover < 0) {\n // stream should never happen\n throw new Error('overwritten')\n }\n\n let toWrite = stream[kImpl].buf.slice(0, leftover)\n let toWriteBytes = Buffer.byteLength(toWrite)\n if (toWriteBytes <= leftover) {\n stream[kImpl].buf = stream[kImpl].buf.slice(leftover)\n // process._rawDebug('writing ' + toWrite.length)\n write(stream, toWrite, cb)\n } else {\n // multi-byte utf-8\n flushSync(stream)\n Atomics.store(stream[kImpl].state, READ_INDEX, 0)\n Atomics.store(stream[kImpl].state, WRITE_INDEX, 0)\n\n // Find a toWrite length that fits the buffer\n // it must exists as the buffer is at least 4 bytes length\n // and the max utf-8 length for a char is 4 bytes.\n while (toWriteBytes > stream[kImpl].buf.length) {\n leftover = leftover / 2\n toWrite = stream[kImpl].buf.slice(0, leftover)\n toWriteBytes = Buffer.byteLength(toWrite)\n }\n stream[kImpl].buf = stream[kImpl].buf.slice(leftover)\n write(stream, toWrite, cb)\n }\n }\n}\n\nfunction flushSync (stream) {\n if (stream[kImpl].flushing) {\n throw new Error('unable to flush while flushing')\n }\n\n // process._rawDebug('flushSync started')\n\n const writeIndex = Atomics.load(stream[kImpl].state, WRITE_INDEX)\n\n let spins = 0\n\n // TODO handle deadlock\n while (true) {\n const readIndex = Atomics.load(stream[kImpl].state, READ_INDEX)\n\n if (readIndex === -2) {\n throw Error('_flushSync failed')\n }\n\n // process._rawDebug(`(flushSync) readIndex (${readIndex}) writeIndex (${writeIndex})`)\n if (readIndex !== writeIndex) {\n // TODO stream timeouts for some reason.\n Atomics.wait(stream[kImpl].state, READ_INDEX, readIndex, 1000)\n } else {\n break\n }\n\n if (++spins === 10) {\n throw new Error('_flushSync took too long (10s)')\n }\n }\n // process._rawDebug('flushSync finished')\n}\n\nmodule.exports = ThreadStream\n","'use strict'\n\nconst { createRequire } = require('module')\nconst getCallers = require('./caller')\nconst { join, isAbsolute, sep } = require('node:path')\nconst sleep = require('atomic-sleep')\nconst onExit = require('on-exit-leak-free')\nconst ThreadStream = require('thread-stream')\n\nfunction setupOnExit (stream) {\n // This is leak free, it does not leave event handlers\n onExit.register(stream, autoEnd)\n onExit.registerBeforeExit(stream, flush)\n\n stream.on('close', function () {\n onExit.unregister(stream)\n })\n}\n\nfunction buildStream (filename, workerData, workerOpts, sync) {\n const stream = new ThreadStream({\n filename,\n workerData,\n workerOpts,\n sync\n })\n\n stream.on('ready', onReady)\n stream.on('close', function () {\n process.removeListener('exit', onExit)\n })\n\n process.on('exit', onExit)\n\n function onReady () {\n process.removeListener('exit', onExit)\n stream.unref()\n\n if (workerOpts.autoEnd !== false) {\n setupOnExit(stream)\n }\n }\n\n function onExit () {\n /* istanbul ignore next */\n if (stream.closed) {\n return\n }\n stream.flushSync()\n // Apparently there is a very sporadic race condition\n // that in certain OS would prevent the messages to be flushed\n // because the thread might not have been created still.\n // Unfortunately we need to sleep(100) in this case.\n sleep(100)\n stream.end()\n }\n\n return stream\n}\n\nfunction autoEnd (stream) {\n stream.ref()\n stream.flushSync()\n stream.end()\n stream.once('close', function () {\n stream.unref()\n })\n}\n\nfunction flush (stream) {\n stream.flushSync()\n}\n\nfunction transport (fullOptions) {\n const { pipeline, targets, levels, dedupe, worker = {}, caller = getCallers(), sync = false } = fullOptions\n\n const options = {\n ...fullOptions.options\n }\n\n // Backwards compatibility\n const callers = typeof caller === 'string' ? [caller] : caller\n\n // This will be eventually modified by bundlers\n const bundlerOverrides = '__bundlerPathsOverrides' in globalThis ? globalThis.__bundlerPathsOverrides : {}\n\n let target = fullOptions.target\n\n if (target && targets) {\n throw new Error('only one of target or targets can be specified')\n }\n\n if (targets) {\n target = bundlerOverrides['pino-worker'] || join(__dirname, 'worker.js')\n options.targets = targets.filter(dest => dest.target).map((dest) => {\n return {\n ...dest,\n target: fixTarget(dest.target)\n }\n })\n options.pipelines = targets.filter(dest => dest.pipeline).map((dest) => {\n return dest.pipeline.map((t) => {\n return {\n ...t,\n level: dest.level, // duplicate the pipeline `level` property defined in the upper level\n target: fixTarget(t.target)\n }\n })\n })\n } else if (pipeline) {\n target = bundlerOverrides['pino-worker'] || join(__dirname, 'worker.js')\n options.pipelines = [pipeline.map((dest) => {\n return {\n ...dest,\n target: fixTarget(dest.target)\n }\n })]\n }\n\n if (levels) {\n options.levels = levels\n }\n\n if (dedupe) {\n options.dedupe = dedupe\n }\n\n options.pinoWillSendConfig = true\n\n return buildStream(fixTarget(target), options, worker, sync)\n\n function fixTarget (origin) {\n origin = bundlerOverrides[origin] || origin\n\n if (isAbsolute(origin) || origin.indexOf('file://') === 0) {\n return origin\n }\n\n if (origin === 'pino/file') {\n return join(__dirname, '..', 'file.js')\n }\n\n let fixTarget\n\n for (const filePath of callers) {\n try {\n const context = filePath === 'node:repl'\n ? process.cwd() + sep\n : filePath\n\n fixTarget = createRequire(context).resolve(origin)\n break\n } catch (err) {\n // Silent catch\n continue\n }\n }\n\n if (!fixTarget) {\n throw new Error(`unable to determine transport target for \"${origin}\"`)\n }\n\n return fixTarget\n }\n}\n\nmodule.exports = transport\n","'use strict'\n\n/* eslint no-prototype-builtins: 0 */\n\nconst format = require('quick-format-unescaped')\nconst { mapHttpRequest, mapHttpResponse } = require('pino-std-serializers')\nconst SonicBoom = require('sonic-boom')\nconst onExit = require('on-exit-leak-free')\nconst {\n lsCacheSym,\n chindingsSym,\n writeSym,\n serializersSym,\n formatOptsSym,\n endSym,\n stringifiersSym,\n stringifySym,\n stringifySafeSym,\n wildcardFirstSym,\n nestedKeySym,\n formattersSym,\n messageKeySym,\n errorKeySym,\n nestedKeyStrSym,\n msgPrefixSym\n} = require('./symbols')\nconst { isMainThread } = require('worker_threads')\nconst transport = require('./transport')\n\nfunction noop () {\n}\n\nfunction genLog (level, hook) {\n if (!hook) return LOG\n\n return function hookWrappedLog (...args) {\n hook.call(this, args, LOG, level)\n }\n\n function LOG (o, ...n) {\n if (typeof o === 'object') {\n let msg = o\n if (o !== null) {\n if (o.method && o.headers && o.socket) {\n o = mapHttpRequest(o)\n } else if (typeof o.setHeader === 'function') {\n o = mapHttpResponse(o)\n }\n }\n let formatParams\n if (msg === null && n.length === 0) {\n formatParams = [null]\n } else {\n msg = n.shift()\n formatParams = n\n }\n // We do not use a coercive check for `msg` as it is\n // measurably slower than the explicit checks.\n if (typeof this[msgPrefixSym] === 'string' && msg !== undefined && msg !== null) {\n msg = this[msgPrefixSym] + msg\n }\n this[writeSym](o, format(msg, formatParams, this[formatOptsSym]), level)\n } else {\n let msg = o === undefined ? n.shift() : o\n\n // We do not use a coercive check for `msg` as it is\n // measurably slower than the explicit checks.\n if (typeof this[msgPrefixSym] === 'string' && msg !== undefined && msg !== null) {\n msg = this[msgPrefixSym] + msg\n }\n this[writeSym](null, format(msg, n, this[formatOptsSym]), level)\n }\n }\n}\n\n// magically escape strings for json\n// relying on their charCodeAt\n// everything below 32 needs JSON.stringify()\n// 34 and 92 happens all the time, so we\n// have a fast case for them\nfunction asString (str) {\n let result = ''\n let last = 0\n let found = false\n let point = 255\n const l = str.length\n if (l > 100) {\n return JSON.stringify(str)\n }\n for (var i = 0; i < l && point >= 32; i++) {\n point = str.charCodeAt(i)\n if (point === 34 || point === 92) {\n result += str.slice(last, i) + '\\\\'\n last = i\n found = true\n }\n }\n if (!found) {\n result = str\n } else {\n result += str.slice(last)\n }\n return point < 32 ? JSON.stringify(str) : '\"' + result + '\"'\n}\n\nfunction asJson (obj, msg, num, time) {\n const stringify = this[stringifySym]\n const stringifySafe = this[stringifySafeSym]\n const stringifiers = this[stringifiersSym]\n const end = this[endSym]\n const chindings = this[chindingsSym]\n const serializers = this[serializersSym]\n const formatters = this[formattersSym]\n const messageKey = this[messageKeySym]\n const errorKey = this[errorKeySym]\n let data = this[lsCacheSym][num] + time\n\n // we need the child bindings added to the output first so instance logged\n // objects can take precedence when JSON.parse-ing the resulting log line\n data = data + chindings\n\n let value\n if (formatters.log) {\n obj = formatters.log(obj)\n }\n const wildcardStringifier = stringifiers[wildcardFirstSym]\n let propStr = ''\n for (const key in obj) {\n value = obj[key]\n if (Object.prototype.hasOwnProperty.call(obj, key) && value !== undefined) {\n if (serializers[key]) {\n value = serializers[key](value)\n } else if (key === errorKey && serializers.err) {\n value = serializers.err(value)\n }\n\n const stringifier = stringifiers[key] || wildcardStringifier\n\n switch (typeof value) {\n case 'undefined':\n case 'function':\n continue\n case 'number':\n /* eslint no-fallthrough: \"off\" */\n if (Number.isFinite(value) === false) {\n value = null\n }\n // this case explicitly falls through to the next one\n case 'boolean':\n if (stringifier) value = stringifier(value)\n break\n case 'string':\n value = (stringifier || asString)(value)\n break\n default:\n value = (stringifier || stringify)(value, stringifySafe)\n }\n if (value === undefined) continue\n const strKey = asString(key)\n propStr += ',' + strKey + ':' + value\n }\n }\n\n let msgStr = ''\n if (msg !== undefined) {\n value = serializers[messageKey] ? serializers[messageKey](msg) : msg\n const stringifier = stringifiers[messageKey] || wildcardStringifier\n\n switch (typeof value) {\n case 'function':\n break\n case 'number':\n /* eslint no-fallthrough: \"off\" */\n if (Number.isFinite(value) === false) {\n value = null\n }\n // this case explicitly falls through to the next one\n case 'boolean':\n if (stringifier) value = stringifier(value)\n msgStr = ',\"' + messageKey + '\":' + value\n break\n case 'string':\n value = (stringifier || asString)(value)\n msgStr = ',\"' + messageKey + '\":' + value\n break\n default:\n value = (stringifier || stringify)(value, stringifySafe)\n msgStr = ',\"' + messageKey + '\":' + value\n }\n }\n\n if (this[nestedKeySym] && propStr) {\n // place all the obj properties under the specified key\n // the nested key is already formatted from the constructor\n return data + this[nestedKeyStrSym] + propStr.slice(1) + '}' + msgStr + end\n } else {\n return data + propStr + msgStr + end\n }\n}\n\nfunction asChindings (instance, bindings) {\n let value\n let data = instance[chindingsSym]\n const stringify = instance[stringifySym]\n const stringifySafe = instance[stringifySafeSym]\n const stringifiers = instance[stringifiersSym]\n const wildcardStringifier = stringifiers[wildcardFirstSym]\n const serializers = instance[serializersSym]\n const formatter = instance[formattersSym].bindings\n bindings = formatter(bindings)\n\n for (const key in bindings) {\n value = bindings[key]\n const valid = key !== 'level' &&\n key !== 'serializers' &&\n key !== 'formatters' &&\n key !== 'customLevels' &&\n bindings.hasOwnProperty(key) &&\n value !== undefined\n if (valid === true) {\n value = serializers[key] ? serializers[key](value) : value\n value = (stringifiers[key] || wildcardStringifier || stringify)(value, stringifySafe)\n if (value === undefined) continue\n data += ',\"' + key + '\":' + value\n }\n }\n return data\n}\n\nfunction hasBeenTampered (stream) {\n return stream.write !== stream.constructor.prototype.write\n}\n\nconst hasNodeCodeCoverage = process.env.NODE_V8_COVERAGE || process.env.V8_COVERAGE\n\nfunction buildSafeSonicBoom (opts) {\n const stream = new SonicBoom(opts)\n stream.on('error', filterBrokenPipe)\n // If we are sync: false, we must flush on exit\n // We must disable this if there is node code coverage due to\n // https://github.com/nodejs/node/issues/49344#issuecomment-1741776308.\n if (!hasNodeCodeCoverage && !opts.sync && isMainThread) {\n onExit.register(stream, autoEnd)\n\n stream.on('close', function () {\n onExit.unregister(stream)\n })\n }\n return stream\n\n function filterBrokenPipe (err) {\n // Impossible to replicate across all operating systems\n /* istanbul ignore next */\n if (err.code === 'EPIPE') {\n // If we get EPIPE, we should stop logging here\n // however we have no control to the consumer of\n // SonicBoom, so we just overwrite the write method\n stream.write = noop\n stream.end = noop\n stream.flushSync = noop\n stream.destroy = noop\n return\n }\n stream.removeListener('error', filterBrokenPipe)\n stream.emit('error', err)\n }\n}\n\nfunction autoEnd (stream, eventName) {\n // This check is needed only on some platforms\n /* istanbul ignore next */\n if (stream.destroyed) {\n return\n }\n\n if (eventName === 'beforeExit') {\n // We still have an event loop, let's use it\n stream.flush()\n stream.on('drain', function () {\n stream.end()\n })\n } else {\n // For some reason istanbul is not detecting this, but it's there\n /* istanbul ignore next */\n // We do not have an event loop, so flush synchronously\n stream.flushSync()\n }\n}\n\nfunction createArgsNormalizer (defaultOptions) {\n return function normalizeArgs (instance, caller, opts = {}, stream) {\n // support stream as a string\n if (typeof opts === 'string') {\n stream = buildSafeSonicBoom({ dest: opts })\n opts = {}\n } else if (typeof stream === 'string') {\n if (opts && opts.transport) {\n throw Error('only one of option.transport or stream can be specified')\n }\n stream = buildSafeSonicBoom({ dest: stream })\n } else if (opts instanceof SonicBoom || opts.writable || opts._writableState) {\n stream = opts\n opts = {}\n } else if (opts.transport) {\n if (opts.transport instanceof SonicBoom || opts.transport.writable || opts.transport._writableState) {\n throw Error('option.transport do not allow stream, please pass to option directly. e.g. pino(transport)')\n }\n if (opts.transport.targets && opts.transport.targets.length && opts.formatters && typeof opts.formatters.level === 'function') {\n throw Error('option.transport.targets do not allow custom level formatters')\n }\n\n let customLevels\n if (opts.customLevels) {\n customLevels = opts.useOnlyCustomLevels ? opts.customLevels : Object.assign({}, opts.levels, opts.customLevels)\n }\n stream = transport({ caller, ...opts.transport, levels: customLevels })\n }\n opts = Object.assign({}, defaultOptions, opts)\n opts.serializers = Object.assign({}, defaultOptions.serializers, opts.serializers)\n opts.formatters = Object.assign({}, defaultOptions.formatters, opts.formatters)\n\n if (opts.prettyPrint) {\n throw new Error('prettyPrint option is no longer supported, see the pino-pretty package (https://github.com/pinojs/pino-pretty)')\n }\n\n const { enabled, onChild } = opts\n if (enabled === false) opts.level = 'silent'\n if (!onChild) opts.onChild = noop\n if (!stream) {\n if (!hasBeenTampered(process.stdout)) {\n // If process.stdout.fd is undefined, it means that we are running\n // in a worker thread. Let's assume we are logging to file descriptor 1.\n stream = buildSafeSonicBoom({ fd: process.stdout.fd || 1 })\n } else {\n stream = process.stdout\n }\n }\n return { opts, stream }\n }\n}\n\nfunction stringify (obj, stringifySafeFn) {\n try {\n return JSON.stringify(obj)\n } catch (_) {\n try {\n const stringify = stringifySafeFn || this[stringifySafeSym]\n return stringify(obj)\n } catch (_) {\n return '\"[unable to serialize, circular reference is too complex to analyze]\"'\n }\n }\n}\n\nfunction buildFormatters (level, bindings, log) {\n return {\n level,\n bindings,\n log\n }\n}\n\n/**\n * Convert a string integer file descriptor to a proper native integer\n * file descriptor.\n *\n * @param {string} destination The file descriptor string to attempt to convert.\n *\n * @returns {Number}\n */\nfunction normalizeDestFileDescriptor (destination) {\n const fd = Number(destination)\n if (typeof destination === 'string' && Number.isFinite(fd)) {\n return fd\n }\n // destination could be undefined if we are in a worker\n if (destination === undefined) {\n // This is stdout in UNIX systems\n return 1\n }\n return destination\n}\n\nmodule.exports = {\n noop,\n buildSafeSonicBoom,\n asChindings,\n asJson,\n genLog,\n createArgsNormalizer,\n stringify,\n buildFormatters,\n normalizeDestFileDescriptor\n}\n","/**\n * Represents default log level values\n *\n * @enum {number}\n */\nconst DEFAULT_LEVELS = {\n trace: 10,\n debug: 20,\n info: 30,\n warn: 40,\n error: 50,\n fatal: 60\n}\n\n/**\n * Represents sort order direction: `ascending` or `descending`\n *\n * @enum {string}\n */\nconst SORTING_ORDER = {\n ASC: 'ASC',\n DESC: 'DESC'\n}\n\nmodule.exports = {\n DEFAULT_LEVELS,\n SORTING_ORDER\n}\n","'use strict'\n/* eslint no-prototype-builtins: 0 */\nconst {\n lsCacheSym,\n levelValSym,\n useOnlyCustomLevelsSym,\n streamSym,\n formattersSym,\n hooksSym,\n levelCompSym\n} = require('./symbols')\nconst { noop, genLog } = require('./tools')\nconst { DEFAULT_LEVELS, SORTING_ORDER } = require('./constants')\n\nconst levelMethods = {\n fatal: (hook) => {\n const logFatal = genLog(DEFAULT_LEVELS.fatal, hook)\n return function (...args) {\n const stream = this[streamSym]\n logFatal.call(this, ...args)\n if (typeof stream.flushSync === 'function') {\n try {\n stream.flushSync()\n } catch (e) {\n // https://github.com/pinojs/pino/pull/740#discussion_r346788313\n }\n }\n }\n },\n error: (hook) => genLog(DEFAULT_LEVELS.error, hook),\n warn: (hook) => genLog(DEFAULT_LEVELS.warn, hook),\n info: (hook) => genLog(DEFAULT_LEVELS.info, hook),\n debug: (hook) => genLog(DEFAULT_LEVELS.debug, hook),\n trace: (hook) => genLog(DEFAULT_LEVELS.trace, hook)\n}\n\nconst nums = Object.keys(DEFAULT_LEVELS).reduce((o, k) => {\n o[DEFAULT_LEVELS[k]] = k\n return o\n}, {})\n\nconst initialLsCache = Object.keys(nums).reduce((o, k) => {\n o[k] = '{\"level\":' + Number(k)\n return o\n}, {})\n\nfunction genLsCache (instance) {\n const formatter = instance[formattersSym].level\n const { labels } = instance.levels\n const cache = {}\n for (const label in labels) {\n const level = formatter(labels[label], Number(label))\n cache[label] = JSON.stringify(level).slice(0, -1)\n }\n instance[lsCacheSym] = cache\n return instance\n}\n\nfunction isStandardLevel (level, useOnlyCustomLevels) {\n if (useOnlyCustomLevels) {\n return false\n }\n\n switch (level) {\n case 'fatal':\n case 'error':\n case 'warn':\n case 'info':\n case 'debug':\n case 'trace':\n return true\n default:\n return false\n }\n}\n\nfunction setLevel (level) {\n const { labels, values } = this.levels\n if (typeof level === 'number') {\n if (labels[level] === undefined) throw Error('unknown level value' + level)\n level = labels[level]\n }\n if (values[level] === undefined) throw Error('unknown level ' + level)\n const preLevelVal = this[levelValSym]\n const levelVal = this[levelValSym] = values[level]\n const useOnlyCustomLevelsVal = this[useOnlyCustomLevelsSym]\n const levelComparison = this[levelCompSym]\n const hook = this[hooksSym].logMethod\n\n for (const key in values) {\n if (levelComparison(values[key], levelVal) === false) {\n this[key] = noop\n continue\n }\n this[key] = isStandardLevel(key, useOnlyCustomLevelsVal) ? levelMethods[key](hook) : genLog(values[key], hook)\n }\n\n this.emit(\n 'level-change',\n level,\n levelVal,\n labels[preLevelVal],\n preLevelVal,\n this\n )\n}\n\nfunction getLevel (level) {\n const { levels, levelVal } = this\n // protection against potential loss of Pino scope from serializers (edge case with circular refs - https://github.com/pinojs/pino/issues/833)\n return (levels && levels.labels) ? levels.labels[levelVal] : ''\n}\n\nfunction isLevelEnabled (logLevel) {\n const { values } = this.levels\n const logLevelVal = values[logLevel]\n return logLevelVal !== undefined && this[levelCompSym](logLevelVal, this[levelValSym])\n}\n\n/**\n * Determine if the given `current` level is enabled by comparing it\n * against the current threshold (`expected`).\n *\n * @param {SORTING_ORDER} direction comparison direction \"ASC\" or \"DESC\"\n * @param {number} current current log level number representation\n * @param {number} expected threshold value to compare with\n * @returns {boolean}\n */\nfunction compareLevel (direction, current, expected) {\n if (direction === SORTING_ORDER.DESC) {\n return current <= expected\n }\n\n return current >= expected\n}\n\n/**\n * Create a level comparison function based on `levelComparison`\n * it could a default function which compares levels either in \"ascending\" or \"descending\" order or custom comparison function\n *\n * @param {SORTING_ORDER | Function} levelComparison sort levels order direction or custom comparison function\n * @returns Function\n */\nfunction genLevelComparison (levelComparison) {\n if (typeof levelComparison === 'string') {\n return compareLevel.bind(null, levelComparison)\n }\n\n return levelComparison\n}\n\nfunction mappings (customLevels = null, useOnlyCustomLevels = false) {\n const customNums = customLevels\n /* eslint-disable */\n ? Object.keys(customLevels).reduce((o, k) => {\n o[customLevels[k]] = k\n return o\n }, {})\n : null\n /* eslint-enable */\n\n const labels = Object.assign(\n Object.create(Object.prototype, { Infinity: { value: 'silent' } }),\n useOnlyCustomLevels ? null : nums,\n customNums\n )\n const values = Object.assign(\n Object.create(Object.prototype, { silent: { value: Infinity } }),\n useOnlyCustomLevels ? null : DEFAULT_LEVELS,\n customLevels\n )\n return { labels, values }\n}\n\nfunction assertDefaultLevelFound (defaultLevel, customLevels, useOnlyCustomLevels) {\n if (typeof defaultLevel === 'number') {\n const values = [].concat(\n Object.keys(customLevels || {}).map(key => customLevels[key]),\n useOnlyCustomLevels ? [] : Object.keys(nums).map(level => +level),\n Infinity\n )\n if (!values.includes(defaultLevel)) {\n throw Error(`default level:${defaultLevel} must be included in custom levels`)\n }\n return\n }\n\n const labels = Object.assign(\n Object.create(Object.prototype, { silent: { value: Infinity } }),\n useOnlyCustomLevels ? null : DEFAULT_LEVELS,\n customLevels\n )\n if (!(defaultLevel in labels)) {\n throw Error(`default level:${defaultLevel} must be included in custom levels`)\n }\n}\n\nfunction assertNoLevelCollisions (levels, customLevels) {\n const { labels, values } = levels\n for (const k in customLevels) {\n if (k in values) {\n throw Error('levels cannot be overridden')\n }\n if (customLevels[k] in labels) {\n throw Error('pre-existing level values cannot be used for new levels')\n }\n }\n}\n\n/**\n * Validates whether `levelComparison` is correct\n *\n * @throws Error\n * @param {SORTING_ORDER | Function} levelComparison - value to validate\n * @returns\n */\nfunction assertLevelComparison (levelComparison) {\n if (typeof levelComparison === 'function') {\n return\n }\n\n if (typeof levelComparison === 'string' && Object.values(SORTING_ORDER).includes(levelComparison)) {\n return\n }\n\n throw new Error('Levels comparison should be one of \"ASC\", \"DESC\" or \"function\" type')\n}\n\nmodule.exports = {\n initialLsCache,\n genLsCache,\n levelMethods,\n getLevel,\n setLevel,\n isLevelEnabled,\n mappings,\n assertNoLevelCollisions,\n assertDefaultLevelFound,\n genLevelComparison,\n assertLevelComparison\n}\n","'use strict'\n\nmodule.exports = { version: '9.5.0' }\n","'use strict'\n\n/* eslint no-prototype-builtins: 0 */\n\nconst { EventEmitter } = require('node:events')\nconst {\n lsCacheSym,\n levelValSym,\n setLevelSym,\n getLevelSym,\n chindingsSym,\n parsedChindingsSym,\n mixinSym,\n asJsonSym,\n writeSym,\n mixinMergeStrategySym,\n timeSym,\n timeSliceIndexSym,\n streamSym,\n serializersSym,\n formattersSym,\n errorKeySym,\n messageKeySym,\n useOnlyCustomLevelsSym,\n needsMetadataGsym,\n redactFmtSym,\n stringifySym,\n formatOptsSym,\n stringifiersSym,\n msgPrefixSym\n} = require('./symbols')\nconst {\n getLevel,\n setLevel,\n isLevelEnabled,\n mappings,\n initialLsCache,\n genLsCache,\n assertNoLevelCollisions\n} = require('./levels')\nconst {\n asChindings,\n asJson,\n buildFormatters,\n stringify\n} = require('./tools')\nconst {\n version\n} = require('./meta')\nconst redaction = require('./redaction')\n\n// note: use of class is satirical\n// https://github.com/pinojs/pino/pull/433#pullrequestreview-127703127\nconst constructor = class Pino {}\nconst prototype = {\n constructor,\n child,\n bindings,\n setBindings,\n flush,\n isLevelEnabled,\n version,\n get level () { return this[getLevelSym]() },\n set level (lvl) { this[setLevelSym](lvl) },\n get levelVal () { return this[levelValSym] },\n set levelVal (n) { throw Error('levelVal is read-only') },\n [lsCacheSym]: initialLsCache,\n [writeSym]: write,\n [asJsonSym]: asJson,\n [getLevelSym]: getLevel,\n [setLevelSym]: setLevel\n}\n\nObject.setPrototypeOf(prototype, EventEmitter.prototype)\n\n// exporting and consuming the prototype object using factory pattern fixes scoping issues with getters when serializing\nmodule.exports = function () {\n return Object.create(prototype)\n}\n\nconst resetChildingsFormatter = bindings => bindings\nfunction child (bindings, options) {\n if (!bindings) {\n throw Error('missing bindings for child Pino')\n }\n options = options || {} // default options to empty object\n const serializers = this[serializersSym]\n const formatters = this[formattersSym]\n const instance = Object.create(this)\n\n if (options.hasOwnProperty('serializers') === true) {\n instance[serializersSym] = Object.create(null)\n\n for (const k in serializers) {\n instance[serializersSym][k] = serializers[k]\n }\n const parentSymbols = Object.getOwnPropertySymbols(serializers)\n /* eslint no-var: off */\n for (var i = 0; i < parentSymbols.length; i++) {\n const ks = parentSymbols[i]\n instance[serializersSym][ks] = serializers[ks]\n }\n\n for (const bk in options.serializers) {\n instance[serializersSym][bk] = options.serializers[bk]\n }\n const bindingsSymbols = Object.getOwnPropertySymbols(options.serializers)\n for (var bi = 0; bi < bindingsSymbols.length; bi++) {\n const bks = bindingsSymbols[bi]\n instance[serializersSym][bks] = options.serializers[bks]\n }\n } else instance[serializersSym] = serializers\n if (options.hasOwnProperty('formatters')) {\n const { level, bindings: chindings, log } = options.formatters\n instance[formattersSym] = buildFormatters(\n level || formatters.level,\n chindings || resetChildingsFormatter,\n log || formatters.log\n )\n } else {\n instance[formattersSym] = buildFormatters(\n formatters.level,\n resetChildingsFormatter,\n formatters.log\n )\n }\n if (options.hasOwnProperty('customLevels') === true) {\n assertNoLevelCollisions(this.levels, options.customLevels)\n instance.levels = mappings(options.customLevels, instance[useOnlyCustomLevelsSym])\n genLsCache(instance)\n }\n\n // redact must place before asChindings and only replace if exist\n if ((typeof options.redact === 'object' && options.redact !== null) || Array.isArray(options.redact)) {\n instance.redact = options.redact // replace redact directly\n const stringifiers = redaction(instance.redact, stringify)\n const formatOpts = { stringify: stringifiers[redactFmtSym] }\n instance[stringifySym] = stringify\n instance[stringifiersSym] = stringifiers\n instance[formatOptsSym] = formatOpts\n }\n\n if (typeof options.msgPrefix === 'string') {\n instance[msgPrefixSym] = (this[msgPrefixSym] || '') + options.msgPrefix\n }\n\n instance[chindingsSym] = asChindings(instance, bindings)\n const childLevel = options.level || this.level\n instance[setLevelSym](childLevel)\n this.onChild(instance)\n return instance\n}\n\nfunction bindings () {\n const chindings = this[chindingsSym]\n const chindingsJson = `{${chindings.substr(1)}}` // at least contains ,\"pid\":7068,\"hostname\":\"myMac\"\n const bindingsFromJson = JSON.parse(chindingsJson)\n delete bindingsFromJson.pid\n delete bindingsFromJson.hostname\n return bindingsFromJson\n}\n\nfunction setBindings (newBindings) {\n const chindings = asChindings(this, newBindings)\n this[chindingsSym] = chindings\n delete this[parsedChindingsSym]\n}\n\n/**\n * Default strategy for creating `mergeObject` from arguments and the result from `mixin()`.\n * Fields from `mergeObject` have higher priority in this strategy.\n *\n * @param {Object} mergeObject The object a user has supplied to the logging function.\n * @param {Object} mixinObject The result of the `mixin` method.\n * @return {Object}\n */\nfunction defaultMixinMergeStrategy (mergeObject, mixinObject) {\n return Object.assign(mixinObject, mergeObject)\n}\n\nfunction write (_obj, msg, num) {\n const t = this[timeSym]()\n const mixin = this[mixinSym]\n const errorKey = this[errorKeySym]\n const messageKey = this[messageKeySym]\n const mixinMergeStrategy = this[mixinMergeStrategySym] || defaultMixinMergeStrategy\n let obj\n\n if (_obj === undefined || _obj === null) {\n obj = {}\n } else if (_obj instanceof Error) {\n obj = { [errorKey]: _obj }\n if (msg === undefined) {\n msg = _obj.message\n }\n } else {\n obj = _obj\n if (msg === undefined && _obj[messageKey] === undefined && _obj[errorKey]) {\n msg = _obj[errorKey].message\n }\n }\n\n if (mixin) {\n obj = mixinMergeStrategy(obj, mixin(obj, num, this))\n }\n\n const s = this[asJsonSym](obj, msg, num, t)\n\n const stream = this[streamSym]\n if (stream[needsMetadataGsym] === true) {\n stream.lastLevel = num\n stream.lastObj = obj\n stream.lastMsg = msg\n stream.lastTime = t.slice(this[timeSliceIndexSym])\n stream.lastLogger = this // for child loggers\n }\n stream.write(s)\n}\n\nfunction noop () {}\n\nfunction flush (cb) {\n if (cb != null && typeof cb !== 'function') {\n throw Error('callback must be a function')\n }\n\n const stream = this[streamSym]\n\n if (typeof stream.flush === 'function') {\n stream.flush(cb || noop)\n } else if (cb) cb()\n}\n","'use strict'\n\nconst { hasOwnProperty } = Object.prototype\n\nconst stringify = configure()\n\n// @ts-expect-error\nstringify.configure = configure\n// @ts-expect-error\nstringify.stringify = stringify\n\n// @ts-expect-error\nstringify.default = stringify\n\n// @ts-expect-error used for named export\nexports.stringify = stringify\n// @ts-expect-error used for named export\nexports.configure = configure\n\nmodule.exports = stringify\n\n// eslint-disable-next-line no-control-regex\nconst strEscapeSequencesRegExp = /[\\u0000-\\u001f\\u0022\\u005c\\ud800-\\udfff]/\n\n// Escape C0 control characters, double quotes, the backslash and every code\n// unit with a numeric value in the inclusive range 0xD800 to 0xDFFF.\nfunction strEscape (str) {\n // Some magic numbers that worked out fine while benchmarking with v8 8.0\n if (str.length < 5000 && !strEscapeSequencesRegExp.test(str)) {\n return `\"${str}\"`\n }\n return JSON.stringify(str)\n}\n\nfunction sort (array, comparator) {\n // Insertion sort is very efficient for small input sizes, but it has a bad\n // worst case complexity. Thus, use native array sort for bigger values.\n if (array.length > 2e2 || comparator) {\n return array.sort(comparator)\n }\n for (let i = 1; i < array.length; i++) {\n const currentValue = array[i]\n let position = i\n while (position !== 0 && array[position - 1] > currentValue) {\n array[position] = array[position - 1]\n position--\n }\n array[position] = currentValue\n }\n return array\n}\n\nconst typedArrayPrototypeGetSymbolToStringTag =\n Object.getOwnPropertyDescriptor(\n Object.getPrototypeOf(\n Object.getPrototypeOf(\n new Int8Array()\n )\n ),\n Symbol.toStringTag\n ).get\n\nfunction isTypedArrayWithEntries (value) {\n return typedArrayPrototypeGetSymbolToStringTag.call(value) !== undefined && value.length !== 0\n}\n\nfunction stringifyTypedArray (array, separator, maximumBreadth) {\n if (array.length < maximumBreadth) {\n maximumBreadth = array.length\n }\n const whitespace = separator === ',' ? '' : ' '\n let res = `\"0\":${whitespace}${array[0]}`\n for (let i = 1; i < maximumBreadth; i++) {\n res += `${separator}\"${i}\":${whitespace}${array[i]}`\n }\n return res\n}\n\nfunction getCircularValueOption (options) {\n if (hasOwnProperty.call(options, 'circularValue')) {\n const circularValue = options.circularValue\n if (typeof circularValue === 'string') {\n return `\"${circularValue}\"`\n }\n if (circularValue == null) {\n return circularValue\n }\n if (circularValue === Error || circularValue === TypeError) {\n return {\n toString () {\n throw new TypeError('Converting circular structure to JSON')\n }\n }\n }\n throw new TypeError('The \"circularValue\" argument must be of type string or the value null or undefined')\n }\n return '\"[Circular]\"'\n}\n\nfunction getDeterministicOption (options) {\n let value\n if (hasOwnProperty.call(options, 'deterministic')) {\n value = options.deterministic\n if (typeof value !== 'boolean' && typeof value !== 'function') {\n throw new TypeError('The \"deterministic\" argument must be of type boolean or comparator function')\n }\n }\n return value === undefined ? true : value\n}\n\nfunction getBooleanOption (options, key) {\n let value\n if (hasOwnProperty.call(options, key)) {\n value = options[key]\n if (typeof value !== 'boolean') {\n throw new TypeError(`The \"${key}\" argument must be of type boolean`)\n }\n }\n return value === undefined ? true : value\n}\n\nfunction getPositiveIntegerOption (options, key) {\n let value\n if (hasOwnProperty.call(options, key)) {\n value = options[key]\n if (typeof value !== 'number') {\n throw new TypeError(`The \"${key}\" argument must be of type number`)\n }\n if (!Number.isInteger(value)) {\n throw new TypeError(`The \"${key}\" argument must be an integer`)\n }\n if (value < 1) {\n throw new RangeError(`The \"${key}\" argument must be >= 1`)\n }\n }\n return value === undefined ? Infinity : value\n}\n\nfunction getItemCount (number) {\n if (number === 1) {\n return '1 item'\n }\n return `${number} items`\n}\n\nfunction getUniqueReplacerSet (replacerArray) {\n const replacerSet = new Set()\n for (const value of replacerArray) {\n if (typeof value === 'string' || typeof value === 'number') {\n replacerSet.add(String(value))\n }\n }\n return replacerSet\n}\n\nfunction getStrictOption (options) {\n if (hasOwnProperty.call(options, 'strict')) {\n const value = options.strict\n if (typeof value !== 'boolean') {\n throw new TypeError('The \"strict\" argument must be of type boolean')\n }\n if (value) {\n return (value) => {\n let message = `Object can not safely be stringified. Received type ${typeof value}`\n if (typeof value !== 'function') message += ` (${value.toString()})`\n throw new Error(message)\n }\n }\n }\n}\n\nfunction configure (options) {\n options = { ...options }\n const fail = getStrictOption(options)\n if (fail) {\n if (options.bigint === undefined) {\n options.bigint = false\n }\n if (!('circularValue' in options)) {\n options.circularValue = Error\n }\n }\n const circularValue = getCircularValueOption(options)\n const bigint = getBooleanOption(options, 'bigint')\n const deterministic = getDeterministicOption(options)\n const comparator = typeof deterministic === 'function' ? deterministic : undefined\n const maximumDepth = getPositiveIntegerOption(options, 'maximumDepth')\n const maximumBreadth = getPositiveIntegerOption(options, 'maximumBreadth')\n\n function stringifyFnReplacer (key, parent, stack, replacer, spacer, indentation) {\n let value = parent[key]\n\n if (typeof value === 'object' && value !== null && typeof value.toJSON === 'function') {\n value = value.toJSON(key)\n }\n value = replacer.call(parent, key, value)\n\n switch (typeof value) {\n case 'string':\n return strEscape(value)\n case 'object': {\n if (value === null) {\n return 'null'\n }\n if (stack.indexOf(value) !== -1) {\n return circularValue\n }\n\n let res = ''\n let join = ','\n const originalIndentation = indentation\n\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return '[]'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Array]\"'\n }\n stack.push(value)\n if (spacer !== '') {\n indentation += spacer\n res += `\\n${indentation}`\n join = `,\\n${indentation}`\n }\n const maximumValuesToStringify = Math.min(value.length, maximumBreadth)\n let i = 0\n for (; i < maximumValuesToStringify - 1; i++) {\n const tmp = stringifyFnReplacer(String(i), value, stack, replacer, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n res += join\n }\n const tmp = stringifyFnReplacer(String(i), value, stack, replacer, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n if (value.length - 1 > maximumBreadth) {\n const removedKeys = value.length - maximumBreadth - 1\n res += `${join}\"... ${getItemCount(removedKeys)} not stringified\"`\n }\n if (spacer !== '') {\n res += `\\n${originalIndentation}`\n }\n stack.pop()\n return `[${res}]`\n }\n\n let keys = Object.keys(value)\n const keyLength = keys.length\n if (keyLength === 0) {\n return '{}'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Object]\"'\n }\n let whitespace = ''\n let separator = ''\n if (spacer !== '') {\n indentation += spacer\n join = `,\\n${indentation}`\n whitespace = ' '\n }\n const maximumPropertiesToStringify = Math.min(keyLength, maximumBreadth)\n if (deterministic && !isTypedArrayWithEntries(value)) {\n keys = sort(keys, comparator)\n }\n stack.push(value)\n for (let i = 0; i < maximumPropertiesToStringify; i++) {\n const key = keys[i]\n const tmp = stringifyFnReplacer(key, value, stack, replacer, spacer, indentation)\n if (tmp !== undefined) {\n res += `${separator}${strEscape(key)}:${whitespace}${tmp}`\n separator = join\n }\n }\n if (keyLength > maximumBreadth) {\n const removedKeys = keyLength - maximumBreadth\n res += `${separator}\"...\":${whitespace}\"${getItemCount(removedKeys)} not stringified\"`\n separator = join\n }\n if (spacer !== '' && separator.length > 1) {\n res = `\\n${indentation}${res}\\n${originalIndentation}`\n }\n stack.pop()\n return `{${res}}`\n }\n case 'number':\n return isFinite(value) ? String(value) : fail ? fail(value) : 'null'\n case 'boolean':\n return value === true ? 'true' : 'false'\n case 'undefined':\n return undefined\n case 'bigint':\n if (bigint) {\n return String(value)\n }\n // fallthrough\n default:\n return fail ? fail(value) : undefined\n }\n }\n\n function stringifyArrayReplacer (key, value, stack, replacer, spacer, indentation) {\n if (typeof value === 'object' && value !== null && typeof value.toJSON === 'function') {\n value = value.toJSON(key)\n }\n\n switch (typeof value) {\n case 'string':\n return strEscape(value)\n case 'object': {\n if (value === null) {\n return 'null'\n }\n if (stack.indexOf(value) !== -1) {\n return circularValue\n }\n\n const originalIndentation = indentation\n let res = ''\n let join = ','\n\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return '[]'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Array]\"'\n }\n stack.push(value)\n if (spacer !== '') {\n indentation += spacer\n res += `\\n${indentation}`\n join = `,\\n${indentation}`\n }\n const maximumValuesToStringify = Math.min(value.length, maximumBreadth)\n let i = 0\n for (; i < maximumValuesToStringify - 1; i++) {\n const tmp = stringifyArrayReplacer(String(i), value[i], stack, replacer, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n res += join\n }\n const tmp = stringifyArrayReplacer(String(i), value[i], stack, replacer, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n if (value.length - 1 > maximumBreadth) {\n const removedKeys = value.length - maximumBreadth - 1\n res += `${join}\"... ${getItemCount(removedKeys)} not stringified\"`\n }\n if (spacer !== '') {\n res += `\\n${originalIndentation}`\n }\n stack.pop()\n return `[${res}]`\n }\n stack.push(value)\n let whitespace = ''\n if (spacer !== '') {\n indentation += spacer\n join = `,\\n${indentation}`\n whitespace = ' '\n }\n let separator = ''\n for (const key of replacer) {\n const tmp = stringifyArrayReplacer(key, value[key], stack, replacer, spacer, indentation)\n if (tmp !== undefined) {\n res += `${separator}${strEscape(key)}:${whitespace}${tmp}`\n separator = join\n }\n }\n if (spacer !== '' && separator.length > 1) {\n res = `\\n${indentation}${res}\\n${originalIndentation}`\n }\n stack.pop()\n return `{${res}}`\n }\n case 'number':\n return isFinite(value) ? String(value) : fail ? fail(value) : 'null'\n case 'boolean':\n return value === true ? 'true' : 'false'\n case 'undefined':\n return undefined\n case 'bigint':\n if (bigint) {\n return String(value)\n }\n // fallthrough\n default:\n return fail ? fail(value) : undefined\n }\n }\n\n function stringifyIndent (key, value, stack, spacer, indentation) {\n switch (typeof value) {\n case 'string':\n return strEscape(value)\n case 'object': {\n if (value === null) {\n return 'null'\n }\n if (typeof value.toJSON === 'function') {\n value = value.toJSON(key)\n // Prevent calling `toJSON` again.\n if (typeof value !== 'object') {\n return stringifyIndent(key, value, stack, spacer, indentation)\n }\n if (value === null) {\n return 'null'\n }\n }\n if (stack.indexOf(value) !== -1) {\n return circularValue\n }\n const originalIndentation = indentation\n\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return '[]'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Array]\"'\n }\n stack.push(value)\n indentation += spacer\n let res = `\\n${indentation}`\n const join = `,\\n${indentation}`\n const maximumValuesToStringify = Math.min(value.length, maximumBreadth)\n let i = 0\n for (; i < maximumValuesToStringify - 1; i++) {\n const tmp = stringifyIndent(String(i), value[i], stack, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n res += join\n }\n const tmp = stringifyIndent(String(i), value[i], stack, spacer, indentation)\n res += tmp !== undefined ? tmp : 'null'\n if (value.length - 1 > maximumBreadth) {\n const removedKeys = value.length - maximumBreadth - 1\n res += `${join}\"... ${getItemCount(removedKeys)} not stringified\"`\n }\n res += `\\n${originalIndentation}`\n stack.pop()\n return `[${res}]`\n }\n\n let keys = Object.keys(value)\n const keyLength = keys.length\n if (keyLength === 0) {\n return '{}'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Object]\"'\n }\n indentation += spacer\n const join = `,\\n${indentation}`\n let res = ''\n let separator = ''\n let maximumPropertiesToStringify = Math.min(keyLength, maximumBreadth)\n if (isTypedArrayWithEntries(value)) {\n res += stringifyTypedArray(value, join, maximumBreadth)\n keys = keys.slice(value.length)\n maximumPropertiesToStringify -= value.length\n separator = join\n }\n if (deterministic) {\n keys = sort(keys, comparator)\n }\n stack.push(value)\n for (let i = 0; i < maximumPropertiesToStringify; i++) {\n const key = keys[i]\n const tmp = stringifyIndent(key, value[key], stack, spacer, indentation)\n if (tmp !== undefined) {\n res += `${separator}${strEscape(key)}: ${tmp}`\n separator = join\n }\n }\n if (keyLength > maximumBreadth) {\n const removedKeys = keyLength - maximumBreadth\n res += `${separator}\"...\": \"${getItemCount(removedKeys)} not stringified\"`\n separator = join\n }\n if (separator !== '') {\n res = `\\n${indentation}${res}\\n${originalIndentation}`\n }\n stack.pop()\n return `{${res}}`\n }\n case 'number':\n return isFinite(value) ? String(value) : fail ? fail(value) : 'null'\n case 'boolean':\n return value === true ? 'true' : 'false'\n case 'undefined':\n return undefined\n case 'bigint':\n if (bigint) {\n return String(value)\n }\n // fallthrough\n default:\n return fail ? fail(value) : undefined\n }\n }\n\n function stringifySimple (key, value, stack) {\n switch (typeof value) {\n case 'string':\n return strEscape(value)\n case 'object': {\n if (value === null) {\n return 'null'\n }\n if (typeof value.toJSON === 'function') {\n value = value.toJSON(key)\n // Prevent calling `toJSON` again\n if (typeof value !== 'object') {\n return stringifySimple(key, value, stack)\n }\n if (value === null) {\n return 'null'\n }\n }\n if (stack.indexOf(value) !== -1) {\n return circularValue\n }\n\n let res = ''\n\n const hasLength = value.length !== undefined\n if (hasLength && Array.isArray(value)) {\n if (value.length === 0) {\n return '[]'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Array]\"'\n }\n stack.push(value)\n const maximumValuesToStringify = Math.min(value.length, maximumBreadth)\n let i = 0\n for (; i < maximumValuesToStringify - 1; i++) {\n const tmp = stringifySimple(String(i), value[i], stack)\n res += tmp !== undefined ? tmp : 'null'\n res += ','\n }\n const tmp = stringifySimple(String(i), value[i], stack)\n res += tmp !== undefined ? tmp : 'null'\n if (value.length - 1 > maximumBreadth) {\n const removedKeys = value.length - maximumBreadth - 1\n res += `,\"... ${getItemCount(removedKeys)} not stringified\"`\n }\n stack.pop()\n return `[${res}]`\n }\n\n let keys = Object.keys(value)\n const keyLength = keys.length\n if (keyLength === 0) {\n return '{}'\n }\n if (maximumDepth < stack.length + 1) {\n return '\"[Object]\"'\n }\n let separator = ''\n let maximumPropertiesToStringify = Math.min(keyLength, maximumBreadth)\n if (hasLength && isTypedArrayWithEntries(value)) {\n res += stringifyTypedArray(value, ',', maximumBreadth)\n keys = keys.slice(value.length)\n maximumPropertiesToStringify -= value.length\n separator = ','\n }\n if (deterministic) {\n keys = sort(keys, comparator)\n }\n stack.push(value)\n for (let i = 0; i < maximumPropertiesToStringify; i++) {\n const key = keys[i]\n const tmp = stringifySimple(key, value[key], stack)\n if (tmp !== undefined) {\n res += `${separator}${strEscape(key)}:${tmp}`\n separator = ','\n }\n }\n if (keyLength > maximumBreadth) {\n const removedKeys = keyLength - maximumBreadth\n res += `${separator}\"...\":\"${getItemCount(removedKeys)} not stringified\"`\n }\n stack.pop()\n return `{${res}}`\n }\n case 'number':\n return isFinite(value) ? String(value) : fail ? fail(value) : 'null'\n case 'boolean':\n return value === true ? 'true' : 'false'\n case 'undefined':\n return undefined\n case 'bigint':\n if (bigint) {\n return String(value)\n }\n // fallthrough\n default:\n return fail ? fail(value) : undefined\n }\n }\n\n function stringify (value, replacer, space) {\n if (arguments.length > 1) {\n let spacer = ''\n if (typeof space === 'number') {\n spacer = ' '.repeat(Math.min(space, 10))\n } else if (typeof space === 'string') {\n spacer = space.slice(0, 10)\n }\n if (replacer != null) {\n if (typeof replacer === 'function') {\n return stringifyFnReplacer('', { '': value }, [], replacer, spacer, '')\n }\n if (Array.isArray(replacer)) {\n return stringifyArrayReplacer('', value, [], getUniqueReplacerSet(replacer), spacer, '')\n }\n }\n if (spacer.length !== 0) {\n return stringifyIndent('', value, [], spacer, '')\n }\n }\n return stringifySimple('', value, [])\n }\n\n return stringify\n}\n","'use strict'\n\nconst metadata = Symbol.for('pino.metadata')\nconst { DEFAULT_LEVELS } = require('./constants')\n\nconst DEFAULT_INFO_LEVEL = DEFAULT_LEVELS.info\n\nfunction multistream (streamsArray, opts) {\n let counter = 0\n streamsArray = streamsArray || []\n opts = opts || { dedupe: false }\n\n const streamLevels = Object.create(DEFAULT_LEVELS)\n streamLevels.silent = Infinity\n if (opts.levels && typeof opts.levels === 'object') {\n Object.keys(opts.levels).forEach(i => {\n streamLevels[i] = opts.levels[i]\n })\n }\n\n const res = {\n write,\n add,\n emit,\n flushSync,\n end,\n minLevel: 0,\n streams: [],\n clone,\n [metadata]: true,\n streamLevels\n }\n\n if (Array.isArray(streamsArray)) {\n streamsArray.forEach(add, res)\n } else {\n add.call(res, streamsArray)\n }\n\n // clean this object up\n // or it will stay allocated forever\n // as it is closed on the following closures\n streamsArray = null\n\n return res\n\n // we can exit early because the streams are ordered by level\n function write (data) {\n let dest\n const level = this.lastLevel\n const { streams } = this\n // for handling situation when several streams has the same level\n let recordedLevel = 0\n let stream\n\n // if dedupe set to true we send logs to the stream with the highest level\n // therefore, we have to change sorting order\n for (let i = initLoopVar(streams.length, opts.dedupe); checkLoopVar(i, streams.length, opts.dedupe); i = adjustLoopVar(i, opts.dedupe)) {\n dest = streams[i]\n if (dest.level <= level) {\n if (recordedLevel !== 0 && recordedLevel !== dest.level) {\n break\n }\n stream = dest.stream\n if (stream[metadata]) {\n const { lastTime, lastMsg, lastObj, lastLogger } = this\n stream.lastLevel = level\n stream.lastTime = lastTime\n stream.lastMsg = lastMsg\n stream.lastObj = lastObj\n stream.lastLogger = lastLogger\n }\n stream.write(data)\n if (opts.dedupe) {\n recordedLevel = dest.level\n }\n } else if (!opts.dedupe) {\n break\n }\n }\n }\n\n function emit (...args) {\n for (const { stream } of this.streams) {\n if (typeof stream.emit === 'function') {\n stream.emit(...args)\n }\n }\n }\n\n function flushSync () {\n for (const { stream } of this.streams) {\n if (typeof stream.flushSync === 'function') {\n stream.flushSync()\n }\n }\n }\n\n function add (dest) {\n if (!dest) {\n return res\n }\n\n // Check that dest implements either StreamEntry or DestinationStream\n const isStream = typeof dest.write === 'function' || dest.stream\n const stream_ = dest.write ? dest : dest.stream\n // This is necessary to provide a meaningful error message, otherwise it throws somewhere inside write()\n if (!isStream) {\n throw Error('stream object needs to implement either StreamEntry or DestinationStream interface')\n }\n\n const { streams, streamLevels } = this\n\n let level\n if (typeof dest.levelVal === 'number') {\n level = dest.levelVal\n } else if (typeof dest.level === 'string') {\n level = streamLevels[dest.level]\n } else if (typeof dest.level === 'number') {\n level = dest.level\n } else {\n level = DEFAULT_INFO_LEVEL\n }\n\n const dest_ = {\n stream: stream_,\n level,\n levelVal: undefined,\n id: counter++\n }\n\n streams.unshift(dest_)\n streams.sort(compareByLevel)\n\n this.minLevel = streams[0].level\n\n return res\n }\n\n function end () {\n for (const { stream } of this.streams) {\n if (typeof stream.flushSync === 'function') {\n stream.flushSync()\n }\n stream.end()\n }\n }\n\n function clone (level) {\n const streams = new Array(this.streams.length)\n\n for (let i = 0; i < streams.length; i++) {\n streams[i] = {\n level,\n stream: this.streams[i].stream\n }\n }\n\n return {\n write,\n add,\n minLevel: level,\n streams,\n clone,\n emit,\n flushSync,\n [metadata]: true\n }\n }\n}\n\nfunction compareByLevel (a, b) {\n return a.level - b.level\n}\n\nfunction initLoopVar (length, dedupe) {\n return dedupe ? length - 1 : 0\n}\n\nfunction adjustLoopVar (i, dedupe) {\n return dedupe ? i - 1 : i + 1\n}\n\nfunction checkLoopVar (i, length, dedupe) {\n return dedupe ? i >= 0 : i < length\n}\n\nmodule.exports = multistream\n","'use strict'\n\nconst os = require('node:os')\nconst stdSerializers = require('pino-std-serializers')\nconst caller = require('./lib/caller')\nconst redaction = require('./lib/redaction')\nconst time = require('./lib/time')\nconst proto = require('./lib/proto')\nconst symbols = require('./lib/symbols')\nconst { configure } = require('safe-stable-stringify')\nconst { assertDefaultLevelFound, mappings, genLsCache, genLevelComparison, assertLevelComparison } = require('./lib/levels')\nconst { DEFAULT_LEVELS, SORTING_ORDER } = require('./lib/constants')\nconst {\n createArgsNormalizer,\n asChindings,\n buildSafeSonicBoom,\n buildFormatters,\n stringify,\n normalizeDestFileDescriptor,\n noop\n} = require('./lib/tools')\nconst { version } = require('./lib/meta')\nconst {\n chindingsSym,\n redactFmtSym,\n serializersSym,\n timeSym,\n timeSliceIndexSym,\n streamSym,\n stringifySym,\n stringifySafeSym,\n stringifiersSym,\n setLevelSym,\n endSym,\n formatOptsSym,\n messageKeySym,\n errorKeySym,\n nestedKeySym,\n mixinSym,\n levelCompSym,\n useOnlyCustomLevelsSym,\n formattersSym,\n hooksSym,\n nestedKeyStrSym,\n mixinMergeStrategySym,\n msgPrefixSym\n} = symbols\nconst { epochTime, nullTime } = time\nconst { pid } = process\nconst hostname = os.hostname()\nconst defaultErrorSerializer = stdSerializers.err\nconst defaultOptions = {\n level: 'info',\n levelComparison: SORTING_ORDER.ASC,\n levels: DEFAULT_LEVELS,\n messageKey: 'msg',\n errorKey: 'err',\n nestedKey: null,\n enabled: true,\n base: { pid, hostname },\n serializers: Object.assign(Object.create(null), {\n err: defaultErrorSerializer\n }),\n formatters: Object.assign(Object.create(null), {\n bindings (bindings) {\n return bindings\n },\n level (label, number) {\n return { level: number }\n }\n }),\n hooks: {\n logMethod: undefined\n },\n timestamp: epochTime,\n name: undefined,\n redact: null,\n customLevels: null,\n useOnlyCustomLevels: false,\n depthLimit: 5,\n edgeLimit: 100\n}\n\nconst normalize = createArgsNormalizer(defaultOptions)\n\nconst serializers = Object.assign(Object.create(null), stdSerializers)\n\nfunction pino (...args) {\n const instance = {}\n const { opts, stream } = normalize(instance, caller(), ...args)\n\n if (opts.level && typeof opts.level === 'string' && DEFAULT_LEVELS[opts.level.toLowerCase()] !== undefined) opts.level = opts.level.toLowerCase()\n\n const {\n redact,\n crlf,\n serializers,\n timestamp,\n messageKey,\n errorKey,\n nestedKey,\n base,\n name,\n level,\n customLevels,\n levelComparison,\n mixin,\n mixinMergeStrategy,\n useOnlyCustomLevels,\n formatters,\n hooks,\n depthLimit,\n edgeLimit,\n onChild,\n msgPrefix\n } = opts\n\n const stringifySafe = configure({\n maximumDepth: depthLimit,\n maximumBreadth: edgeLimit\n })\n\n const allFormatters = buildFormatters(\n formatters.level,\n formatters.bindings,\n formatters.log\n )\n\n const stringifyFn = stringify.bind({\n [stringifySafeSym]: stringifySafe\n })\n const stringifiers = redact ? redaction(redact, stringifyFn) : {}\n const formatOpts = redact\n ? { stringify: stringifiers[redactFmtSym] }\n : { stringify: stringifyFn }\n const end = '}' + (crlf ? '\\r\\n' : '\\n')\n const coreChindings = asChindings.bind(null, {\n [chindingsSym]: '',\n [serializersSym]: serializers,\n [stringifiersSym]: stringifiers,\n [stringifySym]: stringify,\n [stringifySafeSym]: stringifySafe,\n [formattersSym]: allFormatters\n })\n\n let chindings = ''\n if (base !== null) {\n if (name === undefined) {\n chindings = coreChindings(base)\n } else {\n chindings = coreChindings(Object.assign({}, base, { name }))\n }\n }\n\n const time = (timestamp instanceof Function)\n ? timestamp\n : (timestamp ? epochTime : nullTime)\n const timeSliceIndex = time().indexOf(':') + 1\n\n if (useOnlyCustomLevels && !customLevels) throw Error('customLevels is required if useOnlyCustomLevels is set true')\n if (mixin && typeof mixin !== 'function') throw Error(`Unknown mixin type \"${typeof mixin}\" - expected \"function\"`)\n if (msgPrefix && typeof msgPrefix !== 'string') throw Error(`Unknown msgPrefix type \"${typeof msgPrefix}\" - expected \"string\"`)\n\n assertDefaultLevelFound(level, customLevels, useOnlyCustomLevels)\n const levels = mappings(customLevels, useOnlyCustomLevels)\n\n if (typeof stream.emit === 'function') {\n stream.emit('message', { code: 'PINO_CONFIG', config: { levels, messageKey, errorKey } })\n }\n\n assertLevelComparison(levelComparison)\n const levelCompFunc = genLevelComparison(levelComparison)\n\n Object.assign(instance, {\n levels,\n [levelCompSym]: levelCompFunc,\n [useOnlyCustomLevelsSym]: useOnlyCustomLevels,\n [streamSym]: stream,\n [timeSym]: time,\n [timeSliceIndexSym]: timeSliceIndex,\n [stringifySym]: stringify,\n [stringifySafeSym]: stringifySafe,\n [stringifiersSym]: stringifiers,\n [endSym]: end,\n [formatOptsSym]: formatOpts,\n [messageKeySym]: messageKey,\n [errorKeySym]: errorKey,\n [nestedKeySym]: nestedKey,\n // protect against injection\n [nestedKeyStrSym]: nestedKey ? `,${JSON.stringify(nestedKey)}:{` : '',\n [serializersSym]: serializers,\n [mixinSym]: mixin,\n [mixinMergeStrategySym]: mixinMergeStrategy,\n [chindingsSym]: chindings,\n [formattersSym]: allFormatters,\n [hooksSym]: hooks,\n silent: noop,\n onChild,\n [msgPrefixSym]: msgPrefix\n })\n\n Object.setPrototypeOf(instance, proto())\n\n genLsCache(instance)\n\n instance[setLevelSym](level)\n\n return instance\n}\n\nmodule.exports = pino\n\nmodule.exports.destination = (dest = process.stdout.fd) => {\n if (typeof dest === 'object') {\n dest.dest = normalizeDestFileDescriptor(dest.dest || process.stdout.fd)\n return buildSafeSonicBoom(dest)\n } else {\n return buildSafeSonicBoom({ dest: normalizeDestFileDescriptor(dest), minLength: 0 })\n }\n}\n\nmodule.exports.transport = require('./lib/transport')\nmodule.exports.multistream = require('./lib/multistream')\n\nmodule.exports.levels = mappings()\nmodule.exports.stdSerializers = serializers\nmodule.exports.stdTimeFunctions = Object.assign({}, time)\nmodule.exports.symbols = symbols\nmodule.exports.version = version\n\n// Enables default and name export with TypeScript and Babel\nmodule.exports.default = pino\nmodule.exports.pino = pino\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.logger = void 0;\nvar pino_1 = __importDefault(require(\"pino\"));\n// Create and configure a Pino logger instance\nvar logger = (0, pino_1.default)({});\nexports.logger = logger;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./logger\"), exports);\n","var clone = (function() {\n'use strict';\n\nfunction _instanceof(obj, type) {\n return type != null && obj instanceof type;\n}\n\nvar nativeMap;\ntry {\n nativeMap = Map;\n} catch(_) {\n // maybe a reference error because no `Map`. Give it a dummy value that no\n // value will ever be an instanceof.\n nativeMap = function() {};\n}\n\nvar nativeSet;\ntry {\n nativeSet = Set;\n} catch(_) {\n nativeSet = function() {};\n}\n\nvar nativePromise;\ntry {\n nativePromise = Promise;\n} catch(_) {\n nativePromise = function() {};\n}\n\n/**\n * Clones (copies) an Object using deep copying.\n *\n * This function supports circular references by default, but if you are certain\n * there are no circular references in your object, you can save some CPU time\n * by calling clone(obj, false).\n *\n * Caution: if `circular` is false and `parent` contains circular references,\n * your program may enter an infinite loop and crash.\n *\n * @param `parent` - the object to be cloned\n * @param `circular` - set to true if the object to be cloned may contain\n * circular references. (optional - true by default)\n * @param `depth` - set to a number if the object is only to be cloned to\n * a particular depth. (optional - defaults to Infinity)\n * @param `prototype` - sets the prototype to be used when cloning an object.\n * (optional - defaults to parent prototype).\n * @param `includeNonEnumerable` - set to true if the non-enumerable properties\n * should be cloned as well. Non-enumerable properties on the prototype\n * chain will be ignored. (optional - false by default)\n*/\nfunction clone(parent, circular, depth, prototype, includeNonEnumerable) {\n if (typeof circular === 'object') {\n depth = circular.depth;\n prototype = circular.prototype;\n includeNonEnumerable = circular.includeNonEnumerable;\n circular = circular.circular;\n }\n // maintain two arrays for circular references, where corresponding parents\n // and children have the same index\n var allParents = [];\n var allChildren = [];\n\n var useBuffer = typeof Buffer != 'undefined';\n\n if (typeof circular == 'undefined')\n circular = true;\n\n if (typeof depth == 'undefined')\n depth = Infinity;\n\n // recurse this function so we don't reset allParents and allChildren\n function _clone(parent, depth) {\n // cloning null always returns null\n if (parent === null)\n return null;\n\n if (depth === 0)\n return parent;\n\n var child;\n var proto;\n if (typeof parent != 'object') {\n return parent;\n }\n\n if (_instanceof(parent, nativeMap)) {\n child = new nativeMap();\n } else if (_instanceof(parent, nativeSet)) {\n child = new nativeSet();\n } else if (_instanceof(parent, nativePromise)) {\n child = new nativePromise(function (resolve, reject) {\n parent.then(function(value) {\n resolve(_clone(value, depth - 1));\n }, function(err) {\n reject(_clone(err, depth - 1));\n });\n });\n } else if (clone.__isArray(parent)) {\n child = [];\n } else if (clone.__isRegExp(parent)) {\n child = new RegExp(parent.source, __getRegExpFlags(parent));\n if (parent.lastIndex) child.lastIndex = parent.lastIndex;\n } else if (clone.__isDate(parent)) {\n child = new Date(parent.getTime());\n } else if (useBuffer && Buffer.isBuffer(parent)) {\n if (Buffer.allocUnsafe) {\n // Node.js >= 4.5.0\n child = Buffer.allocUnsafe(parent.length);\n } else {\n // Older Node.js versions\n child = new Buffer(parent.length);\n }\n parent.copy(child);\n return child;\n } else if (_instanceof(parent, Error)) {\n child = Object.create(parent);\n } else {\n if (typeof prototype == 'undefined') {\n proto = Object.getPrototypeOf(parent);\n child = Object.create(proto);\n }\n else {\n child = Object.create(prototype);\n proto = prototype;\n }\n }\n\n if (circular) {\n var index = allParents.indexOf(parent);\n\n if (index != -1) {\n return allChildren[index];\n }\n allParents.push(parent);\n allChildren.push(child);\n }\n\n if (_instanceof(parent, nativeMap)) {\n parent.forEach(function(value, key) {\n var keyChild = _clone(key, depth - 1);\n var valueChild = _clone(value, depth - 1);\n child.set(keyChild, valueChild);\n });\n }\n if (_instanceof(parent, nativeSet)) {\n parent.forEach(function(value) {\n var entryChild = _clone(value, depth - 1);\n child.add(entryChild);\n });\n }\n\n for (var i in parent) {\n var attrs;\n if (proto) {\n attrs = Object.getOwnPropertyDescriptor(proto, i);\n }\n\n if (attrs && attrs.set == null) {\n continue;\n }\n child[i] = _clone(parent[i], depth - 1);\n }\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(parent);\n for (var i = 0; i < symbols.length; i++) {\n // Don't need to worry about cloning a symbol because it is a primitive,\n // like a number or string.\n var symbol = symbols[i];\n var descriptor = Object.getOwnPropertyDescriptor(parent, symbol);\n if (descriptor && !descriptor.enumerable && !includeNonEnumerable) {\n continue;\n }\n child[symbol] = _clone(parent[symbol], depth - 1);\n if (!descriptor.enumerable) {\n Object.defineProperty(child, symbol, {\n enumerable: false\n });\n }\n }\n }\n\n if (includeNonEnumerable) {\n var allPropertyNames = Object.getOwnPropertyNames(parent);\n for (var i = 0; i < allPropertyNames.length; i++) {\n var propertyName = allPropertyNames[i];\n var descriptor = Object.getOwnPropertyDescriptor(parent, propertyName);\n if (descriptor && descriptor.enumerable) {\n continue;\n }\n child[propertyName] = _clone(parent[propertyName], depth - 1);\n Object.defineProperty(child, propertyName, {\n enumerable: false\n });\n }\n }\n\n return child;\n }\n\n return _clone(parent, depth);\n}\n\n/**\n * Simple flat clone using prototype, accepts only objects, usefull for property\n * override on FLAT configuration object (no nested props).\n *\n * USE WITH CAUTION! This may not behave as you wish if you do not know how this\n * works.\n */\nclone.clonePrototype = function clonePrototype(parent) {\n if (parent === null)\n return null;\n\n var c = function () {};\n c.prototype = parent;\n return new c();\n};\n\n// private utility functions\n\nfunction __objToStr(o) {\n return Object.prototype.toString.call(o);\n}\nclone.__objToStr = __objToStr;\n\nfunction __isDate(o) {\n return typeof o === 'object' && __objToStr(o) === '[object Date]';\n}\nclone.__isDate = __isDate;\n\nfunction __isArray(o) {\n return typeof o === 'object' && __objToStr(o) === '[object Array]';\n}\nclone.__isArray = __isArray;\n\nfunction __isRegExp(o) {\n return typeof o === 'object' && __objToStr(o) === '[object RegExp]';\n}\nclone.__isRegExp = __isRegExp;\n\nfunction __getRegExpFlags(re) {\n var flags = '';\n if (re.global) flags += 'g';\n if (re.ignoreCase) flags += 'i';\n if (re.multiline) flags += 'm';\n return flags;\n}\nclone.__getRegExpFlags = __getRegExpFlags;\n\nreturn clone;\n})();\n\nif (typeof module === 'object' && module.exports) {\n module.exports = clone;\n}\n","/*\n * node-cache 5.1.2 ( 2020-07-01 )\n * https://github.com/node-cache/node-cache\n *\n * Released under the MIT license\n * https://github.com/node-cache/node-cache/blob/master/LICENSE\n *\n * Maintained by ( )\n*/\n(function() {\n var EventEmitter, NodeCache, clone,\n splice = [].splice,\n boundMethodCheck = function(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new Error('Bound instance method accessed before binding'); } },\n indexOf = [].indexOf;\n\n clone = require(\"clone\");\n\n EventEmitter = require('events').EventEmitter;\n\n // generate superclass\n module.exports = NodeCache = (function() {\n class NodeCache extends EventEmitter {\n constructor(options = {}) {\n super();\n // ## get\n\n // get a cached key and change the stats\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key\n\n // **Example:**\n\n //\tmyCache.get \"myKey\", ( err, val )\n\n this.get = this.get.bind(this);\n // ## mget\n\n // get multiple cached keys at once and change the stats\n\n // **Parameters:**\n\n // * `keys` ( String|Number[] ): an array of keys\n\n // **Example:**\n\n //\tmyCache.mget [ \"foo\", \"bar\" ]\n\n this.mget = this.mget.bind(this);\n // ## set\n\n // set a cached key and change the stats\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key\n // * `value` ( Any ): A element to cache. If the option `option.forceString` is `true` the module trys to translate it to a serialized JSON\n // * `[ ttl ]` ( Number | String ): ( optional ) The time to live in seconds.\n\n // **Example:**\n\n //\tmyCache.set \"myKey\", \"my_String Value\"\n\n //\tmyCache.set \"myKey\", \"my_String Value\", 10\n\n this.set = this.set.bind(this);\n \n // ## mset\n\n // set multiple keys at once\n\n // **Parameters:**\n\n // * `keyValueSet` ( Object[] ): an array of object which includes key,value and ttl\n\n // **Example:**\n\n //\tmyCache.mset(\n //\t\t[\n //\t\t\t{\n //\t\t\t\tkey: \"myKey\",\n //\t\t\t\tval: \"myValue\",\n //\t\t\t\tttl: [ttl in seconds]\n //\t\t\t}\n //\t\t])\n\n this.mset = this.mset.bind(this);\n // ## del\n\n // remove keys\n\n // **Parameters:**\n\n // * `keys` ( String | Number | String|Number[] ): cache key to delete or a array of cache keys\n\n // **Return**\n\n // ( Number ): Number of deleted keys\n\n // **Example:**\n\n //\tmyCache.del( \"myKey\" )\n\n this.del = this.del.bind(this);\n // ## take\n\n // get the cached value and remove the key from the cache.\n // Equivalent to calling `get(key)` + `del(key)`.\n // Useful for implementing `single use` mechanism such as OTP, where once a value is read it will become obsolete.\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key\n\n // **Example:**\n\n //\tmyCache.take \"myKey\", ( err, val )\n\n this.take = this.take.bind(this);\n // ## ttl\n\n // reset or redefine the ttl of a key. `ttl` = 0 means infinite lifetime.\n // If `ttl` is not passed the default ttl is used.\n // If `ttl` < 0 the key will be deleted.\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key to reset the ttl value\n // * `ttl` ( Number ): ( optional -> options.stdTTL || 0 ) The time to live in seconds\n\n // **Return**\n\n // ( Boolen ): key found and ttl set\n\n // **Example:**\n\n //\tmyCache.ttl( \"myKey\" ) // will set ttl to default ttl\n\n //\tmyCache.ttl( \"myKey\", 1000 )\n\n this.ttl = this.ttl.bind(this);\n // ## getTtl\n\n // receive the ttl of a key.\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key to check the ttl value\n\n // **Return**\n\n // ( Number|undefined ): The timestamp in ms when the key will expire, 0 if it will never expire or undefined if it not exists\n\n // **Example:**\n\n //\tmyCache.getTtl( \"myKey\" )\n\n this.getTtl = this.getTtl.bind(this);\n // ## keys\n\n // list all keys within this cache\n\n // **Return**\n\n // ( Array ): An array of all keys\n\n // **Example:**\n\n // _keys = myCache.keys()\n\n // # [ \"foo\", \"bar\", \"fizz\", \"buzz\", \"anotherKeys\" ]\n\n this.keys = this.keys.bind(this);\n // ## has\n\n // Check if a key is cached\n\n // **Parameters:**\n\n // * `key` ( String | Number ): cache key to check the ttl value\n\n // **Return**\n\n // ( Boolean ): A boolean that indicates if the key is cached\n\n // **Example:**\n\n // _exists = myCache.has('myKey')\n\n // # true\n\n this.has = this.has.bind(this);\n // ## getStats\n\n // get the stats\n\n // **Parameters:**\n\n // -\n\n // **Return**\n\n // ( Object ): Stats data\n\n // **Example:**\n\n // myCache.getStats()\n // # {\n // # hits: 0,\n // # misses: 0,\n // # keys: 0,\n // # ksize: 0,\n // # vsize: 0\n // # }\n\n this.getStats = this.getStats.bind(this);\n // ## flushAll\n\n // flush the whole data and reset the stats\n\n // **Example:**\n\n // myCache.flushAll()\n\n // myCache.getStats()\n // # {\n // # hits: 0,\n // # misses: 0,\n // # keys: 0,\n // # ksize: 0,\n // # vsize: 0\n // # }\n\n this.flushAll = this.flushAll.bind(this);\n \n // ## flushStats\n\n // flush the stats and reset all counters to 0\n\n // **Example:**\n\n // myCache.flushStats()\n\n // myCache.getStats()\n // # {\n // # hits: 0,\n // # misses: 0,\n // # keys: 0,\n // # ksize: 0,\n // # vsize: 0\n // # }\n\n this.flushStats = this.flushStats.bind(this);\n // ## close\n\n // This will clear the interval timeout which is set on checkperiod option.\n\n // **Example:**\n\n // myCache.close()\n\n this.close = this.close.bind(this);\n // ## _checkData\n\n // internal housekeeping method.\n // Check all the cached data and delete the invalid values\n this._checkData = this._checkData.bind(this);\n // ## _check\n\n // internal method the check the value. If it's not valid any more delete it\n this._check = this._check.bind(this);\n // ## _isInvalidKey\n\n // internal method to check if the type of a key is either `number` or `string`\n this._isInvalidKey = this._isInvalidKey.bind(this);\n // ## _wrap\n\n // internal method to wrap a value in an object with some metadata\n this._wrap = this._wrap.bind(this);\n // ## _getValLength\n\n // internal method to calculate the value length\n this._getValLength = this._getValLength.bind(this);\n // ## _error\n\n // internal method to handle an error message\n this._error = this._error.bind(this);\n // ## _initErrors\n\n // internal method to generate error message templates\n this._initErrors = this._initErrors.bind(this);\n this.options = options;\n this._initErrors();\n // container for cached data\n this.data = {};\n // module options\n this.options = Object.assign({\n // convert all elements to string\n forceString: false,\n // used standard size for calculating value size\n objectValueSize: 80,\n promiseValueSize: 80,\n arrayValueSize: 40,\n // standard time to live in seconds. 0 = infinity;\n stdTTL: 0,\n // time in seconds to check all data and delete expired keys\n checkperiod: 600,\n // en/disable cloning of variables. If `true` you'll get a copy of the cached variable. If `false` you'll save and get just the reference\n useClones: true,\n // whether values should be deleted automatically at expiration\n deleteOnExpire: true,\n // enable legacy callbacks\n enableLegacyCallbacks: false,\n // max amount of keys that are being stored\n maxKeys: -1\n }, this.options);\n // generate functions with callbacks (legacy)\n if (this.options.enableLegacyCallbacks) {\n console.warn(\"WARNING! node-cache legacy callback support will drop in v6.x\");\n [\"get\", \"mget\", \"set\", \"del\", \"ttl\", \"getTtl\", \"keys\", \"has\"].forEach((methodKey) => {\n var oldMethod;\n // reference real function\n oldMethod = this[methodKey];\n this[methodKey] = function(...args) {\n var cb, err, ref, res;\n ref = args, [...args] = ref, [cb] = splice.call(args, -1);\n // return a callback if cb is defined and a function\n if (typeof cb === \"function\") {\n try {\n res = oldMethod(...args);\n cb(null, res);\n } catch (error1) {\n err = error1;\n cb(err);\n }\n } else {\n return oldMethod(...args, cb);\n }\n };\n });\n }\n // statistics container\n this.stats = {\n hits: 0,\n misses: 0,\n keys: 0,\n ksize: 0,\n vsize: 0\n };\n // pre allocate valid keytypes array\n this.validKeyTypes = [\"string\", \"number\"];\n // initalize checking period\n this._checkData();\n return;\n }\n\n get(key) {\n var _ret, err;\n boundMethodCheck(this, NodeCache);\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // get data and incremet stats\n if ((this.data[key] != null) && this._check(key, this.data[key])) {\n this.stats.hits++;\n _ret = this._unwrap(this.data[key]);\n // return data\n return _ret;\n } else {\n // if not found return undefined\n this.stats.misses++;\n return void 0;\n }\n }\n\n mget(keys) {\n var _err, err, i, key, len, oRet;\n boundMethodCheck(this, NodeCache);\n // convert a string to an array of one key\n if (!Array.isArray(keys)) {\n _err = this._error(\"EKEYSTYPE\");\n throw _err;\n }\n // define return\n oRet = {};\n for (i = 0, len = keys.length; i < len; i++) {\n key = keys[i];\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // get data and increment stats\n if ((this.data[key] != null) && this._check(key, this.data[key])) {\n this.stats.hits++;\n oRet[key] = this._unwrap(this.data[key]);\n } else {\n // if not found return a error\n this.stats.misses++;\n }\n }\n // return all found keys\n return oRet;\n }\n\n set(key, value, ttl) {\n var _err, err, existent;\n boundMethodCheck(this, NodeCache);\n // check if cache is overflowing\n if (this.options.maxKeys > -1 && this.stats.keys >= this.options.maxKeys) {\n _err = this._error(\"ECACHEFULL\");\n throw _err;\n }\n // force the data to string\n if (this.options.forceString && !typeof value === \"string\") {\n value = JSON.stringify(value);\n }\n // set default ttl if not passed\n if (ttl == null) {\n ttl = this.options.stdTTL;\n }\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // internal helper variables\n existent = false;\n // remove existing data from stats\n if (this.data[key]) {\n existent = true;\n this.stats.vsize -= this._getValLength(this._unwrap(this.data[key], false));\n }\n // set the value\n this.data[key] = this._wrap(value, ttl);\n this.stats.vsize += this._getValLength(value);\n // only add the keys and key-size if the key is new\n if (!existent) {\n this.stats.ksize += this._getKeyLength(key);\n this.stats.keys++;\n }\n this.emit(\"set\", key, value);\n // return true\n return true;\n }\n\n mset(keyValueSet) {\n var _err, err, i, j, key, keyValuePair, len, len1, ttl, val;\n boundMethodCheck(this, NodeCache);\n // check if cache is overflowing\n if (this.options.maxKeys > -1 && this.stats.keys + keyValueSet.length >= this.options.maxKeys) {\n _err = this._error(\"ECACHEFULL\");\n throw _err;\n }\n\n// loop over keyValueSet to validate key and ttl\n for (i = 0, len = keyValueSet.length; i < len; i++) {\n keyValuePair = keyValueSet[i];\n ({key, val, ttl} = keyValuePair);\n // check if there is ttl and it's a number\n if (ttl && typeof ttl !== \"number\") {\n _err = this._error(\"ETTLTYPE\");\n throw _err;\n }\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n }\n for (j = 0, len1 = keyValueSet.length; j < len1; j++) {\n keyValuePair = keyValueSet[j];\n ({key, val, ttl} = keyValuePair);\n this.set(key, val, ttl);\n }\n return true;\n }\n\n del(keys) {\n var delCount, err, i, key, len, oldVal;\n boundMethodCheck(this, NodeCache);\n // convert keys to an array of itself\n if (!Array.isArray(keys)) {\n keys = [keys];\n }\n delCount = 0;\n for (i = 0, len = keys.length; i < len; i++) {\n key = keys[i];\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // only delete if existent\n if (this.data[key] != null) {\n // calc the stats\n this.stats.vsize -= this._getValLength(this._unwrap(this.data[key], false));\n this.stats.ksize -= this._getKeyLength(key);\n this.stats.keys--;\n delCount++;\n // delete the value\n oldVal = this.data[key];\n delete this.data[key];\n // return true\n this.emit(\"del\", key, oldVal.v);\n }\n }\n return delCount;\n }\n\n take(key) {\n var _ret;\n boundMethodCheck(this, NodeCache);\n _ret = this.get(key);\n if ((_ret != null)) {\n this.del(key);\n }\n return _ret;\n }\n\n ttl(key, ttl) {\n var err;\n boundMethodCheck(this, NodeCache);\n ttl || (ttl = this.options.stdTTL);\n if (!key) {\n return false;\n }\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // check for existent data and update the ttl value\n if ((this.data[key] != null) && this._check(key, this.data[key])) {\n // if ttl < 0 delete the key. otherwise reset the value\n if (ttl >= 0) {\n this.data[key] = this._wrap(this.data[key].v, ttl, false);\n } else {\n this.del(key);\n }\n return true;\n } else {\n // return false if key has not been found\n return false;\n }\n }\n\n getTtl(key) {\n var _ttl, err;\n boundMethodCheck(this, NodeCache);\n if (!key) {\n return void 0;\n }\n // handle invalid key types\n if ((err = this._isInvalidKey(key)) != null) {\n throw err;\n }\n // check for existant data and update the ttl value\n if ((this.data[key] != null) && this._check(key, this.data[key])) {\n _ttl = this.data[key].t;\n return _ttl;\n } else {\n // return undefined if key has not been found\n return void 0;\n }\n }\n\n keys() {\n var _keys;\n boundMethodCheck(this, NodeCache);\n _keys = Object.keys(this.data);\n return _keys;\n }\n\n has(key) {\n var _exists;\n boundMethodCheck(this, NodeCache);\n _exists = (this.data[key] != null) && this._check(key, this.data[key]);\n return _exists;\n }\n\n getStats() {\n boundMethodCheck(this, NodeCache);\n return this.stats;\n }\n\n flushAll(_startPeriod = true) {\n boundMethodCheck(this, NodeCache);\n // parameter just for testing\n\n // set data empty\n this.data = {};\n // reset stats\n this.stats = {\n hits: 0,\n misses: 0,\n keys: 0,\n ksize: 0,\n vsize: 0\n };\n // reset check period\n this._killCheckPeriod();\n this._checkData(_startPeriod);\n this.emit(\"flush\");\n }\n\n flushStats() {\n boundMethodCheck(this, NodeCache);\n // reset stats\n this.stats = {\n hits: 0,\n misses: 0,\n keys: 0,\n ksize: 0,\n vsize: 0\n };\n this.emit(\"flush_stats\");\n }\n\n close() {\n boundMethodCheck(this, NodeCache);\n this._killCheckPeriod();\n }\n\n _checkData(startPeriod = true) {\n var key, ref, value;\n boundMethodCheck(this, NodeCache);\n ref = this.data;\n // run the housekeeping method\n for (key in ref) {\n value = ref[key];\n this._check(key, value);\n }\n if (startPeriod && this.options.checkperiod > 0) {\n this.checkTimeout = setTimeout(this._checkData, this.options.checkperiod * 1000, startPeriod);\n if ((this.checkTimeout != null) && (this.checkTimeout.unref != null)) {\n this.checkTimeout.unref();\n }\n }\n }\n\n // ## _killCheckPeriod\n\n // stop the checkdata period. Only needed to abort the script in testing mode.\n _killCheckPeriod() {\n if (this.checkTimeout != null) {\n return clearTimeout(this.checkTimeout);\n }\n }\n\n _check(key, data) {\n var _retval;\n boundMethodCheck(this, NodeCache);\n _retval = true;\n // data is invalid if the ttl is too old and is not 0\n // console.log data.t < Date.now(), data.t, Date.now()\n if (data.t !== 0 && data.t < Date.now()) {\n if (this.options.deleteOnExpire) {\n _retval = false;\n this.del(key);\n }\n this.emit(\"expired\", key, this._unwrap(data));\n }\n return _retval;\n }\n\n _isInvalidKey(key) {\n var ref;\n boundMethodCheck(this, NodeCache);\n if (ref = typeof key, indexOf.call(this.validKeyTypes, ref) < 0) {\n return this._error(\"EKEYTYPE\", {\n type: typeof key\n });\n }\n }\n\n _wrap(value, ttl, asClone = true) {\n var livetime, now, oReturn, ttlMultiplicator;\n boundMethodCheck(this, NodeCache);\n if (!this.options.useClones) {\n asClone = false;\n }\n // define the time to live\n now = Date.now();\n livetime = 0;\n ttlMultiplicator = 1000;\n // use given ttl\n if (ttl === 0) {\n livetime = 0;\n } else if (ttl) {\n livetime = now + (ttl * ttlMultiplicator);\n } else {\n // use standard ttl\n if (this.options.stdTTL === 0) {\n livetime = this.options.stdTTL;\n } else {\n livetime = now + (this.options.stdTTL * ttlMultiplicator);\n }\n }\n // return the wrapped value\n return oReturn = {\n t: livetime,\n v: asClone ? clone(value) : value\n };\n }\n\n // ## _unwrap\n\n // internal method to extract get the value out of the wrapped value\n _unwrap(value, asClone = true) {\n if (!this.options.useClones) {\n asClone = false;\n }\n if (value.v != null) {\n if (asClone) {\n return clone(value.v);\n } else {\n return value.v;\n }\n }\n return null;\n }\n\n // ## _getKeyLength\n\n // internal method the calculate the key length\n _getKeyLength(key) {\n return key.toString().length;\n }\n\n _getValLength(value) {\n boundMethodCheck(this, NodeCache);\n if (typeof value === \"string\") {\n // if the value is a String get the real length\n return value.length;\n } else if (this.options.forceString) {\n // force string if it's defined and not passed\n return JSON.stringify(value).length;\n } else if (Array.isArray(value)) {\n // if the data is an Array multiply each element with a defined default length\n return this.options.arrayValueSize * value.length;\n } else if (typeof value === \"number\") {\n return 8;\n } else if (typeof (value != null ? value.then : void 0) === \"function\") {\n // if the data is a Promise, use defined default\n // (can't calculate actual/resolved value size synchronously)\n return this.options.promiseValueSize;\n } else if (typeof Buffer !== \"undefined\" && Buffer !== null ? Buffer.isBuffer(value) : void 0) {\n return value.length;\n } else if ((value != null) && typeof value === \"object\") {\n // if the data is an Object multiply each element with a defined default length\n return this.options.objectValueSize * Object.keys(value).length;\n } else if (typeof value === \"boolean\") {\n return 8;\n } else {\n // default fallback\n return 0;\n }\n }\n\n _error(type, data = {}) {\n var error;\n boundMethodCheck(this, NodeCache);\n // generate the error object\n error = new Error();\n error.name = type;\n error.errorcode = type;\n error.message = this.ERRORS[type] != null ? this.ERRORS[type](data) : \"-\";\n error.data = data;\n // return the error object\n return error;\n }\n\n _initErrors() {\n var _errMsg, _errT, ref;\n boundMethodCheck(this, NodeCache);\n this.ERRORS = {};\n ref = this._ERRORS;\n for (_errT in ref) {\n _errMsg = ref[_errT];\n this.ERRORS[_errT] = this.createErrorMessage(_errMsg);\n }\n }\n\n createErrorMessage(errMsg) {\n return function(args) {\n return errMsg.replace(\"__key\", args.type);\n };\n }\n\n };\n\n NodeCache.prototype._ERRORS = {\n \"ENOTFOUND\": \"Key `__key` not found\",\n \"ECACHEFULL\": \"Cache max keys amount exceeded\",\n \"EKEYTYPE\": \"The key argument has to be of type `string` or `number`. Found: `__key`\",\n \"EKEYSTYPE\": \"The keys argument has to be an array.\",\n \"ETTLTYPE\": \"The ttl argument has to be a number.\"\n };\n\n return NodeCache;\n\n }).call(this);\n\n}).call(this);\n","/*\n * node-cache 5.1.2 ( 2020-07-01 )\n * https://github.com/node-cache/node-cache\n *\n * Released under the MIT license\n * https://github.com/node-cache/node-cache/blob/master/LICENSE\n *\n * Maintained by ( )\n*/\n(function() {\n var exports;\n\n exports = module.exports = require('./lib/node_cache');\n\n exports.version = '5.1.2';\n\n}).call(this);\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.deleteCacheData = exports.getCacheData = exports.setCacheData = void 0;\nvar node_cache_1 = __importDefault(require(\"node-cache\"));\nvar cache = new node_cache_1.default();\n// Function to set data in the cache\nvar setCacheData = function (key, value) {\n cache.set(key, value);\n};\nexports.setCacheData = setCacheData;\n// Function to get data from the cache\nvar getCacheData = function (key) {\n return cache.get(key);\n};\nexports.getCacheData = getCacheData;\n// Function to delete data from the cache\nvar deleteCacheData = function (key) {\n return cache.del(key);\n};\nexports.deleteCacheData = deleteCacheData;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./cache\"), exports);\n","export * from \"./mqttClient\";\n","import { connect } from \"mqtt\";\nimport { logger } from \"@mysetup/logger\";\nimport type { MqttClient } from \"mqtt\";\nimport { setCacheData } from \"@mysetup/cache\";\n\nexport type { MqttClient };\n\ntype MQttOptionProps = \"web\" | \"server\";\n\nconst serverConnectOptions = {\n protocol: \"mqtt\",\n port: 1883,\n host: \"test.mosquitto.org\",\n};\n\nconst webConnectOptions = {\n protocol: \"wss\",\n port: 8081,\n host: \"test.mosquitto.org\",\n};\n\ninterface ConnectionProps {\n value: string;\n option: MQttOptionProps;\n topicList: string[];\n messageCallback?: (topic: string, message: string) => void;\n}\n\nlet mqttClientId = \"\";\n\nconst checkInitConnect = (props: ConnectionProps) => {\n const { protocol, host, port } =\n props.option === \"web\" ? webConnectOptions : serverConnectOptions;\n const connectUrl = `${protocol}://${host}:${port}`;\n\n const client = connect(connectUrl, {\n clientId: props.value,\n clean: true,\n rejectUnauthorized: false,\n resubscribe: true,\n keepalive: 300,\n });\n\n mqttClientId = props.value;\n client.setMaxListeners(100);\n\n client.on(\"connect\", () => {\n logger.info(\"MQTT connection successful\");\n setCacheData(\"mqttClientStatus\", \"connect\");\n mqttSub(props.topicList, props.messageCallback, client);\n });\n\n client.on(\"error\", (err: Error) => {\n logger.error(`MQTT Connection error: ${JSON.stringify(err)}`);\n setCacheData(\"mqttClientStatus\", \"error\");\n mqttDisconnect(props, true, client);\n });\n\n client.on(\"reconnect\", () => {\n setCacheData(\"mqttClientStatus\", \"reconnect\");\n logger.info(\"MQTT Reconnecting\");\n });\n\n client.on(\"close\", () => {\n setCacheData(\"mqttClientStatus\", \"close\");\n logger.info(\"MQTT connection closed\");\n });\n\n client.on(\"offline\", () => {\n setCacheData(\"mqttClientStatus\", \"offline\");\n logger.info(\"MQTT connection offline\");\n });\n\n return client;\n};\n\nconst mqttSub = (\n topicList: string[],\n messageCallback?: (topic: string, message: string) => void,\n client?: MqttClient,\n) => {\n try {\n client?.subscribe(topicList, { qos: 0 }, (error, granted) => {\n if (error) {\n logger.error(`Subscribe to topics error: ${error.message}`);\n }\n\n const grantedList: string[] = [];\n granted?.forEach((element) => {\n grantedList.push(element.topic);\n logger.info(`Subscribed to topics: ${element.topic}`);\n });\n setCacheData(\"subscribedTopic\", grantedList);\n\n messageCallback && mqttOnMessage(messageCallback, client);\n });\n } catch (error) {\n logger.error(`Subscribed error ${JSON.stringify(error)}`);\n }\n};\n\nconst mqttUnSub = (topicList: string[], client?: MqttClient) => {\n try {\n client?.unsubscribe(topicList, (error) => {\n if (error) {\n logger.error(`Unsubscribe to topics error: ${error.message}`);\n return;\n }\n topicList.forEach((topic) => {\n logger.info(`unsubscribed to topic: ${topic}`);\n });\n });\n } catch (error) {\n logger.error(`unsubscribed error: ${JSON.stringify(error)}`);\n }\n};\n\nconst mqttDisconnect = (\n props: ConnectionProps,\n reinit: boolean,\n client?: MqttClient,\n) => {\n try {\n client?.end(false, () => {\n logger.info(\"MQTT disconnected successfully\");\n if (reinit) {\n cachedConnection({\n ...props,\n value: `client${Math.random().toString(36).substring(7)}`,\n });\n }\n });\n } catch (error) {\n logger.error(`disconnect error: ${JSON.stringify(error)}`);\n }\n};\n\nconst mqttOnMessage = (\n messageCallback: (topic: string, message: string) => void,\n client?: MqttClient,\n) => {\n try {\n client?.on(\"message\", (topic, message) => {\n messageCallback(topic, message.toString());\n });\n } catch (error) {\n logger.error(`MQTT onmessage error: ${JSON.stringify(error)}`);\n }\n};\n\nconst memoizedDb = () => {\n const cache: Record<string, MqttClient> = {};\n return (props: ConnectionProps) => {\n if (props.value in cache) {\n logger.info(\"fetching mqtt cache\");\n return cache[props.value];\n }\n logger.info(\"Creating new mqtt cache\");\n const result = checkInitConnect(props);\n cache[props.value] = result;\n return result;\n };\n};\n\n// returned function from memoizedDb\nconst cachedConnection = memoizedDb();\n\nconst mqttCreateConnection = (props: ConnectionProps) => {\n return cachedConnection(props);\n};\n\nconst getMqttClient = () => {\n return mqttClientId;\n};\n\nexport {\n mqttCreateConnection,\n mqttSub,\n mqttUnSub,\n mqttDisconnect,\n mqttOnMessage,\n getMqttClient,\n};\n"],"mappings":"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","names":["exports","exports","module","self","EventTarget","defineEventAttribute","exports","module","Blob","isBlob","exports","module","Base","exports","module","String","ERR_INVALID_ARG_TYPE","exports","module","exports","module","exports","module","process","ERR_INVALID_ARG_TYPE","Promise","exports","module","process","Symbol","self","err","exports","module","exports","module","ERR_INVALID_ARG_TYPE","exports","module","Uint8Array","Buffer","exports","module","exports","module","process","Buffer","ERR_INVALID_ARG_TYPE","exports","module","process","Promise","Symbol","Buffer","ERR_INVALID_ARG_TYPE","self","exports","module","process","Error","Symbol","Buffer","ERR_INVALID_ARG_TYPE","stream","state","exports","module","process","ERR_INVALID_ARG_TYPE","Blob","isBlob","then","exports","module","exports","module","Symbol","exports","module","exports","module","process","Promise","ERR_INVALID_ARG_TYPE","err","onError","endFn","exports","module","writable","readable","exports","module","ERR_INVALID_ARG_TYPE","Boolean","Number","Promise","Symbol","map","asIndexedPairs","options","flatMap","drop","take","exports","module","Promise","exports","module","Buffer","fn","exports","module","exports","module","exports","module","exports","module","Buffer","copy","m","exports","module","piper","exports","module","exports","module","Buffer","exports","module","exports","module","self","exports","module","load","exports","module","exports","module","exports","module","load","useColors","exports","module","exports","module","exports","module","Buffer","cache","exports","module","exports","module","Buffer","connect","name","value","exports","module","Buffer","exports","exports","exports","module","handler","exports","module","exports","exports","exports","exports","module","exports","exports","exports","_a","Stack","v","bf","exports","__extends","ContainerIterator","Base","Container","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","iteratorType","equals","iter","_node","_length","defineProperty","get","enumerable","configurable","size","empty","_super","apply","arguments","__extends","Stack","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","container","_this","_stack","self","forEach","el","push","clear","_length","element","pop","top","Base","__extends","Queue","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","container","_this","_first","_queue","self","forEach","el","push","clear","_length","element","capacity","length","length_1","i","pop","front","Base","__extends","__read","__spreadArray","PriorityQueue","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","o","n","m","Symbol","iterator","i","r","ar","e","next","done","push","value","error","to","from","pack","arguments","length","l","slice","concat","_super","container","cmp","copy","x","y","_this","_cmp","isArray","_priorityQueue","self_1","forEach","el","_length","halfLength","parent_1","_pushDown","_pushUp","pos","item","parent_2","parentItem","left","right","minItem","clear","pop","last","top","find","indexOf","remove","index","splice","updateItem","toArray","Base","__extends","SequentialContainer","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","apply","arguments","Container","throwIteratorAccessError","RangeError","__extends","RandomIterator","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","index","iteratorType","_this","_node","pre","throwIteratorAccessError","next","container","size","defineProperty","get","getElementByPos","set","newValue","setElementByPos","enumerable","configurable","ContainerIterator","__extends","__generator","__read","__spreadArray","__values","VectorIterator","Vector","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","o","m","i","r","ar","error","to","from","pack","arguments","l","slice","concat","s","_super","node","container","iteratorType","_this","copy","_node","RandomIterator","isArray","_vector","_length","self_1","forEach","el","pushBack","clear","begin","end","rBegin","rEnd","front","back","getElementByPos","pos","RangeError","eraseElementByPos","splice","eraseElementByValue","index","eraseElementByIterator","iter","element","popBack","setElementByPos","insert","num","_a","apply","fill","find","reverse","unique","sort","cmp","callback","bind","SequentialContainer","__extends","__generator","LinkListIterator","LinkList","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","_super","_node","_header","container","iteratorType","_this","pre","_pre","throwIteratorAccessError","_next","defineProperty","get","_value","set","newValue","enumerable","configurable","copy","ContainerIterator","_head","_tail","self","forEach","el","pushBack","_eraseNode","node","_length","_insertNode","clear","begin","end","rBegin","rEnd","front","back","getElementByPos","pos","RangeError","curNode","eraseElementByPos","eraseElementByValue","eraseElementByIterator","iter","element","popBack","pushFront","popFront","setElementByPos","insert","num","i","find","reverse","pHead","pTail","cnt","tmp","unique","tmpNode","sort","cmp","arr","merge","list","curNode_1","callback","index","_a","bind","SequentialContainer","__extends","__generator","__read","__spreadArray","DequeIterator","Deque","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","o","m","i","r","ar","error","to","from","pack","arguments","l","slice","concat","_super","node","container","iteratorType","_this","copy","_node","RandomIterator","_bucketSize","_first","_curFirst","_last","_curLast","_bucketNum","_map","_length","size","Math","max","ceil","needBucketNum","self","forEach","element","pushBack","_reAllocate","newMap","addBucketNum","_getElementIndex","pos","offset","offsetRemainder","curNodePointerIndex","curNodeBucketIndex","clear","begin","end","rBegin","rEnd","front","back","popBack","pushFront","popFront","getElementByPos","RangeError","_a","setElementByPos","insert","num","arr","cut","eraseElementByPos","self_1","el","eraseElementByValue","eraseElementByIterator","iter","find","reverse","tmp","unique","index","pre","cur","sort","cmp","shrinkToFit","callback","bind","SequentialContainer","__extends","TreeNode","TreeNodeEnableIndex","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","key","value","_color","_key","undefined","_value","_left","_right","_parent","_pre","preNode","pre","_next","nextNode","_rotateLeft","PP","V","R","_rotateRight","F","K","_super","_this","apply","arguments","_subTreeSize","parent","_recount","__extends","__read","__values","TreeContainer","init_Base","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","o","n","m","Symbol","iterator","i","r","ar","e","next","done","push","value","error","s","length","_super","cmp","enableIndex","x","y","_this","_root","undefined","_cmp","_TreeNodeClass","TreeNodeEnableIndex","_set","key","hint","curNode","_preSet","_parent","_header","_subTreeSize","nodeList","_insertNodeSelfBalance","_a","parentNode","grandParent","curNode_1","_recount","_length","_eraseNode","_preEraseNode","TreeNode","_lowerBound","resNode","cmpResult","_key","_right","_left","_upperBound","_reverseLowerBound","_reverseUpperBound","_eraseNodeSelfBalance","_color","brother","_rotateLeft","_rotateRight","_b","clear","swapNode","_value","_inOrderTraversal","callback","ifReturn","uncle","GP","minNode","compareToMin","maxNode","compareToMax","iterNode","_node","iterCmpRes","preNode","_pre","preCmpRes","_findElementNode","updateKeyByIterator","iter","node","throwIteratorAccessError","_next","preKey","nextKey","eraseElementByPos","pos","RangeError","index","self","eraseElementByKey","eraseElementByIterator","hasNoRight","isNormal","iteratorType","forEach","e_1","_c","element","e_1_1","return","getElementByPos","e_2","res","e_2_1","getHeight","traversal","Math","max","Container","__extends","TreeIterator","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","node","header","iteratorType","_this","_node","_header","pre","_left","throwIteratorAccessError","_pre","next","_next","_right","defineProperty","get","root","_parent","_subTreeSize","index","enumerable","configurable","ContainerIterator","__extends","__generator","__values","OrderedSetIterator","OrderedSet","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","o","s","m","i","_super","node","header","container","iteratorType","_this","defineProperty","get","_node","_header","throwIteratorAccessError","_key","enumerable","configurable","copy","TreeIterator","cmp","enableIndex","self","forEach","el","insert","_iterationFunc","curNode","_a","undefined","_left","_right","begin","end","rBegin","rEnd","front","back","key","hint","_set","find","element","resNode","_findElementNode","_root","lowerBound","_lowerBound","upperBound","_upperBound","reverseLowerBound","_reverseLowerBound","reverseUpperBound","_reverseUpperBound","union","other","_length","TreeContainer","__extends","__generator","__values","OrderedMapIterator","OrderedMap","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","o","s","m","i","_super","node","header","container","iteratorType","_this","defineProperty","get","_node","_header","throwIteratorAccessError","self","Proxy","props","_key","_value","set","newValue","enumerable","configurable","copy","TreeIterator","cmp","enableIndex","forEach","el","setElement","_iterationFunc","curNode","_a","undefined","_left","_right","begin","end","rBegin","rEnd","front","_length","minNode","back","maxNode","lowerBound","key","resNode","_lowerBound","_root","upperBound","_upperBound","reverseLowerBound","_reverseLowerBound","reverseUpperBound","_reverseUpperBound","hint","_set","find","_findElementNode","getElementByKey","union","other","TreeContainer","key","t","__extends","HashContainerIterator","HashContainer","init_Base","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","_super","node","header","iteratorType","_this","_node","_header","pre","_pre","throwIteratorAccessError","next","_next","ContainerIterator","_objMap","_originMap","HASH_TAG","Symbol","_head","_tail","_eraseNode","_length","_set","key","value","isObject","undefined","checkObject","newTail","index","_value","defineProperty","length","configurable","_key","push","_findElementNode","clear","forEach","el","eraseElementByKey","eraseElementByIterator","iter","eraseElementByPos","pos","RangeError","Container","__extends","__generator","HashSetIterator","HashSet","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","_super","node","header","container","iteratorType","_this","defineProperty","get","_node","_header","throwIteratorAccessError","_key","enumerable","configurable","copy","HashContainerIterator","self","forEach","el","insert","begin","_head","end","rBegin","_tail","rEnd","front","back","key","isObject","_set","undefined","getElementByPos","pos","_length","RangeError","_next","find","_findElementNode","callback","index","_a","bind","HashContainer","__extends","__generator","HashMapIterator","HashMap","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","TypeError","String","__","this","constructor","create","thisArg","body","_","label","sent","t","trys","ops","f","y","g","next","verb","throw","return","Symbol","iterator","n","v","step","op","done","value","pop","length","push","e","_super","node","header","container","iteratorType","_this","defineProperty","get","_node","_header","throwIteratorAccessError","self","Proxy","props","_key","_value","set","newValue","enumerable","configurable","copy","HashContainerIterator","forEach","el","setElement","begin","_head","end","rBegin","_tail","rEnd","front","_length","back","key","isObject","_set","getElementByKey","undefined","checkObject","index","HASH_TAG","_objMap","_originMap","getElementByPos","pos","RangeError","_next","find","_findElementNode","callback","_a","bind","HashContainer","exports","module","require_number_allocator","exports","module","exports","exports","exports","exports","exports","exports","generateUniqueNumber","cache","init_module","worker","clearInterval","clearTimeout","setInterval","setTimeout","worker","clearInterval","clearTimeout","setInterval","setTimeout","init_module","exports","exports","setImmediate","exports","require_constants","exports","module","exports","module","exports","module","exports","module","data","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","URL","WebSocket","key","require_stream","exports","module","err","exports","module","protocol","exports","module","WebSocket","exports","module","WebSocket","exports","exports","exports","exports","exports","exports","connect","client","exports","exports","exports","exports","module","exports","module","exports","module","err","exports","module","err","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","i","node","exports","module","require_state","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","exports","module","err","n","releasedBufObj","exports","module","require_package","exports","module","exports","module","exports","module","exports","module","Worker","FinalizationRegistry","WeakRef","worker","exports","module","onExit","worker","fixTarget","exports","module","stringify","_","require_constants","exports","module","exports","module","cache","exports","module","exports","module","bindings","exports","module","value","tmp","key","res","join","stringify","exports","module","streamLevels","exports","module","serializers","time","exports","logger","exports","exports","module","clone","parent","depth","exports","module","NodeCache","require_node_cache","exports","module","exports","cache","setCacheData","require_dist","exports","import_cache","cache"]}