The goal of this package is to make it easier to collect information about our services through logs, metrics and error catching.
With the right configuration, logs will go from the local server to "THE CLOUD", then a bunch of awesome stuff will happen and they'll become available on the tenant's dashboard (if it's related to "business" logs) or on Kibana (for everything else).
Usage:
var pkg = require('./package.json');
var env = require('./lib/env');
var agent = require('auth0-instrumentation');
agent.init(pkg, env);
var logger = agent.logger;
logger.info('Foo');
// logs something along the lines of:
// {"name":"foo","process":{"app":"my-app","version":"0.0.1","node":"v5.7.1"},"hostname":"dirceu-auth0.local","pid":24102,"level":30,"msg":"Foo","time":"2016-03-22T19:39:21.609Z","v":0}
Using the right configuration, you can use a metrics collector to... well, collect metrics.
Usage:
var pkg = require('./package.json');
var env = require('./lib/env');
var agent = require('auth0-instrumentation');
agent.init(pkg, env);
var metrics = agent.metrics;
metrics.gauge('mygauge', 42);
metrics.increment('requests_served');
metrics.histogram('service_time', 0.248);
You can use the error reporter to send exceptions to an external service. You can set it up on your app in three ways, depending on what framework is being used.
For hapi
, the error reporter is a plugin. To use it, you can do something like this:
var pkg = require('./package.json');
var env = require('./lib/env');
var agent = require('auth0-instrumentation');
agent.init(pkg, env);
var hapi = require('hapi');
var server = new hapi.Server();
// to capture hapi exceptions with context
server.register([agent.errorReporter.hapi.plugin], function() {});
// to capture a specific error with some extra information
agent.errorReporter.captureException('My error', {
extra: {
user: myUser,
something: somethingElse,
foo: 'bar'
}
});
For express
, the error reporter is composed of two middlewares. To use it, you can do something like this:
var pkg = require('./package.json');
var env = require('./lib/env');
var agent = require('auth0-instrumentation');
agent.init(pkg, env);
var express = require('express');
var app = express();
// before any other request handlers
app.use(agent.errorReporter.express.requestHandler);
// before any other error handlers
app.use(agent.errorReporter.express.errorHandler);
// to capture a specific error with some extra information
agent.errorReporter.captureException('My error', {
extra: {
user: myUser,
something: somethingElse,
foo: 'bar'
}
});
If you don't use hapi
or express
- maybe it's not an HTTP API, it's a worker process or a command-line application - you can do something like this:
var pkg = require('./package.json');
var env = require('./lib/env');
var agent = require('auth0-instrumentation');
agent.init(pkg, env);
// to capture all uncaughts
agent.errorReporter.patchGlobal(function() {
setTimeout(function(){
process.exit(1);
}, 200);
});
// to capture a specific error with some extra information
agent.errorReporter.captureException('My error', {
extra: {
user: myUser,
something: somethingElse,
foo: 'bar'
}
});
Configuration is done through an object with predefined keys, usually coming from environment variables. You only need to configure the variables you want to change.
These are the variables that can be used, along with their default values:
const env = {
// general configuration
'CONSOLE_LOG_LEVEL': 'info', // log level for console
// AWS configuration for SQS and Kinesis
'AWS_ACCESS_KEY_ID': undefined,
'AWS_ACCESS_KEY_SECRET': undefined,
'AWS_REGION': undefined
// SQS configuration
'LOG_TO_SQS': '', // SQS queue name
'LOG_TO_SQS_LEVEL': 'info', // log level for SQS
// Kinesis configuration
'LOG_TO_KINESIS': undefined, // Kinesis stream name
'LOG_TO_KINESIS_LEVEL': 'info', // log level for Kinesis
'KINESIS_OBJECT_MODE': true,
'KINESIS_TIMEOUT': 5,
'KINESIS_LENGTH': 50,
// Error reporter configuration
'ERROR_REPORTER_URL': undefined, // Sentry URL
// Metrics collector configuration
'METRICS_API_KEY': undefined, // DataDog API key
'METRICS_HOST': require('os').hostname(),
'METRICS_PREFIX': pkg.name + '.',
'METRICS_FLUSH_INTERVAL': 15 // seconds
};