@qccareerschool/winston-nodemailer 5.1.0 → 6.0.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/README.md CHANGED
@@ -22,54 +22,27 @@ var NodemailerTransport = require('winston-nodemailer').NodeMailerTransport;
22
22
 
23
23
  ## Using in a Logger
24
24
 
25
- ### Typescript
26
-
27
25
  ```
28
- const log = new winston.Logger({
29
- transports: [
30
- new winston.transports.Console({
31
- colorize: true,
32
- }),
33
- new NodemailerTransport({
34
- auth: {
35
- pass: 'password',
36
- user: 'username',
37
- },
38
- from: 'winston@example.com',
39
- host: 'host',
40
- port: 587,
41
- secure: false,
42
- tags: ['REST API Error'],
43
- to: 'bugs@example.com',
44
- }),
45
- ],
26
+ const transporter = nodemailer.createTransport({
27
+ host: 'host',
28
+ port: 587,
29
+ secure: false,
30
+ auth: { user: 'username', pass: 'password' },
46
31
  });
47
32
 
48
- log.error('test')!
49
- ```
50
-
51
- ### Javascript
52
-
53
- ```
54
- var log = new winston.Logger({
33
+ const log = new winston.Logger({
55
34
  transports: [
56
35
  new winston.transports.Console({
57
36
  colorize: true,
58
37
  }),
59
38
  new NodemailerTransport({
60
- auth: {
61
- pass: 'password',
62
- user: 'username',
63
- },
39
+ transporter,
64
40
  from: 'winston@example.com',
65
- host: 'host',
66
- port: 587,
67
- secure: false,
68
- tags: ['REST API Error'],
69
41
  to: 'bugs@example.com',
42
+ tags: ['REST API'],
70
43
  }),
71
44
  ],
72
45
  });
73
46
 
74
47
  log.error('test')!
75
- ```
48
+ ```
package/dist/index.d.ts CHANGED
@@ -1,25 +1,20 @@
1
+ import type nodemailer from 'nodemailer';
1
2
  import type { Address } from 'nodemailer/lib/mailer';
2
3
  import Transport from 'winston-transport';
3
- export interface INodemailerOptions extends Transport.TransportStreamOptions {
4
- auth: {
5
- pass: string;
6
- user: string;
7
- };
4
+ export interface NodemailerOptions extends Transport.TransportStreamOptions {
5
+ transporter: nodemailer.Transporter;
6
+ to: string | Address | (string | Address)[];
8
7
  from: string | Address;
9
- host: string;
10
- port: number;
11
- secure: boolean;
12
8
  tags?: string[];
13
- to: string | Address | (string | Address)[];
14
9
  filter?: (info: any) => boolean;
15
10
  }
16
11
  export declare class NodemailerTransport extends Transport {
12
+ private readonly transporter;
17
13
  private readonly from?;
18
14
  private readonly to?;
19
15
  private readonly tags?;
20
16
  private readonly filter?;
21
- private readonly smtpTransport?;
22
- constructor(opts: INodemailerOptions);
17
+ constructor(opts: NodemailerOptions);
23
18
  log(info: any, next: () => void): any;
24
19
  }
25
20
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,SAAS,MAAM,mBAAmB,CAAC;AAE1C,MAAM,WAAW,kBAAmB,SAAQ,SAAS,CAAC,sBAAsB;IAC1E,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,EAAE,EAAE,MAAM,GAAG,OAAO,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC;IAE5C,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,OAAO,CAAC;CACjC;AAED,qBAAa,mBAAoB,SAAQ,SAAS;IAEhD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAmB;IACzC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAA0C;IAE9D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAS;IAE/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAyB;IAEjD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAyB;gBAErC,IAAI,EAAE,kBAAkB;IA4BpC,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,IAAI,GAAG,GAAG;CA0C7C"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,UAAU,MAAM,YAAY,CAAC;AACzC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,SAAS,MAAM,mBAAmB,CAAC;AAE1C,MAAM,WAAW,iBAAkB,SAAQ,SAAS,CAAC,sBAAsB;IACzE,WAAW,EAAE,UAAU,CAAC,WAAW,CAAC;IACpC,EAAE,EAAE,MAAM,GAAG,OAAO,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,EAAE,CAAC;IAC5C,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAEhB,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,OAAO,CAAC;CACjC;AAED,qBAAa,mBAAoB,SAAQ,SAAS;IAEhD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAyB;IACrD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAmB;IACzC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAA0C;IAC9D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAyB;gBAE9B,IAAI,EAAE,iBAAiB;IAuBnC,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,IAAI,GAAG,GAAG;CA0C7C"}
package/dist/index.js CHANGED
@@ -1,61 +1,31 @@
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
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
4
  };
28
5
  Object.defineProperty(exports, "__esModule", { value: true });
29
6
  exports.NodemailerTransport = void 0;
30
- const util = __importStar(require("util"));
31
- const nodemailer = __importStar(require("nodemailer"));
7
+ const util_1 = __importDefault(require("util"));
32
8
  const winston_transport_1 = __importDefault(require("winston-transport"));
33
9
  class NodemailerTransport extends winston_transport_1.default {
34
10
  constructor(opts) {
35
11
  super(opts);
36
- this.to = opts.to;
12
+ this.transporter = opts.transporter;
37
13
  this.from = opts.from;
14
+ this.to = opts.to;
38
15
  if (!(this.to && this.from)) {
39
16
  throw new Error('Winston-nodemailer Specify to and from');
40
17
  }
18
+ void this.transporter.verify();
41
19
  if (opts.filter) {
42
20
  this.filter = opts.filter;
43
21
  }
44
22
  if (opts.tags) {
45
- this.tags = opts.tags.map(tag => {
46
- return '[' + tag + '] ';
47
- }).join('');
48
- }
49
- try {
50
- this.smtpTransport = nodemailer.createTransport(opts);
51
- }
52
- catch (err) {
53
- console.error('Unable to initialize nodemailer--logs won\'t be emailed.', err);
23
+ this.tags = opts.tags.map(tag => `[${tag}] `).join('');
54
24
  }
55
25
  }
56
26
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
57
27
  log(info, next) {
58
- var _a, _b;
28
+ var _a;
59
29
  if (this.silent) {
60
30
  return next();
61
31
  }
@@ -68,7 +38,7 @@ class NodemailerTransport extends winston_transport_1.default {
68
38
  text = info.message;
69
39
  }
70
40
  else {
71
- text = util.inspect(info.message);
41
+ text = util_1.default.inspect(info.message);
72
42
  }
73
43
  }
74
44
  const subject = ((_a = this.tags) !== null && _a !== void 0 ? _a : '') + (hasLevel(info) && typeof info.level === 'string' ? `[${info.level}] ` : '') + text.slice(0, 51);
@@ -83,9 +53,9 @@ class NodemailerTransport extends winston_transport_1.default {
83
53
  }
84
54
  }
85
55
  if (hasMeta) {
86
- text += '\n---\n' + util.inspect(meta);
56
+ text += '\n---\n' + util_1.default.inspect(meta);
87
57
  }
88
- (_b = this.smtpTransport) === null || _b === void 0 ? void 0 : _b.sendMail({
58
+ this.transporter.sendMail({
89
59
  from: this.from,
90
60
  subject,
91
61
  text,
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@qccareerschool/winston-nodemailer",
3
- "version": "5.1.0",
3
+ "version": "6.0.0",
4
4
  "description": "An email transport for winston v3 using nodemailer written in typescript.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -13,6 +13,9 @@
13
13
  "devDependencies": {
14
14
  "@types/dotenv": "^8.2.3",
15
15
  "@types/jest": "^28.1.8",
16
+ "@types/node": "^25.0.9",
17
+ "@types/nodemailer": "^7.0.5",
18
+ "@types/winston": "^2.4.4",
16
19
  "@typescript-eslint/eslint-plugin": "^5.62.0",
17
20
  "@typescript-eslint/parser": "^5.62.0",
18
21
  "dotenv": "^16.6.1",
@@ -20,17 +23,14 @@
20
23
  "eslint-plugin-import": "^2.32.0",
21
24
  "eslint-plugin-jest": "^26.9.0",
22
25
  "jest": "^28.1.3",
26
+ "nodemailer": "^7.0.12",
23
27
  "typescript": "^4.9.5",
24
28
  "winston": "^3.19.0"
25
29
  },
26
- "dependencies": {
27
- "@types/node": "^18.19.130",
28
- "@types/nodemailer": "^7.0.5",
29
- "@types/winston": "^2.4.4",
30
- "nodemailer": "^7.0.12",
31
- "winston-transport": "^4.9.0"
32
- },
33
30
  "peerDependencies": {
34
31
  "winston": "^3.19.0"
32
+ },
33
+ "dependencies": {
34
+ "winston-transport": "^4.9.0"
35
35
  }
36
36
  }
package/src/index.ts CHANGED
@@ -1,58 +1,44 @@
1
- import * as util from 'util';
2
- import * as nodemailer from 'nodemailer';
1
+ import util from 'util';
2
+ import type nodemailer from 'nodemailer';
3
3
  import type { Address } from 'nodemailer/lib/mailer';
4
4
  import Transport from 'winston-transport';
5
5
 
6
- export interface INodemailerOptions extends Transport.TransportStreamOptions {
7
- auth: {
8
- pass: string;
9
- user: string;
10
- };
6
+ export interface NodemailerOptions extends Transport.TransportStreamOptions {
7
+ transporter: nodemailer.Transporter;
8
+ to: string | Address | (string | Address)[];
11
9
  from: string | Address;
12
- host: string;
13
- port: number;
14
- secure: boolean;
15
10
  tags?: string[];
16
- to: string | Address | (string | Address)[];
17
11
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
18
12
  filter?: (info: any) => boolean;
19
13
  }
20
14
 
21
15
  export class NodemailerTransport extends Transport {
22
16
 
17
+ private readonly transporter: nodemailer.Transporter;
23
18
  private readonly from?: string | Address;
24
19
  private readonly to?: string | Address | (string | Address)[];
25
-
26
20
  private readonly tags?: string;
27
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
28
- private readonly filter?: (info: any) => boolean;
29
-
30
- private readonly smtpTransport?: nodemailer.Transporter;
21
+ private readonly filter?: (info: any) => boolean; // eslint-disable-line @typescript-eslint/no-explicit-any
31
22
 
32
- public constructor(opts: INodemailerOptions) {
23
+ public constructor(opts: NodemailerOptions) {
33
24
  super(opts);
34
25
 
35
- this.to = opts.to;
26
+ this.transporter = opts.transporter;
36
27
  this.from = opts.from;
28
+ this.to = opts.to;
37
29
 
38
30
  if (!(this.to && this.from)) {
39
31
  throw new Error('Winston-nodemailer Specify to and from');
40
32
  }
41
33
 
34
+ void this.transporter.verify();
35
+
42
36
  if (opts.filter) {
43
37
  this.filter = opts.filter;
44
38
  }
45
39
 
46
40
  if (opts.tags) {
47
- this.tags = opts.tags.map(tag => {
48
- return '[' + tag + '] ';
49
- }).join('');
50
- }
51
-
52
- try {
53
- this.smtpTransport = nodemailer.createTransport(opts);
54
- } catch (err) {
55
- console.error('Unable to initialize nodemailer--logs won\'t be emailed.', err);
41
+ this.tags = opts.tags.map(tag => `[${tag}] `).join('');
56
42
  }
57
43
  }
58
44
 
@@ -92,7 +78,7 @@ export class NodemailerTransport extends Transport {
92
78
  text += '\n---\n' + util.inspect(meta);
93
79
  }
94
80
 
95
- this.smtpTransport?.sendMail({
81
+ this.transporter.sendMail({
96
82
  from: this.from,
97
83
  subject,
98
84
  text,