1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | const Emitter = require("component-emitter");
|
4 | /**
|
5 | * 所有服务模块的父类
|
6 | */
|
7 | class BaseServiceModule extends Emitter {
|
8 | constructor() {
|
9 | super(...arguments);
|
10 | /**
|
11 | * 简化对其他注册服务的获取
|
12 | */
|
13 | this.services = new Proxy({}, {
|
14 | get: (_, property) => {
|
15 | if (this._servicesManager !== undefined) {
|
16 | const rs = this._servicesManager.services.get(property);
|
17 | if (rs !== undefined)
|
18 | return rs.service;
|
19 | }
|
20 | }
|
21 | });
|
22 | }
|
23 | /**
|
24 | * 获取当前服务的名称(默认是类名)
|
25 | */
|
26 | get name() {
|
27 | return this.constructor.name;
|
28 | }
|
29 | /**
|
30 | * 当前模块的运行状态
|
31 | */
|
32 | get runningStatus() {
|
33 | return this._runningStatus;
|
34 | }
|
35 | set runningStatus(v) {
|
36 | this._runningStatus = v;
|
37 | }
|
38 | /**
|
39 | * 对于服务管理器的引用。
|
40 | * 当服务注册之后,服务管理器会自动对该属性进行绑定
|
41 | */
|
42 | get servicesManager() {
|
43 | return this._servicesManager;
|
44 | }
|
45 | set servicesManager(v) {
|
46 | //确保只能被设置一次
|
47 | if (this._servicesManager === undefined)
|
48 | this._servicesManager = v;
|
49 | else
|
50 | throw new Error(`模块:${this.name}:不允许重复设置ServicesManager`);
|
51 | }
|
52 | /**
|
53 | * 停止服务
|
54 | * 注意:停止过程中出现的错误直接通过Promise.reject()来处理。停止过程中不要出现未捕获异常
|
55 | *
|
56 | * @returns {Promise<void>}
|
57 | */
|
58 | onStop() {
|
59 | return Promise.resolve();
|
60 | }
|
61 | /**
|
62 | * 当服务发生异常时,这个方法会在全局错误处理方法(BaseServicesManager的onError)之前被调用。
|
63 | * 注意:该方法只有当服务在运行过程中发生错误时(通过this.emit('error')触发的错误),该方法才会被调用。
|
64 | *
|
65 | * 返回false、undefined或null :错误将继续交由全局错误处理方法处理
|
66 | * 返回true :错误不再交由全局错误处理方法处理
|
67 | * 返回{errName: string | undefined, err: Error} :替换错误的内容,将新的Error交由全局错误处理方法继续处理
|
68 | *
|
69 | * @param errName 错误消息的名称
|
70 | * @param err 错误消息
|
71 | */
|
72 | onError(errName, err) {
|
73 | return Promise.resolve();
|
74 | }
|
75 | /**
|
76 | * 检查当前服务运行是否正常。
|
77 | * 如果正常直接Promise.resolve(),如果出现问题直接Promise.reject(new Error())
|
78 | *
|
79 | * @returns {Promise<void>}
|
80 | */
|
81 | onHealthCheck() {
|
82 | return Promise.resolve();
|
83 | }
|
84 | on(event, listener) {
|
85 | super.on(event, listener);
|
86 | return this;
|
87 | }
|
88 | once(event, listener) {
|
89 | super.once(event, listener);
|
90 | return this;
|
91 | }
|
92 | emit(event, ...args) {
|
93 | if (event === 'error') {
|
94 | let errName, err;
|
95 | if (args[0] instanceof Error) {
|
96 | err = args[0];
|
97 | }
|
98 | else {
|
99 | errName = args[0];
|
100 | err = args[1];
|
101 | }
|
102 | return super.emit(event, errName, err);
|
103 | }
|
104 | else {
|
105 | return super.emit(event, ...args);
|
106 | }
|
107 | }
|
108 | }
|
109 | exports.BaseServiceModule = BaseServiceModule;
|
110 |
|
111 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["common/BaseServiceModule.ts"],"names":[],"mappings":";;AAEA,6CAA6C;AAE7C;;GAEG;AACH,uBAAwC,SAAQ,OAAO;IAAvD;;QAoCI;;WAEG;QACM,aAAQ,GAAQ,IAAI,KAAK,CAAC,EAAE,EAAE;YACnC,GAAG,EAAE,CAAC,CAAC,EAAE,QAAgB;gBACrB,EAAE,CAAC,CAAC,IAAI,CAAC,gBAAgB,KAAK,SAAS,CAAC,CAAC,CAAC;oBACtC,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACxD,EAAE,CAAC,CAAC,EAAE,KAAK,SAAS,CAAC;wBACjB,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC;gBAC1B,CAAC;YACL,CAAC;SACJ,CAAC,CAAC;IAgGP,CAAC;IA7IG;;OAEG;IACH,IAAI,IAAI;QACJ,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,IAAI,aAAa;QACb,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IACD,IAAI,aAAa,CAAC,CAAgB;QAC9B,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;IAC5B,CAAC;IAGD;;;OAGG;IACH,IAAI,eAAe;QACf,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC;IACjC,CAAC;IACD,IAAI,eAAe,CAAC,CAAsB;QACtC,WAAW;QACX,EAAE,CAAC,CAAC,IAAI,CAAC,gBAAgB,KAAK,SAAS,CAAC;YACpC,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC9B,IAAI;YACA,MAAM,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,IAAI,yBAAyB,CAAC,CAAC;IAClE,CAAC;IA2BD;;;;;OAKG;IACH,MAAM;QACF,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED;;;;;;;;;;OAUG;IACH,OAAO,CAAC,OAA2B,EAAE,GAAU;QAC3C,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACH,aAAa;QACT,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAMD,EAAE,CAAC,KAAa,EAAE,QAAkB;QAChC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC1B,MAAM,CAAC,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,CAAC,KAAa,EAAE,QAAkB;QAClC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC5B,MAAM,CAAC,IAAI,CAAC;IAChB,CAAC;IAqBD,IAAI,CAAC,KAAa,EAAE,GAAG,IAAW;QAC9B,EAAE,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC;YACpB,IAAI,OAAO,EAAE,GAAG,CAAC;YACjB,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC;gBAC3B,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;YAAC,IAAI,CAAC,CAAC;gBACJ,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;YACD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;QAC3C,CAAC;QAAC,IAAI,CAAC,CAAC;YACJ,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;QACtC,CAAC;IACL,CAAC;CACJ;AA/ID,8CA+IC","file":"common/BaseServiceModule.js","sourcesContent":["import { BaseServicesManager } from \"./BaseServicesManager\";\r\nimport { RunningStatus } from './RunningStatus';\r\nimport * as Emitter from 'component-emitter';\r\n\r\n/**\r\n * 所有服务模块的父类    \r\n */\r\nexport abstract class BaseServiceModule extends Emitter {\r\n\r\n    /**\r\n     * 获取当前服务的名称（默认是类名）\r\n     */\r\n    get name(): string {\r\n        return this.constructor.name;\r\n    }\r\n\r\n    /**\r\n     * 当前模块的运行状态\r\n     */\r\n    get runningStatus(): RunningStatus {\r\n        return this._runningStatus;\r\n    }\r\n    set runningStatus(v: RunningStatus) {\r\n        this._runningStatus = v;\r\n    }\r\n    private _runningStatus: RunningStatus;\r\n\r\n    /**\r\n     * 对于服务管理器的引用。    \r\n     * 当服务注册之后，服务管理器会自动对该属性进行绑定\r\n     */\r\n    get servicesManager(): BaseServicesManager {\r\n        return this._servicesManager;\r\n    }\r\n    set servicesManager(v: BaseServicesManager) {\r\n        //确保只能被设置一次\r\n        if (this._servicesManager === undefined)\r\n            this._servicesManager = v;\r\n        else\r\n            throw new Error(`模块：${this.name}：不允许重复设置ServicesManager`);\r\n    }\r\n    private _servicesManager: BaseServicesManager;\r\n\r\n    /**\r\n     * 简化对其他注册服务的获取\r\n     */\r\n    readonly services: any = new Proxy({}, {\r\n        get: (_, property: string) => {\r\n            if (this._servicesManager !== undefined) {\r\n                const rs = this._servicesManager.services.get(property);\r\n                if (rs !== undefined)\r\n                    return rs.service;\r\n            }\r\n        }\r\n    });\r\n\r\n    /**\r\n     * 启动服务     \r\n     * 注意：启动过程中出现的错误直接通过Promise.reject()来处理。\r\n     * 启动之后(运行过程中)出现的错误，通过this.emit('error')来处理。\r\n     * 尽可能多地捕捉异常，然后在onError中处理，未捕捉的异常根据平台的不同可能会导致程序直接被关闭。\r\n     * \r\n     * @abstract\r\n     * @returns {Promise<void>} \r\n     */\r\n    abstract onStart(): Promise<void>;\r\n\r\n    /**\r\n     * 停止服务     \r\n     * 注意：停止过程中出现的错误直接通过Promise.reject()来处理。停止过程中不要出现未捕获异常\r\n     * \r\n     * @returns {Promise<void>} \r\n     */\r\n    onStop(): Promise<void> {\r\n        return Promise.resolve();\r\n    }\r\n\r\n    /**\r\n     * 当服务发生异常时，这个方法会在全局错误处理方法(BaseServicesManager的onError)之前被调用。      \r\n     * 注意：该方法只有当服务在运行过程中发生错误时（通过this.emit('error')触发的错误），该方法才会被调用。    \r\n     * \r\n     * 返回false、undefined或null                     ：错误将继续交由全局错误处理方法处理   \r\n     * 返回true                                       ：错误不再交由全局错误处理方法处理   \r\n     * 返回{errName: string | undefined, err: Error}  ：替换错误的内容，将新的Error交由全局错误处理方法继续处理   \r\n     * \r\n     * @param errName 错误消息的名称\r\n     * @param err 错误消息\r\n     */\r\n    onError(errName: string | undefined, err: Error): Promise<{ errName: string | undefined, err: Error } | boolean | void> {\r\n        return Promise.resolve();\r\n    }\r\n\r\n    /**\r\n     * 检查当前服务运行是否正常。   \r\n     * 如果正常直接Promise.resolve()，如果出现问题直接Promise.reject(new Error())\r\n     * \r\n     * @returns {Promise<void>} \r\n     */\r\n    onHealthCheck(): Promise<void> {\r\n        return Promise.resolve();\r\n    }\r\n\r\n    /**\r\n     * 模块运行过程中发生的从错误\r\n     */\r\n    on(event: 'error', listener: (errName: string | undefined, err: Error) => any): this;\r\n    on(event: string, listener: Function): this {\r\n        super.on(event, listener);\r\n        return this;\r\n    }\r\n\r\n    once(event: 'error', listener: (errName: string | undefined, err: Error) => any): this;\r\n    once(event: string, listener: Function): this {\r\n        super.once(event, listener);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * 触发错误事件。并设置错误事件的errName为undefined\r\n     * \r\n     * @param {'error'} event \r\n     * @param {Error} err 错误消息\r\n     * @returns {boolean} \r\n     * @memberof BaseServiceModule\r\n     */\r\n    emit(event: 'error', err: Error): boolean;\r\n    /**\r\n     * 触发错误事件。\r\n     * \r\n     * @param {'error'} event \r\n     * @param {string} errName 错误消息的名称\r\n     * @param {Error} err 错误消息\r\n     * @returns {boolean} \r\n     * @memberof BaseServiceModule\r\n     */\r\n    emit(event: 'error', errName: string, err: Error): boolean;\r\n    emit(event: string, ...args: any[]): boolean {\r\n        if (event === 'error') {\r\n            let errName, err;\r\n            if (args[0] instanceof Error) {\r\n                err = args[0];\r\n            } else {\r\n                errName = args[0];\r\n                err = args[1];\r\n            }\r\n            return super.emit(event, errName, err);\r\n        } else {\r\n            return super.emit(event, ...args);\r\n        }\r\n    }\r\n}"]}
|