@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.
- package/dist/database/redis/index.d.ts +1 -0
- package/dist/database/redis/index.js +1 -0
- package/dist/database/redis/index.js.map +1 -1
- package/dist/database/redis/record-lock.service.d.ts +20 -0
- package/dist/database/redis/record-lock.service.js +102 -0
- package/dist/database/redis/record-lock.service.js.map +1 -0
- package/dist/database/redis/redis.service.d.ts +1 -0
- package/dist/database/redis/redis.service.js +34 -2
- package/dist/database/redis/redis.service.js.map +1 -1
- package/dist/decorators/index.d.ts +1 -0
- package/dist/decorators/index.js +1 -0
- package/dist/decorators/index.js.map +1 -1
- package/dist/decorators/record-lock.decorator.d.ts +9 -0
- package/dist/decorators/record-lock.decorator.js +8 -0
- package/dist/decorators/record-lock.decorator.js.map +1 -0
- package/dist/examples/custom-lock-response.example.d.ts +14 -0
- package/dist/examples/custom-lock-response.example.js +71 -0
- package/dist/examples/custom-lock-response.example.js.map +1 -0
- package/dist/examples/redis-lock-usage.example.d.ts +49 -0
- package/dist/examples/redis-lock-usage.example.js +164 -0
- package/dist/examples/redis-lock-usage.example.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/interceptors/index.d.ts +1 -0
- package/dist/interceptors/index.js +18 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/interceptors/record-lock.interceptor.d.ts +12 -0
- package/dist/interceptors/record-lock.interceptor.js +85 -0
- package/dist/interceptors/record-lock.interceptor.js.map +1 -0
- package/dist/schemas/order/order.interfaces.d.ts +2 -1
- package/dist/schemas/order/order.interfaces.js +1 -0
- package/dist/schemas/order/order.interfaces.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- 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,
|
|
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"}
|