@eventista/ticketing-common 1.1.7 → 1.1.9-dev.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.
Files changed (35) hide show
  1. package/dist/database/redis/index.d.ts +1 -0
  2. package/dist/database/redis/index.js +1 -0
  3. package/dist/database/redis/index.js.map +1 -1
  4. package/dist/database/redis/record-lock.service.d.ts +20 -0
  5. package/dist/database/redis/record-lock.service.js +102 -0
  6. package/dist/database/redis/record-lock.service.js.map +1 -0
  7. package/dist/database/redis/redis.service.d.ts +1 -0
  8. package/dist/database/redis/redis.service.js +34 -2
  9. package/dist/database/redis/redis.service.js.map +1 -1
  10. package/dist/decorators/index.d.ts +1 -0
  11. package/dist/decorators/index.js +1 -0
  12. package/dist/decorators/index.js.map +1 -1
  13. package/dist/decorators/record-lock.decorator.d.ts +9 -0
  14. package/dist/decorators/record-lock.decorator.js +8 -0
  15. package/dist/decorators/record-lock.decorator.js.map +1 -0
  16. package/dist/examples/custom-lock-response.example.d.ts +14 -0
  17. package/dist/examples/custom-lock-response.example.js +71 -0
  18. package/dist/examples/custom-lock-response.example.js.map +1 -0
  19. package/dist/examples/redis-lock-usage.example.d.ts +49 -0
  20. package/dist/examples/redis-lock-usage.example.js +164 -0
  21. package/dist/examples/redis-lock-usage.example.js.map +1 -0
  22. package/dist/index.d.ts +1 -0
  23. package/dist/index.js +1 -0
  24. package/dist/index.js.map +1 -1
  25. package/dist/interceptors/index.d.ts +1 -0
  26. package/dist/interceptors/index.js +18 -0
  27. package/dist/interceptors/index.js.map +1 -0
  28. package/dist/interceptors/record-lock.interceptor.d.ts +12 -0
  29. package/dist/interceptors/record-lock.interceptor.js +85 -0
  30. package/dist/interceptors/record-lock.interceptor.js.map +1 -0
  31. package/dist/schemas/order/order.interfaces.d.ts +2 -1
  32. package/dist/schemas/order/order.interfaces.js +1 -0
  33. package/dist/schemas/order/order.interfaces.js.map +1 -1
  34. package/dist/tsconfig.tsbuildinfo +1 -1
  35. package/package.json +1 -1
@@ -0,0 +1,18 @@
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("./record-lock.interceptor"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C"}
@@ -0,0 +1,12 @@
1
+ import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
+ import { Reflector } from '@nestjs/core';
3
+ import { Observable } from 'rxjs';
4
+ import { RecordLockService } from '../database/redis/record-lock.service';
5
+ export declare class RecordLockInterceptor implements NestInterceptor {
6
+ private readonly reflector;
7
+ private readonly recordLockService;
8
+ private readonly customLogger;
9
+ constructor(reflector: Reflector, recordLockService: RecordLockService);
10
+ intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
11
+ private extractRecordId;
12
+ }
@@ -0,0 +1,85 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RecordLockInterceptor = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const core_1 = require("@nestjs/core");
15
+ const rxjs_1 = require("rxjs");
16
+ const operators_1 = require("rxjs/operators");
17
+ const record_lock_service_1 = require("../database/redis/record-lock.service");
18
+ const record_lock_decorator_1 = require("../decorators/record-lock.decorator");
19
+ const custom_logger_1 = require("../logger/custom.logger");
20
+ let RecordLockInterceptor = class RecordLockInterceptor {
21
+ constructor(reflector, recordLockService) {
22
+ this.reflector = reflector;
23
+ this.recordLockService = recordLockService;
24
+ this.customLogger = new custom_logger_1.CustomLogger('RecordLockInterceptor');
25
+ }
26
+ intercept(context, next) {
27
+ const lockMetadata = this.reflector.get(record_lock_decorator_1.RECORD_LOCK_KEY, context.getHandler());
28
+ if (!lockMetadata) {
29
+ return next.handle();
30
+ }
31
+ const request = context.switchToHttp().getRequest();
32
+ const recordId = this.extractRecordId(request, lockMetadata.recordIdParam);
33
+ if (!recordId) {
34
+ throw new common_1.BadRequestException(`Parameter ${lockMetadata.recordIdParam} is required for record locking`);
35
+ }
36
+ const { recordType, ttlSeconds = 30, timeoutMs = 5000, prefix = 'record_lock', } = lockMetadata;
37
+ this.customLogger.log(`Attempting to acquire lock for ${recordType}:${recordId}`);
38
+ return (0, rxjs_1.from)(this.recordLockService.acquireRecordLock(recordType, recordId, {
39
+ ttlSeconds,
40
+ timeoutMs,
41
+ prefix,
42
+ })).pipe((0, operators_1.switchMap)(async (lockResult) => {
43
+ if (!lockResult.success) {
44
+ return {
45
+ statusCode: 999999,
46
+ message: lockResult.error ||
47
+ `Record ${recordType}:${recordId} is currently being processed by another request`,
48
+ error: "Conflict"
49
+ };
50
+ }
51
+ try {
52
+ const result = await (0, rxjs_1.lastValueFrom)(next.handle());
53
+ return result;
54
+ }
55
+ finally {
56
+ try {
57
+ await this.recordLockService.releaseRecordLock(recordType, recordId, lockResult.lockToken, prefix);
58
+ this.customLogger.log(`Lock released for ${recordType}:${recordId}`);
59
+ }
60
+ catch (releaseError) {
61
+ this.customLogger.error(`Failed to release lock for ${recordType}:${recordId}`, releaseError.stack);
62
+ }
63
+ }
64
+ }));
65
+ }
66
+ extractRecordId(request, paramName) {
67
+ if (request.params && request.params[paramName]) {
68
+ return request.params[paramName];
69
+ }
70
+ if (request.query && request.query[paramName]) {
71
+ return request.query[paramName];
72
+ }
73
+ if (request.body && request.body[paramName]) {
74
+ return request.body[paramName];
75
+ }
76
+ return null;
77
+ }
78
+ };
79
+ exports.RecordLockInterceptor = RecordLockInterceptor;
80
+ exports.RecordLockInterceptor = RecordLockInterceptor = __decorate([
81
+ (0, common_1.Injectable)(),
82
+ __metadata("design:paramtypes", [core_1.Reflector,
83
+ record_lock_service_1.RecordLockService])
84
+ ], RecordLockInterceptor);
85
+ //# sourceMappingURL=record-lock.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record-lock.interceptor.js","sourceRoot":"","sources":["../../src/interceptors/record-lock.interceptor.ts"],"names":[],"mappings":"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"}
@@ -28,7 +28,8 @@ export declare enum IOrderStatus {
28
28
  USERCANCEL = "CANCELED",
29
29
  PAYMENT = "PAYMENT",
30
30
  CANCELEDFAILED = "CANCELEDFAILED",
31
- PAYMENTFAILED = "PAYMENTFAILED"
31
+ PAYMENTFAILED = "PAYMENTFAILED",
32
+ DONATED = "DONATED"
32
33
  }
33
34
  export declare enum IProductType {
34
35
  EVENT = "event",
@@ -34,6 +34,7 @@ var IOrderStatus;
34
34
  IOrderStatus["PAYMENT"] = "PAYMENT";
35
35
  IOrderStatus["CANCELEDFAILED"] = "CANCELEDFAILED";
36
36
  IOrderStatus["PAYMENTFAILED"] = "PAYMENTFAILED";
37
+ IOrderStatus["DONATED"] = "DONATED";
37
38
  })(IOrderStatus || (exports.IOrderStatus = IOrderStatus = {}));
38
39
  var IProductType;
39
40
  (function (IProductType) {
@@ -1 +1 @@
1
- {"version":3,"file":"order.interfaces.js","sourceRoot":"","sources":["../../../src/schemas/order/order.interfaces.ts"],"names":[],"mappings":";;;AACA,IAAY,oBAgBX;AAhBD,WAAY,oBAAoB;IAC9B,qCAAa,CAAA;IACb,qCAAa,CAAA;IACb,2CAAmB,CAAA;IACnB,yDAAiC,CAAA;IACjC,iDAAyB,CAAA;IACzB,uCAAe,CAAA;IACf,2CAAmB,CAAA;IACnB,yCAAiB,CAAA;IACjB,mDAA2B,CAAA;IAC3B,mCAAW,CAAA;IACX,6CAAqB,CAAA;IACrB,2DAAmC,CAAA;IACnC,6DAAqC,CAAA;IACrC,6DAAqC,CAAA;IACrC,2DAAmC,CAAA;AACrC,CAAC,EAhBW,oBAAoB,oCAApB,oBAAoB,QAgB/B;AAED,IAAY,YAeX;AAfD,WAAY,YAAY;IACtB,mCAAmB,CAAA;IACnB,iCAAiB,CAAA;IACjB,6BAAa,CAAA;IACb,mCAAmB,CAAA;IACnB,iCAAiB,CAAA;IACjB,qCAAqB,CAAA;IACrB,uCAAuB,CAAA;IACvB,mCAAmB,CAAA;IACnB,mCAAmB,CAAA;IACnB,uCAAuB,CAAA;IACvB,mCAAmB,CAAA;IAEnB,iDAAiC,CAAA;IACjC,+CAA+B,CAAA;AACjC,CAAC,EAfW,YAAY,4BAAZ,YAAY,QAevB;AAGD,IAAY,YAIX;AAJD,WAAY,YAAY;IACtB,+BAAe,CAAA;IACf,mCAAmB,CAAA;IACnB,2CAA2B,CAAA;AAC7B,CAAC,EAJW,YAAY,4BAAZ,YAAY,QAIvB;AAGD,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,sCAAmB,CAAA;IACnB,0CAAuB,CAAA;IACvB,wCAAqB,CAAA;AACvB,CAAC,EAJW,eAAe,+BAAf,eAAe,QAI1B;AAGD,IAAY,aAGX;AAHD,WAAY,aAAa;IACvB,4BAAW,CAAA;IACX,4BAAW,CAAA;AACb,CAAC,EAHW,aAAa,6BAAb,aAAa,QAGxB"}
1
+ {"version":3,"file":"order.interfaces.js","sourceRoot":"","sources":["../../../src/schemas/order/order.interfaces.ts"],"names":[],"mappings":";;;AACA,IAAY,oBAgBX;AAhBD,WAAY,oBAAoB;IAC9B,qCAAa,CAAA;IACb,qCAAa,CAAA;IACb,2CAAmB,CAAA;IACnB,yDAAiC,CAAA;IACjC,iDAAyB,CAAA;IACzB,uCAAe,CAAA;IACf,2CAAmB,CAAA;IACnB,yCAAiB,CAAA;IACjB,mDAA2B,CAAA;IAC3B,mCAAW,CAAA;IACX,6CAAqB,CAAA;IACrB,2DAAmC,CAAA;IACnC,6DAAqC,CAAA;IACrC,6DAAqC,CAAA;IACrC,2DAAmC,CAAA;AACrC,CAAC,EAhBW,oBAAoB,oCAApB,oBAAoB,QAgB/B;AAED,IAAY,YAiBX;AAjBD,WAAY,YAAY;IACtB,mCAAmB,CAAA;IACnB,iCAAiB,CAAA;IACjB,6BAAa,CAAA;IACb,mCAAmB,CAAA;IACnB,iCAAiB,CAAA;IACjB,qCAAqB,CAAA;IACrB,uCAAuB,CAAA;IACvB,mCAAmB,CAAA;IACnB,mCAAmB,CAAA;IACnB,uCAAuB,CAAA;IACvB,mCAAmB,CAAA;IAEnB,iDAAiC,CAAA;IACjC,+CAA+B,CAAA;IAE/B,mCAAmB,CAAA;AACrB,CAAC,EAjBW,YAAY,4BAAZ,YAAY,QAiBvB;AAGD,IAAY,YAIX;AAJD,WAAY,YAAY;IACtB,+BAAe,CAAA;IACf,mCAAmB,CAAA;IACnB,2CAA2B,CAAA;AAC7B,CAAC,EAJW,YAAY,4BAAZ,YAAY,QAIvB;AAGD,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,sCAAmB,CAAA;IACnB,0CAAuB,CAAA;IACvB,wCAAqB,CAAA;AACvB,CAAC,EAJW,eAAe,+BAAf,eAAe,QAI1B;AAGD,IAAY,aAGX;AAHD,WAAY,aAAa;IACvB,4BAAW,CAAA;IACX,4BAAW,CAAA;AACb,CAAC,EAHW,aAAa,6BAAb,aAAa,QAGxB"}