/proc/self/root/var/runtime/node_modules/@aws-sdk/node_modules/aws-crt/dist/common
This explorer reads the filesystem of the server it runs on, so /workspace/user isn't present here. Browsing and the terminal still work against this server's own disk from /.
"use strict";/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */Object.defineProperty(exports, "__esModule", { value: true });exports.PublishAcknowledgementHandle = exports.queueAcknowledgeableEvent = exports.emitAcknowledgeableEvent = exports.PublishAcknowledgementHandleWrapper = exports.isValidTopic = exports.isValidTopicFilter = exports.DEFAULT_KEEP_ALIVE = exports.normalize_payload_to_buffer = exports.normalize_payload = void 0;/** * Converts payload to Buffer or string regardless of the supplied type * @param payload The payload to convert * @internal */function normalize_payload(payload) { if (payload instanceof Buffer) { // pass Buffer through return payload; } if (typeof payload === 'string') { // pass string through return payload; } if (ArrayBuffer.isView(payload)) { // return Buffer with view upon the same bytes (no copy) const view = payload; return Buffer.from(view.buffer, view.byteOffset, view.byteLength); } if (payload instanceof ArrayBuffer) { // return Buffer with view upon the same bytes (no copy) return Buffer.from(payload); } if (typeof payload === 'object') { // Convert Object to JSON string return JSON.stringify(payload); } if (!payload) { return ""; } throw new TypeError("payload parameter must be a string, object, or DataView.");}exports.normalize_payload = normalize_payload;/** * Converts payload to Buffer only, regardless of the supplied type * @param payload The payload to convert * @internal */function normalize_payload_to_buffer(payload) { let normalized = normalize_payload(payload); if (typeof normalized === 'string') { // pass string through return Buffer.from(normalized); } return normalized;}exports.normalize_payload_to_buffer = normalize_payload_to_buffer;/** @internal */exports.DEFAULT_KEEP_ALIVE = 1200;function isValidTopicInternal(topic, isFilter) { if (topic.length === 0 || topic.length > 65535) { return false; } let sawHash = false; for (let segment of topic.split('/')) { if (sawHash) { return false; } if (segment.length === 0) { continue; } if (segment.includes("+")) { if (!isFilter) { return false; } if (segment.length > 1) { return false; } } if (segment.includes("#")) { if (!isFilter) { return false; } if (segment.length > 1) { return false; } sawHash = true; } } return true;}function isValidTopicFilter(topicFilter) { if (typeof (topicFilter) !== 'string') { return false; } let topicFilterAsString = topicFilter; return isValidTopicInternal(topicFilterAsString, true);}exports.isValidTopicFilter = isValidTopicFilter;function isValidTopic(topic) { if (typeof (topic) !== 'string') { return false; } let topicAsString = topic; return isValidTopicInternal(topicAsString, false);}exports.isValidTopic = isValidTopic;/** * Wrapper class containing a one-use singleton handle that can be used to trigger sending the acknowledgement (Puback in * QoS 1, Pubrec in QoS 2) packet for an incoming publish. */class PublishAcknowledgementHandleWrapper { constructor(handle) { this.ackHandle = handle; } /** * Attempt to take the acknowledgement handle held by the wrapper. This will only succeed for the first caller; * after the initial call, null will be returned. By taking the handle, the caller assumes responsibility * for sending the acknowledgement packet associated with the incoming publish packet. Failing to trigger the * acknowledgement will cause the broker to potentially re-send the publish. */ acquireHandle() { let handle = this.ackHandle; this.ackHandle = null; return handle; }}exports.PublishAcknowledgementHandleWrapper = PublishAcknowledgementHandleWrapper;function movePublishAcknowledgementHandleWrapper(wrapper, compositionFunctor) { if (wrapper) { let handle = wrapper.acquireHandle(); if (compositionFunctor && handle) { let interiorHandle = handle; handle = new PublishAcknowledgementHandle(() => { interiorHandle.invokeAcknowledgement(); compositionFunctor(); }); } return new PublishAcknowledgementHandleWrapper(handle); } return undefined;}/** @internal */function emitAcknowledgeableEvent(emitter, ackEvent, ackEventPayload, wrapperFieldName, ackHandleWrapper, compositionFunctor) { ackHandleWrapper = movePublishAcknowledgementHandleWrapper(ackHandleWrapper, compositionFunctor); if (ackHandleWrapper) { ackEventPayload[wrapperFieldName] = ackHandleWrapper; emitter.emitWithCallback(ackEvent, () => { if (ackHandleWrapper) { let handle = ackHandleWrapper.acquireHandle(); if (handle) { // Even if corked, all listeners have had a chance to react to the event // and acquire the acknowledgement handle if they wanted to. If no one did so, then we do it ourselves. handle.invokeAcknowledgement(); } } }, ackEventPayload); } else { emitter.emit(ackEvent, ackEventPayload); }}exports.emitAcknowledgeableEvent = emitAcknowledgeableEvent;/** @internal */function queueAcknowledgeableEvent(emitter, ackEvent, ackEventPayload, wrapperFieldName, ackHandleWrapper, compositionFunctor) { let wrapper = movePublishAcknowledgementHandleWrapper(ackHandleWrapper, compositionFunctor); queueMicrotask(() => { if (wrapper) { ackEventPayload[wrapperFieldName] = wrapper; emitter.emitWithCallback(ackEvent, () => { if (wrapper) { let handle = wrapper.acquireHandle(); if (handle) { // Even if corked, all listeners have had a chance to react to the event // and acquire the acknowledgement handle if they wanted to. If no one did so, then we do it ourselves. handle.invokeAcknowledgement(); } } }, ackEventPayload); } else { emitter.emit(ackEvent, ackEventPayload); } });}exports.queueAcknowledgeableEvent = queueAcknowledgeableEvent;/** * Object that allows the holder to trigger the acknowledgement for an associated publish packet. */class PublishAcknowledgementHandle { constructor(acknowledgementFunction) { this.acknowledgementFunction = acknowledgementFunction; } /** * trigger the acknowledgement for an associated Publish packet */ invokeAcknowledgement() { let acknowledgementFunction = this.acknowledgementFunction; this.acknowledgementFunction = undefined; if (acknowledgementFunction) { acknowledgementFunction(); } }}exports.PublishAcknowledgementHandle = PublishAcknowledgementHandle;//# sourceMappingURL=mqtt_shared.js.map