mirror of
https://github.com/nasa/openmct.git
synced 2025-02-12 05:35:56 +00:00
[Persistence] Add JSDoc
Add JSDoc to classes added/modified to support multiple persistence spaces, nasa/openmctweb#245.
This commit is contained in:
parent
a14f30c03c
commit
04ce2f985a
@ -33,6 +33,7 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/core
|
* @memberof platform/core
|
||||||
* @param $injector Angular's `$injector`
|
* @param $injector Angular's `$injector`
|
||||||
|
* @implements {Capability}
|
||||||
*/
|
*/
|
||||||
function InstantiationCapability($injector, identifierService, domainObject) {
|
function InstantiationCapability($injector, identifierService, domainObject) {
|
||||||
this.$injector = $injector;
|
this.$injector = $injector;
|
||||||
@ -47,6 +48,7 @@ define(
|
|||||||
* have been persisted, nor will it have been added to the
|
* have been persisted, nor will it have been added to the
|
||||||
* composition of the object which exposed this capability.
|
* composition of the object which exposed this capability.
|
||||||
*
|
*
|
||||||
|
* @param {object} the model for the new domain object
|
||||||
* @returns {DomainObject} the new domain object
|
* @returns {DomainObject} the new domain object
|
||||||
*/
|
*/
|
||||||
InstantiationCapability.prototype.instantiate = function (model) {
|
InstantiationCapability.prototype.instantiate = function (model) {
|
||||||
|
@ -29,8 +29,15 @@ define(
|
|||||||
var SEPARATOR = ":";
|
var SEPARATOR = ":";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides an interface for interpreting domain object
|
* Provides an interface for interpreting domain object identifiers;
|
||||||
* identifiers.
|
* in particular, parses out persistence space/key pairs associated
|
||||||
|
* with the domain object.
|
||||||
|
*
|
||||||
|
* @memberof platform/core
|
||||||
|
* @constructor
|
||||||
|
* @param {string} id the domain object identifier
|
||||||
|
* @param {string} defaultSpace the persistence space to use if
|
||||||
|
* one is not encoded in the identifier
|
||||||
*/
|
*/
|
||||||
function Identifier(id, defaultSpace) {
|
function Identifier(id, defaultSpace) {
|
||||||
var separatorIndex = id.indexOf(SEPARATOR);
|
var separatorIndex = id.indexOf(SEPARATOR);
|
||||||
@ -46,14 +53,30 @@ define(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the key under which the identified domain object's model
|
||||||
|
* should be persisted, within its persistence space.
|
||||||
|
* @returns {string} the key within its persistence space
|
||||||
|
*/
|
||||||
Identifier.prototype.getKey = function () {
|
Identifier.prototype.getKey = function () {
|
||||||
return this.key;
|
return this.key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the space in which the identified domain object's model should
|
||||||
|
* be persisted.
|
||||||
|
* @returns {string} the persistence space
|
||||||
|
*/
|
||||||
Identifier.prototype.getSpace = function () {
|
Identifier.prototype.getSpace = function () {
|
||||||
return this.space;
|
return this.space;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the persistence space, if any, which has been explicitly
|
||||||
|
* encoded in this domain object's identifier. Returns undefined
|
||||||
|
* if no such space has been specified.
|
||||||
|
* @returns {string} the persistence space, or undefined
|
||||||
|
*/
|
||||||
Identifier.prototype.getDefinedSpace = function () {
|
Identifier.prototype.getDefinedSpace = function () {
|
||||||
return this.definedSpace;
|
return this.definedSpace;
|
||||||
};
|
};
|
||||||
|
@ -28,11 +28,22 @@ define(
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Parses and generates domain object identifiers.
|
* Parses and generates domain object identifiers.
|
||||||
|
* @param {string} defaultSpace the default persistence space
|
||||||
|
* @constructor
|
||||||
|
* @memberof {platform/core}
|
||||||
*/
|
*/
|
||||||
function IdentifierProvider(defaultSpace) {
|
function IdentifierProvider(defaultSpace) {
|
||||||
this.defaultSpace = defaultSpace;
|
this.defaultSpace = defaultSpace;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a new domain object identifier. A persistence space
|
||||||
|
* may optionally be included; if not specified, no space will
|
||||||
|
* be encoded into the identifier.
|
||||||
|
* @param {string} [space] the persistence space to encode
|
||||||
|
* in this identifier
|
||||||
|
* @returns {string} a new domain object identifier
|
||||||
|
*/
|
||||||
IdentifierProvider.prototype.generate = function (space) {
|
IdentifierProvider.prototype.generate = function (space) {
|
||||||
var id = uuid();
|
var id = uuid();
|
||||||
if (space !== undefined) {
|
if (space !== undefined) {
|
||||||
@ -41,6 +52,11 @@ define(
|
|||||||
return id;
|
return id;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse a domain object identifier to examine its component
|
||||||
|
* parts (e.g. its persistence space.)
|
||||||
|
* @returns {platform/core.Identifier} the parsed identifier
|
||||||
|
*/
|
||||||
IdentifierProvider.prototype.parse = function (id) {
|
IdentifierProvider.prototype.parse = function (id) {
|
||||||
return new Identifier(id, this.defaultSpace);
|
return new Identifier(id, this.defaultSpace);
|
||||||
};
|
};
|
||||||
|
@ -62,6 +62,8 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @private
|
* @private
|
||||||
* @memberof platform/entanglement
|
* @memberof platform/entanglement
|
||||||
|
* @param {PolicyService} policyService the policy service to use to
|
||||||
|
* verify that variants of this action are allowed
|
||||||
* @param {platform/entanglement.LocationService} locationService a
|
* @param {platform/entanglement.LocationService} locationService a
|
||||||
* service to request destinations from the user
|
* service to request destinations from the user
|
||||||
* @param {platform/entanglement.AbstractComposeService} composeService
|
* @param {platform/entanglement.AbstractComposeService} composeService
|
||||||
|
@ -33,6 +33,14 @@ define(
|
|||||||
"compose"
|
"compose"
|
||||||
];
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This policy prevents performing move/copy/link actions across
|
||||||
|
* different persistence spaces (e.g. linking to an object in
|
||||||
|
* a private space from an object in a public space.)
|
||||||
|
* @memberof {platform/entanglement}
|
||||||
|
* @constructor
|
||||||
|
* @implements {Policy}
|
||||||
|
*/
|
||||||
function CrossSpacePolicy() {
|
function CrossSpacePolicy() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,10 +36,13 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Aggregates multiple persistence providers, such that they can be
|
||||||
|
* utilized as if they were a single object.
|
||||||
* @memberof platform/persistence/aggregator
|
* @memberof platform/persistence/aggregator
|
||||||
* @constructor
|
* @constructor
|
||||||
* @implements {PersistenceService}
|
* @implements {PersistenceService}
|
||||||
* @param q Angular's $q, for promises
|
* @param $q Angular's $q, for promises
|
||||||
|
* @param {PersistenceService[]} providers the providers to aggregate
|
||||||
*/
|
*/
|
||||||
function PersistenceAggregator($q, providers) {
|
function PersistenceAggregator($q, providers) {
|
||||||
var providerMap = {};
|
var providerMap = {};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user