@haventech/supertype
Advanced tools
Comparing version 5.1.0-beta.0 to 6.0.0-beta.0
export { Supertype } from './Supertype'; | ||
import 'reflect-metadata'; | ||
/** | ||
@@ -4,0 +3,0 @@ * |
@@ -6,4 +6,3 @@ "use strict"; | ||
Object.defineProperty(exports, "Supertype", { enumerable: true, get: function () { return Supertype_1.Supertype; } }); | ||
var ObjectTemplate_1 = require("./ObjectTemplate"); | ||
require("reflect-metadata"); | ||
const ObjectTemplate_1 = require("./ObjectTemplate"); | ||
/** | ||
@@ -112,3 +111,3 @@ * | ||
function getName() { | ||
return target.toString().match(/function ([^(]*)/)[1]; | ||
return ObjectTemplate_1.ObjectTemplate.getName(target); | ||
} | ||
@@ -134,14 +133,4 @@ function getDictionary() { | ||
target.__amorphicprops__ = target.hasOwnProperty('__amorphicprops__') ? target.__amorphicprops__ : {}; | ||
var reflectionType = Reflect.getMetadata('design:type', target, targetKey); | ||
var declaredType = props.type; | ||
var type = reflectionType !== Array ? declaredType || reflectionType : declaredType; | ||
// Type mismatches | ||
if (declaredType && reflectionType && reflectionType !== Array) { | ||
target.__exceptions__ = target.__exceptions__ || {}; | ||
target.__exceptions__[targetKey] = function (className, prop) { | ||
return className + '.' + prop + ' - decorator type does not match actual type'; | ||
}; | ||
// Deferred type | ||
} | ||
else if (typeof props.getType === 'function') { | ||
let type = props.type; | ||
if (typeof props.getType === 'function') { | ||
target.__deferredType__ = target.hasOwnProperty('__deferredType__') ? target.__deferredType__ : {}; | ||
@@ -159,9 +148,2 @@ target.__deferredType__[targetKey] = props.getType; | ||
} | ||
if (reflectionType === Array) { | ||
props.type = Array; | ||
props.of = type; | ||
} | ||
else { | ||
props.type = type; | ||
} | ||
target.__amorphicprops__[targetKey] = props; | ||
@@ -177,2 +159,2 @@ }; | ||
exports.remote = remote; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["export { Supertype } from './Supertype';\nimport { ObjectTemplate } from './ObjectTemplate';\n\nimport 'reflect-metadata';\n\n/**\n    * \n    * @param {*} objectProps- optional property for passing params into supertypeclass, if no params, is undefined,\n    *                      first param of this function defaults to objectTemplate instead\n    * @param {*} objectTemplate \n    * \n    * @TODO: fix return types\n    * https://github.com/haven-life/supertype/issues/6\n    */\nexport function supertypeClass(objectProps?, objectTemplate?): any {\n\n    // When used as @supertypeClass({bla bla bla}), the decorator is first called as it is\n    // is being passed into the decorator processor and so it needs to return a function\n    // so that it will be called again when the decorators are actually processed.  Kinda spliffy.\n\n    // Called by decorator processor\n    if (objectProps.prototype) { // if objectProps is the class (second pass if passed with {toClient style params} or first pass when @supertypeClass no paren and args)\n        return decorator(objectProps);\n    }\n\n    // Called first time with parameter\n    var props = objectProps;\n    return decorator;\n\n    // Decorator Workerbee\n    function decorator(target) {\n        objectTemplate = objectTemplate || ObjectTemplate;\n\n        target.prototype.__template__ = target;\n        target.prototype.amorphicClass = target;\n        target.prototype.amorphicGetClassName = function () { return target.__name__ };\n        target.isObjectTemplate = true;\n        target.__injections__ = [];\n        target.__objectTemplate__ = objectTemplate;\n        var createProps = objectTemplate.getTemplateProperties(props || {});\n        target.__toClient__ = createProps.__toClient__;\n        target.__toServer__ = createProps.__toServer__;\n        target.__shadowChildren__ = [];\n\n        // Push an array of template references (we can't get at their names now).  Later we will\n        // use this to construct __dictionary__\n        objectTemplate.__templates__ = objectTemplate.__templates__ || [];\n        objectTemplate.__templates__.push(target);\n\n\n        // We can never reference template functions at compile time which is when this decorator is executed\n        // Therefore we have to setup getters for properties that need access to the template functions so\n        // that we can ensure they are fully resolved before accessing them\n        Object.defineProperty(target, 'defineProperties', { get: defineProperties });\n        Object.defineProperty(target, 'amorphicProperties', { get: defineProperties });\n        Object.defineProperty(target, '__name__', { get: getName });\n        Object.defineProperty(target, 'amorphicClassName', { get: getName });\n        Object.defineProperty(target, 'parentTemplate', { get: getParent });\n        Object.defineProperty(target, '__parent__', { get: getParent });\n        Object.defineProperty(target, '__children__', { get: getChildren });\n        Object.defineProperty(target, 'amorphicParentClass', { get: getParent });\n        Object.defineProperty(target, 'amorphicChildClasses', { get: getChildren });\n        Object.defineProperty(target, 'amorphicStatic', { get: function () { return objectTemplate } });\n\n        target.fromPOJO = function fromPOJO(pojo) {\n            return objectTemplate.fromPOJO(pojo, target);\n        };\n\n        target.fromJSON = // Legacy\n            target.amorphicFromJSON = function fromJSON(str, idPrefix) {\n                return objectTemplate.fromJSON(str, target, idPrefix);\n            };\n\n        target.getProperties = // Legacy\n            target.amorphicGetProperties = function getProperties(includeVirtual) {\n                return objectTemplate._getDefineProperties(target, undefined, includeVirtual);\n            };\n\n        target.createProperty = // Legacy\n            target.amorphicCreateProperty = function (propertyName, defineProperty) {\n                if (defineProperty.body) {\n                    target.prototype[propertyName] = objectTemplate._setupFunction(propertyName, defineProperty.body,\n                        defineProperty.on, defineProperty.validate);\n                }\n                else {\n                    target.prototype.__amorphicprops__[propertyName] = defineProperty;\n                    if (typeof defineProperty.value in ['string', 'number'] || defineProperty.value == null) {\n                        Object.defineProperty(target.prototype, propertyName,\n                            { enumerable: true, writable: true, value: defineProperty.value });\n                    }\n                    else {\n                        Object.defineProperty(target.prototype, propertyName, {\n                            enumerable: true,\n                            get: function () {\n                                if (!this['__' + propertyName]) {\n                                    this['__' + propertyName] =\n                                        ObjectTemplate.clone(defineProperty.value, defineProperty.of ||\n                                            defineProperty.type || null);\n                                }\n                                return this['__' + propertyName];\n                            },\n                            set: function (value) {\n                                this['__' + propertyName] = value;\n                            }\n                        });\n                    }\n                }\n            };\n\n        if (target.prototype.__exceptions__) {\n            objectTemplate.__exceptions__ = objectTemplate.__exceptions__ || [];\n            for (var exceptionKey in target.prototype.__exceptions__) {\n                objectTemplate.__exceptions__.push({\n                    func: target.prototype.__exceptions__[exceptionKey],\n                    class: getName,\n                    prop: exceptionKey\n                });\n            }\n        }\n\n        function defineProperties() {\n            return target.prototype.__amorphicprops__;\n        }\n        function getName() {\n            return target.toString().match(/function ([^(]*)/)[1];\n        }\n        function getDictionary() {\n            objectTemplate.getClasses();\n        }\n        function getParent() {\n            getDictionary();\n            return target.__shadowParent__;\n        }\n        function getChildren() {\n            getDictionary();\n            return target.__shadowChildren__;\n        }\n    }\n}\n\n\nexport function property(props?): any {\n    return function (target, targetKey) {\n        props = props || {};\n        props.enumerable = true;\n        target.__amorphicprops__ = target.hasOwnProperty('__amorphicprops__') ? target.__amorphicprops__ : {};\n        var reflectionType = Reflect.getMetadata('design:type', target, targetKey);\n        var declaredType = props.type;\n        var type = reflectionType !== Array ? declaredType || reflectionType : declaredType;\n    // Type mismatches\n        if (declaredType && reflectionType && reflectionType !== Array) {\n            target.__exceptions__ = target.__exceptions__ || {};\n            target.__exceptions__[targetKey] = function (className, prop) {\n                return className + '.' + prop + ' - decorator type does not match actual type';\n            };\n    // Deferred type\n        }\n        else if (typeof props.getType === 'function') {\n            target.__deferredType__ = target.hasOwnProperty('__deferredType__') ? target.__deferredType__ : {};\n            target.__deferredType__[targetKey] = props.getType;\n            delete props.getType;\n        }\n        else if (!type) {\n            target.__exceptions__ = target.__exceptions__ || {};\n            target.__exceptions__[targetKey] = function (className, prop) {\n                return className + '.' + prop +\n                ' - type is undefined. Circular reference? Try @property({getType: () => {return ' +\n                prop[0].toUpperCase() + prop.substr(1) + '}})';\n\n            };\n        }\n        if (reflectionType === Array) {\n            props.type = Array;\n            props.of = type;\n        }\n        else {\n            props.type = type;\n        }\n        target.__amorphicprops__[targetKey] = props;\n    };\n};\n\nexport function remote(defineProperty) {\n    return function (target, propertyName, descriptor) {\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../src/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["export { Supertype } from './Supertype';\nimport { ObjectTemplate } from './ObjectTemplate';\n\n/**\n    * \n    * @param {*} objectProps- optional property for passing params into supertypeclass, if no params, is undefined,\n    *                      first param of this function defaults to objectTemplate instead\n    * @param {*} objectTemplate \n    * \n    * @TODO: fix return types\n    * https://github.com/haven-life/supertype/issues/6\n    */\nexport function supertypeClass(objectProps?, objectTemplate?): any {\n\n    // When used as @supertypeClass({bla bla bla}), the decorator is first called as it is\n    // is being passed into the decorator processor and so it needs to return a function\n    // so that it will be called again when the decorators are actually processed.  Kinda spliffy.\n\n    // Called by decorator processor\n    if (objectProps.prototype) { // if objectProps is the class (second pass if passed with {toClient style params} or first pass when @supertypeClass no paren and args)\n        return decorator(objectProps);\n    }\n\n    // Called first time with parameter\n    var props = objectProps;\n    return decorator;\n\n    // Decorator Workerbee\n    function decorator(target) {\n        objectTemplate = objectTemplate || ObjectTemplate;\n\n        target.prototype.__template__ = target;\n        target.prototype.amorphicClass = target;\n        target.prototype.amorphicGetClassName = function () { return target.__name__ };\n        target.isObjectTemplate = true;\n        target.__injections__ = [];\n        target.__objectTemplate__ = objectTemplate;\n        var createProps = objectTemplate.getTemplateProperties(props || {});\n        target.__toClient__ = createProps.__toClient__;\n        target.__toServer__ = createProps.__toServer__;\n        target.__shadowChildren__ = [];\n\n        // Push an array of template references (we can't get at their names now).  Later we will\n        // use this to construct __dictionary__\n        objectTemplate.__templates__ = objectTemplate.__templates__ || [];\n        objectTemplate.__templates__.push(target);\n\n\n        // We can never reference template functions at compile time which is when this decorator is executed\n        // Therefore we have to setup getters for properties that need access to the template functions so\n        // that we can ensure they are fully resolved before accessing them\n        Object.defineProperty(target, 'defineProperties', { get: defineProperties });\n        Object.defineProperty(target, 'amorphicProperties', { get: defineProperties });\n        Object.defineProperty(target, '__name__', { get: getName });\n        Object.defineProperty(target, 'amorphicClassName', { get: getName });\n        Object.defineProperty(target, 'parentTemplate', { get: getParent });\n        Object.defineProperty(target, '__parent__', { get: getParent });\n        Object.defineProperty(target, '__children__', { get: getChildren });\n        Object.defineProperty(target, 'amorphicParentClass', { get: getParent });\n        Object.defineProperty(target, 'amorphicChildClasses', { get: getChildren });\n        Object.defineProperty(target, 'amorphicStatic', { get: function () { return objectTemplate } });\n\n        target.fromPOJO = function fromPOJO(pojo) {\n            return objectTemplate.fromPOJO(pojo, target);\n        };\n\n        target.fromJSON = // Legacy\n            target.amorphicFromJSON = function fromJSON(str, idPrefix) {\n                return objectTemplate.fromJSON(str, target, idPrefix);\n            };\n\n        target.getProperties = // Legacy\n            target.amorphicGetProperties = function getProperties(includeVirtual) {\n                return objectTemplate._getDefineProperties(target, undefined, includeVirtual);\n            };\n\n        target.createProperty = // Legacy\n            target.amorphicCreateProperty = function (propertyName, defineProperty) {\n                if (defineProperty.body) {\n                    target.prototype[propertyName] = objectTemplate._setupFunction(propertyName, defineProperty.body,\n                        defineProperty.on, defineProperty.validate);\n                }\n                else {\n                    target.prototype.__amorphicprops__[propertyName] = defineProperty;\n                    if (typeof defineProperty.value in ['string', 'number'] || defineProperty.value == null) {\n                        Object.defineProperty(target.prototype, propertyName,\n                            { enumerable: true, writable: true, value: defineProperty.value });\n                    }\n                    else {\n                        Object.defineProperty(target.prototype, propertyName, {\n                            enumerable: true,\n                            get: function () {\n                                if (!this['__' + propertyName]) {\n                                    this['__' + propertyName] =\n                                        ObjectTemplate.clone(defineProperty.value, defineProperty.of ||\n                                            defineProperty.type || null);\n                                }\n                                return this['__' + propertyName];\n                            },\n                            set: function (value) {\n                                this['__' + propertyName] = value;\n                            }\n                        });\n                    }\n                }\n            };\n\n        if (target.prototype.__exceptions__) {\n            objectTemplate.__exceptions__ = objectTemplate.__exceptions__ || [];\n            for (var exceptionKey in target.prototype.__exceptions__) {\n                objectTemplate.__exceptions__.push({\n                    func: target.prototype.__exceptions__[exceptionKey],\n                    class: getName,\n                    prop: exceptionKey\n                });\n            }\n        }\n\n        function defineProperties() {\n            return target.prototype.__amorphicprops__;\n        }\n        function getName() {\n            return ObjectTemplate.getName(target);\n        }\n        function getDictionary() {\n            objectTemplate.getClasses();\n        }\n        function getParent() {\n            getDictionary();\n            return target.__shadowParent__;\n        }\n        function getChildren() {\n            getDictionary();\n            return target.__shadowChildren__;\n        }\n    }\n}\n\n\nexport function property(props?): any {\n    return function (target, targetKey) {\n        props = props || {};\n        props.enumerable = true;\n        target.__amorphicprops__ = target.hasOwnProperty('__amorphicprops__') ? target.__amorphicprops__ : {};\n        let type = props.type;\n        if (typeof props.getType === 'function') {\n            target.__deferredType__ = target.hasOwnProperty('__deferredType__') ? target.__deferredType__ : {};\n            target.__deferredType__[targetKey] = props.getType;\n            delete props.getType;\n        }\n        else if (!type) {\n            target.__exceptions__ = target.__exceptions__ || {};\n            target.__exceptions__[targetKey] = function (className, prop) {\n                return className + '.' + prop +\n                ' - type is undefined. Circular reference? Try @property({getType: () => {return ' +\n                prop[0].toUpperCase() + prop.substr(1) + '}})';\n\n            };\n        }\n        target.__amorphicprops__[targetKey] = props;\n    };\n};\n\nexport function remote(defineProperty) {\n    return function (target, propertyName, descriptor) {\n    }\n}"]} |
@@ -24,8 +24,8 @@ "use strict"; | ||
exports.SupertypeSession = exports.amorphicStatic = void 0; | ||
var ObjectTemplate_1 = require("./ObjectTemplate"); | ||
const ObjectTemplate_1 = require("./ObjectTemplate"); | ||
ObjectTemplate_1.ObjectTemplate.init(); | ||
exports.default = ObjectTemplate_1.ObjectTemplate; | ||
var amorphicStatic = ObjectTemplate_1.ObjectTemplate.amorphicStatic; | ||
let amorphicStatic = ObjectTemplate_1.ObjectTemplate.amorphicStatic; | ||
exports.amorphicStatic = amorphicStatic; | ||
var SupertypeSession = ObjectTemplate_1.ObjectTemplate.amorphicStatic; | ||
let SupertypeSession = ObjectTemplate_1.ObjectTemplate.amorphicStatic; | ||
exports.SupertypeSession = SupertypeSession; | ||
@@ -45,2 +45,2 @@ var StatsdHelper_1 = require("./StatsdHelper"); | ||
Object.defineProperty(exports, "remote", { enumerable: true, get: function () { return decorators_1.remote; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJHOzs7QUFFSCxtREFBa0Q7QUFFbEQsK0JBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztBQUN0QixrQkFBZSwrQkFBYyxDQUFDO0FBRTlCLElBQUksY0FBYyxHQUFHLCtCQUFjLENBQUMsY0FBYyxDQUFDO0FBSzFDLHdDQUFjO0FBSnZCLElBQUksZ0JBQWdCLEdBQUcsK0JBQWMsQ0FBQyxjQUFjLENBQUM7QUFJNUIsNENBQWdCO0FBRnpDLCtDQUE4QztBQUFyQyw0R0FBQSxZQUFZLE9BQUE7QUFHckIscURBQW9EO0FBQTNDLGtIQUFBLGVBQWUsT0FBQTtBQUN4QixxREFBMEU7QUFBakUsa0hBQUEsZUFBZSxPQUFBO0FBQUUsdUhBQUEsb0JBQW9CLE9BQUE7QUFDOUMseUNBQXdDO0FBQS9CLHNHQUFBLFNBQVMsT0FBQTtBQUNsQiwyQ0FBZ0U7QUFBdkQsNEdBQUEsY0FBYyxPQUFBO0FBQUUsc0dBQUEsUUFBUSxPQUFBO0FBQUUsb0dBQUEsTUFBTSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyogQ29weXJpZ2h0IDIwMTEtMjAxMiBTYW0gRWxzYW1tYW5cbiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmdcbiBhIGNvcHkgb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGVcbiBcIlNvZnR3YXJlXCIpLCB0byBkZWFsIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmdcbiB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsXG4gZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvXG4gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvXG4gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuXG4gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmVcbiBpbmNsdWRlZCBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cblxuIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsXG4gRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GXG4gTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkRcbiBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFXG4gTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTlxuIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTlxuIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLlxuICovXG5cbmltcG9ydCB7IE9iamVjdFRlbXBsYXRlIH0gZnJvbSAnLi9PYmplY3RUZW1wbGF0ZSc7XG5cbk9iamVjdFRlbXBsYXRlLmluaXQoKTtcbmV4cG9ydCBkZWZhdWx0IE9iamVjdFRlbXBsYXRlO1xuXG5sZXQgYW1vcnBoaWNTdGF0aWMgPSBPYmplY3RUZW1wbGF0ZS5hbW9ycGhpY1N0YXRpYztcbmxldCBTdXBlcnR5cGVTZXNzaW9uID0gT2JqZWN0VGVtcGxhdGUuYW1vcnBoaWNTdGF0aWM7XG5leHBvcnQgeyBTdGF0c2RDbGllbnRJbnRlcmZhY2UgfSBmcm9tICcuL1N0YXRzZENsaWVudEludGVyZmFjZSc7XG5leHBvcnQgeyBTdGF0c2RIZWxwZXIgfSBmcm9tICcuL1N0YXRzZEhlbHBlcic7XG5cbmV4cG9ydCB7IGFtb3JwaGljU3RhdGljLCBTdXBlcnR5cGVTZXNzaW9uIH07XG5leHBvcnQgeyBTdXBlcnR5cGVMb2dnZXIgfSBmcm9tICcuL1N1cGVydHlwZUxvZ2dlcic7XG5leHBvcnQgeyBTdXBlcnR5cGVDb25maWcsIEJ1aWxkU3VwZXJ0eXBlQ29uZmlnIH0gZnJvbSAnLi9TdXBlcnR5cGVDb25maWcnO1xuZXhwb3J0IHsgU3VwZXJ0eXBlIH0gZnJvbSAnLi9TdXBlcnR5cGUnO1xuZXhwb3J0IHsgc3VwZXJ0eXBlQ2xhc3MsIHByb3BlcnR5LCByZW1vdGUgfSBmcm9tICcuL2RlY29yYXRvcnMnOyJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJHOzs7QUFFSCxxREFBa0Q7QUFFbEQsK0JBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztBQUN0QixrQkFBZSwrQkFBYyxDQUFDO0FBRTlCLElBQUksY0FBYyxHQUFHLCtCQUFjLENBQUMsY0FBYyxDQUFDO0FBSzFDLHdDQUFjO0FBSnZCLElBQUksZ0JBQWdCLEdBQUcsK0JBQWMsQ0FBQyxjQUFjLENBQUM7QUFJNUIsNENBQWdCO0FBRnpDLCtDQUE4QztBQUFyQyw0R0FBQSxZQUFZLE9BQUE7QUFHckIscURBQW9EO0FBQTNDLGtIQUFBLGVBQWUsT0FBQTtBQUN4QixxREFBMEU7QUFBakUsa0hBQUEsZUFBZSxPQUFBO0FBQUUsdUhBQUEsb0JBQW9CLE9BQUE7QUFDOUMseUNBQXdDO0FBQS9CLHNHQUFBLFNBQVMsT0FBQTtBQUNsQiwyQ0FBZ0U7QUFBdkQsNEdBQUEsY0FBYyxPQUFBO0FBQUUsc0dBQUEsUUFBUSxPQUFBO0FBQUUsb0dBQUEsTUFBTSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyogQ29weXJpZ2h0IDIwMTEtMjAxMiBTYW0gRWxzYW1tYW5cbiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmdcbiBhIGNvcHkgb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGVcbiBcIlNvZnR3YXJlXCIpLCB0byBkZWFsIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmdcbiB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsXG4gZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvXG4gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvXG4gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuXG4gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmVcbiBpbmNsdWRlZCBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cblxuIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsXG4gRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GXG4gTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkRcbiBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFXG4gTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTlxuIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTlxuIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLlxuICovXG5cbmltcG9ydCB7IE9iamVjdFRlbXBsYXRlIH0gZnJvbSAnLi9PYmplY3RUZW1wbGF0ZSc7XG5cbk9iamVjdFRlbXBsYXRlLmluaXQoKTtcbmV4cG9ydCBkZWZhdWx0IE9iamVjdFRlbXBsYXRlO1xuXG5sZXQgYW1vcnBoaWNTdGF0aWMgPSBPYmplY3RUZW1wbGF0ZS5hbW9ycGhpY1N0YXRpYztcbmxldCBTdXBlcnR5cGVTZXNzaW9uID0gT2JqZWN0VGVtcGxhdGUuYW1vcnBoaWNTdGF0aWM7XG5leHBvcnQgeyBTdGF0c2RDbGllbnRJbnRlcmZhY2UgfSBmcm9tICcuL1N0YXRzZENsaWVudEludGVyZmFjZSc7XG5leHBvcnQgeyBTdGF0c2RIZWxwZXIgfSBmcm9tICcuL1N0YXRzZEhlbHBlcic7XG5cbmV4cG9ydCB7IGFtb3JwaGljU3RhdGljLCBTdXBlcnR5cGVTZXNzaW9uIH07XG5leHBvcnQgeyBTdXBlcnR5cGVMb2dnZXIgfSBmcm9tICcuL1N1cGVydHlwZUxvZ2dlcic7XG5leHBvcnQgeyBTdXBlcnR5cGVDb25maWcsIEJ1aWxkU3VwZXJ0eXBlQ29uZmlnIH0gZnJvbSAnLi9TdXBlcnR5cGVDb25maWcnO1xuZXhwb3J0IHsgU3VwZXJ0eXBlIH0gZnJvbSAnLi9TdXBlcnR5cGUnO1xuZXhwb3J0IHsgc3VwZXJ0eXBlQ2xhc3MsIHByb3BlcnR5LCByZW1vdGUgfSBmcm9tICcuL2RlY29yYXRvcnMnOyJdfQ== |
@@ -176,2 +176,3 @@ import * as serializer from './serializer'; | ||
}; | ||
static getName(object: any): any; | ||
/** | ||
@@ -199,15 +200,2 @@ * Overridden by other Type Systems to cache or globally identify objects | ||
/** | ||
* Used by template setup to create an property descriptor for use by the constructor | ||
* | ||
* @param {unknown} propertyName is the name of the property | ||
* @param {unknown} defineProperty is the property descriptor passed to the template | ||
* @param {unknown} objectProperties is all properties that will be processed manually. A new property is | ||
* added to this if the property needs to be initialized by value | ||
* @param {unknown} defineProperties is all properties that will be passed to Object.defineProperties | ||
* A new property will be added to this object | ||
* | ||
* @private | ||
*/ | ||
static _setupProperty(propertyName: any, defineProperty: any, objectProperties: any, defineProperties: any): void; | ||
/** | ||
* Clone an object created from an ObjectTemplate | ||
@@ -285,45 +273,22 @@ * Used only within supertype (see copyObject for general copy) | ||
/** | ||
/** | ||
* Find the right subclass to instantiate by either looking at the | ||
* declared list in the subClasses define property or walking through | ||
* the subclasses of the declared template | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} objId unknown | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
static _resolveSubClass(template: any, objId: any, defineProperty: any): any; | ||
/** | ||
* Walk recursively through extensions of template via __children__ | ||
* looking for a name match | ||
* Return the highest level template | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} templateName unknown | ||
* | ||
* @returns {*} | ||
* | ||
* @private | ||
*/ | ||
static _findSubClass(template: any, templateName: any): any; | ||
static _getBaseClass(template: any): any; | ||
/** | ||
* Return the highest level template | ||
* An overridable function used to create an object from a template and optionally | ||
* manage the caching of that object (used by derivative type systems). It | ||
* preserves the original id of an object | ||
* | ||
* @param {unknown} template unknown | ||
* | ||
* @param {unknown} template of object | ||
* @param {unknown} objId and id (if present) | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* | ||
* @private | ||
*/ | ||
static _getBaseClass(template: any): any; | ||
/** | ||
* An overridable function used to create an object from a template and optionally | ||
* manage the caching of that object (used by derivative type systems). It | ||
* preserves the original id of an object | ||
* | ||
* @param {unknown} template of object | ||
* @param {unknown} objId and id (if present) | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
static _createEmptyObject(template: any, objId: any, defineProperty: any): any; | ||
@@ -330,0 +295,0 @@ /** |
@@ -64,3 +64,3 @@ "use strict"; | ||
} | ||
var obj; | ||
let obj; | ||
if (creator) { | ||
@@ -170,2 +170,2 @@ obj = creator(parent, prop, template, idMap[pojo.__id__.toString()], pojo.__transient__); | ||
; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"serializer.js","sourceRoot":"","sources":["../src/serializer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ObjectTemplate.toJSONString;\n */\n/**\n * Convert an object to JSON, stripping any recursive object references so they can be\n * reconstituted later\n *\n * @param {unknown} obj unknown\n * @param {unknown} cb unknown\n *\n * @returns {unknown}\n */\nexport function toJSONString(obj, cb?) {\n    var idMap = [];\n\n    try {\n        return JSON.stringify(obj, function a(key, value) {\n            if (key === '__objectTemplate__' || key === 'amorphic') {\n                return null;\n            }\n            if (value && value.__template__ && value.__id__) {\n                if (idMap[value.__id__]) {\n                    value = { __id__: value.__id__.toString() };\n                }\n                else {\n                    idMap[value.__id__.toString()] = value;\n                }\n            }\n\n            if (cb) {\n                return cb(key, value);\n            }\n\n            return value;\n        });\n    }\n    catch (e) {\n        throw e;\n    }\n}\n\nfunction propXfer(prop, pojo, obj) {\n    if (pojo[prop]) {\n        obj[prop] = pojo[prop];\n    }\n}\n\n/**\n * ObjectTemplate.fromPOJO\n */\nexport function fromPOJO(pojo, template, defineProperty?, idMap?, idQualifier?, parent?, prop?, creator?) {\n    function getId(id) {\n        if (typeof (idQualifier) !== 'undefined') {\n            return id + '-' + idQualifier;\n        }\n\n        return id;\n    }\n\n    // For recording back refs\n    if (!idMap) {\n        idMap = {};\n    }\n\n    if (!pojo.__id__) {\n        return;\n    }\n\n    var obj;\n\n    if (creator) {\n        obj = creator(parent, prop, template, idMap[pojo.__id__.toString()], pojo.__transient__);\n\n        if (obj instanceof Array) {\n            obj = obj[0];\n            idMap[obj.__id__.toString()] = obj;\n            return obj;\n        }\n\n        if (typeof (obj) === 'undefined') {\n            return null;\n        }\n\n        if (!obj) {\n            this.noInit = true;\n            obj = new template();\n            this.noInit = false;\n        }\n    }\n    else {\n        obj = this._createEmptyObject(template, getId(pojo.__id__.toString()), defineProperty, pojo.__transient__);\n    }\n\n    idMap[getId(pojo.__id__.toString())] = obj;\n\n    // Go through all the properties and transfer them to newly created object\n    var props = obj.__template__.getProperties();\n\n    for (var propb in pojo) {\n        propb = propb.replace(/^__/, '');\n        var defineProp = props[propb];\n        if (!defineProp)\n            continue;\n        var type = defineProp.type;\n\n        // Because semotus can serialize only the shadow properties we try and restore them\n        var pojoProp = (type && typeof pojo['__' + propb] !== 'undefined') ? '__' + propb : propb;\n\n        if (type && pojo[pojoProp] == null) {\n            obj[propb] = null;\n        }\n        else if (type && typeof (pojo[pojoProp]) !== 'undefined') {\n            if (type == Array && defineProp.of && defineProp.of.isObjectTemplate) { // Array of templated objects\n                var arrayDirections = null;\n\n                if (creator) {\n                    arrayDirections = creator(obj, propb, defineProp.of, idMap[pojo.__id__.toString()], pojo.__transient__);\n                }\n\n                if (typeof (arrayDirections) !== 'undefined') {\n                    obj[propb] = [];\n\n                    for (var ix = 0; ix < pojo[pojoProp].length; ++ix) {\n                        var atype = pojo[pojoProp][ix].__template__ || defineProp.of;\n                        if (pojo[pojoProp][ix]) {\n                            if (pojo[pojoProp][ix].__id__ && idMap[getId(pojo[pojoProp][ix].__id__.toString())]) {\n                                obj[propb][ix] = idMap[getId(pojo[pojoProp][ix].__id__.toString())];\n                            }\n                            else {\n                                obj[propb][ix] = this.fromPOJO(pojo[pojoProp][ix], atype, defineProp, idMap, idQualifier, obj, propb, creator);\n                            }\n                        }\n                        else {\n                            obj[propb][ix] = null;\n                        }\n                    }\n                }\n                else {\n                    obj[propb] = [];\n                }\n            }\n            else if (type.isObjectTemplate) { // Templated objects\n                var otype = pojo[pojoProp].__template__ || type;\n                if (pojo[pojoProp].__id__ && idMap[getId(pojo[pojoProp].__id__.toString())]) {\n                    obj[propb] = idMap[getId(pojo[pojoProp].__id__.toString())];\n                }\n                else {\n                    obj[propb] = this.fromPOJO(pojo[pojoProp], otype, defineProp, idMap, idQualifier, obj, propb, creator);\n                }\n            }\n            else if (type == Date) {\n                if (pojo[pojoProp]) {\n                    obj[propb] = new Date(pojo[pojoProp]);\n                }\n                else {\n                    obj[propb] = null;\n                }\n            }\n            else {\n                obj[propb] = pojo[pojoProp];\n            }\n        }\n    }\n\n    // For the benefit of persistObjectTemplate\n    if (!creator && pojo._id) {\n        obj._id = getId(pojo._id);\n    }\n\n    if (!creator) {\n        propXfer('__changed__', pojo, obj);\n        propXfer('__version__', pojo, obj);\n    }\n\n    propXfer('__toServer__', pojo, obj);\n    propXfer('__toClient__', pojo, obj);\n\n    return obj;\n};\n\n\n/**\n * ObjectTemplate.fromJSON\n */\nexport function fromJSON(str, template, idQualifier) {\n    return this.fromPOJO(JSON.parse(str), template, null, null, idQualifier);\n};\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"serializer.js","sourceRoot":"","sources":["../src/serializer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ObjectTemplate.toJSONString;\n */\n/**\n * Convert an object to JSON, stripping any recursive object references so they can be\n * reconstituted later\n *\n * @param {unknown} obj unknown\n * @param {unknown} cb unknown\n *\n * @returns {unknown}\n */\nexport function toJSONString(obj, cb?) {\n    var idMap = [];\n\n    try {\n        return JSON.stringify(obj, function a(key, value) {\n            if (key === '__objectTemplate__' || key === 'amorphic') {\n                return null;\n            }\n            if (value && value.__template__ && value.__id__) {\n                if (idMap[value.__id__]) {\n                    value = { __id__: value.__id__.toString() };\n                }\n                else {\n                    idMap[value.__id__.toString()] = value;\n                }\n            }\n\n            if (cb) {\n                return cb(key, value);\n            }\n\n            return value;\n        });\n    }\n    catch (e) {\n        throw e;\n    }\n}\n\nfunction propXfer(prop, pojo, obj) {\n    if (pojo[prop]) {\n        obj[prop] = pojo[prop];\n    }\n}\n\n/**\n * ObjectTemplate.fromPOJO\n */\nexport function fromPOJO(pojo, template, defineProperty?, idMap?, idQualifier?, parent?, prop?, creator?) {\n    function getId(id) {\n        if (typeof (idQualifier) !== 'undefined') {\n            return id + '-' + idQualifier;\n        }\n\n        return id;\n    }\n\n    // For recording back refs\n    if (!idMap) {\n        idMap = {};\n    }\n\n    if (!pojo.__id__) {\n        return;\n    }\n\n    let obj;\n\n    if (creator) {\n        obj = creator(parent, prop, template, idMap[pojo.__id__.toString()], pojo.__transient__);\n\n        if (obj instanceof Array) {\n            obj = obj[0];\n            idMap[obj.__id__.toString()] = obj;\n            return obj;\n        }\n\n        if (typeof (obj) === 'undefined') {\n            return null;\n        }\n\n        if (!obj) {\n            this.noInit = true;\n            obj = new template();\n            this.noInit = false;\n        }\n    }\n    else {\n        obj = this._createEmptyObject(template, getId(pojo.__id__.toString()), defineProperty, pojo.__transient__);\n    }\n\n    idMap[getId(pojo.__id__.toString())] = obj;\n\n    // Go through all the properties and transfer them to newly created object\n    var props = obj.__template__.getProperties();\n\n    for (var propb in pojo) {\n        propb = propb.replace(/^__/, '');\n        var defineProp = props[propb];\n        if (!defineProp)\n            continue;\n        var type = defineProp.type;\n\n        // Because semotus can serialize only the shadow properties we try and restore them\n        var pojoProp = (type && typeof pojo['__' + propb] !== 'undefined') ? '__' + propb : propb;\n\n        if (type && pojo[pojoProp] == null) {\n            obj[propb] = null;\n        }\n        else if (type && typeof (pojo[pojoProp]) !== 'undefined') {\n            if (type == Array && defineProp.of && defineProp.of.isObjectTemplate) { // Array of templated objects\n                var arrayDirections = null;\n\n                if (creator) {\n                    arrayDirections = creator(obj, propb, defineProp.of, idMap[pojo.__id__.toString()], pojo.__transient__);\n                }\n\n                if (typeof (arrayDirections) !== 'undefined') {\n                    obj[propb] = [];\n\n                    for (var ix = 0; ix < pojo[pojoProp].length; ++ix) {\n                        var atype = pojo[pojoProp][ix].__template__ || defineProp.of;\n                        if (pojo[pojoProp][ix]) {\n                            if (pojo[pojoProp][ix].__id__ && idMap[getId(pojo[pojoProp][ix].__id__.toString())]) {\n                                obj[propb][ix] = idMap[getId(pojo[pojoProp][ix].__id__.toString())];\n                            }\n                            else {\n                                obj[propb][ix] = this.fromPOJO(pojo[pojoProp][ix], atype, defineProp, idMap, idQualifier, obj, propb, creator);\n                            }\n                        }\n                        else {\n                            obj[propb][ix] = null;\n                        }\n                    }\n                }\n                else {\n                    obj[propb] = [];\n                }\n            }\n            else if (type.isObjectTemplate) { // Templated objects\n                var otype = pojo[pojoProp].__template__ || type;\n                if (pojo[pojoProp].__id__ && idMap[getId(pojo[pojoProp].__id__.toString())]) {\n                    obj[propb] = idMap[getId(pojo[pojoProp].__id__.toString())];\n                }\n                else {\n                    obj[propb] = this.fromPOJO(pojo[pojoProp], otype, defineProp, idMap, idQualifier, obj, propb, creator);\n                }\n            }\n            else if (type == Date) {\n                if (pojo[pojoProp]) {\n                    obj[propb] = new Date(pojo[pojoProp]);\n                }\n                else {\n                    obj[propb] = null;\n                }\n            }\n            else {\n                obj[propb] = pojo[pojoProp];\n            }\n        }\n    }\n\n    // For the benefit of persistObjectTemplate\n    if (!creator && pojo._id) {\n        obj._id = getId(pojo._id);\n    }\n\n    if (!creator) {\n        propXfer('__changed__', pojo, obj);\n        propXfer('__version__', pojo, obj);\n    }\n\n    propXfer('__toServer__', pojo, obj);\n    propXfer('__toClient__', pojo, obj);\n\n    return obj;\n};\n\n\n/**\n * ObjectTemplate.fromJSON\n */\nexport function fromJSON(str, template, idQualifier) {\n    return this.fromPOJO(JSON.parse(str), template, null, null, idQualifier);\n};\n"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.StatsdHelper = void 0; | ||
var index_1 = require("./index"); | ||
const index_1 = require("./index"); | ||
/** | ||
* mostly static utility functions to assist supertype in handling statsd operations | ||
*/ | ||
var StatsdHelper = /** @class */ (function () { | ||
function StatsdHelper() { | ||
} | ||
class StatsdHelper { | ||
/** | ||
@@ -16,5 +14,5 @@ * convert node time format hrtime to milliseconds | ||
*/ | ||
StatsdHelper.convertHRTimeToMilliseconds = function (hrTime) { | ||
static convertHRTimeToMilliseconds(hrTime) { | ||
return hrTime[0] * 1000 + hrTime[1] / 1000000; | ||
}; | ||
} | ||
/** | ||
@@ -26,15 +24,14 @@ * given a start time and a key, record the total amount of time and send stat info. | ||
*/ | ||
StatsdHelper.computeTimingAndSend = function (hrTimeStart, statsKey, tags) { | ||
var statsdClient = index_1.SupertypeSession.statsdClient; | ||
static computeTimingAndSend(hrTimeStart, statsKey, tags) { | ||
const statsdClient = index_1.SupertypeSession.statsdClient; | ||
if (statsdClient | ||
&& statsdClient.timing | ||
&& typeof statsdClient.timing === 'function') { | ||
var timerEndTime = process.hrtime(hrTimeStart); | ||
var totalTimeInMilliseconds = this.convertHRTimeToMilliseconds(timerEndTime); | ||
const timerEndTime = process.hrtime(hrTimeStart); | ||
const totalTimeInMilliseconds = this.convertHRTimeToMilliseconds(timerEndTime); | ||
statsdClient.timing(statsKey, totalTimeInMilliseconds, tags); | ||
} | ||
}; | ||
return StatsdHelper; | ||
}()); | ||
} | ||
} | ||
exports.StatsdHelper = StatsdHelper; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhdHNkSGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL1N0YXRzZEhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBMkM7QUFNM0M7O0dBRUc7QUFDSDtJQUFBO0lBNkJBLENBQUM7SUEzQkc7Ozs7T0FJRztJQUNXLHdDQUEyQixHQUF6QyxVQUEwQyxNQUFjO1FBQ3BELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDO0lBQ2xELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNXLGlDQUFvQixHQUFsQyxVQUFtQyxXQUFtQixFQUFFLFFBQWdCLEVBQUUsSUFBSztRQUMzRSxJQUFNLFlBQVksR0FBRyx3QkFBZ0IsQ0FBQyxZQUFZLENBQUM7UUFFbkQsSUFBRyxZQUFZO2VBQ1IsWUFBWSxDQUFDLE1BQU07ZUFDbkIsT0FBTyxZQUFZLENBQUMsTUFBTSxLQUFLLFVBQVUsRUFBRTtZQUU5QyxJQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2pELElBQU0sdUJBQXVCLEdBQUcsSUFBSSxDQUFDLDJCQUEyQixDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQy9FLFlBQVksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLHVCQUF1QixFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2hFO0lBQ0wsQ0FBQztJQUNMLG1CQUFDO0FBQUQsQ0FBQyxBQTdCRCxJQTZCQztBQTdCWSxvQ0FBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN1cGVydHlwZVNlc3Npb24gfSBmcm9tICcuL2luZGV4JztcblxuLy8gZm9ybWF0IGZvciBocnRpbWVcbi8vIGh0dHBzOi8vbm9kZWpzLm9yZy9hcGkvcHJvY2Vzcy5odG1sI3Byb2Nlc3NfcHJvY2Vzc19ocnRpbWVfdGltZVxudHlwZSBoclRpbWUgPSBbbnVtYmVyLCBudW1iZXJdO1xuXG4vKipcbiAqIG1vc3RseSBzdGF0aWMgdXRpbGl0eSBmdW5jdGlvbnMgdG8gYXNzaXN0IHN1cGVydHlwZSBpbiBoYW5kbGluZyBzdGF0c2Qgb3BlcmF0aW9uc1xuICovXG5leHBvcnQgY2xhc3MgU3RhdHNkSGVscGVyIHtcblxuICAgIC8qKlxuICAgICAqIGNvbnZlcnQgbm9kZSB0aW1lIGZvcm1hdCBocnRpbWUgdG8gbWlsbGlzZWNvbmRzXG4gICAgICogQHBhcmFtIHtoclRpbWV9IGhyVGltZVxuICAgICAqIEByZXR1cm5zIHtudW1iZXJ9XG4gICAgICovXG4gICAgcHVibGljIHN0YXRpYyBjb252ZXJ0SFJUaW1lVG9NaWxsaXNlY29uZHMoaHJUaW1lOiBoclRpbWUpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gaHJUaW1lWzBdICogMTAwMCArIGhyVGltZVsxXSAvIDEwMDAwMDA7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogZ2l2ZW4gYSBzdGFydCB0aW1lIGFuZCBhIGtleSwgcmVjb3JkIHRoZSB0b3RhbCBhbW91bnQgb2YgdGltZSBhbmQgc2VuZCBzdGF0IGluZm8uXG4gICAgICogQHBhcmFtIHtoclRpbWV9IGhyVGltZVN0YXJ0XG4gICAgICogQHBhcmFtIHtzdHJpbmd9IHN0YXRzS2V5XG4gICAgICogQHBhcmFtIHRhZ3NcbiAgICAgKi9cbiAgICBwdWJsaWMgc3RhdGljIGNvbXB1dGVUaW1pbmdBbmRTZW5kKGhyVGltZVN0YXJ0OiBoclRpbWUsIHN0YXRzS2V5OiBzdHJpbmcsIHRhZ3M/KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IHN0YXRzZENsaWVudCA9IFN1cGVydHlwZVNlc3Npb24uc3RhdHNkQ2xpZW50O1xuXG4gICAgICAgIGlmKHN0YXRzZENsaWVudFxuICAgICAgICAgICAgJiYgc3RhdHNkQ2xpZW50LnRpbWluZ1xuICAgICAgICAgICAgJiYgdHlwZW9mIHN0YXRzZENsaWVudC50aW1pbmcgPT09ICdmdW5jdGlvbicpIHtcblxuICAgICAgICAgICAgY29uc3QgdGltZXJFbmRUaW1lID0gcHJvY2Vzcy5ocnRpbWUoaHJUaW1lU3RhcnQpO1xuICAgICAgICAgICAgY29uc3QgdG90YWxUaW1lSW5NaWxsaXNlY29uZHMgPSB0aGlzLmNvbnZlcnRIUlRpbWVUb01pbGxpc2Vjb25kcyh0aW1lckVuZFRpbWUpO1xuICAgICAgICAgICAgc3RhdHNkQ2xpZW50LnRpbWluZyhzdGF0c0tleSwgdG90YWxUaW1lSW5NaWxsaXNlY29uZHMsIHRhZ3MpO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhdHNkSGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL1N0YXRzZEhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBMkM7QUFNM0M7O0dBRUc7QUFDSCxNQUFhLFlBQVk7SUFFckI7Ozs7T0FJRztJQUNJLE1BQU0sQ0FBQywyQkFBMkIsQ0FBQyxNQUFjO1FBQ3BELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDO0lBQ2xELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxXQUFtQixFQUFFLFFBQWdCLEVBQUUsSUFBSztRQUMzRSxNQUFNLFlBQVksR0FBRyx3QkFBZ0IsQ0FBQyxZQUFZLENBQUM7UUFFbkQsSUFBRyxZQUFZO2VBQ1IsWUFBWSxDQUFDLE1BQU07ZUFDbkIsT0FBTyxZQUFZLENBQUMsTUFBTSxLQUFLLFVBQVUsRUFBRTtZQUU5QyxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2pELE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxDQUFDLDJCQUEyQixDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQy9FLFlBQVksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLHVCQUF1QixFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2hFO0lBQ0wsQ0FBQztDQUNKO0FBN0JELG9DQTZCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN1cGVydHlwZVNlc3Npb24gfSBmcm9tICcuL2luZGV4JztcblxuLy8gZm9ybWF0IGZvciBocnRpbWVcbi8vIGh0dHBzOi8vbm9kZWpzLm9yZy9hcGkvcHJvY2Vzcy5odG1sI3Byb2Nlc3NfcHJvY2Vzc19ocnRpbWVfdGltZVxudHlwZSBoclRpbWUgPSBbbnVtYmVyLCBudW1iZXJdO1xuXG4vKipcbiAqIG1vc3RseSBzdGF0aWMgdXRpbGl0eSBmdW5jdGlvbnMgdG8gYXNzaXN0IHN1cGVydHlwZSBpbiBoYW5kbGluZyBzdGF0c2Qgb3BlcmF0aW9uc1xuICovXG5leHBvcnQgY2xhc3MgU3RhdHNkSGVscGVyIHtcblxuICAgIC8qKlxuICAgICAqIGNvbnZlcnQgbm9kZSB0aW1lIGZvcm1hdCBocnRpbWUgdG8gbWlsbGlzZWNvbmRzXG4gICAgICogQHBhcmFtIHtoclRpbWV9IGhyVGltZVxuICAgICAqIEByZXR1cm5zIHtudW1iZXJ9XG4gICAgICovXG4gICAgcHVibGljIHN0YXRpYyBjb252ZXJ0SFJUaW1lVG9NaWxsaXNlY29uZHMoaHJUaW1lOiBoclRpbWUpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gaHJUaW1lWzBdICogMTAwMCArIGhyVGltZVsxXSAvIDEwMDAwMDA7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogZ2l2ZW4gYSBzdGFydCB0aW1lIGFuZCBhIGtleSwgcmVjb3JkIHRoZSB0b3RhbCBhbW91bnQgb2YgdGltZSBhbmQgc2VuZCBzdGF0IGluZm8uXG4gICAgICogQHBhcmFtIHtoclRpbWV9IGhyVGltZVN0YXJ0XG4gICAgICogQHBhcmFtIHtzdHJpbmd9IHN0YXRzS2V5XG4gICAgICogQHBhcmFtIHRhZ3NcbiAgICAgKi9cbiAgICBwdWJsaWMgc3RhdGljIGNvbXB1dGVUaW1pbmdBbmRTZW5kKGhyVGltZVN0YXJ0OiBoclRpbWUsIHN0YXRzS2V5OiBzdHJpbmcsIHRhZ3M/KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IHN0YXRzZENsaWVudCA9IFN1cGVydHlwZVNlc3Npb24uc3RhdHNkQ2xpZW50O1xuXG4gICAgICAgIGlmKHN0YXRzZENsaWVudFxuICAgICAgICAgICAgJiYgc3RhdHNkQ2xpZW50LnRpbWluZ1xuICAgICAgICAgICAgJiYgdHlwZW9mIHN0YXRzZENsaWVudC50aW1pbmcgPT09ICdmdW5jdGlvbicpIHtcblxuICAgICAgICAgICAgY29uc3QgdGltZXJFbmRUaW1lID0gcHJvY2Vzcy5ocnRpbWUoaHJUaW1lU3RhcnQpO1xuICAgICAgICAgICAgY29uc3QgdG90YWxUaW1lSW5NaWxsaXNlY29uZHMgPSB0aGlzLmNvbnZlcnRIUlRpbWVUb01pbGxpc2Vjb25kcyh0aW1lckVuZFRpbWUpO1xuICAgICAgICAgICAgc3RhdHNkQ2xpZW50LnRpbWluZyhzdGF0c0tleSwgdG90YWxUaW1lSW5NaWxsaXNlY29uZHMsIHRhZ3MpO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ== |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.Supertype = void 0; | ||
var ObjectTemplate_1 = require("./ObjectTemplate"); | ||
var serializer = require("./serializer"); | ||
function constructorName(constructor) { | ||
var namedFunction = constructor.toString().match(/function ([^(]*)/); | ||
return namedFunction ? namedFunction[1] : null; | ||
} | ||
const ObjectTemplate_1 = require("./ObjectTemplate"); | ||
const serializer = require("./serializer"); | ||
/** | ||
@@ -16,8 +12,7 @@ * This is the base class for typescript classes. | ||
*/ | ||
var Supertype = /** @class */ (function () { | ||
function Supertype(objectTemplate) { | ||
if (objectTemplate === void 0) { objectTemplate = ObjectTemplate_1.ObjectTemplate; } | ||
class Supertype { | ||
constructor(objectTemplate = ObjectTemplate_1.ObjectTemplate) { | ||
var template = this.__template__; | ||
if (!template) { | ||
throw new Error(constructorName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass'); | ||
throw new Error(ObjectTemplate_1.ObjectTemplate.getName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass'); | ||
} | ||
@@ -43,34 +38,34 @@ // Tell constructor not to execute as this is an empty object | ||
} | ||
Supertype.amorphicCreateProperty = function (prop, defineProperty) { | ||
static amorphicCreateProperty(prop, defineProperty) { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.amorphicGetProperties = function (includeVirtualProperties) { | ||
} | ||
static amorphicGetProperties(includeVirtualProperties) { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.amorphicFromJSON = function (json) { | ||
} | ||
static amorphicFromJSON(json) { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.createProperty = function (prop, defineProperty) { | ||
} | ||
static createProperty(prop, defineProperty) { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.getProperties = function () { | ||
} | ||
static getProperties() { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.prototype.amorphicGetClassName = function () { | ||
} | ||
amorphicGetClassName() { | ||
// Implemented in the decorator @supertypeClass | ||
return ''; | ||
}; | ||
Supertype.fromJSON = function (json, idPrefix) { | ||
} | ||
static fromJSON(json, idPrefix) { | ||
// Implemented in the decorator @supertypeClass | ||
}; | ||
Supertype.inject = function (injector) { | ||
} | ||
static inject(injector) { | ||
// Implemented in Line 128, of ObjectTemplate.ts (static performInjections) | ||
}; | ||
Supertype.prototype.amorphicToJSON = function (cb) { | ||
} | ||
amorphicToJSON(cb) { | ||
return serializer.toJSONString(this, cb); | ||
}; | ||
Supertype.prototype.amorphicGetPropertyDefinition = function (prop) { | ||
} | ||
amorphicGetPropertyDefinition(prop) { | ||
return ObjectTemplate_1.ObjectTemplate._getDefineProperty(prop, this.__template__); | ||
}; | ||
Supertype.prototype.amorphicGetPropertyValues = function (prop) { | ||
} | ||
amorphicGetPropertyValues(prop) { | ||
var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop); | ||
@@ -81,4 +76,4 @@ if (typeof (defineProperty.values) === 'function') { | ||
return defineProperty.values; | ||
}; | ||
Supertype.prototype.amorphicGetPropertyDescriptions = function (prop) { | ||
} | ||
amorphicGetPropertyDescriptions(prop) { | ||
var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop); | ||
@@ -89,30 +84,29 @@ if (typeof (defineProperty.descriptions) === 'function') { | ||
return defineProperty.descriptions; | ||
}; | ||
Supertype.prototype.createCopy = function (creator) { | ||
var obj = this; | ||
} | ||
createCopy(creator) { | ||
const obj = this; | ||
return ObjectTemplate_1.ObjectTemplate.fromPOJO(obj, obj.__template__, null, null, undefined, null, null, creator); | ||
}; | ||
Supertype.prototype.inject = function (injector) { | ||
} | ||
inject(injector) { | ||
ObjectTemplate_1.ObjectTemplate.inject(this, injector); | ||
}; | ||
Supertype.prototype.copyProperties = function (obj) { | ||
} | ||
copyProperties(obj) { | ||
for (var prop in obj) { | ||
this[prop] = obj[prop]; | ||
} | ||
}; | ||
Supertype.prototype.__prop__ = function (prop) { | ||
} | ||
__prop__(prop) { | ||
return this.amorphicGetPropertyDefinition(prop); | ||
}; | ||
Supertype.prototype.__values__ = function (prop) { | ||
} | ||
__values__(prop) { | ||
return this.amorphicGetPropertyValues(prop); | ||
}; | ||
Supertype.prototype.__descriptions__ = function (prop) { | ||
} | ||
__descriptions__(prop) { | ||
return this.amorphicGetPropertyDescriptions(prop); | ||
}; | ||
Supertype.prototype.toJSONString = function (cb) { | ||
} | ||
toJSONString(cb) { | ||
return this.amorphicToJSON(cb); | ||
}; | ||
return Supertype; | ||
}()); | ||
} | ||
} | ||
exports.Supertype = Supertype; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Supertype.js","sourceRoot":"","sources":["../src/Supertype.ts"],"names":[],"mappings":"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","sourcesContent":["import {ObjectTemplate} from './ObjectTemplate';\nimport * as serializer from './serializer';\n\nfunction constructorName(constructor) {\n    var namedFunction = constructor.toString().match(/function ([^(]*)/);\n    return namedFunction ? namedFunction[1] : null;\n}\n\nexport type Constructable = new (...args: any[]) => {};\n\n\n/**\n * This is the base class for typescript classes. \n * It will inject members into the object from both the template and objectTemplate\n * @param {ObjectTemplate} - other layers can pass in their own object template (this is the object not ObjectTemplate)\n * @returns {Object} the object itself\n */\n\nexport class Supertype {\n    __template__: any;\n    amorphic : typeof ObjectTemplate;\n\n    static amorphicCreateProperty(prop: String, defineProperty: Object) {\n        // Implemented in the decorator @supertypeClass\n    }\n\n    static amorphicGetProperties(includeVirtualProperties?: boolean):any {\n        // Implemented in the decorator @supertypeClass\n    }\n    static amorphicFromJSON(json: string) {\n        // Implemented in the decorator @supertypeClass\n    }\n    static createProperty(prop: String, defineProperty: Object) {\n        // Implemented in the decorator @supertypeClass\n    }\n    static getProperties() {\n        // Implemented in the decorator @supertypeClass\n    }\n    amorphicGetClassName () : string {\n        // Implemented in the decorator @supertypeClass\n        return '';\n    }\n    static fromJSON (json: string, idPrefix?: string) {\n        // Implemented in the decorator @supertypeClass\n    \n    }\n\n    static inject (injector: any) {\n        // Implemented in Line 128, of ObjectTemplate.ts (static performInjections)\n    }\n\n    static amorphicProperties: any;\n    static amorphicChildClasses: Array<Constructable>;\n    static amorphicParentClass: Constructable;\n    static amorphicClassName : string;\n    static amorphicStatic : typeof ObjectTemplate;\n\n    // Object members\n    __id__: String;\n    amorphicLeaveEmpty: boolean;\n\n    // Deprecated legacy naming\n    static __children__: Array<Constructable>;\n    static __parent__: Constructable;\n    amorphicClass : any\n\n    constructor(objectTemplate = ObjectTemplate) {\n        var template = this.__template__;\n        if (!template) {\n            throw new Error(constructorName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass');\n        }\n\n        // Tell constructor not to execute as this is an empty object\n        this.amorphicLeaveEmpty = objectTemplate._stashObject(this, template);\n\n        // Template level injections that the application may use\n        var targetTemplate = template;\n        while (targetTemplate) {\n            for (var ix = 0; ix < targetTemplate.__injections__.length; ++ix) {\n                targetTemplate.__injections__[ix].call(this, this);\n            }\n            targetTemplate = targetTemplate.__parent__;\n        }\n\n        // Global injections used by the framework\n        for (var j = 0; j < objectTemplate.__injections__.length; ++j) {\n            objectTemplate.__injections__[j].call(this, this);\n        }\n\n        this.amorphic = objectTemplate;\n\n        //@TODO: fill the properties of 'this' in? do I need this after deleting the callerContext approach\n        // https://github.com/haven-life/supertype/issues/7\n        return this;\n    }\n    amorphicToJSON(cb?){\n        return serializer.toJSONString(this, cb);\n    } \n\n    amorphicGetPropertyDefinition(prop) {\n        return ObjectTemplate._getDefineProperty(prop, this.__template__);\n    }\n    amorphicGetPropertyValues(prop) {\n        var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop);\n    \n        if (typeof(defineProperty.values) === 'function') {\n            return defineProperty.values.call(this);\n        }\n        return defineProperty.values;\n    }\n    amorphicGetPropertyDescriptions(prop) {\n        var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop);\n    \n        if (typeof(defineProperty.descriptions) === 'function') {\n            return defineProperty.descriptions.call(this);\n        }\n    \n        return defineProperty.descriptions;\n    }\n\n    createCopy(creator) {\n        var obj = this;\n        return ObjectTemplate.fromPOJO(obj, obj.__template__, null, null, undefined, null, null, creator);\n    }\n\n    inject(injector) {\n        ObjectTemplate.inject(this, injector);\n    }\n\n    copyProperties(obj) {\n        for (var prop in obj) {\n            this[prop] = obj[prop];\n        }\n    }\n    __prop__(prop) {\n        return this.amorphicGetPropertyDefinition(prop);\n    }\n    __values__(prop) {\n        return this.amorphicGetPropertyValues(prop);\n    }\n    __descriptions__(prop){\n        return this.amorphicGetPropertyDescriptions(prop);\n    }\n    toJSONString(cb?) {\n        return this.amorphicToJSON(cb)\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Supertype.js","sourceRoot":"","sources":["../src/Supertype.ts"],"names":[],"mappings":";;;AAAA,qDAAgD;AAChD,2CAA2C;AAK3C;;;;;GAKG;AAEH,MAAa,SAAS;IAgDlB,YAAY,cAAc,GAAG,+BAAc;QACvC,IAAI,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC;QACjC,IAAI,CAAC,QAAQ,EAAE;YACX,MAAM,IAAI,KAAK,CAAC,+BAAc,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,GAAG,0BAA0B,CAAC,CAAC;SACjH;QAED,6DAA6D;QAC7D,IAAI,CAAC,kBAAkB,GAAG,cAAc,CAAC,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAEtE,yDAAyD;QACzD,IAAI,cAAc,GAAG,QAAQ,CAAC;QAC9B,OAAO,cAAc,EAAE;YACnB,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;gBAC9D,cAAc,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;aACtD;YACD,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC;SAC9C;QAED,0CAA0C;QAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YAC3D,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SACrD;QAED,IAAI,CAAC,QAAQ,GAAG,cAAc,CAAC;QAE/B,mGAAmG;QACnG,mDAAmD;QACnD,OAAO,IAAI,CAAC;IAChB,CAAC;IAxED,MAAM,CAAC,sBAAsB,CAAC,IAAY,EAAE,cAAsB;QAC9D,+CAA+C;IACnD,CAAC;IAED,MAAM,CAAC,qBAAqB,CAAC,wBAAkC;QAC3D,+CAA+C;IACnD,CAAC;IACD,MAAM,CAAC,gBAAgB,CAAC,IAAY;QAChC,+CAA+C;IACnD,CAAC;IACD,MAAM,CAAC,cAAc,CAAC,IAAY,EAAE,cAAsB;QACtD,+CAA+C;IACnD,CAAC;IACD,MAAM,CAAC,aAAa;QAChB,+CAA+C;IACnD,CAAC;IACD,oBAAoB;QAChB,+CAA+C;QAC/C,OAAO,EAAE,CAAC;IACd,CAAC;IACD,MAAM,CAAC,QAAQ,CAAE,IAAY,EAAE,QAAiB;QAC5C,+CAA+C;IAEnD,CAAC;IAED,MAAM,CAAC,MAAM,CAAE,QAAa;QACxB,2EAA2E;IAC/E,CAAC;IA8CD,cAAc,CAAC,EAAG;QACd,OAAO,UAAU,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,6BAA6B,CAAC,IAAI;QAC9B,OAAO,+BAAc,CAAC,kBAAkB,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACtE,CAAC;IACD,yBAAyB,CAAC,IAAI;QAC1B,IAAI,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;QAEtE,IAAI,OAAM,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,UAAU,EAAE;YAC9C,OAAO,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC3C;QACD,OAAO,cAAc,CAAC,MAAM,CAAC;IACjC,CAAC;IACD,+BAA+B,CAAC,IAAI;QAChC,IAAI,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;QAEtE,IAAI,OAAM,CAAC,cAAc,CAAC,YAAY,CAAC,KAAK,UAAU,EAAE;YACpD,OAAO,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACjD;QAED,OAAO,cAAc,CAAC,YAAY,CAAC;IACvC,CAAC;IAED,UAAU,CAAC,OAAO;QACd,MAAM,GAAG,GAAG,IAAI,CAAC;QACjB,OAAO,+BAAc,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;IACtG,CAAC;IAED,MAAM,CAAC,QAAQ;QACX,+BAAc,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,cAAc,CAAC,GAAG;QACd,KAAK,IAAI,IAAI,IAAI,GAAG,EAAE;YAClB,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;SAC1B;IACL,CAAC;IACD,QAAQ,CAAC,IAAI;QACT,OAAO,IAAI,CAAC,6BAA6B,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC;IACD,UAAU,CAAC,IAAI;QACX,OAAO,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IACD,gBAAgB,CAAC,IAAI;QACjB,OAAO,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC;IACD,YAAY,CAAC,EAAG;QACZ,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IAClC,CAAC;CACJ;AAhID,8BAgIC","sourcesContent":["import {ObjectTemplate} from './ObjectTemplate';\nimport * as serializer from './serializer';\n\nexport type Constructable = new (...args: any[]) => {};\n\n\n/**\n * This is the base class for typescript classes. \n * It will inject members into the object from both the template and objectTemplate\n * @param {ObjectTemplate} - other layers can pass in their own object template (this is the object not ObjectTemplate)\n * @returns {Object} the object itself\n */\n\nexport class Supertype {\n    __template__: any;\n    amorphic : typeof ObjectTemplate;\n\n    static amorphicCreateProperty(prop: String, defineProperty: Object) {\n        // Implemented in the decorator @supertypeClass\n    }\n\n    static amorphicGetProperties(includeVirtualProperties?: boolean):any {\n        // Implemented in the decorator @supertypeClass\n    }\n    static amorphicFromJSON(json: string) {\n        // Implemented in the decorator @supertypeClass\n    }\n    static createProperty(prop: String, defineProperty: Object) {\n        // Implemented in the decorator @supertypeClass\n    }\n    static getProperties() {\n        // Implemented in the decorator @supertypeClass\n    }\n    amorphicGetClassName () : string {\n        // Implemented in the decorator @supertypeClass\n        return '';\n    }\n    static fromJSON (json: string, idPrefix?: string) {\n        // Implemented in the decorator @supertypeClass\n    \n    }\n\n    static inject (injector: any) {\n        // Implemented in Line 128, of ObjectTemplate.ts (static performInjections)\n    }\n\n    static amorphicProperties: any;\n    static amorphicChildClasses: Array<Constructable>;\n    static amorphicParentClass: Constructable;\n    static amorphicClassName : string;\n    static amorphicStatic : typeof ObjectTemplate;\n\n    // Object members\n    __id__: String;\n    amorphicLeaveEmpty: boolean;\n\n    // Deprecated legacy naming\n    static __children__: Array<Constructable>;\n    static __parent__: Constructable;\n    amorphicClass : any\n\n    constructor(objectTemplate = ObjectTemplate) {\n        var template = this.__template__;\n        if (!template) {\n            throw new Error(ObjectTemplate.getName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass');\n        }\n\n        // Tell constructor not to execute as this is an empty object\n        this.amorphicLeaveEmpty = objectTemplate._stashObject(this, template);\n\n        // Template level injections that the application may use\n        var targetTemplate = template;\n        while (targetTemplate) {\n            for (var ix = 0; ix < targetTemplate.__injections__.length; ++ix) {\n                targetTemplate.__injections__[ix].call(this, this);\n            }\n            targetTemplate = targetTemplate.__parent__;\n        }\n\n        // Global injections used by the framework\n        for (var j = 0; j < objectTemplate.__injections__.length; ++j) {\n            objectTemplate.__injections__[j].call(this, this);\n        }\n\n        this.amorphic = objectTemplate;\n\n        //@TODO: fill the properties of 'this' in? do I need this after deleting the callerContext approach\n        // https://github.com/haven-life/supertype/issues/7\n        return this;\n    }\n    amorphicToJSON(cb?){\n        return serializer.toJSONString(this, cb);\n    } \n\n    amorphicGetPropertyDefinition(prop) {\n        return ObjectTemplate._getDefineProperty(prop, this.__template__);\n    }\n    amorphicGetPropertyValues(prop) {\n        var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop);\n    \n        if (typeof(defineProperty.values) === 'function') {\n            return defineProperty.values.call(this);\n        }\n        return defineProperty.values;\n    }\n    amorphicGetPropertyDescriptions(prop) {\n        var defineProperty = this.__prop__(prop) || this.__prop__('_' + prop);\n    \n        if (typeof(defineProperty.descriptions) === 'function') {\n            return defineProperty.descriptions.call(this);\n        }\n    \n        return defineProperty.descriptions;\n    }\n\n    createCopy(creator) {\n        const obj = this;\n        return ObjectTemplate.fromPOJO(obj, obj.__template__, null, null, undefined, null, null, creator);\n    }\n\n    inject(injector) {\n        ObjectTemplate.inject(this, injector);\n    }\n\n    copyProperties(obj) {\n        for (var prop in obj) {\n            this[prop] = obj[prop];\n        }\n    }\n    __prop__(prop) {\n        return this.amorphicGetPropertyDefinition(prop);\n    }\n    __values__(prop) {\n        return this.amorphicGetPropertyValues(prop);\n    }\n    __descriptions__(prop){\n        return this.amorphicGetPropertyDescriptions(prop);\n    }\n    toJSONString(cb?) {\n        return this.amorphicToJSON(cb)\n    }\n}"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.BuildSupertypeConfig = exports.SupertypeConfig = void 0; | ||
var nconf = require("nconf"); | ||
const nconf = require("nconf"); | ||
function createNewNConfProvider() { | ||
@@ -11,4 +11,4 @@ return new nconf.Provider().argv().env({ separator: '__' }); | ||
*/ | ||
var SupertypeConfig = /** @class */ (function () { | ||
function SupertypeConfig() { | ||
class SupertypeConfig { | ||
constructor() { | ||
this.internalConfigStore = createNewNConfProvider(); | ||
@@ -22,5 +22,5 @@ } | ||
*/ | ||
SupertypeConfig.prototype.get = function (key) { | ||
get(key) { | ||
return this.internalConfigStore.get(key); | ||
}; | ||
} | ||
/** | ||
@@ -33,5 +33,5 @@ * Sets a value with a key | ||
*/ | ||
SupertypeConfig.prototype.set = function (key, value) { | ||
set(key, value) { | ||
return this.internalConfigStore.set(key, value); | ||
}; | ||
} | ||
/** | ||
@@ -43,8 +43,7 @@ * Load a configuration file into store | ||
*/ | ||
SupertypeConfig.prototype.loadFile = function (fileKey, file) { | ||
loadFile(fileKey, file) { | ||
this.internalConfigStore.file(fileKey, file); | ||
}; | ||
} | ||
; | ||
return SupertypeConfig; | ||
}()); | ||
} | ||
exports.SupertypeConfig = SupertypeConfig; | ||
@@ -56,9 +55,9 @@ /** | ||
function BuildSupertypeConfig(rootDir) { | ||
var rootConfig = new SupertypeConfig(); | ||
const rootConfig = new SupertypeConfig(); | ||
if (!rootDir) { | ||
throw new Error("Valid root path expected. rootDir[" + rootDir + "]"); | ||
throw new Error(`Valid root path expected. rootDir[${rootDir}]`); | ||
} | ||
else { | ||
var configStore = {}; | ||
var envName = rootConfig.internalConfigStore.get('APP_ENV'); | ||
const configStore = {}; | ||
let envName = rootConfig.internalConfigStore.get('APP_ENV'); | ||
if (envName) { | ||
@@ -68,9 +67,9 @@ envName = envName.toLowerCase(); | ||
if (envName) { | ||
loadConfigFile(rootConfig.internalConfigStore, 'root_env', rootDir, "config_" + envName + ".json"); | ||
loadConfigFile(rootConfig.internalConfigStore, 'root_env', rootDir, `config_${envName}.json`); | ||
} | ||
loadConfigFile(rootConfig.internalConfigStore, 'root_secure', rootDir, "config_secure.json"); | ||
loadConfigFile(rootConfig.internalConfigStore, 'root', rootDir, "config.json"); | ||
loadConfigFile(rootConfig.internalConfigStore, 'root_secure', rootDir, `config_secure.json`); | ||
loadConfigFile(rootConfig.internalConfigStore, 'root', rootDir, `config.json`); | ||
configStore['root'] = rootConfig; | ||
var appList = rootConfig.internalConfigStore.get('applications') || {}; | ||
for (var appKey in appList) { | ||
const appList = rootConfig.internalConfigStore.get('applications') || {}; | ||
for (let appKey in appList) { | ||
configStore[appKey] = buildAppSpecificConfigStore(appList[appKey], rootDir, envName); | ||
@@ -83,24 +82,24 @@ } | ||
function buildAppSpecificConfigStore(app, rootDir, envName) { | ||
var appPath = rootDir + "/" + app; // Location of the App relative to root | ||
var appCommonPath = rootDir + "/apps/common"; // Location of the common folder relative to root | ||
var config = new SupertypeConfig(); | ||
var appCfgApi = config.internalConfigStore; | ||
const appPath = `${rootDir}/${app}`; // Location of the App relative to root | ||
const appCommonPath = `${rootDir}/apps/common`; // Location of the common folder relative to root | ||
const config = new SupertypeConfig(); | ||
const appCfgApi = config.internalConfigStore; | ||
// Load the new app environment values into the config | ||
if (envName) { | ||
loadConfigFile(appCfgApi, 'app_env', appPath, "config_" + envName + ".json"); | ||
loadConfigFile(appCfgApi, 'app_env', appPath, `config_${envName}.json`); | ||
} | ||
loadConfigFile(appCfgApi, 'app_secure', appPath, "config_secure.json"); | ||
loadConfigFile(appCfgApi, 'app', appPath, "config.json"); | ||
loadConfigFile(appCfgApi, 'app_secure', appPath, `config_secure.json`); | ||
loadConfigFile(appCfgApi, 'app', appPath, `config.json`); | ||
// Load the common folder configs to this config provider | ||
if (envName) { | ||
loadConfigFile(appCfgApi, 'common_env', appCommonPath, "config_" + envName + ".json"); | ||
loadConfigFile(appCfgApi, 'common_env', appCommonPath, `config_${envName}.json`); | ||
} | ||
loadConfigFile(appCfgApi, 'common_secure', appCommonPath, "config_secure.json"); | ||
loadConfigFile(appCfgApi, 'common', appCommonPath, "config.json"); | ||
loadConfigFile(appCfgApi, 'common_secure', appCommonPath, `config_secure.json`); | ||
loadConfigFile(appCfgApi, 'common', appCommonPath, `config.json`); | ||
// Load the root values here too | ||
if (envName) { | ||
loadConfigFile(appCfgApi, 'root_env', rootDir, "config_" + envName + ".json"); | ||
loadConfigFile(appCfgApi, 'root_env', rootDir, `config_${envName}.json`); | ||
} | ||
loadConfigFile(appCfgApi, 'root_secure', rootDir, "config_secure.json"); | ||
loadConfigFile(appCfgApi, 'root', rootDir, "config.json"); | ||
loadConfigFile(appCfgApi, 'root_secure', rootDir, `config_secure.json`); | ||
loadConfigFile(appCfgApi, 'root', rootDir, `config.json`); | ||
return config; | ||
@@ -110,8 +109,8 @@ } | ||
try { | ||
config.file(name, appPath + "/" + fileName); | ||
config.file(name, `${appPath}/${fileName}`); | ||
} | ||
catch (err) { | ||
console.debug("Error loading " + appPath + "/" + fileName + " to config"); | ||
console.debug(`Error loading ${appPath}/${fileName} to config`); | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SupertypeConfig.js","sourceRoot":"","sources":["../src/SupertypeConfig.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nconf from 'nconf';\nimport {Provider} from 'nconf';\nimport {Config, ApplicationNameToConfigMap} from '@haventech/amorphic-contracts';\n\n\nfunction createNewNConfProvider(): Provider {\n    return new nconf.Provider().argv().env({separator: '__'});\n}\n\n/**\n * Deprecating loadFile for just 'file'\n */\nexport class SupertypeConfig implements Config {\n\n    internalConfigStore: Provider;\n    constructor() {\n        this.internalConfigStore = createNewNConfProvider();\n    }\n\n    /**\n     * Gets a value with a key\n     *\n     * @param key\n     * @returns {*}\n     */\n    get(key) {\n        return this.internalConfigStore.get(key);\n    }\n\n    /**\n     * Sets a value with a key\n     *\n     * @param key\n     * @param value\n     * @returns {*}\n     */\n    set(key, value) {\n        return this.internalConfigStore.set(key, value);\n    }\n\n    /**\n     * Load a configuration file into store\n     *\n     * @param fileKey\n     * @param file\n     */\n    loadFile(fileKey, file) {\n        this.internalConfigStore.file(fileKey, file);\n    };\n}\n\n/**\n * Same type as the AmorphicConfigBuilder build function as specified in amorphic-contracts\n * @param rootDir\n */\nexport function BuildSupertypeConfig(rootDir: string): ApplicationNameToConfigMap {\n    const rootConfig = new SupertypeConfig();\n    if (!rootDir) {\n        throw new Error(`Valid root path expected. rootDir[${rootDir}]`);\n    }\n    else {\n        const configStore: ApplicationNameToConfigMap = {};\n        let envName = rootConfig.internalConfigStore.get('APP_ENV');\n\n        if (envName) {\n            envName = envName.toLowerCase();\n        }\n\n        if (envName) {\n            loadConfigFile(rootConfig.internalConfigStore, 'root_env', rootDir, `config_${envName}.json`);\n        }\n        loadConfigFile(rootConfig.internalConfigStore, 'root_secure', rootDir, `config_secure.json`);\n        loadConfigFile(rootConfig.internalConfigStore, 'root', rootDir, `config.json`);\n\n\n        configStore['root'] = rootConfig;\n\n        const appList = rootConfig.internalConfigStore.get('applications') || {};\n\n        for (let appKey in appList) {\n            configStore[appKey] = buildAppSpecificConfigStore(appList[appKey], rootDir, envName);\n        }\n\n        return configStore;\n    }\n}\n\nfunction buildAppSpecificConfigStore(app: string, rootDir: string, envName?: string): SupertypeConfig {\n    const appPath = `${rootDir}/${app}`; // Location of the App relative to root\n    const appCommonPath = `${rootDir}/apps/common`; // Location of the common folder relative to root\n\n    const config = new SupertypeConfig();\n    const appCfgApi = config.internalConfigStore;\n\n    // Load the new app environment values into the config\n    if(envName) {\n        loadConfigFile(appCfgApi, 'app_env', appPath, `config_${envName}.json`);\n    }\n    loadConfigFile(appCfgApi, 'app_secure', appPath, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'app', appPath, `config.json`);\n\n\n    // Load the common folder configs to this config provider\n    if(envName) {\n        loadConfigFile(appCfgApi, 'common_env', appCommonPath, `config_${envName}.json`);\n    }\n    loadConfigFile(appCfgApi, 'common_secure', appCommonPath, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'common', appCommonPath, `config.json`);\n\n    // Load the root values here too\n    if(envName) {\n        loadConfigFile(appCfgApi, 'root_env', rootDir, `config_${envName}.json`);\n    }\n\n    loadConfigFile(appCfgApi, 'root_secure', rootDir, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'root', rootDir, `config.json`);\n\n    return config;\n}\n\n\nfunction loadConfigFile(config: nconf.Provider, name: string, appPath: string, fileName: string) {\n    try {\n        config.file(name, `${appPath}/${fileName}`);\n    }\n    catch (err) {\n        console.debug(`Error loading ${appPath}/${fileName} to config`);\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SupertypeConfig.js","sourceRoot":"","sources":["../src/SupertypeConfig.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nconf from 'nconf';\nimport {Provider} from 'nconf';\nimport {Config, ApplicationNameToConfigMap} from '@haventech/amorphic-contracts';\n\n\nfunction createNewNConfProvider(): Provider {\n    return new nconf.Provider().argv().env({separator: '__'});\n}\n\n/**\n * Deprecating loadFile for just 'file'\n */\nexport class SupertypeConfig implements Config {\n\n    internalConfigStore: Provider;\n    constructor() {\n        this.internalConfigStore = createNewNConfProvider();\n    }\n\n    /**\n     * Gets a value with a key\n     *\n     * @param key\n     * @returns {*}\n     */\n    get(key) {\n        return this.internalConfigStore.get(key);\n    }\n\n    /**\n     * Sets a value with a key\n     *\n     * @param key\n     * @param value\n     * @returns {*}\n     */\n    set(key, value) {\n        return this.internalConfigStore.set(key, value);\n    }\n\n    /**\n     * Load a configuration file into store\n     *\n     * @param fileKey\n     * @param file\n     */\n    loadFile(fileKey, file) {\n        this.internalConfigStore.file(fileKey, file);\n    };\n}\n\n/**\n * Same type as the AmorphicConfigBuilder build function as specified in amorphic-contracts\n * @param rootDir\n */\nexport function BuildSupertypeConfig(rootDir: string): ApplicationNameToConfigMap {\n    const rootConfig = new SupertypeConfig();\n    if (!rootDir) {\n        throw new Error(`Valid root path expected. rootDir[${rootDir}]`);\n    }\n    else {\n        const configStore: ApplicationNameToConfigMap = {};\n        let envName = rootConfig.internalConfigStore.get('APP_ENV');\n\n        if (envName) {\n            envName = envName.toLowerCase();\n        }\n\n        if (envName) {\n            loadConfigFile(rootConfig.internalConfigStore, 'root_env', rootDir, `config_${envName}.json`);\n        }\n        loadConfigFile(rootConfig.internalConfigStore, 'root_secure', rootDir, `config_secure.json`);\n        loadConfigFile(rootConfig.internalConfigStore, 'root', rootDir, `config.json`);\n\n\n        configStore['root'] = rootConfig;\n\n        const appList = rootConfig.internalConfigStore.get('applications') || {};\n\n        for (let appKey in appList) {\n            configStore[appKey] = buildAppSpecificConfigStore(appList[appKey], rootDir, envName);\n        }\n\n        return configStore;\n    }\n}\n\nfunction buildAppSpecificConfigStore(app: string, rootDir: string, envName?: string): SupertypeConfig {\n    const appPath = `${rootDir}/${app}`; // Location of the App relative to root\n    const appCommonPath = `${rootDir}/apps/common`; // Location of the common folder relative to root\n\n    const config = new SupertypeConfig();\n    const appCfgApi = config.internalConfigStore;\n\n    // Load the new app environment values into the config\n    if(envName) {\n        loadConfigFile(appCfgApi, 'app_env', appPath, `config_${envName}.json`);\n    }\n    loadConfigFile(appCfgApi, 'app_secure', appPath, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'app', appPath, `config.json`);\n\n\n    // Load the common folder configs to this config provider\n    if(envName) {\n        loadConfigFile(appCfgApi, 'common_env', appCommonPath, `config_${envName}.json`);\n    }\n    loadConfigFile(appCfgApi, 'common_secure', appCommonPath, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'common', appCommonPath, `config.json`);\n\n    // Load the root values here too\n    if(envName) {\n        loadConfigFile(appCfgApi, 'root_env', rootDir, `config_${envName}.json`);\n    }\n\n    loadConfigFile(appCfgApi, 'root_secure', rootDir, `config_secure.json`);\n    loadConfigFile(appCfgApi, 'root', rootDir, `config.json`);\n\n    return config;\n}\n\n\nfunction loadConfigFile(config: nconf.Provider, name: string, appPath: string, fileName: string) {\n    try {\n        config.file(name, `${appPath}/${fileName}`);\n    }\n    catch (err) {\n        console.debug(`Error loading ${appPath}/${fileName} to config`);\n    }\n}"]} |
"use strict"; | ||
var __spreadArrays = (this && this.__spreadArrays) || function () { | ||
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; | ||
for (var r = Array(s), k = 0, i = 0; i < il; i++) | ||
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) | ||
r[k] = a[j]; | ||
return r; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.SupertypeLogger = void 0; | ||
var levelToStr = { 60: 'fatal', 50: 'error', 40: 'warn', 30: 'info', 20: 'debug', 10: 'trace' }; | ||
var strToLevel = { 'fatal': 60, 'error': 50, 'warn': 40, 'info': 30, 'debug': 20, 'trace': 10 }; | ||
const levelToStr = { 60: 'fatal', 50: 'error', 40: 'warn', 30: 'info', 20: 'debug', 10: 'trace' }; | ||
const strToLevel = { 'fatal': 60, 'error': 50, 'warn': 40, 'info': 30, 'debug': 20, 'trace': 10 }; | ||
function isObject(obj) { | ||
@@ -20,7 +13,7 @@ return obj != null | ||
} | ||
var SupertypeLogger = /** @class */ (function () { | ||
class SupertypeLogger { | ||
// for overriding | ||
// sendToLog: Function; | ||
// formatDateTime: Function; | ||
function SupertypeLogger() { | ||
constructor() { | ||
this.context = {}; | ||
@@ -30,44 +23,20 @@ this.granularLevels = {}; | ||
} | ||
SupertypeLogger.prototype.fatal = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([60], data)); | ||
}; | ||
SupertypeLogger.prototype.error = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([50], data)); | ||
}; | ||
SupertypeLogger.prototype.warn = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([40], data)); | ||
}; | ||
SupertypeLogger.prototype.info = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([30], data)); | ||
}; | ||
SupertypeLogger.prototype.debug = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([20], data)); | ||
}; | ||
SupertypeLogger.prototype.trace = function () { | ||
var data = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
data[_i] = arguments[_i]; | ||
} | ||
this.log.apply(this, __spreadArrays([10], data)); | ||
}; | ||
fatal(...data) { | ||
this.log(60, ...data); | ||
} | ||
error(...data) { | ||
this.log(50, ...data); | ||
} | ||
warn(...data) { | ||
this.log(40, ...data); | ||
} | ||
info(...data) { | ||
this.log(30, ...data); | ||
} | ||
debug(...data) { | ||
this.log(20, ...data); | ||
} | ||
trace(...data) { | ||
this.log(10, ...data); | ||
} | ||
/** | ||
@@ -77,13 +46,9 @@ * assign a custom send to log functionality. | ||
*/ | ||
SupertypeLogger.prototype.setLogger = function (loggerFunction) { | ||
setLogger(loggerFunction) { | ||
this.sendToLog = loggerFunction; | ||
}; | ||
} | ||
// Log all arguments assuming the first one is level and the second one might be an object (similar to banyan) | ||
SupertypeLogger.prototype.log = function (level) { | ||
var data = []; | ||
for (var _i = 1; _i < arguments.length; _i++) { | ||
data[_i - 1] = arguments[_i]; | ||
} | ||
var msg = ''; | ||
var obj = { | ||
log(level, ...data) { | ||
let msg = ''; | ||
const obj = { | ||
time: (new Date()).toISOString(), | ||
@@ -94,5 +59,5 @@ msg: '', | ||
}; | ||
var amorphicContext = {}; | ||
const amorphicContext = {}; | ||
// Copy amorphic context into the data | ||
for (var prop in this.context) { | ||
for (const prop in this.context) { | ||
obj[prop] = this.context[prop]; | ||
@@ -103,5 +68,5 @@ amorphicContext[prop] = this.context[prop]; | ||
obj.__amorphicContext = amorphicContext; | ||
data.forEach(function (arg, index) { | ||
data.forEach((arg, index) => { | ||
if (index === 0 && isObject(arg)) { | ||
for (var proper in arg) { | ||
for (const proper in arg) { | ||
obj[proper] = arg[proper]; | ||
@@ -111,3 +76,3 @@ } | ||
else { | ||
msg += arg + " "; | ||
msg += `${arg} `; | ||
} | ||
@@ -120,3 +85,3 @@ }); | ||
if (obj.module && obj.activity) { | ||
obj.msg += obj.module + "[" + obj.activity + "] - "; | ||
obj.msg += `${obj.module}[${obj.activity}] - `; | ||
} | ||
@@ -126,15 +91,15 @@ obj.msg += msg; | ||
else if (obj.module && obj.activity) { | ||
obj.msg += obj.module + "[" + obj.activity + "]"; | ||
obj.msg += `${obj.module}[${obj.activity}]`; | ||
} | ||
if (this.isEnabled(levelToStr[obj.level], obj)) { | ||
this.sendToLog.apply(this, __spreadArrays([levelToStr[obj.level], obj], data)); | ||
this.sendToLog(levelToStr[obj.level], obj, ...data); | ||
} | ||
}; | ||
SupertypeLogger.prototype.startContext = function (context) { | ||
} | ||
startContext(context) { | ||
this.context = context; | ||
}; | ||
} | ||
// Save the properties in the context and return a new object that has the properties only so they can be cleared | ||
SupertypeLogger.prototype.setContextProps = function (context) { | ||
var reverse = {}; | ||
for (var prop in context) { | ||
setContextProps(context) { | ||
const reverse = {}; | ||
for (const prop in context) { | ||
reverse[prop] = true; | ||
@@ -144,5 +109,5 @@ this.context[prop] = context[prop]; | ||
return reverse; | ||
}; | ||
} | ||
// Parse log levels such as warn.activity | ||
SupertypeLogger.prototype.setLevel = function (level) { | ||
setLevel(level) { | ||
var levels = level.split(';'); | ||
@@ -164,22 +129,19 @@ for (var ix = 0; ix < levels.length; ++ix) { | ||
} | ||
}; | ||
} | ||
// Remove any properties recorded by setContext | ||
SupertypeLogger.prototype.clearContextProps = function (contextToClear) { | ||
for (var prop in contextToClear) { | ||
clearContextProps(contextToClear) { | ||
for (const prop in contextToClear) { | ||
delete this.context[prop]; | ||
} | ||
}; | ||
} | ||
// Create a new logger and copy over it's context | ||
SupertypeLogger.prototype.createChildLogger = function (context) { | ||
var child = {}; | ||
for (var prop in this) { | ||
child[prop] = this[prop]; | ||
} | ||
createChildLogger(context) { | ||
let child = new SupertypeLogger(); | ||
child.context = context || {}; | ||
for (var proper in this.context) { | ||
for (let proper in this.context) { | ||
child.context[proper] = this.context[proper]; | ||
} | ||
return child; // bad practice but should fix | ||
}; | ||
SupertypeLogger.prototype.formatDateTime = function (date) { | ||
} | ||
formatDateTime(date) { | ||
return f(2, (date.getMonth() + 1), '/') + f(2, date.getDate(), '/') + f(4, date.getFullYear(), ' ') + | ||
@@ -194,3 +156,3 @@ f(2, date.getHours(), ':') + f(2, date.getMinutes(), ':') + f(2, date.getSeconds(), ':') + | ||
} | ||
}; | ||
} | ||
/** | ||
@@ -203,11 +165,7 @@ * this function is designed to be replaced by the consumer of this class. | ||
*/ | ||
SupertypeLogger.prototype.sendToLog = function (logLevel, logObject) { | ||
var rawLogData = []; | ||
for (var _i = 2; _i < arguments.length; _i++) { | ||
rawLogData[_i - 2] = arguments[_i]; | ||
} | ||
sendToLog(logLevel, logObject, ...rawLogData) { | ||
console.log(this.prettyPrint(logLevel, logObject)); // eslint-disable-line no-console | ||
}; | ||
SupertypeLogger.prototype.prettyPrint = function (level, json) { | ||
var split = this.split(json, { time: 1, msg: 1, level: 1, name: 1 }); | ||
} | ||
prettyPrint(level, json) { | ||
let split = this.split(json, { time: 1, msg: 1, level: 1, name: 1 }); | ||
return this.formatDateTime(new Date(json.time)) + ': ' + | ||
@@ -236,13 +194,13 @@ level.toUpperCase() + ': ' + | ||
} | ||
}; | ||
SupertypeLogger.prototype.split = function (json, props) { | ||
var a = {}; | ||
var b = {}; | ||
for (var prop in json) { | ||
} | ||
split(json, props) { | ||
const a = {}; | ||
const b = {}; | ||
for (const prop in json) { | ||
(props[prop] ? b : a)[prop] = json[prop]; | ||
} | ||
return [a, b]; | ||
}; | ||
} | ||
// Logging is enabled if either the level threshold is met or the granular level matches | ||
SupertypeLogger.prototype.isEnabled = function (level, obj) { | ||
isEnabled(level, obj) { | ||
level = strToLevel[level]; | ||
@@ -253,3 +211,3 @@ if (level >= strToLevel[this.level]) { | ||
if (this.granularLevels) { | ||
for (var levelr in this.granularLevels) { | ||
for (let levelr in this.granularLevels) { | ||
if (obj[levelr] && obj[levelr] == this.granularLevels[levelr]) { | ||
@@ -260,6 +218,5 @@ return true; | ||
} | ||
}; | ||
return SupertypeLogger; | ||
}()); | ||
} | ||
} | ||
exports.SupertypeLogger = SupertypeLogger; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SupertypeLogger.js","sourceRoot":"","sources":["../src/SupertypeLogger.ts"],"names":[],"mappings":"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","sourcesContent":["const levelToStr = { 60: 'fatal', 50: 'error', 40: 'warn', 30: 'info', 20: 'debug', 10: 'trace' };\nconst strToLevel = { 'fatal': 60, 'error': 50, 'warn': 40, 'info': 30, 'debug': 20, 'trace': 10 };\n\nfunction isObject(obj) {\n    return obj != null\n        && typeof (obj) === 'object'\n        && !(obj instanceof Array)\n        && !(obj instanceof Date)\n        && !(obj instanceof Error);\n}\n\ntype LoggerFunction = (logLevel: string, logObject: any, ...rawLogData) => void;\n\ntype LogObject = {\n    level: string | number;\n    time: string;\n    msg: string;\n    module?: any;\n    activity?: any;\n    __amorphicContext: any;\n};\n\nexport class SupertypeLogger {\n    context: any;\n    granularLevels: any;\n    level: any;\n\n    // for overriding\n    // sendToLog: Function;\n    // formatDateTime: Function;\n\n    constructor() {\n        this.context = {};\n        this.granularLevels = {};\n        this.level = 'info';\n    }\n\n\n    fatal(...data: any[]): void {\n        this.log(60, ...data);\n    }\n\n    error(...data: any[]): void {\n        this.log(50, ...data);\n    }\n\n    warn(...data: any[]): void {\n        this.log(40, ...data);\n    }\n\n    info(...data: any[]): void {\n        this.log(30, ...data);\n    }\n    debug(...data: any[]): void {\n        this.log(20, ...data);\n    }\n    trace(...data: any[]): void {\n        this.log(10, ...data);\n    }\n\n    /**\n     * assign a custom send to log functionality.\n     * @param {(level: string, data: any) => void} loggerFunction\n     */\n    setLogger(loggerFunction: LoggerFunction) {\n        this.sendToLog = loggerFunction;\n    }\n\n    // Log all arguments assuming the first one is level and the second one might be an object (similar to banyan)\n    private log(level: number, ...data: any[]): void {\n        let msg = '';\n        const obj: LogObject = {\n            time: (new Date()).toISOString(),\n            msg: '',\n            level: 'info', //default info\n            __amorphicContext: {}\n        };\n\n        const amorphicContext = {};\n        // Copy amorphic context into the data\n        for (const prop in this.context) {\n            obj[prop] = this.context[prop];\n            amorphicContext[prop] = this.context[prop];\n        }\n\n        obj.level = level;\n        obj.__amorphicContext = amorphicContext;\n\n        data.forEach((arg, index) => {\n            if (index === 0 && isObject(arg)) {\n                for (const proper in arg) {\n                    obj[proper] = arg[proper];\n                }\n            }\n            else {\n                msg += `${arg} `;\n            }\n        });\n\n        if (obj.msg.length) {\n            obj.msg += ' ';\n        }\n\n        if (msg.length) {\n            if (obj.module && obj.activity) {\n                obj.msg += `${obj.module}[${obj.activity}] - `;\n            }\n\n            obj.msg += msg;\n        }\n        else if (obj.module && obj.activity) {\n            obj.msg += `${obj.module}[${obj.activity}]`;\n        }\n\n        if (this.isEnabled(levelToStr[obj.level], obj)) {\n            this.sendToLog(levelToStr[obj.level], obj, ...data);\n        }\n    }\n\n    startContext(context) {\n        this.context = context;\n    }\n\n    // Save the properties in the context and return a new object that has the properties only so they can be cleared\n    setContextProps(context) {\n        const reverse = {};\n\n        for (const prop in context) {\n            reverse[prop] = true;\n            this.context[prop] = context[prop];\n        }\n\n        return reverse;\n    }\n    // Parse log levels such as warn.activity\n    setLevel(level) {\n        var levels = level.split(';');\n\n        for (var ix = 0; ix < levels.length; ++ix) {\n            var levela = levels[ix];\n\n            if (levela.match(/:/)) {\n                if (levels[ix].match(/(.*):(.*)/)) {\n                    this.granularLevels[RegExp.$1] = this.granularLevels[RegExp.$1] || {};\n                    this.granularLevels[RegExp.$1] = RegExp.$2;\n                }\n                else {\n                    this.level = levels[ix];\n                }\n            }\n            else {\n                this.level = levela;\n            }\n        }\n    }\n\n    // Remove any properties recorded by setContext\n    clearContextProps(contextToClear) {\n        for (const prop in contextToClear) {\n            delete this.context[prop];\n        }\n    }\n\n    // Create a new logger and copy over it's context\n    createChildLogger(context): SupertypeLogger {\n        let child: { [key: string]: any } = {};\n\n        for (let prop in this) {\n            child[prop] = this[prop];\n        }\n\n        child.context = context || {};\n\n        for (let proper in this.context) {\n            child.context[proper] = this.context[proper];\n        }\n\n        return child as SupertypeLogger; // bad practice but should fix\n    }\n\n    formatDateTime(date): string {\n        return f(2, (date.getMonth() + 1), '/') + f(2, date.getDate(), '/') + f(4, date.getFullYear(), ' ') +\n            f(2, date.getHours(), ':') + f(2, date.getMinutes(), ':') + f(2, date.getSeconds(), ':') +\n            f(3, date.getMilliseconds()) + ' GMT' + (0 - date.getTimezoneOffset() / 60);\n\n        function f(z, d, s?) {\n            while (String(d).length < z) {\n                d = '0' + d;\n            }\n\n            return d + (s || '');\n        }\n    }\n\n    /**\n     * this function is designed to be replaced by the consumer of this class.\n     *\n     * @param logLevel - log level\n     * @param logObject - formatted log object, passed in from consumer\n     * @param rawLogData - unformatted and unprocessed version of \"logObject\" param\n     */\n    protected sendToLog(logLevel, logObject, ...rawLogData) {\n        console.log(this.prettyPrint(logLevel, logObject));     // eslint-disable-line no-console\n    }\n\n    prettyPrint(level, json) {\n        let split = this.split(json, {time: 1, msg: 1, level: 1, name: 1});\n\n        return this.formatDateTime(new Date(json.time)) + ': ' +\n            level.toUpperCase() + ': ' +\n            addColonIfToken(split[1].name, ': ') +\n            addColonIfToken(split[1].msg, ': ') +\n            xy(split[0]);\n\n        function addColonIfToken (token, colonAndSpace) {\n            if (token) {\n                return token + colonAndSpace;\n            }\n\n            return '';\n        }\n\n        function xy(j) {\n            var str = '';\n            var sep = '';\n\n            for (var prop in j) {\n                str += sep + prop + '=' + JSON.stringify(j[prop]);\n                sep = ' ';\n            }\n\n            if (str.length > 0) {\n                return '(' + str + ')';\n            }\n\n            return '';\n        }\n    }\n\n    private split(json, props): any[] {\n        const a = {};\n        const b = {};\n\n        for (const prop in json) {\n            (props[prop] ? b : a)[prop] = json[prop];\n        }\n\n        return [a, b];\n    }\n\n    // Logging is enabled if either the level threshold is met or the granular level matches\n    private isEnabled(level, obj) {\n        level = strToLevel[level];\n\n        if (level >= strToLevel[this.level]) {\n            return true;\n        }\n\n        if (this.granularLevels) {\n            for (let levelr in this.granularLevels) {\n                if (obj[levelr] && obj[levelr] == this.granularLevels[levelr]) {\n                    return true;\n                }\n            }\n        }\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SupertypeLogger.js","sourceRoot":"","sources":["../src/SupertypeLogger.ts"],"names":[],"mappings":"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","sourcesContent":["const levelToStr = { 60: 'fatal', 50: 'error', 40: 'warn', 30: 'info', 20: 'debug', 10: 'trace' };\nconst strToLevel = { 'fatal': 60, 'error': 50, 'warn': 40, 'info': 30, 'debug': 20, 'trace': 10 };\n\nfunction isObject(obj) {\n    return obj != null\n        && typeof (obj) === 'object'\n        && !(obj instanceof Array)\n        && !(obj instanceof Date)\n        && !(obj instanceof Error);\n}\n\ntype LoggerFunction = (logLevel: string, logObject: any, ...rawLogData) => void;\n\ntype LogObject = {\n    level: string | number;\n    time: string;\n    msg: string;\n    module?: any;\n    activity?: any;\n    __amorphicContext: any;\n};\n\nexport class SupertypeLogger {\n    context: any;\n    granularLevels: any;\n    level: any;\n\n    // for overriding\n    // sendToLog: Function;\n    // formatDateTime: Function;\n\n    constructor() {\n        this.context = {};\n        this.granularLevels = {};\n        this.level = 'info';\n    }\n\n\n    fatal(...data: any[]): void {\n        this.log(60, ...data);\n    }\n\n    error(...data: any[]): void {\n        this.log(50, ...data);\n    }\n\n    warn(...data: any[]): void {\n        this.log(40, ...data);\n    }\n\n    info(...data: any[]): void {\n        this.log(30, ...data);\n    }\n    debug(...data: any[]): void {\n        this.log(20, ...data);\n    }\n    trace(...data: any[]): void {\n        this.log(10, ...data);\n    }\n\n    /**\n     * assign a custom send to log functionality.\n     * @param {(level: string, data: any) => void} loggerFunction\n     */\n    setLogger(loggerFunction: LoggerFunction) {\n        this.sendToLog = loggerFunction;\n    }\n\n    // Log all arguments assuming the first one is level and the second one might be an object (similar to banyan)\n    private log(level: number, ...data: any[]): void {\n        let msg = '';\n        const obj: LogObject = {\n            time: (new Date()).toISOString(),\n            msg: '',\n            level: 'info', //default info\n            __amorphicContext: {}\n        };\n\n        const amorphicContext = {};\n        // Copy amorphic context into the data\n        for (const prop in this.context) {\n            obj[prop] = this.context[prop];\n            amorphicContext[prop] = this.context[prop];\n        }\n\n        obj.level = level;\n        obj.__amorphicContext = amorphicContext;\n\n        data.forEach((arg, index) => {\n            if (index === 0 && isObject(arg)) {\n                for (const proper in arg) {\n                    obj[proper] = arg[proper];\n                }\n            }\n            else {\n                msg += `${arg} `;\n            }\n        });\n\n        if (obj.msg.length) {\n            obj.msg += ' ';\n        }\n\n        if (msg.length) {\n            if (obj.module && obj.activity) {\n                obj.msg += `${obj.module}[${obj.activity}] - `;\n            }\n\n            obj.msg += msg;\n        }\n        else if (obj.module && obj.activity) {\n            obj.msg += `${obj.module}[${obj.activity}]`;\n        }\n\n        if (this.isEnabled(levelToStr[obj.level], obj)) {\n            this.sendToLog(levelToStr[obj.level], obj, ...data);\n        }\n    }\n\n    startContext(context) {\n        this.context = context;\n    }\n\n    // Save the properties in the context and return a new object that has the properties only so they can be cleared\n    setContextProps(context) {\n        const reverse = {};\n\n        for (const prop in context) {\n            reverse[prop] = true;\n            this.context[prop] = context[prop];\n        }\n\n        return reverse;\n    }\n    // Parse log levels such as warn.activity\n    setLevel(level) {\n        var levels = level.split(';');\n\n        for (var ix = 0; ix < levels.length; ++ix) {\n            var levela = levels[ix];\n\n            if (levela.match(/:/)) {\n                if (levels[ix].match(/(.*):(.*)/)) {\n                    this.granularLevels[RegExp.$1] = this.granularLevels[RegExp.$1] || {};\n                    this.granularLevels[RegExp.$1] = RegExp.$2;\n                }\n                else {\n                    this.level = levels[ix];\n                }\n            }\n            else {\n                this.level = levela;\n            }\n        }\n    }\n\n    // Remove any properties recorded by setContext\n    clearContextProps(contextToClear) {\n        for (const prop in contextToClear) {\n            delete this.context[prop];\n        }\n    }\n\n    // Create a new logger and copy over it's context\n    createChildLogger(context): SupertypeLogger {\n        let child = new SupertypeLogger();\n        \n        child.context = context || {};\n\n        for (let proper in this.context) {\n            child.context[proper] = this.context[proper];\n        }\n\n        return child as SupertypeLogger; // bad practice but should fix\n    }\n\n    formatDateTime(date): string {\n        return f(2, (date.getMonth() + 1), '/') + f(2, date.getDate(), '/') + f(4, date.getFullYear(), ' ') +\n            f(2, date.getHours(), ':') + f(2, date.getMinutes(), ':') + f(2, date.getSeconds(), ':') +\n            f(3, date.getMilliseconds()) + ' GMT' + (0 - date.getTimezoneOffset() / 60);\n\n        function f(z, d, s?) {\n            while (String(d).length < z) {\n                d = '0' + d;\n            }\n\n            return d + (s || '');\n        }\n    }\n\n    /**\n     * this function is designed to be replaced by the consumer of this class.\n     *\n     * @param logLevel - log level\n     * @param logObject - formatted log object, passed in from consumer\n     * @param rawLogData - unformatted and unprocessed version of \"logObject\" param\n     */\n    protected sendToLog(logLevel, logObject, ...rawLogData) {\n        console.log(this.prettyPrint(logLevel, logObject));     // eslint-disable-line no-console\n    }\n\n    prettyPrint(level, json) {\n        let split = this.split(json, {time: 1, msg: 1, level: 1, name: 1});\n\n        return this.formatDateTime(new Date(json.time)) + ': ' +\n            level.toUpperCase() + ': ' +\n            addColonIfToken(split[1].name, ': ') +\n            addColonIfToken(split[1].msg, ': ') +\n            xy(split[0]);\n\n        function addColonIfToken (token, colonAndSpace) {\n            if (token) {\n                return token + colonAndSpace;\n            }\n\n            return '';\n        }\n\n        function xy(j) {\n            var str = '';\n            var sep = '';\n\n            for (var prop in j) {\n                str += sep + prop + '=' + JSON.stringify(j[prop]);\n                sep = ' ';\n            }\n\n            if (str.length > 0) {\n                return '(' + str + ')';\n            }\n\n            return '';\n        }\n    }\n\n    private split(json, props): any[] {\n        const a = {};\n        const b = {};\n\n        for (const prop in json) {\n            (props[prop] ? b : a)[prop] = json[prop];\n        }\n\n        return [a, b];\n    }\n\n    // Logging is enabled if either the level threshold is met or the granular level matches\n    private isEnabled(level, obj) {\n        level = strToLevel[level];\n\n        if (level >= strToLevel[this.level]) {\n            return true;\n        }\n\n        if (this.granularLevels) {\n            for (let levelr in this.granularLevels) {\n                if (obj[levelr] && obj[levelr] == this.granularLevels[levelr]) {\n                    return true;\n                }\n            }\n        }\n    }\n}"]} |
{ | ||
"name": "@haventech/supertype", | ||
"description": "A type system for classical inheritence, mix-ins and composition.", | ||
"version": "5.1.0-beta.0", | ||
"version": "6.0.0-beta.0", | ||
"main": "dist/index.js", | ||
@@ -10,3 +10,3 @@ "types": "dist/index.d.ts", | ||
"@haventech/amorphic-contracts": "^0.2.0", | ||
"nconf": "^0.11.0", | ||
"nconf": "^0.12.0", | ||
"reflect-metadata": "^0.1.12" | ||
@@ -30,4 +30,3 @@ }, | ||
"lint": "eslint .", | ||
"debug:tests": "mocha --inspect-brk test/animals.js", | ||
"debug:tstests": "mocha --inspect-brk test/typescript/*.js", | ||
"test:ts:debug": "mocha --inspect-brk --require ts-node/register test/typescript/*", | ||
"test:ts": "mocha --require ts-node/register test/typescript/*", | ||
@@ -34,0 +33,0 @@ "clean": "rm -rf dist/", |
export { Supertype } from './Supertype'; | ||
import { ObjectTemplate } from './ObjectTemplate'; | ||
import 'reflect-metadata'; | ||
/** | ||
@@ -125,3 +123,3 @@ * | ||
function getName() { | ||
return target.toString().match(/function ([^(]*)/)[1]; | ||
return ObjectTemplate.getName(target); | ||
} | ||
@@ -148,14 +146,4 @@ function getDictionary() { | ||
target.__amorphicprops__ = target.hasOwnProperty('__amorphicprops__') ? target.__amorphicprops__ : {}; | ||
var reflectionType = Reflect.getMetadata('design:type', target, targetKey); | ||
var declaredType = props.type; | ||
var type = reflectionType !== Array ? declaredType || reflectionType : declaredType; | ||
// Type mismatches | ||
if (declaredType && reflectionType && reflectionType !== Array) { | ||
target.__exceptions__ = target.__exceptions__ || {}; | ||
target.__exceptions__[targetKey] = function (className, prop) { | ||
return className + '.' + prop + ' - decorator type does not match actual type'; | ||
}; | ||
// Deferred type | ||
} | ||
else if (typeof props.getType === 'function') { | ||
let type = props.type; | ||
if (typeof props.getType === 'function') { | ||
target.__deferredType__ = target.hasOwnProperty('__deferredType__') ? target.__deferredType__ : {}; | ||
@@ -174,9 +162,2 @@ target.__deferredType__[targetKey] = props.getType; | ||
} | ||
if (reflectionType === Array) { | ||
props.type = Array; | ||
props.of = type; | ||
} | ||
else { | ||
props.type = type; | ||
} | ||
target.__amorphicprops__[targetKey] = props; | ||
@@ -183,0 +164,0 @@ }; |
@@ -418,3 +418,3 @@ import * as serializer from './serializer'; | ||
*/ | ||
static createIfNeeded(template?, thisObj?) { | ||
static createIfNeeded(template?, thisObj?) { | ||
if (template.__createParameters__) { | ||
@@ -453,4 +453,4 @@ const createParameters = template.__createParameters__; | ||
var template = this.__templates__[ix]; | ||
this.__dictionary__[constructorName(template)] = template; | ||
this.__templatesToInject__[constructorName(template)] = template; | ||
this.__dictionary__[ObjectTemplateStatic._getName(template)] = template; | ||
this.__templatesToInject__[ObjectTemplateStatic._getName(template)] = template; | ||
processDeferredTypes(template); | ||
@@ -461,3 +461,3 @@ } | ||
var template = this.__dictionary__[templateName1]; | ||
const parentTemplateName = constructorName(Object.getPrototypeOf(template.prototype).constructor); | ||
const parentTemplateName = ObjectTemplateStatic._getName(Object.getPrototypeOf(template.prototype).constructor); | ||
template.__shadowParent__ = this.__dictionary__[parentTemplateName]; | ||
@@ -500,8 +500,6 @@ if (template.__shadowParent__) { | ||
return this.__dictionary__; | ||
} | ||
function constructorName(constructor) { | ||
const namedFunction = constructor.toString().match(/function ([^(]*)/); | ||
return namedFunction ? namedFunction[1] : null; | ||
} | ||
static getName(object) { | ||
return ObjectTemplateStatic._getName(object); | ||
} | ||
@@ -544,82 +542,2 @@ | ||
/** | ||
* Used by template setup to create an property descriptor for use by the constructor | ||
* | ||
* @param {unknown} propertyName is the name of the property | ||
* @param {unknown} defineProperty is the property descriptor passed to the template | ||
* @param {unknown} objectProperties is all properties that will be processed manually. A new property is | ||
* added to this if the property needs to be initialized by value | ||
* @param {unknown} defineProperties is all properties that will be passed to Object.defineProperties | ||
* A new property will be added to this object | ||
* | ||
* @private | ||
*/ | ||
static _setupProperty(propertyName, defineProperty, objectProperties, defineProperties) { | ||
// Determine whether value needs to be re-initialized in constructor | ||
const value = defineProperty.value; | ||
const byValue = value && typeof (value) !== 'number' && typeof (value) !== 'string'; | ||
if (byValue || !Object.defineProperties || defineProperty.get || defineProperty.set) { | ||
objectProperties[propertyName] = { | ||
init: defineProperty.value, | ||
type: defineProperty.type, | ||
of: defineProperty.of, | ||
byValue | ||
}; | ||
delete defineProperty.value; | ||
} | ||
// When a super class based on objectTemplate don't transport properties | ||
defineProperty.toServer = false; | ||
defineProperty.toClient = false; | ||
defineProperties[propertyName] = defineProperty; | ||
// Add getters and setters | ||
if (defineProperty.get || defineProperty.set) { | ||
const userSetter = defineProperty.set; | ||
defineProperty.set = (function d() { | ||
// Use a closure to record the property name which is not passed to the setter | ||
const prop = propertyName; | ||
return function c(value) { | ||
if (userSetter) { | ||
value = userSetter.call(this, value); | ||
} | ||
if (!defineProperty.isVirtual) { | ||
this[`__${prop}`] = value; | ||
} | ||
}; | ||
})(); | ||
const userGetter = defineProperty.get; | ||
defineProperty.get = (function get() { | ||
// Use closure to record property name which is not passed to the getter | ||
const prop = propertyName; | ||
return function b() { | ||
if (userGetter) { | ||
if (defineProperty.isVirtual) { | ||
return userGetter.call(this, undefined); | ||
} | ||
return userGetter.call(this, this[`__${prop}`]); | ||
} | ||
return this[`__${prop}`]; | ||
}; | ||
})(); | ||
if (!defineProperty.isVirtual) { | ||
defineProperties[`__${propertyName}`] = { enumerable: false, writable: true }; | ||
} | ||
delete defineProperty.value; | ||
delete defineProperty.writable; | ||
} | ||
} | ||
/** | ||
* Clone an object created from an ObjectTemplate | ||
@@ -754,67 +672,3 @@ * Used only within supertype (see copyObject for general copy) | ||
/** | ||
/** | ||
* Find the right subclass to instantiate by either looking at the | ||
* declared list in the subClasses define property or walking through | ||
* the subclasses of the declared template | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} objId unknown | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
static _resolveSubClass(template, objId, defineProperty) { | ||
let templateName = ''; | ||
if (objId.match(/-([A-Za-z0-9_:]*)-/)) { | ||
templateName = RegExp.$1; | ||
} | ||
// Resolve template subclass for polymorphic instantiation | ||
if (defineProperty && defineProperty.subClasses && objId != 'anonymous)') { | ||
if (templateName) { | ||
for (let ix = 0; ix < defineProperty.subClasses.length; ++ix) { | ||
if (templateName == defineProperty.subClasses[ix].__name__) { | ||
template = defineProperty.subClasses[ix]; | ||
} | ||
} | ||
} | ||
} | ||
else { | ||
const subClass = this._findSubClass(template, templateName); | ||
if (subClass) { | ||
template = subClass; | ||
} | ||
} | ||
return template; | ||
} | ||
/** | ||
* Walk recursively through extensions of template via __children__ | ||
* looking for a name match | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} templateName unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
static _findSubClass(template, templateName) { | ||
if (template.__name__ == templateName) { | ||
return template; | ||
} | ||
for (let ix = 0; ix < template.__children__.length; ++ix) { | ||
const subClass = this._findSubClass(template.__children__[ix], templateName); | ||
if (subClass) { | ||
return subClass; | ||
} | ||
} | ||
return null; | ||
} | ||
/** | ||
* Return the highest level template | ||
@@ -828,3 +682,3 @@ * | ||
*/ | ||
static _getBaseClass(template) { | ||
static _getBaseClass(template) { | ||
while (template.__parent__) { | ||
@@ -837,15 +691,15 @@ template = template.__parent__; | ||
/** | ||
* An overridable function used to create an object from a template and optionally | ||
* manage the caching of that object (used by derivative type systems). It | ||
* preserves the original id of an object | ||
* | ||
* @param {unknown} template of object | ||
* @param {unknown} objId and id (if present) | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
/** | ||
* An overridable function used to create an object from a template and optionally | ||
* manage the caching of that object (used by derivative type systems). It | ||
* preserves the original id of an object | ||
* | ||
* @param {unknown} template of object | ||
* @param {unknown} objId and id (if present) | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
* @private | ||
*/ | ||
static _createEmptyObject(template, objId, defineProperty) { | ||
template = this._resolveSubClass(template, objId, defineProperty); | ||
template = ObjectTemplateStatic._resolveSubClass(template, objId, defineProperty); | ||
@@ -1232,3 +1086,3 @@ const oldStashObject = this._stashObject; | ||
objectTemplate._setupProperty(propertyName, defineProperty, objectProperties, defineProperties, parentTemplate, createProperties); | ||
ObjectTemplateStatic._setupProperty(propertyName, defineProperty, objectProperties, defineProperties); | ||
defineProperty.sourceTemplate = templateName; | ||
@@ -1239,2 +1093,160 @@ } | ||
class ObjectTemplateStatic { | ||
/** | ||
* Getting the name of the object | ||
* | ||
* @param {unknown} object object we are getting the name for | ||
* @returns a string of the name of the object or null | ||
*/ | ||
static _getName(object) { | ||
if (typeof object === 'function') { | ||
return object.name; | ||
} | ||
if (object.constructor) { | ||
return object.constructor.name; | ||
} | ||
return null; | ||
} | ||
/** | ||
* Used by template setup to create an property descriptor for use by the constructor | ||
* | ||
* @param {unknown} propertyName is the name of the property | ||
* @param {unknown} defineProperty is the property descriptor passed to the template | ||
* @param {unknown} objectProperties is all properties that will be processed manually. A new property is | ||
* added to this if the property needs to be initialized by value | ||
* @param {unknown} defineProperties is all properties that will be passed to Object.defineProperties | ||
* A new property will be added to this object | ||
* | ||
*/ | ||
static _setupProperty(propertyName, defineProperty, objectProperties, defineProperties) { | ||
// Determine whether value needs to be re-initialized in constructor | ||
const value = defineProperty.value; | ||
const byValue = value && typeof (value) !== 'number' && typeof (value) !== 'string'; | ||
if (byValue || !Object.defineProperties || defineProperty.get || defineProperty.set) { | ||
objectProperties[propertyName] = { | ||
init: defineProperty.value, | ||
type: defineProperty.type, | ||
of: defineProperty.of, | ||
byValue | ||
}; | ||
delete defineProperty.value; | ||
} | ||
// When a super class based on objectTemplate don't transport properties | ||
defineProperty.toServer = false; | ||
defineProperty.toClient = false; | ||
defineProperties[propertyName] = defineProperty; | ||
// Add getters and setters | ||
if (defineProperty.get || defineProperty.set) { | ||
const userSetter = defineProperty.set; | ||
defineProperty.set = (function d() { | ||
// Use a closure to record the property name which is not passed to the setter | ||
const prop = propertyName; | ||
return function c(value) { | ||
if (userSetter) { | ||
value = userSetter.call(this, value); | ||
} | ||
if (!defineProperty.isVirtual) { | ||
this[`__${prop}`] = value; | ||
} | ||
}; | ||
})(); | ||
const userGetter = defineProperty.get; | ||
defineProperty.get = (function get() { | ||
// Use closure to record property name which is not passed to the getter | ||
const prop = propertyName; | ||
return function b() { | ||
if (userGetter) { | ||
if (defineProperty.isVirtual) { | ||
return userGetter.call(this, undefined); | ||
} | ||
return userGetter.call(this, this[`__${prop}`]); | ||
} | ||
return this[`__${prop}`]; | ||
}; | ||
})(); | ||
if (!defineProperty.isVirtual) { | ||
defineProperties[`__${propertyName}`] = { enumerable: false, writable: true }; | ||
} | ||
delete defineProperty.value; | ||
delete defineProperty.writable; | ||
} | ||
} | ||
/** | ||
* Find the right subclass to instantiate by either looking at the | ||
* declared list in the subClasses define property or walking through | ||
* the subclasses of the declared template | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} objId unknown | ||
* @param {unknown} defineProperty unknown | ||
* @returns {*} | ||
*/ | ||
static _resolveSubClass(template, objId, defineProperty) { | ||
let templateName = ''; | ||
if (objId.match(/-([A-Za-z0-9_:]*)-/)) { | ||
templateName = RegExp.$1; | ||
} | ||
// Resolve template subclass for polymorphic instantiation | ||
if (defineProperty && defineProperty.subClasses && objId != 'anonymous)') { | ||
if (templateName) { | ||
for (let ix = 0; ix < defineProperty.subClasses.length; ++ix) { | ||
if (templateName == defineProperty.subClasses[ix].__name__) { | ||
template = defineProperty.subClasses[ix]; | ||
} | ||
} | ||
} | ||
} | ||
else { | ||
const subClass = this._findSubClass(template, templateName); | ||
if (subClass) { | ||
template = subClass; | ||
} | ||
} | ||
return template; | ||
} | ||
/** | ||
* Walk recursively through extensions of template via __children__ | ||
* looking for a name match | ||
* | ||
* @param {unknown} template unknown | ||
* @param {unknown} templateName unknown | ||
* @returns {*} | ||
*/ | ||
static _findSubClass(template, templateName) { | ||
if (template.__name__ == templateName) { | ||
return template; | ||
} | ||
for (let ix = 0; ix < template.__children__.length; ++ix) { | ||
const subClass = this._findSubClass(template.__children__[ix], templateName); | ||
if (subClass) { | ||
return subClass; | ||
} | ||
} | ||
return null; | ||
} | ||
} | ||
function bindParams(templateName, objectTemplate, functionProperties, | ||
@@ -1241,0 +1253,0 @@ defineProperties, parentTemplate, propertiesOrTemplate, |
@@ -69,3 +69,3 @@ /** | ||
var obj; | ||
let obj; | ||
@@ -72,0 +72,0 @@ if (creator) { |
import {ObjectTemplate} from './ObjectTemplate'; | ||
import * as serializer from './serializer'; | ||
function constructorName(constructor) { | ||
var namedFunction = constructor.toString().match(/function ([^(]*)/); | ||
return namedFunction ? namedFunction[1] : null; | ||
} | ||
export type Constructable = new (...args: any[]) => {}; | ||
@@ -70,3 +65,3 @@ | ||
if (!template) { | ||
throw new Error(constructorName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass'); | ||
throw new Error(ObjectTemplate.getName(Object.getPrototypeOf(this).constructor) + ' missing @supertypeClass'); | ||
} | ||
@@ -123,3 +118,3 @@ | ||
createCopy(creator) { | ||
var obj = this; | ||
const obj = this; | ||
return ObjectTemplate.fromPOJO(obj, obj.__template__, null, null, undefined, null, null, creator); | ||
@@ -126,0 +121,0 @@ } |
@@ -166,8 +166,4 @@ const levelToStr = { 60: 'fatal', 50: 'error', 40: 'warn', 30: 'info', 20: 'debug', 10: 'trace' }; | ||
createChildLogger(context): SupertypeLogger { | ||
let child: { [key: string]: any } = {}; | ||
for (let prop in this) { | ||
child[prop] = this[prop]; | ||
} | ||
let child = new SupertypeLogger(); | ||
child.context = context || {}; | ||
@@ -174,0 +170,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
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
362076
4424
+ Addedasync@3.2.6(transitive)
+ Addednconf@0.12.1(transitive)
- Removedasync@1.5.2(transitive)
- Removednconf@0.11.4(transitive)
Updatednconf@^0.12.0