2.0.0 • Published 2 months ago

@gcoreplus/axios-logger v2.0.0

Weekly downloads
13
License
ISC
Repository
github
Last release
2 months ago

npm version Codecov Coverage ISC license

Axios Logger

About

@gcoreplus/axios-logger is a axios interceptor that can log the request/response data displaying the necessary information while communicating with the server.

Inspired by the axios-logger

👨🏻‍💻Installation

Install the main lib

npm install --save @gcoreplus/axios-logger

Usage

import axios from 'axios';
import * as AxiosLogger from '@gcoreplus/axios-logger';

const instance = axios.create();
instance.interceptors.request.use(AxiosLogger.requestLogger, AxiosLogger.errorLogger);
instance.interceptors.response.use(AxiosLogger.responseLogger, AxiosLogger.errorLogger);

Configurations

Custom request/error output logger sample

const instance = axios.create();
instance.interceptors.request.use(
  (request) => AxiosLogger.requestLogger(request, { logger: console.log }),
  (error) => AxiosLogger.errorLogger(error, { logger: console.error })
);

Custom output logger builder sample

import * as AxiosLogger from '@gcoreplus/axios-logger';

AxiosLogger.setGlobalConfig({
  logger: console.log,
  createLoggerBuilder: config => new ObjectLoggerBuilder(config)
});
PropertyTypeDefaultDescription
methodbooleantrueWhether to include HTTP method or not.
urlbooleantrueWhether to include the URL or not.
params.applybooleantrueWhether to include HTTP params or not.
params.redactRedactOptionsundefinedWhether to filter restrict data from params object before print.
data.applybooleantrueWhether to include request/response data or not.
data.redactRedactOptionsundefinedWhether to filter restrict data from data object before print.
headers.applybooleanfalseWhether to include HTTP headers or not.
headers.redactRedactOptionsundefinedWhether to filter restrict data from headers object before print.
statusbooleantrueWhether to include response statuses or not.
prefixTextstring | false'Axios'false => no prefix, otherwise, customize the prefix wanted.
dateFormatdateformat | falsenew Date().toISOString()false => no timestamp, otherwise, customize its format
loggerfunction<string, any>console.logAllows users to customize the logger function to be used. e.g. Winston's logger.info could be leveraged, like this: logger.info.bind(this)
createLoggerBuilderfunction => LoggerBuildernew StringLoggerBuilder(config)Allows to customize the logger output. Possible values, new StringLoggerBuilder(config) and new ObjectLoggerBuilder(config)

Redact with fast-redact - RedactOptions

@gcoreplus/axios-logger uses fast-redact to handle restrict data

For more information see fast-redact and redact documentation

Redact configuration example

import * as AxiosLogger from '@gcoreplus/axios-logger';

AxiosLogger.setGlobalConfig({
  headers: {
    apply: true,
    redact: {
      paths: ['["my-token"]', 'cookie'],
      censor: '***'
    }
  }
});

Backers

License

Distributed under the ISC License. See LICENSE for more information.

Acknowledgements

Copyright © 2020 gCorePlus Inc.