UNPKG

use-stomp

Version:

react provider, class decorator, and a hook for websockets using the stomp protocol

393 lines (313 loc) 38.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); require("core-js/modules/es.array.concat"); require("core-js/modules/es.array.filter"); require("core-js/modules/es.array.for-each"); require("core-js/modules/es.array.includes"); require("core-js/modules/es.array.map"); require("core-js/modules/es.object.get-own-property-descriptor"); require("core-js/modules/es.string.includes"); require("core-js/modules/web.dom-collections.for-each"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper")); var _uuid = require("uuid"); var _webSocketConfigs = require("./webSocketConfigs"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } var WebSocketWorker = /*#__PURE__*/function (_SharedWorker) { (0, _inherits2.default)(WebSocketWorker, _SharedWorker); var _super = _createSuper(WebSocketWorker); function WebSocketWorker(_props) { var _this$_workerEvents; var _this; (0, _classCallCheck2.default)(this, WebSocketWorker); _this = _super.call(this, 'webSocketWorkerInstance.js'); _this._channels = {}; _this._connected = false; _this._id = (0, _uuid.v4)(); _this._onConnected = function () {}; _this._onDisconnected = function () {}; _this._onSyncState = function (state) {}; _this._syncChannels = {}; _this._syncMessages = {}; _this.connect = function () { _this.port.postMessage({ type: _webSocketConfigs.Events.CONNECT }); }; _this.destroy = function () { _this._unregister(); _this.port.removeEventListener('message', _this._onMessage); document.removeEventListener('visibilitychange', _this._setVisibility); window.removeEventListener('beforeunload', _this._unregister); }; _this.disconnect = function () { _this.port.postMessage({ type: _webSocketConfigs.Events.DISCONNECT }); }; _this.testDisconnect = function () { _this.port.postMessage({ type: _webSocketConfigs.Events.TEST_DISCONNECT }); }; _this.dismiss = function (channel, id) { _this.port.postMessage({ type: _webSocketConfigs.Events.DISMISS_SYNC, payload: { channel: channel, id: id } }); }; _this.send = function (channel, message) { _this.port.postMessage({ type: _webSocketConfigs.Events.SEND_MESSAGE, payload: { channel: channel, message: message } }); }; _this.setAuthHeader = function (authHeader) { _this.port.postMessage({ type: _webSocketConfigs.Events.SET_AUTH_HEADER, payload: authHeader }); }; _this.setHeader = function (header) { _this.port.postMessage({ type: _webSocketConfigs.Events.SET_HEADER, payload: header }); }; _this.setUrl = function (url) { _this.port.postMessage({ type: _webSocketConfigs.Events.SET_URL, payload: url }); }; _this.subscribe = function (channel, callback) { if (!(_this._channels[channel] || []).length) { _this._channels[channel] = [callback]; _this.port.postMessage({ type: _webSocketConfigs.Events.SUBSCRIBE, payload: { id: _this._id, channel: channel } }); } else { _this._channels[channel] = [].concat((0, _toConsumableArray2.default)(_this._channels[channel]), [callback]); } return function () { _this._channels[channel] = (_this._channels[channel] || []).filter(function (fn) { return fn !== callback; }); if (!_this._channels[channel].length) { _this.unsubscribe(channel); } }; }; _this.subscribeSync = function (channel, callback) { var fn = function fn(messages) { var oldMessages = _this._syncMessages[channel] || []; var oldIds = oldMessages.map(function (name, callable) { callable.displayName = name; Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, { value: name })); return callable; }("oldIds", function (msg) { return msg.id; })); _this._syncMessages[channel] = messages; var newIds = (_this._syncMessages[channel] || []).map(function (name, callable) { callable.displayName = name; Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, { value: name })); return callable; }("newIds", function (msg) { return msg.id; })); var add = messages.filter(function (name, callable) { callable.displayName = name; Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, { value: name })); return callable; }("add", function (_ref) { var id = _ref.id; return !oldIds.includes(id) && newIds.includes(id); })); var remove = oldMessages.filter(function (name, callable) { callable.displayName = name; Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, { value: name })); return callable; }("remove", function (_ref2) { var id = _ref2.id; return !newIds.includes(id) && oldIds.includes(id); })); callback(messages, add, remove); }; if (!(_this._syncChannels[channel] || []).length) { _this._syncChannels[channel] = [fn]; _this.port.postMessage({ type: _webSocketConfigs.Events.SUBSCRIBE_SYNC, payload: { id: _this._id, channel: channel } }); } else { _this._syncChannels[channel] = [].concat((0, _toConsumableArray2.default)(_this._syncChannels[channel]), [fn]); } return function () { _this._syncChannels[channel] = (_this._syncChannels[channel] || []).filter(function (callback) { return callback !== fn; }); if (!_this._syncChannels[channel].length) { _this.unsubscribeSync(channel); } }; }; _this.unsubscribe = function (channel) { _this.port.postMessage({ type: _webSocketConfigs.Events.UNSUBSCRIBE, payload: { id: _this._id, channel: channel } }); }; _this.unsubscribeSync = function (channel) { _this.port.postMessage({ type: _webSocketConfigs.Events.UNSUBSCRIBE_SYNC, payload: { id: _this._id, channel: channel } }); }; _this._onMessage = function (event) { if (_this._workerEvents[event.data.type]) { _this._workerEvents[event.data.type](event); } }; _this._register = function (props) { _this.port.postMessage({ type: _webSocketConfigs.Events.REGISTER, payload: { id: _this._id, reconnectInterval: props.reconnectInterval, reconnectMaxAttempts: props.reconnectMaxAttempts, visibility: document.visibilityState === 'visible' } }); }; _this._setError = function (event) { console.error('[use-stomp]', event.data.payload); }; _this._setVisibility = function () { _this.port.postMessage({ type: _webSocketConfigs.Events.SET_VISIBILITY, payload: { id: _this._id, visibility: document.visibilityState === 'visible' } }); }; _this._setMessage = function (event) { if (_this._channels[event.data.payload.channel]) { _this._channels[event.data.payload.channel].forEach(function (fn) { return fn(event.data.payload.message); }); } if (_this._syncChannels[event.data.payload.channel]) { _this._syncChannels[event.data.payload.channel].forEach(function (fn) { fn((event.data.payload.message || []).map(function (_ref3) { var message = _ref3.message, item = (0, _objectWithoutProperties2.default)(_ref3, ["message"]); return _objectSpread(_objectSpread({}, item), {}, { content: message, dismiss: function dismiss() { return _this.dismiss(event.data.payload.channel, item.id); } }); })); }); } }; _this._setConnection = function (event) { var wasConnected = !!_this._connected; switch (event.data.payload) { case _webSocketConfigs.States.CONNECTED: _this._connected = true; break; case _webSocketConfigs.States.CONNECTING: _this._connected = false; break; case _webSocketConfigs.States.DISCONNECTED: _this._connected = false; break; case _webSocketConfigs.States.DISCONNECTING: _this._connected = false; break; } if (!wasConnected && _this._connected) { _this._onConnected(); } if (wasConnected && !_this._connected) { _this._onDisconnected(); } }; _this._unregister = function () { _this.port.postMessage({ type: _webSocketConfigs.Events.UNREGISTER, payload: { id: _this._id } }); }; _this._workerEvents = (_this$_workerEvents = {}, (0, _defineProperty2.default)(_this$_workerEvents, _webSocketConfigs.Events.CONNECTION, _this._setConnection), (0, _defineProperty2.default)(_this$_workerEvents, _webSocketConfigs.Events.ERROR, _this._setError), (0, _defineProperty2.default)(_this$_workerEvents, _webSocketConfigs.Events.MESSAGE, _this._setMessage), _this$_workerEvents); if (_props !== null && _props !== void 0 && _props.onConnected) { _this._onConnected = _props.onConnected; } if (_props !== null && _props !== void 0 && _props.onDisconnected) { _this._onDisconnected = _props.onDisconnected; } if (_props !== null && _props !== void 0 && _props.onSyncState) { _this._onSyncState = _props.onSyncState; } _this.port.start(); _this.port.addEventListener('message', _this._onMessage); _this._register({ reconnectMaxAttempts: _props.reconnectMaxAttempts || 10, reconnectInterval: _props.reconnectInterval || 10000 }); if (_props.url) { _this.setUrl(_props.url); } document.addEventListener('visibilitychange', _this._setVisibility); window.addEventListener('beforeunload', _this._unregister); return _this; } return WebSocketWorker; }( /*#__PURE__*/(0, _wrapNativeSuper2.default)(SharedWorker)); exports.default = WebSocketWorker; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/webSocketWorker.ts"],"names":["WebSocketWorker","props","_channels","_connected","_id","_onConnected","_onDisconnected","_onSyncState","state","_syncChannels","_syncMessages","connect","port","postMessage","type","Events","CONNECT","destroy","_unregister","removeEventListener","_onMessage","document","_setVisibility","window","disconnect","DISCONNECT","testDisconnect","TEST_DISCONNECT","dismiss","channel","id","DISMISS_SYNC","payload","send","message","SEND_MESSAGE","setAuthHeader","authHeader","SET_AUTH_HEADER","setHeader","header","SET_HEADER","setUrl","url","SET_URL","subscribe","callback","length","SUBSCRIBE","filter","fn","unsubscribe","subscribeSync","messages","oldMessages","oldIds","map","msg","newIds","add","includes","remove","SUBSCRIBE_SYNC","unsubscribeSync","UNSUBSCRIBE","UNSUBSCRIBE_SYNC","event","_workerEvents","data","_register","REGISTER","reconnectInterval","reconnectMaxAttempts","visibility","visibilityState","_setError","console","error","SET_VISIBILITY","_setMessage","forEach","item","content","_setConnection","wasConnected","States","CONNECTED","CONNECTING","DISCONNECTED","DISCONNECTING","UNREGISTER","CONNECTION","ERROR","MESSAGE","onConnected","onDisconnected","onSyncState","start","addEventListener","SharedWorker"],"mappings":"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","sourcesContent":["import {v4} from 'uuid';\n\nimport {StompNotification} from './useStompNotifications';\nimport {Events, States} from './webSocketConfigs';\n\nexport type WebSocketWorkerProps = {\n    onConnected?(): void;\n    onDisconnected?(): void;\n    onSyncState?(state: any): void;\n    reconnectMaxAttempts?: number;\n    reconnectInterval?: number;\n    url?: string;\n};\n\nexport default class WebSocketWorker extends SharedWorker {\n    _channels = {};\n\n    _connected = false;\n\n    _id = v4();\n\n    _onConnected = () => {};\n\n    _onDisconnected = () => {};\n\n    _onSyncState = (state: any) => {};\n\n    _syncChannels = {};\n\n    _syncMessages = {};\n\n    constructor(props?: WebSocketWorkerProps) {\n        super('webSocketWorkerInstance.js');\n\n        if (props?.onConnected) {\n            this._onConnected = props.onConnected;\n        }\n\n        if (props?.onDisconnected) {\n            this._onDisconnected = props.onDisconnected;\n        }\n\n        if (props?.onSyncState) {\n            this._onSyncState = props.onSyncState;\n        }\n\n        this.port.start();\n\n        this.port.addEventListener('message', this._onMessage);\n\n        this._register({\n            reconnectMaxAttempts: props.reconnectMaxAttempts || 10,\n            reconnectInterval: props.reconnectInterval || 10000\n        });\n\n        if (props.url) {\n            this.setUrl(props.url);\n        }\n\n        document.addEventListener('visibilitychange', this._setVisibility);\n        window.addEventListener('beforeunload', this._unregister);\n    }\n\n    connect = () => {\n        this.port.postMessage({\n            type: Events.CONNECT\n        });\n    };\n\n    destroy = () => {\n        this._unregister();\n\n        this.port.removeEventListener('message', this._onMessage);\n        document.removeEventListener('visibilitychange', this._setVisibility);\n        window.removeEventListener('beforeunload', this._unregister);\n    };\n\n    disconnect = () => {\n        this.port.postMessage({\n            type: Events.DISCONNECT\n        });\n    };\n\n    testDisconnect = () => {\n        this.port.postMessage({\n            type: Events.TEST_DISCONNECT\n        });\n    };\n\n    dismiss = (channel, id) => {\n        this.port.postMessage({\n            type: Events.DISMISS_SYNC,\n            payload: {\n                channel,\n                id\n            }\n        });\n    };\n\n    send = (channel: string, message: any) => {\n        this.port.postMessage({\n            type: Events.SEND_MESSAGE,\n            payload: {\n                channel,\n                message\n            }\n        });\n    };\n\n    setAuthHeader = (authHeader) => {\n        this.port.postMessage({\n            type: Events.SET_AUTH_HEADER,\n            payload: authHeader\n        });\n    };\n\n    setHeader = (header) => {\n        this.port.postMessage({\n            type: Events.SET_HEADER,\n            payload: header\n        });\n    };\n\n    setUrl = (url) => {\n        this.port.postMessage({\n            type: Events.SET_URL,\n            payload: url\n        });\n    };\n\n    subscribe = (\n        channel: string,\n        callback: (message: any) => void\n    ): (() => void) => {\n        if (!(this._channels[channel] || []).length) {\n            this._channels[channel] = [callback];\n\n            this.port.postMessage({\n                type: Events.SUBSCRIBE,\n                payload: {\n                    id: this._id,\n                    channel\n                }\n            });\n        } else {\n            this._channels[channel] = [...this._channels[channel], callback];\n        }\n\n        return () => {\n            this._channels[channel] = (this._channels[channel] || []).filter(\n                (fn) => fn !== callback\n            );\n\n            if (!this._channels[channel].length) {\n                this.unsubscribe(channel);\n            }\n        };\n    };\n\n    subscribeSync = (\n        channel: string,\n        callback: (\n            messages: StompNotification<any>[],\n            add: StompNotification<any>[],\n            remove: StompNotification<any>[]\n        ) => void\n    ): (() => void) => {\n        const fn = (messages) => {\n            const oldMessages = this._syncMessages[channel] || [];\n\n            const oldIds = oldMessages.map((msg) => msg.id);\n\n            this._syncMessages[channel] = messages;\n\n            const newIds = (this._syncMessages[channel] || []).map(\n                (msg) => msg.id\n            );\n\n            const add = messages.filter(\n                ({id}) => !oldIds.includes(id) && newIds.includes(id)\n            );\n\n            const remove = oldMessages.filter(\n                ({id}) => !newIds.includes(id) && oldIds.includes(id)\n            );\n\n            callback(messages, add, remove);\n        };\n\n        if (!(this._syncChannels[channel] || []).length) {\n            this._syncChannels[channel] = [fn];\n\n            this.port.postMessage({\n                type: Events.SUBSCRIBE_SYNC,\n                payload: {\n                    id: this._id,\n                    channel\n                }\n            });\n        } else {\n            this._syncChannels[channel] = [...this._syncChannels[channel], fn];\n        }\n\n        return () => {\n            this._syncChannels[channel] = (\n                this._syncChannels[channel] || []\n            ).filter((callback) => callback !== fn);\n\n            if (!this._syncChannels[channel].length) {\n                this.unsubscribeSync(channel);\n            }\n        };\n    };\n\n    unsubscribe = (channel) => {\n        this.port.postMessage({\n            type: Events.UNSUBSCRIBE,\n            payload: {\n                id: this._id,\n                channel\n            }\n        });\n    };\n\n    unsubscribeSync = (channel) => {\n        this.port.postMessage({\n            type: Events.UNSUBSCRIBE_SYNC,\n            payload: {\n                id: this._id,\n                channel\n            }\n        });\n    };\n\n    _onMessage = (event) => {\n        if (this._workerEvents[event.data.type]) {\n            this._workerEvents[event.data.type](event);\n        }\n    };\n\n    _register = (\n        props: Pick<\n            WebSocketWorkerProps,\n            'reconnectMaxAttempts' | 'reconnectInterval'\n        >\n    ) => {\n        this.port.postMessage({\n            type: Events.REGISTER,\n            payload: {\n                id: this._id,\n                reconnectInterval: props.reconnectInterval,\n                reconnectMaxAttempts: props.reconnectMaxAttempts,\n                visibility: document.visibilityState === 'visible'\n            }\n        });\n    };\n\n    _setError = (event) => {\n        console.error('[use-stomp]', event.data.payload);\n    };\n\n    _setVisibility = () => {\n        this.port.postMessage({\n            type: Events.SET_VISIBILITY,\n            payload: {\n                id: this._id,\n                visibility: document.visibilityState === 'visible'\n            }\n        });\n    };\n\n    _setMessage = (event) => {\n        if (this._channels[event.data.payload.channel]) {\n            this._channels[event.data.payload.channel].forEach((fn) =>\n                fn(event.data.payload.message)\n            );\n        }\n\n        if (this._syncChannels[event.data.payload.channel]) {\n            this._syncChannels[event.data.payload.channel].forEach((fn) => {\n                fn(\n                    (event.data.payload.message || []).map(\n                        ({message, ...item}) => ({\n                            ...item,\n                            content: message,\n                            dismiss: () =>\n                                this.dismiss(\n                                    event.data.payload.channel,\n                                    item.id\n                                )\n                        })\n                    )\n                );\n            });\n        }\n    };\n\n    _setConnection = (event) => {\n        const wasConnected = !!this._connected;\n\n        switch (event.data.payload) {\n            case States.CONNECTED:\n                this._connected = true;\n                break;\n            case States.CONNECTING:\n                this._connected = false;\n                break;\n            case States.DISCONNECTED:\n                this._connected = false;\n                break;\n            case States.DISCONNECTING:\n                this._connected = false;\n                break;\n        }\n\n        if (!wasConnected && this._connected) {\n            this._onConnected();\n        }\n\n        if (wasConnected && !this._connected) {\n            this._onDisconnected();\n        }\n    };\n\n    _unregister = () => {\n        this.port.postMessage({\n            type: Events.UNREGISTER,\n            payload: {\n                id: this._id\n            }\n        });\n    };\n\n    _workerEvents = {\n        [Events.CONNECTION]: this._setConnection,\n        [Events.ERROR]: this._setError,\n        [Events.MESSAGE]: this._setMessage\n    };\n}\n"]}