Current File : //lib/node_modules/pm2/node_modules/@pm2/io/build/main/src/features/notifyInspector.js |
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const async_1 = require("async");
const json_1 = require("../utils/json");
const serviceManager_1 = require("../serviceManager");
class NotifyInspector {
constructor() {
this.inspectorService = serviceManager_1.ServiceManager.get('inspector');
this.exceptionsTrapped = [];
}
init() {
this.inspectorService.createSession();
this.inspectorService.connect();
this.catchAllDebugger();
}
destroy() {
this.inspectorService.disconnect();
}
trapException(listener) {
return (error) => {
// log it
if (listener === 'unhandledRejection') {
console.log('You have triggered an unhandledRejection, you may have forgotten to catch a Promise rejection:');
}
console.error(error);
// create object to be send
const context = this.exceptionsTrapped.find((exception) => {
return !!exception.error.description.match(error.message);
});
error = json_1.default.jsonize(error);
// inject async stackframe
if (context && context.asyncStackTrace) {
const fetchFrames = (entry) => {
return entry.parent ? entry.callFrames.concat(fetchFrames(entry.parent)) : entry.callFrames;
};
const asyncStack = fetchFrames(context.asyncStackTrace)
.filter(frame => frame.url.indexOf('internal') === -1)
.map(frame => {
return ` at ${frame.functionName || '<anonymous>'} (${frame.url}:${frame.lineNumber}:${frame.columnNumber})`;
});
asyncStack.unshift('');
error.stack = error.stack.concat(asyncStack.join('\n'));
}
error.frame = context ? context.frame : undefined;
// send it
serviceManager_1.ServiceManager.get('transport').send('process:exception', error);
// at this point the process should exit
process.exit(1);
};
}
isObjectInteresting(entry) {
if (!entry.value)
return false;
if (!entry.value.objectId)
return false;
if (entry.value.type !== 'object')
return false;
switch (entry.value.description) {
case 'IncomingMessage': {
return true;
}
}
switch (entry.name) {
case 'headers': {
return true;
}
case 'user': {
return true;
}
case 'token': {
return true;
}
case 'body': {
return true;
}
case 'params': {
return true;
}
case 'query': {
return true;
}
}
return false;
}
isPropertyIntesting(entry, parent) {
if (!entry.value)
return false;
if (entry.value.type === 'object' && entry.properties)
return true;
if (parent && parent.name === 'headers')
return true;
if (parent && parent.name === 'body')
return true;
if (parent && parent.name === 'params')
return true;
if (parent && parent.name === 'query')
return true;
if (entry.name === '__proto__')
return false;
switch (entry.name) {
case 'url': {
return true;
}
case 'user': {
return true;
}
case 'token': {
return true;
}
case 'method': {
return true;
}
case 'ip': {
return true;
}
case 'query': {
return true;
}
case 'path': {
return true;
}
case 'body': {
return true;
}
case 'params': {
return true;
}
}
return false;
}
formatProperty(property) {
const value = property.value && property.value.value ? property.value.value : null;
const description = property.value && property.value.description ? property.value.description : null;
return {
name: property.name,
value: value || description || property.value,
properties: property.properties
};
}
fetchObjectProperties(session, object, cb) {
session.post('Runtime.getProperties', {
objectId: object,
ownProperties: true
}, (err, data) => {
if (err)
return cb(err, undefined);
async_1.default.map(data.result, (entry, next) => {
if (entry.value && entry.value.objectId && this.isObjectInteresting(entry)) {
return this.fetchObjectProperties(session, entry.value.objectId, (err, properties) => {
if (err)
return next(err);
// if some properties has been dumped, attach them
if (properties) {
entry.properties = properties
.filter(property => {
return this.isPropertyIntesting(property, entry);
})
.map(this.formatProperty);
}
return next(undefined, this.formatProperty(entry));
});
}
else {
return next(undefined, this.formatProperty(entry));
}
}, cb);
});
}
catchAllDebugger() {
const session = this.inspectorService.createSession();
this.inspectorService.connect();
// trap exception so we can re-use them with the debugger
process.on('uncaughtException', this.trapException('uncaughtException'));
process.on('unhandledRejection', this.trapException('unhandledRejection'));
// enable all the debugger options
session.post('Debugger.enable');
const maxDepth = parseInt(process.env.PM2_APM_ASYNC_STACK_DEPTH || '', 10);
if (!isNaN(maxDepth)) {
session.post('Debugger.setAsyncCallStackDepth', { maxDepth });
}
session.post('Debugger.setPauseOnExceptions', { state: 'uncaught' });
// register handler for paused event
session.on('Debugger.paused', ({ params }) => {
// should not happen but anyway
if (params.reason !== 'exception' && params.reason !== 'promiseRejection') {
return session.post('Debugger.resume');
}
if (!params.data)
return session.post('Debugger.resume');
const error = params.data;
// get only the current frame
const frame = params.callFrames[0];
// on each frame, dump all scopes
async_1.default.map(frame.scopeChain, (scope, nextScope) => {
if (scope.type === 'global')
return nextScope();
if (!scope.object.objectId)
return nextScope();
// get context of the scope
return this.fetchObjectProperties(session, scope.object.objectId, (error, context) => {
return nextScope(error, Object.assign(scope, {
context,
object: undefined
}));
});
}, (err, scopes) => {
if (err) {
console.error(err);
return session.post('Debugger.resume');
}
// we can remove some scope so we want to remove null entry
scopes = scopes.filter(scope => !!scope);
// inspect each scope to retrieve his context
this.exceptionsTrapped.push({
error,
asyncStackTrace: params.asyncStackTrace,
frame: Object.assign(frame, {
scopeChain: scopes
})
});
// continue execution
return session.post('Debugger.resume');
});
});
}
}
exports.default = NotifyInspector;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifyInspector.js","sourceRoot":"","sources":["../../../../src/features/notifyInspector.ts"],"names":[],"mappings":"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"}