All files / node-user-accounts-boilerplate-nahid/helper audit.js

100% Statements 8/8
100% Branches 0/0
100% Functions 1/1
100% Lines 8/8

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64                          73x   73x         2x   2x                   10x                                                 10x   220x     10x  
"use strict";
 
/**
 * Fill in method for audit logging
 * 
 * Use as req.audit(...) or res.audit(...)
 * 
 * @param {string} source source of event. e.g. user or ip
 * @param {string} event type of event. e.g. user or ip
 * @param {string} params data associated with event
 */
function audit(source, event, ...params)
{
  try
  {
    console.log('AUDIT', (new Date())
      .toISOString(), source, event, params.join(' '));
  }
  catch (e)
  {
    try
    {
      console.log('Exception during audit', e);
    }
    catch (ee)
    {}
  }
}
 
/**
 * Audit event type constants.
 */
const notifications = {
  OPERATION_SUCCESS: 'OPERATION_SUCCESS',
  OPERATION_FAILURE: 'OPERATION_FAILURE',
  OPERATION_START: 'OPERATION_START',
  EXCEPTION: 'ERROR_EXCEPTION',
  UNEXPECTED_ERROR: 'ERROR_UNEXPECTED',
  INVALID_REQUEST: 'ERROR_INVALID_REQUEST',
  LOGIN: 'SESSION_LOGIN',
  LOGOUT: 'SESSION_LOGOUT',
  PERMISSION_ERROR: 'SESSION_PERMISSION_ERROR',
  LOGIN_FAILURE: 'SESSION_LOGIN_FAILURE',
  TRACK: 'SESSION_TRACK',
  TIMEOUT: 'SESSION_TIMEOUT',
  ACCOUNT_CHANGE: 'SESSION_ACCOUNT_DETAILS_CHANGE',
  ACCOUNT_CHANGE_PASSWORD: 'SESSION_ACCOUNT_PASSWORD_CHANGE',
  ACCOUNT_CHANGE_PASSWORD_FAILURE: 'SESSION_ACCOUNT_PASSWORD_CHANGE_FAILURE',
  ACCOUNT_SEARCH: 'ACCOUNT_SEARCH',
  ACCOUNT_CREATE: 'ACCOUNT_CREATE',
  ACCOUNT_READ: 'ACCOUNT_READ',
  ACCOUNT_UPDATE: 'ACCOUNT_UPDATE',
  ACCOUNT_DELETE: 'ACCOUNT_DELETE',
  SUCCESS: '_SUCCESS',
  FAILURE: '_FAILURE',
};
 
for (const k in notifications)
{
  audit[k] = notifications[k];
}
 
module.exports = audit;