From 16e20405a62a1207af19e3fbcf3ec3f6d7fda470 Mon Sep 17 00:00:00 2001 From: Mahdi Pourismaiel Date: Thu, 12 Sep 2019 17:56:57 +0430 Subject: [PATCH] Fix bad split in event params (pubsub) --- assets/js/head.js | 2 +- assets/scripts/syna-head.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/assets/js/head.js b/assets/js/head.js index 3da8b461..6e7e3079 100644 --- a/assets/js/head.js +++ b/assets/js/head.js @@ -94,7 +94,7 @@ class Stream { } _translateUrlQuery(url) { - const query = url.split('?')[1] || ''; + const query = url.slice(url.indexOf('?') + 1) || ''; return query .split('&') .reduce((tmp, pair) => { diff --git a/assets/scripts/syna-head.js b/assets/scripts/syna-head.js index ae4bb152..9a2d4dc9 100644 --- a/assets/scripts/syna-head.js +++ b/assets/scripts/syna-head.js @@ -94,7 +94,7 @@ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Stream = function () {\n function Stream() {\n _classCallCheck(this, Stream);\n\n this._topics = {};\n this.subUid = -1;\n this._activeUrlEvent = null;\n\n this._updateActiveEvent(window.location.href);\n window.onhashchange = function (_ref) {\n var newURL = _ref.newURL;\n\n this._publishHashChange(newURL);\n };\n\n this.subscribe = this.subscribe.bind(this);\n this.publish = this.publish.bind(this);\n this.unsubscribe = this.unsubscribe.bind(this);\n this._publishHashChange = this._publishHashChange.bind(this);\n this._translateUrlQuery = this._translateUrlQuery.bind(this);\n this._updateActiveEvent = this._updateActiveEvent.bind(this);\n }\n\n _createClass(Stream, [{\n key: 'subscribe',\n value: function subscribe(topic, func) {\n if (!this._topics[topic]) {\n this._topics[topic] = [];\n }\n var token = (++this.subUid).toString();\n this._topics[topic].push({ token: token, func: func });\n\n if (this._activeUrlEvent && this._activeUrlEvent.event === topic) {\n func.call(null, this._activeUrlEvent.args);\n }\n return token;\n }\n }, {\n key: 'publish',\n value: function publish(topic, argsText) {\n var _this = this;\n\n if (!this._topics[topic]) {\n return false;\n }\n setTimeout(function () {\n var subscribers = _this._topics[topic];\n var args = (typeof argsText === 'undefined' ? 'undefined' : _typeof(argsText)) === 'object' ? argsText : argsText.split(',').reduce(function (tmp, param) {\n var _param$split = param.split(':'),\n _param$split2 = _slicedToArray(_param$split, 2),\n key = _param$split2[0],\n value = _param$split2[1];\n\n tmp[key] = value;\n return tmp;\n }, {});\n\n var len = subscribers ? subscribers.length : 0;\n while (len--) {\n subscribers[len].func.call(null, args);\n }\n }, 0);\n return true;\n }\n }, {\n key: 'unsubscribe',\n value: function unsubscribe(token) {\n for (var topic in this._topics) {\n if (this._topics[topic]) {\n for (var i = 0, j = this._topics[topic].length; i < j; i++) {\n if (this._topics[topic][i].token === token) {\n this._topics[topic].splice(i, 1);\n return token;\n }\n }\n }\n }\n return false;\n }\n }, {\n key: '_publishHashChange',\n value: function _publishHashChange(url) {\n var _updateActiveEvent2 = this._updateActiveEvent(url),\n event = _updateActiveEvent2.event,\n args = _updateActiveEvent2.args;\n\n if (!event) {\n return false;\n }\n return this.publish(event, args);\n }\n }, {\n key: '_updateActiveEvent',\n value: function _updateActiveEvent(url) {\n var params = this._translateUrlQuery(url);\n var event = null;\n if (!params.e && window.syna.enabledUnsafeEvents && params.event) {\n event = params.event;\n } else if (params.e) {\n params = this._translateUrlQuery(atob(params.e));\n event = params.event;\n } else {\n return {};\n }\n\n delete params.event;\n this._activeUrlEvent = { event: event, args: params };\n return this._activeUrlEvent;\n }\n }, {\n key: '_translateUrlQuery',\n value: function _translateUrlQuery(url) {\n var query = url.split('?')[1] || '';\n return query.split('&').reduce(function (tmp, pair) {\n var _pair$split = pair.split('='),\n _pair$split2 = _slicedToArray(_pair$split, 2),\n key = _pair$split2[0],\n value = _pair$split2[1];\n\n tmp[decodeURIComponent(key)] = decodeURIComponent(value);\n return tmp;\n }, {});\n }\n }]);\n\n return Stream;\n}();\n\nvar SynaAPI = function () {\n function SynaAPI() {\n _classCallCheck(this, SynaAPI);\n\n this._registry = {};\n this.register = this.register.bind(this);\n this.update = this.update.bind(this);\n this.get = this.get.bind(this);\n this.getScope = this.getScope.bind(this);\n this.toArray = this.toArray.bind(this);\n }\n\n _createClass(SynaAPI, [{\n key: 'register',\n value: function register(scope, id, value) {\n if (!this._registry[scope]) {\n this._registry[scope] = {};\n }\n\n this._registry[scope][id] = value;\n }\n }, {\n key: 'update',\n value: function update(scope, id, value) {\n if (!this._registry[scope] || !this._registry[scope][id]) {\n return null;\n }\n\n this._registry[scope][id] = value;\n return value;\n }\n }, {\n key: 'get',\n value: function get(scope, id) {\n if (!this._registry[scope]) {\n return null;\n }\n\n return this._registry[scope][id];\n }\n }, {\n key: 'getScope',\n value: function getScope(scope) {\n return this._registry[scope];\n }\n }, {\n key: 'toArray',\n value: function toArray(scope) {\n if (!this._registry[scope]) {\n return null;\n }\n\n return Object.values(this._registry[scope]);\n }\n }, {\n key: 'renderTemplate',\n value: function renderTemplate(templateString, data) {\n var conditionalMatches = void 0,\n conditionalPattern = void 0,\n copy = void 0;\n conditionalPattern = /\\$\\{\\s*isset ([a-zA-Z]*) \\s*\\}(.*)\\$\\{\\s*end\\s*}/g;\n //since loop below depends on re.lastInxdex, we use a copy to capture any manipulations whilst inside the loop\n copy = templateString;\n while ((conditionalMatches = conditionalPattern.exec(templateString)) !== null) {\n if (data[conditionalMatches[1]]) {\n //valid key, remove conditionals, leave contents.\n copy = copy.replace(conditionalMatches[0], conditionalMatches[2]);\n } else {\n //not valid, remove entire section\n copy = copy.replace(conditionalMatches[0], '');\n }\n }\n templateString = copy;\n //now any conditionals removed we can do simple substitution\n var key = void 0,\n find = void 0,\n re = void 0;\n for (key in data) {\n find = '\\\\$\\\\{\\\\s*' + key + '\\\\s*\\\\}';\n re = new RegExp(find, 'g');\n templateString = templateString.replace(re, data[key]);\n }\n return templateString;\n }\n }]);\n\n return SynaAPI;\n}();\n\nwindow.syna = window.syna || {};\nwindow.syna.api = new SynaAPI();\nwindow.syna.stream = new Stream();\nwindow.synaPortals = {};\n\n//# sourceURL=webpack:///./assets/js/head.js?"); +eval("\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Stream = function () {\n function Stream() {\n _classCallCheck(this, Stream);\n\n this._topics = {};\n this.subUid = -1;\n this._activeUrlEvent = null;\n\n this._updateActiveEvent(window.location.href);\n window.onhashchange = function (_ref) {\n var newURL = _ref.newURL;\n\n this._publishHashChange(newURL);\n };\n\n this.subscribe = this.subscribe.bind(this);\n this.publish = this.publish.bind(this);\n this.unsubscribe = this.unsubscribe.bind(this);\n this._publishHashChange = this._publishHashChange.bind(this);\n this._translateUrlQuery = this._translateUrlQuery.bind(this);\n this._updateActiveEvent = this._updateActiveEvent.bind(this);\n }\n\n _createClass(Stream, [{\n key: 'subscribe',\n value: function subscribe(topic, func) {\n if (!this._topics[topic]) {\n this._topics[topic] = [];\n }\n var token = (++this.subUid).toString();\n this._topics[topic].push({ token: token, func: func });\n\n if (this._activeUrlEvent && this._activeUrlEvent.event === topic) {\n func.call(null, this._activeUrlEvent.args);\n }\n return token;\n }\n }, {\n key: 'publish',\n value: function publish(topic, argsText) {\n var _this = this;\n\n if (!this._topics[topic]) {\n return false;\n }\n setTimeout(function () {\n var subscribers = _this._topics[topic];\n var args = (typeof argsText === 'undefined' ? 'undefined' : _typeof(argsText)) === 'object' ? argsText : argsText.split(',').reduce(function (tmp, param) {\n var _param$split = param.split(':'),\n _param$split2 = _slicedToArray(_param$split, 2),\n key = _param$split2[0],\n value = _param$split2[1];\n\n tmp[key] = value;\n return tmp;\n }, {});\n\n var len = subscribers ? subscribers.length : 0;\n while (len--) {\n subscribers[len].func.call(null, args);\n }\n }, 0);\n return true;\n }\n }, {\n key: 'unsubscribe',\n value: function unsubscribe(token) {\n for (var topic in this._topics) {\n if (this._topics[topic]) {\n for (var i = 0, j = this._topics[topic].length; i < j; i++) {\n if (this._topics[topic][i].token === token) {\n this._topics[topic].splice(i, 1);\n return token;\n }\n }\n }\n }\n return false;\n }\n }, {\n key: '_publishHashChange',\n value: function _publishHashChange(url) {\n var _updateActiveEvent2 = this._updateActiveEvent(url),\n event = _updateActiveEvent2.event,\n args = _updateActiveEvent2.args;\n\n if (!event) {\n return false;\n }\n return this.publish(event, args);\n }\n }, {\n key: '_updateActiveEvent',\n value: function _updateActiveEvent(url) {\n var params = this._translateUrlQuery(url);\n var event = null;\n if (!params.e && window.syna.enabledUnsafeEvents && params.event) {\n event = params.event;\n } else if (params.e) {\n params = this._translateUrlQuery(atob(params.e));\n event = params.event;\n } else {\n return {};\n }\n\n delete params.event;\n this._activeUrlEvent = { event: event, args: params };\n return this._activeUrlEvent;\n }\n }, {\n key: '_translateUrlQuery',\n value: function _translateUrlQuery(url) {\n var query = url.slice(url.indexOf('?') + 1) || '';\n return query.split('&').reduce(function (tmp, pair) {\n var _pair$split = pair.split('='),\n _pair$split2 = _slicedToArray(_pair$split, 2),\n key = _pair$split2[0],\n value = _pair$split2[1];\n\n tmp[decodeURIComponent(key)] = decodeURIComponent(value);\n return tmp;\n }, {});\n }\n }]);\n\n return Stream;\n}();\n\nvar SynaAPI = function () {\n function SynaAPI() {\n _classCallCheck(this, SynaAPI);\n\n this._registry = {};\n this.register = this.register.bind(this);\n this.update = this.update.bind(this);\n this.get = this.get.bind(this);\n this.getScope = this.getScope.bind(this);\n this.toArray = this.toArray.bind(this);\n }\n\n _createClass(SynaAPI, [{\n key: 'register',\n value: function register(scope, id, value) {\n if (!this._registry[scope]) {\n this._registry[scope] = {};\n }\n\n this._registry[scope][id] = value;\n }\n }, {\n key: 'update',\n value: function update(scope, id, value) {\n if (!this._registry[scope] || !this._registry[scope][id]) {\n return null;\n }\n\n this._registry[scope][id] = value;\n return value;\n }\n }, {\n key: 'get',\n value: function get(scope, id) {\n if (!this._registry[scope]) {\n return null;\n }\n\n return this._registry[scope][id];\n }\n }, {\n key: 'getScope',\n value: function getScope(scope) {\n return this._registry[scope];\n }\n }, {\n key: 'toArray',\n value: function toArray(scope) {\n if (!this._registry[scope]) {\n return null;\n }\n\n return Object.values(this._registry[scope]);\n }\n }, {\n key: 'renderTemplate',\n value: function renderTemplate(templateString, data) {\n var conditionalMatches = void 0,\n conditionalPattern = void 0,\n copy = void 0;\n conditionalPattern = /\\$\\{\\s*isset ([a-zA-Z]*) \\s*\\}(.*)\\$\\{\\s*end\\s*}/g;\n //since loop below depends on re.lastInxdex, we use a copy to capture any manipulations whilst inside the loop\n copy = templateString;\n while ((conditionalMatches = conditionalPattern.exec(templateString)) !== null) {\n if (data[conditionalMatches[1]]) {\n //valid key, remove conditionals, leave contents.\n copy = copy.replace(conditionalMatches[0], conditionalMatches[2]);\n } else {\n //not valid, remove entire section\n copy = copy.replace(conditionalMatches[0], '');\n }\n }\n templateString = copy;\n //now any conditionals removed we can do simple substitution\n var key = void 0,\n find = void 0,\n re = void 0;\n for (key in data) {\n find = '\\\\$\\\\{\\\\s*' + key + '\\\\s*\\\\}';\n re = new RegExp(find, 'g');\n templateString = templateString.replace(re, data[key]);\n }\n return templateString;\n }\n }]);\n\n return SynaAPI;\n}();\n\nwindow.syna = window.syna || {};\nwindow.syna.api = new SynaAPI();\nwindow.syna.stream = new Stream();\nwindow.synaPortals = {};\n\n//# sourceURL=webpack:///./assets/js/head.js?"); /***/ })