@rudderstack/integrations-lib 0.2.8 → 0.2.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -96,4 +96,10 @@ export declare const GENERIC_MAPPING_CONFIG: {
96
96
  export declare const MappedToDestinationKey = "context.mappedToDestination";
97
97
  export declare const GENERIC_TRUE_VALUES: string[];
98
98
  export declare const GENERIC_FALSE_VALUES: string[];
99
+ export declare const LOGLEVELS: {
100
+ debug: number;
101
+ info: number;
102
+ warn: number;
103
+ error: number;
104
+ };
99
105
  //# sourceMappingURL=constants.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyDlC,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuHlC,CAAC;AAEF,eAAO,MAAM,sBAAsB,gCAAgC,CAAC;AAEpE,eAAO,MAAM,mBAAmB,UAA0C,CAAC;AAC3E,eAAO,MAAM,oBAAoB,UAA6C,CAAC"}
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyDlC,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuHlC,CAAC;AAEF,eAAO,MAAM,sBAAsB,gCAAgC,CAAC;AAEpE,eAAO,MAAM,mBAAmB,UAA0C,CAAC;AAC3E,eAAO,MAAM,oBAAoB,UAA6C,CAAC;AAC/E,eAAO,MAAM,SAAS;;;;;CAKrB,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GENERIC_FALSE_VALUES = exports.GENERIC_TRUE_VALUES = exports.MappedToDestinationKey = exports.GENERIC_MAPPING_CONFIG = exports.NETWORK_STATUS_ERR_MAP = void 0;
3
+ exports.LOGLEVELS = exports.GENERIC_FALSE_VALUES = exports.GENERIC_TRUE_VALUES = exports.MappedToDestinationKey = exports.GENERIC_MAPPING_CONFIG = exports.NETWORK_STATUS_ERR_MAP = void 0;
4
4
  exports.NETWORK_STATUS_ERR_MAP = {
5
5
  EACCES: {
6
6
  status: 400,
@@ -180,4 +180,10 @@ exports.GENERIC_MAPPING_CONFIG = {
180
180
  exports.MappedToDestinationKey = 'context.mappedToDestination';
181
181
  exports.GENERIC_TRUE_VALUES = ['true', 'True', 'TRUE', 't', 'T', '1'];
182
182
  exports.GENERIC_FALSE_VALUES = ['false', 'False', 'FALSE', 'f', 'F', '0'];
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"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","sourcesContent":["export const NETWORK_STATUS_ERR_MAP = {\n  EACCES: {\n    status: 400,\n    message: '[EACCES] :: Permission denied',\n  },\n  EADDRINUSE: {\n    status: 400,\n    message: '[EADDRINUSE] :: Address already in use',\n  },\n  ECONNREFUSED: {\n    status: 500,\n    message: '[ECONNREFUSED] :: Connection refused',\n  },\n  ECONNRESET: {\n    status: 500,\n    message: '[ECONNRESET] :: Connection reset by peer',\n  },\n  EEXIST: {\n    status: 400,\n    message: '[EEXIST] :: File exists',\n  },\n  EISDIR: {\n    status: 400,\n    message: '[EEXIST] :: Is a directory',\n  },\n  EMFILE: {\n    status: 400,\n    message: '[EMFILE] :: Too many open files in system',\n  },\n  ENOENT: {\n    status: 400,\n    message: '[ENOENT] :: No such file or directory',\n  },\n  ENOTDIR: {\n    status: 400,\n    message: '[ENOTDIR] :: Not a directory',\n  },\n  ENOTEMPTY: {\n    status: 400,\n    message: '[ENOTEMPTY] :: Directory not empty)',\n  },\n  ENOTFOUND: {\n    status: 400,\n    message: '[ENOTFOUND] :: DNS lookup failed',\n  },\n  EPERM: {\n    status: 400,\n    message: '[EPERM] :: Operation not permitted',\n  },\n  EPIPE: {\n    status: 400,\n    message: '[EPIPE] :: Broken pipe',\n  },\n  ETIMEDOUT: {\n    status: 500,\n    message: '[ETIMEDOUT] :: Operation timed out',\n  },\n};\n\nexport const GENERIC_MAPPING_CONFIG = {\n  address: ['traits.address', 'context.traits.address'],\n  createdAt: ['traits.createdAt', 'context.traits.createdAt', 'timestamp', 'originalTimestamp'],\n  createdAtOnly: ['traits.createdAt', 'context.traits.createdAt'],\n  email: ['traits.email', 'context.traits.email', 'properties.email', 'context.externalId.0.id'],\n  emailOnly: ['traits.email', 'context.traits.email', 'properties.email'],\n  timestamp: ['timestamp', 'originalTimestamp'],\n  historicalTimestamp: ['timestamp', 'originalTimestamp'],\n  traits: ['traits', 'context.traits'],\n  groupId: ['groupId', 'traits.groupId'],\n  groupTraits: ['traits', 'context.traits'],\n  userId: [\n    'userId',\n    'traits.userId',\n    'traits.id',\n    'context.traits.userId',\n    'context.traits.id',\n    'anonymousId',\n  ],\n  userIdOnly: [\n    'userId',\n    'traits.userId',\n    'traits.id',\n    'context.traits.userId',\n    'context.traits.id',\n  ],\n  name: ['traits.name', 'context.traits.name'],\n  title: ['traits.title', 'context.traits.title'],\n  firstName: [\n    'traits.firstName',\n    'traits.firstname',\n    'traits.first_name',\n    'context.traits.firstName',\n    'context.traits.firstname',\n    'context.traits.first_name',\n  ],\n  lastName: [\n    'traits.lastName',\n    'traits.lastname',\n    'traits.last_name',\n    'context.traits.lastName',\n    'context.traits.lastname',\n    'context.traits.last_name',\n  ],\n  middleName: [\n    'traits.middleName',\n    'traits.middleName',\n    'traits.middle_name',\n    'context.traits.middleName',\n    'context.traits.middleName',\n    'context.traits.middle_name',\n  ],\n  gender: ['traits.gender', 'context.traits.gender'],\n  phone: ['traits.phone', 'context.traits.phone', 'properties.phone'],\n  pageTitle: ['context.page.title', 'properties.title'],\n  pageUrl: ['context.page.url', 'properties.url'],\n  pagePath: ['context.page.path', 'properties.path'],\n  website: ['traits.website', 'context.traits.website', 'properties.website'],\n  GApageUrl: ['properties.url', 'context.page.url'],\n  GApageRef: ['properties.referrer', 'context.page.referrer'],\n  GApageTitle: ['properties.title', 'context.page.title'],\n  GApageSearch: ['properties.search', 'context.page.search'],\n  birthday: [\n    'traits.birthday',\n    'context.traits.birthday',\n    'traits.dateOfBirth',\n    'context.traits.dateOfBirth',\n    'traits.dateofbirth',\n    'context.dateofbirth',\n    'traits.dob',\n    'context.traits.dob',\n    'traits.DOB',\n    'context.traits.DOB',\n  ],\n\n  state: ['traits.state', 'context.traits.state'],\n  country: ['traits.country', 'context.traits.country'],\n  region: ['traits.region', 'context.traits.region'],\n  city: ['traits.address.city', 'context.traits.address.city'],\n\n  avatar: [\n    'traits.avatar',\n    'context.traits.avatar',\n    'traits.avatarURL',\n    'context.traits.avatarURL',\n    'traits.avatar_URL',\n    'context.traits.avatar_URL',\n  ],\n  zipcode: [\n    'traits.zip',\n    'traits.zipcode',\n    'traits.zip_code',\n    'traits.zipCode',\n    'traits.postalcode',\n    'traits.postal_code',\n    'traits.postalCode',\n    'traits.address.zipcode',\n    'traits.address.zip_code',\n    'traits.address.zip',\n    'traits.address.zipCode',\n    'traits.address.postalcode',\n    'traits.address.postal_code',\n    'traits.address.postalCode',\n    'context.traits.zip',\n    'context.traits.zipcode',\n    'context.traits.zip_code',\n    'context.traits.zipCode',\n    'context.traits.postalcode',\n    'context.traits.postal_code',\n    'context.traits.postalCode',\n    'context.traits.address.zip',\n    'context.traits.address.zipcode',\n    'context.traits.address.zip_code',\n    'context.traits.address.zipCode',\n    'context.traits.address.postalcode',\n    'context.traits.address.postal_code',\n    'context.traits.address.postalCode',\n  ],\n  sessionId: ['session_id', 'context.sessionId'],\n};\n\nexport const MappedToDestinationKey = 'context.mappedToDestination';\n\nexport const GENERIC_TRUE_VALUES = ['true', 'True', 'TRUE', 't', 'T', '1'];\nexport const GENERIC_FALSE_VALUES = ['false', 'False', 'FALSE', 'f', 'F', '0'];\n"]}
183
+ exports.LOGLEVELS = {
184
+ debug: 3,
185
+ info: 2,
186
+ warn: 1,
187
+ error: 0, // Logs about errors which dont immediately halt the application
188
+ };
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"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","sourcesContent":["export const NETWORK_STATUS_ERR_MAP = {\n  EACCES: {\n    status: 400,\n    message: '[EACCES] :: Permission denied',\n  },\n  EADDRINUSE: {\n    status: 400,\n    message: '[EADDRINUSE] :: Address already in use',\n  },\n  ECONNREFUSED: {\n    status: 500,\n    message: '[ECONNREFUSED] :: Connection refused',\n  },\n  ECONNRESET: {\n    status: 500,\n    message: '[ECONNRESET] :: Connection reset by peer',\n  },\n  EEXIST: {\n    status: 400,\n    message: '[EEXIST] :: File exists',\n  },\n  EISDIR: {\n    status: 400,\n    message: '[EEXIST] :: Is a directory',\n  },\n  EMFILE: {\n    status: 400,\n    message: '[EMFILE] :: Too many open files in system',\n  },\n  ENOENT: {\n    status: 400,\n    message: '[ENOENT] :: No such file or directory',\n  },\n  ENOTDIR: {\n    status: 400,\n    message: '[ENOTDIR] :: Not a directory',\n  },\n  ENOTEMPTY: {\n    status: 400,\n    message: '[ENOTEMPTY] :: Directory not empty)',\n  },\n  ENOTFOUND: {\n    status: 400,\n    message: '[ENOTFOUND] :: DNS lookup failed',\n  },\n  EPERM: {\n    status: 400,\n    message: '[EPERM] :: Operation not permitted',\n  },\n  EPIPE: {\n    status: 400,\n    message: '[EPIPE] :: Broken pipe',\n  },\n  ETIMEDOUT: {\n    status: 500,\n    message: '[ETIMEDOUT] :: Operation timed out',\n  },\n};\n\nexport const GENERIC_MAPPING_CONFIG = {\n  address: ['traits.address', 'context.traits.address'],\n  createdAt: ['traits.createdAt', 'context.traits.createdAt', 'timestamp', 'originalTimestamp'],\n  createdAtOnly: ['traits.createdAt', 'context.traits.createdAt'],\n  email: ['traits.email', 'context.traits.email', 'properties.email', 'context.externalId.0.id'],\n  emailOnly: ['traits.email', 'context.traits.email', 'properties.email'],\n  timestamp: ['timestamp', 'originalTimestamp'],\n  historicalTimestamp: ['timestamp', 'originalTimestamp'],\n  traits: ['traits', 'context.traits'],\n  groupId: ['groupId', 'traits.groupId'],\n  groupTraits: ['traits', 'context.traits'],\n  userId: [\n    'userId',\n    'traits.userId',\n    'traits.id',\n    'context.traits.userId',\n    'context.traits.id',\n    'anonymousId',\n  ],\n  userIdOnly: [\n    'userId',\n    'traits.userId',\n    'traits.id',\n    'context.traits.userId',\n    'context.traits.id',\n  ],\n  name: ['traits.name', 'context.traits.name'],\n  title: ['traits.title', 'context.traits.title'],\n  firstName: [\n    'traits.firstName',\n    'traits.firstname',\n    'traits.first_name',\n    'context.traits.firstName',\n    'context.traits.firstname',\n    'context.traits.first_name',\n  ],\n  lastName: [\n    'traits.lastName',\n    'traits.lastname',\n    'traits.last_name',\n    'context.traits.lastName',\n    'context.traits.lastname',\n    'context.traits.last_name',\n  ],\n  middleName: [\n    'traits.middleName',\n    'traits.middleName',\n    'traits.middle_name',\n    'context.traits.middleName',\n    'context.traits.middleName',\n    'context.traits.middle_name',\n  ],\n  gender: ['traits.gender', 'context.traits.gender'],\n  phone: ['traits.phone', 'context.traits.phone', 'properties.phone'],\n  pageTitle: ['context.page.title', 'properties.title'],\n  pageUrl: ['context.page.url', 'properties.url'],\n  pagePath: ['context.page.path', 'properties.path'],\n  website: ['traits.website', 'context.traits.website', 'properties.website'],\n  GApageUrl: ['properties.url', 'context.page.url'],\n  GApageRef: ['properties.referrer', 'context.page.referrer'],\n  GApageTitle: ['properties.title', 'context.page.title'],\n  GApageSearch: ['properties.search', 'context.page.search'],\n  birthday: [\n    'traits.birthday',\n    'context.traits.birthday',\n    'traits.dateOfBirth',\n    'context.traits.dateOfBirth',\n    'traits.dateofbirth',\n    'context.dateofbirth',\n    'traits.dob',\n    'context.traits.dob',\n    'traits.DOB',\n    'context.traits.DOB',\n  ],\n\n  state: ['traits.state', 'context.traits.state'],\n  country: ['traits.country', 'context.traits.country'],\n  region: ['traits.region', 'context.traits.region'],\n  city: ['traits.address.city', 'context.traits.address.city'],\n\n  avatar: [\n    'traits.avatar',\n    'context.traits.avatar',\n    'traits.avatarURL',\n    'context.traits.avatarURL',\n    'traits.avatar_URL',\n    'context.traits.avatar_URL',\n  ],\n  zipcode: [\n    'traits.zip',\n    'traits.zipcode',\n    'traits.zip_code',\n    'traits.zipCode',\n    'traits.postalcode',\n    'traits.postal_code',\n    'traits.postalCode',\n    'traits.address.zipcode',\n    'traits.address.zip_code',\n    'traits.address.zip',\n    'traits.address.zipCode',\n    'traits.address.postalcode',\n    'traits.address.postal_code',\n    'traits.address.postalCode',\n    'context.traits.zip',\n    'context.traits.zipcode',\n    'context.traits.zip_code',\n    'context.traits.zipCode',\n    'context.traits.postalcode',\n    'context.traits.postal_code',\n    'context.traits.postalCode',\n    'context.traits.address.zip',\n    'context.traits.address.zipcode',\n    'context.traits.address.zip_code',\n    'context.traits.address.zipCode',\n    'context.traits.address.postalcode',\n    'context.traits.address.postal_code',\n    'context.traits.address.postalCode',\n  ],\n  sessionId: ['session_id', 'context.sessionId'],\n};\n\nexport const MappedToDestinationKey = 'context.mappedToDestination';\n\nexport const GENERIC_TRUE_VALUES = ['true', 'True', 'TRUE', 't', 'T', '1'];\nexport const GENERIC_FALSE_VALUES = ['false', 'False', 'FALSE', 'f', 'F', '0'];\nexport const LOGLEVELS = {\n  debug: 3, // Most verbose logging level\n  info: 2, // Logs about state of the application\n  warn: 1, // Logs about warnings which dont immediately halt the application\n  error: 0, // Logs about errors which dont immediately halt the application\n};\n"]}
package/build/index.d.ts CHANGED
@@ -5,4 +5,5 @@ export * from './logger';
5
5
  export * from './structured-logger';
6
6
  export * from './network';
7
7
  export * from './utils';
8
+ export * from './constants';
8
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC"}
package/build/index.js CHANGED
@@ -21,4 +21,5 @@ __exportStar(require("./logger"), exports);
21
21
  __exportStar(require("./structured-logger"), exports);
22
22
  __exportStar(require("./network"), exports);
23
23
  __exportStar(require("./utils"), exports);
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6QixzREFBb0M7QUFDcEMsNENBQTBCO0FBQzFCLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzJztcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vbG9nZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vc3RydWN0dXJlZC1sb2dnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9uZXR3b3JrJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuIl19
24
+ __exportStar(require("./constants"), exports);
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6QixzREFBb0M7QUFDcEMsNENBQTBCO0FBQzFCLDBDQUF3QjtBQUN4Qiw4Q0FBNEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vdGFncyc7XG5leHBvcnQgKiBmcm9tICcuL2Vycm9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2xvZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL3N0cnVjdHVyZWQtbG9nZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbmV0d29yayc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbiJdfQ==
package/build/logger.d.ts CHANGED
@@ -1,7 +1,8 @@
1
+ declare const getLogLevel: (lvl: string) => string;
1
2
  declare const setLogLevel: (level: any) => void;
2
3
  declare const debug: (...args: any[]) => void;
3
4
  declare const info: (...args: any[]) => void;
4
5
  declare const warn: (...args: any[]) => void;
5
6
  declare const error: (...args: any[]) => void;
6
- export { debug, error, info, setLogLevel, warn };
7
+ export { debug, error, info, setLogLevel, warn, getLogLevel };
7
8
  //# sourceMappingURL=logger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAUA,QAAA,MAAM,WAAW,sBAEhB,CAAC;AAEF,QAAA,MAAM,KAAK,0BAIV,CAAC;AAEF,QAAA,MAAM,IAAI,0BAIT,CAAC;AAEF,QAAA,MAAM,IAAI,0BAIT,CAAC;AAEF,QAAA,MAAM,KAAK,0BAIV,CAAC;AAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,WAAW,QAAS,MAAM,WAK/B,CAAC;AAEF,QAAA,MAAM,WAAW,sBAEhB,CAAC;AAEF,QAAA,MAAM,KAAK,0BAIV,CAAC;AAEF,QAAA,MAAM,IAAI,0BAIT,CAAC;AAEF,QAAA,MAAM,IAAI,0BAIT,CAAC;AAEF,QAAA,MAAM,KAAK,0BAIV,CAAC;AAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC"}
package/build/logger.js CHANGED
@@ -1,39 +1,42 @@
1
1
  "use strict";
2
- /* istanbul ignore file */
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.warn = exports.setLogLevel = exports.info = exports.error = exports.debug = void 0;
5
- const levelDebug = 0; // Most verbose logging level
6
- const levelInfo = 1; // Logs about state of the application
7
- const levelWarn = 2; // Logs about warnings which dont immediately halt the application
8
- const levelError = 3; // Logs about errors which dont immediately halt the application
9
- // any value greater than levelError will work as levelNone
10
- let logLevel = process.env.LOG_LEVEL ? parseInt(process.env.LOG_LEVEL, 10) : levelInfo;
3
+ exports.getLogLevel = exports.warn = exports.setLogLevel = exports.info = exports.error = exports.debug = void 0;
4
+ /* istanbul ignore file */
5
+ const constants_1 = require("./constants");
6
+ let logLevel = 'error';
7
+ const getLogLevel = (lvl) => {
8
+ if (constants_1.LOGLEVELS[lvl] === undefined || constants_1.LOGLEVELS[lvl] === null) {
9
+ return 'error'; // when loglevel is invalid
10
+ }
11
+ return lvl;
12
+ };
13
+ exports.getLogLevel = getLogLevel;
11
14
  const setLogLevel = (level) => {
12
- logLevel = level || logLevel;
15
+ logLevel = getLogLevel(level || logLevel);
13
16
  };
14
17
  exports.setLogLevel = setLogLevel;
15
18
  const debug = (...args) => {
16
- if (levelDebug >= logLevel) {
19
+ if (constants_1.LOGLEVELS.debug >= constants_1.LOGLEVELS[logLevel]) {
17
20
  console.debug(...args);
18
21
  }
19
22
  };
20
23
  exports.debug = debug;
21
24
  const info = (...args) => {
22
- if (levelInfo >= logLevel) {
25
+ if (constants_1.LOGLEVELS.info >= constants_1.LOGLEVELS[logLevel]) {
23
26
  console.info(...args);
24
27
  }
25
28
  };
26
29
  exports.info = info;
27
30
  const warn = (...args) => {
28
- if (levelWarn >= logLevel) {
31
+ if (constants_1.LOGLEVELS.warn >= constants_1.LOGLEVELS[logLevel]) {
29
32
  console.warn(...args);
30
33
  }
31
34
  };
32
35
  exports.warn = warn;
33
36
  const error = (...args) => {
34
- if (levelError >= logLevel) {
37
+ if (constants_1.LOGLEVELS.error >= constants_1.LOGLEVELS[logLevel]) {
35
38
  console.error(...args);
36
39
  }
37
40
  };
38
41
  exports.error = error;
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2xvZ2dlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQTBCOzs7QUFFMUIsTUFBTSxVQUFVLEdBQUcsQ0FBQyxDQUFDLENBQUMsNkJBQTZCO0FBQ25ELE1BQU0sU0FBUyxHQUFHLENBQUMsQ0FBQyxDQUFDLHNDQUFzQztBQUMzRCxNQUFNLFNBQVMsR0FBRyxDQUFDLENBQUMsQ0FBQyxrRUFBa0U7QUFDdkYsTUFBTSxVQUFVLEdBQUcsQ0FBQyxDQUFDLENBQUMsZ0VBQWdFO0FBQ3RGLDJEQUEyRDtBQUUzRCxJQUFJLFFBQVEsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7QUFFdkYsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFLLEVBQUUsRUFBRTtJQUM1QixRQUFRLEdBQUcsS0FBSyxJQUFJLFFBQVEsQ0FBQztBQUMvQixDQUFDLENBQUM7QUEwQjJCLGtDQUFXO0FBeEJ4QyxNQUFNLEtBQUssR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEVBQUU7SUFDeEIsSUFBSSxVQUFVLElBQUksUUFBUSxFQUFFO1FBQzFCLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN4QjtBQUNILENBQUMsQ0FBQztBQW9CTyxzQkFBSztBQWxCZCxNQUFNLElBQUksR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEVBQUU7SUFDdkIsSUFBSSxTQUFTLElBQUksUUFBUSxFQUFFO1FBQ3pCLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN2QjtBQUNILENBQUMsQ0FBQztBQWNxQixvQkFBSTtBQVozQixNQUFNLElBQUksR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEVBQUU7SUFDdkIsSUFBSSxTQUFTLElBQUksUUFBUSxFQUFFO1FBQ3pCLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN2QjtBQUNILENBQUMsQ0FBQztBQVF3QyxvQkFBSTtBQU45QyxNQUFNLEtBQUssR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEVBQUU7SUFDeEIsSUFBSSxVQUFVLElBQUksUUFBUSxFQUFFO1FBQzFCLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN4QjtBQUNILENBQUMsQ0FBQztBQUVjLHNCQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cblxuY29uc3QgbGV2ZWxEZWJ1ZyA9IDA7IC8vIE1vc3QgdmVyYm9zZSBsb2dnaW5nIGxldmVsXG5jb25zdCBsZXZlbEluZm8gPSAxOyAvLyBMb2dzIGFib3V0IHN0YXRlIG9mIHRoZSBhcHBsaWNhdGlvblxuY29uc3QgbGV2ZWxXYXJuID0gMjsgLy8gTG9ncyBhYm91dCB3YXJuaW5ncyB3aGljaCBkb250IGltbWVkaWF0ZWx5IGhhbHQgdGhlIGFwcGxpY2F0aW9uXG5jb25zdCBsZXZlbEVycm9yID0gMzsgLy8gTG9ncyBhYm91dCBlcnJvcnMgd2hpY2ggZG9udCBpbW1lZGlhdGVseSBoYWx0IHRoZSBhcHBsaWNhdGlvblxuLy8gYW55IHZhbHVlIGdyZWF0ZXIgdGhhbiBsZXZlbEVycm9yIHdpbGwgd29yayBhcyBsZXZlbE5vbmVcblxubGV0IGxvZ0xldmVsID0gcHJvY2Vzcy5lbnYuTE9HX0xFVkVMID8gcGFyc2VJbnQocHJvY2Vzcy5lbnYuTE9HX0xFVkVMLCAxMCkgOiBsZXZlbEluZm87XG5cbmNvbnN0IHNldExvZ0xldmVsID0gKGxldmVsKSA9PiB7XG4gIGxvZ0xldmVsID0gbGV2ZWwgfHwgbG9nTGV2ZWw7XG59O1xuXG5jb25zdCBkZWJ1ZyA9ICguLi5hcmdzKSA9PiB7XG4gIGlmIChsZXZlbERlYnVnID49IGxvZ0xldmVsKSB7XG4gICAgY29uc29sZS5kZWJ1ZyguLi5hcmdzKTtcbiAgfVxufTtcblxuY29uc3QgaW5mbyA9ICguLi5hcmdzKSA9PiB7XG4gIGlmIChsZXZlbEluZm8gPj0gbG9nTGV2ZWwpIHtcbiAgICBjb25zb2xlLmluZm8oLi4uYXJncyk7XG4gIH1cbn07XG5cbmNvbnN0IHdhcm4gPSAoLi4uYXJncykgPT4ge1xuICBpZiAobGV2ZWxXYXJuID49IGxvZ0xldmVsKSB7XG4gICAgY29uc29sZS53YXJuKC4uLmFyZ3MpO1xuICB9XG59O1xuXG5jb25zdCBlcnJvciA9ICguLi5hcmdzKSA9PiB7XG4gIGlmIChsZXZlbEVycm9yID49IGxvZ0xldmVsKSB7XG4gICAgY29uc29sZS5lcnJvciguLi5hcmdzKTtcbiAgfVxufTtcblxuZXhwb3J0IHsgZGVidWcsIGVycm9yLCBpbmZvLCBzZXRMb2dMZXZlbCwgd2FybiB9O1xuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2xvZ2dlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwwQkFBMEI7QUFDMUIsMkNBQXdDO0FBRXhDLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQztBQUV2QixNQUFNLFdBQVcsR0FBRyxDQUFDLEdBQVcsRUFBRSxFQUFFO0lBQ2xDLElBQUkscUJBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxTQUFTLElBQUkscUJBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDM0QsT0FBTyxPQUFPLENBQUMsQ0FBQywyQkFBMkI7S0FDNUM7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMsQ0FBQztBQThCOEMsa0NBQVc7QUE1QjNELE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUU7SUFDNUIsUUFBUSxHQUFHLFdBQVcsQ0FBQyxLQUFLLElBQUksUUFBUSxDQUFDLENBQUM7QUFDNUMsQ0FBQyxDQUFDO0FBMEIyQixrQ0FBVztBQXhCeEMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksRUFBRSxFQUFFO0lBQ3hCLElBQUkscUJBQVMsQ0FBQyxLQUFLLElBQUkscUJBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUMxQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7S0FDeEI7QUFDSCxDQUFDLENBQUM7QUFvQk8sc0JBQUs7QUFsQmQsTUFBTSxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUksRUFBRSxFQUFFO0lBQ3ZCLElBQUkscUJBQVMsQ0FBQyxJQUFJLElBQUkscUJBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUN6QyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7S0FDdkI7QUFDSCxDQUFDLENBQUM7QUFjcUIsb0JBQUk7QUFaM0IsTUFBTSxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUksRUFBRSxFQUFFO0lBQ3ZCLElBQUkscUJBQVMsQ0FBQyxJQUFJLElBQUkscUJBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUN6QyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7S0FDdkI7QUFDSCxDQUFDLENBQUM7QUFRd0Msb0JBQUk7QUFOOUMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksRUFBRSxFQUFFO0lBQ3hCLElBQUkscUJBQVMsQ0FBQyxLQUFLLElBQUkscUJBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUMxQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7S0FDeEI7QUFDSCxDQUFDLENBQUM7QUFFYyxzQkFBSyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5pbXBvcnQgeyBMT0dMRVZFTFMgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5cbmxldCBsb2dMZXZlbCA9ICdlcnJvcic7XG5cbmNvbnN0IGdldExvZ0xldmVsID0gKGx2bDogc3RyaW5nKSA9PiB7XG4gIGlmIChMT0dMRVZFTFNbbHZsXSA9PT0gdW5kZWZpbmVkIHx8IExPR0xFVkVMU1tsdmxdID09PSBudWxsKSB7XG4gICAgcmV0dXJuICdlcnJvcic7IC8vIHdoZW4gbG9nbGV2ZWwgaXMgaW52YWxpZFxuICB9XG4gIHJldHVybiBsdmw7XG59O1xuXG5jb25zdCBzZXRMb2dMZXZlbCA9IChsZXZlbCkgPT4ge1xuICBsb2dMZXZlbCA9IGdldExvZ0xldmVsKGxldmVsIHx8IGxvZ0xldmVsKTtcbn07XG5cbmNvbnN0IGRlYnVnID0gKC4uLmFyZ3MpID0+IHtcbiAgaWYgKExPR0xFVkVMUy5kZWJ1ZyA+PSBMT0dMRVZFTFNbbG9nTGV2ZWxdKSB7XG4gICAgY29uc29sZS5kZWJ1ZyguLi5hcmdzKTtcbiAgfVxufTtcblxuY29uc3QgaW5mbyA9ICguLi5hcmdzKSA9PiB7XG4gIGlmIChMT0dMRVZFTFMuaW5mbyA+PSBMT0dMRVZFTFNbbG9nTGV2ZWxdKSB7XG4gICAgY29uc29sZS5pbmZvKC4uLmFyZ3MpO1xuICB9XG59O1xuXG5jb25zdCB3YXJuID0gKC4uLmFyZ3MpID0+IHtcbiAgaWYgKExPR0xFVkVMUy53YXJuID49IExPR0xFVkVMU1tsb2dMZXZlbF0pIHtcbiAgICBjb25zb2xlLndhcm4oLi4uYXJncyk7XG4gIH1cbn07XG5cbmNvbnN0IGVycm9yID0gKC4uLmFyZ3MpID0+IHtcbiAgaWYgKExPR0xFVkVMUy5lcnJvciA+PSBMT0dMRVZFTFNbbG9nTGV2ZWxdKSB7XG4gICAgY29uc29sZS5lcnJvciguLi5hcmdzKTtcbiAgfVxufTtcblxuZXhwb3J0IHsgZGVidWcsIGVycm9yLCBpbmZvLCBzZXRMb2dMZXZlbCwgd2FybiwgZ2V0TG9nTGV2ZWwgfTtcbiJdfQ==
@@ -1,6 +1,4 @@
1
- import { Logform } from 'winston';
2
1
  import { LoggableExtraData } from './types';
3
- export declare const printLog: (info: Logform.TransformableInfo) => string;
4
2
  interface LeveledLogMethod {
5
3
  (message: string, extraData?: Partial<LoggableExtraData>): void;
6
4
  (infoObject: {
@@ -13,6 +11,42 @@ interface CustLogger {
13
11
  debugw: LeveledLogMethod;
14
12
  warnw: LeveledLogMethod;
15
13
  }
16
- export declare const structuredLogger: import("winston").Logger & CustLogger;
14
+ export type LogOpts = {
15
+ level?: string;
16
+ fillExcept?: string[];
17
+ levels?: Record<string, number>;
18
+ };
19
+ /**
20
+ * Structured logger powered by winston
21
+ * We are trying to create structured logging methods.
22
+ * Whenever someone would like to log something using structured logging, they can use these methods to do so.
23
+ * Structured logger methods:
24
+ * - debugw
25
+ * - infow
26
+ * - warnw
27
+ * - errorw
28
+ * Note: While using levels option, we need to make sure that lowest level(debug) has a value higher than higher level(warn)
29
+ *
30
+ * @example
31
+ * const logger = structuredLogger();
32
+ * logger.setLogLevel('warn')
33
+ * logger.warn('my warning', {...})
34
+ * @example
35
+ * const logger = structuredLogger({level: 'info'});
36
+ *
37
+ * @example
38
+ * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
39
+ * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
40
+ *
41
+ * @example
42
+ * const logger = structuredLogger({levels: {error:0,warn:1,info:2,debug:3}})
43
+ *
44
+ * @param opts
45
+ * @returns
46
+ */
47
+ export declare const structuredLogger: (opts?: LogOpts) => import("winston").Logger & CustLogger & {
48
+ setLogLevel: (level: string) => void;
49
+ getLogLevel: (level: string) => string;
50
+ };
17
51
  export {};
18
52
  //# sourceMappingURL=structured-logger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../src/structured-logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoC,OAAO,EAAE,MAAM,SAAS,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAyB5C,eAAO,MAAM,QAAQ,SAAU,QAAQ,iBAAiB,KAAG,MAM1D,CAAC;AA4BF,UAAU,gBAAgB;IACxB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;IAChE,CAAC,UAAU,EAAE;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;CACtE;AAED,UAAU,UAAU;IAClB,MAAM,EAAE,gBAAgB,CAAC;IACzB,KAAK,EAAE,gBAAgB,CAAC;IACxB,MAAM,EAAE,gBAAgB,CAAC;IACzB,KAAK,EAAE,gBAAgB,CAAC;CACzB;AA6CD,eAAO,MAAM,gBAAgB,uCAAsC,CAAC"}
1
+ {"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../src/structured-logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAuB5C,UAAU,gBAAgB;IACxB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;IAChE,CAAC,UAAU,EAAE;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;CACtE;AAED,UAAU,UAAU;IAClB,MAAM,EAAE,gBAAgB,CAAC;IACzB,KAAK,EAAE,gBAAgB,CAAC;IACxB,MAAM,EAAE,gBAAgB,CAAC;IACzB,KAAK,EAAE,gBAAgB,CAAC;CACzB;AAED,MAAM,MAAM,OAAO,GAAG;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACjC,CAAC;AACF;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,eAAO,MAAM,gBAAgB,UAAW,OAAO;yBA6EjB,MAAM;yBAjIR,MAAM;CAyIjC,CAAC"}
@@ -1,8 +1,27 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.structuredLogger = exports.printLog = void 0;
3
+ exports.structuredLogger = void 0;
4
4
  const winston_1 = require("winston");
5
+ const constants_1 = require("./constants");
6
+ const { timestamp, combine, metadata, errors, json, splat } = winston_1.format;
7
+ const metadataKey = 'logMetadata';
8
+ const fillExceptFields = [
9
+ 'destinationId',
10
+ 'sourceId',
11
+ 'destinationType',
12
+ 'workspaceId',
13
+ 'module',
14
+ 'implementation',
15
+ 'feature',
16
+ ];
17
+ const getLogLevel = (level) => {
18
+ if (constants_1.LOGLEVELS[level] === undefined || constants_1.LOGLEVELS[level] === null) {
19
+ return 'error'; // when loglevel is invalid
20
+ }
21
+ return level;
22
+ };
5
23
  /**
24
+ * Structured logger powered by winston
6
25
  * We are trying to create structured logging methods.
7
26
  * Whenever someone would like to log something using structured logging, they can use these methods to do so.
8
27
  * Structured logger methods:
@@ -10,77 +29,94 @@ const winston_1 = require("winston");
10
29
  * - infow
11
30
  * - warnw
12
31
  * - errorw
32
+ * Note: While using levels option, we need to make sure that lowest level(debug) has a value higher than higher level(warn)
33
+ *
34
+ * @example
35
+ * const logger = structuredLogger();
36
+ * logger.setLogLevel('warn')
37
+ * logger.warn('my warning', {...})
38
+ * @example
39
+ * const logger = structuredLogger({level: 'info'});
13
40
  *
14
- * Example for how should one use this logger:
41
+ * @example
15
42
  * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
16
43
  * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
17
- */
18
- const { timestamp, combine, metadata, printf, errors, json, splat } = winston_1.format;
19
- const metadataKey = 'extraData';
20
- const { LOG_LEVEL } = process.env;
21
- const envLevelInt = parseInt(LOG_LEVEL ?? '1', 10);
22
- const winstonConfigLevel = ['debug', 'info', 'warn', 'error'];
23
- const printLog = (info) => {
24
- let extraData = '';
25
- if (info?.[metadataKey]) {
26
- extraData += ` ${JSON.stringify(info[metadataKey])}`;
27
- }
28
- return `${info.timestamp} ${info.level}: ${info.message}${extraData}`;
29
- };
30
- exports.printLog = printLog;
31
- // Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger
32
- const logger = (0, winston_1.createLogger)({
33
- level: winstonConfigLevel[envLevelInt],
34
- format: combine(timestamp({
35
- format: 'YYYY-MM-DD HH:mm:ss',
36
- }), errors({ stack: true }), splat(), metadata({
37
- key: metadataKey,
38
- fillExcept: [
39
- 'timestamp',
40
- 'level',
41
- 'message',
42
- 'stack',
43
- 'destinationResponse',
44
- 'authErrorCategory',
45
- ],
46
- }), printf(exports.printLog), json()),
47
- transports: [new winston_1.transports.Console()],
48
- });
49
- /**
50
- * Logically below method puts structured logger methods into logger instance with required labels such as
51
- * - destinationId
52
- * - workspaceId
53
- * - module
54
- * - implementation
55
- * - sourceId
56
- * - destinationType
57
44
  *
58
- * **Note**: presence of anyone of them is supported at this point
45
+ * @example
46
+ * const logger = structuredLogger({levels: {error:0,warn:1,info:2,debug:3}})
47
+ *
48
+ * @param opts
49
+ * @returns
59
50
  */
60
- const objectLogger = Object.entries({
61
- debugw: 'debug',
62
- infow: 'info',
63
- warnw: 'warning',
64
- errorw: 'error',
65
- }).reduce((agg, curr) => {
66
- const [custLogMethod, winstonLogLevel] = curr;
67
- const method = (msg, ex) => {
68
- const loggableExtraData = {
69
- ...(ex?.destinationId && { destinationId: ex.destinationId }),
70
- ...(ex?.workspaceId && { workspaceId: ex.workspaceId }),
71
- ...(ex?.destinationType && { destinationType: ex.destinationType }),
72
- ...(ex?.sourceId && { sourceId: ex.sourceId }),
73
- ...(ex?.module && { module: ex.module }),
74
- ...(ex?.implementation && { implementation: ex.implementation }),
51
+ const structuredLogger = (opts) => {
52
+ let levels = opts?.levels ?? {};
53
+ if (Object.keys(levels).length === 0) {
54
+ levels = constants_1.LOGLEVELS;
55
+ }
56
+ // Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger
57
+ const logger = (0, winston_1.createLogger)({
58
+ level: getLogLevel(opts?.level || 'error'),
59
+ levels,
60
+ format: combine(timestamp({
61
+ format: 'YYYY-MM-DD HH:mm:ssZ',
62
+ }), errors({ stack: true }), splat(), metadata({
63
+ key: metadataKey,
64
+ fillExcept: [
65
+ 'timestamp',
66
+ 'level',
67
+ 'message',
68
+ 'stack',
69
+ 'destinationResponse',
70
+ 'authErrorCategory',
71
+ ...(opts?.fillExcept || fillExceptFields),
72
+ ],
73
+ }), json()),
74
+ transports: [new winston_1.transports.Console()],
75
+ });
76
+ /**
77
+ * Logically below method puts structured logger methods into logger instance with required labels such as
78
+ * - destinationId
79
+ * - workspaceId
80
+ * - module
81
+ * - implementation
82
+ * - sourceId
83
+ * - destinationType
84
+ *
85
+ * **Note**: presence of anyone of them is supported at this point
86
+ */
87
+ const objectLogger = Object.entries({
88
+ debugw: 'debug',
89
+ infow: 'info',
90
+ warnw: 'warning',
91
+ errorw: 'error',
92
+ }).reduce((agg, curr) => {
93
+ const [custLogMethod, winstonLogLevel] = curr;
94
+ const method = (msg, ex) => {
95
+ const loggableExtraData = {
96
+ ...(ex?.destinationId && { destinationId: ex.destinationId }),
97
+ ...(ex?.workspaceId && { workspaceId: ex.workspaceId }),
98
+ ...(ex?.destinationType && { destinationType: ex.destinationType }),
99
+ ...(ex?.sourceId && { sourceId: ex.sourceId }),
100
+ ...(ex?.module && { module: ex.module }),
101
+ ...(ex?.implementation && { implementation: ex.implementation }),
102
+ ...(ex?.feature && { implementation: ex.feature }),
103
+ };
104
+ if (typeof msg === 'object') {
105
+ const { message, ...others } = msg;
106
+ logger.log(winstonLogLevel, message, { ...others, ...loggableExtraData });
107
+ return;
108
+ }
109
+ logger.log(winstonLogLevel, msg, loggableExtraData);
75
110
  };
76
- if (typeof msg === 'object') {
77
- const { message, ...others } = msg;
78
- logger.log(winstonLogLevel, message, { ...others, ...loggableExtraData });
79
- return;
80
- }
81
- logger.log(winstonLogLevel, msg, loggableExtraData);
111
+ return { ...agg, [custLogMethod]: method };
112
+ }, { errorw: () => { }, infow: () => { }, debugw: () => { }, warnw: () => { } });
113
+ const setLogLevel = (level) => {
114
+ logger.level = getLogLevel(level);
82
115
  };
83
- return { ...agg, [custLogMethod]: method };
84
- }, { errorw: () => { }, infow: () => { }, debugw: () => { }, warnw: () => { } });
85
- exports.structuredLogger = Object.assign(logger, objectLogger);
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"structured-logger.js","sourceRoot":"","sources":["../src/structured-logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { createLogger, transports, format, Logform } from 'winston';\nimport { LoggableExtraData } from './types';\n\n/**\n * We are trying to create structured logging methods.\n * Whenever someone would like to log something using structured logging, they can use these methods to do so.\n * Structured logger methods:\n * - debugw\n * - infow\n * - warnw\n * - errorw\n *\n * Example for how should one use this logger:\n *  logger.infow(\"my error message\", { destinationId: \"destId\", workspaceId: \"wspId\", destinationType: \"dest_type\" }) // preferred\n *  logger.infow({ message: \"my error message-2\", destinationId: \"destId\", workspaceId: \"wspId\",  destinationType: \"dest_type\" })\n */\n\nconst { timestamp, combine, metadata, printf, errors, json, splat } = format;\n\nconst metadataKey = 'extraData';\n\nconst { LOG_LEVEL } = process.env;\n\nconst envLevelInt = parseInt(LOG_LEVEL ?? '1', 10);\nconst winstonConfigLevel = ['debug', 'info', 'warn', 'error'];\n\nexport const printLog = (info: Logform.TransformableInfo): string => {\n  let extraData = '';\n  if (info?.[metadataKey]) {\n    extraData += ` ${JSON.stringify(info[metadataKey])}`;\n  }\n  return `${info.timestamp} ${info.level}: ${info.message}${extraData}`;\n};\n\n// Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger\nconst logger = createLogger({\n  level: winstonConfigLevel[envLevelInt],\n  format: combine(\n    timestamp({\n      format: 'YYYY-MM-DD HH:mm:ss',\n    }),\n    errors({ stack: true }),\n    splat(),\n    metadata({\n      key: metadataKey,\n      fillExcept: [\n        'timestamp',\n        'level',\n        'message',\n        'stack',\n        'destinationResponse',\n        'authErrorCategory',\n      ],\n    }),\n    printf(printLog),\n    json(),\n  ),\n  transports: [new transports.Console()],\n});\n\ninterface LeveledLogMethod {\n  (message: string, extraData?: Partial<LoggableExtraData>): void;\n  (infoObject: { message: string } & Partial<LoggableExtraData>): void;\n}\n\ninterface CustLogger {\n  errorw: LeveledLogMethod;\n  infow: LeveledLogMethod;\n  debugw: LeveledLogMethod;\n  warnw: LeveledLogMethod;\n}\n/**\n * Logically below method puts structured logger methods into logger instance with required labels such as\n * - destinationId\n * - workspaceId\n * - module\n * - implementation\n * - sourceId\n * - destinationType\n *\n * **Note**: presence of anyone of them is supported at this point\n */\nconst objectLogger: CustLogger = Object.entries({\n  debugw: 'debug',\n  infow: 'info',\n  warnw: 'warning',\n  errorw: 'error',\n}).reduce(\n  (agg, curr) => {\n    const [custLogMethod, winstonLogLevel] = curr;\n\n    const method = (\n      msg: string | ({ message: string } & Partial<LoggableExtraData>),\n      ex?: Partial<LoggableExtraData>,\n    ) => {\n      const loggableExtraData: Partial<LoggableExtraData> = {\n        ...(ex?.destinationId && { destinationId: ex.destinationId }),\n        ...(ex?.workspaceId && { workspaceId: ex.workspaceId }),\n        ...(ex?.destinationType && { destinationType: ex.destinationType }),\n        ...(ex?.sourceId && { sourceId: ex.sourceId }),\n        ...(ex?.module && { module: ex.module }),\n        ...(ex?.implementation && { implementation: ex.implementation }),\n      };\n      if (typeof msg === 'object') {\n        const { message, ...others } = msg;\n        logger.log(winstonLogLevel, message, { ...others, ...loggableExtraData });\n        return;\n      }\n      logger.log(winstonLogLevel, msg, loggableExtraData);\n    };\n    return { ...agg, [custLogMethod]: method };\n  },\n  { errorw: () => {}, infow: () => {}, debugw: () => {}, warnw: () => {} },\n);\n\nexport const structuredLogger = Object.assign(logger, objectLogger);\n"]}
116
+ return Object.assign(logger, objectLogger, {
117
+ setLogLevel,
118
+ getLogLevel,
119
+ });
120
+ };
121
+ exports.structuredLogger = structuredLogger;
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"structured-logger.js","sourceRoot":"","sources":["../src/structured-logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { createLogger, transports, format } from 'winston';\nimport { LoggableExtraData } from './types';\nimport { LOGLEVELS } from './constants';\n\nconst { timestamp, combine, metadata, errors, json, splat } = format;\n\nconst metadataKey = 'logMetadata';\nconst fillExceptFields = [\n  'destinationId',\n  'sourceId',\n  'destinationType',\n  'workspaceId',\n  'module',\n  'implementation',\n  'feature',\n];\n\nconst getLogLevel = (level: string) => {\n  if (LOGLEVELS[level] === undefined || LOGLEVELS[level] === null) {\n    return 'error'; // when loglevel is invalid\n  }\n  return level;\n};\n\ninterface LeveledLogMethod {\n  (message: string, extraData?: Partial<LoggableExtraData>): void;\n  (infoObject: { message: string } & Partial<LoggableExtraData>): void;\n}\n\ninterface CustLogger {\n  errorw: LeveledLogMethod;\n  infow: LeveledLogMethod;\n  debugw: LeveledLogMethod;\n  warnw: LeveledLogMethod;\n}\n\nexport type LogOpts = {\n  level?: string;\n  fillExcept?: string[];\n  levels?: Record<string, number>;\n};\n/**\n * Structured logger powered by winston\n * We are trying to create structured logging methods.\n * Whenever someone would like to log something using structured logging, they can use these methods to do so.\n * Structured logger methods:\n * - debugw\n * - infow\n * - warnw\n * - errorw\n * Note: While using levels option, we need to make sure that lowest level(debug) has a value higher than higher level(warn)\n *\n * @example\n *  const logger = structuredLogger();\n *  logger.setLogLevel('warn')\n *  logger.warn('my warning', {...})\n * @example\n *  const logger = structuredLogger({level: 'info'});\n *\n *  @example\n *  logger.infow(\"my error message\", { destinationId: \"destId\", workspaceId: \"wspId\", destinationType: \"dest_type\" }) // preferred\n *  logger.infow({ message: \"my error message-2\", destinationId: \"destId\", workspaceId: \"wspId\",  destinationType: \"dest_type\" })\n *\n * @example\n * const logger = structuredLogger({levels: {error:0,warn:1,info:2,debug:3}})\n *\n * @param opts\n * @returns\n */\nexport const structuredLogger = (opts?: LogOpts) => {\n  let levels = opts?.levels ?? {};\n  if (Object.keys(levels).length === 0) {\n    levels = LOGLEVELS;\n  }\n  // Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger\n  const logger = createLogger({\n    level: getLogLevel(opts?.level || 'error'),\n    levels,\n    format: combine(\n      timestamp({\n        format: 'YYYY-MM-DD HH:mm:ssZ',\n      }),\n      errors({ stack: true }),\n      splat(),\n      metadata({\n        key: metadataKey,\n        fillExcept: [\n          'timestamp',\n          'level',\n          'message',\n          'stack',\n          'destinationResponse',\n          'authErrorCategory',\n          ...(opts?.fillExcept || fillExceptFields),\n        ],\n      }),\n      json(),\n    ),\n    transports: [new transports.Console()],\n  });\n\n  /**\n   * Logically below method puts structured logger methods into logger instance with required labels such as\n   * - destinationId\n   * - workspaceId\n   * - module\n   * - implementation\n   * - sourceId\n   * - destinationType\n   *\n   * **Note**: presence of anyone of them is supported at this point\n   */\n  const objectLogger: CustLogger = Object.entries({\n    debugw: 'debug',\n    infow: 'info',\n    warnw: 'warning',\n    errorw: 'error',\n  }).reduce(\n    (agg, curr) => {\n      const [custLogMethod, winstonLogLevel] = curr;\n\n      const method = (\n        msg: string | ({ message: string } & Partial<LoggableExtraData>),\n        ex?: Partial<LoggableExtraData>,\n      ) => {\n        const loggableExtraData: Partial<LoggableExtraData> = {\n          ...(ex?.destinationId && { destinationId: ex.destinationId }),\n          ...(ex?.workspaceId && { workspaceId: ex.workspaceId }),\n          ...(ex?.destinationType && { destinationType: ex.destinationType }),\n          ...(ex?.sourceId && { sourceId: ex.sourceId }),\n          ...(ex?.module && { module: ex.module }),\n          ...(ex?.implementation && { implementation: ex.implementation }),\n          ...(ex?.feature && { implementation: ex.feature }),\n        };\n        if (typeof msg === 'object') {\n          const { message, ...others } = msg;\n          logger.log(winstonLogLevel, message, { ...others, ...loggableExtraData });\n          return;\n        }\n        logger.log(winstonLogLevel, msg, loggableExtraData);\n      };\n      return { ...agg, [custLogMethod]: method };\n    },\n    { errorw: () => {}, infow: () => {}, debugw: () => {}, warnw: () => {} },\n  );\n\n  const setLogLevel = (level: string) => {\n    logger.level = getLogLevel(level);\n  };\n\n  return Object.assign(logger, objectLogger, {\n    setLogLevel,\n    getLogLevel,\n  });\n};\n"]}
@@ -24,36 +24,34 @@ jest.mock('winston', () => ({
24
24
  }));
25
25
  // eslint-disable-next-line import/first
26
26
  const structured_logger_1 = require("./structured-logger");
27
- const printLogTestCases = [
28
- {
29
- description: 'should show log correctly when extraData is not available',
30
- input: { message: 'some error - 1', level: 'warning', timestamp: 'Jan-12-2024 00:01:02' },
31
- output: 'Jan-12-2024 00:01:02 warning: some error - 1',
32
- },
33
- {
34
- description: 'should show log with stringified extraData when extraData is available',
35
- input: {
36
- message: 'some error - 2',
37
- level: 'warning',
38
- timestamp: 'Jan-12-2024 00:01:02',
39
- extraData: { workspaceId: '21' },
40
- },
41
- output: 'Jan-12-2024 00:01:02 warning: some error - 2 {"workspaceId":"21"}',
42
- },
43
- ];
44
- describe('printLog tests', () => {
45
- test.each(printLogTestCases)('$description', ({ input, output }) => {
46
- expect((0, structured_logger_1.printLog)(input)).toEqual(output);
27
+ const testLogger = (0, structured_logger_1.structuredLogger)(); // initialising logger
28
+ describe('Structured logger setLogLevel tests', () => {
29
+ test('set a debug level', () => {
30
+ testLogger.setLogLevel('debug');
31
+ expect(testLogger.level).toBe('debug');
32
+ });
33
+ test('set a info level', () => {
34
+ testLogger.setLogLevel('info');
35
+ expect(testLogger.level).toBe('info');
36
+ });
37
+ test('set an improper level(invalid loglevel)', () => {
38
+ testLogger.setLogLevel('22');
39
+ expect(testLogger.level).toBe('error');
40
+ });
41
+ test('set an improper level(undefined)', () => {
42
+ // @ts-expect-error this is not possible
43
+ testLogger.setLogLevel(undefined);
44
+ expect(testLogger.level).toBe('error');
47
45
  });
48
46
  });
49
47
  describe('Structured logging tests', () => {
50
48
  test('testing logger errorw function', () => {
51
- structured_logger_1.structuredLogger.errorw('Some error', { destinationId: 'd1' });
49
+ testLogger.errorw('Some error', { destinationId: 'd1' });
52
50
  expect(logger.log).toHaveBeenCalled();
53
51
  expect(logger.log).toHaveBeenCalledWith('error', 'Some error', { destinationId: 'd1' });
54
52
  });
55
53
  test('testing logger debugw function', () => {
56
- structured_logger_1.structuredLogger.debugw('Some error-2', {
54
+ testLogger.debugw('Some error-2', {
57
55
  destinationId: 'd1',
58
56
  workspaceId: 'w1',
59
57
  destinationType: 'd',
@@ -72,7 +70,7 @@ describe('Structured logging tests', () => {
72
70
  });
73
71
  });
74
72
  test('testing logger warnw function', () => {
75
- structured_logger_1.structuredLogger.warnw({
73
+ testLogger.warnw({
76
74
  message: 'some error - 3',
77
75
  destinationId: 'd1',
78
76
  workspaceId: 'w1',
@@ -92,4 +90,4 @@ describe('Structured logging tests', () => {
92
90
  });
93
91
  });
94
92
  });
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1sb2dnZXIudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zdHJ1Y3R1cmVkLWxvZ2dlci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsTUFBTSxNQUFNLEdBQUc7SUFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtJQUNoQixHQUFHLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtDQUNmLENBQUM7QUFFRixtRUFBbUU7QUFDbkUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUMxQixNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNuQixPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNsQixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNoQixTQUFTLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNwQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNmLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2hCLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ3BCO0lBQ0QsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDO0lBQy9DLFVBQVUsRUFBRTtRQUNWLE9BQU8sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ25CO0NBQ0YsQ0FBQyxDQUFDLENBQUM7QUFFSix3Q0FBd0M7QUFDeEMsMkRBQWlFO0FBRWpFLE1BQU0saUJBQWlCLEdBQUc7SUFDeEI7UUFDRSxXQUFXLEVBQUUsMkRBQTJEO1FBQ3hFLEtBQUssRUFBRSxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRTtRQUN6RixNQUFNLEVBQUUsOENBQThDO0tBQ3ZEO0lBQ0Q7UUFDRSxXQUFXLEVBQUUsd0VBQXdFO1FBQ3JGLEtBQUssRUFBRTtZQUNMLE9BQU8sRUFBRSxnQkFBZ0I7WUFDekIsS0FBSyxFQUFFLFNBQVM7WUFDaEIsU0FBUyxFQUFFLHNCQUFzQjtZQUNqQyxTQUFTLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFO1NBQ2pDO1FBQ0QsTUFBTSxFQUFFLG1FQUFtRTtLQUM1RTtDQUNGLENBQUM7QUFDRixRQUFRLENBQUMsZ0JBQWdCLEVBQUUsR0FBRyxFQUFFO0lBQzlCLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFO1FBQ2pFLE1BQU0sQ0FBQyxJQUFBLDRCQUFRLEVBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDMUMsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILFFBQVEsQ0FBQywwQkFBMEIsRUFBRSxHQUFHLEVBQUU7SUFDeEMsSUFBSSxDQUFDLGdDQUFnQyxFQUFFLEdBQUcsRUFBRTtRQUMxQyxvQ0FBZ0IsQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDL0QsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsb0JBQW9CLENBQUMsT0FBTyxFQUFFLFlBQVksRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzFGLENBQUMsQ0FBQyxDQUFDO0lBQ0gsSUFBSSxDQUFDLGdDQUFnQyxFQUFFLEdBQUcsRUFBRTtRQUMxQyxvQ0FBZ0IsQ0FBQyxNQUFNLENBQUMsY0FBYyxFQUFFO1lBQ3RDLGFBQWEsRUFBRSxJQUFJO1lBQ25CLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGVBQWUsRUFBRSxHQUFHO1lBQ3BCLGNBQWMsRUFBRSxNQUFNO1lBQ3RCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7UUFDSCxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDdEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLEVBQUUsY0FBYyxFQUFFO1lBQy9ELGFBQWEsRUFBRSxJQUFJO1lBQ25CLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGVBQWUsRUFBRSxHQUFHO1lBQ3BCLGNBQWMsRUFBRSxNQUFNO1lBQ3RCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQywrQkFBK0IsRUFBRSxHQUFHLEVBQUU7UUFDekMsb0NBQWdCLENBQUMsS0FBSyxDQUFDO1lBQ3JCLE9BQU8sRUFBRSxnQkFBZ0I7WUFDekIsYUFBYSxFQUFFLElBQUk7WUFDbkIsV0FBVyxFQUFFLElBQUk7WUFDakIsZUFBZSxFQUFFLEdBQUc7WUFDcEIsY0FBYyxFQUFFLE1BQU07WUFDdEIsTUFBTSxFQUFFLEtBQUs7WUFDYixRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztRQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUN0QyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtZQUNuRSxhQUFhLEVBQUUsSUFBSTtZQUNuQixXQUFXLEVBQUUsSUFBSTtZQUNqQixlQUFlLEVBQUUsR0FBRztZQUNwQixjQUFjLEVBQUUsTUFBTTtZQUN0QixNQUFNLEVBQUUsS0FBSztZQUNiLFFBQVEsRUFBRSxJQUFJO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGxvZ2dlciA9IHtcbiAgZGVidWc6IGplc3QuZm4oKSxcbiAgbG9nOiBqZXN0LmZuKCksXG59O1xuXG4vLyB0cnlpbmcgdG8gbW9jayBjcmVhdGVMb2dnZXIgdG8gcmV0dXJuIGEgc3BlY2lmaWMgbG9nZ2VyIGluc3RhbmNlXG5qZXN0Lm1vY2soJ3dpbnN0b24nLCAoKSA9PiAoe1xuICBmb3JtYXQ6IHtcbiAgICBjb2xvcml6ZTogamVzdC5mbigpLFxuICAgIGNvbWJpbmU6IGplc3QuZm4oKSxcbiAgICBsYWJlbDogamVzdC5mbigpLFxuICAgIHRpbWVzdGFtcDogamVzdC5mbigpLFxuICAgIHByaW50ZjogamVzdC5mbigpLFxuICAgIGVycm9yczogamVzdC5mbigpLFxuICAgIGpzb246IGplc3QuZm4oKSxcbiAgICBzcGxhdDogamVzdC5mbigpLFxuICAgIG1ldGFkYXRhOiBqZXN0LmZuKCksXG4gIH0sXG4gIGNyZWF0ZUxvZ2dlcjogamVzdC5mbigpLm1vY2tSZXR1cm5WYWx1ZShsb2dnZXIpLFxuICB0cmFuc3BvcnRzOiB7XG4gICAgQ29uc29sZTogamVzdC5mbigpLFxuICB9LFxufSkpO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L2ZpcnN0XG5pbXBvcnQgeyBzdHJ1Y3R1cmVkTG9nZ2VyLCBwcmludExvZyB9IGZyb20gJy4vc3RydWN0dXJlZC1sb2dnZXInO1xuXG5jb25zdCBwcmludExvZ1Rlc3RDYXNlcyA9IFtcbiAge1xuICAgIGRlc2NyaXB0aW9uOiAnc2hvdWxkIHNob3cgbG9nIGNvcnJlY3RseSB3aGVuIGV4dHJhRGF0YSBpcyBub3QgYXZhaWxhYmxlJyxcbiAgICBpbnB1dDogeyBtZXNzYWdlOiAnc29tZSBlcnJvciAtIDEnLCBsZXZlbDogJ3dhcm5pbmcnLCB0aW1lc3RhbXA6ICdKYW4tMTItMjAyNCAwMDowMTowMicgfSxcbiAgICBvdXRwdXQ6ICdKYW4tMTItMjAyNCAwMDowMTowMiB3YXJuaW5nOiBzb21lIGVycm9yIC0gMScsXG4gIH0sXG4gIHtcbiAgICBkZXNjcmlwdGlvbjogJ3Nob3VsZCBzaG93IGxvZyB3aXRoIHN0cmluZ2lmaWVkIGV4dHJhRGF0YSB3aGVuIGV4dHJhRGF0YSBpcyBhdmFpbGFibGUnLFxuICAgIGlucHV0OiB7XG4gICAgICBtZXNzYWdlOiAnc29tZSBlcnJvciAtIDInLFxuICAgICAgbGV2ZWw6ICd3YXJuaW5nJyxcbiAgICAgIHRpbWVzdGFtcDogJ0phbi0xMi0yMDI0IDAwOjAxOjAyJyxcbiAgICAgIGV4dHJhRGF0YTogeyB3b3Jrc3BhY2VJZDogJzIxJyB9LFxuICAgIH0sXG4gICAgb3V0cHV0OiAnSmFuLTEyLTIwMjQgMDA6MDE6MDIgd2FybmluZzogc29tZSBlcnJvciAtIDIge1wid29ya3NwYWNlSWRcIjpcIjIxXCJ9JyxcbiAgfSxcbl07XG5kZXNjcmliZSgncHJpbnRMb2cgdGVzdHMnLCAoKSA9PiB7XG4gIHRlc3QuZWFjaChwcmludExvZ1Rlc3RDYXNlcykoJyRkZXNjcmlwdGlvbicsICh7IGlucHV0LCBvdXRwdXQgfSkgPT4ge1xuICAgIGV4cGVjdChwcmludExvZyhpbnB1dCkpLnRvRXF1YWwob3V0cHV0KTtcbiAgfSk7XG59KTtcblxuZGVzY3JpYmUoJ1N0cnVjdHVyZWQgbG9nZ2luZyB0ZXN0cycsICgpID0+IHtcbiAgdGVzdCgndGVzdGluZyBsb2dnZXIgZXJyb3J3IGZ1bmN0aW9uJywgKCkgPT4ge1xuICAgIHN0cnVjdHVyZWRMb2dnZXIuZXJyb3J3KCdTb21lIGVycm9yJywgeyBkZXN0aW5hdGlvbklkOiAnZDEnIH0pO1xuICAgIGV4cGVjdChsb2dnZXIubG9nKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKCdlcnJvcicsICdTb21lIGVycm9yJywgeyBkZXN0aW5hdGlvbklkOiAnZDEnIH0pO1xuICB9KTtcbiAgdGVzdCgndGVzdGluZyBsb2dnZXIgZGVidWd3IGZ1bmN0aW9uJywgKCkgPT4ge1xuICAgIHN0cnVjdHVyZWRMb2dnZXIuZGVidWd3KCdTb21lIGVycm9yLTInLCB7XG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ2RlYnVnJywgJ1NvbWUgZXJyb3ItMicsIHtcbiAgICAgIGRlc3RpbmF0aW9uSWQ6ICdkMScsXG4gICAgICB3b3Jrc3BhY2VJZDogJ3cxJyxcbiAgICAgIGRlc3RpbmF0aW9uVHlwZTogJ2QnLFxuICAgICAgaW1wbGVtZW50YXRpb246ICdpbXBsJyxcbiAgICAgIG1vZHVsZTogJ21vZCcsXG4gICAgICBzb3VyY2VJZDogJ3MxJyxcbiAgICB9KTtcbiAgfSk7XG5cbiAgdGVzdCgndGVzdGluZyBsb2dnZXIgd2FybncgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgc3RydWN0dXJlZExvZ2dlci53YXJudyh7XG4gICAgICBtZXNzYWdlOiAnc29tZSBlcnJvciAtIDMnLFxuICAgICAgZGVzdGluYXRpb25JZDogJ2QxJyxcbiAgICAgIHdvcmtzcGFjZUlkOiAndzEnLFxuICAgICAgZGVzdGluYXRpb25UeXBlOiAnZCcsXG4gICAgICBpbXBsZW1lbnRhdGlvbjogJ2ltcGwnLFxuICAgICAgbW9kdWxlOiAnbW9kJyxcbiAgICAgIHNvdXJjZUlkOiAnczEnLFxuICAgIH0pO1xuICAgIGV4cGVjdChsb2dnZXIubG9nKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKCd3YXJuaW5nJywgJ3NvbWUgZXJyb3IgLSAzJywge1xuICAgICAgZGVzdGluYXRpb25JZDogJ2QxJyxcbiAgICAgIHdvcmtzcGFjZUlkOiAndzEnLFxuICAgICAgZGVzdGluYXRpb25UeXBlOiAnZCcsXG4gICAgICBpbXBsZW1lbnRhdGlvbjogJ2ltcGwnLFxuICAgICAgbW9kdWxlOiAnbW9kJyxcbiAgICAgIHNvdXJjZUlkOiAnczEnLFxuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1sb2dnZXIudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zdHJ1Y3R1cmVkLWxvZ2dlci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsTUFBTSxNQUFNLEdBQUc7SUFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtJQUNoQixHQUFHLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtDQUNmLENBQUM7QUFFRixtRUFBbUU7QUFDbkUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUMxQixNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNuQixPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNsQixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNoQixTQUFTLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNwQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNmLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2hCLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ3BCO0lBQ0QsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDO0lBQy9DLFVBQVUsRUFBRTtRQUNWLE9BQU8sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ25CO0NBQ0YsQ0FBQyxDQUFDLENBQUM7QUFFSix3Q0FBd0M7QUFDeEMsMkRBQXVEO0FBRXZELE1BQU0sVUFBVSxHQUFHLElBQUEsb0NBQWdCLEdBQUUsQ0FBQyxDQUFDLHNCQUFzQjtBQUU3RCxRQUFRLENBQUMscUNBQXFDLEVBQUUsR0FBRyxF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QkFBZ0IsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsb0JBQW9CLENBQUMsU0FBUyxFQUFFLGdCQUFnQixFQUFFO1lBQ25FLGFBQWEsRUFBRSxJQUFJO1lBQ25CLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGVBQWUsRUFBRSxHQUFHO1lBQ3BCLGNBQWMsRUFBRSxNQUFNO1lBQ3RCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgbG9nZ2VyID0ge1xuICBkZWJ1ZzogamVzdC5mbigpLFxuICBsb2c6IGplc3QuZm4oKSxcbn07XG5cbi8vIHRyeWluZyB0byBtb2NrIGNyZWF0ZUxvZ2dlciB0byByZXR1cm4gYSBzcGVjaWZpYyBsb2dnZXIgaW5zdGFuY2Vcbmplc3QubW9jaygnd2luc3RvbicsICgpID0+ICh7XG4gIGZvcm1hdDoge1xuICAgIGNvbG9yaXplOiBqZXN0LmZuKCksXG4gICAgY29tYmluZTogamVzdC5mbigpLFxuICAgIGxhYmVsOiBqZXN0LmZuKCksXG4gICAgdGltZXN0YW1wOiBqZXN0LmZuKCksXG4gICAgcHJpbnRmOiBqZXN0LmZuKCksXG4gICAgZXJyb3JzOiBqZXN0LmZuKCksXG4gICAganNvbjogamVzdC5mbigpLFxuICAgIHNwbGF0OiBqZXN0LmZuKCksXG4gICAgbWV0YWRhdGE6IGplc3QuZm4oKSxcbiAgfSxcbiAgY3JlYXRlTG9nZ2VyOiBqZXN0LmZuKCkubW9ja1JldHVyblZhbHVlKGxvZ2dlciksXG4gIHRyYW5zcG9ydHM6IHtcbiAgICBDb25zb2xlOiBqZXN0LmZuKCksXG4gIH0sXG59KSk7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQvZmlyc3RcbmltcG9ydCB7IHN0cnVjdHVyZWRMb2dnZXIgfSBmcm9tICcuL3N0cnVjdHVyZWQtbG9nZ2VyJztcblxuY29uc3QgdGVzdExvZ2dlciA9IHN0cnVjdHVyZWRMb2dnZXIoKTsgLy8gaW5pdGlhbGlzaW5nIGxvZ2dlclxuXG5kZXNjcmliZSgnU3RydWN0dXJlZCBsb2dnZXIgc2V0TG9nTGV2ZWwgdGVzdHMnLCAoKSA9PiB7XG4gIHRlc3QoJ3NldCBhIGRlYnVnIGxldmVsJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJ2RlYnVnJyk7XG4gICAgZXhwZWN0KHRlc3RMb2dnZXIubGV2ZWwpLnRvQmUoJ2RlYnVnJyk7XG4gIH0pO1xuICB0ZXN0KCdzZXQgYSBpbmZvIGxldmVsJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJ2luZm8nKTtcbiAgICBleHBlY3QodGVzdExvZ2dlci5sZXZlbCkudG9CZSgnaW5mbycpO1xuICB9KTtcbiAgdGVzdCgnc2V0IGFuIGltcHJvcGVyIGxldmVsKGludmFsaWQgbG9nbGV2ZWwpJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJzIyJyk7XG4gICAgZXhwZWN0KHRlc3RMb2dnZXIubGV2ZWwpLnRvQmUoJ2Vycm9yJyk7XG4gIH0pO1xuICB0ZXN0KCdzZXQgYW4gaW1wcm9wZXIgbGV2ZWwodW5kZWZpbmVkKScsICgpID0+IHtcbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIHRoaXMgaXMgbm90IHBvc3NpYmxlXG4gICAgdGVzdExvZ2dlci5zZXRMb2dMZXZlbCh1bmRlZmluZWQpO1xuICAgIGV4cGVjdCh0ZXN0TG9nZ2VyLmxldmVsKS50b0JlKCdlcnJvcicpO1xuICB9KTtcbn0pO1xuXG5kZXNjcmliZSgnU3RydWN0dXJlZCBsb2dnaW5nIHRlc3RzJywgKCkgPT4ge1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBlcnJvcncgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgdGVzdExvZ2dlci5lcnJvcncoJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ2Vycm9yJywgJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gIH0pO1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBkZWJ1Z3cgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgdGVzdExvZ2dlci5kZWJ1Z3coJ1NvbWUgZXJyb3ItMicsIHtcbiAgICAgIGRlc3RpbmF0aW9uSWQ6ICdkMScsXG4gICAgICB3b3Jrc3BhY2VJZDogJ3cxJyxcbiAgICAgIGRlc3RpbmF0aW9uVHlwZTogJ2QnLFxuICAgICAgaW1wbGVtZW50YXRpb246ICdpbXBsJyxcbiAgICAgIG1vZHVsZTogJ21vZCcsXG4gICAgICBzb3VyY2VJZDogJ3MxJyxcbiAgICB9KTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChsb2dnZXIubG9nKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgnZGVidWcnLCAnU29tZSBlcnJvci0yJywge1xuICAgICAgZGVzdGluYXRpb25JZDogJ2QxJyxcbiAgICAgIHdvcmtzcGFjZUlkOiAndzEnLFxuICAgICAgZGVzdGluYXRpb25UeXBlOiAnZCcsXG4gICAgICBpbXBsZW1lbnRhdGlvbjogJ2ltcGwnLFxuICAgICAgbW9kdWxlOiAnbW9kJyxcbiAgICAgIHNvdXJjZUlkOiAnczEnLFxuICAgIH0pO1xuICB9KTtcblxuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciB3YXJudyBmdW5jdGlvbicsICgpID0+IHtcbiAgICB0ZXN0TG9nZ2VyLndhcm53KHtcbiAgICAgIG1lc3NhZ2U6ICdzb21lIGVycm9yIC0gMycsXG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ3dhcm5pbmcnLCAnc29tZSBlcnJvciAtIDMnLCB7XG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rudderstack/integrations-lib",
3
- "version": "0.2.8",
3
+ "version": "0.2.10",
4
4
  "description": "",
5
5
  "main": "build/index.js",
6
6
  "module": "build/index.js",