Discovers Contrast configuration data (yaml, env vars, etc) and preconfigures a common set of APIs to be used for agent and tooling development.
The module exports a factory function.
-
Logging
core.logger.info('...');
See more about the @contrast/logger
service here.
-
Monkey-patching
core.patcher.patch(res, 'end', {
name: 'http.ServerResponse.end',
patchType: 'http-things',
pre(data) {
}
});
See more about the @contrast/patcher
service here.
-
Code rewriting
core.rewriter.addTransforms({
CallExpression(path, state) {
};
});
core.rewriter.rewrite('function() { ...');
See more about the @contrast/rewriter
service here.
-
Dependency hooks
core.depHooks.resolve({ name: 'http' }, http => {
});
See more about the @contrast/dep-hooks
service here.
-
Models and factories
The construction of model data can rely on configuration and therefore can be stateful. So, we provide the models and their factories as services that can be used by consumers as if static.
const snap = core.models.StacktraceFactory.createSnapshot();
const frames = snap();
See more about the @contrast/models
service here.
-
Report messages
core.reporters.install();
core.messages.emit('ProtectInputTracingEvent', { ... });
See more about the @contrast/reporter
service here.
-
Other stuff
There are some utility-type functions that rely on configuration state.
core.isAgentPath('/foo');