mirror of
https://github.com/nasa/openmct.git
synced 2024-12-22 14:32:22 +00:00
90 lines
3.5 KiB
JavaScript
90 lines
3.5 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.
|
|
*****************************************************************************/
|
|
|
|
|
|
define(
|
|
[],
|
|
function () {
|
|
|
|
// Return values to use when a persistence space is unknown,
|
|
// and there is no appropriate provider to route to.
|
|
var METHOD_DEFAULTS = {
|
|
createObject: false,
|
|
readObject: undefined,
|
|
listObjects: [],
|
|
updateObject: false,
|
|
deleteObject: false
|
|
};
|
|
|
|
/**
|
|
* Aggregates multiple persistence providers, such that they can be
|
|
* utilized as if they were a single object. This is achieved by
|
|
* routing persistence calls to an appropriate provider; the space
|
|
* specified at call time is matched with the first provider (per
|
|
* priority order) which reports that it provides persistence for
|
|
* this space.
|
|
*
|
|
* @memberof platform/persistence/aggregator
|
|
* @constructor
|
|
* @implements {PersistenceService}
|
|
* @param $q Angular's $q, for promises
|
|
* @param {PersistenceService[]} providers the providers to aggregate
|
|
*/
|
|
function PersistenceAggregator($q, providers) {
|
|
var providerMap = {};
|
|
|
|
function addToMap(provider) {
|
|
return provider.listSpaces().then(function (spaces) {
|
|
spaces.forEach(function (space) {
|
|
providerMap[space] = providerMap[space] || provider;
|
|
});
|
|
});
|
|
}
|
|
|
|
this.providerMapPromise = $q.all(providers.map(addToMap))
|
|
.then(function () {
|
|
return providerMap;
|
|
});
|
|
}
|
|
|
|
PersistenceAggregator.prototype.listSpaces = function () {
|
|
return this.providerMapPromise.then(function (map) {
|
|
return Object.keys(map);
|
|
});
|
|
};
|
|
|
|
Object.keys(METHOD_DEFAULTS).forEach(function (method) {
|
|
PersistenceAggregator.prototype[method] = function (space) {
|
|
var delegateArgs = Array.prototype.slice.apply(arguments, []);
|
|
return this.providerMapPromise.then(function (map) {
|
|
var provider = map[space];
|
|
return provider ?
|
|
provider[method].apply(provider, delegateArgs) :
|
|
METHOD_DEFAULTS[method];
|
|
});
|
|
};
|
|
});
|
|
|
|
return PersistenceAggregator;
|
|
}
|
|
);
|