@jayfong/x-server 1.11.5 → 1.13.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 +21 -0
- package/lib/_cjs/cli/template_util.js +6 -0
- package/lib/_cjs/index.js +16 -0
- package/lib/_cjs/services/captcha.js +9 -0
- package/lib/_cjs/services/mail.js +40 -0
- package/lib/cli/template_util.js +6 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +2 -0
- package/lib/services/captcha.d.ts +5 -0
- package/lib/services/captcha.js +9 -0
- package/lib/services/mail.d.ts +21 -0
- package/lib/services/mail.js +28 -0
- package/package.json +3 -1
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.0](https://github.com/jfWorks/x-server/compare/v1.12.0...v1.13.0) (2022-04-26)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
* **CaptchaService:** generate, generateImage ([22bf340](https://github.com/jfWorks/x-server/commit/22bf3404cfb7d3a530714471fe004fcd9ee60760))
|
|
11
|
+
|
|
12
|
+
## [1.12.0](https://github.com/jfWorks/x-server/compare/v1.11.6...v1.12.0) (2022-04-25)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### Features
|
|
16
|
+
|
|
17
|
+
* add MailService ([e7a5337](https://github.com/jfWorks/x-server/commit/e7a53370af0dc29d6183fe66ffa3919ae55f0905))
|
|
18
|
+
|
|
19
|
+
### [1.11.6](https://github.com/jfWorks/x-server/compare/v1.11.5...v1.11.6) (2022-04-21)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
### Bug Fixes
|
|
23
|
+
|
|
24
|
+
* initHelperPackage ([5ddae6a](https://github.com/jfWorks/x-server/commit/5ddae6a7fe6b9695f8817a8525a1cff3f90a3c38))
|
|
25
|
+
|
|
5
26
|
### [1.11.5](https://github.com/jfWorks/x-server/compare/v1.11.4...v1.11.5) (2022-04-20)
|
|
6
27
|
|
|
7
28
|
|
|
@@ -25,6 +25,11 @@ class TemplateUtil {
|
|
|
25
25
|
await _fsExtra.default.copy(fromDir, toDir, {
|
|
26
26
|
overwrite: true
|
|
27
27
|
});
|
|
28
|
+
await (0, _vscodeGenerateIndexStandalone.generateManyIndex)({
|
|
29
|
+
cwd: cwd,
|
|
30
|
+
patterns: ['node_modules/.x/*.ts'],
|
|
31
|
+
replaceFile: true
|
|
32
|
+
});
|
|
28
33
|
}
|
|
29
34
|
/**
|
|
30
35
|
* 初始化模型。
|
|
@@ -67,6 +72,7 @@ class TemplateUtil {
|
|
|
67
72
|
}
|
|
68
73
|
|
|
69
74
|
await (0, _vscodeGenerateIndexStandalone.generateManyIndex)({
|
|
75
|
+
cwd: cwd,
|
|
70
76
|
patterns: [indexFile, indexFile2],
|
|
71
77
|
replaceFile: true
|
|
72
78
|
});
|
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,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/cli/template_util.js
CHANGED
|
@@ -12,6 +12,11 @@ export class TemplateUtil {
|
|
|
12
12
|
await fs.copy(fromDir, toDir, {
|
|
13
13
|
overwrite: true
|
|
14
14
|
});
|
|
15
|
+
await generateManyIndex({
|
|
16
|
+
cwd: cwd,
|
|
17
|
+
patterns: ['node_modules/.x/*.ts'],
|
|
18
|
+
replaceFile: true
|
|
19
|
+
});
|
|
15
20
|
}
|
|
16
21
|
/**
|
|
17
22
|
* 初始化模型。
|
|
@@ -49,6 +54,7 @@ export class TemplateUtil {
|
|
|
49
54
|
}
|
|
50
55
|
|
|
51
56
|
await generateManyIndex({
|
|
57
|
+
cwd: cwd,
|
|
52
58
|
patterns: [indexFile, indexFile2],
|
|
53
59
|
replaceFile: true
|
|
54
60
|
});
|
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
|
|
@@ -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' {
|
package/lib/services/captcha.js
CHANGED
|
@@ -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/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jayfong/x-server",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.13.0",
|
|
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",
|