2016-12-14 23:02:53 +00:00
|
|
|
/*****************************************************************************
|
2023-03-06 17:58:18 +00:00
|
|
|
* Open MCT, Copyright (c) 2014-2023, United States Government
|
2016-12-14 23:02:53 +00:00
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
|
|
|
* Open MCT is licensed under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
* Open MCT includes source code licensed under additional open source
|
|
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
|
|
* this source code distribution or the Licensing information page available
|
|
|
|
* at runtime from the About dialog for additional information.
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
(function () {
|
2023-06-23 20:52:03 +00:00
|
|
|
var FIFTEEN_MINUTES = 15 * 60 * 1000;
|
|
|
|
|
|
|
|
var handlers = {
|
|
|
|
subscribe: onSubscribe,
|
|
|
|
unsubscribe: onUnsubscribe,
|
|
|
|
request: onRequest
|
|
|
|
};
|
|
|
|
|
|
|
|
var subscriptions = {};
|
|
|
|
|
|
|
|
function workSubscriptions(timestamp) {
|
|
|
|
var now = Date.now();
|
|
|
|
var nextWork = Math.min.apply(
|
|
|
|
Math,
|
|
|
|
Object.values(subscriptions).map(function (subscription) {
|
|
|
|
return subscription(now);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
var wait = nextWork - now;
|
|
|
|
if (wait < 0) {
|
|
|
|
wait = 0;
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
if (Number.isFinite(wait)) {
|
|
|
|
setTimeout(workSubscriptions, wait);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function onSubscribe(message) {
|
|
|
|
var data = message.data;
|
|
|
|
|
|
|
|
// Keep
|
|
|
|
var start = Date.now();
|
|
|
|
var step = 1000 / data.dataRateInHz;
|
|
|
|
var nextStep = start - (start % step) + step;
|
|
|
|
let work;
|
|
|
|
if (data.spectra) {
|
|
|
|
work = function (now) {
|
|
|
|
while (nextStep < now) {
|
|
|
|
const messageCopy = Object.create(message);
|
|
|
|
message.data.start = nextStep - 60 * 1000;
|
|
|
|
message.data.end = nextStep;
|
|
|
|
onRequest(messageCopy);
|
|
|
|
nextStep += step;
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return nextStep;
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
work = function (now) {
|
|
|
|
while (nextStep < now) {
|
|
|
|
self.postMessage({
|
|
|
|
id: message.id,
|
|
|
|
data: {
|
|
|
|
name: data.name,
|
|
|
|
utc: nextStep,
|
|
|
|
yesterday: nextStep - 60 * 60 * 24 * 1000,
|
|
|
|
sin: sin(
|
|
|
|
nextStep,
|
|
|
|
data.period,
|
|
|
|
data.amplitude,
|
|
|
|
data.offset,
|
|
|
|
data.phase,
|
|
|
|
data.randomness,
|
|
|
|
data.infinityValues
|
|
|
|
),
|
|
|
|
wavelengths: wavelengths(),
|
|
|
|
intensities: intensities(),
|
|
|
|
cos: cos(
|
|
|
|
nextStep,
|
|
|
|
data.period,
|
|
|
|
data.amplitude,
|
|
|
|
data.offset,
|
|
|
|
data.phase,
|
|
|
|
data.randomness,
|
|
|
|
data.infinityValues
|
|
|
|
)
|
|
|
|
}
|
|
|
|
});
|
|
|
|
nextStep += step;
|
|
|
|
}
|
2016-12-14 23:02:53 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return nextStep;
|
|
|
|
};
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
subscriptions[message.id] = work;
|
|
|
|
workSubscriptions();
|
|
|
|
}
|
2016-12-14 23:02:53 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
function onUnsubscribe(message) {
|
|
|
|
delete subscriptions[message.data.id];
|
|
|
|
}
|
2020-07-31 19:11:03 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
function onRequest(message) {
|
|
|
|
var request = message.data;
|
|
|
|
if (request.end === undefined) {
|
|
|
|
request.end = Date.now();
|
2.0.5 Backmerge (#5505)
* Bump d3-selection from 1.3.2 to 3.0.0
Bumps [d3-selection](https://github.com/d3/d3-selection) from 1.3.2 to 3.0.0.
- [Release notes](https://github.com/d3/d3-selection/releases)
- [Commits](https://github.com/d3/d3-selection/compare/v1.3.2...v3.0.0)
---
updated-dependencies:
- dependency-name: d3-selection
dependency-type: direct:development
update-type: version-update:semver-major
...
Signed-off-by: dependabot[bot] <support@github.com>
* Remove snapshot
* Fix imagery filter slider drag in flexible layouts (#5326) (#5350)
* Dont' mutate a stacked plot unless its user initiated (#5357)
* Port grid icons and imagery test to release 2.0.5 from master (#5360)
* Port grid icons to release 2.0.5 from master
* Port imagery test to release/2.0.5
* Restrict timestrip composition to time based plots, plans and imagery (#5161)
* Restrict timestrip composition to time based plots, plans and imagery
* Adds unit tests for timeline composition policy
* Addresses review comments
Improves tests
* Reuse test objects
Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov>
* Include objectStyles reference to conditionSetIdentifier in imports (#5354)
* Include objectStyles reference to conditionSetIdentifier in imports
* Add tests for export
* Refactored some code and removed console log
* Remove workarounds for chrome 'scrollTop' issue (#5375)
* Fix naming of method (#5368)
* Imagery View does not discard old images when they fall out of bounds (#5351)
* change to using telemetry collection
* fix tests
* added more unit tests
* Cherrypicked commits (#5390)
Co-authored-by: unlikelyzero <jchill2@gmail.com>
* [Timer] Update 3dot menu actions appropriately (#5387)
* Call `removeAllListeners()` after emit
* Manually show/hide actions if within a view
* remove sneaky `console.log()`
* Add Timer e2e test
* Add to comments
* Avoid hard waits in Timer e2e test
- Assert against timer view state instead of menu options
* Let's also test actions from the Timer view
* 5391 Add preview and drag support to Grand Search (#5394)
* add preview and drag actions
* added unit test, simplified remove action
* do not hide search results in preview mode when clicking outside search results
* add semantic aria labels to enable e2e tests
* readd preview
* add e2e test
* remove commented out url
* add percy snapshot and add search to ci
* make percy stuff work
* linting
* fix percy again
* move percy snapshots to a visual test
* added separate visual test and changed test to fixtures
* fix fixtures path
* addressing review comments
* 5361 tags not persisting locally (#5408)
* fixed typo
* remove unneeded lookup
* fix tags adding and deleting
* more reliable way to remove tags
* break tests up for parallel execution
* fixed notebook tagging test
* enable e2e tests
* made schedule index comment more clear and fix uppercase/lowercase issue
* address e2e changes
* add unit test to bump coverage
* fix typo
* need to check on annotation creation if provider exists or not
* added fixtures
* undo silly couchdb commit
* Plot progress bar fix for 2.0.5 (#5386)
* Add .bind(this) to stopLoading() in loadMoreData()
* Replace load spinner with progress bar for plots
* Add loading delay prop to swg
* fix linting errors
* match load order
* Update accessibility
* Add Math.max to timeout to handle negative inputs
* Moved math.max to load delay variable
* Add loading fix for stacked plots
* Move loadingUpdate func into plot item for update
* Merge conflict resolve
* Check if delay is 0 and send, put post in a func
* Put obj directly to model, removed computed prop
* Lint fix
* Fix template where legend was not displayed
* Remove commented out template
* Fixed failing test
Co-authored-by: unlikelyzero <jchill2@gmail.com>
* Make plans non editable. (#5377)
* Make plans non editable.
* Add unit test for fix
* [CouchDB] Better determination of indicator status (#5415)
* Add unknown state, remove maintenance state
* Handle all CouchDB status codes
- Set unknown status if we receive an unhandled code
* Include status code in error messages
* SharedWorker can send unknown status
* Add test for unknown status
* Gauge fixes for Firefox and units display (#5369)
* Closes #5323, #5325. Parent branch is release/2.0.5.
- Significant work refactoring SVG markup and CSS for dial gauge;
- Fixed missing `v-if` to control display of units for #5325;
- Fixed bad `.length` test for limit properties;
* Closes #5323, #5325
- Add 'value out of range' indicator
* Closes #5323, #5325
- More accurate element naming;
- Fix cross-browser problems with current value display in dial gauge;
- Refinements to "out of range" indicator approach;
- Fixed size of "Amplitude" input in Sine Wave Generator;
* Closes #5323, #5325
- Styles and stubbed in code to support needle meter type;
* Closes #5323, #5325
- Stubbed in markup and CSS for needle-style meter;
* Closes #5323, #5325
- Fixed missing `js-*` classes that were failing npm run test;
* Closes #5323, #5325
- Fix to not display meter value bar unless a data value is expected;
* Addressing PR comments
- Renamed method for clarity;
- Added null value check in method `valueExpected`;
* [Static Root] Return leafValue if null/undefined/false (#5416)
* Return leafValue if null/undefined/false
* Added a null to the test json
* Show a better default poll question (#5425)
* 5361 Tags not persisting when several notebook entries are created at once (#5428)
* add end to end test to catch multiple entry errors
* click expansion triangle instead
* fix race condition between annotation creation and mutation
* make sure notebook tags run in e2e
* address PR comments
* Handle missing objects gracefully (#5399)
* Handle missing object errors for display layouts
* Handle missing object errors for Overlay Plots
* Add check for this.config
* Add try/catch statement & check if obj is missing
* Changed console.error to console.warn
* Lint fix
* Fix for this.metadata.value is undefined
* Add e2e test
* Update comment text
* Add reload check and @private, verify console.warn
* Redid assignment and metadata check
* Fix typo
* Changed assignment and metadata check
* Redid checks for isMissing(object)
* Lint fix
* Backmerge e2e code coverage changes and fixes into release/2.0.5 (#5431)
* [Telemetry Collections] Respect "Latest" Strategy Option (#5421)
* Respect latest strategy in Telemetry Collections to limit potential memory growth.
* fix sourcemaps (#5373)
Co-authored-by: John Hill <john.c.hill@nasa.gov>
* Debounce status summary (#5448)
Co-authored-by: John Hill <john.c.hill@nasa.gov>
* No gauge (#5451)
* Installed gauge plugin by default
* Make gauge part of standard install in e2e suite and add restrictednotebook
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* [CouchDB] Always subscribe to the CouchDB changes feed (#5434)
* Add unknown state, remove maintenance state
* Handle all CouchDB status codes
- Set unknown status if we receive an unhandled code
* Include status code in error messages
* SharedWorker can send unknown status
* Add test for unknown status
* Always subscribe to CouchDB changes feed
- Always subscribe to the CouchDB changes feed, even if there are no observable objects, since we are also checking the status of CouchDB via this feed.
* Update indicator status if not using SharedWorker
* Start listening to changes feed on first request
* fix test
* adjust test to hopefully avoid race condition
* lint
Co-authored-by: John Hill <john.c.hill@nasa.gov>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
Co-authored-by: Scott Bell <scott@traclabs.com>
* Fix for Fault Management Visual Bugs (#5376)
* Closes #5365
* General visual improvements
Co-authored-by: Charles Hacskaylo <charlesh88@gmail.com>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* fix pathing (#5452)
Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com>
* [Static Root] Static Root Plugin not loading (#5455)
* Log if hitting falsy leafValue
* Add some logging
* Remove logs and specify null/undefined
Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com>
* Allow endpoints with a single enum metadata value in Bar/Line graphs (#5443)
* If there is only 1 metadata value, set yKey to none. Also, fix bug for determining the name of a metadata value
* Update tests for enum metadata values
Co-authored-by: John Hill <john.c.hill@nasa.gov>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* [Remote Clock] Wait for first tick and recalculate historical request bounds (#5433)
* Updated to ES6 class
* added request intercept functionality to telemetry api, added a request interceptor for remote clock
* add remoteClock e2e test stub
Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* Fix for missing object for LADTableSet (#5458)
* Handle missing object errors for display layouts
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* removing the call for default import now that TelemetryAPI is an ES6 class (#5461)
* [Remote Clock] Fix requestInterceptor typo (#5462)
* Fix typo in telemetry request interceptor
Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* Lock model (#5457)
* Lock event Model to prevent reactification
* de-reactify all the things
* Make API properties writable to allow test mocks to override them
* Fix merge conflict
* Added plot interceptor for missing series config (#5422)
Co-authored-by: Andrew Henry <akhenry@gmail.com>
Co-authored-by: Shefali Joshi <simplyrender@gmail.com>
* Remove performance marks (#5465)
* Remove performance marks
* Retain performance mark in view large. It doesn't happen very often and it's needed for an automated performance test
* Use timeKey for time comparison (#5471)
* Fix couchdb no response (#5474)
* Update the creation date only when the document is created for the first time
* If there is no response from a bulk get, couch db has issues
* Check the response - if it's null, don't apply interceptors
* Fix shelved alarms (#5479)
* Fix the logic around shelved alarms
* Remove application router listener
* Release 2.0.5 UI and Gauge fixes (#5470)
* Various UI fixes
- Tweak to Gauge properties form for clarity and usability.
- Fix Gauge 'dial' type not obeying "Show units" property setting, closes #5325.
- Tweaks to Operator Status UI label and layout for clarity.
- Changed name and description of Graph object for clarity and consistency.
- Fixed CSS classing that was coloring Export menu items text incorrectly.
- Fixed icon-to-text vertical alignment in `.c-object-label`.
- Fix for broken layout in imagery local controls (brightness, layers, magnification).
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* Stacked plot interceptor rename (#5468)
* Rename stacked plot interceptor and move to folder
Co-authored-by: Andrew Henry <akhenry@gmail.com>
* Clear data when time bounds are changed (#5482)
* Clear data when time bounds are changed
Also react to clear data action
Ensure that the yKey is set to 'none' if there is no range with array Values
* Refactor trace updates to a method
* get rid of root (#5483)
* Do not pass onPartialResponse option on to upstream telemetry (#5486)
* Fix all of the e2e tests (#5477)
* Fix timer test
* be explicit about the warnings text
* add full suite to CI to enable CircleCI Checks
* add back in devtool=false for CI env so firefox tests run
* add framework suite
* Don't install webpack HMR in CI
* Fix playwright version installs
* exclude HMR if running tests in any environment
- use NODE_ENV=TEST to exclude webpack HMR
- deparameterize some of the playwright configs
* use lower-case 'test'
* timer hover fix
* conditionally skip for firefox due to missing console events
* increase timeouts to give time for mutation
* no need to close save banner
* remove devtool setting
* revert
* update snapshots
* disable video to save some resources
* use one worker
* more timeouts :)
* Remove `browser.close()` and `page.close()` as it was breaking other tests
* Remove unnecessary awaits and fix func call syntax
* Fix image reset test
* fix restrictedNotebook tests
* revert playwright-ci.config settings
* increase timeout for polling imagery test
* remove unnecessary waits
* disable notebook lock test for chrome-beta as its unreliable
- remove some unnecessary 'wait for save banner' logic
- remove unused await
- mark imagery test as slow in chrome-beta
* LINT!! *shakes fist*
* don't run full e2e suite per commit
* disable video in all configs
* add flakey zoom comment
* exclude webpack HMR in non-development modes
Co-authored-by: Jesse Mazzella <jesse.d.mazzella@nasa.gov>
Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com>
* lint fix
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Joshi <simplyrender@gmail.com>
Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com>
Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov>
Co-authored-by: Andrew Henry <akhenry@gmail.com>
Co-authored-by: Scott Bell <scott@traclabs.com>
Co-authored-by: unlikelyzero <jchill2@gmail.com>
Co-authored-by: Alize Nguyen <alizenguyen@gmail.com>
Co-authored-by: Charles Hacskaylo <charlesh88@gmail.com>
Co-authored-by: Khalid Adil <khalidadil29@gmail.com>
Co-authored-by: rukmini-bose <48999852+rukmini-bose@users.noreply.github.com>
Co-authored-by: Jesse Mazzella <jesse.d.mazzella@nasa.gov>
2022-07-14 21:52:28 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
if (request.start === undefined) {
|
|
|
|
request.start = request.end - FIFTEEN_MINUTES;
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
var now = Date.now();
|
|
|
|
var start = request.start;
|
|
|
|
var end = request.end > now ? now : request.end;
|
|
|
|
var amplitude = request.amplitude;
|
|
|
|
var period = request.period;
|
|
|
|
var offset = request.offset;
|
|
|
|
var dataRateInHz = request.dataRateInHz;
|
|
|
|
var phase = request.phase;
|
|
|
|
var randomness = request.randomness;
|
|
|
|
var loadDelay = Math.max(request.loadDelay, 0);
|
|
|
|
var infinityValues = request.infinityValues;
|
|
|
|
|
|
|
|
var step = 1000 / dataRateInHz;
|
|
|
|
var nextStep = start - (start % step) + step;
|
|
|
|
|
|
|
|
var data = [];
|
|
|
|
|
|
|
|
for (; nextStep < end && data.length < 5000; nextStep += step) {
|
|
|
|
data.push({
|
|
|
|
utc: nextStep,
|
|
|
|
yesterday: nextStep - 60 * 60 * 24 * 1000,
|
|
|
|
sin: sin(nextStep, period, amplitude, offset, phase, randomness, infinityValues),
|
|
|
|
wavelengths: wavelengths(),
|
|
|
|
intensities: intensities(),
|
|
|
|
cos: cos(nextStep, period, amplitude, offset, phase, randomness, infinityValues)
|
|
|
|
});
|
|
|
|
}
|
2022-12-12 19:51:57 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
if (loadDelay === 0) {
|
|
|
|
postOnRequest(message, request, data);
|
|
|
|
} else {
|
|
|
|
setTimeout(() => postOnRequest(message, request, data), loadDelay);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function postOnRequest(message, request, data) {
|
|
|
|
self.postMessage({
|
|
|
|
id: message.id,
|
|
|
|
data: request.spectra
|
|
|
|
? {
|
|
|
|
wavelength: data.map((item) => {
|
|
|
|
return item.wavelength;
|
|
|
|
}),
|
|
|
|
cos: data.map((item) => {
|
|
|
|
return item.cos;
|
|
|
|
})
|
|
|
|
}
|
|
|
|
: data
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function cos(timestamp, period, amplitude, offset, phase, randomness, infinityValues) {
|
|
|
|
if (infinityValues && Math.random() > 0.5) {
|
|
|
|
return Number.POSITIVE_INFINITY;
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return (
|
|
|
|
amplitude * Math.cos(phase + (timestamp / period / 1000) * Math.PI * 2) +
|
|
|
|
amplitude * Math.random() * randomness +
|
|
|
|
offset
|
|
|
|
);
|
|
|
|
}
|
2022-12-12 19:51:57 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
function sin(timestamp, period, amplitude, offset, phase, randomness, infinityValues) {
|
|
|
|
if (infinityValues && Math.random() > 0.5) {
|
|
|
|
return Number.POSITIVE_INFINITY;
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return (
|
|
|
|
amplitude * Math.sin(phase + (timestamp / period / 1000) * Math.PI * 2) +
|
|
|
|
amplitude * Math.random() * randomness +
|
|
|
|
offset
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
function wavelengths() {
|
|
|
|
let values = [];
|
|
|
|
while (values.length < 5) {
|
|
|
|
const randomValue = Math.random() * 100;
|
|
|
|
if (!values.includes(randomValue)) {
|
|
|
|
values.push(String(randomValue));
|
|
|
|
}
|
2022-06-04 02:32:32 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return values;
|
|
|
|
}
|
2022-06-04 02:32:32 +00:00
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
function intensities() {
|
|
|
|
let values = [];
|
|
|
|
while (values.length < 5) {
|
|
|
|
const randomValue = Math.random() * 10;
|
|
|
|
if (!values.includes(randomValue)) {
|
|
|
|
values.push(String(randomValue));
|
|
|
|
}
|
2021-09-18 20:00:16 +00:00
|
|
|
}
|
|
|
|
|
2023-06-23 20:52:03 +00:00
|
|
|
return values;
|
|
|
|
}
|
|
|
|
|
|
|
|
function sendError(error, message) {
|
|
|
|
self.postMessage({
|
|
|
|
error: error.name + ': ' + error.message,
|
|
|
|
message: message,
|
|
|
|
id: message.id
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
self.onmessage = function handleMessage(event) {
|
|
|
|
var message = event.data;
|
|
|
|
var handler = handlers[message.request];
|
|
|
|
|
|
|
|
if (!handler) {
|
|
|
|
sendError(new Error('unknown message type'), message);
|
|
|
|
} else {
|
|
|
|
try {
|
|
|
|
handler(message);
|
|
|
|
} catch (e) {
|
|
|
|
sendError(e, message);
|
|
|
|
}
|
2016-12-14 23:02:53 +00:00
|
|
|
}
|
2023-06-23 20:52:03 +00:00
|
|
|
};
|
|
|
|
})();
|