@venturialstd/kyc 0.0.1
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/README.md +278 -0
- package/dist/constants/kyc.constant.d.ts +47 -0
- package/dist/constants/kyc.constant.d.ts.map +1 -0
- package/dist/constants/kyc.constant.js +55 -0
- package/dist/constants/kyc.constant.js.map +1 -0
- package/dist/dtos/create-kyc-profile.dto.d.ts +20 -0
- package/dist/dtos/create-kyc-profile.dto.d.ts.map +1 -0
- package/dist/dtos/create-kyc-profile.dto.js +113 -0
- package/dist/dtos/create-kyc-profile.dto.js.map +1 -0
- package/dist/dtos/update-kyc-profile.dto.d.ts +6 -0
- package/dist/dtos/update-kyc-profile.dto.d.ts.map +1 -0
- package/dist/dtos/update-kyc-profile.dto.js +9 -0
- package/dist/dtos/update-kyc-profile.dto.js.map +1 -0
- package/dist/entities/kyc-document.entity.d.ts +26 -0
- package/dist/entities/kyc-document.entity.d.ts.map +1 -0
- package/dist/entities/kyc-document.entity.js +177 -0
- package/dist/entities/kyc-document.entity.js.map +1 -0
- package/dist/entities/kyc-profile.entity.d.ts +31 -0
- package/dist/entities/kyc-profile.entity.d.ts.map +1 -0
- package/dist/entities/kyc-profile.entity.js +213 -0
- package/dist/entities/kyc-profile.entity.js.map +1 -0
- package/dist/entities/kyc-verification.entity.d.ts +21 -0
- package/dist/entities/kyc-verification.entity.d.ts.map +1 -0
- package/dist/entities/kyc-verification.entity.js +135 -0
- package/dist/entities/kyc-verification.entity.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/kyc-provider.interface.d.ts +98 -0
- package/dist/interfaces/kyc-provider.interface.d.ts.map +1 -0
- package/dist/interfaces/kyc-provider.interface.js +12 -0
- package/dist/interfaces/kyc-provider.interface.js.map +1 -0
- package/dist/kyc.module.d.ts +12 -0
- package/dist/kyc.module.d.ts.map +1 -0
- package/dist/kyc.module.js +65 -0
- package/dist/kyc.module.js.map +1 -0
- package/dist/providers/aiprise.provider.d.ts +9 -0
- package/dist/providers/aiprise.provider.d.ts.map +1 -0
- package/dist/providers/aiprise.provider.js +73 -0
- package/dist/providers/aiprise.provider.js.map +1 -0
- package/dist/providers/index.d.ts +2 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +18 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/services/kyc-provider.service.d.ts +18 -0
- package/dist/services/kyc-provider.service.d.ts.map +1 -0
- package/dist/services/kyc-provider.service.js +179 -0
- package/dist/services/kyc-provider.service.js.map +1 -0
- package/dist/services/kyc.service.d.ts +15 -0
- package/dist/services/kyc.service.d.ts.map +1 -0
- package/dist/services/kyc.service.js +96 -0
- package/dist/services/kyc.service.js.map +1 -0
- package/package.json +42 -0
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
export interface KYCProvider {
|
|
2
|
+
readonly name: string;
|
|
3
|
+
createVerificationSession(userId: string, userData: ProviderUserData): Promise<ProviderVerificationSession>;
|
|
4
|
+
getVerificationStatus(sessionId: string): Promise<ProviderVerificationResult>;
|
|
5
|
+
handleWebhook(payload: unknown): Promise<ProviderWebhookEvent>;
|
|
6
|
+
uploadDocument(sessionId: string, documentData: ProviderDocumentData): Promise<ProviderDocumentResponse>;
|
|
7
|
+
}
|
|
8
|
+
export interface ProviderUserData {
|
|
9
|
+
firstName?: string;
|
|
10
|
+
lastName?: string;
|
|
11
|
+
email?: string;
|
|
12
|
+
phone?: string;
|
|
13
|
+
dateOfBirth?: string;
|
|
14
|
+
nationality?: string;
|
|
15
|
+
[key: string]: unknown;
|
|
16
|
+
}
|
|
17
|
+
export interface ProviderVerificationSession {
|
|
18
|
+
sessionId: string;
|
|
19
|
+
clientReferenceId: string;
|
|
20
|
+
redirectUrl?: string;
|
|
21
|
+
widgetConfig?: Record<string, unknown>;
|
|
22
|
+
expiresAt?: Date;
|
|
23
|
+
metadata?: Record<string, unknown>;
|
|
24
|
+
}
|
|
25
|
+
export interface ProviderVerificationResult {
|
|
26
|
+
sessionId: string;
|
|
27
|
+
status: ProviderVerificationStatus;
|
|
28
|
+
result: 'APPROVED' | 'REJECTED' | 'PENDING' | 'REVIEW';
|
|
29
|
+
confidenceScore?: number;
|
|
30
|
+
summary?: Record<string, unknown>;
|
|
31
|
+
documents?: ProviderDocumentResult[];
|
|
32
|
+
faceMatch?: ProviderFaceMatchResult;
|
|
33
|
+
liveness?: ProviderLivenessResult;
|
|
34
|
+
amlCheck?: ProviderAMLResult;
|
|
35
|
+
fraudInsights?: ProviderFraudInsights;
|
|
36
|
+
metadata?: Record<string, unknown>;
|
|
37
|
+
}
|
|
38
|
+
export declare enum ProviderVerificationStatus {
|
|
39
|
+
PENDING = "PENDING",
|
|
40
|
+
IN_PROGRESS = "IN_PROGRESS",
|
|
41
|
+
COMPLETED = "COMPLETED",
|
|
42
|
+
FAILED = "FAILED",
|
|
43
|
+
EXPIRED = "EXPIRED"
|
|
44
|
+
}
|
|
45
|
+
export interface ProviderDocumentData {
|
|
46
|
+
type: string;
|
|
47
|
+
side?: 'FRONT' | 'BACK';
|
|
48
|
+
fileUrl?: string;
|
|
49
|
+
fileBase64?: string;
|
|
50
|
+
fileName?: string;
|
|
51
|
+
metadata?: Record<string, unknown>;
|
|
52
|
+
}
|
|
53
|
+
export interface ProviderDocumentResponse {
|
|
54
|
+
documentId: string;
|
|
55
|
+
status: string;
|
|
56
|
+
extractedData?: Record<string, unknown>;
|
|
57
|
+
metadata?: Record<string, unknown>;
|
|
58
|
+
}
|
|
59
|
+
export interface ProviderDocumentResult {
|
|
60
|
+
documentId: string;
|
|
61
|
+
type: string;
|
|
62
|
+
status: 'VERIFIED' | 'REJECTED' | 'PENDING';
|
|
63
|
+
extractedData?: Record<string, unknown>;
|
|
64
|
+
confidenceScore?: number;
|
|
65
|
+
}
|
|
66
|
+
export interface ProviderFaceMatchResult {
|
|
67
|
+
matched: boolean;
|
|
68
|
+
confidenceScore?: number;
|
|
69
|
+
details?: Record<string, unknown>;
|
|
70
|
+
}
|
|
71
|
+
export interface ProviderLivenessResult {
|
|
72
|
+
passed: boolean;
|
|
73
|
+
confidenceScore?: number;
|
|
74
|
+
method?: string;
|
|
75
|
+
details?: Record<string, unknown>;
|
|
76
|
+
}
|
|
77
|
+
export interface ProviderAMLResult {
|
|
78
|
+
status: 'CLEAR' | 'MATCH' | 'PENDING';
|
|
79
|
+
matches?: Array<{
|
|
80
|
+
list: string;
|
|
81
|
+
name: string;
|
|
82
|
+
score?: number;
|
|
83
|
+
}>;
|
|
84
|
+
details?: Record<string, unknown>;
|
|
85
|
+
}
|
|
86
|
+
export interface ProviderFraudInsights {
|
|
87
|
+
riskScore?: number;
|
|
88
|
+
flags?: string[];
|
|
89
|
+
details?: Record<string, unknown>;
|
|
90
|
+
}
|
|
91
|
+
export interface ProviderWebhookEvent {
|
|
92
|
+
eventType: string;
|
|
93
|
+
sessionId: string;
|
|
94
|
+
clientReferenceId?: string;
|
|
95
|
+
timestamp: Date;
|
|
96
|
+
data: Record<string, unknown>;
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=kyc-provider.interface.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc-provider.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/kyc-provider.interface.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProviderVerificationStatus = void 0;
|
|
4
|
+
var ProviderVerificationStatus;
|
|
5
|
+
(function (ProviderVerificationStatus) {
|
|
6
|
+
ProviderVerificationStatus["PENDING"] = "PENDING";
|
|
7
|
+
ProviderVerificationStatus["IN_PROGRESS"] = "IN_PROGRESS";
|
|
8
|
+
ProviderVerificationStatus["COMPLETED"] = "COMPLETED";
|
|
9
|
+
ProviderVerificationStatus["FAILED"] = "FAILED";
|
|
10
|
+
ProviderVerificationStatus["EXPIRED"] = "EXPIRED";
|
|
11
|
+
})(ProviderVerificationStatus || (exports.ProviderVerificationStatus = ProviderVerificationStatus = {}));
|
|
12
|
+
//# sourceMappingURL=kyc-provider.interface.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc-provider.interface.js","sourceRoot":"","sources":["../../src/interfaces/kyc-provider.interface.ts"],"names":[],"mappings":";;;AAkFA,IAAY,0BAMX;AAND,WAAY,0BAA0B;IACpC,iDAAmB,CAAA;IACnB,yDAA2B,CAAA;IAC3B,qDAAuB,CAAA;IACvB,+CAAiB,CAAA;IACjB,iDAAmB,CAAA;AACrB,CAAC,EANW,0BAA0B,0CAA1B,0BAA0B,QAMrC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { DynamicModule, Type } from '@nestjs/common';
|
|
2
|
+
import { KYCProvider } from './interfaces/kyc-provider.interface';
|
|
3
|
+
export interface KYCModuleOptions {
|
|
4
|
+
additionalEntities?: Type[];
|
|
5
|
+
providers?: Type<KYCProvider>[];
|
|
6
|
+
registerDefaultProviders?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare class KYCModule {
|
|
9
|
+
static forRoot(options?: KYCModuleOptions): DynamicModule;
|
|
10
|
+
static forFeature(): DynamicModule;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=kyc.module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc.module.d.ts","sourceRoot":"","sources":["../src/kyc.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAU,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAO7D,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAKlE,MAAM,WAAW,gBAAgB;IAI/B,kBAAkB,CAAC,EAAE,IAAI,EAAE,CAAC;IAM5B,SAAS,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;IAMhC,wBAAwB,CAAC,EAAE,OAAO,CAAC;CACpC;AAED,qBACa,SAAS;IAKpB,MAAM,CAAC,OAAO,CAAC,OAAO,GAAE,gBAAqB,GAAG,aAAa;IA6C7D,MAAM,CAAC,UAAU,IAAI,aAAa;CAGnC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
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 KYCModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.KYCModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
13
|
+
const core_1 = require("@venturialstd/core");
|
|
14
|
+
const kyc_document_entity_1 = require("./entities/kyc-document.entity");
|
|
15
|
+
const kyc_profile_entity_1 = require("./entities/kyc-profile.entity");
|
|
16
|
+
const kyc_verification_entity_1 = require("./entities/kyc-verification.entity");
|
|
17
|
+
const aiprise_provider_1 = require("./providers/aiprise.provider");
|
|
18
|
+
const kyc_provider_service_1 = require("./services/kyc-provider.service");
|
|
19
|
+
const kyc_service_1 = require("./services/kyc.service");
|
|
20
|
+
let KYCModule = KYCModule_1 = class KYCModule {
|
|
21
|
+
static forRoot(options = {}) {
|
|
22
|
+
const entities = [
|
|
23
|
+
kyc_profile_entity_1.KYCProfile,
|
|
24
|
+
kyc_document_entity_1.KYCDocument,
|
|
25
|
+
kyc_verification_entity_1.KYCVerification,
|
|
26
|
+
...(options.additionalEntities || []),
|
|
27
|
+
];
|
|
28
|
+
const registerDefaultProviders = options.registerDefaultProviders !== false;
|
|
29
|
+
const customProviders = options.providers || [];
|
|
30
|
+
const providerClasses = [];
|
|
31
|
+
if (registerDefaultProviders) {
|
|
32
|
+
providerClasses.push(aiprise_provider_1.AIPRISEProvider);
|
|
33
|
+
}
|
|
34
|
+
providerClasses.push(...customProviders);
|
|
35
|
+
return {
|
|
36
|
+
module: KYCModule_1,
|
|
37
|
+
imports: [core_1.SharedModule, typeorm_1.TypeOrmModule.forFeature(entities)],
|
|
38
|
+
providers: [
|
|
39
|
+
kyc_service_1.KYCService,
|
|
40
|
+
kyc_provider_service_1.KYCProviderService,
|
|
41
|
+
...providerClasses,
|
|
42
|
+
{
|
|
43
|
+
provide: 'KYC_PROVIDER_INIT',
|
|
44
|
+
useFactory: (providerService, ...providers) => {
|
|
45
|
+
providers.forEach((provider) => {
|
|
46
|
+
providerService.registerProvider(provider);
|
|
47
|
+
});
|
|
48
|
+
return providers;
|
|
49
|
+
},
|
|
50
|
+
inject: [kyc_provider_service_1.KYCProviderService, ...providerClasses],
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
controllers: [],
|
|
54
|
+
exports: [kyc_service_1.KYCService, kyc_provider_service_1.KYCProviderService],
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
static forFeature() {
|
|
58
|
+
return KYCModule_1.forRoot({});
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
exports.KYCModule = KYCModule;
|
|
62
|
+
exports.KYCModule = KYCModule = KYCModule_1 = __decorate([
|
|
63
|
+
(0, common_1.Module)({})
|
|
64
|
+
], KYCModule);
|
|
65
|
+
//# sourceMappingURL=kyc.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc.module.js","sourceRoot":"","sources":["../src/kyc.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAA6D;AAC7D,6CAAgD;AAChD,6CAAkD;AAElD,wEAA6D;AAC7D,sEAA2D;AAC3D,gFAAqE;AAErE,mEAA+D;AAC/D,0EAAqE;AACrE,wDAAoD;AAsB7C,IAAM,SAAS,iBAAf,MAAM,SAAS;IAKpB,MAAM,CAAC,OAAO,CAAC,UAA4B,EAAE;QAC3C,MAAM,QAAQ,GAAG;YACf,+BAAU;YACV,iCAAW;YACX,yCAAe;YACf,GAAG,CAAC,OAAO,CAAC,kBAAkB,IAAI,EAAE,CAAC;SACtC,CAAC;QAEF,MAAM,wBAAwB,GAAG,OAAO,CAAC,wBAAwB,KAAK,KAAK,CAAC;QAC5E,MAAM,eAAe,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;QAGhD,MAAM,eAAe,GAAwB,EAAE,CAAC;QAChD,IAAI,wBAAwB,EAAE,CAAC;YAC7B,eAAe,CAAC,IAAI,CAAC,kCAAe,CAAC,CAAC;QACxC,CAAC;QACD,eAAe,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,CAAC;QAEzC,OAAO;YACL,MAAM,EAAE,WAAS;YACjB,OAAO,EAAE,CAAC,mBAAY,EAAE,uBAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC3D,SAAS,EAAE;gBACT,wBAAU;gBACV,yCAAkB;gBAClB,GAAG,eAAe;gBAClB;oBACE,OAAO,EAAE,mBAAmB;oBAC5B,UAAU,EAAE,CAAC,eAAmC,EAAE,GAAG,SAAwB,EAAE,EAAE;wBAC/E,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;4BAC7B,eAAe,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;wBAC7C,CAAC,CAAC,CAAC;wBACH,OAAO,SAAS,CAAC;oBACnB,CAAC;oBACD,MAAM,EAAE,CAAC,yCAAkB,EAAE,GAAG,eAAe,CAAC;iBACjD;aACF;YACD,WAAW,EAAE,EAAE;YACf,OAAO,EAAE,CAAC,wBAAU,EAAE,yCAAkB,CAAC;SAC1C,CAAC;IACJ,CAAC;IAMD,MAAM,CAAC,UAAU;QACf,OAAO,WAAS,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;CACF,CAAA;AArDY,8BAAS;oBAAT,SAAS;IADrB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,SAAS,CAqDrB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { KYCProvider, ProviderDocumentData, ProviderDocumentResponse, ProviderUserData, ProviderVerificationResult, ProviderVerificationSession, ProviderWebhookEvent } from '../interfaces/kyc-provider.interface';
|
|
2
|
+
export declare class AIPRISEProvider implements KYCProvider {
|
|
3
|
+
readonly name = "AIPRISE";
|
|
4
|
+
createVerificationSession(userId: string, userData: ProviderUserData): Promise<ProviderVerificationSession>;
|
|
5
|
+
getVerificationStatus(sessionId: string): Promise<ProviderVerificationResult>;
|
|
6
|
+
handleWebhook(payload: unknown): Promise<ProviderWebhookEvent>;
|
|
7
|
+
uploadDocument(sessionId: string, documentData: ProviderDocumentData): Promise<ProviderDocumentResponse>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=aiprise.provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aiprise.provider.d.ts","sourceRoot":"","sources":["../../src/providers/aiprise.provider.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,WAAW,EACX,oBAAoB,EACpB,wBAAwB,EACxB,gBAAgB,EAChB,0BAA0B,EAC1B,2BAA2B,EAE3B,oBAAoB,EACrB,MAAM,sCAAsC,CAAC;AAU9C,qBACa,eAAgB,YAAW,WAAW;IACjD,QAAQ,CAAC,IAAI,aAAa;IAQpB,yBAAyB,CAC7B,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,gBAAgB,GACzB,OAAO,CAAC,2BAA2B,CAAC;IA2BjC,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,0BAA0B,CAAC;IA2B7E,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAmB9D,cAAc,CAClB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,oBAAoB,GACjC,OAAO,CAAC,wBAAwB,CAAC;CAkBrC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AIPRISEProvider = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const kyc_provider_interface_1 = require("../interfaces/kyc-provider.interface");
|
|
12
|
+
let AIPRISEProvider = class AIPRISEProvider {
|
|
13
|
+
name = 'AIPRISE';
|
|
14
|
+
async createVerificationSession(userId, userData) {
|
|
15
|
+
return {
|
|
16
|
+
sessionId: 'aiprise_session_123',
|
|
17
|
+
clientReferenceId: userId,
|
|
18
|
+
redirectUrl: 'https://verify.aiprise.com/session/123',
|
|
19
|
+
widgetConfig: {
|
|
20
|
+
templateId: 'your_template_id',
|
|
21
|
+
environment: 'sandbox',
|
|
22
|
+
},
|
|
23
|
+
metadata: {
|
|
24
|
+
provider: 'AIPRISE',
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
async getVerificationStatus(sessionId) {
|
|
29
|
+
return {
|
|
30
|
+
sessionId,
|
|
31
|
+
status: kyc_provider_interface_1.ProviderVerificationStatus.COMPLETED,
|
|
32
|
+
result: 'APPROVED',
|
|
33
|
+
confidenceScore: 95,
|
|
34
|
+
summary: {},
|
|
35
|
+
faceMatch: {
|
|
36
|
+
matched: true,
|
|
37
|
+
confidenceScore: 98,
|
|
38
|
+
},
|
|
39
|
+
liveness: {
|
|
40
|
+
passed: true,
|
|
41
|
+
confidenceScore: 97,
|
|
42
|
+
},
|
|
43
|
+
metadata: {
|
|
44
|
+
provider: 'AIPRISE',
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
async handleWebhook(payload) {
|
|
49
|
+
const event = payload;
|
|
50
|
+
return {
|
|
51
|
+
eventType: event.event_type,
|
|
52
|
+
sessionId: event.verification_session_id,
|
|
53
|
+
clientReferenceId: event.client_reference_id,
|
|
54
|
+
timestamp: event.timestamp ? new Date(event.timestamp) : new Date(),
|
|
55
|
+
data: event,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
async uploadDocument(sessionId, documentData) {
|
|
59
|
+
return {
|
|
60
|
+
documentId: 'doc_123',
|
|
61
|
+
status: 'UPLOADED',
|
|
62
|
+
extractedData: {},
|
|
63
|
+
metadata: {
|
|
64
|
+
provider: 'AIPRISE',
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
exports.AIPRISEProvider = AIPRISEProvider;
|
|
70
|
+
exports.AIPRISEProvider = AIPRISEProvider = __decorate([
|
|
71
|
+
(0, common_1.Injectable)()
|
|
72
|
+
], AIPRISEProvider);
|
|
73
|
+
//# sourceMappingURL=aiprise.provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aiprise.provider.js","sourceRoot":"","sources":["../../src/providers/aiprise.provider.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAE5C,iFAS8C;AAWvC,IAAM,eAAe,GAArB,MAAM,eAAe;IACjB,IAAI,GAAG,SAAS,CAAC;IAQ1B,KAAK,CAAC,yBAAyB,CAC7B,MAAc,EACd,QAA0B;QAc1B,OAAO;YACL,SAAS,EAAE,qBAAqB;YAChC,iBAAiB,EAAE,MAAM;YACzB,WAAW,EAAE,wCAAwC;YACrD,YAAY,EAAE;gBACZ,UAAU,EAAE,kBAAkB;gBAC9B,WAAW,EAAE,SAAS;aACvB;YACD,QAAQ,EAAE;gBACR,QAAQ,EAAE,SAAS;aACpB;SACF,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,qBAAqB,CAAC,SAAiB;QAK3C,OAAO;YACL,SAAS;YACT,MAAM,EAAE,mDAA0B,CAAC,SAAS;YAC5C,MAAM,EAAE,UAAU;YAClB,eAAe,EAAE,EAAE;YACnB,OAAO,EAAE,EAER;YACD,SAAS,EAAE;gBACT,OAAO,EAAE,IAAI;gBACb,eAAe,EAAE,EAAE;aACpB;YACD,QAAQ,EAAE;gBACR,MAAM,EAAE,IAAI;gBACZ,eAAe,EAAE,EAAE;aACpB;YACD,QAAQ,EAAE;gBACR,QAAQ,EAAE,SAAS;aACpB;SACF,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,OAAgB;QAElC,MAAM,KAAK,GAAG,OAMb,CAAC;QAEF,OAAO;YACL,SAAS,EAAE,KAAK,CAAC,UAAU;YAC3B,SAAS,EAAE,KAAK,CAAC,uBAAuB;YACxC,iBAAiB,EAAE,KAAK,CAAC,mBAAmB;YAC5C,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;YACnE,IAAI,EAAE,KAAK;SACZ,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,cAAc,CAClB,SAAiB,EACjB,YAAkC;QAUlC,OAAO;YACL,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE,UAAU;YAClB,aAAa,EAAE,EAAE;YACjB,QAAQ,EAAE;gBACR,QAAQ,EAAE,SAAS;aACpB;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AA1GY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,mBAAU,GAAE;GACA,eAAe,CA0G3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC"}
|
|
@@ -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("./aiprise.provider"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { KYCProvider, ProviderVerificationSession } from '../interfaces/kyc-provider.interface';
|
|
3
|
+
import { KYCProfile } from '../entities/kyc-profile.entity';
|
|
4
|
+
import { KYCVerification } from '../entities/kyc-verification.entity';
|
|
5
|
+
export declare class KYCProviderService {
|
|
6
|
+
private readonly kycProfileRepository;
|
|
7
|
+
private readonly kycVerificationRepository;
|
|
8
|
+
private providers;
|
|
9
|
+
constructor(kycProfileRepository: Repository<KYCProfile>, kycVerificationRepository: Repository<KYCVerification>);
|
|
10
|
+
registerProvider(provider: KYCProvider): void;
|
|
11
|
+
getProvider(name: string): KYCProvider | undefined;
|
|
12
|
+
getProviders(): KYCProvider[];
|
|
13
|
+
createVerification(userId: string, providerName: string, userData: Parameters<KYCProvider['createVerificationSession']>[1]): Promise<ProviderVerificationSession>;
|
|
14
|
+
syncVerificationResult(providerName: string, sessionId: string): Promise<KYCProfile | null>;
|
|
15
|
+
handleProviderWebhook(providerName: string, payload: unknown): Promise<KYCProfile | null>;
|
|
16
|
+
private mapProviderStatusToKYCStatus;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=kyc-provider.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc-provider.service.d.ts","sourceRoot":"","sources":["../../src/services/kyc-provider.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EACL,WAAW,EAEX,2BAA2B,EAE5B,MAAM,sCAAsC,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAMtE,qBACa,kBAAkB;IAK3B,OAAO,CAAC,QAAQ,CAAC,oBAAoB;IAErC,OAAO,CAAC,QAAQ,CAAC,yBAAyB;IAN5C,OAAO,CAAC,SAAS,CAAuC;gBAIrC,oBAAoB,EAAE,UAAU,CAAC,UAAU,CAAC,EAE5C,yBAAyB,EAAE,UAAU,CAAC,eAAe,CAAC;IAMzE,gBAAgB,CAAC,QAAQ,EAAE,WAAW,GAAG,IAAI;IAO7C,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS;IAOlD,YAAY,IAAI,WAAW,EAAE;IAOvB,kBAAkB,CACtB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,UAAU,CAAC,WAAW,CAAC,2BAA2B,CAAC,CAAC,CAAC,CAAC,CAAC,GAChE,OAAO,CAAC,2BAA2B,CAAC;IAiEjC,sBAAsB,CAC1B,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IA2EvB,qBAAqB,CACzB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAyB7B,OAAO,CAAC,4BAA4B;CAarC"}
|
|
@@ -0,0 +1,179 @@
|
|
|
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.KYCProviderService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
|
+
const typeorm_2 = require("typeorm");
|
|
19
|
+
const kyc_constant_1 = require("../constants/kyc.constant");
|
|
20
|
+
const kyc_profile_entity_1 = require("../entities/kyc-profile.entity");
|
|
21
|
+
const kyc_verification_entity_1 = require("../entities/kyc-verification.entity");
|
|
22
|
+
let KYCProviderService = class KYCProviderService {
|
|
23
|
+
kycProfileRepository;
|
|
24
|
+
kycVerificationRepository;
|
|
25
|
+
providers = new Map();
|
|
26
|
+
constructor(kycProfileRepository, kycVerificationRepository) {
|
|
27
|
+
this.kycProfileRepository = kycProfileRepository;
|
|
28
|
+
this.kycVerificationRepository = kycVerificationRepository;
|
|
29
|
+
}
|
|
30
|
+
registerProvider(provider) {
|
|
31
|
+
this.providers.set(provider.name, provider);
|
|
32
|
+
}
|
|
33
|
+
getProvider(name) {
|
|
34
|
+
return this.providers.get(name);
|
|
35
|
+
}
|
|
36
|
+
getProviders() {
|
|
37
|
+
return Array.from(this.providers.values());
|
|
38
|
+
}
|
|
39
|
+
async createVerification(userId, providerName, userData) {
|
|
40
|
+
const provider = this.getProvider(providerName);
|
|
41
|
+
if (!provider) {
|
|
42
|
+
throw new Error(`KYC provider not found: ${providerName}`);
|
|
43
|
+
}
|
|
44
|
+
const session = await provider.createVerificationSession(userId, userData);
|
|
45
|
+
let profile = await this.kycProfileRepository.findOne({
|
|
46
|
+
where: { userId },
|
|
47
|
+
});
|
|
48
|
+
if (!profile) {
|
|
49
|
+
profile = this.kycProfileRepository.create({
|
|
50
|
+
userId,
|
|
51
|
+
status: kyc_constant_1.KYC_STATUS.IN_PROGRESS,
|
|
52
|
+
});
|
|
53
|
+
await this.kycProfileRepository.save(profile);
|
|
54
|
+
}
|
|
55
|
+
let verification = await this.kycVerificationRepository.findOne({
|
|
56
|
+
where: {
|
|
57
|
+
kycProfileId: profile.id,
|
|
58
|
+
verificationType: 'EXTERNAL_PROVIDER',
|
|
59
|
+
provider: providerName,
|
|
60
|
+
},
|
|
61
|
+
});
|
|
62
|
+
if (!verification) {
|
|
63
|
+
verification = this.kycVerificationRepository.create({
|
|
64
|
+
kycProfileId: profile.id,
|
|
65
|
+
verificationType: 'EXTERNAL_PROVIDER',
|
|
66
|
+
provider: providerName,
|
|
67
|
+
providerVerificationId: session.sessionId,
|
|
68
|
+
status: kyc_constant_1.KYC_STATUS.IN_PROGRESS,
|
|
69
|
+
metadata: {
|
|
70
|
+
clientReferenceId: session.clientReferenceId,
|
|
71
|
+
...session.metadata,
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
verification.providerVerificationId = session.sessionId;
|
|
77
|
+
verification.status = kyc_constant_1.KYC_STATUS.IN_PROGRESS;
|
|
78
|
+
verification.metadata = {
|
|
79
|
+
...verification.metadata,
|
|
80
|
+
clientReferenceId: session.clientReferenceId,
|
|
81
|
+
...session.metadata,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
await this.kycVerificationRepository.save(verification);
|
|
85
|
+
profile.status = kyc_constant_1.KYC_STATUS.IN_PROGRESS;
|
|
86
|
+
await this.kycProfileRepository.save(profile);
|
|
87
|
+
return session;
|
|
88
|
+
}
|
|
89
|
+
async syncVerificationResult(providerName, sessionId) {
|
|
90
|
+
const provider = this.getProvider(providerName);
|
|
91
|
+
if (!provider) {
|
|
92
|
+
throw new Error(`KYC provider not found: ${providerName}`);
|
|
93
|
+
}
|
|
94
|
+
const result = await provider.getVerificationStatus(sessionId);
|
|
95
|
+
const verification = await this.kycVerificationRepository.findOne({
|
|
96
|
+
where: {
|
|
97
|
+
provider: providerName,
|
|
98
|
+
providerVerificationId: sessionId,
|
|
99
|
+
},
|
|
100
|
+
relations: ['kycProfile'],
|
|
101
|
+
});
|
|
102
|
+
if (!verification) {
|
|
103
|
+
throw new Error(`Verification not found for session: ${sessionId}`);
|
|
104
|
+
}
|
|
105
|
+
const profile = verification.kycProfile;
|
|
106
|
+
verification.status = this.mapProviderStatusToKYCStatus(result.status);
|
|
107
|
+
verification.providerResponse = result;
|
|
108
|
+
if (result.confidenceScore !== undefined) {
|
|
109
|
+
verification.confidenceScore = result.confidenceScore;
|
|
110
|
+
}
|
|
111
|
+
verification.verifiedAt = new Date();
|
|
112
|
+
if (result.result === 'APPROVED') {
|
|
113
|
+
verification.status = kyc_constant_1.KYC_STATUS.APPROVED;
|
|
114
|
+
}
|
|
115
|
+
else if (result.result === 'REJECTED') {
|
|
116
|
+
verification.status = kyc_constant_1.KYC_STATUS.REJECTED;
|
|
117
|
+
verification.rejectionReason = JSON.stringify(result.summary);
|
|
118
|
+
}
|
|
119
|
+
await this.kycVerificationRepository.save(verification);
|
|
120
|
+
if (result.result === 'APPROVED') {
|
|
121
|
+
profile.status = kyc_constant_1.KYC_STATUS.APPROVED;
|
|
122
|
+
profile.approvedAt = new Date();
|
|
123
|
+
profile.verificationLevel = kyc_constant_1.KYC_VERIFICATION_LEVEL.FULL;
|
|
124
|
+
}
|
|
125
|
+
else if (result.result === 'REJECTED') {
|
|
126
|
+
profile.status = kyc_constant_1.KYC_STATUS.REJECTED;
|
|
127
|
+
profile.rejectedAt = new Date();
|
|
128
|
+
profile.rejectionReason = JSON.stringify(result.summary);
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
profile.status = kyc_constant_1.KYC_STATUS.UNDER_REVIEW;
|
|
132
|
+
}
|
|
133
|
+
profile.metadata = {
|
|
134
|
+
...profile.metadata,
|
|
135
|
+
providerResults: {
|
|
136
|
+
[providerName]: {
|
|
137
|
+
sessionId,
|
|
138
|
+
result: result.result,
|
|
139
|
+
summary: result.summary,
|
|
140
|
+
confidenceScore: result.confidenceScore,
|
|
141
|
+
},
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
await this.kycProfileRepository.save(profile);
|
|
145
|
+
return profile;
|
|
146
|
+
}
|
|
147
|
+
async handleProviderWebhook(providerName, payload) {
|
|
148
|
+
const provider = this.getProvider(providerName);
|
|
149
|
+
if (!provider) {
|
|
150
|
+
throw new Error(`KYC provider not found: ${providerName}`);
|
|
151
|
+
}
|
|
152
|
+
const event = await provider.handleWebhook(payload);
|
|
153
|
+
if (event.eventType === 'VERIFICATION_COMPLETED' ||
|
|
154
|
+
event.eventType === 'CASE_STATUS_UPDATE' ||
|
|
155
|
+
event.eventType === 'VERIFICATION_SESSION_COMPLETION') {
|
|
156
|
+
return this.syncVerificationResult(providerName, event.sessionId);
|
|
157
|
+
}
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
mapProviderStatusToKYCStatus(providerStatus) {
|
|
161
|
+
const statusMap = {
|
|
162
|
+
PENDING: kyc_constant_1.KYC_STATUS.PENDING,
|
|
163
|
+
IN_PROGRESS: kyc_constant_1.KYC_STATUS.IN_PROGRESS,
|
|
164
|
+
COMPLETED: kyc_constant_1.KYC_STATUS.SUBMITTED,
|
|
165
|
+
FAILED: kyc_constant_1.KYC_STATUS.REJECTED,
|
|
166
|
+
EXPIRED: kyc_constant_1.KYC_STATUS.EXPIRED,
|
|
167
|
+
};
|
|
168
|
+
return statusMap[providerStatus] || kyc_constant_1.KYC_STATUS.PENDING;
|
|
169
|
+
}
|
|
170
|
+
};
|
|
171
|
+
exports.KYCProviderService = KYCProviderService;
|
|
172
|
+
exports.KYCProviderService = KYCProviderService = __decorate([
|
|
173
|
+
(0, common_1.Injectable)(),
|
|
174
|
+
__param(0, (0, typeorm_1.InjectRepository)(kyc_profile_entity_1.KYCProfile)),
|
|
175
|
+
__param(1, (0, typeorm_1.InjectRepository)(kyc_verification_entity_1.KYCVerification)),
|
|
176
|
+
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
177
|
+
typeorm_2.Repository])
|
|
178
|
+
], KYCProviderService);
|
|
179
|
+
//# sourceMappingURL=kyc-provider.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc-provider.service.js","sourceRoot":"","sources":["../../src/services/kyc-provider.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
2
|
+
import { Repository } from 'typeorm';
|
|
3
|
+
import { KYC_STATUS, KYC_VERIFICATION_LEVEL } from '../constants/kyc.constant';
|
|
4
|
+
import { KYCProfile } from '../entities/kyc-profile.entity';
|
|
5
|
+
export declare class KYCService extends TypeOrmCrudService<KYCProfile> {
|
|
6
|
+
readonly repo: Repository<KYCProfile>;
|
|
7
|
+
constructor(repo: Repository<KYCProfile>);
|
|
8
|
+
findByUserId(userId: string): Promise<KYCProfile | null>;
|
|
9
|
+
createOrUpdateProfile(userId: string, data: Partial<KYCProfile>): Promise<KYCProfile>;
|
|
10
|
+
updateStatus(profileId: string, status: KYC_STATUS, reviewedBy?: string, notes?: string): Promise<KYCProfile>;
|
|
11
|
+
updateVerificationLevel(profileId: string, level: KYC_VERIFICATION_LEVEL): Promise<KYCProfile>;
|
|
12
|
+
isKYCCompleted(userId: string): Promise<boolean>;
|
|
13
|
+
getVerificationLevel(userId: string): Promise<KYC_VERIFICATION_LEVEL | null>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=kyc.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kyc.service.d.ts","sourceRoot":"","sources":["../../src/services/kyc.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,UAAU,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBACa,UAAW,SAAQ,kBAAkB,CAAC,UAAU,CAAC;aAG1C,IAAI,EAAE,UAAU,CAAC,UAAU,CAAC;gBAA5B,IAAI,EAAE,UAAU,CAAC,UAAU,CAAC;IAQxC,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IASxD,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC;IAmBrF,YAAY,CAChB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,UAAU,EAClB,UAAU,CAAC,EAAE,MAAM,EACnB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,UAAU,CAAC;IAkChB,uBAAuB,CAC3B,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,sBAAsB,GAC5B,OAAO,CAAC,UAAU,CAAC;IAchB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQhD,oBAAoB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC;CAInF"}
|