@haventech/semotus
Advanced tools
Comparing version 6.0.1 to 7.0.0-beta.1
@@ -21,7 +21,7 @@ "use strict"; | ||
function supertypeClass(objectTemplate, SupertypeModule, target) { | ||
var ret; | ||
var ObjectTemplate = SupertypeModule.default; | ||
var syncStates = []; // Default syncStates to empty array | ||
let ret; | ||
let ObjectTemplate = SupertypeModule.default; | ||
let syncStates = []; // Default syncStates to empty array | ||
// Decorator workerbee | ||
var decorator = function decorator(target) { | ||
const decorator = function decorator(target) { | ||
// second time we must call the function returned the first time because it has the | ||
@@ -42,13 +42,13 @@ // properties as a closure | ||
target.prototype.__amorphicprops__[propertyName] = defineProperty; | ||
var value_1 = defineProperty.value; | ||
const value = defineProperty.value; | ||
// The getter actually initializes the property | ||
defineProperty.get = function () { | ||
var nameSpacedProperty = "__" + propertyName; | ||
let nameSpacedProperty = `__${propertyName}`; | ||
if (!this[nameSpacedProperty]) { | ||
var cloneTemplate = defineProperty.of || defineProperty.type || null; | ||
this[nameSpacedProperty] = ObjectTemplate.clone(value_1, cloneTemplate); | ||
let cloneTemplate = defineProperty.of || defineProperty.type || null; | ||
this[nameSpacedProperty] = ObjectTemplate.clone(value, cloneTemplate); | ||
} | ||
return this[nameSpacedProperty]; | ||
}; | ||
var defineProperties = {}; | ||
const defineProperties = {}; | ||
objectTemplate._setupProperty(propertyName, defineProperty, undefined, defineProperties); | ||
@@ -72,3 +72,3 @@ Object.defineProperties(target.prototype, defineProperties); | ||
else if (target && target.syncStates) { | ||
console.warn("Semotus warning: " + target.syncStates + " is not an array value, so not setting up SyncStates for this target: " + target); | ||
console.warn(`Semotus warning: ${target.syncStates} is not an array value, so not setting up SyncStates for this target: ${target}`); | ||
} | ||
@@ -83,3 +83,3 @@ // Called first time with parameters (prop definition) rather than target (template) | ||
function Supertype(template, objectTemplate, Supertype) { | ||
return Supertype.call(template, objectTemplate); | ||
return Reflect.construct(Supertype, [objectTemplate], template.constructor); | ||
} | ||
@@ -91,6 +91,6 @@ exports.Supertype = Supertype; | ||
props.toServer = applyRuleSet(props.toServer, toServerRuleSet); | ||
var baseDecorator = SupertypeModule.property(props, objectTemplate); | ||
const baseDecorator = SupertypeModule.property(props, objectTemplate); | ||
return function (target, targetKey) { | ||
baseDecorator(target, targetKey); | ||
var defineProperties = {}; | ||
const defineProperties = {}; | ||
props.enumerable = true; | ||
@@ -113,4 +113,4 @@ props.writable = true; | ||
// function that we call to validate any changes for remote calls | ||
var remoteValidator = defineProperty.serverValidation; | ||
var isPublic = !!defineProperty.public; | ||
let remoteValidator = defineProperty.serverValidation; | ||
let isPublic = !!defineProperty.public; | ||
return function (target, propertyName, descriptor) { | ||
@@ -146,2 +146,2 @@ descriptor.value = objectTemplate._setupFunction(propertyName, descriptor.value, defineProperty.on, defineProperty.validate, remoteValidator, isPublic, defineProperty.target); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Attaches syncStates props to the template\n * If a class is decorated like @supertypeClass({syncStates: ['internal', 'home']}), any instances of that class\n * including those that exist at the beginning of the application, should only be sent over when the controller state on\n * the server indicates that the correct syncState (if and only if controller.syncState = 'home' or 'internal', then an\n * object of this class will be sent, otherwise semotus will refrain from sending it over). The caveat, however, is if\n * semotus' controller's syncState is defined as '*' then we will by default send all templates unless specified other-\n * wise (the same as treating syncState: ['*'])\n *\n */\n\n\n/**\n * @TODO: This should be consolidated with Supertype's version when we finish converting to typescript\n */\n\n// Context Switch Chain:\n// 1st pass: Semotus (sClass) -> Supertype (sClass) -> Semotus (return Ret)\n// 2nd pass: Semotus (sClass) -> Semotus (decorator) -> Supertype (eval ret) -> Semotus (return)\nexport function supertypeClass(objectTemplate, SupertypeModule, target): any {\n    let ret;\n    let ObjectTemplate = SupertypeModule.default;\n    let syncStates: String[] = [];  // Default syncStates to empty array\n\n    // Decorator workerbee\n    const decorator = function decorator(target) {\n        // second time we must call the function returned the first time because it has the\n        // properties as a closure\n        if (ret) {\n            ret = ret(target, objectTemplate)\n        } else {\n            ret = SupertypeModule.supertypeClass(target, objectTemplate);\n        }\n\n        // Mainly for persistor properties to make sure they get transported\n        target.createProperty = function (propertyName, defineProperty) {\n            if (defineProperty.body) {\n                target.prototype[propertyName] = objectTemplate._setupFunction(\n                    propertyName,\n                    defineProperty.body,\n                    defineProperty.on,\n                    defineProperty.validate\n                );\n            } else {\n                target.prototype.__amorphicprops__[propertyName] = defineProperty;\n                const value = defineProperty.value;\n\n                // The getter actually initializes the property\n                defineProperty.get = function () {\n                    let nameSpacedProperty = `__${propertyName}`;\n\n                    if (!this[nameSpacedProperty]) {\n                        let cloneTemplate = defineProperty.of || defineProperty.type || null;\n                        this[nameSpacedProperty] = ObjectTemplate.clone(value, cloneTemplate);\n                    }\n                    return this[nameSpacedProperty];\n                };\n\n                const defineProperties = {};\n                objectTemplate._setupProperty(propertyName, defineProperty, undefined, defineProperties);\n                Object.defineProperties(target.prototype, defineProperties);\n            }\n        };\n\n        // Assigning sync states from prop definition onto the template\n        if (syncStates) {\n            target.syncStates = syncStates;\n        }\n\n        return ret;\n    };\n\n    // Calling the decorator processor with the actual Template (2nd time)\n    if (target.prototype) {\n        return decorator(target);\n    } else if (target && target.syncStates && target.syncStates instanceof Array) {\n        syncStates = target.syncStates;\n    } else if (target && target.syncStates ) {\n        console.warn(`Semotus warning: ${target.syncStates} is not an array value, so not setting up SyncStates for this target: ${target}`);\n    }\n\n    // Called first time with parameters (prop definition) rather than target (template)\n    // call supertypes supertypeClass function which will return a function that must be\n    // called on the 2nd pass when we have a target. This function's closure will also have a ref to the original properties\n    ret = SupertypeModule.supertypeClass(target, objectTemplate);\n    return decorator; // decorator will be called 2nd time with ret as a closure\n}\n\nexport function Supertype(template, objectTemplate, Supertype) {\n    return Supertype.call(template, objectTemplate);\n}\n\nexport function property(objectTemplate, SupertypeModule, props, toClientRuleSet, toServerRuleSet) {\n    props = props || {};\n    props.toClient = applyRuleSet(props.toClient, toClientRuleSet);\n    props.toServer = applyRuleSet(props.toServer, toServerRuleSet);\n    const baseDecorator = SupertypeModule.property(props, objectTemplate);\n    return function (target, targetKey) {\n        baseDecorator(target, targetKey);\n        const defineProperties = {};\n        props.enumerable = true;\n        props.writable = true;\n        objectTemplate._setupProperty(targetKey, props, undefined, defineProperties);\n        Object.defineProperties(target, defineProperties);\n    };\n}\n\n\nexport function remote(objectTemplate, defineProperty) {\n    defineProperty = defineProperty || {};\n\n    /*\n        if we haven't supplied a configuration object into the decorator,\n         default the role of this function to a server API function\n     */\n    if (!defineProperty.on) {\n        defineProperty.on = 'server';\n    }\n\n    // function that we call to validate any changes for remote calls\n    let remoteValidator = defineProperty.serverValidation;\n    let isPublic = !!defineProperty.public;\n\n    return function (target, propertyName, descriptor) {\n        descriptor.value = objectTemplate._setupFunction(\n            propertyName,\n            descriptor.value,\n            defineProperty.on,\n            defineProperty.validate,\n            remoteValidator,\n            isPublic,\n            defineProperty.target\n        );\n\n        /*\n            this function been marked as a server API either explicitly or by default.\n            set the appropriate metadata.\n         */\n        if (defineProperty.on === 'server') {\n            descriptor.value.__on__ = 'server';\n        }\n\n        if (defineProperty.type) {\n            descriptor.value.__returns__ = defineProperty.type;\n        }\n        if (defineProperty.of) {\n            descriptor.value.__returns__ = defineProperty.of;\n            descriptor.value.__returnsarray__ = true;\n        }\n    };\n};\n\n\nfunction applyRuleSet(prop, ruleSet) {\n    if (prop instanceof Array && ruleSet instanceof Array && ruleSet.length > 0) {\n        return prop.some(function (r) {\n            return ruleSet.indexOf(r) >= 0;\n        });\n    } else {\n        return prop;\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Attaches syncStates props to the template\n * If a class is decorated like @supertypeClass({syncStates: ['internal', 'home']}), any instances of that class\n * including those that exist at the beginning of the application, should only be sent over when the controller state on\n * the server indicates that the correct syncState (if and only if controller.syncState = 'home' or 'internal', then an\n * object of this class will be sent, otherwise semotus will refrain from sending it over). The caveat, however, is if\n * semotus' controller's syncState is defined as '*' then we will by default send all templates unless specified other-\n * wise (the same as treating syncState: ['*'])\n *\n */\n\n\n/**\n * @TODO: This should be consolidated with Supertype's version when we finish converting to typescript\n */\n\n// Context Switch Chain:\n// 1st pass: Semotus (sClass) -> Supertype (sClass) -> Semotus (return Ret)\n// 2nd pass: Semotus (sClass) -> Semotus (decorator) -> Supertype (eval ret) -> Semotus (return)\nexport function supertypeClass(objectTemplate, SupertypeModule, target): any {\n    let ret;\n    let ObjectTemplate = SupertypeModule.default;\n    let syncStates: String[] = [];  // Default syncStates to empty array\n\n    // Decorator workerbee\n    const decorator = function decorator(target) {\n        // second time we must call the function returned the first time because it has the\n        // properties as a closure\n        if (ret) {\n            ret = ret(target, objectTemplate)\n        } else {\n            ret = SupertypeModule.supertypeClass(target, objectTemplate);\n        }\n\n        // Mainly for persistor properties to make sure they get transported\n        target.createProperty = function (propertyName, defineProperty) {\n            if (defineProperty.body) {\n                target.prototype[propertyName] = objectTemplate._setupFunction(\n                    propertyName,\n                    defineProperty.body,\n                    defineProperty.on,\n                    defineProperty.validate\n                );\n            } else {\n                target.prototype.__amorphicprops__[propertyName] = defineProperty;\n                const value = defineProperty.value;\n\n                // The getter actually initializes the property\n                defineProperty.get = function () {\n                    let nameSpacedProperty = `__${propertyName}`;\n\n                    if (!this[nameSpacedProperty]) {\n                        let cloneTemplate = defineProperty.of || defineProperty.type || null;\n                        this[nameSpacedProperty] = ObjectTemplate.clone(value, cloneTemplate);\n                    }\n                    return this[nameSpacedProperty];\n                };\n\n                const defineProperties = {};\n                objectTemplate._setupProperty(propertyName, defineProperty, undefined, defineProperties);\n                Object.defineProperties(target.prototype, defineProperties);\n            }\n        };\n\n        // Assigning sync states from prop definition onto the template\n        if (syncStates) {\n            target.syncStates = syncStates;\n        }\n\n        return ret;\n    };\n\n    // Calling the decorator processor with the actual Template (2nd time)\n    if (target.prototype) {\n        return decorator(target);\n    } else if (target && target.syncStates && target.syncStates instanceof Array) {\n        syncStates = target.syncStates;\n    } else if (target && target.syncStates ) {\n        console.warn(`Semotus warning: ${target.syncStates} is not an array value, so not setting up SyncStates for this target: ${target}`);\n    }\n\n    // Called first time with parameters (prop definition) rather than target (template)\n    // call supertypes supertypeClass function which will return a function that must be\n    // called on the 2nd pass when we have a target. This function's closure will also have a ref to the original properties\n    ret = SupertypeModule.supertypeClass(target, objectTemplate);\n    return decorator; // decorator will be called 2nd time with ret as a closure\n}\n\nexport function Supertype(template, objectTemplate, Supertype) {\n    return Reflect.construct( Supertype, [objectTemplate], template.constructor );\n}\n\nexport function property(objectTemplate, SupertypeModule, props, toClientRuleSet, toServerRuleSet) {\n    props = props || {};\n    props.toClient = applyRuleSet(props.toClient, toClientRuleSet);\n    props.toServer = applyRuleSet(props.toServer, toServerRuleSet);\n    const baseDecorator = SupertypeModule.property(props, objectTemplate);\n    return function (target, targetKey) {\n        baseDecorator(target, targetKey);\n        const defineProperties = {};\n        props.enumerable = true;\n        props.writable = true;\n        objectTemplate._setupProperty(targetKey, props, undefined, defineProperties);\n        Object.defineProperties(target, defineProperties);\n    };\n}\n\n\nexport function remote(objectTemplate, defineProperty) {\n    defineProperty = defineProperty || {};\n\n    /*\n        if we haven't supplied a configuration object into the decorator,\n         default the role of this function to a server API function\n     */\n    if (!defineProperty.on) {\n        defineProperty.on = 'server';\n    }\n\n    // function that we call to validate any changes for remote calls\n    let remoteValidator = defineProperty.serverValidation;\n    let isPublic = !!defineProperty.public;\n\n    return function (target, propertyName, descriptor) {\n        descriptor.value = objectTemplate._setupFunction(\n            propertyName,\n            descriptor.value,\n            defineProperty.on,\n            defineProperty.validate,\n            remoteValidator,\n            isPublic,\n            defineProperty.target\n        );\n\n        /*\n            this function been marked as a server API either explicitly or by default.\n            set the appropriate metadata.\n         */\n        if (defineProperty.on === 'server') {\n            descriptor.value.__on__ = 'server';\n        }\n\n        if (defineProperty.type) {\n            descriptor.value.__returns__ = defineProperty.type;\n        }\n        if (defineProperty.of) {\n            descriptor.value.__returns__ = defineProperty.of;\n            descriptor.value.__returnsarray__ = true;\n        }\n    };\n};\n\n\nfunction applyRuleSet(prop, ruleSet) {\n    if (prop instanceof Array && ruleSet instanceof Array && ruleSet.length > 0) {\n        return prop.some(function (r) {\n            return ruleSet.indexOf(r) >= 0;\n        });\n    } else {\n        return prop;\n    }\n}"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.removeAll = exports.remove = exports.getArrayChangeGroup = exports.getPropChangeGroup = exports.get = void 0; | ||
var Types_1 = require("./Types"); | ||
var Subscriptions = require("./Subscriptions"); | ||
const Types_1 = require("./Types"); | ||
const Subscriptions = require("./Subscriptions"); | ||
function get(type, subscriptionId, semotus) { | ||
var subscription = Subscriptions.getSubscription(semotus, subscriptionId); | ||
const subscription = Subscriptions.getSubscription(semotus, subscriptionId); | ||
return subscription.log[type]; | ||
@@ -51,3 +51,3 @@ } | ||
function removeAll(type, semotus) { | ||
for (var subscription in Subscriptions.getSubscriptions(semotus)) { | ||
for (const subscription in Subscriptions.getSubscriptions(semotus)) { | ||
remove(type, subscription, semotus); | ||
@@ -57,2 +57,2 @@ } | ||
exports.removeAll = removeAll; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhbmdlR3JvdXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlbHBlcnMvQ2hhbmdlR3JvdXBzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlDQUE2RTtBQUM3RSwrQ0FBaUQ7QUFFakQsU0FBZ0IsR0FBRyxDQUFDLElBQTJCLEVBQUUsY0FBYyxFQUFFLE9BQWdCO0lBQzdFLElBQU0sWUFBWSxHQUFHLGFBQWEsQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQzVFLE9BQU8sWUFBWSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUNsQyxDQUFDO0FBSEQsa0JBR0M7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLGtCQUFrQixDQUFDLGNBQWMsRUFBRSxPQUFnQjtJQUMvRCxPQUFPLEdBQUcsQ0FBQyxjQUFNLEVBQUUsY0FBYyxFQUFFLE9BQU8sQ0FBZ0IsQ0FBQztBQUMvRCxDQUFDO0FBRkQsZ0RBRUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixtQkFBbUIsQ0FBQyxJQUFnQixFQUFFLGNBQWMsRUFBRSxPQUFnQjtJQUNsRixPQUFPLEdBQUcsQ0FBQyxJQUFJLEVBQUUsY0FBYyxFQUFFLE9BQU8sQ0FBZSxDQUFDO0FBQzVELENBQUM7QUFGRCxrREFFQztBQUdEOzs7Ozs7R0FNRztBQUNILFNBQWdCLE1BQU0sQ0FBQyxJQUFZLEVBQUUsY0FBYyxFQUFFLE9BQWdCO0lBQ2pFLGFBQWEsQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUUsQ0FBQztBQUZELHdCQUVDO0FBR0Q7Ozs7OztHQU1HO0FBQ0gsU0FBZ0IsU0FBUyxDQUFDLElBQVksRUFBRSxPQUFnQjtJQUNwRCxLQUFLLElBQU0sWUFBWSxJQUFJLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUNoRSxNQUFNLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRSxPQUFPLENBQUMsQ0FBQztLQUN2QztBQUNMLENBQUM7QUFKRCw4QkFJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXJyYXlHcm91cCwgQXJyYXlUeXBlcywgQ2hhbmdlLCBDaGFuZ2VHcm91cCwgU2Vtb3R1c30gZnJvbSAnLi9UeXBlcyc7XG5pbXBvcnQgKiBhcyBTdWJzY3JpcHRpb25zIGZyb20gJy4vU3Vic2NyaXB0aW9ucyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXQodHlwZTogJ2NoYW5nZScgfCBBcnJheVR5cGVzLCBzdWJzY3JpcHRpb25JZCwgc2Vtb3R1czogU2Vtb3R1cyk6IENoYW5nZUdyb3VwIHwgQXJyYXlHcm91cCB7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gU3Vic2NyaXB0aW9ucy5nZXRTdWJzY3JpcHRpb24oc2Vtb3R1cywgc3Vic2NyaXB0aW9uSWQpO1xuICAgIHJldHVybiBzdWJzY3JpcHRpb24ubG9nW3R5cGVdO1xufVxuXG4vKipcbiAqIEdldHMgUHJvcGVydHkgY2hhbmdlIGdyb3VwcyAobm9uLWFycmF5KVxuICpcbiAqIEBwYXJhbSBzdWJzY3JpcHRpb25JZFxuICogQHBhcmFtIHNlbW90dXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFByb3BDaGFuZ2VHcm91cChzdWJzY3JpcHRpb25JZCwgc2Vtb3R1czogU2Vtb3R1cyk6IENoYW5nZUdyb3VwIHtcbiAgICByZXR1cm4gZ2V0KENoYW5nZSwgc3Vic2NyaXB0aW9uSWQsIHNlbW90dXMpIGFzIENoYW5nZUdyb3VwO1xufVxuXG4vKipcbiAqIEdldHMgQXJyYXkgQ2hhbmdlIEdyb3Vwc1xuICpcbiAqIEBwYXJhbSB0eXBlXG4gKiBAcGFyYW0gc3Vic2NyaXB0aW9uSWRcbiAqIEBwYXJhbSBzZW1vdHVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRBcnJheUNoYW5nZUdyb3VwKHR5cGU6IEFycmF5VHlwZXMsIHN1YnNjcmlwdGlvbklkLCBzZW1vdHVzOiBTZW1vdHVzKTogQXJyYXlHcm91cCB7XG4gICAgcmV0dXJuIGdldCh0eXBlLCBzdWJzY3JpcHRpb25JZCwgc2Vtb3R1cykgYXMgQXJyYXlHcm91cDtcbn1cblxuXG4vKipcbiAqIFJlbW92ZSBhIGNoYW5nZSBncm91cCBmcm9tIGEgc3Vic2NyaXB0aW9uXG4gKlxuICogQHBhcmFtIHR5cGVcbiAqIEBwYXJhbSBzdWJzY3JpcHRpb25JZCB1bmtub3duXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICovXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlKHR5cGU6IHN0cmluZywgc3Vic2NyaXB0aW9uSWQsIHNlbW90dXM6IFNlbW90dXMpIHtcbiAgICBTdWJzY3JpcHRpb25zLmdldFN1YnNjcmlwdGlvbihzZW1vdHVzLCBzdWJzY3JpcHRpb25JZCkubG9nW3R5cGVdID0ge307XG59XG5cblxuLyoqXG4gKiBSZW1vdmUgYWxsIGNoYW5nZSBncm91cHMgZnJvbSBhIHN1YnNjcmlwdGlvbiB3aXRoIGdpdmVuIHR5cGVcbiAqIEBwYXJhbSB0eXBlXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICpcbiAqIEBwcml2YXRlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW1vdmVBbGwodHlwZTogc3RyaW5nLCBzZW1vdHVzOiBTZW1vdHVzKSB7XG4gICAgZm9yIChjb25zdCBzdWJzY3JpcHRpb24gaW4gU3Vic2NyaXB0aW9ucy5nZXRTdWJzY3JpcHRpb25zKHNlbW90dXMpKSB7XG4gICAgICAgIHJlbW92ZSh0eXBlLCBzdWJzY3JpcHRpb24sIHNlbW90dXMpO1xuICAgIH1cbn0iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhbmdlR3JvdXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlbHBlcnMvQ2hhbmdlR3JvdXBzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1DQUE2RTtBQUM3RSxpREFBaUQ7QUFFakQsU0FBZ0IsR0FBRyxDQUFDLElBQTJCLEVBQUUsY0FBYyxFQUFFLE9BQWdCO0lBQzdFLE1BQU0sWUFBWSxHQUFHLGFBQWEsQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQzVFLE9BQU8sWUFBWSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUNsQyxDQUFDO0FBSEQsa0JBR0M7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLGtCQUFrQixDQUFDLGNBQWMsRUFBRSxPQUFnQjtJQUMvRCxPQUFPLEdBQUcsQ0FBQyxjQUFNLEVBQUUsY0FBYyxFQUFFLE9BQU8sQ0FBZ0IsQ0FBQztBQUMvRCxDQUFDO0FBRkQsZ0RBRUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixtQkFBbUIsQ0FBQyxJQUFnQixFQUFFLGNBQWMsRUFBRSxPQUFnQjtJQUNsRixPQUFPLEdBQUcsQ0FBQyxJQUFJLEVBQUUsY0FBYyxFQUFFLE9BQU8sQ0FBZSxDQUFDO0FBQzVELENBQUM7QUFGRCxrREFFQztBQUdEOzs7Ozs7R0FNRztBQUNILFNBQWdCLE1BQU0sQ0FBQyxJQUFZLEVBQUUsY0FBYyxFQUFFLE9BQWdCO0lBQ2pFLGFBQWEsQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUUsQ0FBQztBQUZELHdCQUVDO0FBR0Q7Ozs7OztHQU1HO0FBQ0gsU0FBZ0IsU0FBUyxDQUFDLElBQVksRUFBRSxPQUFnQjtJQUNwRCxLQUFLLE1BQU0sWUFBWSxJQUFJLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUNoRSxNQUFNLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRSxPQUFPLENBQUMsQ0FBQztLQUN2QztBQUNMLENBQUM7QUFKRCw4QkFJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXJyYXlHcm91cCwgQXJyYXlUeXBlcywgQ2hhbmdlLCBDaGFuZ2VHcm91cCwgU2Vtb3R1c30gZnJvbSAnLi9UeXBlcyc7XG5pbXBvcnQgKiBhcyBTdWJzY3JpcHRpb25zIGZyb20gJy4vU3Vic2NyaXB0aW9ucyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXQodHlwZTogJ2NoYW5nZScgfCBBcnJheVR5cGVzLCBzdWJzY3JpcHRpb25JZCwgc2Vtb3R1czogU2Vtb3R1cyk6IENoYW5nZUdyb3VwIHwgQXJyYXlHcm91cCB7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gU3Vic2NyaXB0aW9ucy5nZXRTdWJzY3JpcHRpb24oc2Vtb3R1cywgc3Vic2NyaXB0aW9uSWQpO1xuICAgIHJldHVybiBzdWJzY3JpcHRpb24ubG9nW3R5cGVdO1xufVxuXG4vKipcbiAqIEdldHMgUHJvcGVydHkgY2hhbmdlIGdyb3VwcyAobm9uLWFycmF5KVxuICpcbiAqIEBwYXJhbSBzdWJzY3JpcHRpb25JZFxuICogQHBhcmFtIHNlbW90dXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFByb3BDaGFuZ2VHcm91cChzdWJzY3JpcHRpb25JZCwgc2Vtb3R1czogU2Vtb3R1cyk6IENoYW5nZUdyb3VwIHtcbiAgICByZXR1cm4gZ2V0KENoYW5nZSwgc3Vic2NyaXB0aW9uSWQsIHNlbW90dXMpIGFzIENoYW5nZUdyb3VwO1xufVxuXG4vKipcbiAqIEdldHMgQXJyYXkgQ2hhbmdlIEdyb3Vwc1xuICpcbiAqIEBwYXJhbSB0eXBlXG4gKiBAcGFyYW0gc3Vic2NyaXB0aW9uSWRcbiAqIEBwYXJhbSBzZW1vdHVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRBcnJheUNoYW5nZUdyb3VwKHR5cGU6IEFycmF5VHlwZXMsIHN1YnNjcmlwdGlvbklkLCBzZW1vdHVzOiBTZW1vdHVzKTogQXJyYXlHcm91cCB7XG4gICAgcmV0dXJuIGdldCh0eXBlLCBzdWJzY3JpcHRpb25JZCwgc2Vtb3R1cykgYXMgQXJyYXlHcm91cDtcbn1cblxuXG4vKipcbiAqIFJlbW92ZSBhIGNoYW5nZSBncm91cCBmcm9tIGEgc3Vic2NyaXB0aW9uXG4gKlxuICogQHBhcmFtIHR5cGVcbiAqIEBwYXJhbSBzdWJzY3JpcHRpb25JZCB1bmtub3duXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICovXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlKHR5cGU6IHN0cmluZywgc3Vic2NyaXB0aW9uSWQsIHNlbW90dXM6IFNlbW90dXMpIHtcbiAgICBTdWJzY3JpcHRpb25zLmdldFN1YnNjcmlwdGlvbihzZW1vdHVzLCBzdWJzY3JpcHRpb25JZCkubG9nW3R5cGVdID0ge307XG59XG5cblxuLyoqXG4gKiBSZW1vdmUgYWxsIGNoYW5nZSBncm91cHMgZnJvbSBhIHN1YnNjcmlwdGlvbiB3aXRoIGdpdmVuIHR5cGVcbiAqIEBwYXJhbSB0eXBlXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICpcbiAqIEBwcml2YXRlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW1vdmVBbGwodHlwZTogc3RyaW5nLCBzZW1vdHVzOiBTZW1vdHVzKSB7XG4gICAgZm9yIChjb25zdCBzdWJzY3JpcHRpb24gaW4gU3Vic2NyaXB0aW9ucy5nZXRTdWJzY3JpcHRpb25zKHNlbW90dXMpKSB7XG4gICAgICAgIHJlbW92ZSh0eXBlLCBzdWJzY3JpcHRpb24sIHNlbW90dXMpO1xuICAgIH1cbn0iXX0= |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.logChanges = exports.clearClientSession = exports.generate = exports.manage = exports.create = exports.accept = exports.doNotAccept = exports.doNotChange = exports.objectOnServerOnly = exports.objectOnClientOnly = exports.isIsolatedObject = void 0; | ||
var Sessions = require("./Sessions"); | ||
const Sessions = require("./Sessions"); | ||
/** | ||
@@ -66,4 +66,4 @@ * @TODO: Fill out with array change functions, etc. | ||
function filterSyncStates(semotusClass, semotus) { | ||
var _a = semotus.controller.syncState, scope = _a.scope, state = _a.state; | ||
var syncStates = semotusClass.syncStates; | ||
const { scope, state } = semotus.controller.syncState; | ||
const syncStates = semotusClass.syncStates; | ||
if (semotus.controller.__template__ === semotusClass) { // Don't filter out the controller | ||
@@ -184,4 +184,4 @@ return false; | ||
function manage(defineProperty) { | ||
var isLocal = defineProperty.isLocal === true; | ||
var isLocalAlt = defineProperty.toServer === false && defineProperty.toClient === false; | ||
const isLocal = defineProperty.isLocal === true; | ||
const isLocalAlt = defineProperty.toServer === false && defineProperty.toClient === false; | ||
return !(isLocal || isLocalAlt); | ||
@@ -196,4 +196,4 @@ } | ||
function generate(semotus) { | ||
var session = Sessions.get(semotus); | ||
for (var obj in session.objects) { | ||
const session = Sessions.get(semotus); | ||
for (const obj in session.objects) { | ||
logChanges(session.objects[obj], semotus); | ||
@@ -207,4 +207,4 @@ } | ||
function clearClientSession(semotus, controller) { | ||
var session = Sessions.get(semotus); | ||
for (var obj in session.objects) { | ||
const session = Sessions.get(semotus); | ||
for (const obj in session.objects) { | ||
if (obj !== controller.__id__) { | ||
@@ -231,11 +231,11 @@ delete session.objects[obj]; | ||
// Go through all the properties and transfer them to newly created object | ||
var props = obj.__template__.getProperties(); | ||
for (var prop in props) { | ||
var defineProperty = props[prop]; | ||
var type = defineProperty.type; | ||
const props = obj.__template__.getProperties(); | ||
for (const prop in props) { | ||
const defineProperty = props[prop]; | ||
const type = defineProperty.type; | ||
if (type && manage(defineProperty)) { | ||
var createChanges = create(defineProperty, obj.__template__, semotus); | ||
const createChanges = create(defineProperty, obj.__template__, semotus); | ||
if (type == Array) { | ||
if (createChanges) { | ||
if (obj["__" + prop] && !obj[prop]) { | ||
if (obj[`__${prop}`] && !obj[prop]) { | ||
// switch to null treated like a property change | ||
@@ -246,3 +246,3 @@ semotus._changedValue(obj, prop, obj[prop]); | ||
// switch from null like an array ref where array will be created | ||
if (!obj["__" + prop]) { | ||
if (!obj[`__${prop}`]) { | ||
if (obj[prop].length == 0) { | ||
@@ -252,5 +252,5 @@ // switch to empty array | ||
} | ||
obj["__" + prop] = []; // Start from scratch | ||
obj[`__${prop}`] = []; // Start from scratch | ||
} | ||
semotus._referencedArray(obj, prop, obj["__" + prop]); | ||
semotus._referencedArray(obj, prop, obj[`__${prop}`]); | ||
} | ||
@@ -260,8 +260,8 @@ } | ||
else { | ||
var currValue = semotus._convertValue(obj[prop]); | ||
var prevValue = semotus._convertValue(obj["__" + prop]); | ||
const currValue = semotus._convertValue(obj[prop]); | ||
const prevValue = semotus._convertValue(obj[`__${prop}`]); | ||
if (createChanges && currValue !== prevValue) { | ||
semotus._changedValue(obj, prop, obj[prop]); | ||
} | ||
obj["__" + prop] = obj[prop]; | ||
obj[`__${prop}`] = obj[prop]; | ||
} | ||
@@ -272,2 +272,2 @@ } | ||
exports.logChanges = logChanges; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Changes.js","sourceRoot":"","sources":["../../src/helpers/Changes.ts"],"names":[],"mappings":"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","sourcesContent":["import {RemoteableClass, Semotus} from './Types';\nimport * as Sessions from './Sessions';\n\n/**\n * @TODO: Fill out with array change functions, etc.\n */\n\n/**************************** Change Management Functions **********************************/\n\nfunction controllerHasSyncState(semotus: Semotus): boolean {\n    return !!(semotus.role === 'server' && semotus.controller && semotus.controller.syncState);\n}\n\nexport function isIsolatedObject(semotus: Semotus, obj): boolean {\n    if (objectOnClientOnly(semotus, obj)) {\n        return true;\n    }\n    else if (objectOnServerOnly(semotus, obj)) {\n        return true;\n    }\n    else if (obj.__template__.syncStates && controllerHasSyncState(semotus)) {\n        return filterSyncStates(obj.__template__, semotus);\n    }\n    else {\n        return false;\n    }\n}\n\nexport function objectOnClientOnly(semotus: Semotus, obj) {\n    return semotus.role == 'client' && obj.__template__.__toServer__ === false;\n}\n\nexport function objectOnServerOnly(semotus: Semotus, obj) {\n    return semotus.role == 'server' && obj.__template__.__toClient__ === false;\n}\n\n\n/**\n * Helper method to check if the specified state exists in this array of syncStates\n * @param state\n * @param syncStates\n * @param scope\n */\nfunction hasState(state: string | undefined, syncStates: Array<string>, scope: '+' | '-') {\n    // If the state is empty string, null, or undefined, will sync only semotusClass without syncStates, if state exists, will filter out all that do not have that state in their syncStates\n    if (!state) {\n        return syncStates.length === 0; // IF array is empty, THEN default state exists in array. ELSE IF array has any values, returns false\n    }\n    else {\n        if (syncStates.length === 0 && scope === '+') {\n            return true; // Return true on empty syncStates array, only if scope is INCLUSIVE\n        }\n        else {\n            return syncStates.includes(state); // IF has state AND does not match array indexes, THEN state does NOT exist\n        }\n    }\n}\n\n/**\n * Returns true if we should filter this property OUT\n * Returns false if we should not filter this property out, and actually accept and change properties on this ref\n *    Scope values:\n *    If '*': Everything gets sent (No explicit check for this, just checks for - and +)\n *    If '-': Exclusive to syncStates\n *    If '+': Inclusive of [default_set, syncState]\n * @param semotusClass\n * @param semotus\n */\nfunction filterSyncStates(semotusClass: RemoteableClass, semotus: Semotus): boolean {\n    const {scope, state} = semotus.controller.syncState;\n    const syncStates: Array<string> = semotusClass.syncStates;\n\n    if (semotus.controller.__template__ === semotusClass) { // Don't filter out the controller\n        return false;\n    }\n\n    if (scope === '-' || scope === '+') {\n        return !hasState(state, syncStates, scope);\n    }\n    else {  // scope is default '*', or anything not - or +\n        return false; // Do not filter this semotusClass, do not bother checking syncState\n    }\n}\n\n/**\n * Helper function to determine if we should NOT create changes for the property this defineProperty metadata is associated with\n *\n * No need to check syncStates here since this is only called when\n * 1) Reading the static typescript\n * 2) On the client side\n *\n * @param defineProperty\n * @param semotusClass\n * @param semotus\n */\nexport function doNotChange(defineProperty, semotusClass:  RemoteableClass | undefined, semotus: Semotus) {\n    if (defineProperty.isLocal) { // If we've defined the property as local to where it's created / modified\n        return true;\n    }\n    else if (defineProperty.toServer === false && semotus.role === 'client') {\n        return true; // If we're trying to send property to the server from client, when prop's toServer == false;\n    }\n    else if (defineProperty.toClient === false && semotus.role === 'server') {\n        return true; // If we're trying to send property to the client from server, when prop's toClient == false;\n    }\n    else if (semotusClass) { // Dealing with an actual semotus class\n        if (semotusClass.__toServer__ === false && semotus.role == 'client') {\n            return true; // If we're trying to send property to the server from client, when the whole semotusClass has toServer == false;\n        }\n        else if (semotusClass.__toClient__ === false && semotus.role === 'server') {\n            return true; // If we're trying to send property to the client from server, when the whole semotusClass has toClient == false;\n        }\n    }\n\n    return false;\n}\n\n\n/**\n * Helper function to determine if we should not accept changes for the property this defineProperty metadata is associated with\n *\n *\n * @param defineProperty\n * @param semotusClass\n * @param semotus\n */\nexport function doNotAccept(defineProperty, semotusClass: RemoteableClass, semotus: Semotus) {\n    if (defineProperty.isLocal) { // If we've defined the property as local to where it's created / modified\n        return true;\n    }\n    else if (defineProperty.toServer === false && semotus.role === 'server') {\n        return true; // If we're trying to accept changes where toServer == false, but we're on the server\n    }\n    else if (defineProperty.toClient === false && semotus.role === 'client') {\n        return true; // If we're trying to accept changes where toClient is false, but we're on the client\n    }\n    else if (semotusClass.__toServer__ === false && semotus.role == 'server') {\n        return true; // If we're trying to accept changes where semotusClass's toServer == false, but we're on the server\n    }\n    else if (semotusClass.__toClient__ === false && semotus.role === 'client') {\n        return true; // If we're trying to accept changes where semotusClass's toClient is false, but we're on the client\n    }\n    else if (controllerHasSyncState(semotus)) { // We've set the syncState property on the controller, and we have a semotusClass\n        return filterSyncStates(semotusClass, semotus);\n    }\n\n    return false;\n}\n\n/**\n * Determine whether changes should be accepted for a property\n *\n * @param defineProperty unknown\n * @param semotusClass unknown\n * @param semotus\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\nexport function accept(defineProperty, semotusClass: RemoteableClass, semotus: Semotus) {\n    return !(doNotAccept(defineProperty, semotusClass, semotus));\n}\n\n\n/**\n * Determine whether changes need to be created for a property\n *\n * @param defineProperty unknown\n * @param semotusClass unknown\n * @param semotus\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\n\nexport function create(defineProperty, semotusClass: RemoteableClass | undefined, semotus: Semotus) {\n    return !(doNotChange(defineProperty, semotusClass, semotus));\n}\n\n/**\n * Determine whether any tracking of old values is needed\n *\n *\n * For a specific property if isLocal is true, it means that the property will never be synced over the wire\n * If toServer === false AND toClient === false, it is another indicator that this property will never be synced over the wire\n * @param defineProperty unknown\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\nexport function manage(defineProperty) {\n    const isLocal = defineProperty.isLocal === true;\n    const isLocalAlt = defineProperty.toServer === false && defineProperty.toClient === false;\n    return !(isLocal || isLocalAlt);\n}\n\n\n/**\n * Register some of the new property changes / creations to a log\n *\n * @param semotus\n */\nexport function generate(semotus: Semotus) {\n    const session = Sessions.get(semotus);\n\n    for (const obj in session.objects) {\n        logChanges(session.objects[obj], semotus);\n    }\n}\n\n/**\n * Delete session objects for tests, because unit tests for client object erroneously have server session objects\n */\nexport function clearClientSession(semotus: Semotus, controller) {\n    const session = Sessions.get(semotus);\n\n    for (const obj in session.objects) {\n        if (obj !== controller.__id__) {\n            delete session.objects[obj];\n        }\n    }\n}\n\n/**\n * Simulate getters and setters by tracking the old value and if it\n * has changed, creating a change log.  local properties are ignored\n * and properties not to be transmitted to the other party do not\n * generate changes but still track the old value so that changes\n * can be applied from the other party\n *\n * @param {unknown} obj - object to be processed\n * @param semotus\n *\n * @private\n * ONLY CALLED FROM CLIENT\n */\nexport function logChanges(obj, semotus: Semotus) {\n    // Go through all the properties and transfer them to newly created object\n    const props = obj.__template__.getProperties();\n\n    for (const prop in props) {\n        const defineProperty = props[prop];\n        const type = defineProperty.type;\n\n        if (type && manage(defineProperty)) {\n            const createChanges = create(defineProperty, obj.__template__, semotus);\n\n            if (type == Array) {\n                if (createChanges) {\n                    if (obj[`__${prop}`] && !obj[prop]) {\n                        // switch to null treated like a property change\n                        semotus._changedValue(obj, prop, obj[prop]);\n                    } else if (obj[prop]) {\n                        // switch from null like an array ref where array will be created\n                        if (!obj[`__${prop}`]) {\n                            if (obj[prop].length == 0) {\n                                // switch to empty array\n                                semotus._changedValue(obj, prop, obj[prop]);\n                            }\n\n                            obj[`__${prop}`] = []; // Start from scratch\n                        }\n\n                        semotus._referencedArray(obj, prop, obj[`__${prop}`]);\n                    }\n                }\n            } else {\n                const currValue = semotus._convertValue(obj[prop]);\n                const prevValue = semotus._convertValue(obj[`__${prop}`]);\n\n                if (createChanges && currValue !== prevValue) {\n                    semotus._changedValue(obj, prop, obj[prop]);\n                }\n\n                obj[`__${prop}`] = obj[prop];\n            }\n        }\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Changes.js","sourceRoot":"","sources":["../../src/helpers/Changes.ts"],"names":[],"mappings":"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","sourcesContent":["import {RemoteableClass, Semotus} from './Types';\nimport * as Sessions from './Sessions';\n\n/**\n * @TODO: Fill out with array change functions, etc.\n */\n\n/**************************** Change Management Functions **********************************/\n\nfunction controllerHasSyncState(semotus: Semotus): boolean {\n    return !!(semotus.role === 'server' && semotus.controller && semotus.controller.syncState);\n}\n\nexport function isIsolatedObject(semotus: Semotus, obj): boolean {\n    if (objectOnClientOnly(semotus, obj)) {\n        return true;\n    }\n    else if (objectOnServerOnly(semotus, obj)) {\n        return true;\n    }\n    else if (obj.__template__.syncStates && controllerHasSyncState(semotus)) {\n        return filterSyncStates(obj.__template__, semotus);\n    }\n    else {\n        return false;\n    }\n}\n\nexport function objectOnClientOnly(semotus: Semotus, obj) {\n    return semotus.role == 'client' && obj.__template__.__toServer__ === false;\n}\n\nexport function objectOnServerOnly(semotus: Semotus, obj) {\n    return semotus.role == 'server' && obj.__template__.__toClient__ === false;\n}\n\n\n/**\n * Helper method to check if the specified state exists in this array of syncStates\n * @param state\n * @param syncStates\n * @param scope\n */\nfunction hasState(state: string | undefined, syncStates: Array<string>, scope: '+' | '-') {\n    // If the state is empty string, null, or undefined, will sync only semotusClass without syncStates, if state exists, will filter out all that do not have that state in their syncStates\n    if (!state) {\n        return syncStates.length === 0; // IF array is empty, THEN default state exists in array. ELSE IF array has any values, returns false\n    }\n    else {\n        if (syncStates.length === 0 && scope === '+') {\n            return true; // Return true on empty syncStates array, only if scope is INCLUSIVE\n        }\n        else {\n            return syncStates.includes(state); // IF has state AND does not match array indexes, THEN state does NOT exist\n        }\n    }\n}\n\n/**\n * Returns true if we should filter this property OUT\n * Returns false if we should not filter this property out, and actually accept and change properties on this ref\n *    Scope values:\n *    If '*': Everything gets sent (No explicit check for this, just checks for - and +)\n *    If '-': Exclusive to syncStates\n *    If '+': Inclusive of [default_set, syncState]\n * @param semotusClass\n * @param semotus\n */\nfunction filterSyncStates(semotusClass: RemoteableClass, semotus: Semotus): boolean {\n    const {scope, state} = semotus.controller.syncState;\n    const syncStates: Array<string> = semotusClass.syncStates;\n\n    if (semotus.controller.__template__ === semotusClass) { // Don't filter out the controller\n        return false;\n    }\n\n    if (scope === '-' || scope === '+') {\n        return !hasState(state, syncStates, scope);\n    }\n    else {  // scope is default '*', or anything not - or +\n        return false; // Do not filter this semotusClass, do not bother checking syncState\n    }\n}\n\n/**\n * Helper function to determine if we should NOT create changes for the property this defineProperty metadata is associated with\n *\n * No need to check syncStates here since this is only called when\n * 1) Reading the static typescript\n * 2) On the client side\n *\n * @param defineProperty\n * @param semotusClass\n * @param semotus\n */\nexport function doNotChange(defineProperty, semotusClass:  RemoteableClass | undefined, semotus: Semotus) {\n    if (defineProperty.isLocal) { // If we've defined the property as local to where it's created / modified\n        return true;\n    }\n    else if (defineProperty.toServer === false && semotus.role === 'client') {\n        return true; // If we're trying to send property to the server from client, when prop's toServer == false;\n    }\n    else if (defineProperty.toClient === false && semotus.role === 'server') {\n        return true; // If we're trying to send property to the client from server, when prop's toClient == false;\n    }\n    else if (semotusClass) { // Dealing with an actual semotus class\n        if (semotusClass.__toServer__ === false && semotus.role == 'client') {\n            return true; // If we're trying to send property to the server from client, when the whole semotusClass has toServer == false;\n        }\n        else if (semotusClass.__toClient__ === false && semotus.role === 'server') {\n            return true; // If we're trying to send property to the client from server, when the whole semotusClass has toClient == false;\n        }\n    }\n\n    return false;\n}\n\n\n/**\n * Helper function to determine if we should not accept changes for the property this defineProperty metadata is associated with\n *\n *\n * @param defineProperty\n * @param semotusClass\n * @param semotus\n */\nexport function doNotAccept(defineProperty, semotusClass: RemoteableClass, semotus: Semotus) {\n    if (defineProperty.isLocal) { // If we've defined the property as local to where it's created / modified\n        return true;\n    }\n    else if (defineProperty.toServer === false && semotus.role === 'server') {\n        return true; // If we're trying to accept changes where toServer == false, but we're on the server\n    }\n    else if (defineProperty.toClient === false && semotus.role === 'client') {\n        return true; // If we're trying to accept changes where toClient is false, but we're on the client\n    }\n    else if (semotusClass.__toServer__ === false && semotus.role == 'server') {\n        return true; // If we're trying to accept changes where semotusClass's toServer == false, but we're on the server\n    }\n    else if (semotusClass.__toClient__ === false && semotus.role === 'client') {\n        return true; // If we're trying to accept changes where semotusClass's toClient is false, but we're on the client\n    }\n    else if (controllerHasSyncState(semotus)) { // We've set the syncState property on the controller, and we have a semotusClass\n        return filterSyncStates(semotusClass, semotus);\n    }\n\n    return false;\n}\n\n/**\n * Determine whether changes should be accepted for a property\n *\n * @param defineProperty unknown\n * @param semotusClass unknown\n * @param semotus\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\nexport function accept(defineProperty, semotusClass: RemoteableClass, semotus: Semotus) {\n    return !(doNotAccept(defineProperty, semotusClass, semotus));\n}\n\n\n/**\n * Determine whether changes need to be created for a property\n *\n * @param defineProperty unknown\n * @param semotusClass unknown\n * @param semotus\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\n\nexport function create(defineProperty, semotusClass: RemoteableClass | undefined, semotus: Semotus) {\n    return !(doNotChange(defineProperty, semotusClass, semotus));\n}\n\n/**\n * Determine whether any tracking of old values is needed\n *\n *\n * For a specific property if isLocal is true, it means that the property will never be synced over the wire\n * If toServer === false AND toClient === false, it is another indicator that this property will never be synced over the wire\n * @param defineProperty unknown\n *\n * @returns {Boolean} unknown\n *\n * @private\n */\nexport function manage(defineProperty) {\n    const isLocal = defineProperty.isLocal === true;\n    const isLocalAlt = defineProperty.toServer === false && defineProperty.toClient === false;\n    return !(isLocal || isLocalAlt);\n}\n\n\n/**\n * Register some of the new property changes / creations to a log\n *\n * @param semotus\n */\nexport function generate(semotus: Semotus) {\n    const session = Sessions.get(semotus);\n\n    for (const obj in session.objects) {\n        logChanges(session.objects[obj], semotus);\n    }\n}\n\n/**\n * Delete session objects for tests, because unit tests for client object erroneously have server session objects\n */\nexport function clearClientSession(semotus: Semotus, controller) {\n    const session = Sessions.get(semotus);\n\n    for (const obj in session.objects) {\n        if (obj !== controller.__id__) {\n            delete session.objects[obj];\n        }\n    }\n}\n\n/**\n * Simulate getters and setters by tracking the old value and if it\n * has changed, creating a change log.  local properties are ignored\n * and properties not to be transmitted to the other party do not\n * generate changes but still track the old value so that changes\n * can be applied from the other party\n *\n * @param {unknown} obj - object to be processed\n * @param semotus\n *\n * @private\n * ONLY CALLED FROM CLIENT\n */\nexport function logChanges(obj, semotus: Semotus) {\n    // Go through all the properties and transfer them to newly created object\n    const props = obj.__template__.getProperties();\n\n    for (const prop in props) {\n        const defineProperty = props[prop];\n        const type = defineProperty.type;\n\n        if (type && manage(defineProperty)) {\n            const createChanges = create(defineProperty, obj.__template__, semotus);\n\n            if (type == Array) {\n                if (createChanges) {\n                    if (obj[`__${prop}`] && !obj[prop]) {\n                        // switch to null treated like a property change\n                        semotus._changedValue(obj, prop, obj[prop]);\n                    } else if (obj[prop]) {\n                        // switch from null like an array ref where array will be created\n                        if (!obj[`__${prop}`]) {\n                            if (obj[prop].length == 0) {\n                                // switch to empty array\n                                semotus._changedValue(obj, prop, obj[prop]);\n                            }\n\n                            obj[`__${prop}`] = []; // Start from scratch\n                        }\n\n                        semotus._referencedArray(obj, prop, obj[`__${prop}`]);\n                    }\n                }\n            } else {\n                const currValue = semotus._convertValue(obj[prop]);\n                const prevValue = semotus._convertValue(obj[`__${prop}`]);\n\n                if (createChanges && currValue !== prevValue) {\n                    semotus._changedValue(obj, prop, obj[prop]);\n                }\n\n                obj[`__${prop}`] = obj[prop];\n            }\n        }\n    }\n}\n"]} |
"use strict"; | ||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
}; | ||
var __generator = (this && this.__generator) || function (thisArg, body) { | ||
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) throw new TypeError("Generator is already executing."); | ||
while (_) try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; | ||
if (y = 0, t) op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: case 1: t = op; break; | ||
case 4: _.label++; return { value: op[1], done: false }; | ||
case 5: _.label++; y = op[1]; op = [0]; continue; | ||
case 7: op = _.ops.pop(); _.trys.pop(); continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } | ||
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } | ||
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } | ||
if (t[2]) _.ops.pop(); | ||
_.trys.pop(); continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } | ||
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.postCallErrorLog = exports.processCall = void 0; | ||
var Utilities_1 = require("./Utilities"); | ||
const Utilities_1 = require("./Utilities"); | ||
/** | ||
@@ -53,41 +17,15 @@ * We process the call the remote method in stages starting by letting the controller examine the | ||
*/ | ||
function processCall(payload, forceupdate) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var validation, result, err_1; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
_a.trys.push([0, 8, , 10]); | ||
return [4 /*yield*/, Promise.resolve(forceupdate)]; | ||
case 1: | ||
forceupdate = _a.sent(); | ||
return [4 /*yield*/, preCallHook(payload, forceupdate)]; | ||
case 2: | ||
_a.sent(); | ||
return [4 /*yield*/, applyChangesAndValidateCall(payload)]; | ||
case 3: | ||
validation = _a.sent(); | ||
return [4 /*yield*/, customValidation(payload, validation)]; | ||
case 4: | ||
validation = _a.sent(); | ||
return [4 /*yield*/, callIfValid(payload, validation)]; | ||
case 5: | ||
result = _a.sent(); | ||
return [4 /*yield*/, postCallHook(payload, result)]; | ||
case 6: | ||
_a.sent(); | ||
return [4 /*yield*/, postCallSuccess(payload, result)]; | ||
case 7: | ||
_a.sent(); | ||
return [3 /*break*/, 10]; | ||
case 8: | ||
err_1 = _a.sent(); | ||
return [4 /*yield*/, postCallFailure(payload, err_1)]; | ||
case 9: | ||
_a.sent(); | ||
return [3 /*break*/, 10]; | ||
case 10: return [2 /*return*/]; | ||
} | ||
}); | ||
}); | ||
async function processCall(payload, forceupdate) { | ||
try { | ||
forceupdate = await Promise.resolve(forceupdate); | ||
await preCallHook(payload, forceupdate); | ||
let validation = await applyChangesAndValidateCall(payload); | ||
validation = await customValidation(payload, validation); | ||
const result = await callIfValid(payload, validation); | ||
await postCallHook(payload, result); | ||
await postCallSuccess(payload, result); | ||
} | ||
catch (err) { | ||
await postCallFailure(payload, err); | ||
} | ||
} | ||
@@ -100,13 +38,8 @@ exports.processCall = processCall; | ||
*/ | ||
function retryCall(payload) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback; | ||
return __generator(this, function (_a) { | ||
semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback; | ||
if (restoreSessionCallback) { | ||
restoreSessionCallback(); | ||
} | ||
return [2 /*return*/, processCall(payload, true)]; | ||
}); | ||
}); | ||
async function retryCall(payload) { | ||
const { semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback } = payload; | ||
if (restoreSessionCallback) { | ||
restoreSessionCallback(); | ||
} | ||
return processCall(payload, true); | ||
} | ||
@@ -121,8 +54,31 @@ /** | ||
*/ | ||
function preCallHook(payload, forceupdate) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var semotus, remoteCall, session, callContext, HTTPObjs, changes, objId, remoteObject, remoteTemplate, isPublic; | ||
return __generator(this, function (_a) { | ||
semotus = payload.semotus, remoteCall = payload.remoteCall, session = payload.session, callContext = payload.callContext, HTTPObjs = payload.HTTPObjs; | ||
semotus.logger.info({ | ||
async function preCallHook(payload, forceupdate) { | ||
const { semotus, remoteCall, session, callContext, HTTPObjs } = payload; | ||
semotus.logger.info({ | ||
component: 'semotus', | ||
module: 'processCall', | ||
activity: 'preServerCall', | ||
data: { | ||
call: remoteCall.name, | ||
sequence: remoteCall.sequence | ||
} | ||
}, remoteCall.name); | ||
if (semotus.controller && semotus.controller.preServerCall) { | ||
let changes = {}; | ||
for (var objId in JSON.parse(remoteCall.changes)) { | ||
changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true; | ||
} | ||
let remoteObject = session.objects[remoteCall.id]; | ||
// Need to double check if not in session, what the template is. | ||
let remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')]; | ||
let isPublic = false; | ||
if (remoteObject) { | ||
isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic; | ||
} | ||
else if (remoteTemplate) { | ||
// If the class doesn't exist, we should get the remote function from the prototype | ||
isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic; | ||
} | ||
else { | ||
semotus.logger.error({ | ||
component: 'semotus', | ||
@@ -135,37 +91,9 @@ module: 'processCall', | ||
} | ||
}, remoteCall.name); | ||
if (semotus.controller && semotus.controller.preServerCall) { | ||
changes = {}; | ||
for (objId in JSON.parse(remoteCall.changes)) { | ||
changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true; | ||
} | ||
remoteObject = session.objects[remoteCall.id]; | ||
remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')]; | ||
isPublic = false; | ||
if (remoteObject) { | ||
isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic; | ||
} | ||
else if (remoteTemplate) { | ||
// If the class doesn't exist, we should get the remote function from the prototype | ||
isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic; | ||
} | ||
else { | ||
semotus.logger.error({ | ||
component: 'semotus', | ||
module: 'processCall', | ||
activity: 'preServerCall', | ||
data: { | ||
call: remoteCall.name, | ||
sequence: remoteCall.sequence | ||
} | ||
}, 'Could not find template for ' + objId); | ||
} | ||
return [2 /*return*/, semotus.controller.preServerCall.call(semotus.controller, remoteCall.changes.length > 2, changes, callContext, forceupdate, remoteCall.name, remoteCall, isPublic, HTTPObjs)]; | ||
} | ||
else { | ||
return [2 /*return*/, true]; | ||
} | ||
return [2 /*return*/]; | ||
}); | ||
}); | ||
}, 'Could not find template for ' + objId); | ||
} | ||
return semotus.controller.preServerCall.call(semotus.controller, remoteCall.changes.length > 2, changes, callContext, forceupdate, remoteCall.name, remoteCall, isPublic, HTTPObjs); | ||
} | ||
else { | ||
return true; | ||
} | ||
} | ||
@@ -178,3 +106,3 @@ /** | ||
function applyChangesAndValidateCall(payload) { | ||
var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback; | ||
const { semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback } = payload; | ||
semotus.logger.info({ | ||
@@ -190,8 +118,8 @@ component: 'semotus', | ||
}, remoteCall.name); | ||
var changes = JSON.parse(remoteCall.changes); | ||
var res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext); | ||
let changes = JSON.parse(remoteCall.changes); | ||
const res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext); | ||
if (res) { | ||
var obj = session.objects[remoteCall.id]; | ||
const obj = session.objects[remoteCall.id]; | ||
if (!obj) { | ||
throw new Error("Cannot find object for remote call " + remoteCall.id); | ||
throw new Error(`Cannot find object for remote call ${remoteCall.id}`); | ||
} | ||
@@ -221,4 +149,4 @@ // check to see if this function is supposed to be called directly from client | ||
function customValidation(payload, isValid) { | ||
var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback; | ||
var loggerObject = { | ||
const { semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback } = payload; | ||
let loggerObject = { | ||
component: 'semotus', | ||
@@ -233,3 +161,3 @@ module: 'processCall', | ||
}; | ||
var remoteObject = session.objects[remoteCall.id]; | ||
let remoteObject = session.objects[remoteCall.id]; | ||
semotus.logger.info(loggerObject, remoteCall.name); | ||
@@ -240,3 +168,3 @@ if (!isValid) { | ||
else if (semotus.role === 'server' && remoteObject[remoteCall.name].serverValidation) { | ||
var args = semotus._extractArguments(remoteCall); | ||
let args = semotus._extractArguments(remoteCall); | ||
args.unshift(remoteObject); | ||
@@ -260,29 +188,24 @@ return remoteObject[remoteCall.name].serverValidation.apply(null, args); | ||
*/ | ||
function callIfValid(payload, isValid) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback, loggerObject, obj, args; | ||
return __generator(this, function (_a) { | ||
semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback; | ||
loggerObject = { | ||
component: 'semotus', | ||
module: 'processCall', | ||
activity: 'callIfValid', | ||
data: { | ||
call: remoteCall.name, | ||
sequence: remoteCall.sequence, | ||
remoteCallId: remoteCall.id | ||
} | ||
}; | ||
semotus.logger.info(loggerObject, remoteCall.name); | ||
obj = session.objects[remoteCall.id]; | ||
if (!obj[remoteCall.name]) { | ||
throw new Error(remoteCall.name + ' function does not exist.'); | ||
} | ||
if (!isValid && remoteCall && remoteCall.name) { | ||
throw new Error(remoteCall.name + ' refused'); | ||
} | ||
args = semotus._extractArguments(remoteCall); | ||
return [2 /*return*/, obj[remoteCall.name].apply(obj, args)]; | ||
}); | ||
}); | ||
async function callIfValid(payload, isValid) { | ||
const { semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback } = payload; | ||
let loggerObject = { | ||
component: 'semotus', | ||
module: 'processCall', | ||
activity: 'callIfValid', | ||
data: { | ||
call: remoteCall.name, | ||
sequence: remoteCall.sequence, | ||
remoteCallId: remoteCall.id | ||
} | ||
}; | ||
semotus.logger.info(loggerObject, remoteCall.name); | ||
let obj = session.objects[remoteCall.id]; | ||
if (!obj[remoteCall.name]) { | ||
throw new Error(remoteCall.name + ' function does not exist.'); | ||
} | ||
if (!isValid && remoteCall && remoteCall.name) { | ||
throw new Error(remoteCall.name + ' refused'); | ||
} | ||
let args = semotus._extractArguments(remoteCall); | ||
return obj[remoteCall.name].apply(obj, args); | ||
} | ||
@@ -297,19 +220,9 @@ /** | ||
*/ | ||
function postCallHook(payload, returnValue) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var semotus, remoteCall, callContext, HTTPObjs, hasChanges; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, HTTPObjs = payload.HTTPObjs; | ||
if (!(semotus.controller && semotus.controller.postServerCall)) return [3 /*break*/, 2]; | ||
hasChanges = remoteCall.changes.length > 2; | ||
return [4 /*yield*/, semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs)]; | ||
case 1: | ||
_a.sent(); | ||
_a.label = 2; | ||
case 2: return [2 /*return*/, returnValue]; | ||
} | ||
}); | ||
}); | ||
async function postCallHook(payload, returnValue) { | ||
const { semotus, remoteCall, callContext, HTTPObjs } = payload; | ||
if (semotus.controller && semotus.controller.postServerCall) { | ||
const hasChanges = remoteCall.changes.length > 2; | ||
await semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs); | ||
} | ||
return returnValue; | ||
} | ||
@@ -326,3 +239,3 @@ /** | ||
function postCallSuccess(payload, ret) { | ||
var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, remoteCallId = payload.remoteCallId; | ||
const { semotus, remoteCall, callContext, session, remoteCallId } = payload; | ||
semotus.logger.info({ | ||
@@ -358,46 +271,33 @@ component: 'semotus', | ||
*/ | ||
function resolveErrorHandler(logger, controller, type, remoteCall, remoteCallId, callContext, changeString, session) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var errorType, functionName, obj, logBody, error_1; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!(controller && controller.postServerErrorHandler)) return [3 /*break*/, 4]; | ||
errorType = type; | ||
functionName = remoteCall.name; | ||
obj = undefined; | ||
if (session.objects[remoteCall.id]) { | ||
obj = session.objects[remoteCall.id]; | ||
} | ||
logBody = { | ||
component: 'semotus', | ||
module: 'processCall.failure', | ||
activity: 'postCall.resolveErrorHandler', | ||
data: { | ||
call: remoteCall.name, | ||
message: undefined | ||
} | ||
}; | ||
_a.label = 1; | ||
case 1: | ||
_a.trys.push([1, 3, , 4]); | ||
return [4 /*yield*/, controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString)]; | ||
case 2: | ||
_a.sent(); | ||
return [3 /*break*/, 4]; | ||
case 3: | ||
error_1 = _a.sent(); | ||
if (error_1.message) { | ||
logBody.data.message = error_1.message; | ||
logger.error(error_1.message); | ||
} | ||
else { | ||
logBody.data.message = JSON.stringify(error_1); | ||
} | ||
logger.error(logBody, 'User defined postServerErrorHandler threw an error'); | ||
return [3 /*break*/, 4]; | ||
case 4: return [2 /*return*/]; | ||
async function resolveErrorHandler(logger, controller, type, remoteCall, remoteCallId, callContext, changeString, session) { | ||
if (controller && controller.postServerErrorHandler) { | ||
let errorType = type; | ||
let functionName = remoteCall.name; | ||
let obj = undefined; | ||
if (session.objects[remoteCall.id]) { | ||
obj = session.objects[remoteCall.id]; | ||
} | ||
let logBody = { | ||
component: 'semotus', | ||
module: 'processCall.failure', | ||
activity: 'postCall.resolveErrorHandler', | ||
data: { | ||
call: remoteCall.name, | ||
message: undefined | ||
} | ||
}); | ||
}); | ||
}; | ||
try { | ||
await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString); | ||
} | ||
catch (error) { | ||
if (error.message) { | ||
logBody.data.message = error.message; | ||
logger.error(error.message); | ||
} | ||
else { | ||
logBody.data.message = JSON.stringify(error); | ||
} | ||
logger.error(logBody, 'User defined postServerErrorHandler threw an error'); | ||
} | ||
} | ||
} | ||
@@ -415,74 +315,65 @@ /** | ||
*/ | ||
function postCallFailure(payload, err) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback, logString, packageChangesPayload, updateConflictRetry; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback; | ||
logString = ''; | ||
packageChangesPayload = {}; | ||
updateConflictRetry = false; | ||
if (err === 'Sync Error') { | ||
postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext); | ||
packageChangesPayload = { | ||
type: 'response', | ||
sync: false, | ||
changes: '' | ||
}; | ||
} | ||
else if (err.message == 'Update Conflict') { | ||
// Not this may be caught in the transport (e.g. Amorphic) and retried) | ||
// increment callContext.retries after checking if < 3. Should retry 3 times. | ||
if (callContext.retries++ < 3) { | ||
postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext); | ||
updateConflictRetry = true; | ||
// The following assignment is only used for the error handler | ||
packageChangesPayload = { | ||
type: 'retry' | ||
}; | ||
} | ||
else { | ||
postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext); | ||
packageChangesPayload = { | ||
type: 'retry', | ||
sync: false | ||
}; | ||
} | ||
} | ||
else { | ||
if (!(err instanceof Error)) { | ||
postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext); | ||
} | ||
else { | ||
if (err.stack) { | ||
logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack); | ||
} | ||
else { | ||
logString = 'Exception in ' + remoteCall.name + ' - ' + err.message; | ||
} | ||
postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext); | ||
} | ||
packageChangesPayload = { | ||
type: 'error', | ||
sync: true, | ||
value: Utilities_1.getError(err), | ||
name: remoteCall.name | ||
}; | ||
} | ||
Object.assign(packageChangesPayload, { remoteCallId: remoteCallId }); | ||
return [4 /*yield*/, resolveErrorHandler(semotus.logger, semotus.controller, | ||
// @ts-ignore | ||
packageChangesPayload.type, remoteCall, remoteCallId, callContext, semotus.changeString, session)]; | ||
case 1: | ||
_a.sent(); | ||
if (!updateConflictRetry) return [3 /*break*/, 3]; | ||
return [4 /*yield*/, Utilities_1.delay(callContext.retries * 1000)]; | ||
case 2: | ||
_a.sent(); | ||
return [2 /*return*/, retryCall(payload)]; | ||
case 3: return [2 /*return*/, packageChanges(semotus, session, packageChangesPayload)]; | ||
async function postCallFailure(payload, err) { | ||
const { semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback } = payload; | ||
let logString = ''; | ||
let packageChangesPayload = {}; | ||
let updateConflictRetry = false; | ||
if (err === 'Sync Error') { | ||
postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext); | ||
packageChangesPayload = { | ||
type: 'response', | ||
sync: false, | ||
changes: '' | ||
}; | ||
} | ||
else if (err.message == 'Update Conflict') { | ||
// Not this may be caught in the transport (e.g. Amorphic) and retried) | ||
// increment callContext.retries after checking if < 3. Should retry 3 times. | ||
if (callContext.retries++ < 3) { | ||
postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext); | ||
updateConflictRetry = true; | ||
// The following assignment is only used for the error handler | ||
packageChangesPayload = { | ||
type: 'retry' | ||
}; | ||
} | ||
else { | ||
postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext); | ||
packageChangesPayload = { | ||
type: 'retry', | ||
sync: false | ||
}; | ||
} | ||
} | ||
else { | ||
if (!(err instanceof Error)) { | ||
postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext); | ||
} | ||
else { | ||
if (err.stack) { | ||
logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack); | ||
} | ||
}); | ||
}); | ||
else { | ||
logString = 'Exception in ' + remoteCall.name + ' - ' + err.message; | ||
} | ||
postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext); | ||
} | ||
packageChangesPayload = { | ||
type: 'error', | ||
sync: true, | ||
value: Utilities_1.getError(err), | ||
name: remoteCall.name | ||
}; | ||
} | ||
Object.assign(packageChangesPayload, { remoteCallId: remoteCallId }); | ||
await resolveErrorHandler(semotus.logger, semotus.controller, | ||
// @ts-ignore | ||
packageChangesPayload.type, remoteCall, remoteCallId, callContext, semotus.changeString, session); | ||
if (updateConflictRetry) { | ||
await Utilities_1.delay(callContext.retries * 1000); | ||
return retryCall(payload); | ||
} | ||
else { | ||
return packageChanges(semotus, session, packageChangesPayload); | ||
} | ||
} | ||
@@ -521,3 +412,3 @@ /** | ||
function postCallErrorLog(logger, activity, message, logType, logString, remoteCall, callContext) { | ||
var logBody = { | ||
let logBody = { | ||
component: 'semotus', | ||
@@ -540,2 +431,2 @@ module: 'processCall.failure', | ||
exports.postCallErrorLog = postCallErrorLog; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ProcessCall.js","sourceRoot":"","sources":["../../src/helpers/ProcessCall.ts"],"names":[],"mappings":"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","sourcesContent":["import {delay, getError, logTime} from './Utilities';\nimport {CallContext, ProcessCallPayload, RemoteCall, Semotus, Session} from './Types';\n\n/**\n * We process the call the remote method in stages starting by letting the controller examine the\n * changes (preCallHook) and giving it a chance to refresh data if it needs to.  Then we apply any\n * changes in the messages and give the object owning the method a chance to validate that the\n * call is valid and take care of any authorization concerns.  Finally we let the controller perform\n * any post-call processing such as commiting data and then we deal with a failure or success.\n *\n * @param payload\n * @param {unknown} forceupdate unknown\n *\n * @returns {unknown} unknown\n */\nexport async function processCall(payload: ProcessCallPayload, forceupdate?: boolean) {\n\n    try {\n        forceupdate = await Promise.resolve(forceupdate);\n        await preCallHook(payload, forceupdate);\n        let validation = await applyChangesAndValidateCall(payload);\n        validation = await customValidation(payload, validation);\n        const result = await callIfValid(payload, validation);\n        await postCallHook(payload, result);\n        await postCallSuccess(payload, result);\n    } catch (err) {\n        await postCallFailure(payload, err);\n    }\n}\n\n\n/**\n * If there is an update conflict we want to retry after restoring the session\n *\n * @returns {*} unknown\n */\nasync function retryCall(payload: ProcessCallPayload) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    if (restoreSessionCallback) {\n        restoreSessionCallback();\n    }\n\n    return processCall(payload, true);\n}\n\n/**\n * Determine what objects changed and pass this to the preServerCall method on the controller\n *\n * @param payload\n * @param  forceupdate unknown\n *\n * @returns  unknown\n */\nasync function preCallHook(payload: ProcessCallPayload, forceupdate?: boolean): Promise<any> {\n    const {semotus, remoteCall, session, callContext, HTTPObjs} = payload;\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'preServerCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    if (semotus.controller && semotus.controller.preServerCall) {\n        let changes = {};\n\n        for (var objId in JSON.parse(remoteCall.changes)) {\n            changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true;\n        }\n\n        let remoteObject = session.objects[remoteCall.id];\n\n        // Need to double check if not in session, what the template is.\n        let remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')];\n        let isPublic = false;\n\n        if (remoteObject) {\n            isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic;\n        }\n        else if (remoteTemplate) {\n            // If the class doesn't exist, we should get the remote function from the prototype\n            isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic;\n        }\n        else {\n            semotus.logger.error({\n                component: 'semotus',\n                module: 'processCall',\n                activity: 'preServerCall',\n                data: {\n                    call: remoteCall.name,\n                    sequence: remoteCall.sequence\n                }\n            }, \t'Could not find template for ' + objId);\n        }\n\n        return semotus.controller.preServerCall.call(\n            semotus.controller,\n            remoteCall.changes.length > 2,\n            changes,\n            callContext,\n            forceupdate,\n            remoteCall.name,\n            remoteCall,\n            isPublic,\n            HTTPObjs\n        );\n    } else {\n        return true;\n    }\n}\n\n/**\n * Apply changes in the message and then validate the call.  Throw \"Sync Error\" if changes can't be applied\n *\n * @returns {unknown} unknown\n */\nfunction applyChangesAndValidateCall(payload: ProcessCallPayload): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'applyChangesAndValidateCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence,\n                remoteCallId: remoteCall.id\n            }\n        },\n        remoteCall.name\n    );\n\n    let changes = JSON.parse(remoteCall.changes);\n\n    const res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext);\n    if (res) {\n        const obj = session.objects[remoteCall.id];\n\n        if (!obj) {\n            throw new Error(`Cannot find object for remote call ${remoteCall.id}`);\n        }\n\n        // check to see if this function is supposed to be called directly from client\n        if (obj.__proto__[remoteCall.name].__on__ !== 'server') {\n            throw 'Invalid Function Call; not an API function';\n        }\n\n        if (semotus.role === 'server' && obj.validateServerCall) {\n            return obj.validateServerCall.call(obj, remoteCall.name, callContext);\n        }\n\n        return true;\n    } else {\n        throw 'Sync Error';\n    }\n}\n\n/**\n * Apply function specific custom serverSide validation functions\n *\n * @param semotus\n * @param {boolean} isValid - Result of previous validation step (applyChangesAndValidateCall)\n * @param session\n * @param remoteCall\n * @returns {boolean} True if passed function\n */\nfunction customValidation(payload: ProcessCallPayload, isValid: boolean): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'customValidation',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    let remoteObject = session.objects[remoteCall.id];\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    if (!isValid) {\n        return false;\n    } else if (semotus.role === 'server' && remoteObject[remoteCall.name].serverValidation) {\n        let args = semotus._extractArguments(remoteCall);\n        args.unshift(remoteObject);\n\n        return remoteObject[remoteCall.name].serverValidation.apply(null, args);\n    } else {\n        return true;\n    }\n}\n\n/**\n * If the changes could be applied and the validation was successful call the method\n *\n * @param semotus\n * @param {boolean} isValid - takes a flag if the call is valid or not, if it is then we proceed normally,\n * otherwise, we throw an error and stop execution\n *\n * @param session\n * @param remoteCall\n * @returns {unknown} unknown\n */\nasync function callIfValid(payload: ProcessCallPayload, isValid: boolean) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'callIfValid',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    let obj = session.objects[remoteCall.id];\n\n    if (!obj[remoteCall.name]) {\n        throw new Error(remoteCall.name + ' function does not exist.');\n    }\n\n    if (!isValid && remoteCall && remoteCall.name) {\n        throw new Error(remoteCall.name + ' refused');\n    }\n\n    let args = semotus._extractArguments(remoteCall);\n\n    return obj[remoteCall.name].apply(obj, args);\n}\n\n/**\n * Let the controller know that the method was completed and give it a chance to commit changes\n *\n * @param payload\n * @param  returnValue unknown\n *\n * @returns\n */\nasync function postCallHook(payload: ProcessCallPayload, returnValue) {\n    const {semotus, remoteCall, callContext, HTTPObjs} = payload;\n\n    if (semotus.controller && semotus.controller.postServerCall) {\n        const hasChanges: boolean = remoteCall.changes.length > 2;\n        await semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs);\n    }\n    return returnValue;\n}\n\n/**\n * Package up any changes resulting from the execution and send them back in the message, clearing\n * our change queue to accumulate more changes for the next call\n *\n * @param semotus\n * @param remoteCall\n * @param remoteCallId\n * @param {unknown} ret unknown\n */\nfunction postCallSuccess(payload: ProcessCallPayload, ret): void {\n    const {semotus, remoteCall, callContext, session, remoteCallId} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'postCall.success',\n            data: {\n                call: remoteCall.name,\n                callTime: logTime(callContext),\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    packageChanges(semotus, session,{\n        type: 'response',\n        sync: true,\n        value: JSON.stringify(semotus._toTransport(ret)),\n        name: remoteCall.name,\n        remoteCallId: remoteCallId\n    });\n}\n\n/**\n * Helper function to identify if there's a postServerErrorHandler callback on the base controller\n * If there is, we execute the handler, and if we catch an error in the handler, we propogate it up to the logger.\n * @param logger\n * @param {*} controller\n * @param type\n * @param remoteCall\n * @param remoteCallId\n * @param callContext\n * @param changeString\n * @param session\n */\nasync function resolveErrorHandler(logger, controller: any, type, remoteCall: RemoteCall, remoteCallId, callContext: CallContext, changeString, session: Session) {\n\n    if (controller && controller.postServerErrorHandler) {\n        let errorType = type;\n        let functionName = remoteCall.name;\n        let obj = undefined;\n        if (session.objects[remoteCall.id]) {\n            obj = session.objects[remoteCall.id];\n        }\n        let logBody = {\n            component: 'semotus',\n            module: 'processCall.failure',\n            activity: 'postCall.resolveErrorHandler',\n            data: {\n                call: remoteCall.name,\n                message: undefined\n            }\n        };\n\n        try {\n            await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString);\n        } catch (error) {\n            if (error.message) {\n                logBody.data.message = error.message;\n                logger.error(error.message);\n            } else {\n                logBody.data.message = JSON.stringify(error);\n            }\n\n            logger.error(logBody, 'User defined postServerErrorHandler threw an error');\n        }\n    }\n}\n\n/**\n * Handle errors by returning an apropriate message.  In all cases changes sent back though they\n *\n * @param semotus\n * @param remoteCall\n * @param callContext\n * @param session\n * @param {unknown} err unknown\n *\n * @returns {unknown} A Promise\n */\nasync function postCallFailure(payload: ProcessCallPayload, err) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let logString = '';\n\n    let packageChangesPayload = {};\n\n    let updateConflictRetry = false;\n\n    if (err === 'Sync Error') {\n        postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext);\n        packageChangesPayload = {\n            type: 'response',\n            sync: false,\n            changes: ''\n        };\n    } else if (err.message == 'Update Conflict') {\n        // Not this may be caught in the transport (e.g. Amorphic) and retried)\n\n        // increment callContext.retries after checking if < 3. Should retry 3 times.\n        if (callContext.retries++ < 3) {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext);\n            updateConflictRetry = true;\n            // The following assignment is only used for the error handler\n            packageChangesPayload = {\n                type: 'retry'\n            };\n        } else {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext);\n            packageChangesPayload = {\n                type: 'retry',\n                sync: false\n            };\n        }\n    } else {\n        if (!(err instanceof Error)) {\n            postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext);\n        } else {\n            if (err.stack) {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack);\n            } else {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message;\n            }\n\n            postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext);\n        }\n\n        packageChangesPayload = {\n            type: 'error',\n            sync: true,\n            value: getError(err),\n            name: remoteCall.name\n        };\n    }\n\n    Object.assign(packageChangesPayload, {remoteCallId: remoteCallId});\n\n    await resolveErrorHandler(\n        semotus.logger,\n        semotus.controller,\n        // @ts-ignore\n        packageChangesPayload.type,\n        remoteCall,\n        remoteCallId,\n        callContext,\n        semotus.changeString,\n        session\n    );\n\n    if (updateConflictRetry) {\n        await delay(callContext.retries * 1000);\n        return retryCall(payload);\n    } else {\n        return packageChanges(semotus, session, packageChangesPayload);\n    }\n}\n\n/**\n * Deal with changes going back to the caller - Actually not Async!\n *\n * @param semotus\n * @param session\n * @param {unknown} message unknown\n */\nfunction packageChanges(semotus: Semotus, session: Session, message) {\n    semotus._convertArrayReferencesToChanges();\n    message.changes = JSON.stringify(semotus.getChanges());\n\n    if (semotus.memSession && semotus.memSession.semotus && semotus.memSession.semotus.callStartTime) {\n        semotus.memSession.semotus.callStartTime = 0;\n    }\n\n    // Inspect a copy of the message on the server only before sent out. Only for debug purposes\n    if (semotus.controller && semotus.controller.inspectMessage) {\n        semotus.controller.inspectMessage(Object.assign({}, message));\n    }\n\n    session.sendMessage(message);\n    semotus._deleteChanges();\n    semotus._processQueue();\n}\n\n\n/**\n *  Helper function to log amorphic errors.\n * @param {*} logger\n * @param {*} activity\n * @param {*} message\n * @param {*} logType\n * @param {*} logString\n * @param remoteCall\n * @param callContext\n */\nexport function postCallErrorLog(logger, activity, message, logType, logString, remoteCall: RemoteCall, callContext: CallContext) {\n    let logBody = {\n        component: 'semotus',\n        module: 'processCall.failure',\n        data: {\n            call: remoteCall.name,\n            callTime: logTime(callContext),\n            sequence: remoteCall.sequence,\n            message: undefined\n        },\n        activity: undefined\n    };\n\n    logBody.activity = activity;\n\n    if (logger.data) {\n        logBody.data.message = message;\n    }\n\n    logger[logType](logBody, logString);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ProcessCall.js","sourceRoot":"","sources":["../../src/helpers/ProcessCall.ts"],"names":[],"mappings":"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","sourcesContent":["import {delay, getError, logTime} from './Utilities';\nimport {CallContext, ProcessCallPayload, RemoteCall, Semotus, Session} from './Types';\n\n/**\n * We process the call the remote method in stages starting by letting the controller examine the\n * changes (preCallHook) and giving it a chance to refresh data if it needs to.  Then we apply any\n * changes in the messages and give the object owning the method a chance to validate that the\n * call is valid and take care of any authorization concerns.  Finally we let the controller perform\n * any post-call processing such as commiting data and then we deal with a failure or success.\n *\n * @param payload\n * @param {unknown} forceupdate unknown\n *\n * @returns {unknown} unknown\n */\nexport async function processCall(payload: ProcessCallPayload, forceupdate?: boolean) {\n\n    try {\n        forceupdate = await Promise.resolve(forceupdate);\n        await preCallHook(payload, forceupdate);\n        let validation = await applyChangesAndValidateCall(payload);\n        validation = await customValidation(payload, validation);\n        const result = await callIfValid(payload, validation);\n        await postCallHook(payload, result);\n        await postCallSuccess(payload, result);\n    } catch (err) {\n        await postCallFailure(payload, err);\n    }\n}\n\n\n/**\n * If there is an update conflict we want to retry after restoring the session\n *\n * @returns {*} unknown\n */\nasync function retryCall(payload: ProcessCallPayload) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    if (restoreSessionCallback) {\n        restoreSessionCallback();\n    }\n\n    return processCall(payload, true);\n}\n\n/**\n * Determine what objects changed and pass this to the preServerCall method on the controller\n *\n * @param payload\n * @param  forceupdate unknown\n *\n * @returns  unknown\n */\nasync function preCallHook(payload: ProcessCallPayload, forceupdate?: boolean): Promise<any> {\n    const {semotus, remoteCall, session, callContext, HTTPObjs} = payload;\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'preServerCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    if (semotus.controller && semotus.controller.preServerCall) {\n        let changes = {};\n\n        for (var objId in JSON.parse(remoteCall.changes)) {\n            changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true;\n        }\n\n        let remoteObject = session.objects[remoteCall.id];\n\n        // Need to double check if not in session, what the template is.\n        let remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')];\n        let isPublic = false;\n\n        if (remoteObject) {\n            isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic;\n        }\n        else if (remoteTemplate) {\n            // If the class doesn't exist, we should get the remote function from the prototype\n            isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic;\n        }\n        else {\n            semotus.logger.error({\n                component: 'semotus',\n                module: 'processCall',\n                activity: 'preServerCall',\n                data: {\n                    call: remoteCall.name,\n                    sequence: remoteCall.sequence\n                }\n            }, \t'Could not find template for ' + objId);\n        }\n\n        return semotus.controller.preServerCall.call(\n            semotus.controller,\n            remoteCall.changes.length > 2,\n            changes,\n            callContext,\n            forceupdate,\n            remoteCall.name,\n            remoteCall,\n            isPublic,\n            HTTPObjs\n        );\n    } else {\n        return true;\n    }\n}\n\n/**\n * Apply changes in the message and then validate the call.  Throw \"Sync Error\" if changes can't be applied\n *\n * @returns {unknown} unknown\n */\nfunction applyChangesAndValidateCall(payload: ProcessCallPayload): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'applyChangesAndValidateCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence,\n                remoteCallId: remoteCall.id\n            }\n        },\n        remoteCall.name\n    );\n\n    let changes = JSON.parse(remoteCall.changes);\n\n    const res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext);\n    if (res) {\n        const obj = session.objects[remoteCall.id];\n\n        if (!obj) {\n            throw new Error(`Cannot find object for remote call ${remoteCall.id}`);\n        }\n\n        // check to see if this function is supposed to be called directly from client\n        if (obj.__proto__[remoteCall.name].__on__ !== 'server') {\n            throw 'Invalid Function Call; not an API function';\n        }\n\n        if (semotus.role === 'server' && obj.validateServerCall) {\n            return obj.validateServerCall.call(obj, remoteCall.name, callContext);\n        }\n\n        return true;\n    } else {\n        throw 'Sync Error';\n    }\n}\n\n/**\n * Apply function specific custom serverSide validation functions\n *\n * @param semotus\n * @param {boolean} isValid - Result of previous validation step (applyChangesAndValidateCall)\n * @param session\n * @param remoteCall\n * @returns {boolean} True if passed function\n */\nfunction customValidation(payload: ProcessCallPayload, isValid: boolean): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'customValidation',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    let remoteObject = session.objects[remoteCall.id];\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    if (!isValid) {\n        return false;\n    } else if (semotus.role === 'server' && remoteObject[remoteCall.name].serverValidation) {\n        let args = semotus._extractArguments(remoteCall);\n        args.unshift(remoteObject);\n\n        return remoteObject[remoteCall.name].serverValidation.apply(null, args);\n    } else {\n        return true;\n    }\n}\n\n/**\n * If the changes could be applied and the validation was successful call the method\n *\n * @param semotus\n * @param {boolean} isValid - takes a flag if the call is valid or not, if it is then we proceed normally,\n * otherwise, we throw an error and stop execution\n *\n * @param session\n * @param remoteCall\n * @returns {unknown} unknown\n */\nasync function callIfValid(payload: ProcessCallPayload, isValid: boolean) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'callIfValid',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    let obj = session.objects[remoteCall.id];\n\n    if (!obj[remoteCall.name]) {\n        throw new Error(remoteCall.name + ' function does not exist.');\n    }\n\n    if (!isValid && remoteCall && remoteCall.name) {\n        throw new Error(remoteCall.name + ' refused');\n    }\n\n    let args = semotus._extractArguments(remoteCall);\n\n    return obj[remoteCall.name].apply(obj, args);\n}\n\n/**\n * Let the controller know that the method was completed and give it a chance to commit changes\n *\n * @param payload\n * @param  returnValue unknown\n *\n * @returns\n */\nasync function postCallHook(payload: ProcessCallPayload, returnValue) {\n    const {semotus, remoteCall, callContext, HTTPObjs} = payload;\n\n    if (semotus.controller && semotus.controller.postServerCall) {\n        const hasChanges: boolean = remoteCall.changes.length > 2;\n        await semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs);\n    }\n    return returnValue;\n}\n\n/**\n * Package up any changes resulting from the execution and send them back in the message, clearing\n * our change queue to accumulate more changes for the next call\n *\n * @param semotus\n * @param remoteCall\n * @param remoteCallId\n * @param {unknown} ret unknown\n */\nfunction postCallSuccess(payload: ProcessCallPayload, ret): void {\n    const {semotus, remoteCall, callContext, session, remoteCallId} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'postCall.success',\n            data: {\n                call: remoteCall.name,\n                callTime: logTime(callContext),\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    packageChanges(semotus, session,{\n        type: 'response',\n        sync: true,\n        value: JSON.stringify(semotus._toTransport(ret)),\n        name: remoteCall.name,\n        remoteCallId: remoteCallId\n    });\n}\n\n/**\n * Helper function to identify if there's a postServerErrorHandler callback on the base controller\n * If there is, we execute the handler, and if we catch an error in the handler, we propogate it up to the logger.\n * @param logger\n * @param {*} controller\n * @param type\n * @param remoteCall\n * @param remoteCallId\n * @param callContext\n * @param changeString\n * @param session\n */\nasync function resolveErrorHandler(logger, controller: any, type, remoteCall: RemoteCall, remoteCallId, callContext: CallContext, changeString, session: Session) {\n\n    if (controller && controller.postServerErrorHandler) {\n        let errorType = type;\n        let functionName = remoteCall.name;\n        let obj = undefined;\n        if (session.objects[remoteCall.id]) {\n            obj = session.objects[remoteCall.id];\n        }\n        let logBody = {\n            component: 'semotus',\n            module: 'processCall.failure',\n            activity: 'postCall.resolveErrorHandler',\n            data: {\n                call: remoteCall.name,\n                message: undefined\n            }\n        };\n\n        try {\n            await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString);\n        } catch (error) {\n            if (error.message) {\n                logBody.data.message = error.message;\n                logger.error(error.message);\n            } else {\n                logBody.data.message = JSON.stringify(error);\n            }\n\n            logger.error(logBody, 'User defined postServerErrorHandler threw an error');\n        }\n    }\n}\n\n/**\n * Handle errors by returning an apropriate message.  In all cases changes sent back though they\n *\n * @param semotus\n * @param remoteCall\n * @param callContext\n * @param session\n * @param {unknown} err unknown\n *\n * @returns {unknown} A Promise\n */\nasync function postCallFailure(payload: ProcessCallPayload, err) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let logString = '';\n\n    let packageChangesPayload = {};\n\n    let updateConflictRetry = false;\n\n    if (err === 'Sync Error') {\n        postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext);\n        packageChangesPayload = {\n            type: 'response',\n            sync: false,\n            changes: ''\n        };\n    } else if (err.message == 'Update Conflict') {\n        // Not this may be caught in the transport (e.g. Amorphic) and retried)\n\n        // increment callContext.retries after checking if < 3. Should retry 3 times.\n        if (callContext.retries++ < 3) {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext);\n            updateConflictRetry = true;\n            // The following assignment is only used for the error handler\n            packageChangesPayload = {\n                type: 'retry'\n            };\n        } else {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext);\n            packageChangesPayload = {\n                type: 'retry',\n                sync: false\n            };\n        }\n    } else {\n        if (!(err instanceof Error)) {\n            postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext);\n        } else {\n            if (err.stack) {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack);\n            } else {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message;\n            }\n\n            postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext);\n        }\n\n        packageChangesPayload = {\n            type: 'error',\n            sync: true,\n            value: getError(err),\n            name: remoteCall.name\n        };\n    }\n\n    Object.assign(packageChangesPayload, {remoteCallId: remoteCallId});\n\n    await resolveErrorHandler(\n        semotus.logger,\n        semotus.controller,\n        // @ts-ignore\n        packageChangesPayload.type,\n        remoteCall,\n        remoteCallId,\n        callContext,\n        semotus.changeString,\n        session\n    );\n\n    if (updateConflictRetry) {\n        await delay(callContext.retries * 1000);\n        return retryCall(payload);\n    } else {\n        return packageChanges(semotus, session, packageChangesPayload);\n    }\n}\n\n/**\n * Deal with changes going back to the caller - Actually not Async!\n *\n * @param semotus\n * @param session\n * @param {unknown} message unknown\n */\nfunction packageChanges(semotus: Semotus, session: Session, message) {\n    semotus._convertArrayReferencesToChanges();\n    message.changes = JSON.stringify(semotus.getChanges());\n\n    if (semotus.memSession && semotus.memSession.semotus && semotus.memSession.semotus.callStartTime) {\n        semotus.memSession.semotus.callStartTime = 0;\n    }\n\n    // Inspect a copy of the message on the server only before sent out. Only for debug purposes\n    if (semotus.controller && semotus.controller.inspectMessage) {\n        semotus.controller.inspectMessage(Object.assign({}, message));\n    }\n\n    session.sendMessage(message);\n    semotus._deleteChanges();\n    semotus._processQueue();\n}\n\n\n/**\n *  Helper function to log amorphic errors.\n * @param {*} logger\n * @param {*} activity\n * @param {*} message\n * @param {*} logType\n * @param {*} logString\n * @param remoteCall\n * @param callContext\n */\nexport function postCallErrorLog(logger, activity, message, logType, logString, remoteCall: RemoteCall, callContext: CallContext) {\n    let logBody = {\n        component: 'semotus',\n        module: 'processCall.failure',\n        data: {\n            call: remoteCall.name,\n            callTime: logTime(callContext),\n            sequence: remoteCall.sequence,\n            message: undefined\n        },\n        activity: undefined\n    };\n\n    logBody.activity = activity;\n\n    if (logger.data) {\n        logBody.data.message = message;\n    }\n\n    logger[logType](logBody, logString);\n}\n"]} |
@@ -58,3 +58,3 @@ "use strict"; | ||
function remove(semotus, sessionId) { | ||
var session = get(semotus, sessionId); | ||
let session = get(semotus, sessionId); | ||
for (var calls in session.remoteCalls) { | ||
@@ -109,3 +109,3 @@ session.remoteCalls[calls].deferred.reject({ code: 'reset', text: 'Session resynchronized' }); | ||
semotus.setSession(sessionId); | ||
var session = semotus.sessions[sessionId]; | ||
const session = semotus.sessions[sessionId]; | ||
semotus.logger.debug({ component: 'semotus', module: 'restore', activity: 'save' }); | ||
@@ -134,8 +134,8 @@ if (session) { | ||
function save(semotus, sessionId) { | ||
var session = get(semotus, sessionId); | ||
const session = get(semotus, sessionId); | ||
session.nextSaveSessionId = session.nextSaveSessionId + 1; | ||
session.savedSessionId = session.nextSaveSessionId; | ||
var objects = session.objects; | ||
const objects = session.objects; | ||
session.objects = {}; | ||
var savedSession = { | ||
const savedSession = { | ||
callCount: semotus.getPendingCallCount(sessionId), | ||
@@ -151,2 +151,2 @@ revision: session.savedSessionId, | ||
exports.save = save; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sessions.js","sourceRoot":"","sources":["../../src/helpers/Sessions.ts"],"names":[],"mappings":"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","sourcesContent":["import {SavedSession, Semotus, SendMessage, Session} from './Types';\n\n/**\n * Obtain a session for tracking subscriptions\n *\n * @param semotus\n * @param {unknown} role unknown\n * @param {unknown} sendMessage unknown\n * @param {unknown} sessionId unknown\n *\n * @returns {*} unknown\n */\nexport function create(semotus: Semotus, role, sendMessage: SendMessage, sessionId): any {\n    if (!semotus.sessions) {\n        semotus.nextSubscriptionId = 0;\n        semotus.nextSessionId = 1;\n        semotus.sessions = {};\n    }\n\n    if (!sessionId) {\n        sessionId = semotus.nextSessionId++;\n    }\n\n    semotus.setSession(sessionId);\n\n    semotus.sessions[sessionId] = {\n        subscriptions: {}, // Change listeners\n        sendMessage: sendMessage, // Send message callback\n        sendMessageEnabled: !!sendMessage,\n        remoteCalls: [], // Remote calls queued to go out\n        pendingRemoteCalls: {}, // Remote calls waiting for response\n        nextPendingRemoteCallId: 1,\n        nextSaveSessionId: 1,\n        savedSessionId: 0,\n        nextSubscriptionId: 0,\n        objects: {},\n        nextObjId: 1,\n        dispenseNextId: null // Force next object Id\n    };\n\n    if (role instanceof Array) {\n        for (var ix = 0; ix < role.length; ++ix) {\n            semotus.subscribe(role[ix]);\n        }\n\n        semotus.role = role[1];\n    } else {\n        semotus.subscribe(role);\n        semotus.role = role;\n    }\n\n    return sessionId;\n}\n\n\n/**\n * Remove the session from the sessions map, rejecting any outstanding promises\n * WARNING: Async side effects\n * @param semotus\n * @param {unknown} sessionId unknown\n */\nexport function remove(semotus: Semotus, sessionId: string | number) {\n    let session = get(semotus, sessionId);\n\n    for (var calls in session.remoteCalls) {\n        session.remoteCalls[calls].deferred.reject({code: 'reset', text: 'Session resynchronized'});\n    }\n\n    if (semotus.sessions[sessionId]) {\n        delete semotus.sessions[sessionId];\n    }\n}\n\n/**\n * Get the current session structure\n *\n * @returns {*} the session\n *\n * @private\n */\nexport function get(semotus: Semotus, _sid?): Session | null {\n    if (!semotus.currentSession) {\n        return null;\n    }\n    return semotus.sessions[semotus.currentSession];\n}\n\n\n/**\n * Indicate that all changes have been accepted outside of the message\n * mechanism as would usually happen when a session is starting up\n *\n * @param semotus\n * @param {unknown} sessionId unknown\n */\nexport function sync(semotus: Semotus, sessionId) {\n    get(semotus, sessionId);\n    semotus.getChanges();\n    semotus._deleteChanges();\n}\n\n\n/**\n * Restore session that was potentially serialized/deserialized\n *\n * A revision number is used to determine whether the in-memory copy is good\n *\n * @param semotus\n * @param {unknown} sessionId - the id under which it was created with createSession\n * @param {unknown} savedSession - the POJO version of the session data\n * @param {unknown} sendMessage - new message function to be in effect\n *\n * @returns {Boolean} false means that messages were in flight and a reset is needed\n */\nexport function restore(semotus: Semotus, sessionId, savedSession: SavedSession, sendMessage: SendMessage) {\n    semotus.setSession(sessionId);\n    const session = semotus.sessions[sessionId];\n    semotus.logger.debug({component: 'semotus', module: 'restore', activity: 'save'});\n\n    if (session) {\n        if (session.savedSessionId == savedSession.revision) {\n            return true;\n        } else {\n            delete semotus.sessions[sessionId];\n        }\n    }\n\n    semotus.sessions[sessionId] = JSON.parse(savedSession.data);\n    semotus.sessions[sessionId].sendMessage = sendMessage;\n\n    return savedSession.callCount > 0;\n}\n\n/**\n * Save the session data in a way that can be serialized/de-serialized\n *\n * @param semotus\n * @param {unknown} sessionId unknown\n *\n * @returns {Object} unknown\n */\nexport function save(semotus: Semotus, sessionId): SavedSession {\n    const session = get(semotus, sessionId);\n\n    session.nextSaveSessionId = session.nextSaveSessionId + 1;\n    session.savedSessionId = session.nextSaveSessionId;\n    const objects = session.objects;\n    session.objects = {};\n\n    const savedSession = {\n        callCount: semotus.getPendingCallCount(sessionId), // Can't just restore on another server and carry on\n        revision: session.savedSessionId, // Used to see if our memory copy good enough\n        referenced: new Date().getTime(), // Used for reaping old sessions\n        data: JSON.stringify(session) // All the session data\n    };\n\n    session.objects = objects;\n    semotus.logger.debug({component: 'semotus', module: 'save', activity: 'save'});\n\n    return savedSession;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sessions.js","sourceRoot":"","sources":["../../src/helpers/Sessions.ts"],"names":[],"mappings":"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","sourcesContent":["import {SavedSession, Semotus, SendMessage, Session} from './Types';\n\n/**\n * Obtain a session for tracking subscriptions\n *\n * @param semotus\n * @param {unknown} role unknown\n * @param {unknown} sendMessage unknown\n * @param {unknown} sessionId unknown\n *\n * @returns {*} unknown\n */\nexport function create(semotus: Semotus, role, sendMessage: SendMessage, sessionId): any {\n    if (!semotus.sessions) {\n        semotus.nextSubscriptionId = 0;\n        semotus.nextSessionId = 1;\n        semotus.sessions = {};\n    }\n\n    if (!sessionId) {\n        sessionId = semotus.nextSessionId++;\n    }\n\n    semotus.setSession(sessionId);\n\n    semotus.sessions[sessionId] = {\n        subscriptions: {}, // Change listeners\n        sendMessage: sendMessage, // Send message callback\n        sendMessageEnabled: !!sendMessage,\n        remoteCalls: [], // Remote calls queued to go out\n        pendingRemoteCalls: {}, // Remote calls waiting for response\n        nextPendingRemoteCallId: 1,\n        nextSaveSessionId: 1,\n        savedSessionId: 0,\n        nextSubscriptionId: 0,\n        objects: {},\n        nextObjId: 1,\n        dispenseNextId: null // Force next object Id\n    };\n\n    if (role instanceof Array) {\n        for (var ix = 0; ix < role.length; ++ix) {\n            semotus.subscribe(role[ix]);\n        }\n\n        semotus.role = role[1];\n    } else {\n        semotus.subscribe(role);\n        semotus.role = role;\n    }\n\n    return sessionId;\n}\n\n\n/**\n * Remove the session from the sessions map, rejecting any outstanding promises\n * WARNING: Async side effects\n * @param semotus\n * @param {unknown} sessionId unknown\n */\nexport function remove(semotus: Semotus, sessionId: string | number) {\n    let session = get(semotus, sessionId);\n\n    for (var calls in session.remoteCalls) {\n        session.remoteCalls[calls].deferred.reject({code: 'reset', text: 'Session resynchronized'});\n    }\n\n    if (semotus.sessions[sessionId]) {\n        delete semotus.sessions[sessionId];\n    }\n}\n\n/**\n * Get the current session structure\n *\n * @returns {*} the session\n *\n * @private\n */\nexport function get(semotus: Semotus, _sid?): Session | null {\n    if (!semotus.currentSession) {\n        return null;\n    }\n    return semotus.sessions[semotus.currentSession];\n}\n\n\n/**\n * Indicate that all changes have been accepted outside of the message\n * mechanism as would usually happen when a session is starting up\n *\n * @param semotus\n * @param {unknown} sessionId unknown\n */\nexport function sync(semotus: Semotus, sessionId) {\n    get(semotus, sessionId);\n    semotus.getChanges();\n    semotus._deleteChanges();\n}\n\n\n/**\n * Restore session that was potentially serialized/deserialized\n *\n * A revision number is used to determine whether the in-memory copy is good\n *\n * @param semotus\n * @param {unknown} sessionId - the id under which it was created with createSession\n * @param {unknown} savedSession - the POJO version of the session data\n * @param {unknown} sendMessage - new message function to be in effect\n *\n * @returns {Boolean} false means that messages were in flight and a reset is needed\n */\nexport function restore(semotus: Semotus, sessionId, savedSession: SavedSession, sendMessage: SendMessage) {\n    semotus.setSession(sessionId);\n    const session = semotus.sessions[sessionId];\n    semotus.logger.debug({component: 'semotus', module: 'restore', activity: 'save'});\n\n    if (session) {\n        if (session.savedSessionId == savedSession.revision) {\n            return true;\n        } else {\n            delete semotus.sessions[sessionId];\n        }\n    }\n\n    semotus.sessions[sessionId] = JSON.parse(savedSession.data);\n    semotus.sessions[sessionId].sendMessage = sendMessage;\n\n    return savedSession.callCount > 0;\n}\n\n/**\n * Save the session data in a way that can be serialized/de-serialized\n *\n * @param semotus\n * @param {unknown} sessionId unknown\n *\n * @returns {Object} unknown\n */\nexport function save(semotus: Semotus, sessionId): SavedSession {\n    const session = get(semotus, sessionId);\n\n    session.nextSaveSessionId = session.nextSaveSessionId + 1;\n    session.savedSessionId = session.nextSaveSessionId;\n    const objects = session.objects;\n    session.objects = {};\n\n    const savedSession = {\n        callCount: semotus.getPendingCallCount(sessionId), // Can't just restore on another server and carry on\n        revision: session.savedSessionId, // Used to see if our memory copy good enough\n        referenced: new Date().getTime(), // Used for reaping old sessions\n        data: JSON.stringify(session) // All the session data\n    };\n\n    session.objects = objects;\n    semotus.logger.debug({component: 'semotus', module: 'save', activity: 'save'});\n\n    return savedSession;\n}\n"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.subscribe = exports.getSubscriptions = exports.getSubscription = void 0; | ||
var Sessions = require("./Sessions"); | ||
const Sessions = require("./Sessions"); | ||
/** | ||
@@ -30,3 +30,3 @@ * Purpose unknown | ||
function getSubscriptions(semotus, sessionId) { | ||
var session = Sessions.get(semotus, sessionId); | ||
const session = Sessions.get(semotus, sessionId); | ||
if (session) { | ||
@@ -51,4 +51,4 @@ return session.subscriptions; | ||
function subscribe(semotus, role) { | ||
var session = Sessions.get(semotus); | ||
var subscriptionId = session.nextSubscriptionId++; | ||
const session = Sessions.get(semotus); | ||
const subscriptionId = session.nextSubscriptionId++; | ||
session.subscriptions[subscriptionId] = { | ||
@@ -65,2 +65,2 @@ role: role, | ||
exports.subscribe = subscribe; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3Vic2NyaXB0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oZWxwZXJzL1N1YnNjcmlwdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUNBQXVDO0FBR3ZDOzs7Ozs7Ozs7R0FTRztBQUNILFNBQWdCLGVBQWUsQ0FBQyxPQUFnQixFQUFFLGNBQWU7SUFDN0QsT0FBTyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLGFBQWEsQ0FBQyxjQUFjLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDcEUsQ0FBQztBQUZELDBDQUVDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsT0FBZ0IsRUFBRSxTQUFVO0lBQ3pELElBQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBRWpELElBQUksT0FBTyxFQUFFO1FBQ1QsT0FBTyxPQUFPLENBQUMsYUFBYSxDQUFDO0tBQ2hDO1NBQU07UUFDSCxPQUFPLElBQUksQ0FBQztLQUNmO0FBQ0wsQ0FBQztBQVJELDRDQVFDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsU0FBUyxDQUFDLE9BQWdCLEVBQUUsSUFBSTtJQUM1QyxJQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RDLElBQU0sY0FBYyxHQUFHLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBRXBELE9BQU8sQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLEdBQUc7UUFDcEMsSUFBSSxFQUFFLElBQUk7UUFDVixHQUFHLEVBQUU7WUFDRCxLQUFLLEVBQUUsRUFBRTtZQUNULE1BQU0sRUFBRSxFQUFFO1lBQ1YsVUFBVSxFQUFFLEVBQUU7U0FDakI7S0FDSixDQUFDO0lBRUYsT0FBTyxjQUFjLENBQUM7QUFDMUIsQ0FBQztBQWRELDhCQWNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgU2Vzc2lvbnMgZnJvbSAnLi9TZXNzaW9ucyc7XG5pbXBvcnQge1NlbW90dXMsIFN1YnNjcmlwdGlvbiwgU3Vic2NyaXB0aW9uc30gZnJvbSAnLi9UeXBlcyc7XG5cbi8qKlxuICogUHVycG9zZSB1bmtub3duXG4gKlxuICogQHBhcmFtIHNlbW90dXNcbiAqIEBwYXJhbSB7dW5rbm93bn0gc3Vic2NyaXB0aW9uSWQgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHt1bmtub3dufSB1bmtub3duXG4gKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFN1YnNjcmlwdGlvbihzZW1vdHVzOiBTZW1vdHVzLCBzdWJzY3JpcHRpb25JZD8pOiBTdWJzY3JpcHRpb24ge1xuICAgIHJldHVybiBTZXNzaW9ucy5nZXQoc2Vtb3R1cykuc3Vic2NyaXB0aW9uc1tzdWJzY3JpcHRpb25JZCB8fCAwXTtcbn1cblxuLyoqXG4gKiBQdXJwb3NlIHVua25vd25cbiAqXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICogQHBhcmFtIHt1bmtub3dufSBzZXNzaW9uSWQgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHt1bmtub3dufSB1bmtub3duXG4gKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFN1YnNjcmlwdGlvbnMoc2Vtb3R1czogU2Vtb3R1cywgc2Vzc2lvbklkPyk6IG51bGwgfCBTdWJzY3JpcHRpb25zIHtcbiAgICBjb25zdCBzZXNzaW9uID0gU2Vzc2lvbnMuZ2V0KHNlbW90dXMsIHNlc3Npb25JZCk7XG5cbiAgICBpZiAoc2Vzc2lvbikge1xuICAgICAgICByZXR1cm4gc2Vzc2lvbi5zdWJzY3JpcHRpb25zO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbn1cblxuLyoqXG4gKiBTdWJzY3JpYmUgdG8gY2hhbmdlcyBhbmQgb3B0aW9uYWxseSBlc3RhYmxpc2ggc3Vic2NyaXB0aW9uIGFzIHRoZVxuICogc29sZSByZWNpcGllbnQgb2YgcmVtb3RlIGNhbGwgbWVzc2FnZXMuICBDaGFuZ2UgdHJhY2tpbmcgaXMgdGhlbiBtYW5hZ2VkXG4gKiBieSB0aGUgZnVuY3Rpb25zIHRoYXQgZm9sbG93LlxuICpcbiAqIEBwYXJhbSBzZW1vdHVzXG4gKiBAcGFyYW0ge3Vua25vd259IHJvbGUgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHsqfSB1bmtub3duXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzdWJzY3JpYmUoc2Vtb3R1czogU2Vtb3R1cywgcm9sZSkge1xuICAgIGNvbnN0IHNlc3Npb24gPSBTZXNzaW9ucy5nZXQoc2Vtb3R1cyk7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uSWQgPSBzZXNzaW9uLm5leHRTdWJzY3JpcHRpb25JZCsrO1xuXG4gICAgc2Vzc2lvbi5zdWJzY3JpcHRpb25zW3N1YnNjcmlwdGlvbklkXSA9IHtcbiAgICAgICAgcm9sZTogcm9sZSxcbiAgICAgICAgbG9nOiB7XG4gICAgICAgICAgICBhcnJheToge30sXG4gICAgICAgICAgICBjaGFuZ2U6IHt9LFxuICAgICAgICAgICAgYXJyYXlEaXJ0eToge31cbiAgICAgICAgfVxuICAgIH07XG5cbiAgICByZXR1cm4gc3Vic2NyaXB0aW9uSWQ7XG59Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3Vic2NyaXB0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oZWxwZXJzL1N1YnNjcmlwdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBQXVDO0FBR3ZDOzs7Ozs7Ozs7R0FTRztBQUNILFNBQWdCLGVBQWUsQ0FBQyxPQUFnQixFQUFFLGNBQWU7SUFDN0QsT0FBTyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLGFBQWEsQ0FBQyxjQUFjLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDcEUsQ0FBQztBQUZELDBDQUVDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsT0FBZ0IsRUFBRSxTQUFVO0lBQ3pELE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBRWpELElBQUksT0FBTyxFQUFFO1FBQ1QsT0FBTyxPQUFPLENBQUMsYUFBYSxDQUFDO0tBQ2hDO1NBQU07UUFDSCxPQUFPLElBQUksQ0FBQztLQUNmO0FBQ0wsQ0FBQztBQVJELDRDQVFDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsU0FBUyxDQUFDLE9BQWdCLEVBQUUsSUFBSTtJQUM1QyxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RDLE1BQU0sY0FBYyxHQUFHLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBRXBELE9BQU8sQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLEdBQUc7UUFDcEMsSUFBSSxFQUFFLElBQUk7UUFDVixHQUFHLEVBQUU7WUFDRCxLQUFLLEVBQUUsRUFBRTtZQUNULE1BQU0sRUFBRSxFQUFFO1lBQ1YsVUFBVSxFQUFFLEVBQUU7U0FDakI7S0FDSixDQUFDO0lBRUYsT0FBTyxjQUFjLENBQUM7QUFDMUIsQ0FBQztBQWRELDhCQWNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgU2Vzc2lvbnMgZnJvbSAnLi9TZXNzaW9ucyc7XG5pbXBvcnQge1NlbW90dXMsIFN1YnNjcmlwdGlvbiwgU3Vic2NyaXB0aW9uc30gZnJvbSAnLi9UeXBlcyc7XG5cbi8qKlxuICogUHVycG9zZSB1bmtub3duXG4gKlxuICogQHBhcmFtIHNlbW90dXNcbiAqIEBwYXJhbSB7dW5rbm93bn0gc3Vic2NyaXB0aW9uSWQgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHt1bmtub3dufSB1bmtub3duXG4gKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFN1YnNjcmlwdGlvbihzZW1vdHVzOiBTZW1vdHVzLCBzdWJzY3JpcHRpb25JZD8pOiBTdWJzY3JpcHRpb24ge1xuICAgIHJldHVybiBTZXNzaW9ucy5nZXQoc2Vtb3R1cykuc3Vic2NyaXB0aW9uc1tzdWJzY3JpcHRpb25JZCB8fCAwXTtcbn1cblxuLyoqXG4gKiBQdXJwb3NlIHVua25vd25cbiAqXG4gKiBAcGFyYW0gc2Vtb3R1c1xuICogQHBhcmFtIHt1bmtub3dufSBzZXNzaW9uSWQgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHt1bmtub3dufSB1bmtub3duXG4gKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFN1YnNjcmlwdGlvbnMoc2Vtb3R1czogU2Vtb3R1cywgc2Vzc2lvbklkPyk6IG51bGwgfCBTdWJzY3JpcHRpb25zIHtcbiAgICBjb25zdCBzZXNzaW9uID0gU2Vzc2lvbnMuZ2V0KHNlbW90dXMsIHNlc3Npb25JZCk7XG5cbiAgICBpZiAoc2Vzc2lvbikge1xuICAgICAgICByZXR1cm4gc2Vzc2lvbi5zdWJzY3JpcHRpb25zO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbn1cblxuLyoqXG4gKiBTdWJzY3JpYmUgdG8gY2hhbmdlcyBhbmQgb3B0aW9uYWxseSBlc3RhYmxpc2ggc3Vic2NyaXB0aW9uIGFzIHRoZVxuICogc29sZSByZWNpcGllbnQgb2YgcmVtb3RlIGNhbGwgbWVzc2FnZXMuICBDaGFuZ2UgdHJhY2tpbmcgaXMgdGhlbiBtYW5hZ2VkXG4gKiBieSB0aGUgZnVuY3Rpb25zIHRoYXQgZm9sbG93LlxuICpcbiAqIEBwYXJhbSBzZW1vdHVzXG4gKiBAcGFyYW0ge3Vua25vd259IHJvbGUgdW5rbm93blxuICpcbiAqIEByZXR1cm5zIHsqfSB1bmtub3duXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzdWJzY3JpYmUoc2Vtb3R1czogU2Vtb3R1cywgcm9sZSkge1xuICAgIGNvbnN0IHNlc3Npb24gPSBTZXNzaW9ucy5nZXQoc2Vtb3R1cyk7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uSWQgPSBzZXNzaW9uLm5leHRTdWJzY3JpcHRpb25JZCsrO1xuXG4gICAgc2Vzc2lvbi5zdWJzY3JpcHRpb25zW3N1YnNjcmlwdGlvbklkXSA9IHtcbiAgICAgICAgcm9sZTogcm9sZSxcbiAgICAgICAgbG9nOiB7XG4gICAgICAgICAgICBhcnJheToge30sXG4gICAgICAgICAgICBjaGFuZ2U6IHt9LFxuICAgICAgICAgICAgYXJyYXlEaXJ0eToge31cbiAgICAgICAgfVxuICAgIH07XG5cbiAgICByZXR1cm4gc3Vic2NyaXB0aW9uSWQ7XG59Il19 |
@@ -6,7 +6,7 @@ "use strict"; | ||
function delay(ms) { | ||
return new Promise(function (_) { return setTimeout(_, ms); }); | ||
return new Promise(_ => setTimeout(_, ms)); | ||
} | ||
exports.delay = delay; | ||
function defer() { | ||
var result = {}; | ||
const result = {}; | ||
result.promise = new Promise(function (resolve, reject) { | ||
@@ -48,2 +48,2 @@ result.resolve = resolve; | ||
exports.logTime = logTime; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlbHBlcnMvVXRpbGl0aWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx3QkFBd0I7OztBQUl4QixTQUFnQixLQUFLLENBQUMsRUFBVTtJQUM1QixPQUFPLElBQUksT0FBTyxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsVUFBVSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBakIsQ0FBaUIsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFGRCxzQkFFQztBQUVELFNBQWdCLEtBQUs7SUFDakIsSUFBTSxNQUFNLEdBQW1ELEVBQUUsQ0FBQztJQUNsRSxNQUFNLENBQUMsT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsT0FBTyxFQUFFLE1BQU07UUFDbEQsTUFBTSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDekIsTUFBTSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDM0IsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBUEQsc0JBT0M7QUFHRDs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFnQixRQUFRLENBQUMsR0FBRztJQUN4QixJQUFJLEdBQUcsWUFBWSxLQUFLLEVBQUU7UUFDdEIsT0FBTyxFQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLEVBQUUsNEJBQTRCLEVBQUMsQ0FBQztLQUN2RTtTQUFNO1FBQ0gsSUFBSSxPQUFPLEdBQUcsS0FBSyxRQUFRLEVBQUU7WUFDekIsT0FBTyxFQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUMsQ0FBQztTQUN6QjthQUFNO1lBQ0gsT0FBTyxHQUFHLENBQUM7U0FDZDtLQUNKO0FBQ0wsQ0FBQztBQVZELDRCQVVDO0FBRUQsU0FBZ0IsT0FBTyxDQUFDLFdBQXdCO0lBQzVDLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUU7UUFDdkIsV0FBVyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztBQUN4QyxDQUFDO0FBSEQsMEJBR0MiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBRIFJlcGxhY2VtZW50IEhlbHBlcnNcblxuaW1wb3J0IHtDYWxsQ29udGV4dH0gZnJvbSAnLi9UeXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWxheShtczogbnVtYmVyKSB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKF8gPT4gc2V0VGltZW91dChfLCBtcykpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVmZXIoKSB7XG4gICAgY29uc3QgcmVzdWx0OiB7IHByb21pc2U/OiBhbnksIHJlc29sdmU/OiBhbnksIHJlamVjdD86IGFueSB9ID0ge307XG4gICAgcmVzdWx0LnByb21pc2UgPSBuZXcgUHJvbWlzZShmdW5jdGlvbiAocmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICAgIHJlc3VsdC5yZXNvbHZlID0gcmVzb2x2ZTtcbiAgICAgICAgcmVzdWx0LnJlamVjdCA9IHJlamVjdDtcbiAgICB9KTtcbiAgICByZXR1cm4gcmVzdWx0O1xufVxuXG5cbi8qKlxuICogSGVscGVyIGZ1bmN0aW9uIHRvXG4gKlxuICogRGlzdGluZ3Vpc2ggYmV0d2VlbiBhbiBhY3R1YWwgZXJyb3IgKHdpbGwgdGhyb3cgYW4gRXJyb3Igb2JqZWN0KSBhbmQgYSBzdHJpbmcgdGhhdCB0aGUgYXBwbGljYXRpb24gbWF5XG4gKiB0aHJvdyB3aGljaCBpcyB0byBnZXQgcGlwZWQgYmFjayB0byB0aGUgY2FsbGVyLiAgRm9yIGFuIGFjdHVhbCBlcnJvciB3ZSB3YW50IHRvIGxvZyB0aGUgc3RhY2sgdHJhY2VcbiAqXG4gKiBAcGFyYW0gZXJyIHVua25vd25cbiAqXG4gKiBAcmV0dXJucyB7Kn0gdW5rbm93blxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0RXJyb3IoZXJyKSB7XG4gICAgaWYgKGVyciBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgICAgIHJldHVybiB7Y29kZTogJ2ludGVybmFsX2Vycm9yJywgdGV4dDogJ0FuIGludGVybmFsIGVycm9yIG9jY3VycmVkJ307XG4gICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKHR5cGVvZiBlcnIgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4ge21lc3NhZ2U6IGVycn07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gZXJyO1xuICAgICAgICB9XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbG9nVGltZShjYWxsQ29udGV4dDogQ2FsbENvbnRleHQpIHtcbiAgICByZXR1cm4gbmV3IERhdGUoKS5nZXRUaW1lKCkgLVxuICAgICAgICBjYWxsQ29udGV4dC5zdGFydFRpbWUuZ2V0VGltZSgpO1xufSJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlbHBlcnMvVXRpbGl0aWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx3QkFBd0I7OztBQUl4QixTQUFnQixLQUFLLENBQUMsRUFBVTtJQUM1QixPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFGRCxzQkFFQztBQUVELFNBQWdCLEtBQUs7SUFDakIsTUFBTSxNQUFNLEdBQW1ELEVBQUUsQ0FBQztJQUNsRSxNQUFNLENBQUMsT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsT0FBTyxFQUFFLE1BQU07UUFDbEQsTUFBTSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDekIsTUFBTSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDM0IsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBUEQsc0JBT0M7QUFHRDs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFnQixRQUFRLENBQUMsR0FBRztJQUN4QixJQUFJLEdBQUcsWUFBWSxLQUFLLEVBQUU7UUFDdEIsT0FBTyxFQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLEVBQUUsNEJBQTRCLEVBQUMsQ0FBQztLQUN2RTtTQUFNO1FBQ0gsSUFBSSxPQUFPLEdBQUcsS0FBSyxRQUFRLEVBQUU7WUFDekIsT0FBTyxFQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUMsQ0FBQztTQUN6QjthQUFNO1lBQ0gsT0FBTyxHQUFHLENBQUM7U0FDZDtLQUNKO0FBQ0wsQ0FBQztBQVZELDRCQVVDO0FBRUQsU0FBZ0IsT0FBTyxDQUFDLFdBQXdCO0lBQzVDLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUU7UUFDdkIsV0FBVyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztBQUN4QyxDQUFDO0FBSEQsMEJBR0MiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBRIFJlcGxhY2VtZW50IEhlbHBlcnNcblxuaW1wb3J0IHtDYWxsQ29udGV4dH0gZnJvbSAnLi9UeXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWxheShtczogbnVtYmVyKSB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKF8gPT4gc2V0VGltZW91dChfLCBtcykpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVmZXIoKSB7XG4gICAgY29uc3QgcmVzdWx0OiB7IHByb21pc2U/OiBhbnksIHJlc29sdmU/OiBhbnksIHJlamVjdD86IGFueSB9ID0ge307XG4gICAgcmVzdWx0LnByb21pc2UgPSBuZXcgUHJvbWlzZShmdW5jdGlvbiAocmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICAgIHJlc3VsdC5yZXNvbHZlID0gcmVzb2x2ZTtcbiAgICAgICAgcmVzdWx0LnJlamVjdCA9IHJlamVjdDtcbiAgICB9KTtcbiAgICByZXR1cm4gcmVzdWx0O1xufVxuXG5cbi8qKlxuICogSGVscGVyIGZ1bmN0aW9uIHRvXG4gKlxuICogRGlzdGluZ3Vpc2ggYmV0d2VlbiBhbiBhY3R1YWwgZXJyb3IgKHdpbGwgdGhyb3cgYW4gRXJyb3Igb2JqZWN0KSBhbmQgYSBzdHJpbmcgdGhhdCB0aGUgYXBwbGljYXRpb24gbWF5XG4gKiB0aHJvdyB3aGljaCBpcyB0byBnZXQgcGlwZWQgYmFjayB0byB0aGUgY2FsbGVyLiAgRm9yIGFuIGFjdHVhbCBlcnJvciB3ZSB3YW50IHRvIGxvZyB0aGUgc3RhY2sgdHJhY2VcbiAqXG4gKiBAcGFyYW0gZXJyIHVua25vd25cbiAqXG4gKiBAcmV0dXJucyB7Kn0gdW5rbm93blxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0RXJyb3IoZXJyKSB7XG4gICAgaWYgKGVyciBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgICAgIHJldHVybiB7Y29kZTogJ2ludGVybmFsX2Vycm9yJywgdGV4dDogJ0FuIGludGVybmFsIGVycm9yIG9jY3VycmVkJ307XG4gICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKHR5cGVvZiBlcnIgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4ge21lc3NhZ2U6IGVycn07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gZXJyO1xuICAgICAgICB9XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gbG9nVGltZShjYWxsQ29udGV4dDogQ2FsbENvbnRleHQpIHtcbiAgICByZXR1cm4gbmV3IERhdGUoKS5nZXRUaW1lKCkgLVxuICAgICAgICBjYWxsQ29udGV4dC5zdGFydFRpbWUuZ2V0VGltZSgpO1xufSJdfQ== |
@@ -6,5 +6,5 @@ "use strict"; | ||
exports.Bindable = exports.Remoteable = exports.Persistable = void 0; | ||
var __extends = (this && this.__extends) || | ||
const __extends = (this && this.__extends) || | ||
(function () { | ||
var extendStatics = Object.setPrototypeOf || | ||
const extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && | ||
@@ -59,2 +59,2 @@ function (d, b) { | ||
exports.Bindable = Bindable; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2V0dXBFeHRlbmRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3NldHVwRXh0ZW5kcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsa0hBQWtIO0FBQ2xILCtFQUErRTs7O0FBRS9FLElBQU0sU0FBUyxHQUNYLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztRQUNHLElBQU0sYUFBYSxHQUNmLE1BQU0sQ0FBQyxjQUFjO1lBQ3JCLENBQUMsRUFBQyxTQUFTLEVBQUUsRUFBRSxFQUFDLFlBQVksS0FBSztnQkFDN0IsVUFBVSxDQUFDLEVBQUUsQ0FBQztvQkFDVixDQUFDLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztnQkFDcEIsQ0FBQyxDQUFDO1lBQ04sVUFBVSxDQUFDLEVBQUUsQ0FBQztnQkFDVixLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDYixJQUFJLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLEVBQUU7d0JBQ3JCLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7cUJBQ2Y7aUJBQ0o7WUFDTCxDQUFDLENBQUM7UUFDTixPQUFPLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDakIsYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUVwQixTQUFTLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7WUFDekIsQ0FBQztZQUVELENBQUMsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMzRixDQUFDLENBQUM7SUFDTixDQUFDLENBQUMsRUFBRSxDQUFDO0FBRVQsU0FBZ0IsV0FBVyxDQUFDLElBQUk7SUFDNUIsT0FBTyxDQUFDLFVBQVUsTUFBTTtRQUNwQixTQUFTLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRTNCLFNBQVMsT0FBTztZQUNaLE9BQU8sQ0FBQyxNQUFNLEtBQUssSUFBSSxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDO1FBQ3RFLENBQUM7UUFFRCxPQUFPLE9BQU8sQ0FBQztJQUNuQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQTtBQUNaLENBQUM7QUFWRCxrQ0FVQztBQUVELFNBQWdCLFVBQVUsQ0FBQyxJQUFJO0lBQzNCLE9BQU8sQ0FBQyxVQUFVLE1BQU07UUFDcEIsU0FBUyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUUzQixTQUFTLE9BQU87WUFDWixPQUFPLENBQUMsTUFBTSxLQUFLLElBQUksSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQztRQUN0RSxDQUFDO1FBRUQsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUE7QUFDWixDQUFDO0FBVkQsZ0NBVUM7QUFFRCxTQUFnQixRQUFRLENBQUMsSUFBSTtJQUN6QixPQUFPLENBQUMsVUFBVSxNQUFNO1FBQ3BCLFNBQVMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFM0IsU0FBUyxPQUFPO1lBQ1osT0FBTyxDQUFDLE1BQU0sS0FBSyxJQUFJLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7UUFDdEUsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFBO0FBQ1osQ0FBQztBQVZELDRCQVVDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhlc2UgdHdvIG1peGlucyBhbmQgZXh0ZW5kZXIgZnVuY3Rpb25zIGFyZSBuZWVkZWQgYmVjYXVzZSBpbiB0aGUgYnJvd3NlciB3ZSBvbmx5IGluY2x1ZGUgc3VwZXJ0eXBlIGFuZCBzZW1vdHVzXG4vLyBhbmQgc2luY2UgY2xhc3NlcyB1c2UgdGhlc2UgaW4gdGhlaXIgZXh0ZW5kcyBoaWVyYXJjaHkgdGhleSBtdXN0IGJlIGRlZmluZWQuXG5cbmNvbnN0IF9fZXh0ZW5kcyA9XG4gICAgKHRoaXMgJiYgdGhpcy5fX2V4dGVuZHMpIHx8XG4gICAgKGZ1bmN0aW9uICgpIHtcbiAgICAgICAgY29uc3QgZXh0ZW5kU3RhdGljcyA9XG4gICAgICAgICAgICBPYmplY3Quc2V0UHJvdG90eXBlT2YgfHxcbiAgICAgICAgICAgICh7X19wcm90b19fOiBbXX0gaW5zdGFuY2VvZiBBcnJheSAmJlxuICAgICAgICAgICAgICAgIGZ1bmN0aW9uIChkLCBiKSB7XG4gICAgICAgICAgICAgICAgICAgIGQuX19wcm90b19fID0gYjtcbiAgICAgICAgICAgICAgICB9KSB8fFxuICAgICAgICAgICAgZnVuY3Rpb24gKGQsIGIpIHtcbiAgICAgICAgICAgICAgICBmb3IgKHZhciBwIGluIGIpIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKGIuaGFzT3duUHJvcGVydHkocCkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGRbcF0gPSBiW3BdO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIGZ1bmN0aW9uIChkLCBiKSB7XG4gICAgICAgICAgICBleHRlbmRTdGF0aWNzKGQsIGIpO1xuXG4gICAgICAgICAgICBmdW5jdGlvbiBfXygpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnN0cnVjdG9yID0gZDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgZC5wcm90b3R5cGUgPSBiID09PSBudWxsID8gT2JqZWN0LmNyZWF0ZShiKSA6ICgoX18ucHJvdG90eXBlID0gYi5wcm90b3R5cGUpLCBuZXcgX18oKSk7XG4gICAgICAgIH07XG4gICAgfSkoKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFBlcnNpc3RhYmxlKEJhc2UpIHtcbiAgICByZXR1cm4gKGZ1bmN0aW9uIChfc3VwZXIpIHtcbiAgICAgICAgX19leHRlbmRzKGNsYXNzXzEsIF9zdXBlcik7XG5cbiAgICAgICAgZnVuY3Rpb24gY2xhc3NfMSgpIHtcbiAgICAgICAgICAgIHJldHVybiAoX3N1cGVyICE9PSBudWxsICYmIF9zdXBlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpKSB8fCB0aGlzO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGNsYXNzXzE7XG4gICAgfSkoQmFzZSlcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFJlbW90ZWFibGUoQmFzZSkge1xuICAgIHJldHVybiAoZnVuY3Rpb24gKF9zdXBlcikge1xuICAgICAgICBfX2V4dGVuZHMoY2xhc3NfMSwgX3N1cGVyKTtcblxuICAgICAgICBmdW5jdGlvbiBjbGFzc18xKCkge1xuICAgICAgICAgICAgcmV0dXJuIChfc3VwZXIgIT09IG51bGwgJiYgX3N1cGVyLmFwcGx5KHRoaXMsIGFyZ3VtZW50cykpIHx8IHRoaXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY2xhc3NfMTtcbiAgICB9KShCYXNlKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gQmluZGFibGUoQmFzZSkge1xuICAgIHJldHVybiAoZnVuY3Rpb24gKF9zdXBlcikge1xuICAgICAgICBfX2V4dGVuZHMoY2xhc3NfMSwgX3N1cGVyKTtcblxuICAgICAgICBmdW5jdGlvbiBjbGFzc18xKCkge1xuICAgICAgICAgICAgcmV0dXJuIChfc3VwZXIgIT09IG51bGwgJiYgX3N1cGVyLmFwcGx5KHRoaXMsIGFyZ3VtZW50cykpIHx8IHRoaXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY2xhc3NfMTtcbiAgICB9KShCYXNlKVxufVxuXG5cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2V0dXBFeHRlbmRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3NldHVwRXh0ZW5kcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsa0hBQWtIO0FBQ2xILCtFQUErRTs7O0FBRS9FLE1BQU0sU0FBUyxHQUNYLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztRQUNHLE1BQU0sYUFBYSxHQUNmLE1BQU0sQ0FBQyxjQUFjO1lBQ3JCLENBQUMsRUFBQyxTQUFTLEVBQUUsRUFBRSxFQUFDLFlBQVksS0FBSztnQkFDN0IsVUFBVSxDQUFDLEVBQUUsQ0FBQztvQkFDVixDQUFDLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztnQkFDcEIsQ0FBQyxDQUFDO1lBQ04sVUFBVSxDQUFDLEVBQUUsQ0FBQztnQkFDVixLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDYixJQUFJLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLEVBQUU7d0JBQ3JCLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7cUJBQ2Y7aUJBQ0o7WUFDTCxDQUFDLENBQUM7UUFDTixPQUFPLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDakIsYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUVwQixTQUFTLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7WUFDekIsQ0FBQztZQUVELENBQUMsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMzRixDQUFDLENBQUM7SUFDTixDQUFDLENBQUMsRUFBRSxDQUFDO0FBRVQsU0FBZ0IsV0FBVyxDQUFDLElBQUk7SUFDNUIsT0FBTyxDQUFDLFVBQVUsTUFBTTtRQUNwQixTQUFTLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRTNCLFNBQVMsT0FBTztZQUNaLE9BQU8sQ0FBQyxNQUFNLEtBQUssSUFBSSxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDO1FBQ3RFLENBQUM7UUFFRCxPQUFPLE9BQU8sQ0FBQztJQUNuQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQTtBQUNaLENBQUM7QUFWRCxrQ0FVQztBQUVELFNBQWdCLFVBQVUsQ0FBQyxJQUFJO0lBQzNCLE9BQU8sQ0FBQyxVQUFVLE1BQU07UUFDcEIsU0FBUyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUUzQixTQUFTLE9BQU87WUFDWixPQUFPLENBQUMsTUFBTSxLQUFLLElBQUksSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQztRQUN0RSxDQUFDO1FBRUQsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUE7QUFDWixDQUFDO0FBVkQsZ0NBVUM7QUFFRCxTQUFnQixRQUFRLENBQUMsSUFBSTtJQUN6QixPQUFPLENBQUMsVUFBVSxNQUFNO1FBQ3BCLFNBQVMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFM0IsU0FBUyxPQUFPO1lBQ1osT0FBTyxDQUFDLE1BQU0sS0FBSyxJQUFJLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7UUFDdEUsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFBO0FBQ1osQ0FBQztBQVZELDRCQVVDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhlc2UgdHdvIG1peGlucyBhbmQgZXh0ZW5kZXIgZnVuY3Rpb25zIGFyZSBuZWVkZWQgYmVjYXVzZSBpbiB0aGUgYnJvd3NlciB3ZSBvbmx5IGluY2x1ZGUgc3VwZXJ0eXBlIGFuZCBzZW1vdHVzXG4vLyBhbmQgc2luY2UgY2xhc3NlcyB1c2UgdGhlc2UgaW4gdGhlaXIgZXh0ZW5kcyBoaWVyYXJjaHkgdGhleSBtdXN0IGJlIGRlZmluZWQuXG5cbmNvbnN0IF9fZXh0ZW5kcyA9XG4gICAgKHRoaXMgJiYgdGhpcy5fX2V4dGVuZHMpIHx8XG4gICAgKGZ1bmN0aW9uICgpIHtcbiAgICAgICAgY29uc3QgZXh0ZW5kU3RhdGljcyA9XG4gICAgICAgICAgICBPYmplY3Quc2V0UHJvdG90eXBlT2YgfHxcbiAgICAgICAgICAgICh7X19wcm90b19fOiBbXX0gaW5zdGFuY2VvZiBBcnJheSAmJlxuICAgICAgICAgICAgICAgIGZ1bmN0aW9uIChkLCBiKSB7XG4gICAgICAgICAgICAgICAgICAgIGQuX19wcm90b19fID0gYjtcbiAgICAgICAgICAgICAgICB9KSB8fFxuICAgICAgICAgICAgZnVuY3Rpb24gKGQsIGIpIHtcbiAgICAgICAgICAgICAgICBmb3IgKHZhciBwIGluIGIpIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKGIuaGFzT3duUHJvcGVydHkocCkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGRbcF0gPSBiW3BdO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIGZ1bmN0aW9uIChkLCBiKSB7XG4gICAgICAgICAgICBleHRlbmRTdGF0aWNzKGQsIGIpO1xuXG4gICAgICAgICAgICBmdW5jdGlvbiBfXygpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnN0cnVjdG9yID0gZDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgZC5wcm90b3R5cGUgPSBiID09PSBudWxsID8gT2JqZWN0LmNyZWF0ZShiKSA6ICgoX18ucHJvdG90eXBlID0gYi5wcm90b3R5cGUpLCBuZXcgX18oKSk7XG4gICAgICAgIH07XG4gICAgfSkoKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFBlcnNpc3RhYmxlKEJhc2UpIHtcbiAgICByZXR1cm4gKGZ1bmN0aW9uIChfc3VwZXIpIHtcbiAgICAgICAgX19leHRlbmRzKGNsYXNzXzEsIF9zdXBlcik7XG5cbiAgICAgICAgZnVuY3Rpb24gY2xhc3NfMSgpIHtcbiAgICAgICAgICAgIHJldHVybiAoX3N1cGVyICE9PSBudWxsICYmIF9zdXBlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpKSB8fCB0aGlzO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGNsYXNzXzE7XG4gICAgfSkoQmFzZSlcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFJlbW90ZWFibGUoQmFzZSkge1xuICAgIHJldHVybiAoZnVuY3Rpb24gKF9zdXBlcikge1xuICAgICAgICBfX2V4dGVuZHMoY2xhc3NfMSwgX3N1cGVyKTtcblxuICAgICAgICBmdW5jdGlvbiBjbGFzc18xKCkge1xuICAgICAgICAgICAgcmV0dXJuIChfc3VwZXIgIT09IG51bGwgJiYgX3N1cGVyLmFwcGx5KHRoaXMsIGFyZ3VtZW50cykpIHx8IHRoaXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY2xhc3NfMTtcbiAgICB9KShCYXNlKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gQmluZGFibGUoQmFzZSkge1xuICAgIHJldHVybiAoZnVuY3Rpb24gKF9zdXBlcikge1xuICAgICAgICBfX2V4dGVuZHMoY2xhc3NfMSwgX3N1cGVyKTtcblxuICAgICAgICBmdW5jdGlvbiBjbGFzc18xKCkge1xuICAgICAgICAgICAgcmV0dXJuIChfc3VwZXIgIT09IG51bGwgJiYgX3N1cGVyLmFwcGx5KHRoaXMsIGFyZ3VtZW50cykpIHx8IHRoaXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY2xhc3NfMTtcbiAgICB9KShCYXNlKVxufVxuXG5cbiJdfQ== |
@@ -0,1 +1,4 @@ | ||
## 7.0.0 | ||
* target es2020 | ||
* use supertype 6, remove emitDecoratorMetadata | ||
## 6.0.1 | ||
@@ -2,0 +5,0 @@ * bump nconf version due to security vulnerability. |
{ | ||
"name": "@haventech/semotus", | ||
"version": "6.0.1", | ||
"version": "7.0.0-beta.1", | ||
"description": "A subclass of supertype that synchronizes sets of objects.", | ||
@@ -30,3 +30,3 @@ "homepage": "https://github.com/haven-life/amorphic-framework", | ||
"setup": "npm install", | ||
"test": "mocha -- test/types.js test/javascript/semotus.js", | ||
"test": "mocha -- test/javascript/types.js test/javascript/semotus.js", | ||
"test:ts": "npm run test:ts:supertype && npm run test:ts:syncstates", | ||
@@ -41,3 +41,3 @@ "test:ts:compiled": "mocha test/supertype/semotus.js", | ||
"devDependencies": { | ||
"@haventech/supertype": "5.x", | ||
"@haventech/supertype": "6.0.0-beta.3", | ||
"@types/chai": "4.3.0", | ||
@@ -44,0 +44,0 @@ "@types/express": "4.17.13", |
@@ -90,3 +90,3 @@ /** | ||
export function Supertype(template, objectTemplate, Supertype) { | ||
return Supertype.call(template, objectTemplate); | ||
return Reflect.construct( Supertype, [objectTemplate], template.constructor ); | ||
} | ||
@@ -93,0 +93,0 @@ |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
557820
6536
1
1