nightingale-slack 14.0.2 → 14.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 CHANGED
@@ -3,6 +3,15 @@
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
+ ## [14.1.0](https://github.com/christophehurpeau/nightingale/compare/v14.0.2...v14.1.0) (2023-07-27)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * **nightingale-slack:** remove dependency request ([9ed95ee](https://github.com/christophehurpeau/nightingale/commit/9ed95eefd8df40864e6790306b33b666fa65b392))
12
+
13
+
14
+
6
15
  ## [14.0.2](https://github.com/christophehurpeau/nightingale/compare/v14.0.1...v14.0.2) (2023-06-30)
7
16
 
8
17
 
@@ -2,6 +2,9 @@ import type { Handle, Handler, Level } from 'nightingale-types';
2
2
  import type { SlackConfig } from './SlackConfig';
3
3
  export type { SlackConfig } from './SlackConfig';
4
4
  export { default as createBody } from './createBody';
5
+ declare global {
6
+ const fetch: typeof import('node-fetch').default;
7
+ }
5
8
  export declare class SlackHandler implements Handler {
6
9
  minLevel: Level;
7
10
  handle: Handle;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,MAAM,EAEN,OAAO,EACP,KAAK,EACN,MAAM,mBAAmB,CAAC;AAE3B,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;AAerD,qBAAa,YAAa,YAAW,OAAO;IAC1C,QAAQ,EAAE,KAAK,CAAC;IAEhB,MAAM,EAAE,MAAM,CAAC;gBAEH,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK;CAItD"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,MAAM,EAEN,OAAO,EACP,KAAK,EACN,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;AAGrD,OAAO,CAAC,MAAM,CAAC;IAEb,MAAM,KAAK,EAAE,cAAc,YAAY,EAAE,OAAO,CAAC;CAClD;AAeD,qBAAa,YAAa,YAAW,OAAO;IAC1C,QAAQ,EAAE,KAAK,CAAC;IAEhB,MAAM,EAAE,MAAM,CAAC;gBAEH,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK;CAItD"}
@@ -1,4 +1,3 @@
1
- import { post } from 'request';
2
1
  import { Level } from 'nightingale-levels';
3
2
  import markdownFormatter from 'nightingale-markdown-formatter';
4
3
  import rawFormatter from 'nightingale-raw-formatter';
@@ -32,14 +31,15 @@ function createBody(record, slackConfig) {
32
31
  };
33
32
  }
34
33
 
34
+ // temp fix for global fetch: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/60924
35
+
35
36
  const createHandler = slackConfig => record => {
36
37
  const body = createBody(record, slackConfig);
37
- post({
38
- url: slackConfig.webhookUrl,
39
- body,
40
- json: true
41
- }).on('error', err2 => {
42
- console.error(err2.stack);
38
+ fetch(slackConfig.webhookUrl, {
39
+ method: 'POST',
40
+ body: JSON.stringify(body)
41
+ }).catch(error => {
42
+ console.error(error.stack);
43
43
  });
44
44
  };
45
45
  class SlackHandler {
@@ -1 +1 @@
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 { post } from 'request';\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 post({ url: slackConfig.webhookUrl, body, json: true }).on(\n 'error',\n (err2: Error) => {\n console.error(err2.stack);\n },\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","post","url","webhookUrl","json","on","err2","console","error","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;;ACzBA,MAAMC,aAAa,GAChBnB,WAAwB,IACJD,MAAoB,IAAK;AAC5C,EAAA,MAAMqB,IAAI,GAAGtB,UAAU,CAACC,MAAM,EAAEC,WAAW,CAAC,CAAA;AAE5CqB,EAAAA,IAAI,CAAC;IAAEC,GAAG,EAAEtB,WAAW,CAACuB,UAAU;IAAEH,IAAI;AAAEI,IAAAA,IAAI,EAAE,IAAA;AAAK,GAAC,CAAC,CAACC,EAAE,CACxD,OAAO,EACNC,IAAW,IAAK;AACfC,IAAAA,OAAO,CAACC,KAAK,CAACF,IAAI,CAACG,KAAK,CAAC,CAAA;AAC3B,GACF,CAAC,CAAA;AACH,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;;;;"}
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\n// temp fix for global fetch: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/60924\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/consistent-type-imports\n const fetch: typeof import('node-fetch').default;\n}\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;;AAMA,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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-slack",
3
- "version": "14.0.2",
3
+ "version": "14.1.0",
4
4
  "description": "Slack handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -53,17 +53,17 @@
53
53
  ]
54
54
  },
55
55
  "dependencies": {
56
- "nightingale-levels": "14.0.2",
57
- "nightingale-markdown-formatter": "14.0.2",
58
- "nightingale-raw-formatter": "14.0.2",
59
- "nightingale-types": "14.0.2",
60
- "request": "^2.88.0"
56
+ "nightingale-levels": "14.1.0",
57
+ "nightingale-markdown-formatter": "14.1.0",
58
+ "nightingale-raw-formatter": "14.1.0",
59
+ "nightingale-types": "14.1.0"
61
60
  },
62
61
  "devDependencies": {
63
- "@babel/core": "7.22.5",
64
- "@types/request": "2.48.8",
65
- "pob-babel": "36.1.0",
62
+ "@babel/core": "7.22.9",
63
+ "@types/node": "18.17.1",
64
+ "@types/node-fetch": "2.6.4",
65
+ "pob-babel": "36.2.0",
66
66
  "typescript": "5.1.6"
67
67
  },
68
- "gitHead": "0e7b4a98b0ea8135163c1f5f08108bbd36b1905f"
68
+ "gitHead": "fa6fa6109188db75b1b0e6a7ad5d6ae607a26711"
69
69
  }
package/src/index.ts CHANGED
@@ -5,7 +5,6 @@ import type {
5
5
  Handler,
6
6
  Level,
7
7
  } from 'nightingale-types';
8
- import { post } from 'request';
9
8
  import type { SlackConfig } from './SlackConfig';
10
9
  import createBody from './createBody';
11
10
 
@@ -13,17 +12,23 @@ export type { SlackConfig } from './SlackConfig';
13
12
 
14
13
  export { default as createBody } from './createBody';
15
14
 
15
+ // temp fix for global fetch: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/60924
16
+ declare global {
17
+ // eslint-disable-next-line @typescript-eslint/consistent-type-imports
18
+ const fetch: typeof import('node-fetch').default;
19
+ }
20
+
16
21
  const createHandler =
17
22
  (slackConfig: SlackConfig) =>
18
23
  <T extends Metadata>(record: LogRecord<T>) => {
19
24
  const body = createBody(record, slackConfig);
20
25
 
21
- post({ url: slackConfig.webhookUrl, body, json: true }).on(
22
- 'error',
23
- (err2: Error) => {
24
- console.error(err2.stack);
25
- },
26
- );
26
+ fetch(slackConfig.webhookUrl, {
27
+ method: 'POST',
28
+ body: JSON.stringify(body),
29
+ }).catch((error: Error) => {
30
+ console.error(error.stack);
31
+ });
27
32
  };
28
33
 
29
34
  export class SlackHandler implements Handler {