1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | const RunningStatus_1 = require("../RunningStatus");
|
4 | const Log_1 = require("../Log");
|
5 | /**
|
6 | * 对注册了的服务进行一层封装,便于ServicesManager使用。
|
7 | * 对于注册服务的生命周期进行管理。
|
8 | *
|
9 | * @class RegisteredService
|
10 | */
|
11 | class RegisteredService {
|
12 | constructor(service, manager) {
|
13 | /**
|
14 | * 绑定在服务上的错误监听器。
|
15 | *
|
16 | * @type {Function}
|
17 | */
|
18 | this._errorListener = async (err) => {
|
19 | const value = await this.service.onError(err);
|
20 | switch (value) {
|
21 | case false:
|
22 | this._manager.onError(err, this.service);
|
23 | break;
|
24 | case true:
|
25 | break;
|
26 | default:
|
27 | if (value instanceof Error)
|
28 | this._manager.onError(value, this.service);
|
29 | break;
|
30 | }
|
31 | };
|
32 | this._status = RunningStatus_1.RunningStatus.stopped;
|
33 | this.service = service;
|
34 | this._manager = manager;
|
35 | // 给服务绑定管理器
|
36 | this.service.servicesManager = manager;
|
37 | }
|
38 | /**
|
39 | * 服务的运行状态
|
40 | */
|
41 | get status() {
|
42 | return this._status;
|
43 | }
|
44 | /**
|
45 | * 启动服务。成功返回void,失败返回Error。
|
46 | * 如果抛出异常则一定是该程序内部逻辑错误
|
47 | * 这个方法仅供内部使用。
|
48 | *
|
49 | * @returns {Promise<Error | void>}
|
50 | */
|
51 | async _start() {
|
52 | //确保只有在stopped的情况下才能执行_start
|
53 | if (this._status !== RunningStatus_1.RunningStatus.stopped) {
|
54 | throw new Error(Log_1.log.s1.format(`服务:${this.service.name}`, '在还未完全关闭的情况下又再次被启动。', `当前的状态为:${RunningStatus_1.RunningStatus[this._status]}`));
|
55 | }
|
56 | try {
|
57 | Log_1.log.s1.l(Log_1.log.chalk.blue('服务:开始启动'), this.service.name);
|
58 | this._status = RunningStatus_1.RunningStatus.starting;
|
59 | await this.service.onStart();
|
60 | this.service.on('error', this._errorListener);
|
61 | Log_1.log.s1.l(Log_1.log.chalk.green('服务:成功启动'), this.service.name);
|
62 | this._status = RunningStatus_1.RunningStatus.running;
|
63 | }
|
64 | catch (err) {
|
65 | Log_1.log.s1.e(Log_1.log.chalk.red('服务:启动失败'), this.service.name, err);
|
66 | await this._stop();
|
67 | return err;
|
68 | }
|
69 | }
|
70 | /**
|
71 | * 停止服务。
|
72 | * 如果抛出异常则一定是该程序内部逻辑错误
|
73 | * 这个方法仅供内部使用。
|
74 | */
|
75 | async _stop() {
|
76 | //确保不会重复停止
|
77 | if (this._status === RunningStatus_1.RunningStatus.stopping || this._status === RunningStatus_1.RunningStatus.stopped) {
|
78 | throw new Error(Log_1.log.s1.format(`服务:${this.service.name}`, '在处于正在停止或已停止的状态下又再次被停止。', `当前的状态为:${RunningStatus_1.RunningStatus[this._status]}`));
|
79 | }
|
80 | try {
|
81 | Log_1.log.s1.l(Log_1.log.chalk.blue('服务:开始停止'), this.service.name);
|
82 | this._status = RunningStatus_1.RunningStatus.stopping;
|
83 | await this.service.onStop();
|
84 | Log_1.log.s1.l(Log_1.log.chalk.green('服务:成功停止'), this.service.name);
|
85 | }
|
86 | catch (err) {
|
87 | Log_1.log.s1.e(Log_1.log.chalk.red('服务:停止失败'), this.service.name, err);
|
88 | }
|
89 | finally {
|
90 | this._status = RunningStatus_1.RunningStatus.stopped;
|
91 | this.service.removeListener('error', this._errorListener);
|
92 | }
|
93 | }
|
94 | /**
|
95 | * 健康检查。
|
96 | * 如果抛出异常则一定是该程序内部逻辑错误
|
97 | * 这个方法仅供内部使用。
|
98 | *
|
99 | * @returns {(Promise<Error | void>)} 健康检查出现的错误
|
100 | */
|
101 | async _healthCheck() {
|
102 | // 确保只检查运行状况下的健康状态
|
103 | if (this._status !== RunningStatus_1.RunningStatus.running) {
|
104 | throw new Error(Log_1.log.s1.format(`服务:${this.service.name}`, '在非运行状态下进行了健康检查。', `当前的状态为:${RunningStatus_1.RunningStatus[this._status]}`));
|
105 | }
|
106 | try {
|
107 | await this.service.onHealthChecking();
|
108 | }
|
109 | catch (err) {
|
110 | Log_1.log.s1.w(`服务:${this.service.name}`, '运行状况异常:', err);
|
111 | return err;
|
112 | }
|
113 | }
|
114 | }
|
115 | exports.RegisteredService = RegisteredService;
|
116 |
|
117 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["RegisteredService/RegisteredService.ts"],"names":[],"mappings":";;AAEA,oDAAiD;AACjD,gCAA6B;AAE7B;;;;;GAKG;AACH;IA2CI,YAAY,OAAsB,EAAE,OAAwB;QApC5D;;;;WAIG;QACc,mBAAc,GAAG,KAAK,EAAE,GAAU;YAC/C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAE9C,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBACZ,KAAK,KAAK;oBACN,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;oBACzC,KAAK,CAAC;gBACV,KAAK,IAAI;oBACL,KAAK,CAAC;gBACV;oBACI,EAAE,CAAC,CAAC,KAAK,YAAY,KAAK,CAAC;wBACvB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;oBAC/C,KAAK,CAAC;YACd,CAAC;QACL,CAAC,CAAC;QAeM,YAAO,GAAkB,6BAAa,CAAC,OAAO,CAAC;QAGnD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QAExB,WAAW;QACX,IAAI,CAAC,OAAO,CAAC,eAAe,GAAG,OAAO,CAAC;IAC3C,CAAC;IAdD;;OAEG;IACH,IAAW,MAAM;QACb,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAWD;;;;;;OAMG;IACH,KAAK,CAAC,MAAM;QACR,4BAA4B;QAC5B,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,KAAK,6BAAa,CAAC,OAAO,CAAC,CAAC,CAAC;YACzC,MAAM,IAAI,KAAK,CACX,SAAG,CAAC,EAAE,CAAC,MAAM,CACT,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EACzB,oBAAoB,EACpB,UAAU,6BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAC1C,CACJ,CAAC;QACN,CAAC;QAED,IAAI,CAAC;YACD,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACvD,IAAI,CAAC,OAAO,GAAG,6BAAa,CAAC,QAAQ,CAAC;YAEtC,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;YAE9C,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACxD,IAAI,CAAC,OAAO,GAAG,6BAAa,CAAC,OAAO,CAAC;QACzC,CAAC;QAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACX,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YAC3D,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YAEnB,MAAM,CAAC,GAAG,CAAC;QACf,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAK;QACP,UAAU;QACV,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,KAAK,6BAAa,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,KAAK,6BAAa,CAAC,OAAO,CAAC,CAAC,CAAC;YACpF,MAAM,IAAI,KAAK,CACX,SAAG,CAAC,EAAE,CAAC,MAAM,CACT,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EACzB,wBAAwB,EACxB,UAAU,6BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAC1C,CACJ,CAAC;QACN,CAAC;QAED,IAAI,CAAC;YACD,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACvD,IAAI,CAAC,OAAO,GAAG,6BAAa,CAAC,QAAQ,CAAC;YAEtC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YAE5B,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5D,CAAC;QAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACX,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC/D,CAAC;gBAAS,CAAC;YACP,IAAI,CAAC,OAAO,GAAG,6BAAa,CAAC,OAAO,CAAC;YACrC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC9D,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,YAAY;QACd,kBAAkB;QAClB,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,KAAK,6BAAa,CAAC,OAAO,CAAC,CAAC,CAAC;YACzC,MAAM,IAAI,KAAK,CACX,SAAG,CAAC,EAAE,CAAC,MAAM,CACT,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EACzB,iBAAiB,EACjB,UAAU,6BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAC1C,CACJ,CAAC;QACN,CAAC;QAED,IAAI,CAAC;YACD,MAAM,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QAC1C,CAAC;QAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACX,SAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;YACpD,MAAM,CAAC,GAAG,CAAC;QACf,CAAC;IACL,CAAC;CACJ;AAjJD,8CAiJC","file":"RegisteredService/RegisteredService.js","sourcesContent":["import { ServiceModule } from \"../ServiceModule/ServiceModule\";\nimport { ServicesManager } from \"../ServicesManager/ServicesManager\";\nimport { RunningStatus } from \"../RunningStatus\";\nimport { log } from \"../Log\";\n\n/**\n * 对注册了的服务进行一层封装，便于ServicesManager使用。\n * 对于注册服务的生命周期进行管理。\n * \n * @class RegisteredService\n */\nexport class RegisteredService {\n\n    /**\n     * 保存对服务管理器的引用\n     */\n    private readonly _manager: ServicesManager;\n\n    /**\n     * 绑定在服务上的错误监听器。\n     * \n     * @type {Function}\n     */\n    private readonly _errorListener = async (err: Error) => {\n        const value = await this.service.onError(err);\n\n        switch (value) {\n            case false:\n                this._manager.onError(err, this.service);\n                break;\n            case true:\n                break;\n            default:\n                if (value instanceof Error)\n                    this._manager.onError(value, this.service);\n                break;\n        }\n    };\n\n    /**\n     * 服务实例\n     * \n     * @type {ServiceModule}\n     */\n    readonly service: ServiceModule;\n\n    /**\n     * 服务的运行状态\n     */\n    public get status() {\n        return this._status;\n    }\n    private _status: RunningStatus = RunningStatus.stopped;\n\n    constructor(service: ServiceModule, manager: ServicesManager) {\n        this.service = service;\n        this._manager = manager;\n\n        // 给服务绑定管理器\n        this.service.servicesManager = manager;\n    }\n\n    /**\n     * 启动服务。成功返回void，失败返回Error。    \n     * 如果抛出异常则一定是该程序内部逻辑错误      \n     * 这个方法仅供内部使用。\n     * \n     * @returns {Promise<Error | void>} \n     */\n    async _start(): Promise<Error | void> {\n        //确保只有在stopped的情况下才能执行_start\n        if (this._status !== RunningStatus.stopped) {\n            throw new Error(\n                log.s1.format(\n                    `服务：${this.service.name}`,\n                    '在还未完全关闭的情况下又再次被启动。',\n                    `当前的状态为：${RunningStatus[this._status]}`\n                )\n            );\n        }\n\n        try {\n            log.s1.l(log.chalk.blue('服务：开始启动'), this.service.name);\n            this._status = RunningStatus.starting;\n\n            await this.service.onStart();\n            this.service.on('error', this._errorListener);\n\n            log.s1.l(log.chalk.green('服务：成功启动'), this.service.name);\n            this._status = RunningStatus.running;\n        } catch (err) {\n            log.s1.e(log.chalk.red('服务：启动失败'), this.service.name, err);\n            await this._stop();\n\n            return err;\n        }\n    }\n\n    /**\n     * 停止服务。    \n     * 如果抛出异常则一定是该程序内部逻辑错误      \n     * 这个方法仅供内部使用。\n     */\n    async _stop() {\n        //确保不会重复停止\n        if (this._status === RunningStatus.stopping || this._status === RunningStatus.stopped) {\n            throw new Error(\n                log.s1.format(\n                    `服务：${this.service.name}`,\n                    '在处于正在停止或已停止的状态下又再次被停止。',\n                    `当前的状态为：${RunningStatus[this._status]}`\n                )\n            );\n        }\n\n        try {\n            log.s1.l(log.chalk.blue('服务：开始停止'), this.service.name);\n            this._status = RunningStatus.stopping;\n\n            await this.service.onStop();\n\n            log.s1.l(log.chalk.green('服务：成功停止'), this.service.name);\n        } catch (err) {\n            log.s1.e(log.chalk.red('服务：停止失败'), this.service.name, err);\n        } finally {\n            this._status = RunningStatus.stopped;\n            this.service.removeListener('error', this._errorListener);\n        }\n    }\n\n    /**\n     * 健康检查。\n     * 如果抛出异常则一定是该程序内部逻辑错误      \n     * 这个方法仅供内部使用。\n     * \n     * @returns {(Promise<Error | void>)} 健康检查出现的错误\n     */\n    async _healthCheck(): Promise<Error | void> {\n        // 确保只检查运行状况下的健康状态\n        if (this._status !== RunningStatus.running) {\n            throw new Error(\n                log.s1.format(\n                    `服务：${this.service.name}`,\n                    '在非运行状态下进行了健康检查。',\n                    `当前的状态为：${RunningStatus[this._status]}`\n                )\n            );\n        }\n\n        try {\n            await this.service.onHealthChecking();\n        } catch (err) {\n            log.s1.w(`服务：${this.service.name}`, '运行状况异常：', err);\n            return err;\n        }\n    }\n}"]}
|