@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 +1 -1
- package/slack.js +5 -0
- package/utils.d.ts +2 -0
- package/utils.js +26 -0
package/package.json
CHANGED
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
|
+
}
|