@xpr/nestjs-slack 0.2.0 → 0.4.0

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xpr/nestjs-slack",
3
- "version": "0.2.0",
3
+ "version": "0.4.0",
4
4
  "description": "NestJS server implementation of the Slack Assistant",
5
5
  "main": "index.js",
6
6
  "scripts": {
package/slack.js CHANGED
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const microservices_1 = require("@nestjs/microservices");
4
4
  const bolt_1 = require("@slack/bolt");
5
5
  const decorators_1 = require("./decorators");
6
+ const utils_1 = require("./utils");
6
7
  class Slack extends microservices_1.Server {
7
8
  options;
8
9
  #app;
@@ -55,6 +56,10 @@ class Slack extends microservices_1.Server {
55
56
  */
56
57
  app() {
57
58
  if (!this.#app) {
59
+ // make sure to add logger if not provided
60
+ if (!this.options.slack.logger) {
61
+ this.options.slack.logger = (0, utils_1.adjustLogger)(this.logger);
62
+ }
58
63
  this.#app = new bolt_1.App(this.options.slack);
59
64
  this.logger.log("Bolt app created");
60
65
  }
package/utils.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ import { type Logger } from "@slack/bolt";
1
2
  export type Pattern = string | RegExp;
2
3
  /**
3
4
  * Create method decorator
@@ -11,3 +12,4 @@ export declare function eventDecorator<T>(type: string, event: T): MethodDecorat
11
12
  * @param pattern how to identify the message
12
13
  */
13
14
  export declare function messageDecorator(type: string, pattern: Pattern): MethodDecorator;
15
+ export declare function adjustLogger(logger: any): Logger;
package/utils.js CHANGED
@@ -2,7 +2,9 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.eventDecorator = eventDecorator;
4
4
  exports.messageDecorator = messageDecorator;
5
+ exports.adjustLogger = adjustLogger;
5
6
  const microservices_1 = require("@nestjs/microservices");
7
+ const bolt_1 = require("@slack/bolt");
6
8
  const normalizePattern = (pattern) => {
7
9
  if (typeof pattern === "string") {
8
10
  return pattern;
@@ -34,3 +36,27 @@ function messageDecorator(type, pattern) {
34
36
  pattern,
35
37
  })(target, key, descriptor);
36
38
  }
39
+ function adjustLogger(logger) {
40
+ // minimal logger interface required by the library
41
+ for (const method of ["debug", "info", "warn", "error"]) {
42
+ if (typeof logger[method] !== "function") {
43
+ throw new Error(`Logger must implement "${method}" method`);
44
+ }
45
+ }
46
+ const noop = () => {
47
+ };
48
+ return Object.assign(logger, {
49
+ setLevel(_) {
50
+ // don't allow library to set the level
51
+ },
52
+ setName(name) {
53
+ // setContext is alias for setName
54
+ (logger.setName ?? logger.setContext ?? noop)(name);
55
+ },
56
+ getLevel() {
57
+ // always return the lowest supported level (by library, not real logger)
58
+ // to avoid filtering log messages by library instead of real logger
59
+ return bolt_1.LogLevel.DEBUG;
60
+ },
61
+ });
62
+ }