@jayfong/x-server 1.11.6 → 1.13.1

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
@@ -2,6 +2,27 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ### [1.13.1](https://github.com/jfWorks/x-server/compare/v1.13.0...v1.13.1) (2022-04-26)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * appname -> appid ([88d14d1](https://github.com/jfWorks/x-server/commit/88d14d18078c7bc19ddf2c973e53cc0353a533de))
11
+
12
+ ## [1.13.0](https://github.com/jfWorks/x-server/compare/v1.12.0...v1.13.0) (2022-04-26)
13
+
14
+
15
+ ### Features
16
+
17
+ * **CaptchaService:** generate, generateImage ([22bf340](https://github.com/jfWorks/x-server/commit/22bf3404cfb7d3a530714471fe004fcd9ee60760))
18
+
19
+ ## [1.12.0](https://github.com/jfWorks/x-server/compare/v1.11.6...v1.12.0) (2022-04-25)
20
+
21
+
22
+ ### Features
23
+
24
+ * add MailService ([e7a5337](https://github.com/jfWorks/x-server/commit/e7a53370af0dc29d6183fe66ffa3919ae55f0905))
25
+
5
26
  ### [1.11.6](https://github.com/jfWorks/x-server/compare/v1.11.5...v1.11.6) (2022-04-21)
6
27
 
7
28
 
@@ -12,7 +12,7 @@ var _x = require("../x");
12
12
  async function defineTask(options) {
13
13
  const queue = new _bull.default(options.name, {
14
14
  redis: _x.x.redis.options,
15
- prefix: `${_x.x.appName}_task`
15
+ prefix: `${_x.x.appId}_task`
16
16
  });
17
17
  queue.process(async job => {
18
18
  return options.handle(job.data);
package/lib/_cjs/index.js CHANGED
@@ -58,6 +58,14 @@ Object.keys(_http_error).forEach(function (key) {
58
58
  exports[key] = _http_error[key];
59
59
  });
60
60
 
61
+ var _http_method = require("./core/http_method");
62
+
63
+ Object.keys(_http_method).forEach(function (key) {
64
+ if (key === "default" || key === "__esModule") return;
65
+ if (key in exports && exports[key] === _http_method[key]) return;
66
+ exports[key] = _http_method[key];
67
+ });
68
+
61
69
  var _server = require("./core/server");
62
70
 
63
71
  Object.keys(_server).forEach(function (key) {
@@ -154,6 +162,14 @@ Object.keys(_jwt).forEach(function (key) {
154
162
  exports[key] = _jwt[key];
155
163
  });
156
164
 
165
+ var _mail = require("./services/mail");
166
+
167
+ Object.keys(_mail).forEach(function (key) {
168
+ if (key === "default" || key === "__esModule") return;
169
+ if (key in exports && exports[key] === _mail[key]) return;
170
+ exports[key] = _mail[key];
171
+ });
172
+
157
173
  var _redis = require("./services/redis");
158
174
 
159
175
  Object.keys(_redis).forEach(function (key) {
@@ -16,7 +16,7 @@ class CacheService {
16
16
  this.options = options;
17
17
  this.serviceName = 'cache';
18
18
  this.prefix = void 0;
19
- this.prefix = `${_x.x.appName}:`;
19
+ this.prefix = `${_x.x.appId}:`;
20
20
  }
21
21
 
22
22
  toRedisKey(key) {
@@ -16,6 +16,15 @@ class CaptchaService {
16
16
  }
17
17
 
18
18
  async generate() {
19
+ const text = Math.random().toString().slice(0 - this.options.size);
20
+ const token = await _x.x.cache.save(text, this.options.ttl);
21
+ return {
22
+ text: text,
23
+ token: token
24
+ };
25
+ }
26
+
27
+ async generateImage() {
19
28
  const res = _svgCaptcha.default.create({
20
29
  size: this.options.size
21
30
  });
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ exports.__esModule = true;
6
+ exports.MailService = void 0;
7
+
8
+ var _nodemailer = _interopRequireDefault(require("nodemailer"));
9
+
10
+ var _x = require("../x");
11
+
12
+ class MailService {
13
+ constructor(options) {
14
+ this.options = options;
15
+ this.serviceName = 'mail';
16
+ this.transporter = void 0;
17
+ }
18
+
19
+ async send(data) {
20
+ if (!this.transporter) {
21
+ this.transporter = _nodemailer.default.createTransport({
22
+ host: this.options.host,
23
+ port: this.options.port,
24
+ secure: this.options.secure,
25
+ auth: {
26
+ user: this.options.user,
27
+ pass: this.options.pass
28
+ }
29
+ });
30
+ await this.transporter.verify();
31
+
32
+ _x.x.dispose.add(() => this.transporter.close());
33
+ }
34
+
35
+ return this.transporter.sendMail(data);
36
+ }
37
+
38
+ }
39
+
40
+ exports.MailService = MailService;
package/lib/_cjs/x.js CHANGED
@@ -6,7 +6,7 @@ exports.x = void 0;
6
6
  var _dispose = require("./services/dispose");
7
7
 
8
8
  const x = {
9
- appName: process.env.APP_NAME,
9
+ appId: process.env.APP_ID,
10
10
  register: (...services) => {
11
11
  for (const service of services) {
12
12
  // @ts-ignore
@@ -3,7 +3,7 @@ import { x } from "../x";
3
3
  export async function defineTask(options) {
4
4
  const queue = new Queue(options.name, {
5
5
  redis: x.redis.options,
6
- prefix: `${x.appName}_task`
6
+ prefix: `${x.appId}_task`
7
7
  });
8
8
  queue.process(async job => {
9
9
  return options.handle(job.data);
package/lib/index.d.ts CHANGED
@@ -5,6 +5,7 @@ export * from './core/define_server';
5
5
  export * from './core/define_task';
6
6
  export * from './core/handler';
7
7
  export * from './core/http_error';
8
+ export * from './core/http_method';
8
9
  export * from './core/server';
9
10
  export * from './core/types';
10
11
  export * from './plugins/base';
@@ -17,6 +18,7 @@ export * from './services/cache';
17
18
  export * from './services/captcha';
18
19
  export * from './services/dispose';
19
20
  export * from './services/jwt';
21
+ export * from './services/mail';
20
22
  export * from './services/redis';
21
23
  export * from './x';
22
24
  export * from '.x/models';
package/lib/index.js CHANGED
@@ -6,6 +6,7 @@ export * from "./core/define_server";
6
6
  export * from "./core/define_task";
7
7
  export * from "./core/handler";
8
8
  export * from "./core/http_error";
9
+ export * from "./core/http_method";
9
10
  export * from "./core/server";
10
11
  export * from "./core/types";
11
12
  export * from "./plugins/base";
@@ -18,6 +19,7 @@ export * from "./services/cache";
18
19
  export * from "./services/captcha";
19
20
  export * from "./services/dispose";
20
21
  export * from "./services/jwt";
22
+ export * from "./services/mail";
21
23
  export * from "./services/redis";
22
24
  export * from "./x"; // @endindex
23
25
  // @ts-ignore
@@ -6,7 +6,7 @@ export class CacheService {
6
6
  this.options = options;
7
7
  this.serviceName = 'cache';
8
8
  this.prefix = void 0;
9
- this.prefix = `${x.appName}:`;
9
+ this.prefix = `${x.appId}:`;
10
10
  }
11
11
 
12
12
  toRedisKey(key) {
@@ -11,6 +11,10 @@ export interface CaptchaOptions {
11
11
  ttl: MsValue;
12
12
  }
13
13
  export interface CaptchaGenerateResult {
14
+ text: string;
15
+ token: string;
16
+ }
17
+ export interface CaptchaGenerateImageResult {
14
18
  text: string;
15
19
  svg: string;
16
20
  token: string;
@@ -24,6 +28,7 @@ export declare class CaptchaService implements BaseService {
24
28
  serviceName: string;
25
29
  constructor(options: CaptchaOptions);
26
30
  generate(): Promise<CaptchaGenerateResult>;
31
+ generateImage(): Promise<CaptchaGenerateImageResult>;
27
32
  verify(options: CaptchaVerifyOptions): Promise<boolean>;
28
33
  }
29
34
  declare module '../x' {
@@ -7,6 +7,15 @@ export class CaptchaService {
7
7
  }
8
8
 
9
9
  async generate() {
10
+ const text = Math.random().toString().slice(0 - this.options.size);
11
+ const token = await x.cache.save(text, this.options.ttl);
12
+ return {
13
+ text: text,
14
+ token: token
15
+ };
16
+ }
17
+
18
+ async generateImage() {
10
19
  const res = svgCaptcha.create({
11
20
  size: this.options.size
12
21
  });
@@ -0,0 +1,21 @@
1
+ import nodemailer from 'nodemailer';
2
+ import { BaseService } from './base';
3
+ export interface MailServiceOptions {
4
+ host: string;
5
+ port: number;
6
+ secure: boolean;
7
+ user: string;
8
+ pass: string;
9
+ }
10
+ export declare class MailService implements BaseService {
11
+ private options;
12
+ serviceName: string;
13
+ private transporter;
14
+ constructor(options: MailServiceOptions);
15
+ send(data: nodemailer.SendMailOptions): Promise<any>;
16
+ }
17
+ declare module '../x' {
18
+ interface X {
19
+ mail: MailService;
20
+ }
21
+ }
@@ -0,0 +1,28 @@
1
+ import nodemailer from 'nodemailer';
2
+ import { x } from "../x";
3
+ export class MailService {
4
+ constructor(options) {
5
+ this.options = options;
6
+ this.serviceName = 'mail';
7
+ this.transporter = void 0;
8
+ }
9
+
10
+ async send(data) {
11
+ if (!this.transporter) {
12
+ this.transporter = nodemailer.createTransport({
13
+ host: this.options.host,
14
+ port: this.options.port,
15
+ secure: this.options.secure,
16
+ auth: {
17
+ user: this.options.user,
18
+ pass: this.options.pass
19
+ }
20
+ });
21
+ await this.transporter.verify();
22
+ x.dispose.add(() => this.transporter.close());
23
+ }
24
+
25
+ return this.transporter.sendMail(data);
26
+ }
27
+
28
+ }
package/lib/x.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { BaseService } from './services/base';
2
2
  import './services/dispose';
3
3
  export interface X {
4
- readonly appName: string;
4
+ readonly appId: string;
5
5
  readonly register: (...services: BaseService[]) => void;
6
6
  }
7
7
  export declare const x: X;
package/lib/x.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { DisposeService } from "./services/dispose";
2
2
  export const x = {
3
- appName: process.env.APP_NAME,
3
+ appId: process.env.APP_ID,
4
4
  register: (...services) => {
5
5
  for (const service of services) {
6
6
  // @ts-ignore
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jayfong/x-server",
3
- "version": "1.11.6",
3
+ "version": "1.13.1",
4
4
  "license": "ISC",
5
5
  "sideEffects": false,
6
6
  "main": "lib/_cjs/index.js",
@@ -31,6 +31,7 @@
31
31
  "@types/busboy": "^0.3.2",
32
32
  "@types/http-errors": "^1.8.2",
33
33
  "@types/jsonwebtoken": "^8.5.8",
34
+ "@types/nodemailer": "^6.4.4",
34
35
  "@types/ws": "^8.5.3",
35
36
  "bufferutil": "^4.0.6",
36
37
  "bull": "^4.8.1",
@@ -53,6 +54,7 @@
53
54
  "ioredis": "^4.28.5",
54
55
  "jsonwebtoken": "^8.5.1",
55
56
  "node-ssh": "^12.0.4",
57
+ "nodemailer": "^6.7.3",
56
58
  "pino-pretty": "^7.6.1",
57
59
  "prisma": "^3.12.0",
58
60
  "select-run": "^1.1.2",