Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@haventech/semotus

Package Overview
Dependencies
Maintainers
5
Versions
45
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@haventech/semotus - npm Package Compare versions

Comparing version 6.0.1 to 6.1.0-beta.0

123

dist/helpers/ProcessCall.js

@@ -41,2 +41,3 @@ "use strict";

var Utilities_1 = require("./Utilities");
var moduleName = 'ProcessCall';
/**

@@ -122,14 +123,16 @@ * We process the call the remote method in stages starting by letting the controller examine the

return __awaiter(this, void 0, void 0, function () {
var semotus, remoteCall, session, callContext, HTTPObjs, changes, objId, remoteObject, remoteTemplate, isPublic;
var semotus, remoteCall, session, callContext, HTTPObjs, functionName, changes, objId, remoteObject, remoteTemplate, isPublic;
return __generator(this, function (_a) {
semotus = payload.semotus, remoteCall = payload.remoteCall, session = payload.session, callContext = payload.callContext, HTTPObjs = payload.HTTPObjs;
functionName = preCallHook.name;
semotus.logger.info({
component: 'semotus',
module: 'processCall',
activity: 'preServerCall',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'preServerCall',
call: remoteCall.name,
sequence: remoteCall.sequence
}
}, remoteCall.name);
});
if (semotus.controller && semotus.controller.preServerCall) {

@@ -152,10 +155,12 @@ changes = {};

semotus.logger.error({
component: 'semotus',
module: 'processCall',
activity: 'preServerCall',
module: moduleName,
function: functionName,
category: 'milestone',
message: 'Could not find template for ' + objId,
data: {
activity: 'preServerCall',
call: remoteCall.name,
sequence: remoteCall.sequence
}
}, 'Could not find template for ' + objId);
});
}

@@ -178,7 +183,9 @@ return [2 /*return*/, semotus.controller.preServerCall.call(semotus.controller, remoteCall.changes.length > 2, changes, callContext, forceupdate, remoteCall.name, remoteCall, isPublic, HTTPObjs)];

var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback;
var functionName = applyChangesAndValidateCall.name;
semotus.logger.info({
component: 'semotus',
module: 'processCall',
activity: 'applyChangesAndValidateCall',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'applyChangesAndValidateCall',
call: remoteCall.name,

@@ -188,3 +195,3 @@ sequence: remoteCall.sequence,

}
}, remoteCall.name);
});
var changes = JSON.parse(remoteCall.changes);

@@ -221,7 +228,9 @@ var res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext);

var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback;
var functionName = customValidation.name;
var loggerObject = {
component: 'semotus',
module: 'processCall',
activity: 'customValidation',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'customValidation',
call: remoteCall.name,

@@ -233,3 +242,3 @@ sequence: remoteCall.sequence,

var remoteObject = session.objects[remoteCall.id];
semotus.logger.info(loggerObject, remoteCall.name);
semotus.logger.info(loggerObject);
if (!isValid) {

@@ -260,10 +269,12 @@ return false;

return __awaiter(this, void 0, void 0, function () {
var semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback, loggerObject, obj, args;
var semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback, functionName, loggerObject, obj, args;
return __generator(this, function (_a) {
semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, subscriptionId = payload.subscriptionId, remoteCallId = payload.remoteCallId, restoreSessionCallback = payload.restoreSessionCallback;
functionName = callIfValid.name;
loggerObject = {
component: 'semotus',
module: 'processCall',
activity: 'callIfValid',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'callIfValid',
call: remoteCall.name,

@@ -274,3 +285,3 @@ sequence: remoteCall.sequence,

};
semotus.logger.info(loggerObject, remoteCall.name);
semotus.logger.info(loggerObject);
obj = session.objects[remoteCall.id];

@@ -325,7 +336,9 @@ if (!obj[remoteCall.name]) {

var semotus = payload.semotus, remoteCall = payload.remoteCall, callContext = payload.callContext, session = payload.session, remoteCallId = payload.remoteCallId;
var functionName = postCallSuccess.name;
semotus.logger.info({
component: 'semotus',
module: 'processCall',
activity: 'postCall.success',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'postCall.success',
call: remoteCall.name,

@@ -335,3 +348,3 @@ callTime: Utilities_1.logTime(callContext),

}
}, remoteCall.name);
});
packageChanges(semotus, session, {

@@ -359,9 +372,10 @@ type: 'response',

return __awaiter(this, void 0, void 0, function () {
var errorType, functionName, obj, logBody, error_1;
var functionName, errorType, remoteCallName, obj, error_1, logBody;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
functionName = resolveErrorHandler.name;
if (!(controller && controller.postServerErrorHandler)) return [3 /*break*/, 4];
errorType = type;
functionName = remoteCall.name;
remoteCallName = remoteCall.name;
obj = undefined;

@@ -371,15 +385,6 @@ if (session.objects[remoteCall.id]) {

}
logBody = {
component: 'semotus',
module: 'processCall.failure',
activity: 'postCall.resolveErrorHandler',
data: {
call: remoteCall.name,
message: undefined
}
};
_a.label = 1;
case 1:
_a.trys.push([1, 3, , 4]);
return [4 /*yield*/, controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString)];
return [4 /*yield*/, controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, remoteCallName, callContext, changeString)];
case 2:

@@ -390,10 +395,15 @@ _a.sent();

error_1 = _a.sent();
if (error_1.message) {
logBody.data.message = error_1.message;
logger.error(error_1.message);
}
else {
logBody.data.message = JSON.stringify(error_1);
}
logger.error(logBody, 'User defined postServerErrorHandler threw an error');
logBody = {
module: moduleName,
function: functionName,
category: 'milestone',
error: error_1,
message: 'User defined postServerErrorHandler threw an error',
data: {
activity: 'postCall.resolveErrorHandler',
call: remoteCall.name,
message: error_1.message ? error_1.message : JSON.stringify(error_1)
}
};
logger.error(logBody);
return [3 /*break*/, 4];

@@ -521,20 +531,19 @@ case 4: return [2 /*return*/];

function postCallErrorLog(logger, activity, message, logType, logString, remoteCall, callContext) {
var functionName = processCall.name;
var logBody = {
component: 'semotus',
module: 'processCall.failure',
module: moduleName,
function: functionName,
category: 'milestone',
message: logString,
data: {
message: message,
activity: activity,
call: remoteCall.name,
callTime: Utilities_1.logTime(callContext),
sequence: remoteCall.sequence,
message: undefined
},
activity: undefined
}
};
logBody.activity = activity;
if (logger.data) {
logBody.data.message = message;
}
logger[logType](logBody, logString);
logger[logType](logBody);
}
exports.postCallErrorLog = postCallErrorLog;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ProcessCall.js","sourceRoot":"","sources":["../../src/helpers/ProcessCall.ts"],"names":[],"mappings":"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","sourcesContent":["import {delay, getError, logTime} from './Utilities';\nimport {CallContext, ProcessCallPayload, RemoteCall, Semotus, Session} from './Types';\n\n/**\n * We process the call the remote method in stages starting by letting the controller examine the\n * changes (preCallHook) and giving it a chance to refresh data if it needs to.  Then we apply any\n * changes in the messages and give the object owning the method a chance to validate that the\n * call is valid and take care of any authorization concerns.  Finally we let the controller perform\n * any post-call processing such as commiting data and then we deal with a failure or success.\n *\n * @param payload\n * @param {unknown} forceupdate unknown\n *\n * @returns {unknown} unknown\n */\nexport async function processCall(payload: ProcessCallPayload, forceupdate?: boolean) {\n\n    try {\n        forceupdate = await Promise.resolve(forceupdate);\n        await preCallHook(payload, forceupdate);\n        let validation = await applyChangesAndValidateCall(payload);\n        validation = await customValidation(payload, validation);\n        const result = await callIfValid(payload, validation);\n        await postCallHook(payload, result);\n        await postCallSuccess(payload, result);\n    } catch (err) {\n        await postCallFailure(payload, err);\n    }\n}\n\n\n/**\n * If there is an update conflict we want to retry after restoring the session\n *\n * @returns {*} unknown\n */\nasync function retryCall(payload: ProcessCallPayload) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    if (restoreSessionCallback) {\n        restoreSessionCallback();\n    }\n\n    return processCall(payload, true);\n}\n\n/**\n * Determine what objects changed and pass this to the preServerCall method on the controller\n *\n * @param payload\n * @param  forceupdate unknown\n *\n * @returns  unknown\n */\nasync function preCallHook(payload: ProcessCallPayload, forceupdate?: boolean): Promise<any> {\n    const {semotus, remoteCall, session, callContext, HTTPObjs} = payload;\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'preServerCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    if (semotus.controller && semotus.controller.preServerCall) {\n        let changes = {};\n\n        for (var objId in JSON.parse(remoteCall.changes)) {\n            changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true;\n        }\n\n        let remoteObject = session.objects[remoteCall.id];\n\n        // Need to double check if not in session, what the template is.\n        let remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')];\n        let isPublic = false;\n\n        if (remoteObject) {\n            isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic;\n        }\n        else if (remoteTemplate) {\n            // If the class doesn't exist, we should get the remote function from the prototype\n            isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic;\n        }\n        else {\n            semotus.logger.error({\n                component: 'semotus',\n                module: 'processCall',\n                activity: 'preServerCall',\n                data: {\n                    call: remoteCall.name,\n                    sequence: remoteCall.sequence\n                }\n            }, \t'Could not find template for ' + objId);\n        }\n\n        return semotus.controller.preServerCall.call(\n            semotus.controller,\n            remoteCall.changes.length > 2,\n            changes,\n            callContext,\n            forceupdate,\n            remoteCall.name,\n            remoteCall,\n            isPublic,\n            HTTPObjs\n        );\n    } else {\n        return true;\n    }\n}\n\n/**\n * Apply changes in the message and then validate the call.  Throw \"Sync Error\" if changes can't be applied\n *\n * @returns {unknown} unknown\n */\nfunction applyChangesAndValidateCall(payload: ProcessCallPayload): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'applyChangesAndValidateCall',\n            data: {\n                call: remoteCall.name,\n                sequence: remoteCall.sequence,\n                remoteCallId: remoteCall.id\n            }\n        },\n        remoteCall.name\n    );\n\n    let changes = JSON.parse(remoteCall.changes);\n\n    const res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext);\n    if (res) {\n        const obj = session.objects[remoteCall.id];\n\n        if (!obj) {\n            throw new Error(`Cannot find object for remote call ${remoteCall.id}`);\n        }\n\n        // check to see if this function is supposed to be called directly from client\n        if (obj.__proto__[remoteCall.name].__on__ !== 'server') {\n            throw 'Invalid Function Call; not an API function';\n        }\n\n        if (semotus.role === 'server' && obj.validateServerCall) {\n            return obj.validateServerCall.call(obj, remoteCall.name, callContext);\n        }\n\n        return true;\n    } else {\n        throw 'Sync Error';\n    }\n}\n\n/**\n * Apply function specific custom serverSide validation functions\n *\n * @param semotus\n * @param {boolean} isValid - Result of previous validation step (applyChangesAndValidateCall)\n * @param session\n * @param remoteCall\n * @returns {boolean} True if passed function\n */\nfunction customValidation(payload: ProcessCallPayload, isValid: boolean): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'customValidation',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    let remoteObject = session.objects[remoteCall.id];\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    if (!isValid) {\n        return false;\n    } else if (semotus.role === 'server' && remoteObject[remoteCall.name].serverValidation) {\n        let args = semotus._extractArguments(remoteCall);\n        args.unshift(remoteObject);\n\n        return remoteObject[remoteCall.name].serverValidation.apply(null, args);\n    } else {\n        return true;\n    }\n}\n\n/**\n * If the changes could be applied and the validation was successful call the method\n *\n * @param semotus\n * @param {boolean} isValid - takes a flag if the call is valid or not, if it is then we proceed normally,\n * otherwise, we throw an error and stop execution\n *\n * @param session\n * @param remoteCall\n * @returns {unknown} unknown\n */\nasync function callIfValid(payload: ProcessCallPayload, isValid: boolean) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let loggerObject = {\n        component: 'semotus',\n        module: 'processCall',\n        activity: 'callIfValid',\n        data: {\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    semotus.logger.info(loggerObject, remoteCall.name);\n\n    let obj = session.objects[remoteCall.id];\n\n    if (!obj[remoteCall.name]) {\n        throw new Error(remoteCall.name + ' function does not exist.');\n    }\n\n    if (!isValid && remoteCall && remoteCall.name) {\n        throw new Error(remoteCall.name + ' refused');\n    }\n\n    let args = semotus._extractArguments(remoteCall);\n\n    return obj[remoteCall.name].apply(obj, args);\n}\n\n/**\n * Let the controller know that the method was completed and give it a chance to commit changes\n *\n * @param payload\n * @param  returnValue unknown\n *\n * @returns\n */\nasync function postCallHook(payload: ProcessCallPayload, returnValue) {\n    const {semotus, remoteCall, callContext, HTTPObjs} = payload;\n\n    if (semotus.controller && semotus.controller.postServerCall) {\n        const hasChanges: boolean = remoteCall.changes.length > 2;\n        await semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs);\n    }\n    return returnValue;\n}\n\n/**\n * Package up any changes resulting from the execution and send them back in the message, clearing\n * our change queue to accumulate more changes for the next call\n *\n * @param semotus\n * @param remoteCall\n * @param remoteCallId\n * @param {unknown} ret unknown\n */\nfunction postCallSuccess(payload: ProcessCallPayload, ret): void {\n    const {semotus, remoteCall, callContext, session, remoteCallId} = payload;\n\n    semotus.logger.info(\n        {\n            component: 'semotus',\n            module: 'processCall',\n            activity: 'postCall.success',\n            data: {\n                call: remoteCall.name,\n                callTime: logTime(callContext),\n                sequence: remoteCall.sequence\n            }\n        },\n        remoteCall.name\n    );\n\n    packageChanges(semotus, session,{\n        type: 'response',\n        sync: true,\n        value: JSON.stringify(semotus._toTransport(ret)),\n        name: remoteCall.name,\n        remoteCallId: remoteCallId\n    });\n}\n\n/**\n * Helper function to identify if there's a postServerErrorHandler callback on the base controller\n * If there is, we execute the handler, and if we catch an error in the handler, we propogate it up to the logger.\n * @param logger\n * @param {*} controller\n * @param type\n * @param remoteCall\n * @param remoteCallId\n * @param callContext\n * @param changeString\n * @param session\n */\nasync function resolveErrorHandler(logger, controller: any, type, remoteCall: RemoteCall, remoteCallId, callContext: CallContext, changeString, session: Session) {\n\n    if (controller && controller.postServerErrorHandler) {\n        let errorType = type;\n        let functionName = remoteCall.name;\n        let obj = undefined;\n        if (session.objects[remoteCall.id]) {\n            obj = session.objects[remoteCall.id];\n        }\n        let logBody = {\n            component: 'semotus',\n            module: 'processCall.failure',\n            activity: 'postCall.resolveErrorHandler',\n            data: {\n                call: remoteCall.name,\n                message: undefined\n            }\n        };\n\n        try {\n            await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString);\n        } catch (error) {\n            if (error.message) {\n                logBody.data.message = error.message;\n                logger.error(error.message);\n            } else {\n                logBody.data.message = JSON.stringify(error);\n            }\n\n            logger.error(logBody, 'User defined postServerErrorHandler threw an error');\n        }\n    }\n}\n\n/**\n * Handle errors by returning an apropriate message.  In all cases changes sent back though they\n *\n * @param semotus\n * @param remoteCall\n * @param callContext\n * @param session\n * @param {unknown} err unknown\n *\n * @returns {unknown} A Promise\n */\nasync function postCallFailure(payload: ProcessCallPayload, err) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let logString = '';\n\n    let packageChangesPayload = {};\n\n    let updateConflictRetry = false;\n\n    if (err === 'Sync Error') {\n        postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext);\n        packageChangesPayload = {\n            type: 'response',\n            sync: false,\n            changes: ''\n        };\n    } else if (err.message == 'Update Conflict') {\n        // Not this may be caught in the transport (e.g. Amorphic) and retried)\n\n        // increment callContext.retries after checking if < 3. Should retry 3 times.\n        if (callContext.retries++ < 3) {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext);\n            updateConflictRetry = true;\n            // The following assignment is only used for the error handler\n            packageChangesPayload = {\n                type: 'retry'\n            };\n        } else {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext);\n            packageChangesPayload = {\n                type: 'retry',\n                sync: false\n            };\n        }\n    } else {\n        if (!(err instanceof Error)) {\n            postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext);\n        } else {\n            if (err.stack) {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack);\n            } else {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message;\n            }\n\n            postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext);\n        }\n\n        packageChangesPayload = {\n            type: 'error',\n            sync: true,\n            value: getError(err),\n            name: remoteCall.name\n        };\n    }\n\n    Object.assign(packageChangesPayload, {remoteCallId: remoteCallId});\n\n    await resolveErrorHandler(\n        semotus.logger,\n        semotus.controller,\n        // @ts-ignore\n        packageChangesPayload.type,\n        remoteCall,\n        remoteCallId,\n        callContext,\n        semotus.changeString,\n        session\n    );\n\n    if (updateConflictRetry) {\n        await delay(callContext.retries * 1000);\n        return retryCall(payload);\n    } else {\n        return packageChanges(semotus, session, packageChangesPayload);\n    }\n}\n\n/**\n * Deal with changes going back to the caller - Actually not Async!\n *\n * @param semotus\n * @param session\n * @param {unknown} message unknown\n */\nfunction packageChanges(semotus: Semotus, session: Session, message) {\n    semotus._convertArrayReferencesToChanges();\n    message.changes = JSON.stringify(semotus.getChanges());\n\n    if (semotus.memSession && semotus.memSession.semotus && semotus.memSession.semotus.callStartTime) {\n        semotus.memSession.semotus.callStartTime = 0;\n    }\n\n    // Inspect a copy of the message on the server only before sent out. Only for debug purposes\n    if (semotus.controller && semotus.controller.inspectMessage) {\n        semotus.controller.inspectMessage(Object.assign({}, message));\n    }\n\n    session.sendMessage(message);\n    semotus._deleteChanges();\n    semotus._processQueue();\n}\n\n\n/**\n *  Helper function to log amorphic errors.\n * @param {*} logger\n * @param {*} activity\n * @param {*} message\n * @param {*} logType\n * @param {*} logString\n * @param remoteCall\n * @param callContext\n */\nexport function postCallErrorLog(logger, activity, message, logType, logString, remoteCall: RemoteCall, callContext: CallContext) {\n    let logBody = {\n        component: 'semotus',\n        module: 'processCall.failure',\n        data: {\n            call: remoteCall.name,\n            callTime: logTime(callContext),\n            sequence: remoteCall.sequence,\n            message: undefined\n        },\n        activity: undefined\n    };\n\n    logBody.activity = activity;\n\n    if (logger.data) {\n        logBody.data.message = message;\n    }\n\n    logger[logType](logBody, logString);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ProcessCall.js","sourceRoot":"","sources":["../../src/helpers/ProcessCall.ts"],"names":[],"mappings":"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","sourcesContent":["import {delay, getError, logTime} from './Utilities';\nimport {CallContext, ProcessCallPayload, RemoteCall, Semotus, Session} from './Types';\n\nconst moduleName = 'ProcessCall';\n\n/**\n * We process the call the remote method in stages starting by letting the controller examine the\n * changes (preCallHook) and giving it a chance to refresh data if it needs to.  Then we apply any\n * changes in the messages and give the object owning the method a chance to validate that the\n * call is valid and take care of any authorization concerns.  Finally we let the controller perform\n * any post-call processing such as commiting data and then we deal with a failure or success.\n *\n * @param payload\n * @param {unknown} forceupdate unknown\n *\n * @returns {unknown} unknown\n */\nexport async function processCall(payload: ProcessCallPayload, forceupdate?: boolean) {\n\n    try {\n        forceupdate = await Promise.resolve(forceupdate);\n        await preCallHook(payload, forceupdate);\n        let validation = await applyChangesAndValidateCall(payload);\n        validation = await customValidation(payload, validation);\n        const result = await callIfValid(payload, validation);\n        await postCallHook(payload, result);\n        await postCallSuccess(payload, result);\n    } catch (err) {\n        await postCallFailure(payload, err);\n    }\n}\n\n\n/**\n * If there is an update conflict we want to retry after restoring the session\n *\n * @returns {*} unknown\n */\nasync function retryCall(payload: ProcessCallPayload) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    if (restoreSessionCallback) {\n        restoreSessionCallback();\n    }\n\n    return processCall(payload, true);\n}\n\n/**\n * Determine what objects changed and pass this to the preServerCall method on the controller\n *\n * @param payload\n * @param  forceupdate unknown\n *\n * @returns  unknown\n */\nasync function preCallHook(payload: ProcessCallPayload, forceupdate?: boolean): Promise<any> {\n    const {semotus, remoteCall, session, callContext, HTTPObjs} = payload;\n    const functionName = preCallHook.name;\n    semotus.logger.info(\n        {\n            module: moduleName,\n            function: functionName,\n            category: 'milestone',\n            data: {\n                activity: 'preServerCall',\n                call: remoteCall.name,\n                sequence: remoteCall.sequence\n            }\n        }\n    );\n\n    if (semotus.controller && semotus.controller.preServerCall) {\n        let changes = {};\n\n        for (var objId in JSON.parse(remoteCall.changes)) {\n            changes[semotus.__dictionary__[objId.replace(/[^-]*-/, '').replace(/-.*/, '')].__name__] = true;\n        }\n\n        let remoteObject = session.objects[remoteCall.id];\n\n        // Need to double check if not in session, what the template is.\n        let remoteTemplate = semotus.__dictionary__[remoteCall.id.replace(/[^-]*-/, '').replace(/-.*/, '')];\n        let isPublic = false;\n\n        if (remoteObject) {\n            isPublic = semotus.role === 'server' && remoteObject[remoteCall.name] && remoteObject[remoteCall.name].remotePublic;\n        }\n        else if (remoteTemplate) {\n            // If the class doesn't exist, we should get the remote function from the prototype\n            isPublic = semotus.role === 'server' && remoteTemplate.prototype[remoteCall.name] && remoteTemplate.prototype[remoteCall.name].remotePublic;\n        }\n        else {\n            semotus.logger.error({\n                module: moduleName,\n                function: functionName,\n                category: 'milestone',\n                message: 'Could not find template for ' + objId,\n                data: {\n                    activity: 'preServerCall',\n                    call: remoteCall.name,\n                    sequence: remoteCall.sequence\n                }\n            });\n        }\n\n        return semotus.controller.preServerCall.call(\n            semotus.controller,\n            remoteCall.changes.length > 2,\n            changes,\n            callContext,\n            forceupdate,\n            remoteCall.name,\n            remoteCall,\n            isPublic,\n            HTTPObjs\n        );\n    } else {\n        return true;\n    }\n}\n\n/**\n * Apply changes in the message and then validate the call.  Throw \"Sync Error\" if changes can't be applied\n *\n * @returns {unknown} unknown\n */\nfunction applyChangesAndValidateCall(payload: ProcessCallPayload): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n    const functionName = applyChangesAndValidateCall.name;\n\n    semotus.logger.info(\n        {\n            module: moduleName,\n            function: functionName,\n            category: 'milestone',\n            data: {\n                activity: 'applyChangesAndValidateCall',\n                call: remoteCall.name,\n                sequence: remoteCall.sequence,\n                remoteCallId: remoteCall.id\n            }\n        }\n    );\n\n    let changes = JSON.parse(remoteCall.changes);\n\n    const res = semotus._applyChanges(changes, semotus.role === 'client', subscriptionId, callContext);\n    if (res) {\n        const obj = session.objects[remoteCall.id];\n\n        if (!obj) {\n            throw new Error(`Cannot find object for remote call ${remoteCall.id}`);\n        }\n\n        // check to see if this function is supposed to be called directly from client\n        if (obj.__proto__[remoteCall.name].__on__ !== 'server') {\n            throw 'Invalid Function Call; not an API function';\n        }\n\n        if (semotus.role === 'server' && obj.validateServerCall) {\n            return obj.validateServerCall.call(obj, remoteCall.name, callContext);\n        }\n\n        return true;\n    } else {\n        throw 'Sync Error';\n    }\n}\n\n/**\n * Apply function specific custom serverSide validation functions\n *\n * @param semotus\n * @param {boolean} isValid - Result of previous validation step (applyChangesAndValidateCall)\n * @param session\n * @param remoteCall\n * @returns {boolean} True if passed function\n */\nfunction customValidation(payload: ProcessCallPayload, isValid: boolean): boolean {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n    const functionName = customValidation.name;\n\n    let loggerObject = {\n        module: moduleName,\n        function: functionName,\n        category: 'milestone',\n        data: {\n            activity: 'customValidation',\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    let remoteObject = session.objects[remoteCall.id];\n\n    semotus.logger.info(loggerObject);\n\n    if (!isValid) {\n        return false;\n    } else if (semotus.role === 'server' && remoteObject[remoteCall.name].serverValidation) {\n        let args = semotus._extractArguments(remoteCall);\n        args.unshift(remoteObject);\n\n        return remoteObject[remoteCall.name].serverValidation.apply(null, args);\n    } else {\n        return true;\n    }\n}\n\n/**\n * If the changes could be applied and the validation was successful call the method\n *\n * @param semotus\n * @param {boolean} isValid - takes a flag if the call is valid or not, if it is then we proceed normally,\n * otherwise, we throw an error and stop execution\n *\n * @param session\n * @param remoteCall\n * @returns {unknown} unknown\n */\nasync function callIfValid(payload: ProcessCallPayload, isValid: boolean) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n    const functionName = callIfValid.name;\n\n    let loggerObject = {\n        module: moduleName,\n        function: functionName,\n        category: 'milestone',\n        data: {\n            activity: 'callIfValid',\n            call: remoteCall.name,\n            sequence: remoteCall.sequence,\n            remoteCallId: remoteCall.id\n        }\n    };\n\n    semotus.logger.info(loggerObject);\n\n    let obj = session.objects[remoteCall.id];\n\n    if (!obj[remoteCall.name]) {\n        throw new Error(remoteCall.name + ' function does not exist.');\n    }\n\n    if (!isValid && remoteCall && remoteCall.name) {\n        throw new Error(remoteCall.name + ' refused');\n    }\n\n    let args = semotus._extractArguments(remoteCall);\n\n    return obj[remoteCall.name].apply(obj, args);\n}\n\n/**\n * Let the controller know that the method was completed and give it a chance to commit changes\n *\n * @param payload\n * @param  returnValue unknown\n *\n * @returns\n */\nasync function postCallHook(payload: ProcessCallPayload, returnValue) {\n    const {semotus, remoteCall, callContext, HTTPObjs} = payload;\n\n    if (semotus.controller && semotus.controller.postServerCall) {\n        const hasChanges: boolean = remoteCall.changes.length > 2;\n        await semotus.controller.postServerCall.call(semotus.controller, hasChanges, callContext, semotus.changeString, HTTPObjs);\n    }\n    return returnValue;\n}\n\n/**\n * Package up any changes resulting from the execution and send them back in the message, clearing\n * our change queue to accumulate more changes for the next call\n *\n * @param semotus\n * @param remoteCall\n * @param remoteCallId\n * @param {unknown} ret unknown\n */\nfunction postCallSuccess(payload: ProcessCallPayload, ret): void {\n    const {semotus, remoteCall, callContext, session, remoteCallId} = payload;\n    const functionName = postCallSuccess.name;\n\n    semotus.logger.info(\n        {\n            module: moduleName,\n            function: functionName,\n            category: 'milestone',\n            data: {\n                activity: 'postCall.success',\n                call: remoteCall.name,\n                callTime: logTime(callContext),\n                sequence: remoteCall.sequence\n            }\n        }\n    );\n\n    packageChanges(semotus, session,{\n        type: 'response',\n        sync: true,\n        value: JSON.stringify(semotus._toTransport(ret)),\n        name: remoteCall.name,\n        remoteCallId: remoteCallId\n    });\n}\n\n/**\n * Helper function to identify if there's a postServerErrorHandler callback on the base controller\n * If there is, we execute the handler, and if we catch an error in the handler, we propogate it up to the logger.\n * @param logger\n * @param {*} controller\n * @param type\n * @param remoteCall\n * @param remoteCallId\n * @param callContext\n * @param changeString\n * @param session\n */\nasync function resolveErrorHandler(logger, controller: any, type, remoteCall: RemoteCall, remoteCallId, callContext: CallContext, changeString, session: Session) {\n    const functionName = resolveErrorHandler.name;\n    if (controller && controller.postServerErrorHandler) {\n        let errorType = type;\n        let remoteCallName = remoteCall.name;\n        let obj = undefined;\n        if (session.objects[remoteCall.id]) {\n            obj = session.objects[remoteCall.id];\n        }\n        try {\n            await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, remoteCallName, callContext, changeString);\n        } catch (error) {\n            let logBody = {\n                module: moduleName,\n                function: functionName,\n                category: 'milestone',\n                error: error,\n                message: 'User defined postServerErrorHandler threw an error',\n                data: {\n                    activity: 'postCall.resolveErrorHandler',\n                    call: remoteCall.name,\n                    message: error.message ? error.message : JSON.stringify(error)\n                }\n            };\n            logger.error(logBody);\n        }\n    }\n}\n\n/**\n * Handle errors by returning an apropriate message.  In all cases changes sent back though they\n *\n * @param semotus\n * @param remoteCall\n * @param callContext\n * @param session\n * @param {unknown} err unknown\n *\n * @returns {unknown} A Promise\n */\nasync function postCallFailure(payload: ProcessCallPayload, err) {\n    const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;\n\n    let logString = '';\n\n    let packageChangesPayload = {};\n\n    let updateConflictRetry = false;\n\n    if (err === 'Sync Error') {\n        postCallErrorLog(semotus.logger, 'postCall.syncError', undefined, 'error', remoteCall.name, remoteCall, callContext);\n        packageChangesPayload = {\n            type: 'response',\n            sync: false,\n            changes: ''\n        };\n    } else if (err.message == 'Update Conflict') {\n        // Not this may be caught in the transport (e.g. Amorphic) and retried)\n\n        // increment callContext.retries after checking if < 3. Should retry 3 times.\n        if (callContext.retries++ < 3) {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'warn', remoteCall.name, remoteCall, callContext);\n            updateConflictRetry = true;\n            // The following assignment is only used for the error handler\n            packageChangesPayload = {\n                type: 'retry'\n            };\n        } else {\n            postCallErrorLog(semotus.logger, 'postCall.updateConflict', undefined, 'error', remoteCall.name, remoteCall, callContext);\n            packageChangesPayload = {\n                type: 'retry',\n                sync: false\n            };\n        }\n    } else {\n        if (!(err instanceof Error)) {\n            postCallErrorLog(semotus.logger, 'postCall.error', JSON.stringify(err), 'info', remoteCall.name, remoteCall, callContext);\n        } else {\n            if (err.stack) {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message + (' ' + err.stack);\n            } else {\n                logString = 'Exception in ' + remoteCall.name + ' - ' + err.message;\n            }\n\n            postCallErrorLog(semotus.logger, 'postCall.exception', err.message, 'error', logString, remoteCall, callContext);\n        }\n\n        packageChangesPayload = {\n            type: 'error',\n            sync: true,\n            value: getError(err),\n            name: remoteCall.name\n        };\n    }\n\n    Object.assign(packageChangesPayload, {remoteCallId: remoteCallId});\n\n    await resolveErrorHandler(\n        semotus.logger,\n        semotus.controller,\n        // @ts-ignore\n        packageChangesPayload.type,\n        remoteCall,\n        remoteCallId,\n        callContext,\n        semotus.changeString,\n        session\n    );\n\n    if (updateConflictRetry) {\n        await delay(callContext.retries * 1000);\n        return retryCall(payload);\n    } else {\n        return packageChanges(semotus, session, packageChangesPayload);\n    }\n}\n\n/**\n * Deal with changes going back to the caller - Actually not Async!\n *\n * @param semotus\n * @param session\n * @param {unknown} message unknown\n */\nfunction packageChanges(semotus: Semotus, session: Session, message) {\n    semotus._convertArrayReferencesToChanges();\n    message.changes = JSON.stringify(semotus.getChanges());\n\n    if (semotus.memSession && semotus.memSession.semotus && semotus.memSession.semotus.callStartTime) {\n        semotus.memSession.semotus.callStartTime = 0;\n    }\n\n    // Inspect a copy of the message on the server only before sent out. Only for debug purposes\n    if (semotus.controller && semotus.controller.inspectMessage) {\n        semotus.controller.inspectMessage(Object.assign({}, message));\n    }\n\n    session.sendMessage(message);\n    semotus._deleteChanges();\n    semotus._processQueue();\n}\n\n\n/**\n *  Helper function to log amorphic errors.\n * @param {*} logger\n * @param {*} activity\n * @param {*} message\n * @param {*} logType\n * @param {*} logString\n * @param remoteCall\n * @param callContext\n */\nexport function postCallErrorLog(logger, activity, message, logType, logString, remoteCall: RemoteCall, callContext: CallContext) {\n    const functionName = processCall.name;\n    \n    let logBody = {\n        module: moduleName,\n        function: functionName,\n        category: 'milestone',\n        message: logString,\n        data: {\n            message: message,\n            activity: activity,\n            call: remoteCall.name,\n            callTime: logTime(callContext),\n            sequence: remoteCall.sequence,\n        }\n    };\n\n    logger[logType](logBody);\n}\n"]}

@@ -5,2 +5,2 @@ "use strict";

exports.Change = 'change';
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Types.js","sourceRoot":"","sources":["../../src/helpers/Types.ts"],"names":[],"mappings":";;;AAaa,QAAA,MAAM,GAAG,QAAQ,CAAC","sourcesContent":["import {Supertype} from '@haventech/supertype';\nimport {Request, Response} from 'express';\nexport type HTTPObjs = {request: Request, response: Response};\n\nexport type Subscription = {\n    role: string;\n    log: {\n        array: ArrayGroup;\n        arrayDirty: ArrayGroup;\n        change: ChangeGroup;\n    }\n}\n\nexport const Change = 'change';\nexport type ArrayTypes = 'array' | 'arrayDirty';\nexport type ErrorType = 'error' | 'retry' | 'response';\n\nexport type CallContext = { retries: number; startTime: Date };\n\nexport type ProcessCallPayload = {\n    semotus: Semotus;\n    remoteCall: RemoteCall;\n    callContext: CallContext;\n    session: Session;\n    subscriptionId: any;\n    remoteCallId: any;\n    restoreSessionCallback?: Function;\n    HTTPObjs?: HTTPObjs;\n}\n\n/**\n *  id is the id of the object + '/' + property.\n *  Ex: there are 1 School to Many Students\n *\n *  School {\n *      students: Array<Students>\n *  }\n *\n *  In this case, one entry within this ArrayGroup may be 'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]\n *\n *  If that's all the changes then the ArrayGroup would be {'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]}\n */\nexport type ArrayGroup = { [id: string]: ArrayChanges };\n\n/**\n * An array of Id references to Supertype Objects or primitive values\n */\ntype ArrayChanges = Array<any>;\nexport type ChangeGroup = { [objId: string]: PropChanges };\ntype PropChanges = { [prop: string]: Changes };\n\n// Changes[0] is oldValue, Changes[1] is newValue\ntype oldVal = any;\ntype newVal = any;\ntype Changes = [oldVal, newVal][];\n\nexport type Subscriptions = { [key: string]: Subscription };\n\nexport type RemoteCall = {\n    remoteCallId: any;\n    id: any;\n    changes: string; // The string is of type ChangeGroup\n    name: string;\n    sequence: any;\n    type: any;\n    sync: any;\n    value: any;\n}\n\nexport type Session = {\n    subscriptions: Subscriptions;\n    sendMessage: SendMessage;\n    sendMessageEnabled: boolean;\n    remoteCalls: Array<any>;\n    pendingRemoteCalls: any;\n    nextPendingRemoteCallId: number;\n    nextSaveSessionId: number;\n    savedSessionId: number;\n    nextSubscriptionId: number;\n    objects: any;\n    nextObjId: number;\n    dispenseNextId: null; // not used anywhere\n}\n\n\nexport type Sessions = { [sessionId: number]: Session };\n\nexport type SendMessage = (message: any) => void;\n\nexport type SavedSession = {\n    revision: number;\n    data: string; // Serialized Session data\n    callCount: number;\n    referenced: number;\n};\n\nexport interface RemoteableClass extends Supertype {\n    syncStates: Array<string>;\n    __toClient__: boolean;\n    __toServer__: boolean;\n}\n\nexport type ChangeString = { [key: string]: string };\ntype PreServerCallChanges = { [key: string]: boolean };\n\nexport type ControllerSyncState = {\n    scope: '+' | '*' | '-'\n    state: string\n}\n\nexport interface ISemotusController {\n    __template__: any;\n    syncState?: ControllerSyncState\n\n    /**\n     * @server\n     *\n     * Callback after a successful remote function call (just the application of changes and the execution of the function call)\n     * Note that this doesn't mean we can't error out on this or subsequent steps of a remote call.\n     *\n     * We can utilize this function as a generic function handler to run after we have successfully called a remote function.\n     * One such use may be to see the changes that were applied from the client\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {changeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     * @param HTTPObjs\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerCall?(hasChanges: boolean, callContext: CallContext, changeString: ChangeString, HTTPObjs?: HTTPObjs): Promise<any>;\n\n    /**\n     * @server\n     *\n     * Callback to handle errors on a remote call.\n     *\n     * Executes after every other step in the remote call pipeline (see remote call documentation)\n     * but before retrying the call (or packaging response and sending back to client)\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * @param {ErrorType} errorType - Error type associated (error, retry, response)\n     * @param {number} remoteCallId - Id for remote call\n     * @param {extends Supertype} remoteObj - Instance for which the remote object function is called for - @TODO: revisit when we create a proper remoteable type\n     * @param {string} functionName - Name of function being called\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {ChangeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerErrorHandler?(errorType: ErrorType, remoteCallId: number, remoteObj: Supertype, functionName: string, callContext: CallContext, changeString: ChangeString): Promise<void>;\n\n    /**\n     * @server\n     *\n     * Callback before a remote function call (1st step of a remote call)\n     *\n     * We can utilize this function as a generic function handler to run before we call a\n     * remote function or before we apply changes from the client to the server\n     *\n     * We can also utilize this function to do any context-specific prep work / loading\n     * if this a subsequent try of this function due to an update conflict.\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {PreServerCallChanges} changes - Dictionary of Objects that have been changed from the client\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {boolean} [forceUpdate] - Optional parameter passed in. True if this is a retry of the call based on an update conflict. False / undefined otherwise.\n     *\n     * @param functionName\n     * @param remoteCall\n     * @param isPublic\n     * @param HTTPObjs\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    preServerCall?(hasChanges: boolean, changes: PreServerCallChanges, callContext: CallContext, forceUpdate: undefined | boolean, functionName: string, remoteCall: RemoteCall, isPublic: boolean, HTTPObjs?: HTTPObjs ): Promise<any>;\n\n    /**\n     * This is a handler that will only be used for testing and debugging purposes\n     *\n     * When this is used, allows us to inspect the message body before we send it out in 'packageChanges'\n     *\n     * DO NOT USE THIS IN PRODUCTION CODE\n     *\n     * @param message\n     */\n    inspectMessage?(message): any;\n}\n\nexport interface Semotus {\n    setSyncState: (str) => void;\n    syncState: string;\n    getSyncState: () => any;\n    maxCallTime: number;\n    __dictionary__: any;\n    memSession: { semotus: { callStartTime: number } };\n    _injectIntoTemplate: (template) => void;\n    serializeAndGarbageCollect: () => any;\n    getMessage: (sessionId, forceMessage) => any;\n    clearPendingCalls: (sessionId) => void;\n    getChangeGroup: (type, subscriptionId) => ChangeGroup;\n    deleteChangeGroup: (type: any, subscriptionId: any) => void;\n    getChangeStatus: () => string;\n    _stashObject: (obj, template) => boolean;\n    sessionize: (obj, referencingObj) => (undefined | any);\n    _setupFunction: (propertyName, propertyValue, role, validate, serverValidation, isPublic: boolean, template) => (any);\n    _setupProperty: (propertyName, defineProperty, objectProperties, defineProperties) => void;\n    withoutChangeTracking: (cb) => void;\n    _changedValue: (obj, prop, value) => void;\n    _referencedArray: (obj, prop, arrayRef, sessionId?) => void;\n    _convertArrayReferencesToChanges: () => void;\n    MarkChangedArrayReferences: () => void;\n    _convertValue: (value) => (any[] | null);\n    getObject: (objId, template) => (any | null);\n    _applyChanges: (changes, force, subscriptionId, callContext) => (number);\n    _applyObjectChanges: (changes, rollback, obj, force) => (boolean);\n    _validateServerIncomingProperty: (obj, prop, defineProperty, newValue) => (boolean);\n    _applyPropertyChange: (changes, rollback, obj, prop, ix, oldValue, newValue, force) => (boolean);\n    _rollback: (rollback) => void;\n    _rollbackChanges: () => void;\n    _createEmptyObject: (template, objId, defineProperty, isTransient) => any;\n    inject: (template, injector) => void;\n    _queueRemoteCall: (objId, functionName, deferred, args) => void;\n    _processQueue: () => void;\n    _toTransport: (obj) => any;\n    _fromTransport: (obj) => any;\n    _extractArguments: (remoteCall) => any;\n    _trimArray: (array) => void;\n    _deleteChangeGroups: (type) => void;\n    _getSubscriptions: (sessionId?) => Subscriptions | null;\n    _getSubscription: (subscriptionId?) => Subscription;\n    cleanPrivateValues: (prop, logValue, defineProperty) => (string | any);\n    Remoteable: (Base) => () => any;\n    Bindable: (Base) => () => any;\n    Persistable: (Base) => () => any;\n    bindDecorators: (objectTemplate?) => void;\n    processMessage: (remoteCall, subscriptionId, restoreSessionCallback, req?: Request, res?: Response) => (undefined | any);\n    enableSendMessage: (value, messageCallback, sessionId) => void;\n    syncSession: (sessionId) => void;\n    restoreSession: (sessionId, savedSession: SavedSession, sendMessage: SendMessage) => boolean;\n    saveSession: (sessionId) => SavedSession;\n    setMinimumSequence: (nextObjId) => void;\n    deleteSession: (sessionId) => void;\n    createSession: (role: any, sendMessage: SendMessage, sessionId: any) => any;\n    log: (level, data) => void;\n    nextObjId: number;\n    maxClientSequence: number;\n    logLevel: number;\n    __conflictMode__: string;\n    __changeTracking__: boolean;\n    _useGettersSetters: boolean;\n    logger: any;\n    role: any;\n    currentSession: any;\n    sessions?: Sessions;\n    nextSubscriptionId: number;\n    nextSessionId: number;\n    controller: ISemotusController;\n    changeString: string;\n\n\n    _getSession(_sid?: any): Session;\n\n    subscribe(role: any): number;\n\n    setSession(sessionId: any): void;\n\n    getChanges(subscriptionId?: any): ChangeGroup;\n\n    _deleteChanges(): void;\n\n    getPendingCallCount(sessionId: any): any;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Types.js","sourceRoot":"","sources":["../../src/helpers/Types.ts"],"names":[],"mappings":";;;AAaa,QAAA,MAAM,GAAG,QAAQ,CAAC","sourcesContent":["import {Supertype} from '@haventech/supertype';\nimport {Request, Response} from 'express';\nexport type HTTPObjs = {request: Request, response: Response};\n\nexport type Subscription = {\n    role: string;\n    log: {\n        array: ArrayGroup;\n        arrayDirty: ArrayGroup;\n        change: ChangeGroup;\n    }\n}\n\nexport const Change = 'change';\nexport type ArrayTypes = 'array' | 'arrayDirty';\nexport type ErrorType = 'error' | 'retry' | 'response';\n\nexport type CallContext = { retries: number; startTime: Date };\n\nexport type ProcessCallPayload = {\n    semotus: Semotus;\n    remoteCall: RemoteCall;\n    callContext: CallContext;\n    session: Session;\n    subscriptionId: any;\n    remoteCallId: any;\n    restoreSessionCallback?: Function;\n    HTTPObjs?: HTTPObjs;\n}\n\n/**\n *  id is the id of the object + '/' + property.\n *  Ex: there are 1 School to Many Students\n *\n *  School {\n *      students: Array<Students>\n *  }\n *\n *  In this case, one entry within this ArrayGroup may be 'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]\n *\n *  If that's all the changes then the ArrayGroup would be {'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]}\n */\nexport type ArrayGroup = { [id: string]: ArrayChanges };\n\n/**\n * An array of Id references to Supertype Objects or primitive values\n */\ntype ArrayChanges = Array<any>;\nexport type ChangeGroup = { [objId: string]: PropChanges };\ntype PropChanges = { [prop: string]: Changes };\n\n// Changes[0] is oldValue, Changes[1] is newValue\ntype oldVal = any;\ntype newVal = any;\ntype Changes = [oldVal, newVal][];\n\nexport type Subscriptions = { [key: string]: Subscription };\n\nexport type RemoteCall = {\n    remoteCallId: any;\n    id: any;\n    changes: string; // The string is of type ChangeGroup\n    name: string;\n    sequence: any;\n    type: any;\n    sync: any;\n    value: any;\n}\n\nexport type Session = {\n    subscriptions: Subscriptions;\n    sendMessage: SendMessage;\n    sendMessageEnabled: boolean;\n    remoteCalls: Array<any>;\n    pendingRemoteCalls: any;\n    nextPendingRemoteCallId: number;\n    nextSaveSessionId: number;\n    savedSessionId: number;\n    nextSubscriptionId: number;\n    objects: any;\n    nextObjId: number;\n    dispenseNextId: null; // not used anywhere\n}\n\n\nexport type Sessions = { [sessionId: number]: Session };\n\nexport type SendMessage = (message: any) => void;\n\nexport type SavedSession = {\n    revision: number;\n    data: string; // Serialized Session data\n    callCount: number;\n    referenced: number;\n};\n\nexport interface RemoteableClass extends Supertype {\n    syncStates: Array<string>;\n    __toClient__: boolean;\n    __toServer__: boolean;\n}\n\nexport type ChangeString = { [key: string]: string };\ntype PreServerCallChanges = { [key: string]: boolean };\n\nexport type ControllerSyncState = {\n    scope: '+' | '*' | '-'\n    state: string\n}\n\nexport interface ISemotusController {\n    __template__: any;\n    syncState?: ControllerSyncState\n\n    /**\n     * @server\n     *\n     * Callback after a successful remote function call (just the application of changes and the execution of the function call)\n     * Note that this doesn't mean we can't error out on this or subsequent steps of a remote call.\n     *\n     * We can utilize this function as a generic function handler to run after we have successfully called a remote function.\n     * One such use may be to see the changes that were applied from the client\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {changeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     * @param HTTPObjs\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerCall?(hasChanges: boolean, callContext: CallContext, changeString: ChangeString, HTTPObjs?: HTTPObjs): Promise<any>;\n\n    /**\n     * @server\n     *\n     * Callback to handle errors on a remote call.\n     *\n     * Executes after every other step in the remote call pipeline (see remote call documentation)\n     * but before retrying the call (or packaging response and sending back to client)\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * @param {ErrorType} errorType - Error type associated (error, retry, response)\n     * @param {number} remoteCallId - Id for remote call\n     * @param {extends Supertype} remoteObj - Instance for which the remote object function is called for - @TODO: revisit when we create a proper remoteable type\n     * @param {string} functionName - Name of function being called\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {ChangeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerErrorHandler?(errorType: ErrorType, remoteCallId: number, remoteObj: Supertype, functionName: string, callContext: CallContext, changeString: ChangeString): Promise<void>;\n\n    /**\n     * @server\n     *\n     * Callback before a remote function call (1st step of a remote call)\n     *\n     * We can utilize this function as a generic function handler to run before we call a\n     * remote function or before we apply changes from the client to the server\n     *\n     * We can also utilize this function to do any context-specific prep work / loading\n     * if this a subsequent try of this function due to an update conflict.\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {PreServerCallChanges} changes - Dictionary of Objects that have been changed from the client\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {boolean} [forceUpdate] - Optional parameter passed in. True if this is a retry of the call based on an update conflict. False / undefined otherwise.\n     *\n     * @param functionName\n     * @param remoteCall\n     * @param isPublic\n     * @param HTTPObjs\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    preServerCall?(hasChanges: boolean, changes: PreServerCallChanges, callContext: CallContext, forceUpdate: undefined | boolean, functionName: string, remoteCall: RemoteCall, isPublic: boolean, HTTPObjs?: HTTPObjs ): Promise<any>;\n\n    /**\n     * This is a handler that will only be used for testing and debugging purposes\n     *\n     * When this is used, allows us to inspect the message body before we send it out in 'packageChanges'\n     *\n     * DO NOT USE THIS IN PRODUCTION CODE\n     *\n     * @param message\n     */\n    inspectMessage?(message): any;\n}\n\nexport interface Semotus {\n    setSyncState: (str) => void;\n    syncState: string;\n    getSyncState: () => any;\n    maxCallTime: number;\n    __dictionary__: any;\n    memSession: { semotus: { callStartTime: number } };\n    _injectIntoTemplate: (template) => void;\n    serializeAndGarbageCollect: () => any;\n    getMessage: (sessionId, forceMessage) => any;\n    clearPendingCalls: (sessionId) => void;\n    getChangeGroup: (type, subscriptionId) => ChangeGroup;\n    deleteChangeGroup: (type: any, subscriptionId: any) => void;\n    getChangeStatus: () => string;\n    _stashObject: (obj, template) => boolean;\n    sessionize: (obj, referencingObj) => (undefined | any);\n    _setupFunction: (propertyName, propertyValue, role, validate, serverValidation, isPublic: boolean, template) => (any);\n    _setupProperty: (propertyName, defineProperty, objectProperties, defineProperties) => void;\n    withoutChangeTracking: (cb) => void;\n    _changedValue: (obj, prop, value) => void;\n    _referencedArray: (obj, prop, arrayRef, sessionId?) => void;\n    _convertArrayReferencesToChanges: () => void;\n    MarkChangedArrayReferences: () => void;\n    _convertValue: (value) => (any[] | null);\n    getObject: (objId, template) => (any | null);\n    _applyChanges: (changes, force, subscriptionId, callContext) => (number);\n    _applyObjectChanges: (changes, rollback, obj, force) => (boolean);\n    _validateServerIncomingProperty: (obj, prop, defineProperty, newValue) => (boolean);\n    _applyPropertyChange: (changes, rollback, obj, prop, ix, oldValue, newValue, force) => (boolean);\n    _rollback: (rollback) => void;\n    _rollbackChanges: () => void;\n    _createEmptyObject: (template, objId, defineProperty, isTransient) => any;\n    inject: (template, injector) => void;\n    _queueRemoteCall: (objId, functionName, deferred, args) => void;\n    _processQueue: () => void;\n    _toTransport: (obj) => any;\n    _fromTransport: (obj) => any;\n    _extractArguments: (remoteCall) => any;\n    _trimArray: (array) => void;\n    _deleteChangeGroups: (type) => void;\n    _getSubscriptions: (sessionId?) => Subscriptions | null;\n    _getSubscription: (subscriptionId?) => Subscription;\n    cleanPrivateValues: (prop, logValue, defineProperty) => (string | any);\n    Remoteable: (Base) => () => any;\n    Bindable: (Base) => () => any;\n    Persistable: (Base) => () => any;\n    bindDecorators: (objectTemplate?) => void;\n    processMessage: (remoteCall, subscriptionId, restoreSessionCallback, req?: Request, res?: Response) => (undefined | any);\n    enableSendMessage: (value, messageCallback, sessionId) => void;\n    syncSession: (sessionId) => void;\n    restoreSession: (sessionId, savedSession: SavedSession, sendMessage: SendMessage) => boolean;\n    saveSession: (sessionId) => SavedSession;\n    setMinimumSequence: (nextObjId) => void;\n    deleteSession: (sessionId) => void;\n    createSession: (role: any, sendMessage: SendMessage, sessionId: any) => any;\n    log: (level, data) => void;\n    nextObjId: number;\n    maxClientSequence: number;\n    logLevel: number;\n    __conflictMode__: string;\n    __changeTracking__: boolean;\n    _useGettersSetters: boolean;\n    logger: any;\n    role: any;\n    currentSession: any;\n    sessions?: Sessions;\n    nextSubscriptionId: number;\n    nextSessionId: number;\n    controller: ISemotusController;\n    changeString: string;\n    moduleName: string;\n\n\n    _getSession(_sid?: any): Session;\n\n    subscribe(role: any): number;\n\n    setSession(sessionId: any): void;\n\n    getChanges(subscriptionId?: any): ChangeGroup;\n\n    _deleteChanges(): void;\n\n    getPendingCallCount(sessionId: any): any;\n}\n"]}

@@ -0,1 +1,3 @@

## 6.1.0
* update supertype to use new logging
## 6.0.1

@@ -2,0 +4,0 @@ * bump nconf version due to security vulnerability.

{
"name": "@haventech/semotus",
"version": "6.0.1",
"version": "6.1.0-beta.0",
"description": "A subclass of supertype that synchronizes sets of objects.",

@@ -40,3 +40,3 @@ "homepage": "https://github.com/haven-life/amorphic-framework",

"devDependencies": {
"@haventech/supertype": "5.x",
"@haventech/supertype": "5.1.0-beta.1",
"@types/chai": "4.3.0",

@@ -43,0 +43,0 @@ "@types/express": "4.17.13",

import {delay, getError, logTime} from './Utilities';
import {CallContext, ProcessCallPayload, RemoteCall, Semotus, Session} from './Types';
const moduleName = 'ProcessCall';
/**

@@ -57,13 +59,14 @@ * We process the call the remote method in stages starting by letting the controller examine the

const {semotus, remoteCall, session, callContext, HTTPObjs} = payload;
const functionName = preCallHook.name;
semotus.logger.info(
{
component: 'semotus',
module: 'processCall',
activity: 'preServerCall',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'preServerCall',
call: remoteCall.name,
sequence: remoteCall.sequence
}
},
remoteCall.name
}
);

@@ -93,10 +96,12 @@

semotus.logger.error({
component: 'semotus',
module: 'processCall',
activity: 'preServerCall',
module: moduleName,
function: functionName,
category: 'milestone',
message: 'Could not find template for ' + objId,
data: {
activity: 'preServerCall',
call: remoteCall.name,
sequence: remoteCall.sequence
}
}, 'Could not find template for ' + objId);
});
}

@@ -127,9 +132,11 @@

const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;
const functionName = applyChangesAndValidateCall.name;
semotus.logger.info(
{
component: 'semotus',
module: 'processCall',
activity: 'applyChangesAndValidateCall',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'applyChangesAndValidateCall',
call: remoteCall.name,

@@ -139,4 +146,3 @@ sequence: remoteCall.sequence,

}
},
remoteCall.name
}
);

@@ -180,8 +186,10 @@

const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;
const functionName = customValidation.name;
let loggerObject = {
component: 'semotus',
module: 'processCall',
activity: 'customValidation',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'customValidation',
call: remoteCall.name,

@@ -195,3 +203,3 @@ sequence: remoteCall.sequence,

semotus.logger.info(loggerObject, remoteCall.name);
semotus.logger.info(loggerObject);

@@ -223,8 +231,10 @@ if (!isValid) {

const {semotus, remoteCall, callContext, session, subscriptionId, remoteCallId, restoreSessionCallback} = payload;
const functionName = callIfValid.name;
let loggerObject = {
component: 'semotus',
module: 'processCall',
activity: 'callIfValid',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'callIfValid',
call: remoteCall.name,

@@ -236,3 +246,3 @@ sequence: remoteCall.sequence,

semotus.logger.info(loggerObject, remoteCall.name);
semotus.logger.info(loggerObject);

@@ -283,9 +293,11 @@ let obj = session.objects[remoteCall.id];

const {semotus, remoteCall, callContext, session, remoteCallId} = payload;
const functionName = postCallSuccess.name;
semotus.logger.info(
{
component: 'semotus',
module: 'processCall',
activity: 'postCall.success',
module: moduleName,
function: functionName,
category: 'milestone',
data: {
activity: 'postCall.success',
call: remoteCall.name,

@@ -295,4 +307,3 @@ callTime: logTime(callContext),

}
},
remoteCall.name
}
);

@@ -322,6 +333,6 @@

async function resolveErrorHandler(logger, controller: any, type, remoteCall: RemoteCall, remoteCallId, callContext: CallContext, changeString, session: Session) {
const functionName = resolveErrorHandler.name;
if (controller && controller.postServerErrorHandler) {
let errorType = type;
let functionName = remoteCall.name;
let remoteCallName = remoteCall.name;
let obj = undefined;

@@ -331,23 +342,18 @@ if (session.objects[remoteCall.id]) {

}
let logBody = {
component: 'semotus',
module: 'processCall.failure',
activity: 'postCall.resolveErrorHandler',
data: {
call: remoteCall.name,
message: undefined
}
};
try {
await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, functionName, callContext, changeString);
await controller.postServerErrorHandler.call(controller, errorType, remoteCallId, obj, remoteCallName, callContext, changeString);
} catch (error) {
if (error.message) {
logBody.data.message = error.message;
logger.error(error.message);
} else {
logBody.data.message = JSON.stringify(error);
}
logger.error(logBody, 'User defined postServerErrorHandler threw an error');
let logBody = {
module: moduleName,
function: functionName,
category: 'milestone',
error: error,
message: 'User defined postServerErrorHandler threw an error',
data: {
activity: 'postCall.resolveErrorHandler',
call: remoteCall.name,
message: error.message ? error.message : JSON.stringify(error)
}
};
logger.error(logBody);
}

@@ -482,21 +488,19 @@ }

export function postCallErrorLog(logger, activity, message, logType, logString, remoteCall: RemoteCall, callContext: CallContext) {
const functionName = processCall.name;
let logBody = {
component: 'semotus',
module: 'processCall.failure',
module: moduleName,
function: functionName,
category: 'milestone',
message: logString,
data: {
message: message,
activity: activity,
call: remoteCall.name,
callTime: logTime(callContext),
sequence: remoteCall.sequence,
message: undefined
},
activity: undefined
}
};
logBody.activity = activity;
if (logger.data) {
logBody.data.message = message;
}
logger[logType](logBody, logString);
logger[logType](logBody);
}

@@ -5,2 +5,2 @@ "use strict";

exports.Change = 'change';
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Types.js","sourceRoot":"","sources":["Types.ts"],"names":[],"mappings":";;;AAaa,QAAA,MAAM,GAAG,QAAQ,CAAC","sourcesContent":["import {Supertype} from '@haventech/supertype';\nimport {Request, Response} from 'express';\nexport type HTTPObjs = {request: Request, response: Response};\n\nexport type Subscription = {\n    role: string;\n    log: {\n        array: ArrayGroup;\n        arrayDirty: ArrayGroup;\n        change: ChangeGroup;\n    }\n}\n\nexport const Change = 'change';\nexport type ArrayTypes = 'array' | 'arrayDirty';\nexport type ErrorType = 'error' | 'retry' | 'response';\n\nexport type CallContext = { retries: number; startTime: Date };\n\nexport type ProcessCallPayload = {\n    semotus: Semotus;\n    remoteCall: RemoteCall;\n    callContext: CallContext;\n    session: Session;\n    subscriptionId: any;\n    remoteCallId: any;\n    restoreSessionCallback?: Function;\n    HTTPObjs?: HTTPObjs;\n}\n\n/**\n *  id is the id of the object + '/' + property.\n *  Ex: there are 1 School to Many Students\n *\n *  School {\n *      students: Array<Students>\n *  }\n *\n *  In this case, one entry within this ArrayGroup may be 'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]\n *\n *  If that's all the changes then the ArrayGroup would be {'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]}\n */\nexport type ArrayGroup = { [id: string]: ArrayChanges };\n\n/**\n * An array of Id references to Supertype Objects or primitive values\n */\ntype ArrayChanges = Array<any>;\nexport type ChangeGroup = { [objId: string]: PropChanges };\ntype PropChanges = { [prop: string]: Changes };\n\n// Changes[0] is oldValue, Changes[1] is newValue\ntype oldVal = any;\ntype newVal = any;\ntype Changes = [oldVal, newVal][];\n\nexport type Subscriptions = { [key: string]: Subscription };\n\nexport type RemoteCall = {\n    remoteCallId: any;\n    id: any;\n    changes: string; // The string is of type ChangeGroup\n    name: string;\n    sequence: any;\n    type: any;\n    sync: any;\n    value: any;\n}\n\nexport type Session = {\n    subscriptions: Subscriptions;\n    sendMessage: SendMessage;\n    sendMessageEnabled: boolean;\n    remoteCalls: Array<any>;\n    pendingRemoteCalls: any;\n    nextPendingRemoteCallId: number;\n    nextSaveSessionId: number;\n    savedSessionId: number;\n    nextSubscriptionId: number;\n    objects: any;\n    nextObjId: number;\n    dispenseNextId: null; // not used anywhere\n}\n\n\nexport type Sessions = { [sessionId: number]: Session };\n\nexport type SendMessage = (message: any) => void;\n\nexport type SavedSession = {\n    revision: number;\n    data: string; // Serialized Session data\n    callCount: number;\n    referenced: number;\n};\n\nexport interface RemoteableClass extends Supertype {\n    syncStates: Array<string>;\n    __toClient__: boolean;\n    __toServer__: boolean;\n}\n\nexport type ChangeString = { [key: string]: string };\ntype PreServerCallChanges = { [key: string]: boolean };\n\nexport type ControllerSyncState = {\n    scope: '+' | '*' | '-'\n    state: string\n}\n\nexport interface ISemotusController {\n    __template__: any;\n    syncState?: ControllerSyncState\n\n    /**\n     * @server\n     *\n     * Callback after a successful remote function call (just the application of changes and the execution of the function call)\n     * Note that this doesn't mean we can't error out on this or subsequent steps of a remote call.\n     *\n     * We can utilize this function as a generic function handler to run after we have successfully called a remote function.\n     * One such use may be to see the changes that were applied from the client\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {changeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     * @param HTTPObjs\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerCall?(hasChanges: boolean, callContext: CallContext, changeString: ChangeString, HTTPObjs?: HTTPObjs): Promise<any>;\n\n    /**\n     * @server\n     *\n     * Callback to handle errors on a remote call.\n     *\n     * Executes after every other step in the remote call pipeline (see remote call documentation)\n     * but before retrying the call (or packaging response and sending back to client)\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * @param {ErrorType} errorType - Error type associated (error, retry, response)\n     * @param {number} remoteCallId - Id for remote call\n     * @param {extends Supertype} remoteObj - Instance for which the remote object function is called for - @TODO: revisit when we create a proper remoteable type\n     * @param {string} functionName - Name of function being called\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {ChangeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerErrorHandler?(errorType: ErrorType, remoteCallId: number, remoteObj: Supertype, functionName: string, callContext: CallContext, changeString: ChangeString): Promise<void>;\n\n    /**\n     * @server\n     *\n     * Callback before a remote function call (1st step of a remote call)\n     *\n     * We can utilize this function as a generic function handler to run before we call a\n     * remote function or before we apply changes from the client to the server\n     *\n     * We can also utilize this function to do any context-specific prep work / loading\n     * if this a subsequent try of this function due to an update conflict.\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {PreServerCallChanges} changes - Dictionary of Objects that have been changed from the client\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {boolean} [forceUpdate] - Optional parameter passed in. True if this is a retry of the call based on an update conflict. False / undefined otherwise.\n     *\n     * @param functionName\n     * @param remoteCall\n     * @param isPublic\n     * @param HTTPObjs\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    preServerCall?(hasChanges: boolean, changes: PreServerCallChanges, callContext: CallContext, forceUpdate: undefined | boolean, functionName: string, remoteCall: RemoteCall, isPublic: boolean, HTTPObjs?: HTTPObjs ): Promise<any>;\n\n    /**\n     * This is a handler that will only be used for testing and debugging purposes\n     *\n     * When this is used, allows us to inspect the message body before we send it out in 'packageChanges'\n     *\n     * DO NOT USE THIS IN PRODUCTION CODE\n     *\n     * @param message\n     */\n    inspectMessage?(message): any;\n}\n\nexport interface Semotus {\n    setSyncState: (str) => void;\n    syncState: string;\n    getSyncState: () => any;\n    maxCallTime: number;\n    __dictionary__: any;\n    memSession: { semotus: { callStartTime: number } };\n    _injectIntoTemplate: (template) => void;\n    serializeAndGarbageCollect: () => any;\n    getMessage: (sessionId, forceMessage) => any;\n    clearPendingCalls: (sessionId) => void;\n    getChangeGroup: (type, subscriptionId) => ChangeGroup;\n    deleteChangeGroup: (type: any, subscriptionId: any) => void;\n    getChangeStatus: () => string;\n    _stashObject: (obj, template) => boolean;\n    sessionize: (obj, referencingObj) => (undefined | any);\n    _setupFunction: (propertyName, propertyValue, role, validate, serverValidation, isPublic: boolean, template) => (any);\n    _setupProperty: (propertyName, defineProperty, objectProperties, defineProperties) => void;\n    withoutChangeTracking: (cb) => void;\n    _changedValue: (obj, prop, value) => void;\n    _referencedArray: (obj, prop, arrayRef, sessionId?) => void;\n    _convertArrayReferencesToChanges: () => void;\n    MarkChangedArrayReferences: () => void;\n    _convertValue: (value) => (any[] | null);\n    getObject: (objId, template) => (any | null);\n    _applyChanges: (changes, force, subscriptionId, callContext) => (number);\n    _applyObjectChanges: (changes, rollback, obj, force) => (boolean);\n    _validateServerIncomingProperty: (obj, prop, defineProperty, newValue) => (boolean);\n    _applyPropertyChange: (changes, rollback, obj, prop, ix, oldValue, newValue, force) => (boolean);\n    _rollback: (rollback) => void;\n    _rollbackChanges: () => void;\n    _createEmptyObject: (template, objId, defineProperty, isTransient) => any;\n    inject: (template, injector) => void;\n    _queueRemoteCall: (objId, functionName, deferred, args) => void;\n    _processQueue: () => void;\n    _toTransport: (obj) => any;\n    _fromTransport: (obj) => any;\n    _extractArguments: (remoteCall) => any;\n    _trimArray: (array) => void;\n    _deleteChangeGroups: (type) => void;\n    _getSubscriptions: (sessionId?) => Subscriptions | null;\n    _getSubscription: (subscriptionId?) => Subscription;\n    cleanPrivateValues: (prop, logValue, defineProperty) => (string | any);\n    Remoteable: (Base) => () => any;\n    Bindable: (Base) => () => any;\n    Persistable: (Base) => () => any;\n    bindDecorators: (objectTemplate?) => void;\n    processMessage: (remoteCall, subscriptionId, restoreSessionCallback, req?: Request, res?: Response) => (undefined | any);\n    enableSendMessage: (value, messageCallback, sessionId) => void;\n    syncSession: (sessionId) => void;\n    restoreSession: (sessionId, savedSession: SavedSession, sendMessage: SendMessage) => boolean;\n    saveSession: (sessionId) => SavedSession;\n    setMinimumSequence: (nextObjId) => void;\n    deleteSession: (sessionId) => void;\n    createSession: (role: any, sendMessage: SendMessage, sessionId: any) => any;\n    log: (level, data) => void;\n    nextObjId: number;\n    maxClientSequence: number;\n    logLevel: number;\n    __conflictMode__: string;\n    __changeTracking__: boolean;\n    _useGettersSetters: boolean;\n    logger: any;\n    role: any;\n    currentSession: any;\n    sessions?: Sessions;\n    nextSubscriptionId: number;\n    nextSessionId: number;\n    controller: ISemotusController;\n    changeString: string;\n\n\n    _getSession(_sid?: any): Session;\n\n    subscribe(role: any): number;\n\n    setSession(sessionId: any): void;\n\n    getChanges(subscriptionId?: any): ChangeGroup;\n\n    _deleteChanges(): void;\n\n    getPendingCallCount(sessionId: any): any;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Types.js","sourceRoot":"","sources":["Types.ts"],"names":[],"mappings":";;;AAaa,QAAA,MAAM,GAAG,QAAQ,CAAC","sourcesContent":["import {Supertype} from '@haventech/supertype';\nimport {Request, Response} from 'express';\nexport type HTTPObjs = {request: Request, response: Response};\n\nexport type Subscription = {\n    role: string;\n    log: {\n        array: ArrayGroup;\n        arrayDirty: ArrayGroup;\n        change: ChangeGroup;\n    }\n}\n\nexport const Change = 'change';\nexport type ArrayTypes = 'array' | 'arrayDirty';\nexport type ErrorType = 'error' | 'retry' | 'response';\n\nexport type CallContext = { retries: number; startTime: Date };\n\nexport type ProcessCallPayload = {\n    semotus: Semotus;\n    remoteCall: RemoteCall;\n    callContext: CallContext;\n    session: Session;\n    subscriptionId: any;\n    remoteCallId: any;\n    restoreSessionCallback?: Function;\n    HTTPObjs?: HTTPObjs;\n}\n\n/**\n *  id is the id of the object + '/' + property.\n *  Ex: there are 1 School to Many Students\n *\n *  School {\n *      students: Array<Students>\n *  }\n *\n *  In this case, one entry within this ArrayGroup may be 'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]\n *\n *  If that's all the changes then the ArrayGroup would be {'server-School-1/students': [\"server-Student-3\", \"server-Student-5\"]}\n */\nexport type ArrayGroup = { [id: string]: ArrayChanges };\n\n/**\n * An array of Id references to Supertype Objects or primitive values\n */\ntype ArrayChanges = Array<any>;\nexport type ChangeGroup = { [objId: string]: PropChanges };\ntype PropChanges = { [prop: string]: Changes };\n\n// Changes[0] is oldValue, Changes[1] is newValue\ntype oldVal = any;\ntype newVal = any;\ntype Changes = [oldVal, newVal][];\n\nexport type Subscriptions = { [key: string]: Subscription };\n\nexport type RemoteCall = {\n    remoteCallId: any;\n    id: any;\n    changes: string; // The string is of type ChangeGroup\n    name: string;\n    sequence: any;\n    type: any;\n    sync: any;\n    value: any;\n}\n\nexport type Session = {\n    subscriptions: Subscriptions;\n    sendMessage: SendMessage;\n    sendMessageEnabled: boolean;\n    remoteCalls: Array<any>;\n    pendingRemoteCalls: any;\n    nextPendingRemoteCallId: number;\n    nextSaveSessionId: number;\n    savedSessionId: number;\n    nextSubscriptionId: number;\n    objects: any;\n    nextObjId: number;\n    dispenseNextId: null; // not used anywhere\n}\n\n\nexport type Sessions = { [sessionId: number]: Session };\n\nexport type SendMessage = (message: any) => void;\n\nexport type SavedSession = {\n    revision: number;\n    data: string; // Serialized Session data\n    callCount: number;\n    referenced: number;\n};\n\nexport interface RemoteableClass extends Supertype {\n    syncStates: Array<string>;\n    __toClient__: boolean;\n    __toServer__: boolean;\n}\n\nexport type ChangeString = { [key: string]: string };\ntype PreServerCallChanges = { [key: string]: boolean };\n\nexport type ControllerSyncState = {\n    scope: '+' | '*' | '-'\n    state: string\n}\n\nexport interface ISemotusController {\n    __template__: any;\n    syncState?: ControllerSyncState\n\n    /**\n     * @server\n     *\n     * Callback after a successful remote function call (just the application of changes and the execution of the function call)\n     * Note that this doesn't mean we can't error out on this or subsequent steps of a remote call.\n     *\n     * We can utilize this function as a generic function handler to run after we have successfully called a remote function.\n     * One such use may be to see the changes that were applied from the client\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {changeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     * @param HTTPObjs\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerCall?(hasChanges: boolean, callContext: CallContext, changeString: ChangeString, HTTPObjs?: HTTPObjs): Promise<any>;\n\n    /**\n     * @server\n     *\n     * Callback to handle errors on a remote call.\n     *\n     * Executes after every other step in the remote call pipeline (see remote call documentation)\n     * but before retrying the call (or packaging response and sending back to client)\n     *\n     * NOTE THAT THE CHANGESTRING DOES NOT INCLUDE CHANGES DONE WITHIN THE REMOTE FUNCTION CALL ITSELF, ONLY CHANGES FROM THE CLIENT\n     *\n     * @param {ErrorType} errorType - Error type associated (error, retry, response)\n     * @param {number} remoteCallId - Id for remote call\n     * @param {extends Supertype} remoteObj - Instance for which the remote object function is called for - @TODO: revisit when we create a proper remoteable type\n     * @param {string} functionName - Name of function being called\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {ChangeString} changeString - Object of Changes - Key is [ClassName].[propertyName], Value is [changedValue] example: {'Customer.middlename': 'Karen'}, See above note\n     *\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    postServerErrorHandler?(errorType: ErrorType, remoteCallId: number, remoteObj: Supertype, functionName: string, callContext: CallContext, changeString: ChangeString): Promise<void>;\n\n    /**\n     * @server\n     *\n     * Callback before a remote function call (1st step of a remote call)\n     *\n     * We can utilize this function as a generic function handler to run before we call a\n     * remote function or before we apply changes from the client to the server\n     *\n     * We can also utilize this function to do any context-specific prep work / loading\n     * if this a subsequent try of this function due to an update conflict.\n     *\n     * See remote call documentation to know where this executes in the lifecycle\n     *\n     * @param {boolean} hasChanges - Whether or not we have applied client changes onto the server's object graph\n     * @param {PreServerCallChanges} changes - Dictionary of Objects that have been changed from the client\n     * @param {CallContext} callContext - Context (number of retries etc)\n     * @param {boolean} [forceUpdate] - Optional parameter passed in. True if this is a retry of the call based on an update conflict. False / undefined otherwise.\n     *\n     * @param functionName\n     * @param remoteCall\n     * @param isPublic\n     * @param HTTPObjs\n     * @returns {Promise<void>}\n     * @memberof Controller\n     */\n    preServerCall?(hasChanges: boolean, changes: PreServerCallChanges, callContext: CallContext, forceUpdate: undefined | boolean, functionName: string, remoteCall: RemoteCall, isPublic: boolean, HTTPObjs?: HTTPObjs ): Promise<any>;\n\n    /**\n     * This is a handler that will only be used for testing and debugging purposes\n     *\n     * When this is used, allows us to inspect the message body before we send it out in 'packageChanges'\n     *\n     * DO NOT USE THIS IN PRODUCTION CODE\n     *\n     * @param message\n     */\n    inspectMessage?(message): any;\n}\n\nexport interface Semotus {\n    setSyncState: (str) => void;\n    syncState: string;\n    getSyncState: () => any;\n    maxCallTime: number;\n    __dictionary__: any;\n    memSession: { semotus: { callStartTime: number } };\n    _injectIntoTemplate: (template) => void;\n    serializeAndGarbageCollect: () => any;\n    getMessage: (sessionId, forceMessage) => any;\n    clearPendingCalls: (sessionId) => void;\n    getChangeGroup: (type, subscriptionId) => ChangeGroup;\n    deleteChangeGroup: (type: any, subscriptionId: any) => void;\n    getChangeStatus: () => string;\n    _stashObject: (obj, template) => boolean;\n    sessionize: (obj, referencingObj) => (undefined | any);\n    _setupFunction: (propertyName, propertyValue, role, validate, serverValidation, isPublic: boolean, template) => (any);\n    _setupProperty: (propertyName, defineProperty, objectProperties, defineProperties) => void;\n    withoutChangeTracking: (cb) => void;\n    _changedValue: (obj, prop, value) => void;\n    _referencedArray: (obj, prop, arrayRef, sessionId?) => void;\n    _convertArrayReferencesToChanges: () => void;\n    MarkChangedArrayReferences: () => void;\n    _convertValue: (value) => (any[] | null);\n    getObject: (objId, template) => (any | null);\n    _applyChanges: (changes, force, subscriptionId, callContext) => (number);\n    _applyObjectChanges: (changes, rollback, obj, force) => (boolean);\n    _validateServerIncomingProperty: (obj, prop, defineProperty, newValue) => (boolean);\n    _applyPropertyChange: (changes, rollback, obj, prop, ix, oldValue, newValue, force) => (boolean);\n    _rollback: (rollback) => void;\n    _rollbackChanges: () => void;\n    _createEmptyObject: (template, objId, defineProperty, isTransient) => any;\n    inject: (template, injector) => void;\n    _queueRemoteCall: (objId, functionName, deferred, args) => void;\n    _processQueue: () => void;\n    _toTransport: (obj) => any;\n    _fromTransport: (obj) => any;\n    _extractArguments: (remoteCall) => any;\n    _trimArray: (array) => void;\n    _deleteChangeGroups: (type) => void;\n    _getSubscriptions: (sessionId?) => Subscriptions | null;\n    _getSubscription: (subscriptionId?) => Subscription;\n    cleanPrivateValues: (prop, logValue, defineProperty) => (string | any);\n    Remoteable: (Base) => () => any;\n    Bindable: (Base) => () => any;\n    Persistable: (Base) => () => any;\n    bindDecorators: (objectTemplate?) => void;\n    processMessage: (remoteCall, subscriptionId, restoreSessionCallback, req?: Request, res?: Response) => (undefined | any);\n    enableSendMessage: (value, messageCallback, sessionId) => void;\n    syncSession: (sessionId) => void;\n    restoreSession: (sessionId, savedSession: SavedSession, sendMessage: SendMessage) => boolean;\n    saveSession: (sessionId) => SavedSession;\n    setMinimumSequence: (nextObjId) => void;\n    deleteSession: (sessionId) => void;\n    createSession: (role: any, sendMessage: SendMessage, sessionId: any) => any;\n    log: (level, data) => void;\n    nextObjId: number;\n    maxClientSequence: number;\n    logLevel: number;\n    __conflictMode__: string;\n    __changeTracking__: boolean;\n    _useGettersSetters: boolean;\n    logger: any;\n    role: any;\n    currentSession: any;\n    sessions?: Sessions;\n    nextSubscriptionId: number;\n    nextSessionId: number;\n    controller: ISemotusController;\n    changeString: string;\n    moduleName: string;\n\n\n    _getSession(_sid?: any): Session;\n\n    subscribe(role: any): number;\n\n    setSession(sessionId: any): void;\n\n    getChanges(subscriptionId?: any): ChangeGroup;\n\n    _deleteChanges(): void;\n\n    getPendingCallCount(sessionId: any): any;\n}\n"]}

@@ -269,2 +269,3 @@ import {Supertype} from '@haventech/supertype';

changeString: string;
moduleName: string;

@@ -271,0 +272,0 @@

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc