@rudderstack/integrations-lib 0.2.9 → 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.
@@ -181,9 +181,9 @@ 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
183
  exports.LOGLEVELS = {
184
- debug: 0,
185
- info: 1,
186
- warn: 2,
187
- error: 3, // Logs about errors which dont immediately halt the application
184
+ debug: 3,
185
+ info: 2,
186
+ warn: 1,
187
+ error: 0, // Logs about errors which dont immediately halt the application
188
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: 0, // Most verbose logging level\n  info: 1, // Logs about state of the application\n  warn: 2, // Logs about warnings which dont immediately halt the application\n  error: 3, // Logs about errors which dont immediately halt the application\n};\n"]}
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"]}
@@ -14,6 +14,7 @@ interface CustLogger {
14
14
  export type LogOpts = {
15
15
  level?: string;
16
16
  fillExcept?: string[];
17
+ levels?: Record<string, number>;
17
18
  };
18
19
  /**
19
20
  * Structured logger powered by winston
@@ -24,6 +25,7 @@ export type LogOpts = {
24
25
  * - infow
25
26
  * - warnw
26
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)
27
29
  *
28
30
  * @example
29
31
  * const logger = structuredLogger();
@@ -36,6 +38,9 @@ export type LogOpts = {
36
38
  * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
37
39
  * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
38
40
  *
41
+ * @example
42
+ * const logger = structuredLogger({levels: {error:0,warn:1,info:2,debug:3}})
43
+ *
39
44
  * @param opts
40
45
  * @returns
41
46
  */
@@ -1 +1 @@
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;CACvB,CAAC;AACF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,eAAO,MAAM,gBAAgB,UAAW,OAAO;yBAyEjB,MAAM;yBAxHR,MAAM;CAgIjC,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"}
@@ -29,6 +29,7 @@ const getLogLevel = (level) => {
29
29
  * - infow
30
30
  * - warnw
31
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)
32
33
  *
33
34
  * @example
34
35
  * const logger = structuredLogger();
@@ -41,14 +42,21 @@ const getLogLevel = (level) => {
41
42
  * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
42
43
  * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
43
44
  *
45
+ * @example
46
+ * const logger = structuredLogger({levels: {error:0,warn:1,info:2,debug:3}})
47
+ *
44
48
  * @param opts
45
49
  * @returns
46
50
  */
47
51
  const structuredLogger = (opts) => {
52
+ let levels = opts?.levels ?? {};
53
+ if (Object.keys(levels).length === 0) {
54
+ levels = constants_1.LOGLEVELS;
55
+ }
48
56
  // Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger
49
57
  const logger = (0, winston_1.createLogger)({
50
58
  level: getLogLevel(opts?.level || 'error'),
51
- levels: constants_1.LOGLEVELS,
59
+ levels,
52
60
  format: combine(timestamp({
53
61
  format: 'YYYY-MM-DD HH:mm:ssZ',
54
62
  }), errors({ stack: true }), splat(), metadata({
@@ -111,4 +119,4 @@ const structuredLogger = (opts) => {
111
119
  });
112
120
  };
113
121
  exports.structuredLogger = structuredLogger;
114
- //# 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};\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 *\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 * @param opts\n * @returns\n */\nexport const structuredLogger = (opts?: LogOpts) => {\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: LOGLEVELS,\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"]}
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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rudderstack/integrations-lib",
3
- "version": "0.2.9",
3
+ "version": "0.2.10",
4
4
  "description": "",
5
5
  "main": "build/index.js",
6
6
  "module": "build/index.js",