egame-shared-lib 1.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 +45 -0
- package/dist/constants/error-codes.d.ts +94 -0
- package/dist/constants/error-codes.js +97 -0
- package/dist/constants/error-codes.js.map +1 -0
- package/dist/constants/error-messages.d.ts +124 -0
- package/dist/constants/error-messages.js +133 -0
- package/dist/constants/error-messages.js.map +1 -0
- package/dist/constants/index.d.ts +3 -0
- package/dist/constants/index.js +20 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/constants/message-patterns.d.ts +50 -0
- package/dist/constants/message-patterns.js +54 -0
- package/dist/constants/message-patterns.js.map +1 -0
- package/dist/database/auth-database.module.d.ts +2 -0
- package/dist/database/auth-database.module.js +33 -0
- package/dist/database/auth-database.module.js.map +1 -0
- package/dist/database/database.module.d.ts +2 -0
- package/dist/database/database.module.js +32 -0
- package/dist/database/database.module.js.map +1 -0
- package/dist/database/index.d.ts +2 -0
- package/dist/database/index.js +19 -0
- package/dist/database/index.js.map +1 -0
- package/dist/decorators/current-user.decorator.d.ts +1 -0
- package/dist/decorators/current-user.decorator.js +10 -0
- package/dist/decorators/current-user.decorator.js.map +1 -0
- package/dist/decorators/index.d.ts +3 -0
- package/dist/decorators/index.js +20 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/public.decorator.d.ts +1 -0
- package/dist/decorators/public.decorator.js +7 -0
- package/dist/decorators/public.decorator.js.map +1 -0
- package/dist/decorators/roles.decorator.d.ts +2 -0
- package/dist/decorators/roles.decorator.js +7 -0
- package/dist/decorators/roles.decorator.js.map +1 -0
- package/dist/discovery/index.d.ts +4 -0
- package/dist/discovery/index.js +21 -0
- package/dist/discovery/index.js.map +1 -0
- package/dist/discovery/service-discovery-client.d.ts +30 -0
- package/dist/discovery/service-discovery-client.js +84 -0
- package/dist/discovery/service-discovery-client.js.map +1 -0
- package/dist/discovery/service-discovery.module.d.ts +2 -0
- package/dist/discovery/service-discovery.module.js +26 -0
- package/dist/discovery/service-discovery.module.js.map +1 -0
- package/dist/discovery/service-registration.d.ts +16 -0
- package/dist/discovery/service-registration.js +95 -0
- package/dist/discovery/service-registration.js.map +1 -0
- package/dist/discovery/service-registry.d.ts +38 -0
- package/dist/discovery/service-registry.js +124 -0
- package/dist/discovery/service-registry.js.map +1 -0
- package/dist/dto/auth.dto.d.ts +37 -0
- package/dist/dto/auth.dto.js +156 -0
- package/dist/dto/auth.dto.js.map +1 -0
- package/dist/dto/game.dto.d.ts +17 -0
- package/dist/dto/game.dto.js +66 -0
- package/dist/dto/game.dto.js.map +1 -0
- package/dist/dto/index.d.ts +4 -0
- package/dist/dto/index.js +21 -0
- package/dist/dto/index.js.map +1 -0
- package/dist/dto/payment.dto.d.ts +19 -0
- package/dist/dto/payment.dto.js +83 -0
- package/dist/dto/payment.dto.js.map +1 -0
- package/dist/dto/user.dto.d.ts +16 -0
- package/dist/dto/user.dto.js +75 -0
- package/dist/dto/user.dto.js.map +1 -0
- package/dist/exceptions/base-exception.d.ts +12 -0
- package/dist/exceptions/base-exception.js +19 -0
- package/dist/exceptions/base-exception.js.map +1 -0
- package/dist/exceptions/custom-exception.d.ts +10 -0
- package/dist/exceptions/custom-exception.js +40 -0
- package/dist/exceptions/custom-exception.js.map +1 -0
- package/dist/exceptions/index.d.ts +2 -0
- package/dist/exceptions/index.js +19 -0
- package/dist/exceptions/index.js.map +1 -0
- package/dist/filters/global-exception.filter.d.ts +15 -0
- package/dist/filters/global-exception.filter.js +99 -0
- package/dist/filters/global-exception.filter.js.map +1 -0
- package/dist/filters/index.d.ts +1 -0
- package/dist/filters/index.js +18 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/guards/jwt-auth.guard.d.ts +8 -0
- package/dist/guards/jwt-auth.guard.js +45 -0
- package/dist/guards/jwt-auth.guard.js.map +1 -0
- package/dist/guards/roles.guard.d.ts +7 -0
- package/dist/guards/roles.guard.js +44 -0
- package/dist/guards/roles.guard.js.map +1 -0
- package/dist/health/health.controller.d.ts +17 -0
- package/dist/health/health.controller.js +55 -0
- package/dist/health/health.controller.js.map +1 -0
- package/dist/health/health.module.d.ts +2 -0
- package/dist/health/health.module.js +20 -0
- package/dist/health/health.module.js.map +1 -0
- package/dist/health/index.d.ts +2 -0
- package/dist/health/index.js +19 -0
- package/dist/health/index.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/index.d.ts +105 -0
- package/dist/interfaces/index.js +31 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/rmq/rmq.module.d.ts +8 -0
- package/dist/rmq/rmq.module.js +54 -0
- package/dist/rmq/rmq.module.js.map +1 -0
- package/dist/rmq/rmq.service.d.ts +7 -0
- package/dist/rmq/rmq.service.js +40 -0
- package/dist/rmq/rmq.service.js.map +1 -0
- package/dist/services/email.module.d.ts +2 -0
- package/dist/services/email.module.js +23 -0
- package/dist/services/email.module.js.map +1 -0
- package/dist/services/email.service.d.ts +17 -0
- package/dist/services/email.service.js +200 -0
- package/dist/services/email.service.js.map +1 -0
- package/dist/services/index.d.ts +2 -0
- package/dist/services/index.js +19 -0
- package/dist/services/index.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +51 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AuthDatabaseModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const mongoose_1 = require("@nestjs/mongoose");
|
|
12
|
+
const config_1 = require("@nestjs/config");
|
|
13
|
+
let AuthDatabaseModule = class AuthDatabaseModule {
|
|
14
|
+
};
|
|
15
|
+
exports.AuthDatabaseModule = AuthDatabaseModule;
|
|
16
|
+
exports.AuthDatabaseModule = AuthDatabaseModule = __decorate([
|
|
17
|
+
(0, common_1.Global)(),
|
|
18
|
+
(0, common_1.Module)({
|
|
19
|
+
imports: [
|
|
20
|
+
config_1.ConfigModule,
|
|
21
|
+
mongoose_1.MongooseModule.forRootAsync({
|
|
22
|
+
connectionName: 'authConnection',
|
|
23
|
+
imports: [config_1.ConfigModule],
|
|
24
|
+
useFactory: (configService) => ({
|
|
25
|
+
uri: configService.get('MONGODB_AUTH_URI'),
|
|
26
|
+
}),
|
|
27
|
+
inject: [config_1.ConfigService],
|
|
28
|
+
}),
|
|
29
|
+
],
|
|
30
|
+
exports: [mongoose_1.MongooseModule],
|
|
31
|
+
})
|
|
32
|
+
], AuthDatabaseModule);
|
|
33
|
+
//# sourceMappingURL=auth-database.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-database.module.js","sourceRoot":"","sources":["../../src/database/auth-database.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,+CAAkD;AAClD,2CAA6D;AAiBtD,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;CAAG,CAAA;AAArB,gDAAkB;6BAAlB,kBAAkB;IAf9B,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,qBAAY;YACZ,yBAAc,CAAC,YAAY,CAAC;gBAC1B,cAAc,EAAE,gBAAgB;gBAChC,OAAO,EAAE,CAAC,qBAAY,CAAC;gBACvB,UAAU,EAAE,CAAC,aAA4B,EAAE,EAAE,CAAC,CAAC;oBAC7C,GAAG,EAAE,aAAa,CAAC,GAAG,CAAS,kBAAkB,CAAC;iBACnD,CAAC;gBACF,MAAM,EAAE,CAAC,sBAAa,CAAC;aACxB,CAAC;SACH;QACD,OAAO,EAAE,CAAC,yBAAc,CAAC;KAC1B,CAAC;GACW,kBAAkB,CAAG"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.DatabaseModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const mongoose_1 = require("@nestjs/mongoose");
|
|
12
|
+
const config_1 = require("@nestjs/config");
|
|
13
|
+
let DatabaseModule = class DatabaseModule {
|
|
14
|
+
};
|
|
15
|
+
exports.DatabaseModule = DatabaseModule;
|
|
16
|
+
exports.DatabaseModule = DatabaseModule = __decorate([
|
|
17
|
+
(0, common_1.Global)(),
|
|
18
|
+
(0, common_1.Module)({
|
|
19
|
+
imports: [
|
|
20
|
+
config_1.ConfigModule,
|
|
21
|
+
mongoose_1.MongooseModule.forRootAsync({
|
|
22
|
+
imports: [config_1.ConfigModule],
|
|
23
|
+
useFactory: (configService) => ({
|
|
24
|
+
uri: configService.get('MONGODB_APP_URI') || configService.get('MONGODB_URI'),
|
|
25
|
+
}),
|
|
26
|
+
inject: [config_1.ConfigService],
|
|
27
|
+
}),
|
|
28
|
+
],
|
|
29
|
+
exports: [mongoose_1.MongooseModule],
|
|
30
|
+
})
|
|
31
|
+
], DatabaseModule);
|
|
32
|
+
//# sourceMappingURL=database.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.module.js","sourceRoot":"","sources":["../../src/database/database.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,+CAAkD;AAClD,2CAA6D;AAgBtD,IAAM,cAAc,GAApB,MAAM,cAAc;CAAG,CAAA;AAAjB,wCAAc;yBAAd,cAAc;IAd1B,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,qBAAY;YACZ,yBAAc,CAAC,YAAY,CAAC;gBAC1B,OAAO,EAAE,CAAC,qBAAY,CAAC;gBACvB,UAAU,EAAE,CAAC,aAA4B,EAAE,EAAE,CAAC,CAAC;oBAC7C,GAAG,EAAE,aAAa,CAAC,GAAG,CAAS,iBAAiB,CAAC,IAAI,aAAa,CAAC,GAAG,CAAS,aAAa,CAAC;iBAC9F,CAAC;gBACF,MAAM,EAAE,CAAC,sBAAa,CAAC;aACxB,CAAC;SACH;QACD,OAAO,EAAE,CAAC,yBAAc,CAAC;KAC1B,CAAC;GACW,cAAc,CAAG"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./database.module"), exports);
|
|
18
|
+
__exportStar(require("./auth-database.module"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/database/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,yDAAuC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const CurrentUser: (...dataOrPipes: (string | import("@nestjs/common").PipeTransform<any, any> | import("@nestjs/common").Type<import("@nestjs/common").PipeTransform<any, any>>)[]) => ParameterDecorator;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CurrentUser = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
exports.CurrentUser = (0, common_1.createParamDecorator)((data, ctx) => {
|
|
6
|
+
const request = ctx.switchToHttp().getRequest();
|
|
7
|
+
const user = request.user;
|
|
8
|
+
return data ? user?.[data] : user;
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=current-user.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"current-user.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-user.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAwE;AAE3D,QAAA,WAAW,GAAG,IAAA,6BAAoB,EAC7C,CAAC,IAAwB,EAAE,GAAqB,EAAE,EAAE;IAClD,MAAM,OAAO,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;IAChD,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAE1B,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AACpC,CAAC,CACF,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./current-user.decorator"), exports);
|
|
18
|
+
__exportStar(require("./public.decorator"), exports);
|
|
19
|
+
__exportStar(require("./roles.decorator"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,qDAAmC;AACnC,oDAAkC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const Public: () => import("@nestjs/common").CustomDecorator<string>;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Public = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const Public = () => (0, common_1.SetMetadata)('isPublic', true);
|
|
6
|
+
exports.Public = Public;
|
|
7
|
+
//# sourceMappingURL=public.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"public.decorator.js","sourceRoot":"","sources":["../../src/decorators/public.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEtC,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,IAAA,oBAAW,EAAC,UAAU,EAAE,IAAI,CAAC,CAAC;AAA7C,QAAA,MAAM,UAAuC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Roles = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const Roles = (...roles) => (0, common_1.SetMetadata)('roles', roles);
|
|
6
|
+
exports.Roles = Roles;
|
|
7
|
+
//# sourceMappingURL=roles.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"roles.decorator.js","sourceRoot":"","sources":["../../src/decorators/roles.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAGtC,MAAM,KAAK,GAAG,CAAC,GAAG,KAAiB,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,OAAO,EAAE,KAAK,CAAC,CAAC;AAA9D,QAAA,KAAK,SAAyD"}
|
|
@@ -0,0 +1,21 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./service-registry"), exports);
|
|
18
|
+
__exportStar(require("./service-registration"), exports);
|
|
19
|
+
__exportStar(require("./service-discovery-client"), exports);
|
|
20
|
+
__exportStar(require("./service-discovery.module"), exports);
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/discovery/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,yDAAuC;AACvC,6DAA2C;AAC3C,6DAA2C"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ServiceRegistry } from './service-registry';
|
|
2
|
+
export declare class ServiceDiscoveryClient {
|
|
3
|
+
private registry;
|
|
4
|
+
private readonly logger;
|
|
5
|
+
private clientCache;
|
|
6
|
+
constructor(registry: ServiceRegistry);
|
|
7
|
+
send<T = any>(serviceName: string, pattern: string, data: any, timeoutMs?: number): Promise<T>;
|
|
8
|
+
emit(serviceName: string, pattern: string, data: any): Promise<void>;
|
|
9
|
+
getServiceHealth(serviceName: string): Promise<{
|
|
10
|
+
serviceName: string;
|
|
11
|
+
totalInstances: number;
|
|
12
|
+
healthyInstances: number;
|
|
13
|
+
instances: {
|
|
14
|
+
id: string;
|
|
15
|
+
host: string;
|
|
16
|
+
port: number;
|
|
17
|
+
status: "UP" | "DOWN";
|
|
18
|
+
lastHeartbeat: Date;
|
|
19
|
+
}[];
|
|
20
|
+
}>;
|
|
21
|
+
getAllServicesStatus(): Promise<{
|
|
22
|
+
totalServices: number;
|
|
23
|
+
services: Record<string, {
|
|
24
|
+
total: number;
|
|
25
|
+
healthy: number;
|
|
26
|
+
unhealthy: number;
|
|
27
|
+
}>;
|
|
28
|
+
}>;
|
|
29
|
+
private getClient;
|
|
30
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var ServiceDiscoveryClient_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.ServiceDiscoveryClient = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const service_registry_1 = require("./service-registry");
|
|
16
|
+
const rxjs_1 = require("rxjs");
|
|
17
|
+
let ServiceDiscoveryClient = ServiceDiscoveryClient_1 = class ServiceDiscoveryClient {
|
|
18
|
+
constructor(registry) {
|
|
19
|
+
this.registry = registry;
|
|
20
|
+
this.logger = new common_1.Logger(ServiceDiscoveryClient_1.name);
|
|
21
|
+
this.clientCache = new Map();
|
|
22
|
+
}
|
|
23
|
+
async send(serviceName, pattern, data, timeoutMs = 5000) {
|
|
24
|
+
try {
|
|
25
|
+
const instance = await this.registry.getInstance(serviceName, 'random');
|
|
26
|
+
if (!instance) {
|
|
27
|
+
throw new Error(`No healthy instances found for service: ${serviceName}`);
|
|
28
|
+
}
|
|
29
|
+
this.logger.debug(`Routing to ${serviceName} (${instance.id}) at ${instance.host}:${instance.port}`);
|
|
30
|
+
const client = this.getClient(instance.queue);
|
|
31
|
+
return await (0, rxjs_1.firstValueFrom)(client.send(pattern, data).pipe((0, rxjs_1.timeout)(timeoutMs)));
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
this.logger.error(`Failed to send message to ${serviceName}: ${error.message}`);
|
|
35
|
+
throw error;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
async emit(serviceName, pattern, data) {
|
|
39
|
+
try {
|
|
40
|
+
const instances = await this.registry.discoverHealthy(serviceName);
|
|
41
|
+
if (instances.length === 0) {
|
|
42
|
+
this.logger.warn(`No healthy instances found for service: ${serviceName}`);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const promises = instances.map(instance => {
|
|
46
|
+
const client = this.getClient(instance.queue);
|
|
47
|
+
return (0, rxjs_1.firstValueFrom)(client.emit(pattern, data));
|
|
48
|
+
});
|
|
49
|
+
await Promise.all(promises);
|
|
50
|
+
this.logger.debug(`Event emitted to ${instances.length} instances of ${serviceName}`);
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
this.logger.error(`Failed to emit event to ${serviceName}: ${error.message}`);
|
|
54
|
+
throw error;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async getServiceHealth(serviceName) {
|
|
58
|
+
const instances = await this.registry.discover(serviceName);
|
|
59
|
+
return {
|
|
60
|
+
serviceName,
|
|
61
|
+
totalInstances: instances.length,
|
|
62
|
+
healthyInstances: instances.filter(i => i.status === 'UP').length,
|
|
63
|
+
instances: instances.map(i => ({
|
|
64
|
+
id: i.id,
|
|
65
|
+
host: i.host,
|
|
66
|
+
port: i.port,
|
|
67
|
+
status: i.status,
|
|
68
|
+
lastHeartbeat: i.lastHeartbeat,
|
|
69
|
+
})),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
async getAllServicesStatus() {
|
|
73
|
+
return this.registry.getStats();
|
|
74
|
+
}
|
|
75
|
+
getClient(queue) {
|
|
76
|
+
return this.clientCache.get(queue);
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
exports.ServiceDiscoveryClient = ServiceDiscoveryClient;
|
|
80
|
+
exports.ServiceDiscoveryClient = ServiceDiscoveryClient = ServiceDiscoveryClient_1 = __decorate([
|
|
81
|
+
(0, common_1.Injectable)(),
|
|
82
|
+
__metadata("design:paramtypes", [service_registry_1.ServiceRegistry])
|
|
83
|
+
], ServiceDiscoveryClient);
|
|
84
|
+
//# sourceMappingURL=service-discovery-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-discovery-client.js","sourceRoot":"","sources":["../../src/discovery/service-discovery-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.ServiceDiscoveryModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const config_1 = require("@nestjs/config");
|
|
12
|
+
const service_registry_1 = require("./service-registry");
|
|
13
|
+
const service_registration_1 = require("./service-registration");
|
|
14
|
+
const service_discovery_client_1 = require("./service-discovery-client");
|
|
15
|
+
let ServiceDiscoveryModule = class ServiceDiscoveryModule {
|
|
16
|
+
};
|
|
17
|
+
exports.ServiceDiscoveryModule = ServiceDiscoveryModule;
|
|
18
|
+
exports.ServiceDiscoveryModule = ServiceDiscoveryModule = __decorate([
|
|
19
|
+
(0, common_1.Global)(),
|
|
20
|
+
(0, common_1.Module)({
|
|
21
|
+
imports: [config_1.ConfigModule],
|
|
22
|
+
providers: [service_registry_1.ServiceRegistry, service_registration_1.ServiceRegistration, service_discovery_client_1.ServiceDiscoveryClient],
|
|
23
|
+
exports: [service_registry_1.ServiceRegistry, service_registration_1.ServiceRegistration, service_discovery_client_1.ServiceDiscoveryClient],
|
|
24
|
+
})
|
|
25
|
+
], ServiceDiscoveryModule);
|
|
26
|
+
//# sourceMappingURL=service-discovery.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-discovery.module.js","sourceRoot":"","sources":["../../src/discovery/service-discovery.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,2CAA8C;AAC9C,yDAAqD;AACrD,iEAA6D;AAC7D,yEAAoE;AAQ7D,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;CAAG,CAAA;AAAzB,wDAAsB;iCAAtB,sBAAsB;IANlC,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,qBAAY,CAAC;QACvB,SAAS,EAAE,CAAC,kCAAe,EAAE,0CAAmB,EAAE,iDAAsB,CAAC;QACzE,OAAO,EAAE,CAAC,kCAAe,EAAE,0CAAmB,EAAE,iDAAsB,CAAC;KACxE,CAAC;GACW,sBAAsB,CAAG"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { OnModuleInit, OnModuleDestroy } from '@nestjs/common';
|
|
2
|
+
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
import { ServiceRegistry } from './service-registry';
|
|
4
|
+
export declare class ServiceRegistration implements OnModuleInit, OnModuleDestroy {
|
|
5
|
+
private registry;
|
|
6
|
+
private configService;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
private serviceId;
|
|
9
|
+
private heartbeatInterval;
|
|
10
|
+
constructor(registry: ServiceRegistry, configService: ConfigService);
|
|
11
|
+
onModuleInit(): Promise<void>;
|
|
12
|
+
onModuleDestroy(): Promise<void>;
|
|
13
|
+
private registerService;
|
|
14
|
+
private deregisterService;
|
|
15
|
+
private startHeartbeat;
|
|
16
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var ServiceRegistration_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.ServiceRegistration = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const config_1 = require("@nestjs/config");
|
|
16
|
+
const service_registry_1 = require("./service-registry");
|
|
17
|
+
let ServiceRegistration = ServiceRegistration_1 = class ServiceRegistration {
|
|
18
|
+
constructor(registry, configService) {
|
|
19
|
+
this.registry = registry;
|
|
20
|
+
this.configService = configService;
|
|
21
|
+
this.logger = new common_1.Logger(ServiceRegistration_1.name);
|
|
22
|
+
}
|
|
23
|
+
async onModuleInit() {
|
|
24
|
+
if (!this.configService.get('SERVICE_DISCOVERY_ENABLED', false)) {
|
|
25
|
+
this.logger.log('Service discovery is disabled');
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
await this.registerService();
|
|
29
|
+
this.startHeartbeat();
|
|
30
|
+
}
|
|
31
|
+
async onModuleDestroy() {
|
|
32
|
+
await this.deregisterService();
|
|
33
|
+
if (this.heartbeatInterval) {
|
|
34
|
+
clearInterval(this.heartbeatInterval);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
async registerService() {
|
|
38
|
+
const serviceName = this.configService.get('SERVICE_NAME');
|
|
39
|
+
const serviceHost = this.configService.get('SERVICE_HOST', 'localhost');
|
|
40
|
+
const servicePort = this.configService.get('SERVICE_PORT');
|
|
41
|
+
const queueName = this.configService.get('RABBITMQ_QUEUE');
|
|
42
|
+
if (!serviceName || !servicePort || !queueName) {
|
|
43
|
+
this.logger.warn('Service registration skipped - missing configuration');
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
try {
|
|
47
|
+
this.serviceId = await this.registry.register({
|
|
48
|
+
name: serviceName,
|
|
49
|
+
host: serviceHost,
|
|
50
|
+
port: parseInt(servicePort),
|
|
51
|
+
queue: queueName,
|
|
52
|
+
health: '/health',
|
|
53
|
+
metadata: {
|
|
54
|
+
version: process.env.npm_package_version || '1.0.0',
|
|
55
|
+
environment: this.configService.get('NODE_ENV', 'development'),
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
this.logger.log(`Service registered successfully: ${serviceName} (${this.serviceId})`);
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
this.logger.error(`Failed to register service: ${error.message}`);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
async deregisterService() {
|
|
65
|
+
if (this.serviceId) {
|
|
66
|
+
try {
|
|
67
|
+
await this.registry.deregister(this.serviceId);
|
|
68
|
+
this.logger.log(`Service deregistered: ${this.serviceId}`);
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
this.logger.error(`Failed to deregister service: ${error.message}`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
startHeartbeat() {
|
|
76
|
+
const heartbeatInterval = this.configService.get('HEALTH_CHECK_INTERVAL', '10000');
|
|
77
|
+
this.heartbeatInterval = setInterval(async () => {
|
|
78
|
+
if (this.serviceId) {
|
|
79
|
+
try {
|
|
80
|
+
await this.registry.heartbeat(this.serviceId);
|
|
81
|
+
}
|
|
82
|
+
catch (error) {
|
|
83
|
+
this.logger.error(`Heartbeat failed: ${error.message}`);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}, parseInt(heartbeatInterval));
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
exports.ServiceRegistration = ServiceRegistration;
|
|
90
|
+
exports.ServiceRegistration = ServiceRegistration = ServiceRegistration_1 = __decorate([
|
|
91
|
+
(0, common_1.Injectable)(),
|
|
92
|
+
__metadata("design:paramtypes", [service_registry_1.ServiceRegistry,
|
|
93
|
+
config_1.ConfigService])
|
|
94
|
+
], ServiceRegistration);
|
|
95
|
+
//# sourceMappingURL=service-registration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-registration.js","sourceRoot":"","sources":["../../src/discovery/service-registration.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
export interface ServiceInstance {
|
|
4
|
+
id: string;
|
|
5
|
+
name: string;
|
|
6
|
+
host: string;
|
|
7
|
+
port: number;
|
|
8
|
+
queue: string;
|
|
9
|
+
health: string;
|
|
10
|
+
status: 'UP' | 'DOWN';
|
|
11
|
+
lastHeartbeat: Date;
|
|
12
|
+
metadata?: Record<string, any>;
|
|
13
|
+
}
|
|
14
|
+
export declare class ServiceRegistry implements OnModuleInit {
|
|
15
|
+
private configService;
|
|
16
|
+
private readonly logger;
|
|
17
|
+
private services;
|
|
18
|
+
private readonly HEARTBEAT_TIMEOUT;
|
|
19
|
+
private readonly HEALTH_CHECK_INTERVAL;
|
|
20
|
+
constructor(configService: ConfigService);
|
|
21
|
+
onModuleInit(): Promise<void>;
|
|
22
|
+
register(instance: Omit<ServiceInstance, 'id' | 'status' | 'lastHeartbeat'>): Promise<string>;
|
|
23
|
+
deregister(serviceId: string): Promise<boolean>;
|
|
24
|
+
heartbeat(serviceId: string): Promise<boolean>;
|
|
25
|
+
discover(serviceName: string): Promise<ServiceInstance[]>;
|
|
26
|
+
discoverHealthy(serviceName: string): Promise<ServiceInstance[]>;
|
|
27
|
+
getInstance(serviceName: string, strategy?: 'round-robin' | 'random'): Promise<ServiceInstance | null>;
|
|
28
|
+
getAllServices(): Promise<Map<string, ServiceInstance[]>>;
|
|
29
|
+
private startHealthCheckMonitor;
|
|
30
|
+
getStats(): {
|
|
31
|
+
totalServices: number;
|
|
32
|
+
services: Record<string, {
|
|
33
|
+
total: number;
|
|
34
|
+
healthy: number;
|
|
35
|
+
unhealthy: number;
|
|
36
|
+
}>;
|
|
37
|
+
};
|
|
38
|
+
}
|