use-stomp
Version:
react provider, class decorator, and a hook for websockets using the stomp protocol
393 lines (313 loc) • 38.7 kB
JavaScript
;
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"]}