Audit log npm package for RDP products
npm install @reddotpay/rdp-auditlog dotenv
npm install aws-sdk --save-dev
- refer to Sample Environment File for environment variables
ENVIRONMENT=development | staging | production
DELIVERY_STREAM_NAME=$RDP_AUDITLOGS_STREAM_DEV | $RDP_AUDITLOGS_STREAM | $RDP_AUDITLOGS_STREAM_PROD
DISPLAY_AUDITLOG=true
AWS Role can refer to either Managed Policy ARN or Policy below.
arn:aws:iam::aws:policy/AmazonKinesisFirehoseFullAccess
BackendFunctionRole
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
-
Effect: Allow
Action:
- 'sts:AssumeRole'
Principal:
Service:
- lambda.amazonaws.com
Policies:
-
PolicyName: {Product}BackendFunctionRole
PolicyDocument:
Version: '2012-10-17'
Statement:
-
Effect: Allow
Action:
- 'lambda:*'
- 'firehose:*'
- 'logs:*'
- 'ec2:*'
Resource: '*'
/*
DATA TYPE
summmary {string} - description of log / error
variable {any} - the variable to log
error {object} - error object return in catch block
event {object} - lambda event
response {object} - response that is return to frontend
*/
Function 1: rdp.log(summary, variable); - equivalent to console.log
Function 2: rdp.error(summary, error); - equivalent to console.error
Function 3: await rdp.audit(event, response); - only called once before lambda return response
// index.js
const rdp = require('@reddotpay/rdp-auditlog');
exports.handler = async (event) => {
/*
All the Lambda Routes
*/
await rdp.audit(event, response); <==== fn 3
return response;
}
// models/test.js
const axios = require('axios');
const rdp = require('@reddotpay/rdp-auditlog');
class test {
async get(input) {
try {
rdp.log('test get route>>', input); <==== fn 1
...
} catch (e) {
rdp.error('test get route error>>', e); <==== fn 2
...
}
return;
}
async post(input) {
try {
rdp.log('test get route>>', input); <==== fn 1
...
} catch (e) {
rdp.error('test get route error>>', e); <==== fn 2
...
}
return;
}
}
{
FailedPutCount: 0,
Encrypted: false,
RequestResponses: [{
RecordId: 'streamId',
}],
}
rdp.maskReturnDefault();
rdp.maskEmail(email);
rdp.maskCard(cardNumber);
rdp.maskString(string);
rdp.maskObject(object);
const maskReturnDefault = rdp.maskReturnDefault();
// ****************
remarks: default is always 16 asterisk
const maskedEmail = rdp.maskEmail('[email protected]');
// use*****@domain.com
const maskedCard = rdp.maskCard('1111222233334444');
// ****************
const maskedString = rdp.maskString('teststring');
// **********
const maskedObject = rdp.maskObject({
key1: "value1",
key2: [1, 2, 3],
key3: {
nestedKey1: "nestedValue1",
nestedKey2: "nestedValue2",
},
});
/*
{
key1: ****************,
key2: ****************,
key3: ****************,
}
*/