
Product
Introducing Socket Firewall Enterprise: Flexible, Configurable Protection for Modern Package Ecosystems
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.
auth0-log-extension-tools
Advanced tools
The API client is a low level client allowing you to fetch logs from the Auth0 Management API. This client will get an access_token from the Management API and cache it in memory for as long as it is valid.
const client = new LogsApiClient({
domain: config('AUTH0_DOMAIN'),
clientId: config('AUTH0_CLIENT_ID'),
clientSecret: config('AUTH0_CLIENT_SECRET'),
tokenCache: myTokenCache
});
client.getLogs(query)
.then(data => {
// data.logs contains an array of logs.
// data.limits contains the rate limit details for this request.
});
A custom token cache provider can be supplied to persist the token somewhere (instead of in memory):
{
getToken: function() {
return Promise.resolve('my token');
},
setToken: function(token) {
// Save the token somewhere
return Promise.resolve();
}
}
The stream client is a wrapper around the API client and allows you to fetch all logs from a specific point (the checkpoint ID).
const stream = new LogsApiStream({
domain: config('AUTH0_DOMAIN'),
clientId: config('AUTH0_CLIENT_ID'),
clientSecret: config('AUTH0_CLIENT_SECRET'),
tokenCache: myTokenCache,
checkpointId: startCheckpoint,
types: [ 'ss', 'fn' ]
});
// Get the first batch of 50 items.
stream.next(50);
// Process batch of logs.
stream.on('data', function(data) {
// data.logs contains an array of logs.
// data.limits contains the rate limit details for this request.
// You can now ask for the next batch.
stream.next(50);
// Or you can also stop the stream.
stream.done();
});
// We've reached the end of the stream OR rate limiting kicked in.
stream.on('end', function() {
});
// An error occured when processing the stream.
stream.on('error', function(err) {
console.log(err);
});
The logs processor will orchestrate everything to make log shipping and processing much easier. It will handle retries, timeouts etc..
batchSize: Size of the batch we'll make available in the handlermaxRetries: How many times the batch should be retried (the send part) before discarding the logsmaxRunTimeSeconds: How long the processor is allowed to runstartFrom: The Auth0 Log identifier to start fromlogTypes: An array of log types to filter onlogLevel: The log level to filter on (0 = debug, 1 = info, 2 = warning, 3 = error, 4 = critical)const processor = new LogsProcessor(storageContext, {
domain: config('AUTH0_DOMAIN'),
clientId: config('AUTH0_CLIENT_ID'),
clientSecret: config('AUTH0_CLIENT_SECRET'),
batchSize: config('BATCH_SIZE'),
startFrom: config('START_FROM'),
logTypes: [ 'ss', 'fn' ],
logLevel: config('LOG_LEVEL')
});
processor
.run((logs, cb) => {
sendLogsSomewhere(function(err, result) {
if (err) {
return cb(err);
}
cb();
});
})
.then(status => console.log(status))
.catch(err => console.log(err));
FAQs
A set of tools for logging
We found that auth0-log-extension-tools demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 37 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.

Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.