@eventista/ticketing-common 1.1.8 → 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 (32) 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/tsconfig.tsbuildinfo +1 -1
  32. 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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"}