cqrs-boilerplate-common 1.1.7 → 1.1.9

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.
@@ -0,0 +1 @@
1
+ export declare const LOGGER_OPTIONS: unique symbol;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LOGGER_OPTIONS = void 0;
4
+ exports.LOGGER_OPTIONS = Symbol("LOGGER_OPTIONS");
5
+ //# sourceMappingURL=logger.constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.constants.js","sourceRoot":"","sources":["../../../src/core-common/logger/logger.constants.ts"],"names":[],"mappings":";;;AACa,QAAA,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC","sourcesContent":["// src/logger/logger.constants.ts\nexport const LOGGER_OPTIONS = Symbol(\"LOGGER_OPTIONS\");\n"]}
@@ -1,6 +1,12 @@
1
1
  import { DynamicModule } from "@nestjs/common";
2
+ import { ConfigService } from "@nestjs/config";
2
3
  import { LoggerModuleOptions } from "./logger.interface";
3
- export declare const LOGGER_OPTIONS: unique symbol;
4
4
  export declare class LoggerModule {
5
5
  static forRoot(options?: LoggerModuleOptions): DynamicModule;
6
+ static forRootAsync(options: {
7
+ useConfigService?: boolean;
8
+ useFactory?: (configService?: ConfigService) => Promise<LoggerModuleOptions> | LoggerModuleOptions;
9
+ inject?: any[];
10
+ imports?: any[];
11
+ }): DynamicModule;
6
12
  }
@@ -7,19 +7,47 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
7
7
  };
8
8
  var LoggerModule_1;
9
9
  Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.LoggerModule = exports.LOGGER_OPTIONS = void 0;
10
+ exports.LoggerModule = void 0;
11
11
  const common_1 = require("@nestjs/common");
12
+ const config_1 = require("@nestjs/config");
12
13
  const logger_service_1 = require("./logger.service");
13
- exports.LOGGER_OPTIONS = Symbol("LOGGER_OPTIONS");
14
+ const logger_constants_1 = require("./logger.constants");
14
15
  let LoggerModule = LoggerModule_1 = class LoggerModule {
15
16
  static forRoot(options = {}) {
16
17
  return {
17
18
  module: LoggerModule_1,
19
+ global: true,
18
20
  providers: [
21
+ logger_service_1.LoggerService,
19
22
  {
20
- provide: exports.LOGGER_OPTIONS,
23
+ provide: logger_constants_1.LOGGER_OPTIONS,
21
24
  useValue: options,
22
25
  },
26
+ ],
27
+ exports: [logger_service_1.LoggerService],
28
+ };
29
+ }
30
+ static forRootAsync(options) {
31
+ const { useConfigService = true, useFactory, inject = [], imports = [], } = options;
32
+ return {
33
+ module: LoggerModule_1,
34
+ global: true,
35
+ imports: useConfigService ? [config_1.ConfigModule, ...imports] : imports,
36
+ providers: [
37
+ {
38
+ provide: logger_constants_1.LOGGER_OPTIONS,
39
+ inject: useConfigService ? [config_1.ConfigService, ...inject] : inject,
40
+ useFactory: async (configService) => {
41
+ if (useFactory) {
42
+ return useFactory(configService);
43
+ }
44
+ return {
45
+ level: configService?.get("LOG_LEVEL"),
46
+ prettyPrint: configService?.get("LOG_PRETTY"),
47
+ serviceName: configService?.get("SERVICE_NAME"),
48
+ };
49
+ },
50
+ },
23
51
  logger_service_1.LoggerService,
24
52
  ],
25
53
  exports: [logger_service_1.LoggerService],
@@ -1 +1 @@
1
- {"version":3,"file":"logger.module.js","sourceRoot":"","sources":["../../../src/core-common/logger/logger.module.ts"],"names":[],"mappings":";;;;;;;;;;AACA,2CAAuD;AAEvD,qDAAiD;AAEpC,QAAA,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;AAGhD,IAAM,YAAY,oBAAlB,MAAM,YAAY;IACvB,MAAM,CAAC,OAAO,CAAC,UAA+B,EAAE;QAC9C,OAAO;YACL,MAAM,EAAE,cAAY;YACpB,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,sBAAc;oBACvB,QAAQ,EAAE,OAAO;iBAClB;gBACD,8BAAa;aACd;YACD,OAAO,EAAE,CAAC,8BAAa,CAAC;SACzB,CAAC;IACJ,CAAC;CACF,CAAA;AAdY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,YAAY,CAcxB","sourcesContent":["// src/logger/logger.module.ts\nimport { DynamicModule, Module } from \"@nestjs/common\";\nimport { LoggerModuleOptions } from \"./logger.interface\";\nimport { LoggerService } from \"./logger.service\";\n\nexport const LOGGER_OPTIONS = Symbol(\"LOGGER_OPTIONS\");\n\n@Module({})\nexport class LoggerModule {\n static forRoot(options: LoggerModuleOptions = {}): DynamicModule {\n return {\n module: LoggerModule,\n providers: [\n {\n provide: LOGGER_OPTIONS,\n useValue: options,\n },\n LoggerService,\n ],\n exports: [LoggerService],\n };\n }\n}\n"]}
1
+ {"version":3,"file":"logger.module.js","sourceRoot":"","sources":["../../../src/core-common/logger/logger.module.ts"],"names":[],"mappings":";;;;;;;;;;AACA,2CAAuD;AACvD,2CAA6D;AAE7D,qDAAiD;AACjD,yDAAoD;AAG7C,IAAM,YAAY,oBAAlB,MAAM,YAAY;IACvB,MAAM,CAAC,OAAO,CAAC,UAA+B,EAAE;QAC9C,OAAO;YACL,MAAM,EAAE,cAAY;YACpB,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE;gBACT,8BAAa;gBACb;oBACE,OAAO,EAAE,iCAAc;oBACvB,QAAQ,EAAE,OAAO;iBAClB;aACF;YACD,OAAO,EAAE,CAAC,8BAAa,CAAC;SACzB,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,OAOnB;QACC,MAAM,EACJ,gBAAgB,GAAG,IAAI,EACvB,UAAU,EACV,MAAM,GAAG,EAAE,EACX,OAAO,GAAG,EAAE,GACb,GAAG,OAAO,CAAC;QAEZ,OAAO;YACL,MAAM,EAAE,cAAY;YACpB,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,qBAAY,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO;YAChE,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,iCAAc;oBACvB,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,sBAAa,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM;oBAC9D,UAAU,EAAE,KAAK,EAAE,aAA6B,EAAE,EAAE;wBAClD,IAAI,UAAU,EAAE,CAAC;4BACf,OAAO,UAAU,CAAC,aAAa,CAAC,CAAC;wBACnC,CAAC;wBAED,OAAO;4BACL,KAAK,EAAE,aAAa,EAAE,GAAG,CAAC,WAAW,CAAC;4BACtC,WAAW,EAAE,aAAa,EAAE,GAAG,CAAC,YAAY,CAAC;4BAC7C,WAAW,EAAE,aAAa,EAAE,GAAG,CAAC,cAAc,CAAC;yBAChD,CAAC;oBACJ,CAAC;iBACF;gBACD,8BAAa;aACd;YACD,OAAO,EAAE,CAAC,8BAAa,CAAC;SACzB,CAAC;IACJ,CAAC;CACF,CAAA;AAxDY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,YAAY,CAwDxB","sourcesContent":["// src/logger/logger.module.ts\nimport { DynamicModule, Module } from \"@nestjs/common\";\nimport { ConfigModule, ConfigService } from \"@nestjs/config\";\nimport { LoggerModuleOptions } from \"./logger.interface\";\nimport { LoggerService } from \"./logger.service\";\nimport { LOGGER_OPTIONS } from \"./logger.constants\";\n\n@Module({})\nexport class LoggerModule {\n static forRoot(options: LoggerModuleOptions = {}): DynamicModule {\n return {\n module: LoggerModule,\n global: true,\n providers: [\n LoggerService,\n {\n provide: LOGGER_OPTIONS,\n useValue: options,\n },\n ],\n exports: [LoggerService],\n };\n }\n\n static forRootAsync(options: {\n useConfigService?: boolean;\n useFactory?: (\n configService?: ConfigService\n ) => Promise<LoggerModuleOptions> | LoggerModuleOptions;\n inject?: any[];\n imports?: any[];\n }): DynamicModule {\n const {\n useConfigService = true,\n useFactory,\n inject = [],\n imports = [],\n } = options;\n\n return {\n module: LoggerModule,\n global: true,\n imports: useConfigService ? [ConfigModule, ...imports] : imports,\n providers: [\n {\n provide: LOGGER_OPTIONS,\n inject: useConfigService ? [ConfigService, ...inject] : inject,\n useFactory: async (configService?: ConfigService) => {\n if (useFactory) {\n return useFactory(configService);\n }\n\n return {\n level: configService?.get(\"LOG_LEVEL\"),\n prettyPrint: configService?.get(\"LOG_PRETTY\"),\n serviceName: configService?.get(\"SERVICE_NAME\"),\n };\n },\n },\n LoggerService,\n ],\n exports: [LoggerService],\n };\n }\n}\n"]}
@@ -9,6 +9,7 @@ export type OrgContext = {
9
9
  userId?: string;
10
10
  };
11
11
  export declare class LoggerService {
12
+ readonly options: LoggerModuleOptions;
12
13
  private readonly logger;
13
14
  private readonly deploymentEnv;
14
15
  private readonly hostImageVersion;
@@ -19,7 +19,7 @@ exports.LoggerService = void 0;
19
19
  const common_1 = require("@nestjs/common");
20
20
  const strip_ansi_1 = __importDefault(require("strip-ansi"));
21
21
  const winston_1 = __importDefault(require("winston"));
22
- const logger_module_1 = require("./logger.module");
22
+ const logger_constants_1 = require("./logger.constants");
23
23
  var SeverityText;
24
24
  (function (SeverityText) {
25
25
  SeverityText["INFO"] = "Information";
@@ -28,11 +28,13 @@ var SeverityText;
28
28
  SeverityText["ERROR"] = "Error";
29
29
  })(SeverityText || (SeverityText = {}));
30
30
  let LoggerService = class LoggerService {
31
+ options;
31
32
  logger;
32
33
  deploymentEnv;
33
34
  hostImageVersion;
34
35
  otelAgentHost;
35
36
  constructor(options) {
37
+ this.options = options;
36
38
  this.deploymentEnv = options.deploymentEnv ?? "rls-dev";
37
39
  this.hostImageVersion = options.serviceVersion ?? "202501.1";
38
40
  this.otelAgentHost = options.otelAgentHost ?? "10.0.0.1";
@@ -139,7 +141,7 @@ let LoggerService = class LoggerService {
139
141
  exports.LoggerService = LoggerService;
140
142
  exports.LoggerService = LoggerService = __decorate([
141
143
  (0, common_1.Injectable)(),
142
- __param(0, (0, common_1.Inject)(logger_module_1.LOGGER_OPTIONS)),
144
+ __param(0, (0, common_1.Inject)(logger_constants_1.LOGGER_OPTIONS)),
143
145
  __metadata("design:paramtypes", [Object])
144
146
  ], LoggerService);
145
147
  //# sourceMappingURL=logger.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../../src/core-common/logger/logger.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from \"@nestjs/common\";\nimport stripAnsi from \"strip-ansi\";\nimport winston, { Logger } from \"winston\";\nimport { LoggerModuleOptions } from \"./logger.interface\";\nimport { LOGGER_OPTIONS } from \"./logger.module\";\n/* ---------------------------------- Types --------------------------------- */\n\nenum SeverityText {\n INFO = \"Information\",\n DEBUG = \"Debug\",\n WARNING = \"Warning\",\n ERROR = \"Error\",\n}\n\ntype LogMetadata = {\n ClassName?: string;\n MethodName?: string;\n};\n\nexport type OrgContext = {\n orgId?: string;\n orgFid?: string;\n userId?: string;\n};\n\n/* --------------------------------- Service -------------------------------- */\n\n@Injectable()\nexport class LoggerService {\n private readonly logger: Logger;\n private readonly deploymentEnv: string;\n private readonly hostImageVersion: string;\n private readonly otelAgentHost: string;\n\n constructor(@Inject(LOGGER_OPTIONS) options: LoggerModuleOptions) {\n this.deploymentEnv = options.deploymentEnv ?? \"rls-dev\";\n this.hostImageVersion = options.serviceVersion ?? \"202501.1\";\n this.otelAgentHost = options.otelAgentHost ?? \"10.0.0.1\";\n this.logger = this.createLogger(options.level ?? \"info\");\n this.overrideConsole();\n }\n\n /* ------------------------------- Public API ------------------------------- */\n\n log(message: string, metadata?: LogMetadata) {\n this.write(\"info\", SeverityText.INFO, message, metadata);\n }\n\n debug(message: string, metadata?: LogMetadata) {\n this.write(\"debug\", SeverityText.DEBUG, message, metadata);\n }\n\n warn(message: string, metadata?: LogMetadata) {\n this.write(\"warn\", SeverityText.WARNING, message, metadata);\n }\n\n error(message: string, metadata?: LogMetadata, error?: Error) {\n this.write(\"error\", SeverityText.ERROR, message, metadata, error);\n }\n\n /* ------------------------------ Logger Core ------------------------------ */\n\n private write(\n level: keyof Logger,\n severity: SeverityText,\n message: string,\n metadata: LogMetadata = {},\n error?: Error\n ) {\n const body = {\n SeverityText: severity,\n ...metadata,\n ...(error && {\n ErrorMessage: error.message,\n StackTrace: error.stack,\n }),\n };\n\n this.logger[level](this.redactSecrets(message), body);\n }\n\n private createLogger(level: string): Logger {\n return winston.createLogger({\n level,\n levels: winston.config.npm.levels,\n format: winston.format.combine(\n winston.format.uncolorize(),\n winston.format.timestamp({ format: \"YYYY-MM-DD HH:mm:ss\" }),\n winston.format.json(),\n winston.format.printf(({ level, message, timestamp, ...meta }) =>\n JSON.stringify({\n message: stripAnsi(this.safeStringify(message)),\n attributes: this.buildAttributes(level),\n timestamp: timestamp,\n ...this.cleanMeta(meta),\n })\n )\n ),\n transports: [new winston.transports.Console()],\n });\n }\n\n /* ------------------------------- Context -------------------------------- */\n\n private buildAttributes(level: string) {\n return {\n \"service.image.version\": this.hostImageVersion,\n \"deployment.environment\": this.deploymentEnv,\n \"otel.agent.host\": this.otelAgentHost,\n \"service.log.level\": level,\n };\n }\n\n /* ------------------------------- Helpers -------------------------------- */\n\n private cleanMeta(meta: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(meta).filter(\n ([_, value]) => value !== undefined && value !== \"None\"\n )\n );\n }\n\n private safeStringify(input: unknown): string {\n try {\n return typeof input === \"string\"\n ? input\n : JSON.stringify(input, this.circularReplacer());\n } catch {\n return \"[Unserializable Object]\";\n }\n }\n\n private circularReplacer() {\n const seen = new WeakSet();\n return (_: string, value: any) => {\n if (typeof value === \"object\" && value !== null) {\n if (seen.has(value)) return \"[Circular]\";\n seen.add(value);\n }\n return value;\n };\n }\n\n /* ----------------------------- Redaction -------------------------------- */\n\n private redactSecrets(message: string): string {\n const patterns = [\n {\n name: \"JWT\",\n regex: /eyJ[a-zA-Z0-9-_]+\\.[a-zA-Z0-9-_]+\\.[a-zA-Z0-9-_]+/g,\n visible: 10,\n },\n {\n name: \"BEARER\",\n regex: /Bearer\\s+eyJ[A-Za-z0-9\\-._~+/]+=*/gi,\n visible: 15,\n },\n { name: \"API_KEY\", regex: /\\b[A-Za-z0-9]{32,}\\b/g, visible: 8 },\n { name: \"AWS_SECRET\", regex: /AKIA[0-9A-Z]{16}/g, visible: 8 },\n ];\n\n return patterns.reduce((msg, { regex, visible, name }) => {\n return msg.replace(\n regex,\n (m) => `${m.slice(0, visible)}...[REDACTED_${name}]`\n );\n }, message);\n }\n\n /* --------------------------- Console Override ---------------------------- */\n\n private overrideConsole() {\n const blocked = [\"NodeSDK\", \"AuthToken\"];\n console.log = (...args: unknown[]) => {\n const msg = args.map(String).join(\" \");\n if (blocked.some((k) => msg.includes(k))) return;\n this.log(msg);\n };\n }\n}\n"]}
1
+ {"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../../src/core-common/logger/logger.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from \"@nestjs/common\";\nimport stripAnsi from \"strip-ansi\";\nimport winston, { Logger } from \"winston\";\nimport { LOGGER_OPTIONS } from \"./logger.constants\";\nimport { LoggerModuleOptions } from \"./logger.interface\";\n/* ---------------------------------- Types --------------------------------- */\n\nenum SeverityText {\n INFO = \"Information\",\n DEBUG = \"Debug\",\n WARNING = \"Warning\",\n ERROR = \"Error\",\n}\n\ntype LogMetadata = {\n ClassName?: string;\n MethodName?: string;\n};\n\nexport type OrgContext = {\n orgId?: string;\n orgFid?: string;\n userId?: string;\n};\n\n/* --------------------------------- Service -------------------------------- */\n\n@Injectable()\nexport class LoggerService {\n private readonly logger: Logger;\n private readonly deploymentEnv: string;\n private readonly hostImageVersion: string;\n private readonly otelAgentHost: string;\n\n constructor(\n @Inject(LOGGER_OPTIONS) readonly options: LoggerModuleOptions\n ) {\n this.deploymentEnv = options.deploymentEnv ?? \"rls-dev\";\n this.hostImageVersion = options.serviceVersion ?? \"202501.1\";\n this.otelAgentHost = options.otelAgentHost ?? \"10.0.0.1\";\n this.logger = this.createLogger(options.level ?? \"info\");\n this.overrideConsole();\n }\n\n /* ------------------------------- Public API ------------------------------- */\n\n log(message: string, metadata?: LogMetadata) {\n this.write(\"info\", SeverityText.INFO, message, metadata);\n }\n\n debug(message: string, metadata?: LogMetadata) {\n this.write(\"debug\", SeverityText.DEBUG, message, metadata);\n }\n\n warn(message: string, metadata?: LogMetadata) {\n this.write(\"warn\", SeverityText.WARNING, message, metadata);\n }\n\n error(message: string, metadata?: LogMetadata, error?: Error) {\n this.write(\"error\", SeverityText.ERROR, message, metadata, error);\n }\n\n /* ------------------------------ Logger Core ------------------------------ */\n\n private write(\n level: keyof Logger,\n severity: SeverityText,\n message: string,\n metadata: LogMetadata = {},\n error?: Error\n ) {\n const body = {\n SeverityText: severity,\n ...metadata,\n ...(error && {\n ErrorMessage: error.message,\n StackTrace: error.stack,\n }),\n };\n\n this.logger[level](this.redactSecrets(message), body);\n }\n\n private createLogger(level: string): Logger {\n return winston.createLogger({\n level,\n levels: winston.config.npm.levels,\n format: winston.format.combine(\n winston.format.uncolorize(),\n winston.format.timestamp({ format: \"YYYY-MM-DD HH:mm:ss\" }),\n winston.format.json(),\n winston.format.printf(({ level, message, timestamp, ...meta }) =>\n JSON.stringify({\n message: stripAnsi(this.safeStringify(message)),\n attributes: this.buildAttributes(level),\n timestamp: timestamp,\n ...this.cleanMeta(meta),\n })\n )\n ),\n transports: [new winston.transports.Console()],\n });\n }\n\n /* ------------------------------- Context -------------------------------- */\n\n private buildAttributes(level: string) {\n return {\n \"service.image.version\": this.hostImageVersion,\n \"deployment.environment\": this.deploymentEnv,\n \"otel.agent.host\": this.otelAgentHost,\n \"service.log.level\": level,\n };\n }\n\n /* ------------------------------- Helpers -------------------------------- */\n\n private cleanMeta(meta: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(meta).filter(\n ([_, value]) => value !== undefined && value !== \"None\"\n )\n );\n }\n\n private safeStringify(input: unknown): string {\n try {\n return typeof input === \"string\"\n ? input\n : JSON.stringify(input, this.circularReplacer());\n } catch {\n return \"[Unserializable Object]\";\n }\n }\n\n private circularReplacer() {\n const seen = new WeakSet();\n return (_: string, value: any) => {\n if (typeof value === \"object\" && value !== null) {\n if (seen.has(value)) return \"[Circular]\";\n seen.add(value);\n }\n return value;\n };\n }\n\n /* ----------------------------- Redaction -------------------------------- */\n\n private redactSecrets(message: string): string {\n const patterns = [\n {\n name: \"JWT\",\n regex: /eyJ[a-zA-Z0-9-_]+\\.[a-zA-Z0-9-_]+\\.[a-zA-Z0-9-_]+/g,\n visible: 10,\n },\n {\n name: \"BEARER\",\n regex: /Bearer\\s+eyJ[A-Za-z0-9\\-._~+/]+=*/gi,\n visible: 15,\n },\n { name: \"API_KEY\", regex: /\\b[A-Za-z0-9]{32,}\\b/g, visible: 8 },\n { name: \"AWS_SECRET\", regex: /AKIA[0-9A-Z]{16}/g, visible: 8 },\n ];\n\n return patterns.reduce((msg, { regex, visible, name }) => {\n return msg.replace(\n regex,\n (m) => `${m.slice(0, visible)}...[REDACTED_${name}]`\n );\n }, message);\n }\n\n /* --------------------------- Console Override ---------------------------- */\n\n private overrideConsole() {\n const blocked = [\"NodeSDK\", \"AuthToken\"];\n console.log = (...args: unknown[]) => {\n const msg = args.map(String).join(\" \");\n if (blocked.some((k) => msg.includes(k))) return;\n this.log(msg);\n };\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import * as net from "net";
2
+ export interface TcpMessageHandler<T> {
3
+ parse(data: Buffer, socket: net.Socket): T;
4
+ handle(message: T, socket: net.Socket): void;
5
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=tcp-handler.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tcp-handler.interface.js","sourceRoot":"","sources":["../../../src/core-common/tcp-handler/tcp-handler.interface.ts"],"names":[],"mappings":"","sourcesContent":["// tcp-handler.interface.ts\nimport * as net from \"net\";\n\nexport interface TcpMessageHandler<T> {\n parse(data: Buffer, socket: net.Socket): T;\n handle(message: T, socket: net.Socket): void;\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import { OnModuleInit, OnModuleDestroy } from "@nestjs/common";
2
+ import { TcpMessageHandler } from "./tcp-handler.interface";
3
+ export declare class TcpListenerService<T> implements OnModuleInit, OnModuleDestroy {
4
+ private readonly port;
5
+ private readonly host;
6
+ private readonly handler;
7
+ private server;
8
+ constructor(port: number, host: string, handler: TcpMessageHandler<T>);
9
+ onModuleInit(): void;
10
+ onModuleDestroy(): void;
11
+ }
@@ -0,0 +1,97 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ 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;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ var __metadata = (this && this.__metadata) || function (k, v) {
42
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.TcpListenerService = void 0;
46
+ const common_1 = require("@nestjs/common");
47
+ const net = __importStar(require("net"));
48
+ const result_1 = require("../result-model/result");
49
+ const generic_error_1 = require("../error/generic.error");
50
+ let TcpListenerService = class TcpListenerService {
51
+ port;
52
+ host;
53
+ handler;
54
+ server;
55
+ constructor(port, host, handler) {
56
+ this.port = port;
57
+ this.host = host;
58
+ this.handler = handler;
59
+ }
60
+ onModuleInit() {
61
+ this.server = net.createServer((socket) => {
62
+ const ip = socket.remoteAddress;
63
+ const port = socket.remotePort;
64
+ console.log(`📡 Connected: ${ip}:${port}`);
65
+ socket.on("data", (data) => {
66
+ try {
67
+ const message = this.handler.parse(data, socket);
68
+ this.handler.handle(message, socket);
69
+ }
70
+ catch (err) {
71
+ console.error("❌ TCP processing error:", err.message);
72
+ result_1.Result.throwError(new generic_error_1.GenericError("TCP processing error", err.message));
73
+ }
74
+ });
75
+ socket.on("close", () => {
76
+ console.log(`❌ Disconnected: ${ip}:${port}`);
77
+ });
78
+ socket.on("error", (err) => {
79
+ console.error("Socket error:", err.message);
80
+ result_1.Result.throwError(new generic_error_1.GenericError("Socket error", err.message));
81
+ });
82
+ });
83
+ this.server.listen(this.port, this.host, () => {
84
+ console.log(`🚀 TCP listening on ${this.host}:${this.port}`);
85
+ });
86
+ }
87
+ onModuleDestroy() {
88
+ this.server?.close();
89
+ console.log("🛑 TCP server closed");
90
+ }
91
+ };
92
+ exports.TcpListenerService = TcpListenerService;
93
+ exports.TcpListenerService = TcpListenerService = __decorate([
94
+ (0, common_1.Injectable)(),
95
+ __metadata("design:paramtypes", [Number, String, Object])
96
+ ], TcpListenerService);
97
+ //# sourceMappingURL=tcp-listener.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tcp-listener.service.js","sourceRoot":"","sources":["../../../src/core-common/tcp-handler/tcp-listener.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA2E;AAC3E,yCAA2B;AAE3B,mDAAgD;AAChD,0DAAsD;AAG/C,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAIV;IACA;IACA;IALX,MAAM,CAAa;IAE3B,YACmB,IAAY,EACZ,IAAY,EACZ,OAA6B;QAF7B,SAAI,GAAJ,IAAI,CAAQ;QACZ,SAAI,GAAJ,IAAI,CAAQ;QACZ,YAAO,GAAP,OAAO,CAAsB;IAC7C,CAAC;IAEJ,YAAY;QACV,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,EAAE;YACxC,MAAM,EAAE,GAAG,MAAM,CAAC,aAAa,CAAC;YAChC,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC;YAC/B,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;YAC3C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;gBACjC,IAAI,CAAC;oBACH,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;oBACjD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;gBACvC,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;oBACtD,eAAM,CAAC,UAAU,CACf,IAAI,4BAAY,CAAC,sBAAsB,EAAE,GAAG,CAAC,OAAO,CAAC,CACtD,CAAC;gBACJ,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBACtB,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;YAC/C,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;gBACzB,OAAO,CAAC,KAAK,CAAC,eAAe,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;gBAC5C,eAAM,CAAC,UAAU,CACf,IAAI,4BAAY,CAAC,cAAc,EAAE,GAAG,CAAC,OAAO,CAAC,CAC9C,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;YAC5C,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC;QACrB,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;IACtC,CAAC;CACF,CAAA;AA/CY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;;GACA,kBAAkB,CA+C9B","sourcesContent":["import { Injectable, OnModuleInit, OnModuleDestroy } from \"@nestjs/common\";\nimport * as net from \"net\";\nimport { TcpMessageHandler } from \"./tcp-handler.interface\";\nimport { Result } from \"../result-model/result\";\nimport { GenericError } from \"../error/generic.error\";\n\n@Injectable()\nexport class TcpListenerService<T> implements OnModuleInit, OnModuleDestroy {\n private server: net.Server;\n\n constructor(\n private readonly port: number,\n private readonly host: string,\n private readonly handler: TcpMessageHandler<T>\n ) {}\n\n onModuleInit() {\n this.server = net.createServer((socket) => {\n const ip = socket.remoteAddress;\n const port = socket.remotePort;\n console.log(`📡 Connected: ${ip}:${port}`);\n socket.on(\"data\", (data: Buffer) => {\n try {\n const message = this.handler.parse(data, socket);\n this.handler.handle(message, socket);\n } catch (err) {\n console.error(\"❌ TCP processing error:\", err.message);\n Result.throwError(\n new GenericError(\"TCP processing error\", err.message)\n );\n }\n });\n\n socket.on(\"close\", () => {\n console.log(`❌ Disconnected: ${ip}:${port}`);\n });\n\n socket.on(\"error\", (err) => {\n console.error(\"Socket error:\", err.message);\n Result.throwError(\n new GenericError(\"Socket error\", err.message)\n );\n });\n });\n\n this.server.listen(this.port, this.host, () => {\n console.log(`🚀 TCP listening on ${this.host}:${this.port}`);\n });\n }\n\n onModuleDestroy() {\n this.server?.close();\n console.log(\"🛑 TCP server closed\");\n }\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -17,6 +17,7 @@ export * from './core-common/result-model/result';
17
17
  export * from './core-common/logger/logger.interface';
18
18
  export * from './core-common/logger/logger.module';
19
19
  export * from './core-common/logger/logger.service';
20
+ export * from './core-common/logger/logger.constants';
20
21
  export * from './common-infra/common-infra.module';
21
22
  export * from './common-infra/database/database.module';
22
23
  export * from './common-infra/http/http.module';
@@ -43,3 +44,5 @@ export * from './middleware/utils/http-response.interceptor';
43
44
  export * from './middleware/utils/http-response.module';
44
45
  export * from './middleware/response-handler/response-handler.interceptor';
45
46
  export * from './middleware/response-handler/response-handler.module';
47
+ export * from './core-common/tcp-handler/tcp-handler.interface';
48
+ export * from './core-common/tcp-handler/tcp-listener.service';
package/dist/index.js CHANGED
@@ -34,6 +34,7 @@ __exportStar(require("./core-common/result-model/result"), exports);
34
34
  __exportStar(require("./core-common/logger/logger.interface"), exports);
35
35
  __exportStar(require("./core-common/logger/logger.module"), exports);
36
36
  __exportStar(require("./core-common/logger/logger.service"), exports);
37
+ __exportStar(require("./core-common/logger/logger.constants"), exports);
37
38
  __exportStar(require("./common-infra/common-infra.module"), exports);
38
39
  __exportStar(require("./common-infra/database/database.module"), exports);
39
40
  __exportStar(require("./common-infra/http/http.module"), exports);
@@ -60,4 +61,6 @@ __exportStar(require("./middleware/utils/http-response.interceptor"), exports);
60
61
  __exportStar(require("./middleware/utils/http-response.module"), exports);
61
62
  __exportStar(require("./middleware/response-handler/response-handler.interceptor"), exports);
62
63
  __exportStar(require("./middleware/response-handler/response-handler.module"), exports);
64
+ __exportStar(require("./core-common/tcp-handler/tcp-handler.interface"), exports);
65
+ __exportStar(require("./core-common/tcp-handler/tcp-listener.service"), exports);
63
66
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,sEAAmD;AAGnD,wFAAqE;AACrE,qFAAkE;AAClE,kFAA+D;AAC/D,2FAAwE;AACxE,mFAAgE;AAChE,yFAAsE;AACtE,mFAAgE;AAChE,6FAA0E;AAC1E,sFAAmE;AACnE,0FAAuE;AACvE,oFAAiE;AACjE,oEAAiD;AAGjD,4FAAyE;AACzE,8FAA2E;AAC3E,oEAAiD;AAGjD,wEAAqD;AACrD,qEAAkD;AAClD,sEAAmD;AAGnD,qEAAkD;AAClD,0EAAuD;AACvD,kEAA+C;AAC/C,yEAAsD;AACtD,sEAAmD;AACnD,mEAAgD;AAGhD,0EAAuD;AACvD,oEAAiD;AACjD,kEAA+C;AAC/C,oEAAiD;AAGjD,sEAAmD;AACnD,0EAAuD;AACvD,yEAAsD;AACtD,0EAAuD;AAGvD,+EAA4D;AAC5D,gFAAsF;AAA7E,0HAAA,uBAAuB,OAAA;AAEhC,6EAA0D;AAG1D,+EAA4D;AAG5D,yFAAsE;AACtE,sFAAmE;AAGnE,6EAA0D;AAC1D,+EAA4D;AAC5D,0EAAuD;AAGvD,6FAA0E;AAC1E,wFAAqE","sourcesContent":["\nexport * from './core-common/constant/app.constant'\n\n// Error Exports\nexport * from './core-common/error/custom-error/already-exists.error'\nexport * from './core-common/error/custom-error/bad-request.error'\nexport * from './core-common/error/custom-error/conflict.error'\nexport * from './core-common/error/custom-error/custom-validation-error'\nexport * from './core-common/error/custom-error/forbidden.error'\nexport * from './core-common/error/custom-error/internal-server.error'\nexport * from './core-common/error/custom-error/not-found.error'\nexport * from './core-common/error/custom-error/service-unavailable.error'\nexport * from './core-common/error/custom-error/unauthorized.error'\nexport * from './core-common/error/custom-error/unprocess-entity.error'\nexport * from './core-common/error/custom-error/validation.error'\nexport * from './core-common/error/generic.error'\n\n// Model Exports\nexport * from './core-common/response-model/generic-error-response.model'\nexport * from './core-common/response-model/generic-success-response.model'\nexport * from './core-common/result-model/result'\n\n// Logger Exports\nexport * from './core-common/logger/logger.interface'\nexport * from './core-common/logger/logger.module'\nexport * from './core-common/logger/logger.service'\n\n// Module Exports\nexport * from './common-infra/common-infra.module'\nexport * from './common-infra/database/database.module'\nexport * from './common-infra/http/http.module'\nexport * from './common-infra/database/typeorm.config'\nexport * from './core-common/constant/app.constant'\nexport * from './core-common/core-common.module'\n\n// HTTP Exports\nexport * from './common-infra/http/http-module.options'\nexport * from './common-infra/http/http.constant'\nexport * from './common-infra/http/http.module'\nexport * from './common-infra/http/https.service'\n\n// Socket.IO Exports\nexport * from './common-infra/socket.io/interfaces'\nexport * from './common-infra/socket.io/socket.gateway'\nexport * from './common-infra/socket.io/socket.module'\nexport * from './common-infra/socket.io/socket.options'\n\n// Middleware Exports\nexport * from './middleware/auth-middleware/auth.middleware'\nexport { AUTH_MIDDLEWARE_OPTIONS } from './middleware/auth-middleware/auth.middleware'\nexport { AuthMiddlewareOptions } from './middleware/auth-middleware/auth.middleware'\nexport * from './middleware/auth-middleware/jwt-validator'\n\n// Global Exception Filter Exports\nexport * from './middleware/filter/global-exeception.filter'\n\n// Async Storage Middleware Exports\nexport * from './middleware/async-middleware/async-storage.middleware'\nexport * from './middleware/async-middleware/async-storage.service'\n\n// Http Formatter Exports\nexport * from './middleware/utils/http-response.formatter'\nexport * from './middleware/utils/http-response.interceptor'\nexport * from './middleware/utils/http-response.module'\n\n// Response Handler Exports\nexport * from './middleware/response-handler/response-handler.interceptor'\nexport * from './middleware/response-handler/response-handler.module'"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,sEAAmD;AAGnD,wFAAqE;AACrE,qFAAkE;AAClE,kFAA+D;AAC/D,2FAAwE;AACxE,mFAAgE;AAChE,yFAAsE;AACtE,mFAAgE;AAChE,6FAA0E;AAC1E,sFAAmE;AACnE,0FAAuE;AACvE,oFAAiE;AACjE,oEAAiD;AAGjD,4FAAyE;AACzE,8FAA2E;AAC3E,oEAAiD;AAGjD,wEAAqD;AACrD,qEAAkD;AAClD,sEAAmD;AACnD,wEAAqD;AAGrD,qEAAkD;AAClD,0EAAuD;AACvD,kEAA+C;AAC/C,yEAAsD;AACtD,sEAAmD;AACnD,mEAAgD;AAGhD,0EAAuD;AACvD,oEAAiD;AACjD,kEAA+C;AAC/C,oEAAiD;AAGjD,sEAAmD;AACnD,0EAAuD;AACvD,yEAAsD;AACtD,0EAAuD;AAGvD,+EAA4D;AAC5D,gFAAsF;AAA7E,0HAAA,uBAAuB,OAAA;AAEhC,6EAA0D;AAG1D,+EAA4D;AAG5D,yFAAsE;AACtE,sFAAmE;AAGnE,6EAA0D;AAC1D,+EAA4D;AAC5D,0EAAuD;AAGvD,6FAA0E;AAC1E,wFAAqE;AAGrE,kFAA+D;AAC/D,iFAA8D","sourcesContent":["\nexport * from './core-common/constant/app.constant'\n\n// Error Exports\nexport * from './core-common/error/custom-error/already-exists.error'\nexport * from './core-common/error/custom-error/bad-request.error'\nexport * from './core-common/error/custom-error/conflict.error'\nexport * from './core-common/error/custom-error/custom-validation-error'\nexport * from './core-common/error/custom-error/forbidden.error'\nexport * from './core-common/error/custom-error/internal-server.error'\nexport * from './core-common/error/custom-error/not-found.error'\nexport * from './core-common/error/custom-error/service-unavailable.error'\nexport * from './core-common/error/custom-error/unauthorized.error'\nexport * from './core-common/error/custom-error/unprocess-entity.error'\nexport * from './core-common/error/custom-error/validation.error'\nexport * from './core-common/error/generic.error'\n\n// Model Exports\nexport * from './core-common/response-model/generic-error-response.model'\nexport * from './core-common/response-model/generic-success-response.model'\nexport * from './core-common/result-model/result'\n\n// Logger Exports\nexport * from './core-common/logger/logger.interface'\nexport * from './core-common/logger/logger.module'\nexport * from './core-common/logger/logger.service'\nexport * from './core-common/logger/logger.constants'\n\n// Module Exports\nexport * from './common-infra/common-infra.module'\nexport * from './common-infra/database/database.module'\nexport * from './common-infra/http/http.module'\nexport * from './common-infra/database/typeorm.config'\nexport * from './core-common/constant/app.constant'\nexport * from './core-common/core-common.module'\n\n// HTTP Exports\nexport * from './common-infra/http/http-module.options'\nexport * from './common-infra/http/http.constant'\nexport * from './common-infra/http/http.module'\nexport * from './common-infra/http/https.service'\n\n// Socket.IO Exports\nexport * from './common-infra/socket.io/interfaces'\nexport * from './common-infra/socket.io/socket.gateway'\nexport * from './common-infra/socket.io/socket.module'\nexport * from './common-infra/socket.io/socket.options'\n\n// Middleware Exports\nexport * from './middleware/auth-middleware/auth.middleware'\nexport { AUTH_MIDDLEWARE_OPTIONS } from './middleware/auth-middleware/auth.middleware'\nexport { AuthMiddlewareOptions } from './middleware/auth-middleware/auth.middleware'\nexport * from './middleware/auth-middleware/jwt-validator'\n\n// Global Exception Filter Exports\nexport * from './middleware/filter/global-exeception.filter'\n\n// Async Storage Middleware Exports\nexport * from './middleware/async-middleware/async-storage.middleware'\nexport * from './middleware/async-middleware/async-storage.service'\n\n// Http Formatter Exports\nexport * from './middleware/utils/http-response.formatter'\nexport * from './middleware/utils/http-response.interceptor'\nexport * from './middleware/utils/http-response.module'\n\n// Response Handler Exports\nexport * from './middleware/response-handler/response-handler.interceptor'\nexport * from './middleware/response-handler/response-handler.module'\n\n// TCP Handler Exports\nexport * from './core-common/tcp-handler/tcp-handler.interface'\nexport * from './core-common/tcp-handler/tcp-listener.service'"]}