@aldb2b/common 1.0.544 → 1.0.545
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/build/middlewares/full-fill-verification.middleware.d.ts +8 -0
- package/build/middlewares/full-fill-verification.middleware.js +49 -0
- package/build/middlewares/full-fill-verification.middleware.js.map +1 -0
- package/build/middlewares/verify-contact.middleware.d.ts +1 -0
- package/build/middlewares/verify-contact.middleware.js +33 -25
- package/build/middlewares/verify-contact.middleware.js.map +1 -1
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestMiddleware } from '@nestjs/common';
|
|
2
|
+
import { Request, Response, NextFunction } from 'express';
|
|
3
|
+
import { ClientProxy } from '@nestjs/microservices';
|
|
4
|
+
export declare class FullFillVerificationMiddleware implements NestMiddleware {
|
|
5
|
+
private readonly ChallengeClient;
|
|
6
|
+
constructor(ChallengeClient: ClientProxy);
|
|
7
|
+
use(req: Request, res: Response, next: NextFunction): void;
|
|
8
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
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 __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.FullFillVerificationMiddleware = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const microservices_1 = require("@nestjs/microservices");
|
|
18
|
+
const rxjs_1 = require("rxjs");
|
|
19
|
+
const subjects_1 = require("../events/subjects");
|
|
20
|
+
const challenge_status_enum_1 = require("../enums/challenge-status.enum");
|
|
21
|
+
let FullFillVerificationMiddleware = class FullFillVerificationMiddleware {
|
|
22
|
+
constructor(ChallengeClient) {
|
|
23
|
+
this.ChallengeClient = ChallengeClient;
|
|
24
|
+
}
|
|
25
|
+
use(req, res, next) {
|
|
26
|
+
res.on('finish', async () => {
|
|
27
|
+
const { statusCode } = res;
|
|
28
|
+
if (statusCode < 200 || statusCode >= 300) {
|
|
29
|
+
return next();
|
|
30
|
+
}
|
|
31
|
+
const response = await (0, rxjs_1.firstValueFrom)(this.ChallengeClient.send(subjects_1.Subjects.UpdateChallenge, {
|
|
32
|
+
data: {
|
|
33
|
+
query: { _id: req.body.chalengeId },
|
|
34
|
+
data: { status: challenge_status_enum_1.ChallengeStatus.FULL_FILLED },
|
|
35
|
+
},
|
|
36
|
+
}));
|
|
37
|
+
console.log('FullFillVerificationMiddleware - response: ', response);
|
|
38
|
+
next();
|
|
39
|
+
});
|
|
40
|
+
next();
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
exports.FullFillVerificationMiddleware = FullFillVerificationMiddleware;
|
|
44
|
+
exports.FullFillVerificationMiddleware = FullFillVerificationMiddleware = __decorate([
|
|
45
|
+
(0, common_1.Injectable)(),
|
|
46
|
+
__param(0, (0, common_1.Inject)('GET_CHALLENGE_BY_ID_SERVICE')),
|
|
47
|
+
__metadata("design:paramtypes", [microservices_1.ClientProxy])
|
|
48
|
+
], FullFillVerificationMiddleware);
|
|
49
|
+
//# sourceMappingURL=full-fill-verification.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"full-fill-verification.middleware.js","sourceRoot":"","sources":["../../src/middlewares/full-fill-verification.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAoE;AAEpE,yDAAoD;AACpD,+BAAsC;AACtC,iDAA8C;AAC9C,0EAAiE;AAG1D,IAAM,8BAA8B,GAApC,MAAM,8BAA8B;IACzC,YAEmB,eAA4B;QAA5B,oBAAe,GAAf,eAAe,CAAa;IAC5C,CAAC;IAEJ,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QACjD,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;YAC1B,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC;YAC3B,IAAI,UAAU,GAAG,GAAG,IAAI,UAAU,IAAI,GAAG,EAAE,CAAC;gBAC1C,OAAO,IAAI,EAAE,CAAC;YAChB,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAA,qBAAc,EACnC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,mBAAQ,CAAC,eAAe,EAAE;gBAClD,IAAI,EAAE;oBACJ,KAAK,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE;oBACnC,IAAI,EAAE,EAAE,MAAM,EAAE,uCAAe,CAAC,WAAW,EAAE;iBAC9C;aACF,CAAC,CACH,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,6CAA6C,EAAE,QAAQ,CAAC,CAAC;YACrE,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;QACH,IAAI,EAAE,CAAC;IACT,CAAC;CACF,CAAA;AAzBY,wEAA8B;yCAA9B,8BAA8B;IAD1C,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,eAAM,EAAC,6BAA6B,CAAC,CAAA;qCACJ,2BAAW;GAHpC,8BAA8B,CAyB1C"}
|
|
@@ -6,4 +6,5 @@ export declare class VerifyContactMiddleware implements NestMiddleware {
|
|
|
6
6
|
private readonly ContactClient;
|
|
7
7
|
constructor(ChallengeClient: ClientProxy, ContactClient: ClientProxy);
|
|
8
8
|
use(req: Request, res: Response, next: NextFunction): Promise<void>;
|
|
9
|
+
private getContact;
|
|
9
10
|
}
|
|
@@ -17,7 +17,6 @@ const common_1 = require("@nestjs/common");
|
|
|
17
17
|
const rxjs_1 = require("rxjs");
|
|
18
18
|
const subjects_1 = require("../events/subjects");
|
|
19
19
|
const microservices_1 = require("@nestjs/microservices");
|
|
20
|
-
const getHeaderParam_1 = require("../utils/getHeaderParam");
|
|
21
20
|
const challenge_status_enum_1 = require("../enums/challenge-status.enum");
|
|
22
21
|
let VerifyContactMiddleware = class VerifyContactMiddleware {
|
|
23
22
|
constructor(ChallengeClient, ContactClient) {
|
|
@@ -28,9 +27,13 @@ let VerifyContactMiddleware = class VerifyContactMiddleware {
|
|
|
28
27
|
var _a, _b;
|
|
29
28
|
console.log('req.body: ', req.body);
|
|
30
29
|
if (req.body.chalengeId) {
|
|
30
|
+
const contact = await this.getContact(req);
|
|
31
31
|
const response = await (0, rxjs_1.firstValueFrom)(this.ChallengeClient.send(subjects_1.Subjects.GetChallengeByQuery, {
|
|
32
32
|
data: {
|
|
33
|
-
query: {
|
|
33
|
+
query: {
|
|
34
|
+
_id: req.body.chalengeId,
|
|
35
|
+
email: contact === null || contact === void 0 ? void 0 : contact.email,
|
|
36
|
+
},
|
|
34
37
|
projection: [
|
|
35
38
|
'email',
|
|
36
39
|
'eventId',
|
|
@@ -44,38 +47,23 @@ let VerifyContactMiddleware = class VerifyContactMiddleware {
|
|
|
44
47
|
}));
|
|
45
48
|
console.log('response: ', response);
|
|
46
49
|
if (((_a = response === null || response === void 0 ? void 0 : response.result) === null || _a === void 0 ? void 0 : _a.data.length) === 0) {
|
|
47
|
-
throw new common_1.ConflictException('Invalid challenge
|
|
50
|
+
throw new common_1.ConflictException('Invalid challenge');
|
|
48
51
|
}
|
|
49
52
|
const challenge = (_b = response === null || response === void 0 ? void 0 : response.result) === null || _b === void 0 ? void 0 : _b.data[0];
|
|
50
53
|
console.log('challenge: ', challenge);
|
|
54
|
+
if ((challenge === null || challenge === void 0 ? void 0 : challenge.status) === challenge_status_enum_1.ChallengeStatus.FULL_FILLED) {
|
|
55
|
+
throw new common_1.ConflictException('Invalid challenge, code is already used');
|
|
56
|
+
}
|
|
51
57
|
if ((challenge === null || challenge === void 0 ? void 0 : challenge.status) === challenge_status_enum_1.ChallengeStatus.PENDING) {
|
|
52
|
-
throw new common_1.ConflictException('Verification process is incomplete, please finish it before proceeding
|
|
58
|
+
throw new common_1.ConflictException('Verification process is incomplete, please finish it before proceeding');
|
|
53
59
|
}
|
|
54
60
|
if ((challenge === null || challenge === void 0 ? void 0 : challenge.status) === challenge_status_enum_1.ChallengeStatus.EXPIRED) {
|
|
55
|
-
throw new common_1.ConflictException('Verification
|
|
61
|
+
throw new common_1.ConflictException('Verification code is expired');
|
|
56
62
|
}
|
|
57
63
|
}
|
|
58
64
|
else {
|
|
59
|
-
const contact = await
|
|
60
|
-
|
|
61
|
-
query: {
|
|
62
|
-
email: req.body.email,
|
|
63
|
-
eventId: (0, getHeaderParam_1.getHeaderParam)(req.headers, 'event-id'),
|
|
64
|
-
status: 'Active',
|
|
65
|
-
},
|
|
66
|
-
projection: [
|
|
67
|
-
'_id',
|
|
68
|
-
'firstname',
|
|
69
|
-
'lastname',
|
|
70
|
-
'email',
|
|
71
|
-
'eventId',
|
|
72
|
-
'status',
|
|
73
|
-
],
|
|
74
|
-
},
|
|
75
|
-
}));
|
|
76
|
-
console.log('contact: ', contact);
|
|
77
|
-
if (contact.length) {
|
|
78
|
-
console.log('>>>>>>>>>>>>>>>>>: ', contact);
|
|
65
|
+
const contact = await this.getContact(req);
|
|
66
|
+
if (contact) {
|
|
79
67
|
throw new common_1.ConflictException({
|
|
80
68
|
statusCode: 'auth_challenge_code',
|
|
81
69
|
message: 'Auth Challenge is required',
|
|
@@ -84,6 +72,26 @@ let VerifyContactMiddleware = class VerifyContactMiddleware {
|
|
|
84
72
|
}
|
|
85
73
|
next();
|
|
86
74
|
}
|
|
75
|
+
async getContact(req) {
|
|
76
|
+
const contact = await (0, rxjs_1.firstValueFrom)(this.ContactClient.send(subjects_1.Subjects.ContactsByQuery, {
|
|
77
|
+
data: {
|
|
78
|
+
query: {
|
|
79
|
+
email: req.body.email,
|
|
80
|
+
status: 'Active',
|
|
81
|
+
},
|
|
82
|
+
projection: [
|
|
83
|
+
'_id',
|
|
84
|
+
'firstname',
|
|
85
|
+
'lastname',
|
|
86
|
+
'email',
|
|
87
|
+
'eventId',
|
|
88
|
+
'status',
|
|
89
|
+
],
|
|
90
|
+
},
|
|
91
|
+
}));
|
|
92
|
+
console.log('contact: ', contact);
|
|
93
|
+
return contact.length ? contact[0] : null;
|
|
94
|
+
}
|
|
87
95
|
};
|
|
88
96
|
exports.VerifyContactMiddleware = VerifyContactMiddleware;
|
|
89
97
|
exports.VerifyContactMiddleware = VerifyContactMiddleware = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"verify-contact.middleware.js","sourceRoot":"","sources":["../../src/middlewares/verify-contact.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,+BAAsC;AACtC,iDAA4C;AAC5C,yDAAoD;
|
|
1
|
+
{"version":3,"file":"verify-contact.middleware.js","sourceRoot":"","sources":["../../src/middlewares/verify-contact.middleware.ts"],"names":[],"mappings":"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"}
|