nightingale-slack 15.0.0 → 16.1.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/CHANGELOG.md +19 -0
- package/README.md +6 -6
- package/dist/definitions/createBody.d.ts +2 -2
- package/dist/definitions/createBody.d.ts.map +1 -1
- package/dist/definitions/index.d.ts +4 -4
- package/dist/definitions/index.d.ts.map +1 -1
- package/dist/{index-node18.mjs → index-node20.mjs} +17 -17
- package/dist/index-node20.mjs.map +1 -0
- package/package.json +19 -20
- package/src/createBody.test.ts +19 -19
- package/src/createBody.ts +14 -16
- package/src/index.ts +11 -10
- package/dist/index-node18.mjs.map +0 -1
- package/src/.eslintrc.json +0 -30
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,25 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [16.1.0](https://github.com/christophehurpeau/nightingale/compare/v16.0.0...v16.1.0) (2025-03-30)
|
|
7
|
+
|
|
8
|
+
Version bump for dependency: nightingale
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
## [16.0.0](https://github.com/christophehurpeau/nightingale/compare/v15.0.0...v16.0.0) (2025-03-30)
|
|
12
|
+
|
|
13
|
+
### ⚠ BREAKING CHANGES
|
|
14
|
+
|
|
15
|
+
* drop node 18
|
|
16
|
+
|
|
17
|
+
### Features
|
|
18
|
+
|
|
19
|
+
* drop node 18 ([1b11a55](https://github.com/christophehurpeau/nightingale/commit/1b11a55dd24c9435be50519a748316079f554414))
|
|
20
|
+
|
|
21
|
+
Version bump for dependency: nightingale
|
|
22
|
+
Version bump for dependency: nightingale-types
|
|
23
|
+
|
|
24
|
+
|
|
6
25
|
## [15.0.0](https://github.com/christophehurpeau/nightingale/compare/v14.2.1...v15.0.0) (2023-12-25)
|
|
7
26
|
|
|
8
27
|
|
package/README.md
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
<
|
|
1
|
+
<h1 align="center">
|
|
2
2
|
nightingale-slack
|
|
3
|
-
</
|
|
3
|
+
</h1>
|
|
4
4
|
|
|
5
5
|
<p align="center">
|
|
6
6
|
Slack handler for nightingale
|
|
7
7
|
</p>
|
|
8
8
|
|
|
9
9
|
<p align="center">
|
|
10
|
-
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/v/nightingale-slack.svg?style=flat-square"></a>
|
|
11
|
-
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/dw/nightingale-slack.svg?style=flat-square"></a>
|
|
12
|
-
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/node/v/nightingale-slack.svg?style=flat-square"></a>
|
|
13
|
-
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/types/nightingale-slack.svg?style=flat-square"></a>
|
|
10
|
+
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/v/nightingale-slack.svg?style=flat-square" alt="npm version"></a>
|
|
11
|
+
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/dw/nightingale-slack.svg?style=flat-square" alt="npm downloads"></a>
|
|
12
|
+
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/node/v/nightingale-slack.svg?style=flat-square" alt="node version"></a>
|
|
13
|
+
<a href="https://npmjs.org/package/nightingale-slack"><img src="https://img.shields.io/npm/types/nightingale-slack.svg?style=flat-square" alt="types"></a>
|
|
14
14
|
<a href="https://codecov.io/gh/christophehurpeau/nightingale"><img src="https://img.shields.io/codecov/c/github/christophehurpeau/nightingale/master.svg?style=flat-square"></a>
|
|
15
15
|
</p>
|
|
16
16
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { LogRecord, Metadata } from
|
|
2
|
-
import type { SlackConfig } from
|
|
1
|
+
import type { LogRecord, Metadata } from "nightingale-types";
|
|
2
|
+
import type { SlackConfig } from "./SlackConfig";
|
|
3
3
|
export default function createBody<T extends Metadata>(record: LogRecord<T>, slackConfig: SlackConfig): Record<string, unknown>;
|
|
4
4
|
//# sourceMappingURL=createBody.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createBody.d.ts","sourceRoot":"","sources":["../../src/createBody.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"createBody.d.ts","sourceRoot":"","sources":["../../src/createBody.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAajD,MAAM,CAAC,OAAO,UAAU,UAAU,CAAC,CAAC,SAAS,QAAQ,EACnD,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EACpB,WAAW,EAAE,WAAW,GACvB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAmBzB"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { Handle, Handler, Level } from
|
|
2
|
-
import type { SlackConfig } from
|
|
3
|
-
export type { SlackConfig } from
|
|
4
|
-
export { default as createBody } from
|
|
1
|
+
import type { Handle, Handler, Level } from "nightingale-types";
|
|
2
|
+
import type { SlackConfig } from "./SlackConfig";
|
|
3
|
+
export type { SlackConfig } from "./SlackConfig";
|
|
4
|
+
export { default as createBody } from "./createBody";
|
|
5
5
|
export declare class SlackHandler implements Handler {
|
|
6
6
|
minLevel: Level;
|
|
7
7
|
handle: Handle;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,OAAO,EACP,KAAK,EAGN,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAGjD,YAAY,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAEjD,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AAgBrD,qBAAa,YAAa,YAAW,OAAO;IAC1C,QAAQ,EAAE,KAAK,CAAC;IAEhB,MAAM,EAAE,MAAM,CAAC;gBAEH,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK;CAItD"}
|
|
@@ -1,21 +1,19 @@
|
|
|
1
|
-
import { Level } from 'nightingale
|
|
2
|
-
import markdownFormatter from 'nightingale-markdown-formatter';
|
|
3
|
-
import rawFormatter from 'nightingale-raw-formatter';
|
|
1
|
+
import { MarkdownFormatter, RawFormatter, Level } from 'nightingale';
|
|
4
2
|
|
|
5
3
|
/* eslint-disable camelcase */
|
|
6
4
|
const levelToSlackColor = {
|
|
7
|
-
[Level.TRACE]:
|
|
8
|
-
[Level.DEBUG]:
|
|
9
|
-
[Level.INFO]:
|
|
10
|
-
[Level.WARN]:
|
|
11
|
-
[Level.ERROR]:
|
|
12
|
-
[Level.CRITICAL]:
|
|
13
|
-
[Level.FATAL]:
|
|
14
|
-
[Level.EMERGENCY]:
|
|
5
|
+
[Level.TRACE]: "#808080",
|
|
6
|
+
[Level.DEBUG]: "#808080",
|
|
7
|
+
[Level.INFO]: "#808080",
|
|
8
|
+
[Level.WARN]: "warning",
|
|
9
|
+
[Level.ERROR]: "danger",
|
|
10
|
+
[Level.CRITICAL]: "danger",
|
|
11
|
+
[Level.FATAL]: "danger",
|
|
12
|
+
[Level.EMERGENCY]: "danger"
|
|
15
13
|
};
|
|
16
14
|
function createBody(record, slackConfig) {
|
|
17
|
-
const markdown =
|
|
18
|
-
const raw =
|
|
15
|
+
const markdown = MarkdownFormatter.format(record);
|
|
16
|
+
const raw = RawFormatter.format(record);
|
|
19
17
|
return {
|
|
20
18
|
channel: slackConfig.channel,
|
|
21
19
|
username: slackConfig.username,
|
|
@@ -26,18 +24,20 @@ function createBody(record, slackConfig) {
|
|
|
26
24
|
title: record.message,
|
|
27
25
|
color: levelToSlackColor[record.level],
|
|
28
26
|
text: markdown,
|
|
29
|
-
mrkdwn_in: [
|
|
27
|
+
mrkdwn_in: ["text"]
|
|
30
28
|
}]
|
|
31
29
|
};
|
|
32
30
|
}
|
|
33
31
|
|
|
34
32
|
const createHandler = slackConfig => record => {
|
|
35
33
|
const body = createBody(record, slackConfig);
|
|
34
|
+
|
|
35
|
+
// eslint-disable-next-line n/no-unsupported-features/node-builtins
|
|
36
36
|
fetch(slackConfig.webhookUrl, {
|
|
37
|
-
method:
|
|
37
|
+
method: "POST",
|
|
38
38
|
body: JSON.stringify(body)
|
|
39
39
|
}).catch(error => {
|
|
40
|
-
console.error(error
|
|
40
|
+
console.error(error);
|
|
41
41
|
});
|
|
42
42
|
};
|
|
43
43
|
class SlackHandler {
|
|
@@ -48,4 +48,4 @@ class SlackHandler {
|
|
|
48
48
|
}
|
|
49
49
|
|
|
50
50
|
export { SlackHandler, createBody };
|
|
51
|
-
//# sourceMappingURL=index-
|
|
51
|
+
//# sourceMappingURL=index-node20.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-node20.mjs","sources":["../src/createBody.ts","../src/index.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport { Level, MarkdownFormatter, RawFormatter } from \"nightingale\";\nimport type { LogRecord, Metadata } from \"nightingale-types\";\nimport type { SlackConfig } from \"./SlackConfig\";\n\nconst levelToSlackColor: Record<number, string> = {\n [Level.TRACE]: \"#808080\",\n [Level.DEBUG]: \"#808080\",\n [Level.INFO]: \"#808080\",\n [Level.WARN]: \"warning\",\n [Level.ERROR]: \"danger\",\n [Level.CRITICAL]: \"danger\",\n [Level.FATAL]: \"danger\",\n [Level.EMERGENCY]: \"danger\",\n};\n\nexport default function createBody<T extends Metadata>(\n record: LogRecord<T>,\n slackConfig: SlackConfig,\n): Record<string, unknown> {\n const markdown = MarkdownFormatter.format(record);\n const raw = RawFormatter.format(record);\n\n return {\n channel: slackConfig.channel,\n username: slackConfig.username,\n icon_url: slackConfig.iconUrl,\n icon_emoji: slackConfig.iconEmoji,\n attachments: [\n {\n fallback: raw,\n title: record.message,\n color: levelToSlackColor[record.level],\n text: markdown,\n mrkdwn_in: [\"text\"],\n },\n ],\n };\n}\n","import type {\n Handle,\n Handler,\n Level,\n LogRecord,\n Metadata,\n} from \"nightingale-types\";\nimport type { SlackConfig } from \"./SlackConfig\";\nimport createBody from \"./createBody\";\n\nexport type { SlackConfig } from \"./SlackConfig\";\n\nexport { default as createBody } from \"./createBody\";\n\nconst createHandler =\n (slackConfig: SlackConfig) =>\n <T extends Metadata>(record: LogRecord<T>) => {\n const body = createBody(record, slackConfig);\n\n // eslint-disable-next-line n/no-unsupported-features/node-builtins\n fetch(slackConfig.webhookUrl, {\n method: \"POST\",\n body: JSON.stringify(body),\n }).catch((error: unknown) => {\n console.error(error);\n });\n };\n\nexport class SlackHandler implements Handler {\n minLevel: Level;\n\n handle: Handle;\n\n constructor(slackConfig: SlackConfig, minLevel: Level) {\n this.minLevel = minLevel;\n this.handle = createHandler(slackConfig);\n }\n}\n"],"names":["levelToSlackColor","Level","TRACE","DEBUG","INFO","WARN","ERROR","CRITICAL","FATAL","EMERGENCY","createBody","record","slackConfig","markdown","MarkdownFormatter","format","raw","RawFormatter","channel","username","icon_url","iconUrl","icon_emoji","iconEmoji","attachments","fallback","title","message","color","level","text","mrkdwn_in","createHandler","body","fetch","webhookUrl","method","JSON","stringify","catch","error","console","SlackHandler","constructor","minLevel","handle"],"mappings":";;AAAA;AAKA,MAAMA,iBAAyC,GAAG;AAChD,EAAA,CAACC,KAAK,CAACC,KAAK,GAAG,SAAS;AACxB,EAAA,CAACD,KAAK,CAACE,KAAK,GAAG,SAAS;AACxB,EAAA,CAACF,KAAK,CAACG,IAAI,GAAG,SAAS;AACvB,EAAA,CAACH,KAAK,CAACI,IAAI,GAAG,SAAS;AACvB,EAAA,CAACJ,KAAK,CAACK,KAAK,GAAG,QAAQ;AACvB,EAAA,CAACL,KAAK,CAACM,QAAQ,GAAG,QAAQ;AAC1B,EAAA,CAACN,KAAK,CAACO,KAAK,GAAG,QAAQ;EACvB,CAACP,KAAK,CAACQ,SAAS,GAAG;AACrB,CAAC;AAEc,SAASC,UAAUA,CAChCC,MAAoB,EACpBC,WAAwB,EACC;AACzB,EAAA,MAAMC,QAAQ,GAAGC,iBAAiB,CAACC,MAAM,CAACJ,MAAM,CAAC;AACjD,EAAA,MAAMK,GAAG,GAAGC,YAAY,CAACF,MAAM,CAACJ,MAAM,CAAC;EAEvC,OAAO;IACLO,OAAO,EAAEN,WAAW,CAACM,OAAO;IAC5BC,QAAQ,EAAEP,WAAW,CAACO,QAAQ;IAC9BC,QAAQ,EAAER,WAAW,CAACS,OAAO;IAC7BC,UAAU,EAAEV,WAAW,CAACW,SAAS;AACjCC,IAAAA,WAAW,EAAE,CACX;AACEC,MAAAA,QAAQ,EAAET,GAAG;MACbU,KAAK,EAAEf,MAAM,CAACgB,OAAO;AACrBC,MAAAA,KAAK,EAAE5B,iBAAiB,CAACW,MAAM,CAACkB,KAAK,CAAC;AACtCC,MAAAA,IAAI,EAAEjB,QAAQ;MACdkB,SAAS,EAAE,CAAC,MAAM;KACnB;GAEJ;AACH;;ACxBA,MAAMC,aAAa,GAChBpB,WAAwB,IACJD,MAAoB,IAAK;AAC5C,EAAA,MAAMsB,IAAI,GAAGvB,UAAU,CAACC,MAAM,EAAEC,WAAW,CAAC;;AAE5C;AACAsB,EAAAA,KAAK,CAACtB,WAAW,CAACuB,UAAU,EAAE;AAC5BC,IAAAA,MAAM,EAAE,MAAM;AACdH,IAAAA,IAAI,EAAEI,IAAI,CAACC,SAAS,CAACL,IAAI;AAC3B,GAAC,CAAC,CAACM,KAAK,CAAEC,KAAc,IAAK;AAC3BC,IAAAA,OAAO,CAACD,KAAK,CAACA,KAAK,CAAC;AACtB,GAAC,CAAC;AACJ,CAAC;AAEI,MAAME,YAAY,CAAoB;AAK3CC,EAAAA,WAAWA,CAAC/B,WAAwB,EAAEgC,QAAe,EAAE;IACrD,IAAI,CAACA,QAAQ,GAAGA,QAAQ;AACxB,IAAA,IAAI,CAACC,MAAM,GAAGb,aAAa,CAACpB,WAAW,CAAC;AAC1C;AACF;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nightingale-slack",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "16.1.0",
|
|
4
4
|
"description": "Slack handler for nightingale",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"nightingale",
|
|
@@ -16,20 +16,20 @@
|
|
|
16
16
|
"homepage": "https://github.com/christophehurpeau/nightingale",
|
|
17
17
|
"type": "module",
|
|
18
18
|
"engines": {
|
|
19
|
-
"node": ">=
|
|
19
|
+
"node": ">=20.9.0"
|
|
20
20
|
},
|
|
21
|
-
"
|
|
21
|
+
"sideEffects": false,
|
|
22
|
+
"main": "./dist/index-node20.mjs",
|
|
22
23
|
"types": "./dist/definitions/index.d.ts",
|
|
23
24
|
"exports": {
|
|
24
25
|
"./package.json": "./package.json",
|
|
25
26
|
".": {
|
|
26
27
|
"types": "./dist/definitions/index.d.ts",
|
|
27
28
|
"node": {
|
|
28
|
-
"import": "./dist/index-
|
|
29
|
+
"import": "./dist/index-node20.mjs"
|
|
29
30
|
}
|
|
30
31
|
}
|
|
31
32
|
},
|
|
32
|
-
"sideEffects": false,
|
|
33
33
|
"files": [
|
|
34
34
|
"src",
|
|
35
35
|
"dist"
|
|
@@ -40,32 +40,31 @@
|
|
|
40
40
|
"clean": "yarn clean:build",
|
|
41
41
|
"clean:build": "pob-babel-clean-out dist",
|
|
42
42
|
"lint": "yarn run lint:eslint",
|
|
43
|
-
"lint:eslint": "yarn ../.. run eslint --
|
|
43
|
+
"lint:eslint": "yarn ../.. run eslint --quiet packages/nightingale-slack",
|
|
44
44
|
"test": "yarn ../../ run test -- packages/nightingale-slack",
|
|
45
45
|
"watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
|
|
46
46
|
},
|
|
47
|
-
"prettier": "@pob/root/prettier-config",
|
|
48
47
|
"pob": {
|
|
49
|
-
"
|
|
48
|
+
"bundler": "rollup-babel",
|
|
49
|
+
"entries": [
|
|
50
|
+
"index"
|
|
51
|
+
],
|
|
52
|
+
"envs": [
|
|
50
53
|
{
|
|
51
54
|
"target": "node",
|
|
52
|
-
"version": "
|
|
55
|
+
"version": "20"
|
|
53
56
|
}
|
|
54
|
-
],
|
|
55
|
-
"entries": [
|
|
56
|
-
"index"
|
|
57
57
|
]
|
|
58
58
|
},
|
|
59
|
+
"prettier": "@pob/root/prettier-config",
|
|
59
60
|
"dependencies": {
|
|
60
|
-
"nightingale
|
|
61
|
-
"nightingale-
|
|
62
|
-
"nightingale-raw-formatter": "15.0.0",
|
|
63
|
-
"nightingale-types": "15.0.0"
|
|
61
|
+
"nightingale": "16.1.0",
|
|
62
|
+
"nightingale-types": "16.0.0"
|
|
64
63
|
},
|
|
65
64
|
"devDependencies": {
|
|
66
|
-
"@babel/core": "7.
|
|
67
|
-
"@types/node": "
|
|
68
|
-
"pob-babel": "
|
|
69
|
-
"typescript": "5.
|
|
65
|
+
"@babel/core": "7.26.10",
|
|
66
|
+
"@types/node": "22.13.14",
|
|
67
|
+
"pob-babel": "43.4.0",
|
|
68
|
+
"typescript": "5.8.2"
|
|
70
69
|
}
|
|
71
70
|
}
|
package/src/createBody.test.ts
CHANGED
|
@@ -1,52 +1,52 @@
|
|
|
1
1
|
/* eslint-disable camelcase */
|
|
2
|
-
import { Level } from
|
|
3
|
-
import createBody from
|
|
2
|
+
import { Level } from "nightingale";
|
|
3
|
+
import createBody from "./createBody";
|
|
4
4
|
|
|
5
|
-
const webhookUrl =
|
|
5
|
+
const webhookUrl = "webhookUrl";
|
|
6
6
|
const record = {
|
|
7
|
-
key:
|
|
7
|
+
key: "key",
|
|
8
8
|
datetime: new Date(2010, 1, 1, 1, 1, 1),
|
|
9
9
|
level: Level.INFO,
|
|
10
|
-
message:
|
|
10
|
+
message: "hello",
|
|
11
11
|
metadata: { isMeta1: true },
|
|
12
12
|
};
|
|
13
13
|
|
|
14
|
-
test(
|
|
15
|
-
const testChannel =
|
|
14
|
+
test("keep channel", () => {
|
|
15
|
+
const testChannel = "testChannel";
|
|
16
16
|
expect(createBody(record, { webhookUrl, channel: testChannel }).channel).toBe(
|
|
17
17
|
testChannel,
|
|
18
18
|
);
|
|
19
19
|
});
|
|
20
20
|
|
|
21
|
-
test(
|
|
22
|
-
const testUsername =
|
|
21
|
+
test("keep username", () => {
|
|
22
|
+
const testUsername = "testUsername";
|
|
23
23
|
expect(
|
|
24
24
|
createBody(record, { webhookUrl, username: testUsername }).username,
|
|
25
25
|
).toBe(testUsername);
|
|
26
26
|
});
|
|
27
27
|
|
|
28
|
-
test(
|
|
29
|
-
const testIconUrl =
|
|
28
|
+
test("keep iconUrl", () => {
|
|
29
|
+
const testIconUrl = "testIconUrl";
|
|
30
30
|
expect(
|
|
31
31
|
createBody(record, { webhookUrl, iconUrl: testIconUrl }).icon_url,
|
|
32
32
|
).toBe(testIconUrl);
|
|
33
33
|
});
|
|
34
34
|
|
|
35
|
-
test(
|
|
36
|
-
const testIconEmoji =
|
|
35
|
+
test("keep iconEmoji", () => {
|
|
36
|
+
const testIconEmoji = "testIconEmoji";
|
|
37
37
|
expect(
|
|
38
38
|
createBody(record, { webhookUrl, iconEmoji: testIconEmoji }).icon_emoji,
|
|
39
39
|
).toBe(testIconEmoji);
|
|
40
40
|
});
|
|
41
41
|
|
|
42
|
-
test(
|
|
42
|
+
test("attachments has both raw and markdown", () => {
|
|
43
43
|
expect(createBody(record, { webhookUrl }).attachments).toEqual([
|
|
44
44
|
{
|
|
45
|
-
color:
|
|
46
|
-
fallback:
|
|
47
|
-
mrkdwn_in: [
|
|
48
|
-
text:
|
|
49
|
-
title:
|
|
45
|
+
color: "#808080",
|
|
46
|
+
fallback: "key 01:01:01 → hello { isMeta1: true }",
|
|
47
|
+
mrkdwn_in: ["text"],
|
|
48
|
+
text: "key *01:01:01* → hello { *isMeta1:* true }",
|
|
49
|
+
title: "hello",
|
|
50
50
|
},
|
|
51
51
|
]);
|
|
52
52
|
});
|
package/src/createBody.ts
CHANGED
|
@@ -1,27 +1,25 @@
|
|
|
1
1
|
/* eslint-disable camelcase */
|
|
2
|
-
import { Level } from
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import type { LogRecord, Metadata } from 'nightingale-types';
|
|
6
|
-
import type { SlackConfig } from './SlackConfig';
|
|
2
|
+
import { Level, MarkdownFormatter, RawFormatter } from "nightingale";
|
|
3
|
+
import type { LogRecord, Metadata } from "nightingale-types";
|
|
4
|
+
import type { SlackConfig } from "./SlackConfig";
|
|
7
5
|
|
|
8
6
|
const levelToSlackColor: Record<number, string> = {
|
|
9
|
-
[Level.TRACE]:
|
|
10
|
-
[Level.DEBUG]:
|
|
11
|
-
[Level.INFO]:
|
|
12
|
-
[Level.WARN]:
|
|
13
|
-
[Level.ERROR]:
|
|
14
|
-
[Level.CRITICAL]:
|
|
15
|
-
[Level.FATAL]:
|
|
16
|
-
[Level.EMERGENCY]:
|
|
7
|
+
[Level.TRACE]: "#808080",
|
|
8
|
+
[Level.DEBUG]: "#808080",
|
|
9
|
+
[Level.INFO]: "#808080",
|
|
10
|
+
[Level.WARN]: "warning",
|
|
11
|
+
[Level.ERROR]: "danger",
|
|
12
|
+
[Level.CRITICAL]: "danger",
|
|
13
|
+
[Level.FATAL]: "danger",
|
|
14
|
+
[Level.EMERGENCY]: "danger",
|
|
17
15
|
};
|
|
18
16
|
|
|
19
17
|
export default function createBody<T extends Metadata>(
|
|
20
18
|
record: LogRecord<T>,
|
|
21
19
|
slackConfig: SlackConfig,
|
|
22
20
|
): Record<string, unknown> {
|
|
23
|
-
const markdown =
|
|
24
|
-
const raw =
|
|
21
|
+
const markdown = MarkdownFormatter.format(record);
|
|
22
|
+
const raw = RawFormatter.format(record);
|
|
25
23
|
|
|
26
24
|
return {
|
|
27
25
|
channel: slackConfig.channel,
|
|
@@ -34,7 +32,7 @@ export default function createBody<T extends Metadata>(
|
|
|
34
32
|
title: record.message,
|
|
35
33
|
color: levelToSlackColor[record.level],
|
|
36
34
|
text: markdown,
|
|
37
|
-
mrkdwn_in: [
|
|
35
|
+
mrkdwn_in: ["text"],
|
|
38
36
|
},
|
|
39
37
|
],
|
|
40
38
|
};
|
package/src/index.ts
CHANGED
|
@@ -1,27 +1,28 @@
|
|
|
1
1
|
import type {
|
|
2
|
-
LogRecord,
|
|
3
2
|
Handle,
|
|
4
|
-
Metadata,
|
|
5
3
|
Handler,
|
|
6
4
|
Level,
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
5
|
+
LogRecord,
|
|
6
|
+
Metadata,
|
|
7
|
+
} from "nightingale-types";
|
|
8
|
+
import type { SlackConfig } from "./SlackConfig";
|
|
9
|
+
import createBody from "./createBody";
|
|
10
10
|
|
|
11
|
-
export type { SlackConfig } from
|
|
11
|
+
export type { SlackConfig } from "./SlackConfig";
|
|
12
12
|
|
|
13
|
-
export { default as createBody } from
|
|
13
|
+
export { default as createBody } from "./createBody";
|
|
14
14
|
|
|
15
15
|
const createHandler =
|
|
16
16
|
(slackConfig: SlackConfig) =>
|
|
17
17
|
<T extends Metadata>(record: LogRecord<T>) => {
|
|
18
18
|
const body = createBody(record, slackConfig);
|
|
19
19
|
|
|
20
|
+
// eslint-disable-next-line n/no-unsupported-features/node-builtins
|
|
20
21
|
fetch(slackConfig.webhookUrl, {
|
|
21
|
-
method:
|
|
22
|
+
method: "POST",
|
|
22
23
|
body: JSON.stringify(body),
|
|
23
|
-
}).catch((error:
|
|
24
|
-
console.error(error
|
|
24
|
+
}).catch((error: unknown) => {
|
|
25
|
+
console.error(error);
|
|
25
26
|
});
|
|
26
27
|
};
|
|
27
28
|
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-node18.mjs","sources":["../src/createBody.ts","../src/index.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport { Level } from 'nightingale-levels';\nimport markdownFormatter from 'nightingale-markdown-formatter';\nimport rawFormatter from 'nightingale-raw-formatter';\nimport type { LogRecord, Metadata } from 'nightingale-types';\nimport type { SlackConfig } from './SlackConfig';\n\nconst levelToSlackColor: Record<number, string> = {\n [Level.TRACE]: '#808080',\n [Level.DEBUG]: '#808080',\n [Level.INFO]: '#808080',\n [Level.WARN]: 'warning',\n [Level.ERROR]: 'danger',\n [Level.CRITICAL]: 'danger',\n [Level.FATAL]: 'danger',\n [Level.EMERGENCY]: 'danger',\n};\n\nexport default function createBody<T extends Metadata>(\n record: LogRecord<T>,\n slackConfig: SlackConfig,\n): Record<string, unknown> {\n const markdown = markdownFormatter(record);\n const raw = rawFormatter(record);\n\n return {\n channel: slackConfig.channel,\n username: slackConfig.username,\n icon_url: slackConfig.iconUrl,\n icon_emoji: slackConfig.iconEmoji,\n attachments: [\n {\n fallback: raw,\n title: record.message,\n color: levelToSlackColor[record.level],\n text: markdown,\n mrkdwn_in: ['text'],\n },\n ],\n };\n}\n","import type {\n LogRecord,\n Handle,\n Metadata,\n Handler,\n Level,\n} from 'nightingale-types';\nimport type { SlackConfig } from './SlackConfig';\nimport createBody from './createBody';\n\nexport type { SlackConfig } from './SlackConfig';\n\nexport { default as createBody } from './createBody';\n\nconst createHandler =\n (slackConfig: SlackConfig) =>\n <T extends Metadata>(record: LogRecord<T>) => {\n const body = createBody(record, slackConfig);\n\n fetch(slackConfig.webhookUrl, {\n method: 'POST',\n body: JSON.stringify(body),\n }).catch((error: Error) => {\n console.error(error.stack);\n });\n };\n\nexport class SlackHandler implements Handler {\n minLevel: Level;\n\n handle: Handle;\n\n constructor(slackConfig: SlackConfig, minLevel: Level) {\n this.minLevel = minLevel;\n this.handle = createHandler(slackConfig);\n }\n}\n"],"names":["levelToSlackColor","Level","TRACE","DEBUG","INFO","WARN","ERROR","CRITICAL","FATAL","EMERGENCY","createBody","record","slackConfig","markdown","markdownFormatter","raw","rawFormatter","channel","username","icon_url","iconUrl","icon_emoji","iconEmoji","attachments","fallback","title","message","color","level","text","mrkdwn_in","createHandler","body","fetch","webhookUrl","method","JSON","stringify","catch","error","console","stack","SlackHandler","constructor","minLevel","handle"],"mappings":";;;;AAAA;AAOA,MAAMA,iBAAyC,GAAG;AAChD,EAAA,CAACC,KAAK,CAACC,KAAK,GAAG,SAAS;AACxB,EAAA,CAACD,KAAK,CAACE,KAAK,GAAG,SAAS;AACxB,EAAA,CAACF,KAAK,CAACG,IAAI,GAAG,SAAS;AACvB,EAAA,CAACH,KAAK,CAACI,IAAI,GAAG,SAAS;AACvB,EAAA,CAACJ,KAAK,CAACK,KAAK,GAAG,QAAQ;AACvB,EAAA,CAACL,KAAK,CAACM,QAAQ,GAAG,QAAQ;AAC1B,EAAA,CAACN,KAAK,CAACO,KAAK,GAAG,QAAQ;EACvB,CAACP,KAAK,CAACQ,SAAS,GAAG,QAAA;AACrB,CAAC,CAAA;AAEc,SAASC,UAAUA,CAChCC,MAAoB,EACpBC,WAAwB,EACC;AACzB,EAAA,MAAMC,QAAQ,GAAGC,iBAAiB,CAACH,MAAM,CAAC,CAAA;AAC1C,EAAA,MAAMI,GAAG,GAAGC,YAAY,CAACL,MAAM,CAAC,CAAA;EAEhC,OAAO;IACLM,OAAO,EAAEL,WAAW,CAACK,OAAO;IAC5BC,QAAQ,EAAEN,WAAW,CAACM,QAAQ;IAC9BC,QAAQ,EAAEP,WAAW,CAACQ,OAAO;IAC7BC,UAAU,EAAET,WAAW,CAACU,SAAS;AACjCC,IAAAA,WAAW,EAAE,CACX;AACEC,MAAAA,QAAQ,EAAET,GAAG;MACbU,KAAK,EAAEd,MAAM,CAACe,OAAO;AACrBC,MAAAA,KAAK,EAAE3B,iBAAiB,CAACW,MAAM,CAACiB,KAAK,CAAC;AACtCC,MAAAA,IAAI,EAAEhB,QAAQ;MACdiB,SAAS,EAAE,CAAC,MAAM,CAAA;KACnB,CAAA;GAEJ,CAAA;AACH;;AC1BA,MAAMC,aAAa,GAChBnB,WAAwB,IACJD,MAAoB,IAAK;AAC5C,EAAA,MAAMqB,IAAI,GAAGtB,UAAU,CAACC,MAAM,EAAEC,WAAW,CAAC,CAAA;AAE5CqB,EAAAA,KAAK,CAACrB,WAAW,CAACsB,UAAU,EAAE;AAC5BC,IAAAA,MAAM,EAAE,MAAM;AACdH,IAAAA,IAAI,EAAEI,IAAI,CAACC,SAAS,CAACL,IAAI,CAAA;AAC3B,GAAC,CAAC,CAACM,KAAK,CAAEC,KAAY,IAAK;AACzBC,IAAAA,OAAO,CAACD,KAAK,CAACA,KAAK,CAACE,KAAK,CAAC,CAAA;AAC5B,GAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAEI,MAAMC,YAAY,CAAoB;AAK3CC,EAAAA,WAAWA,CAAC/B,WAAwB,EAAEgC,QAAe,EAAE;IACrD,IAAI,CAACA,QAAQ,GAAGA,QAAQ,CAAA;AACxB,IAAA,IAAI,CAACC,MAAM,GAAGd,aAAa,CAACnB,WAAW,CAAC,CAAA;AAC1C,GAAA;AACF;;;;"}
|
package/src/.eslintrc.json
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"root": true,
|
|
3
|
-
"parser": "@typescript-eslint/parser",
|
|
4
|
-
"parserOptions": {
|
|
5
|
-
"project": "packages/nightingale-slack/tsconfig.json"
|
|
6
|
-
},
|
|
7
|
-
"plugins": ["@typescript-eslint"],
|
|
8
|
-
"extends": [
|
|
9
|
-
"@pob/eslint-config-typescript",
|
|
10
|
-
"@pob/eslint-config-typescript/node"
|
|
11
|
-
],
|
|
12
|
-
"ignorePatterns": ["*.d.ts"],
|
|
13
|
-
"overrides": [
|
|
14
|
-
{
|
|
15
|
-
"files": ["**/*.test.ts", "__tests__/**/*.ts"],
|
|
16
|
-
"extends": ["@pob/eslint-config-typescript/test"],
|
|
17
|
-
"env": {
|
|
18
|
-
"jest": true
|
|
19
|
-
},
|
|
20
|
-
"rules": {
|
|
21
|
-
"import/no-extraneous-dependencies": [
|
|
22
|
-
"error",
|
|
23
|
-
{
|
|
24
|
-
"devDependencies": true
|
|
25
|
-
}
|
|
26
|
-
]
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
]
|
|
30
|
-
}
|