mirror of
https://github.com/nasa/openmct.git
synced 2025-03-11 23:14:16 +00:00
137 lines
5.6 KiB
JavaScript
137 lines
5.6 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2016, 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.
|
|
*****************************************************************************/
|
|
|
|
/**
|
|
* This bundle provides infrastructure and utility services for handling
|
|
* telemetry data.
|
|
* @namespace platform/telemetry
|
|
*/
|
|
define(
|
|
[],
|
|
function () {
|
|
|
|
/**
|
|
* Describes a request for telemetry data. Note that responses
|
|
* may contain either a sub- or superset of the requested data.
|
|
* @typedef TelemetryRequest
|
|
* @property {string} source an identifier for the relevant
|
|
* source of telemetry data
|
|
* @property {string} key an identifier for the specific
|
|
* series of telemetry data provided by that source
|
|
* @property {number} [start] the earliest domain value of
|
|
* interest for that telemetry data; for time-based
|
|
* domains, this is in milliseconds since the start
|
|
* of 1970
|
|
* @property {number} [end] the latest domain value of interest
|
|
* for that telemetry data; for time-based domains,
|
|
* this is in milliseconds since 1970
|
|
* @property {string} [domain] the domain for the query; if
|
|
* omitted, this will be whatever the "normal"
|
|
* domain is for a given telemetry series (the
|
|
* first domain from its metadata)
|
|
* @property {number} [size] if set, indicates the maximum number
|
|
* of data points of interest for this request (more
|
|
* recent domain values will be preferred)
|
|
*/
|
|
|
|
/**
|
|
* Request telemetry data.
|
|
* @param {TelemetryRequest[]} requests and array of
|
|
* requests to be handled
|
|
* @returns {Promise} a promise for telemetry data
|
|
* which may (or may not, depending on
|
|
* availability) satisfy the requests
|
|
* @method TelemetryService#requestTelemetry
|
|
*/
|
|
/**
|
|
* Subscribe to streaming updates to telemetry data.
|
|
* The provided callback will be invoked as new
|
|
* telemetry becomes available; as an argument, it
|
|
* will receive an object of key-value pairs, where
|
|
* keys are source identifiers and values are objects
|
|
* of key-value pairs, where keys are point identifiers
|
|
* and values are TelemetrySeries objects containing
|
|
* the latest streaming telemetry.
|
|
* @param {Function} callback the callback to invoke
|
|
* @param {TelemetryRequest[]} requests an array of
|
|
* requests to be subscribed upon
|
|
* @returns {Function} a function which can be called
|
|
* to unsubscribe
|
|
* @method TelmetryService#subscribe
|
|
*/
|
|
|
|
/**
|
|
* A telemetry aggregator makes many telemetry providers
|
|
* appear as one.
|
|
*
|
|
* @memberof platform/telemetry
|
|
* @constructor
|
|
*/
|
|
function TelemetryAggregator($q, telemetryProviders) {
|
|
this.$q = $q;
|
|
this.telemetryProviders = telemetryProviders;
|
|
}
|
|
|
|
// Merge the results from many providers into one
|
|
// result object.
|
|
function mergeResults(results) {
|
|
var merged = {};
|
|
|
|
results.forEach(function (result) {
|
|
Object.keys(result).forEach(function (k) {
|
|
merged[k] = result[k];
|
|
});
|
|
});
|
|
|
|
return merged;
|
|
}
|
|
|
|
// Request telemetry from all providers; once they've
|
|
// responded, merge the results into one result object.
|
|
TelemetryAggregator.prototype.requestTelemetry = function (requests) {
|
|
return this.$q.all(this.telemetryProviders.map(function (provider) {
|
|
return provider.requestTelemetry(requests);
|
|
})).then(mergeResults);
|
|
};
|
|
|
|
// Subscribe to updates from all providers
|
|
TelemetryAggregator.prototype.subscribe = function (callback, requests) {
|
|
var unsubscribes = this.telemetryProviders.map(function (provider) {
|
|
return provider.subscribe(callback, requests);
|
|
});
|
|
|
|
// Return an unsubscribe function that invokes unsubscribe
|
|
// for all providers.
|
|
return function () {
|
|
unsubscribes.forEach(function (unsubscribe) {
|
|
if (unsubscribe) {
|
|
unsubscribe();
|
|
}
|
|
});
|
|
};
|
|
};
|
|
|
|
|
|
return TelemetryAggregator;
|
|
}
|
|
);
|