openmct/example/eventGenerator/EventTelemetryProvider.js

105 lines
3.2 KiB
JavaScript
Raw Normal View History

/*****************************************************************************
* Open MCT, Copyright (c) 2014-2023, United States Government
* 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.
*****************************************************************************/
/**
* Module defining EventTelemetryProvider. Created by chacskaylo on 06/18/2015.
*/
import messages from './transcript.json';
class EventTelemetryProvider {
2023-05-19 14:10:03 +00:00
constructor() {
this.defaultSize = 25;
}
2023-05-19 14:10:03 +00:00
generateData(firstObservedTime, count, startTime, duration, name) {
const millisecondsSinceStart = startTime - firstObservedTime;
const utc = startTime + count * duration;
const ind = count % messages.length;
const message = messages[ind] + ' - [' + millisecondsSinceStart + ']';
2023-05-19 14:10:03 +00:00
return {
name,
utc,
message
};
}
2023-05-19 14:10:03 +00:00
supportsRequest(domainObject) {
return domainObject.type === 'eventGenerator';
}
2023-05-19 14:10:03 +00:00
supportsSubscribe(domainObject) {
return domainObject.type === 'eventGenerator';
}
2023-05-19 14:10:03 +00:00
subscribe(domainObject, callback) {
const duration = domainObject.telemetry.duration * 1000;
const firstObservedTime = Date.now();
let count = 0;
2023-05-19 14:10:03 +00:00
const interval = setInterval(() => {
const startTime = Date.now();
const datum = this.generateData(
firstObservedTime,
count,
startTime,
duration,
domainObject.name
);
count += 1;
callback(datum);
}, duration);
2023-05-19 14:10:03 +00:00
return function () {
clearInterval(interval);
};
}
2023-05-19 14:10:03 +00:00
request(domainObject, options) {
let start = options.start;
const end = Math.min(Date.now(), options.end); // no future values
const duration = domainObject.telemetry.duration * 1000;
const size = options.size ? options.size : this.defaultSize;
const data = [];
const firstObservedTime = options.start;
let count = 0;
2023-05-19 14:10:03 +00:00
if (options.strategy === 'latest' || options.size === 1) {
start = end;
}
2023-05-19 14:10:03 +00:00
while (start <= end && data.length < size) {
const startTime = options.start + count;
data.push(
this.generateData(firstObservedTime, count, startTime, duration, domainObject.name)
);
start += duration;
count += 1;
}
2023-05-19 14:10:03 +00:00
return Promise.resolve(data);
}
}
export default EventTelemetryProvider;