@rudderstack/integrations-lib 0.2.7 → 0.2.9

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: 0,
185
+ info: 1,
186
+ warn: 2,
187
+ error: 3, // 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: 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"]}
package/build/index.d.ts CHANGED
@@ -2,6 +2,8 @@ export * from './types';
2
2
  export * from './tags';
3
3
  export * from './errors';
4
4
  export * from './logger';
5
+ export * from './structured-logger';
5
6
  export * from './network';
6
7
  export * from './utils';
8
+ export * from './constants';
7
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,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
@@ -18,6 +18,8 @@ __exportStar(require("./types"), exports);
18
18
  __exportStar(require("./tags"), exports);
19
19
  __exportStar(require("./errors"), exports);
20
20
  __exportStar(require("./logger"), exports);
21
+ __exportStar(require("./structured-logger"), exports);
21
22
  __exportStar(require("./network"), exports);
22
23
  __exportStar(require("./utils"), exports);
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6Qiw0Q0FBMEI7QUFDMUIsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3RhZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9lcnJvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2dnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9uZXR3b3JrJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuIl19
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,37 @@ interface CustLogger {
13
11
  debugw: LeveledLogMethod;
14
12
  warnw: LeveledLogMethod;
15
13
  }
16
- declare const customLogger: import("winston").Logger & CustLogger;
17
- export default customLogger;
14
+ export type LogOpts = {
15
+ level?: string;
16
+ fillExcept?: string[];
17
+ };
18
+ /**
19
+ * Structured logger powered by winston
20
+ * We are trying to create structured logging methods.
21
+ * Whenever someone would like to log something using structured logging, they can use these methods to do so.
22
+ * Structured logger methods:
23
+ * - debugw
24
+ * - infow
25
+ * - warnw
26
+ * - errorw
27
+ *
28
+ * @example
29
+ * const logger = structuredLogger();
30
+ * logger.setLogLevel('warn')
31
+ * logger.warn('my warning', {...})
32
+ * @example
33
+ * const logger = structuredLogger({level: 'info'});
34
+ *
35
+ * @example
36
+ * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
37
+ * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
38
+ *
39
+ * @param opts
40
+ * @returns
41
+ */
42
+ export declare const structuredLogger: (opts?: LogOpts) => import("winston").Logger & CustLogger & {
43
+ setLogLevel: (level: string) => void;
44
+ getLogLevel: (level: string) => string;
45
+ };
46
+ export {};
18
47
  //# 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,QAAA,MAAM,YAAY,uCAAsC,CAAC;AAEzD,eAAe,YAAY,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;CACvB,CAAC;AACF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,eAAO,MAAM,gBAAgB,UAAW,OAAO;yBAyEjB,MAAM;yBAxHR,MAAM;CAgIjC,CAAC"}
@@ -1,8 +1,27 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- 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:
@@ -11,77 +30,85 @@ const winston_1 = require("winston");
11
30
  * - warnw
12
31
  * - errorw
13
32
  *
14
- * Example for how should one use this logger:
33
+ * @example
34
+ * const logger = structuredLogger();
35
+ * logger.setLogLevel('warn')
36
+ * logger.warn('my warning', {...})
37
+ * @example
38
+ * const logger = structuredLogger({level: 'info'});
39
+ *
40
+ * @example
15
41
  * logger.infow("my error message", { destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" }) // preferred
16
42
  * logger.infow({ message: "my error message-2", destinationId: "destId", workspaceId: "wspId", destinationType: "dest_type" })
17
- */
18
- const { timestamp, combine, metadata, printf, align, errors, json } = 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: 'MMM-DD-YYYY HH:mm:ss',
36
- }), errors({ stack: true }), align(), 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
43
  *
58
- * **Note**: presence of anyone of them is supported at this point
44
+ * @param opts
45
+ * @returns
59
46
  */
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 }),
47
+ const structuredLogger = (opts) => {
48
+ // Doc: https://github.com/winstonjs/winston?tab=readme-ov-file#creating-your-own-logger
49
+ const logger = (0, winston_1.createLogger)({
50
+ level: getLogLevel(opts?.level || 'error'),
51
+ levels: constants_1.LOGLEVELS,
52
+ format: combine(timestamp({
53
+ format: 'YYYY-MM-DD HH:mm:ssZ',
54
+ }), errors({ stack: true }), splat(), metadata({
55
+ key: metadataKey,
56
+ fillExcept: [
57
+ 'timestamp',
58
+ 'level',
59
+ 'message',
60
+ 'stack',
61
+ 'destinationResponse',
62
+ 'authErrorCategory',
63
+ ...(opts?.fillExcept || fillExceptFields),
64
+ ],
65
+ }), json()),
66
+ transports: [new winston_1.transports.Console()],
67
+ });
68
+ /**
69
+ * Logically below method puts structured logger methods into logger instance with required labels such as
70
+ * - destinationId
71
+ * - workspaceId
72
+ * - module
73
+ * - implementation
74
+ * - sourceId
75
+ * - destinationType
76
+ *
77
+ * **Note**: presence of anyone of them is supported at this point
78
+ */
79
+ const objectLogger = Object.entries({
80
+ debugw: 'debug',
81
+ infow: 'info',
82
+ warnw: 'warning',
83
+ errorw: 'error',
84
+ }).reduce((agg, curr) => {
85
+ const [custLogMethod, winstonLogLevel] = curr;
86
+ const method = (msg, ex) => {
87
+ const loggableExtraData = {
88
+ ...(ex?.destinationId && { destinationId: ex.destinationId }),
89
+ ...(ex?.workspaceId && { workspaceId: ex.workspaceId }),
90
+ ...(ex?.destinationType && { destinationType: ex.destinationType }),
91
+ ...(ex?.sourceId && { sourceId: ex.sourceId }),
92
+ ...(ex?.module && { module: ex.module }),
93
+ ...(ex?.implementation && { implementation: ex.implementation }),
94
+ ...(ex?.feature && { implementation: ex.feature }),
95
+ };
96
+ if (typeof msg === 'object') {
97
+ const { message, ...others } = msg;
98
+ logger.log(winstonLogLevel, message, { ...others, ...loggableExtraData });
99
+ return;
100
+ }
101
+ logger.log(winstonLogLevel, msg, loggableExtraData);
75
102
  };
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);
103
+ return { ...agg, [custLogMethod]: method };
104
+ }, { errorw: () => { }, infow: () => { }, debugw: () => { }, warnw: () => { } });
105
+ const setLogLevel = (level) => {
106
+ logger.level = getLogLevel(level);
82
107
  };
83
- return { ...agg, [custLogMethod]: method };
84
- }, { errorw: () => { }, infow: () => { }, debugw: () => { }, warnw: () => { } });
85
- const customLogger = Object.assign(logger, objectLogger);
86
- exports.default = customLogger;
87
- //# 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, align, errors, json } = 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: 'MMM-DD-YYYY HH:mm:ss',\n    }),\n    errors({ stack: true }),\n    align(),\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\nconst customLogger = Object.assign(logger, objectLogger);\n\nexport default customLogger;\n"]}
108
+ return Object.assign(logger, objectLogger, {
109
+ setLogLevel,
110
+ getLogLevel,
111
+ });
112
+ };
113
+ 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"]}
@@ -1,27 +1,4 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  Object.defineProperty(exports, "__esModule", { value: true });
26
3
  const logger = {
27
4
  debug: jest.fn(),
@@ -37,7 +14,7 @@ jest.mock('winston', () => ({
37
14
  printf: jest.fn(),
38
15
  errors: jest.fn(),
39
16
  json: jest.fn(),
40
- align: jest.fn(),
17
+ splat: jest.fn(),
41
18
  metadata: jest.fn(),
42
19
  },
43
20
  createLogger: jest.fn().mockReturnValue(logger),
@@ -46,37 +23,35 @@ jest.mock('winston', () => ({
46
23
  },
47
24
  }));
48
25
  // eslint-disable-next-line import/first
49
- const structured_logger_1 = __importStar(require("./structured-logger"));
50
- const printLogTestCases = [
51
- {
52
- description: 'should show log correctly when extraData is not available',
53
- input: { message: 'some error - 1', level: 'warning', timestamp: 'Jan-12-2024 00:01:02' },
54
- output: 'Jan-12-2024 00:01:02 warning: some error - 1',
55
- },
56
- {
57
- description: 'should show log with stringified extraData when extraData is available',
58
- input: {
59
- message: 'some error - 2',
60
- level: 'warning',
61
- timestamp: 'Jan-12-2024 00:01:02',
62
- extraData: { workspaceId: '21' },
63
- },
64
- output: 'Jan-12-2024 00:01:02 warning: some error - 2 {"workspaceId":"21"}',
65
- },
66
- ];
67
- describe('printLog tests', () => {
68
- test.each(printLogTestCases)('$description', ({ input, output }) => {
69
- expect((0, structured_logger_1.printLog)(input)).toEqual(output);
26
+ const structured_logger_1 = require("./structured-logger");
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');
70
45
  });
71
46
  });
72
47
  describe('Structured logging tests', () => {
73
48
  test('testing logger errorw function', () => {
74
- structured_logger_1.default.errorw('Some error', { destinationId: 'd1' });
49
+ testLogger.errorw('Some error', { destinationId: 'd1' });
75
50
  expect(logger.log).toHaveBeenCalled();
76
51
  expect(logger.log).toHaveBeenCalledWith('error', 'Some error', { destinationId: 'd1' });
77
52
  });
78
53
  test('testing logger debugw function', () => {
79
- structured_logger_1.default.debugw('Some error-2', {
54
+ testLogger.debugw('Some error-2', {
80
55
  destinationId: 'd1',
81
56
  workspaceId: 'w1',
82
57
  destinationType: 'd',
@@ -95,7 +70,7 @@ describe('Structured logging tests', () => {
95
70
  });
96
71
  });
97
72
  test('testing logger warnw function', () => {
98
- structured_logger_1.default.warnw({
73
+ testLogger.warnw({
99
74
  message: 'some error - 3',
100
75
  destinationId: 'd1',
101
76
  workspaceId: 'w1',
@@ -115,4 +90,4 @@ describe('Structured logging tests', () => {
115
90
  });
116
91
  });
117
92
  });
118
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1sb2dnZXIudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zdHJ1Y3R1cmVkLWxvZ2dlci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxNQUFNLE1BQU0sR0FBRztJQUNiLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0lBQ2hCLEdBQUcsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0NBQ2YsQ0FBQztBQUVGLG1FQUFtRTtBQUNuRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBQzFCLE1BQU0sRUFBRTtRQUNOLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ25CLE9BQU8sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2xCLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2hCLFNBQVMsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ3BCLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2pCLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2pCLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2YsS0FBSyxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7UUFDaEIsUUFBUSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7S0FDcEI7SUFDRCxZQUFZLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUM7SUFDL0MsVUFBVSxFQUFFO1FBQ1YsT0FBTyxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7S0FDbkI7Q0FDRixDQUFDLENBQUMsQ0FBQztBQUVKLHdDQUF3QztBQUN4Qyx5RUFBaUU7QUFFakUsTUFBTSxpQkFBaUIsR0FBRztJQUN4QjtRQUNFLFdBQVcsRUFBRSwyREFBMkQ7UUFDeEUsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLHNCQUFzQixFQUFFO1FBQ3pGLE1BQU0sRUFBRSw4Q0FBOEM7S0FDdkQ7SUFDRDtRQUNFLFdBQVcsRUFBRSx3RUFBd0U7UUFDckYsS0FBSyxFQUFFO1lBQ0wsT0FBTyxFQUFFLGdCQUFnQjtZQUN6QixLQUFLLEVBQUUsU0FBUztZQUNoQixTQUFTLEVBQUUsc0JBQXNCO1lBQ2pDLFNBQVMsRUFBRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUU7U0FDakM7UUFDRCxNQUFNLEVBQUUsbUVBQW1FO0tBQzVFO0NBQ0YsQ0FBQztBQUNGLFFBQVEsQ0FBQyxnQkFBZ0IsRUFBRSxHQUFHLEVBQUU7SUFDOUIsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLGNBQWMsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUU7UUFDakUsTUFBTSxDQUFDLElBQUEsNEJBQVEsRUFBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMxQyxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDO0FBRUgsUUFBUSxDQUFDLDBCQUEwQixFQUFFLEdBQUcsRUFBRTtJQUN4QyxJQUFJLENBQUMsZ0NBQWdDLEVBQUUsR0FBRyxFQUFFO1FBQzFDLDJCQUFnQixDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUMvRCxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDdEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLEVBQUUsWUFBWSxFQUFFLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDMUYsQ0FBQyxDQUFDLENBQUM7SUFDSCxJQUFJLENBQUMsZ0NBQWdDLEVBQUUsR0FBRyxFQUFFO1FBQzFDLDJCQUFnQixDQUFDLE1BQU0sQ0FBQyxjQUFjLEVBQUU7WUFDdEMsYUFBYSxFQUFFLElBQUk7WUFDbkIsV0FBVyxFQUFFLElBQUk7WUFDakIsZUFBZSxFQUFFLEdBQUc7WUFDcEIsY0FBYyxFQUFFLE1BQU07WUFDdEIsTUFBTSxFQUFFLEtBQUs7WUFDYixRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztRQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUN0QyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLE9BQU8sRUFBRSxjQUFjLEVBQUU7WUFDL0QsYUFBYSxFQUFFLElBQUk7WUFDbkIsV0FBVyxFQUFFLElBQUk7WUFDakIsZUFBZSxFQUFFLEdBQUc7WUFDcEIsY0FBYyxFQUFFLE1BQU07WUFDdEIsTUFBTSxFQUFFLEtBQUs7WUFDYixRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0lBRUgsSUFBSSxDQUFDLCtCQUErQixFQUFFLEdBQUcsRUFBRTtRQUN6QywyQkFBZ0IsQ0FBQyxLQUFLLENBQUM7WUFDckIsT0FBTyxFQUFFLGdCQUFnQjtZQUN6QixhQUFhLEVBQUUsSUFBSTtZQUNuQixXQUFXLEVBQUUsSUFBSTtZQUNqQixlQUFlLEVBQUUsR0FBRztZQUNwQixjQUFjLEVBQUUsTUFBTTtZQUN0QixNQUFNLEVBQUUsS0FBSztZQUNiLFFBQVEsRUFBRSxJQUFJO1NBQ2YsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsb0JBQW9CLENBQUMsU0FBUyxFQUFFLGdCQUFnQixFQUFFO1lBQ25FLGFBQWEsRUFBRSxJQUFJO1lBQ25CLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGVBQWUsRUFBRSxHQUFHO1lBQ3BCLGNBQWMsRUFBRSxNQUFNO1lBQ3RCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgbG9nZ2VyID0ge1xuICBkZWJ1ZzogamVzdC5mbigpLFxuICBsb2c6IGplc3QuZm4oKSxcbn07XG5cbi8vIHRyeWluZyB0byBtb2NrIGNyZWF0ZUxvZ2dlciB0byByZXR1cm4gYSBzcGVjaWZpYyBsb2dnZXIgaW5zdGFuY2Vcbmplc3QubW9jaygnd2luc3RvbicsICgpID0+ICh7XG4gIGZvcm1hdDoge1xuICAgIGNvbG9yaXplOiBqZXN0LmZuKCksXG4gICAgY29tYmluZTogamVzdC5mbigpLFxuICAgIGxhYmVsOiBqZXN0LmZuKCksXG4gICAgdGltZXN0YW1wOiBqZXN0LmZuKCksXG4gICAgcHJpbnRmOiBqZXN0LmZuKCksXG4gICAgZXJyb3JzOiBqZXN0LmZuKCksXG4gICAganNvbjogamVzdC5mbigpLFxuICAgIGFsaWduOiBqZXN0LmZuKCksXG4gICAgbWV0YWRhdGE6IGplc3QuZm4oKSxcbiAgfSxcbiAgY3JlYXRlTG9nZ2VyOiBqZXN0LmZuKCkubW9ja1JldHVyblZhbHVlKGxvZ2dlciksXG4gIHRyYW5zcG9ydHM6IHtcbiAgICBDb25zb2xlOiBqZXN0LmZuKCksXG4gIH0sXG59KSk7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQvZmlyc3RcbmltcG9ydCBzdHJ1Y3R1cmVkTG9nZ2VyLCB7IHByaW50TG9nIH0gZnJvbSAnLi9zdHJ1Y3R1cmVkLWxvZ2dlcic7XG5cbmNvbnN0IHByaW50TG9nVGVzdENhc2VzID0gW1xuICB7XG4gICAgZGVzY3JpcHRpb246ICdzaG91bGQgc2hvdyBsb2cgY29ycmVjdGx5IHdoZW4gZXh0cmFEYXRhIGlzIG5vdCBhdmFpbGFibGUnLFxuICAgIGlucHV0OiB7IG1lc3NhZ2U6ICdzb21lIGVycm9yIC0gMScsIGxldmVsOiAnd2FybmluZycsIHRpbWVzdGFtcDogJ0phbi0xMi0yMDI0IDAwOjAxOjAyJyB9LFxuICAgIG91dHB1dDogJ0phbi0xMi0yMDI0IDAwOjAxOjAyIHdhcm5pbmc6IHNvbWUgZXJyb3IgLSAxJyxcbiAgfSxcbiAge1xuICAgIGRlc2NyaXB0aW9uOiAnc2hvdWxkIHNob3cgbG9nIHdpdGggc3RyaW5naWZpZWQgZXh0cmFEYXRhIHdoZW4gZXh0cmFEYXRhIGlzIGF2YWlsYWJsZScsXG4gICAgaW5wdXQ6IHtcbiAgICAgIG1lc3NhZ2U6ICdzb21lIGVycm9yIC0gMicsXG4gICAgICBsZXZlbDogJ3dhcm5pbmcnLFxuICAgICAgdGltZXN0YW1wOiAnSmFuLTEyLTIwMjQgMDA6MDE6MDInLFxuICAgICAgZXh0cmFEYXRhOiB7IHdvcmtzcGFjZUlkOiAnMjEnIH0sXG4gICAgfSxcbiAgICBvdXRwdXQ6ICdKYW4tMTItMjAyNCAwMDowMTowMiB3YXJuaW5nOiBzb21lIGVycm9yIC0gMiB7XCJ3b3Jrc3BhY2VJZFwiOlwiMjFcIn0nLFxuICB9LFxuXTtcbmRlc2NyaWJlKCdwcmludExvZyB0ZXN0cycsICgpID0+IHtcbiAgdGVzdC5lYWNoKHByaW50TG9nVGVzdENhc2VzKSgnJGRlc2NyaXB0aW9uJywgKHsgaW5wdXQsIG91dHB1dCB9KSA9PiB7XG4gICAgZXhwZWN0KHByaW50TG9nKGlucHV0KSkudG9FcXVhbChvdXRwdXQpO1xuICB9KTtcbn0pO1xuXG5kZXNjcmliZSgnU3RydWN0dXJlZCBsb2dnaW5nIHRlc3RzJywgKCkgPT4ge1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBlcnJvcncgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgc3RydWN0dXJlZExvZ2dlci5lcnJvcncoJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ2Vycm9yJywgJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gIH0pO1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBkZWJ1Z3cgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgc3RydWN0dXJlZExvZ2dlci5kZWJ1Z3coJ1NvbWUgZXJyb3ItMicsIHtcbiAgICAgIGRlc3RpbmF0aW9uSWQ6ICdkMScsXG4gICAgICB3b3Jrc3BhY2VJZDogJ3cxJyxcbiAgICAgIGRlc3RpbmF0aW9uVHlwZTogJ2QnLFxuICAgICAgaW1wbGVtZW50YXRpb246ICdpbXBsJyxcbiAgICAgIG1vZHVsZTogJ21vZCcsXG4gICAgICBzb3VyY2VJZDogJ3MxJyxcbiAgICB9KTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChsb2dnZXIubG9nKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgnZGVidWcnLCAnU29tZSBlcnJvci0yJywge1xuICAgICAgZGVzdGluYXRpb25JZDogJ2QxJyxcbiAgICAgIHdvcmtzcGFjZUlkOiAndzEnLFxuICAgICAgZGVzdGluYXRpb25UeXBlOiAnZCcsXG4gICAgICBpbXBsZW1lbnRhdGlvbjogJ2ltcGwnLFxuICAgICAgbW9kdWxlOiAnbW9kJyxcbiAgICAgIHNvdXJjZUlkOiAnczEnLFxuICAgIH0pO1xuICB9KTtcblxuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciB3YXJudyBmdW5jdGlvbicsICgpID0+IHtcbiAgICBzdHJ1Y3R1cmVkTG9nZ2VyLndhcm53KHtcbiAgICAgIG1lc3NhZ2U6ICdzb21lIGVycm9yIC0gMycsXG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ3dhcm5pbmcnLCAnc29tZSBlcnJvciAtIDMnLCB7XG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1sb2dnZXIudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zdHJ1Y3R1cmVkLWxvZ2dlci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsTUFBTSxNQUFNLEdBQUc7SUFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtJQUNoQixHQUFHLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtDQUNmLENBQUM7QUFFRixtRUFBbUU7QUFDbkUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUMxQixNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNuQixPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNsQixLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNoQixTQUFTLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNwQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNqQixJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtRQUNmLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ2hCLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ3BCO0lBQ0QsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDO0lBQy9DLFVBQVUsRUFBRTtRQUNWLE9BQU8sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFO0tBQ25CO0NBQ0YsQ0FBQyxDQUFDLENBQUM7QUFFSix3Q0FBd0M7QUFDeEMsMkRBQXVEO0FBRXZELE1BQU0sVUFBVSxHQUFHLElBQUEsb0NBQWdCLEdBQUUsQ0FBQyxDQUFDLHNCQUFzQjtBQUU3RCxRQUFRLENBQUMscUNBQXFDLEVBQUUsR0FBRyxF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QkFBZ0IsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsb0JBQW9CLENBQUMsU0FBUyxFQUFFLGdCQUFnQixFQUFFO1lBQ25FLGFBQWEsRUFBRSxJQUFJO1lBQ25CLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGVBQWUsRUFBRSxHQUFHO1lBQ3BCLGNBQWMsRUFBRSxNQUFNO1lBQ3RCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgbG9nZ2VyID0ge1xuICBkZWJ1ZzogamVzdC5mbigpLFxuICBsb2c6IGplc3QuZm4oKSxcbn07XG5cbi8vIHRyeWluZyB0byBtb2NrIGNyZWF0ZUxvZ2dlciB0byByZXR1cm4gYSBzcGVjaWZpYyBsb2dnZXIgaW5zdGFuY2Vcbmplc3QubW9jaygnd2luc3RvbicsICgpID0+ICh7XG4gIGZvcm1hdDoge1xuICAgIGNvbG9yaXplOiBqZXN0LmZuKCksXG4gICAgY29tYmluZTogamVzdC5mbigpLFxuICAgIGxhYmVsOiBqZXN0LmZuKCksXG4gICAgdGltZXN0YW1wOiBqZXN0LmZuKCksXG4gICAgcHJpbnRmOiBqZXN0LmZuKCksXG4gICAgZXJyb3JzOiBqZXN0LmZuKCksXG4gICAganNvbjogamVzdC5mbigpLFxuICAgIHNwbGF0OiBqZXN0LmZuKCksXG4gICAgbWV0YWRhdGE6IGplc3QuZm4oKSxcbiAgfSxcbiAgY3JlYXRlTG9nZ2VyOiBqZXN0LmZuKCkubW9ja1JldHVyblZhbHVlKGxvZ2dlciksXG4gIHRyYW5zcG9ydHM6IHtcbiAgICBDb25zb2xlOiBqZXN0LmZuKCksXG4gIH0sXG59KSk7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQvZmlyc3RcbmltcG9ydCB7IHN0cnVjdHVyZWRMb2dnZXIgfSBmcm9tICcuL3N0cnVjdHVyZWQtbG9nZ2VyJztcblxuY29uc3QgdGVzdExvZ2dlciA9IHN0cnVjdHVyZWRMb2dnZXIoKTsgLy8gaW5pdGlhbGlzaW5nIGxvZ2dlclxuXG5kZXNjcmliZSgnU3RydWN0dXJlZCBsb2dnZXIgc2V0TG9nTGV2ZWwgdGVzdHMnLCAoKSA9PiB7XG4gIHRlc3QoJ3NldCBhIGRlYnVnIGxldmVsJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJ2RlYnVnJyk7XG4gICAgZXhwZWN0KHRlc3RMb2dnZXIubGV2ZWwpLnRvQmUoJ2RlYnVnJyk7XG4gIH0pO1xuICB0ZXN0KCdzZXQgYSBpbmZvIGxldmVsJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJ2luZm8nKTtcbiAgICBleHBlY3QodGVzdExvZ2dlci5sZXZlbCkudG9CZSgnaW5mbycpO1xuICB9KTtcbiAgdGVzdCgnc2V0IGFuIGltcHJvcGVyIGxldmVsKGludmFsaWQgbG9nbGV2ZWwpJywgKCkgPT4ge1xuICAgIHRlc3RMb2dnZXIuc2V0TG9nTGV2ZWwoJzIyJyk7XG4gICAgZXhwZWN0KHRlc3RMb2dnZXIubGV2ZWwpLnRvQmUoJ2Vycm9yJyk7XG4gIH0pO1xuICB0ZXN0KCdzZXQgYW4gaW1wcm9wZXIgbGV2ZWwodW5kZWZpbmVkKScsICgpID0+IHtcbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIHRoaXMgaXMgbm90IHBvc3NpYmxlXG4gICAgdGVzdExvZ2dlci5zZXRMb2dMZXZlbCh1bmRlZmluZWQpO1xuICAgIGV4cGVjdCh0ZXN0TG9nZ2VyLmxldmVsKS50b0JlKCdlcnJvcicpO1xuICB9KTtcbn0pO1xuXG5kZXNjcmliZSgnU3RydWN0dXJlZCBsb2dnaW5nIHRlc3RzJywgKCkgPT4ge1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBlcnJvcncgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgdGVzdExvZ2dlci5lcnJvcncoJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ2Vycm9yJywgJ1NvbWUgZXJyb3InLCB7IGRlc3RpbmF0aW9uSWQ6ICdkMScgfSk7XG4gIH0pO1xuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciBkZWJ1Z3cgZnVuY3Rpb24nLCAoKSA9PiB7XG4gICAgdGVzdExvZ2dlci5kZWJ1Z3coJ1NvbWUgZXJyb3ItMicsIHtcbiAgICAgIGRlc3RpbmF0aW9uSWQ6ICdkMScsXG4gICAgICB3b3Jrc3BhY2VJZDogJ3cxJyxcbiAgICAgIGRlc3RpbmF0aW9uVHlwZTogJ2QnLFxuICAgICAgaW1wbGVtZW50YXRpb246ICdpbXBsJyxcbiAgICAgIG1vZHVsZTogJ21vZCcsXG4gICAgICBzb3VyY2VJZDogJ3MxJyxcbiAgICB9KTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgIGV4cGVjdChsb2dnZXIubG9nKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCgnZGVidWcnLCAnU29tZSBlcnJvci0yJywge1xuICAgICAgZGVzdGluYXRpb25JZDogJ2QxJyxcbiAgICAgIHdvcmtzcGFjZUlkOiAndzEnLFxuICAgICAgZGVzdGluYXRpb25UeXBlOiAnZCcsXG4gICAgICBpbXBsZW1lbnRhdGlvbjogJ2ltcGwnLFxuICAgICAgbW9kdWxlOiAnbW9kJyxcbiAgICAgIHNvdXJjZUlkOiAnczEnLFxuICAgIH0pO1xuICB9KTtcblxuICB0ZXN0KCd0ZXN0aW5nIGxvZ2dlciB3YXJudyBmdW5jdGlvbicsICgpID0+IHtcbiAgICB0ZXN0TG9nZ2VyLndhcm53KHtcbiAgICAgIG1lc3NhZ2U6ICdzb21lIGVycm9yIC0gMycsXG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gICAgZXhwZWN0KGxvZ2dlci5sb2cpLnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICBleHBlY3QobG9nZ2VyLmxvZykudG9IYXZlQmVlbkNhbGxlZFdpdGgoJ3dhcm5pbmcnLCAnc29tZSBlcnJvciAtIDMnLCB7XG4gICAgICBkZXN0aW5hdGlvbklkOiAnZDEnLFxuICAgICAgd29ya3NwYWNlSWQ6ICd3MScsXG4gICAgICBkZXN0aW5hdGlvblR5cGU6ICdkJyxcbiAgICAgIGltcGxlbWVudGF0aW9uOiAnaW1wbCcsXG4gICAgICBtb2R1bGU6ICdtb2QnLFxuICAgICAgc291cmNlSWQ6ICdzMScsXG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
package/build/types.d.ts CHANGED
@@ -278,6 +278,7 @@ export type LoggableExtraData = {
278
278
  implementation: string;
279
279
  sourceId: string;
280
280
  destinationType: string;
281
+ feature?: string;
281
282
  };
282
283
  export {};
283
284
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/build/types.js CHANGED
@@ -25,4 +25,4 @@ var WorkflowType;
25
25
  WorkflowType["STREAM"] = "stream";
26
26
  WorkflowType["RETL"] = "retl";
27
27
  })(WorkflowType || (exports.WorkflowType = WorkflowType = {}));
28
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;;AAAA;;GAEG;AACH,IAAY,WAQX;AARD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,8BAAe,CAAA;IACf,4BAAa,CAAA;IACb,gCAAiB,CAAA;IACjB,8BAAe,CAAA;IACf,8BAAe,CAAA;IACf,6CAA8B,CAAA;AAChC,CAAC,EARW,WAAW,2BAAX,WAAW,QAQtB;AAyOM,MAAM,OAAO,GAAG,CAAC,MAAc,EAAmB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC;AAAvE,QAAA,OAAO,WAAgE;AAE7E,MAAM,WAAW,GAAG,CAAC,MAAc,EAAsB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,CAAC;AAAlF,QAAA,WAAW,eAAuE;AAExF,MAAM,SAAS,GAAG,CAAC,MAAc,EAAqB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,CAAC;AAA7E,QAAA,SAAS,aAAoE;AA6C1F,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,iCAAiB,CAAA;IACjB,6BAAa,CAAA;AACf,CAAC,EAHW,YAAY,4BAAZ,YAAY,QAGvB","sourcesContent":["/**\n * declare types of events for rudderstack\n */\nexport enum MessageType {\n  IDENTIFY = 'identify',\n  TRACK = 'track',\n  PAGE = 'page',\n  SCREEN = 'screen',\n  GROUP = 'group',\n  ALIAS = 'alias',\n  AUDIENCE_LIST = 'audiencelist',\n}\n\ntype ExclusiveProperties<T, U> = T extends undefined ? U : U extends undefined ? T : never;\n\nexport type ExternalId = {\n  identifierType?: string;\n  id: unknown;\n  type: string;\n};\n\n/**\n * define the context of the event\n * @see https://www.rudderstack.com/docs/event-spec/standard-events/common-fields/#contextual-fields\n */\ntype Context = {\n  app: {\n    name: string;\n    version: string;\n    build: string;\n    namespace: string;\n  };\n  campaign: {\n    name?: string;\n    source?: string;\n    medium?: string;\n    term?: string;\n    content?: string;\n  };\n  device: {\n    id?: string;\n    manufacturer?: string;\n    model?: string;\n    name?: string;\n    type?: string;\n    version?: string;\n    token?: string;\n    advertisingId?: string;\n    adTrackingEnabled?: boolean;\n    attTrackingStatus?: string;\n  };\n  library: {\n    name: string;\n    version: string;\n  };\n  locale: string;\n  network: {\n    bluetooth?: string;\n    carrier?: string;\n    cellular?: string;\n    wifi?: string;\n  };\n  os: {\n    name?: string;\n    version?: string;\n  };\n  screen: {\n    density: number;\n    width: number;\n    height: number;\n    innerWidth?: number;\n    innerHeight?: number;\n  };\n  timezone?: string;\n  traits?: Record<string, unknown>;\n  userAgent?: string;\n  ip?: string;\n  mappedToDestination?: boolean;\n  page: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n  };\n  location?: {\n    city?: string;\n    country?: string;\n    latitude?: number;\n    longitude?: number;\n    timezone?: string;\n    geoSource?: string;\n  };\n  externalId?: ExternalId[];\n};\n\n/**\n * a loose definition of rudderstack event without considering\n * the exclusivity of userId and anonymousId\n */\ntype LooseRudderStackEvent = {\n  channel: string;\n  context: Context;\n  type: MessageType;\n  originalTimestamp: string;\n  sentAt: string;\n  traits?: Record<string, unknown>;\n  event?: string;\n  integrations?: Record<string, unknown>;\n  messageId?: string;\n  properties?: Record<string, unknown>;\n  receivedAt?: string;\n  timestamp?: string;\n  userId?: string;\n  anonymousId?: string;\n  request_ip?: string;\n};\n\n/**\n * a strict definition of rudderstack event\n * @see https://www.rudderstack.com/docs/event-spec/standard-events/common-fields/#contextual-fields\n */\nexport type RudderStackEvent = LooseRudderStackEvent & {\n  anonymousId?: ExclusiveProperties<LooseRudderStackEvent['anonymousId'], undefined>;\n  userId?: ExclusiveProperties<LooseRudderStackEvent['userId'], undefined>;\n};\n\nexport type RudderStackEventPayload = { message: RudderStackEvent };\n\n/**\n * define metadata of the event used by rs-server\n */\nexport type Metadata = {\n  sourceId: string;\n  workspaceId: string;\n  namespace: string;\n  instanceId: string;\n  sourceType: string;\n  sourceCategory: string;\n  trackingPlanId: string;\n  trackingPlanVersion: number;\n  sourceTpConfig: Object;\n  mergedTpConfig: Object;\n  destinationId: string;\n  jobRunId: string;\n  jobId: number;\n  sourceBatchId: string;\n  sourceJobId: string;\n  sourceJobRunId: string;\n  sourceTaskId: string;\n  sourceTaskRunId: string;\n  recordId: Object;\n  destinationType: string;\n  messageId: string;\n  oauthAccessToken: string;\n  messageIds: string[];\n  rudderId: string;\n  receivedAt: string;\n  eventName: string;\n  eventType: string;\n  sourceDefinitionId: string;\n  destinationDefinitionId: string;\n  transformationId: string;\n};\n\n/**\n * define the transformation version\n */\ntype UserTransformationVersion = {\n  VersionID: string;\n  ID: string;\n  Config: Object;\n};\n\n/**\n * define the destination definition\n */\nexport type DestinationDefinition = {\n  ID: string;\n  Name: string;\n  DisplayName: string;\n  Config: Object;\n};\n\n/**\n * define the destination object\n */\nexport type Destination = {\n  ID: string;\n  Name: string;\n  DestinationDefinition: DestinationDefinition;\n  Config: Object;\n  Enabled: boolean;\n  WorkspaceID: string;\n  Transformations?: UserTransformationVersion[];\n  RevisionID?: string;\n  IsProcessorEnabled: boolean;\n};\n\nexport type Payload = any;\nexport type Output = any;\n\n// All plugin related types start here\n\nexport type PluginType = 'process' | 'batch' | 'multiplex';\nexport type PluginImplementation = 'js' | 'template';\n\nexport interface Plugin {\n  type: PluginType;\n  implentation: PluginImplementation;\n  apply(\n    event: Payload | Payload[],\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output | Output[];\n}\n\nexport interface Muliplex extends Plugin {\n  apply(\n    event: Payload,\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output[];\n}\n\nexport interface Batch extends Plugin {\n  apply(\n    event: Payload[],\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output[];\n}\n\nexport interface Process extends Plugin {\n  apply(\n    event: Payload,\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output;\n}\n\nexport const isBatch = (plugin: Plugin): plugin is Batch => plugin.type === 'batch';\n\nexport const isMultiplex = (plugin: Plugin): plugin is Muliplex => plugin.type === 'multiplex';\n\nexport const isProcess = (plugin: Plugin): plugin is Process => plugin.type === 'process';\n\nexport type DeliveryResponse = {\n  statusCode: number;\n  message: string;\n  destinationResponse: Object;\n  statTags: Object;\n  authErrorCategory?: string;\n};\nexport type RegulationResponse = {\n  statusCode: number;\n  error?: string;\n  status?: string;\n  authErrorCategory?: string;\n  statTags: Object;\n};\n\n// All plugin related types end here\n\nexport interface Integration {\n  getName(): string;\n  execute(\n    inputsData: { event: RudderStackEventPayload[]; metadata: Metadata[] }[],\n    destination: Destination,\n  ): Promise<{\n    resultContext: {\n      payload: Payload[];\n      metadata: Metadata[];\n    }[];\n    errorResults: {\n      error: any;\n      metadata: Metadata[];\n    }[];\n  }>;\n}\n\nexport type IntegrationConfig = {\n  name: string;\n  saveResponse: boolean;\n  eventOrdering: boolean;\n  plugins: string[];\n};\n\nexport type JSONValue = string | number | boolean | { [x: string]: JSONValue } | Array<JSONValue>;\n\nexport enum WorkflowType {\n  STREAM = 'stream',\n  RETL = 'retl',\n}\n\nexport type LoggableExtraData = {\n  destinationId: string;\n  workspaceId: string;\n  module: string;\n  implementation: string;\n  sourceId: string;\n  destinationType: string;\n};\n"]}
28
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;;AAAA;;GAEG;AACH,IAAY,WAQX;AARD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,8BAAe,CAAA;IACf,4BAAa,CAAA;IACb,gCAAiB,CAAA;IACjB,8BAAe,CAAA;IACf,8BAAe,CAAA;IACf,6CAA8B,CAAA;AAChC,CAAC,EARW,WAAW,2BAAX,WAAW,QAQtB;AAyOM,MAAM,OAAO,GAAG,CAAC,MAAc,EAAmB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC;AAAvE,QAAA,OAAO,WAAgE;AAE7E,MAAM,WAAW,GAAG,CAAC,MAAc,EAAsB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,CAAC;AAAlF,QAAA,WAAW,eAAuE;AAExF,MAAM,SAAS,GAAG,CAAC,MAAc,EAAqB,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,CAAC;AAA7E,QAAA,SAAS,aAAoE;AA6C1F,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,iCAAiB,CAAA;IACjB,6BAAa,CAAA;AACf,CAAC,EAHW,YAAY,4BAAZ,YAAY,QAGvB","sourcesContent":["/**\n * declare types of events for rudderstack\n */\nexport enum MessageType {\n  IDENTIFY = 'identify',\n  TRACK = 'track',\n  PAGE = 'page',\n  SCREEN = 'screen',\n  GROUP = 'group',\n  ALIAS = 'alias',\n  AUDIENCE_LIST = 'audiencelist',\n}\n\ntype ExclusiveProperties<T, U> = T extends undefined ? U : U extends undefined ? T : never;\n\nexport type ExternalId = {\n  identifierType?: string;\n  id: unknown;\n  type: string;\n};\n\n/**\n * define the context of the event\n * @see https://www.rudderstack.com/docs/event-spec/standard-events/common-fields/#contextual-fields\n */\ntype Context = {\n  app: {\n    name: string;\n    version: string;\n    build: string;\n    namespace: string;\n  };\n  campaign: {\n    name?: string;\n    source?: string;\n    medium?: string;\n    term?: string;\n    content?: string;\n  };\n  device: {\n    id?: string;\n    manufacturer?: string;\n    model?: string;\n    name?: string;\n    type?: string;\n    version?: string;\n    token?: string;\n    advertisingId?: string;\n    adTrackingEnabled?: boolean;\n    attTrackingStatus?: string;\n  };\n  library: {\n    name: string;\n    version: string;\n  };\n  locale: string;\n  network: {\n    bluetooth?: string;\n    carrier?: string;\n    cellular?: string;\n    wifi?: string;\n  };\n  os: {\n    name?: string;\n    version?: string;\n  };\n  screen: {\n    density: number;\n    width: number;\n    height: number;\n    innerWidth?: number;\n    innerHeight?: number;\n  };\n  timezone?: string;\n  traits?: Record<string, unknown>;\n  userAgent?: string;\n  ip?: string;\n  mappedToDestination?: boolean;\n  page: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n  };\n  location?: {\n    city?: string;\n    country?: string;\n    latitude?: number;\n    longitude?: number;\n    timezone?: string;\n    geoSource?: string;\n  };\n  externalId?: ExternalId[];\n};\n\n/**\n * a loose definition of rudderstack event without considering\n * the exclusivity of userId and anonymousId\n */\ntype LooseRudderStackEvent = {\n  channel: string;\n  context: Context;\n  type: MessageType;\n  originalTimestamp: string;\n  sentAt: string;\n  traits?: Record<string, unknown>;\n  event?: string;\n  integrations?: Record<string, unknown>;\n  messageId?: string;\n  properties?: Record<string, unknown>;\n  receivedAt?: string;\n  timestamp?: string;\n  userId?: string;\n  anonymousId?: string;\n  request_ip?: string;\n};\n\n/**\n * a strict definition of rudderstack event\n * @see https://www.rudderstack.com/docs/event-spec/standard-events/common-fields/#contextual-fields\n */\nexport type RudderStackEvent = LooseRudderStackEvent & {\n  anonymousId?: ExclusiveProperties<LooseRudderStackEvent['anonymousId'], undefined>;\n  userId?: ExclusiveProperties<LooseRudderStackEvent['userId'], undefined>;\n};\n\nexport type RudderStackEventPayload = { message: RudderStackEvent };\n\n/**\n * define metadata of the event used by rs-server\n */\nexport type Metadata = {\n  sourceId: string;\n  workspaceId: string;\n  namespace: string;\n  instanceId: string;\n  sourceType: string;\n  sourceCategory: string;\n  trackingPlanId: string;\n  trackingPlanVersion: number;\n  sourceTpConfig: Object;\n  mergedTpConfig: Object;\n  destinationId: string;\n  jobRunId: string;\n  jobId: number;\n  sourceBatchId: string;\n  sourceJobId: string;\n  sourceJobRunId: string;\n  sourceTaskId: string;\n  sourceTaskRunId: string;\n  recordId: Object;\n  destinationType: string;\n  messageId: string;\n  oauthAccessToken: string;\n  messageIds: string[];\n  rudderId: string;\n  receivedAt: string;\n  eventName: string;\n  eventType: string;\n  sourceDefinitionId: string;\n  destinationDefinitionId: string;\n  transformationId: string;\n};\n\n/**\n * define the transformation version\n */\ntype UserTransformationVersion = {\n  VersionID: string;\n  ID: string;\n  Config: Object;\n};\n\n/**\n * define the destination definition\n */\nexport type DestinationDefinition = {\n  ID: string;\n  Name: string;\n  DisplayName: string;\n  Config: Object;\n};\n\n/**\n * define the destination object\n */\nexport type Destination = {\n  ID: string;\n  Name: string;\n  DestinationDefinition: DestinationDefinition;\n  Config: Object;\n  Enabled: boolean;\n  WorkspaceID: string;\n  Transformations?: UserTransformationVersion[];\n  RevisionID?: string;\n  IsProcessorEnabled: boolean;\n};\n\nexport type Payload = any;\nexport type Output = any;\n\n// All plugin related types start here\n\nexport type PluginType = 'process' | 'batch' | 'multiplex';\nexport type PluginImplementation = 'js' | 'template';\n\nexport interface Plugin {\n  type: PluginType;\n  implentation: PluginImplementation;\n  apply(\n    event: Payload | Payload[],\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output | Output[];\n}\n\nexport interface Muliplex extends Plugin {\n  apply(\n    event: Payload,\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output[];\n}\n\nexport interface Batch extends Plugin {\n  apply(\n    event: Payload[],\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output[];\n}\n\nexport interface Process extends Plugin {\n  apply(\n    event: Payload,\n    destination: Destination,\n    state: { store: Map<string, any>; skipNext: boolean; exit: boolean },\n  ): Output;\n}\n\nexport const isBatch = (plugin: Plugin): plugin is Batch => plugin.type === 'batch';\n\nexport const isMultiplex = (plugin: Plugin): plugin is Muliplex => plugin.type === 'multiplex';\n\nexport const isProcess = (plugin: Plugin): plugin is Process => plugin.type === 'process';\n\nexport type DeliveryResponse = {\n  statusCode: number;\n  message: string;\n  destinationResponse: Object;\n  statTags: Object;\n  authErrorCategory?: string;\n};\nexport type RegulationResponse = {\n  statusCode: number;\n  error?: string;\n  status?: string;\n  authErrorCategory?: string;\n  statTags: Object;\n};\n\n// All plugin related types end here\n\nexport interface Integration {\n  getName(): string;\n  execute(\n    inputsData: { event: RudderStackEventPayload[]; metadata: Metadata[] }[],\n    destination: Destination,\n  ): Promise<{\n    resultContext: {\n      payload: Payload[];\n      metadata: Metadata[];\n    }[];\n    errorResults: {\n      error: any;\n      metadata: Metadata[];\n    }[];\n  }>;\n}\n\nexport type IntegrationConfig = {\n  name: string;\n  saveResponse: boolean;\n  eventOrdering: boolean;\n  plugins: string[];\n};\n\nexport type JSONValue = string | number | boolean | { [x: string]: JSONValue } | Array<JSONValue>;\n\nexport enum WorkflowType {\n  STREAM = 'stream',\n  RETL = 'retl',\n}\n\nexport type LoggableExtraData = {\n  destinationId: string;\n  workspaceId: string;\n  module: string;\n  implementation: string;\n  sourceId: string;\n  destinationType: string;\n  feature?: string;\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rudderstack/integrations-lib",
3
- "version": "0.2.7",
3
+ "version": "0.2.9",
4
4
  "description": "",
5
5
  "main": "build/index.js",
6
6
  "module": "build/index.js",