@nauth-toolkit/core 0.1.108 → 0.1.111
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/bootstrap.d.ts.map +1 -1
- package/dist/bootstrap.js.map +1 -1
- package/dist/dto/admin-remove-device.dto.d.ts +22 -0
- package/dist/dto/admin-remove-device.dto.d.ts.map +1 -0
- package/dist/dto/{admin-remove-devices.dto.js → admin-remove-device.dto.js} +21 -21
- package/dist/dto/admin-remove-device.dto.js.map +1 -0
- package/dist/dto/admin-set-preferred-device.dto.d.ts +32 -0
- package/dist/dto/admin-set-preferred-device.dto.d.ts.map +1 -0
- package/dist/dto/admin-set-preferred-device.dto.js +64 -0
- package/dist/dto/admin-set-preferred-device.dto.js.map +1 -0
- package/dist/dto/admin-signup-social.dto.d.ts +2 -2
- package/dist/dto/admin-signup.dto.d.ts +2 -2
- package/dist/dto/challenge-response.dto.d.ts +4 -0
- package/dist/dto/challenge-response.dto.d.ts.map +1 -1
- package/dist/dto/disable-user.dto.d.ts +2 -2
- package/dist/dto/enable-user.dto.d.ts +2 -2
- package/dist/dto/get-user-devices.dto.d.ts +5 -3
- package/dist/dto/get-user-devices.dto.d.ts.map +1 -1
- package/dist/dto/get-user-devices.dto.js +3 -1
- package/dist/dto/get-user-devices.dto.js.map +1 -1
- package/dist/dto/get-user-response.dto.d.ts +1 -1
- package/dist/dto/get-user-response.dto.js +1 -1
- package/dist/dto/get-users.dto.d.ts +2 -2
- package/dist/dto/index.d.ts +6 -4
- package/dist/dto/index.d.ts.map +1 -1
- package/dist/dto/index.js +6 -4
- package/dist/dto/index.js.map +1 -1
- package/dist/dto/mfa-device-response.dto.d.ts +68 -0
- package/dist/dto/mfa-device-response.dto.d.ts.map +1 -0
- package/dist/dto/mfa-device-response.dto.js +81 -0
- package/dist/dto/mfa-device-response.dto.js.map +1 -0
- package/dist/dto/remove-device.dto.d.ts +49 -0
- package/dist/dto/remove-device.dto.d.ts.map +1 -0
- package/dist/dto/remove-device.dto.js +76 -0
- package/dist/dto/remove-device.dto.js.map +1 -0
- package/dist/dto/respond-challenge.dto.d.ts +8 -0
- package/dist/dto/respond-challenge.dto.d.ts.map +1 -1
- package/dist/dto/respond-challenge.dto.js +14 -0
- package/dist/dto/respond-challenge.dto.js.map +1 -1
- package/dist/dto/set-preferred-device.dto.d.ts +46 -0
- package/dist/dto/set-preferred-device.dto.d.ts.map +1 -0
- package/dist/dto/set-preferred-device.dto.js +74 -0
- package/dist/dto/set-preferred-device.dto.js.map +1 -0
- package/dist/dto/setup-mfa.dto.d.ts.map +1 -1
- package/dist/dto/setup-mfa.dto.js.map +1 -1
- package/dist/dto/user-response.dto.d.ts +3 -3
- package/dist/dto/user-response.dto.js +5 -5
- package/dist/dto/verify-mfa-setup-response.dto.d.ts +18 -0
- package/dist/dto/verify-mfa-setup-response.dto.d.ts.map +1 -0
- package/dist/dto/verify-mfa-setup-response.dto.js +22 -0
- package/dist/dto/verify-mfa-setup-response.dto.js.map +1 -0
- package/dist/handlers/client-info.handler.d.ts.map +1 -1
- package/dist/handlers/client-info.handler.js.map +1 -1
- package/dist/interfaces/provider.interface.d.ts.map +1 -1
- package/dist/openapi/components.schemas.json +112 -140
- package/dist/services/admin-auth.service.d.ts +12 -5
- package/dist/services/admin-auth.service.d.ts.map +1 -1
- package/dist/services/admin-auth.service.js +46 -2
- package/dist/services/admin-auth.service.js.map +1 -1
- package/dist/services/auth-audit.service.d.ts.map +1 -1
- package/dist/services/auth-audit.service.js +1 -1
- package/dist/services/auth-audit.service.js.map +1 -1
- package/dist/services/auth-challenge-helper.service.d.ts.map +1 -1
- package/dist/services/auth-challenge-helper.service.js +34 -0
- package/dist/services/auth-challenge-helper.service.js.map +1 -1
- package/dist/services/auth-service-internal-helpers.d.ts.map +1 -1
- package/dist/services/auth-service-internal-helpers.js +4 -0
- package/dist/services/auth-service-internal-helpers.js.map +1 -1
- package/dist/services/auth.service.d.ts +9 -2
- package/dist/services/auth.service.d.ts.map +1 -1
- package/dist/services/auth.service.js +36 -0
- package/dist/services/auth.service.js.map +1 -1
- package/dist/services/challenge.service.d.ts.map +1 -1
- package/dist/services/challenge.service.js +1 -3
- package/dist/services/challenge.service.js.map +1 -1
- package/dist/services/email-verification.service.d.ts.map +1 -1
- package/dist/services/email-verification.service.js +3 -9
- package/dist/services/email-verification.service.js.map +1 -1
- package/dist/services/mfa-base.service.d.ts +23 -6
- package/dist/services/mfa-base.service.d.ts.map +1 -1
- package/dist/services/mfa-base.service.js +70 -18
- package/dist/services/mfa-base.service.js.map +1 -1
- package/dist/services/mfa.service.d.ts +54 -35
- package/dist/services/mfa.service.d.ts.map +1 -1
- package/dist/services/mfa.service.js +216 -168
- package/dist/services/mfa.service.js.map +1 -1
- package/dist/services/phone-verification.service.d.ts.map +1 -1
- package/dist/services/phone-verification.service.js +3 -8
- package/dist/services/phone-verification.service.js.map +1 -1
- package/dist/services/session.service.d.ts +1 -2
- package/dist/services/session.service.d.ts.map +1 -1
- package/dist/services/session.service.js.map +1 -1
- package/dist/services/user.service.d.ts +5 -5
- package/dist/services/user.service.d.ts.map +1 -1
- package/dist/services/user.service.js +16 -10
- package/dist/services/user.service.js.map +1 -1
- package/package.json +2 -2
- package/dist/dto/admin-remove-devices.dto.d.ts +0 -25
- package/dist/dto/admin-remove-devices.dto.d.ts.map +0 -1
- package/dist/dto/admin-remove-devices.dto.js.map +0 -1
- package/dist/dto/admin-set-preferred-method.dto.d.ts +0 -25
- package/dist/dto/admin-set-preferred-method.dto.d.ts.map +0 -1
- package/dist/dto/admin-set-preferred-method.dto.js +0 -50
- package/dist/dto/admin-set-preferred-method.dto.js.map +0 -1
- package/dist/dto/remove-devices.dto.d.ts +0 -48
- package/dist/dto/remove-devices.dto.d.ts.map +0 -1
- package/dist/dto/remove-devices.dto.js +0 -79
- package/dist/dto/remove-devices.dto.js.map +0 -1
- package/dist/dto/set-preferred-method.dto.d.ts +0 -44
- package/dist/dto/set-preferred-method.dto.d.ts.map +0 -1
- package/dist/dto/set-preferred-method.dto.js +0 -75
- package/dist/dto/set-preferred-method.dto.js.map +0 -1
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Outward-facing MFA Device Response DTO
|
|
4
|
+
*
|
|
5
|
+
* This DTO is used for all API responses that return device information.
|
|
6
|
+
* It maps internal `isPrimary` to external `isPreferred` to avoid exposing
|
|
7
|
+
* internal database field names.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```typescript
|
|
11
|
+
* const device: MFADeviceResponseDTO = {
|
|
12
|
+
* id: 1,
|
|
13
|
+
* type: 'totp',
|
|
14
|
+
* name: 'My Phone',
|
|
15
|
+
* isPreferred: true,
|
|
16
|
+
* isActive: true,
|
|
17
|
+
* createdAt: new Date()
|
|
18
|
+
* };
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
exports.MFADeviceResponseDTO = void 0;
|
|
23
|
+
/**
|
|
24
|
+
* Outward-facing MFA device information
|
|
25
|
+
*
|
|
26
|
+
* Note: Uses `isPreferred` instead of internal `isPrimary` field
|
|
27
|
+
*/
|
|
28
|
+
class MFADeviceResponseDTO {
|
|
29
|
+
/**
|
|
30
|
+
* Unique device identifier
|
|
31
|
+
*/
|
|
32
|
+
id;
|
|
33
|
+
/**
|
|
34
|
+
* MFA method type (totp, sms, email, passkey)
|
|
35
|
+
*/
|
|
36
|
+
type;
|
|
37
|
+
/**
|
|
38
|
+
* Device name (user-assigned)
|
|
39
|
+
*/
|
|
40
|
+
name;
|
|
41
|
+
/**
|
|
42
|
+
* Whether this is the preferred device for this method
|
|
43
|
+
* Maps from internal `isPrimary` field
|
|
44
|
+
*/
|
|
45
|
+
isPreferred;
|
|
46
|
+
/**
|
|
47
|
+
* Whether device is currently active
|
|
48
|
+
*/
|
|
49
|
+
isActive;
|
|
50
|
+
/**
|
|
51
|
+
* Device creation timestamp
|
|
52
|
+
*/
|
|
53
|
+
createdAt;
|
|
54
|
+
/**
|
|
55
|
+
* Convert internal device entity to outward-facing DTO
|
|
56
|
+
*
|
|
57
|
+
* @param device - Internal device entity
|
|
58
|
+
* @returns Outward-facing device DTO
|
|
59
|
+
*/
|
|
60
|
+
static fromEntity(device) {
|
|
61
|
+
const dto = new MFADeviceResponseDTO();
|
|
62
|
+
dto.id = device.id;
|
|
63
|
+
dto.type = device.type;
|
|
64
|
+
dto.name = device.name;
|
|
65
|
+
dto.isPreferred = device.isPrimary === true;
|
|
66
|
+
dto.isActive = device.isActive;
|
|
67
|
+
dto.createdAt = device.createdAt;
|
|
68
|
+
return dto;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Convert array of internal device entities to outward-facing DTOs
|
|
72
|
+
*
|
|
73
|
+
* @param devices - Array of internal device entities
|
|
74
|
+
* @returns Array of outward-facing device DTOs
|
|
75
|
+
*/
|
|
76
|
+
static fromEntities(devices) {
|
|
77
|
+
return devices.map((device) => MFADeviceResponseDTO.fromEntity(device));
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
exports.MFADeviceResponseDTO = MFADeviceResponseDTO;
|
|
81
|
+
//# sourceMappingURL=mfa-device-response.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mfa-device-response.dto.js","sourceRoot":"","sources":["../../src/dto/mfa-device-response.dto.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;GAkBG;;;AAKH;;;;GAIG;AACH,MAAa,oBAAoB;IAC/B;;OAEG;IACH,EAAE,CAAU;IAEZ;;OAEG;IACH,IAAI,CAAmB;IAEvB;;OAEG;IACH,IAAI,CAAU;IAEd;;;OAGG;IACH,WAAW,CAAW;IAEtB;;OAEG;IACH,QAAQ,CAAW;IAEnB;;OAEG;IACH,SAAS,CAAQ;IAEjB;;;;;OAKG;IACH,MAAM,CAAC,UAAU,CAAC,MAAkB;QAClC,MAAM,GAAG,GAAG,IAAI,oBAAoB,EAAE,CAAC;QACvC,GAAG,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;QACnB,GAAG,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACvB,GAAG,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACvB,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC;QAC5C,GAAG,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAC/B,GAAG,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;QACjC,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,YAAY,CAAC,OAAqB;QACvC,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1E,CAAC;CACF;AA1DD,oDA0DC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DTO for removing a single MFA device by ID
|
|
3
|
+
*
|
|
4
|
+
* Used to remove one enrolled MFA device for the current authenticated user.
|
|
5
|
+
* This is important when users can register multiple devices per method
|
|
6
|
+
* (e.g., multiple TOTP authenticators and multiple passkeys).
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```typescript
|
|
10
|
+
* const result = await mfaService.removeDevice({ deviceId: 123 });
|
|
11
|
+
* // { removedDeviceId: 123, removedMethod: 'passkey', mfaDisabled: false }
|
|
12
|
+
* ```
|
|
13
|
+
*/
|
|
14
|
+
import { MFADeviceMethod } from '../enums/mfa-method.enum';
|
|
15
|
+
/**
|
|
16
|
+
* DTO for removing a single MFA device
|
|
17
|
+
*/
|
|
18
|
+
export declare class RemoveDeviceDTO {
|
|
19
|
+
/**
|
|
20
|
+
* MFA device ID to remove
|
|
21
|
+
*
|
|
22
|
+
* Validation:
|
|
23
|
+
* - Must be a positive integer
|
|
24
|
+
*
|
|
25
|
+
* Sanitization:
|
|
26
|
+
* - Strings are converted to numbers (useful for path params)
|
|
27
|
+
*
|
|
28
|
+
* @example 123
|
|
29
|
+
*/
|
|
30
|
+
deviceId: number;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Response DTO for removing a single MFA device
|
|
34
|
+
*/
|
|
35
|
+
export declare class RemoveDeviceResponseDTO {
|
|
36
|
+
/**
|
|
37
|
+
* ID of the removed device
|
|
38
|
+
*/
|
|
39
|
+
removedDeviceId: number;
|
|
40
|
+
/**
|
|
41
|
+
* MFA method type of the removed device
|
|
42
|
+
*/
|
|
43
|
+
removedMethod: MFADeviceMethod;
|
|
44
|
+
/**
|
|
45
|
+
* Whether MFA was disabled (when this was the last remaining device)
|
|
46
|
+
*/
|
|
47
|
+
mfaDisabled: boolean;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=remove-device.dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-device.dto.d.ts","sourceRoot":"","sources":["../../src/dto/remove-device.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAIH,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D;;GAEG;AACH,qBAAa,eAAe;IAC1B;;;;;;;;;;OAUG;IAUH,QAAQ,EAAG,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,qBAAa,uBAAuB;IAClC;;OAEG;IACH,eAAe,EAAG,MAAM,CAAC;IAEzB;;OAEG;IACH,aAAa,EAAG,eAAe,CAAC;IAEhC;;OAEG;IACH,WAAW,EAAG,OAAO,CAAC;CACvB"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* DTO for removing a single MFA device by ID
|
|
4
|
+
*
|
|
5
|
+
* Used to remove one enrolled MFA device for the current authenticated user.
|
|
6
|
+
* This is important when users can register multiple devices per method
|
|
7
|
+
* (e.g., multiple TOTP authenticators and multiple passkeys).
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```typescript
|
|
11
|
+
* const result = await mfaService.removeDevice({ deviceId: 123 });
|
|
12
|
+
* // { removedDeviceId: 123, removedMethod: 'passkey', mfaDisabled: false }
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
16
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
17
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
18
|
+
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;
|
|
19
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
20
|
+
};
|
|
21
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
22
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
23
|
+
};
|
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
exports.RemoveDeviceResponseDTO = exports.RemoveDeviceDTO = void 0;
|
|
26
|
+
const class_transformer_1 = require("class-transformer");
|
|
27
|
+
const class_validator_1 = require("class-validator");
|
|
28
|
+
/**
|
|
29
|
+
* DTO for removing a single MFA device
|
|
30
|
+
*/
|
|
31
|
+
class RemoveDeviceDTO {
|
|
32
|
+
/**
|
|
33
|
+
* MFA device ID to remove
|
|
34
|
+
*
|
|
35
|
+
* Validation:
|
|
36
|
+
* - Must be a positive integer
|
|
37
|
+
*
|
|
38
|
+
* Sanitization:
|
|
39
|
+
* - Strings are converted to numbers (useful for path params)
|
|
40
|
+
*
|
|
41
|
+
* @example 123
|
|
42
|
+
*/
|
|
43
|
+
deviceId;
|
|
44
|
+
}
|
|
45
|
+
exports.RemoveDeviceDTO = RemoveDeviceDTO;
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, class_transformer_1.Transform)(({ value }) => {
|
|
48
|
+
if (typeof value === 'string') {
|
|
49
|
+
const parsed = Number(value);
|
|
50
|
+
return Number.isFinite(parsed) ? parsed : value;
|
|
51
|
+
}
|
|
52
|
+
return value;
|
|
53
|
+
}),
|
|
54
|
+
(0, class_validator_1.IsInt)({ message: 'Device ID must be an integer' }),
|
|
55
|
+
(0, class_validator_1.Min)(1, { message: 'Device ID must be a positive integer' }),
|
|
56
|
+
__metadata("design:type", Number)
|
|
57
|
+
], RemoveDeviceDTO.prototype, "deviceId", void 0);
|
|
58
|
+
/**
|
|
59
|
+
* Response DTO for removing a single MFA device
|
|
60
|
+
*/
|
|
61
|
+
class RemoveDeviceResponseDTO {
|
|
62
|
+
/**
|
|
63
|
+
* ID of the removed device
|
|
64
|
+
*/
|
|
65
|
+
removedDeviceId;
|
|
66
|
+
/**
|
|
67
|
+
* MFA method type of the removed device
|
|
68
|
+
*/
|
|
69
|
+
removedMethod;
|
|
70
|
+
/**
|
|
71
|
+
* Whether MFA was disabled (when this was the last remaining device)
|
|
72
|
+
*/
|
|
73
|
+
mfaDisabled;
|
|
74
|
+
}
|
|
75
|
+
exports.RemoveDeviceResponseDTO = RemoveDeviceResponseDTO;
|
|
76
|
+
//# sourceMappingURL=remove-device.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-device.dto.js","sourceRoot":"","sources":["../../src/dto/remove-device.dto.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;GAYG;;;;;;;;;;;;AAEH,yDAA8C;AAC9C,qDAA6C;AAG7C;;GAEG;AACH,MAAa,eAAe;IAC1B;;;;;;;;;;OAUG;IAUH,QAAQ,CAAU;CACnB;AAtBD,0CAsBC;AADC;IATC,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;QACvB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC7B,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;QAClD,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;IACD,IAAA,uBAAK,EAAC,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC;IAClD,IAAA,qBAAG,EAAC,CAAC,EAAE,EAAE,OAAO,EAAE,sCAAsC,EAAE,CAAC;;iDAC1C;AAGpB;;GAEG;AACH,MAAa,uBAAuB;IAClC;;OAEG;IACH,eAAe,CAAU;IAEzB;;OAEG;IACH,aAAa,CAAmB;IAEhC;;OAEG;IACH,WAAW,CAAW;CACvB;AAfD,0DAeC"}
|
|
@@ -141,6 +141,14 @@ export declare class RespondChallengeDTO {
|
|
|
141
141
|
* - Contains WebAuthn credential from navigator.credentials.get()
|
|
142
142
|
*/
|
|
143
143
|
credential?: Record<string, unknown>;
|
|
144
|
+
/**
|
|
145
|
+
* Optional device ID for MFA_REQUIRED when method supports multiple devices (TOTP, Passkey)
|
|
146
|
+
*
|
|
147
|
+
* Validation:
|
|
148
|
+
* - Must be a positive integer if provided
|
|
149
|
+
* - Optional field (maintains backward compatibility)
|
|
150
|
+
*/
|
|
151
|
+
deviceId?: number;
|
|
144
152
|
/**
|
|
145
153
|
* MFA setup data (method-specific)
|
|
146
154
|
* Required for MFA_SETUP_REQUIRED challenge
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"respond-challenge.dto.d.ts","sourceRoot":"","sources":["../../src/dto/respond-challenge.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;
|
|
1
|
+
{"version":3,"file":"respond-challenge.dto.d.ts","sourceRoot":"","sources":["../../src/dto/respond-challenge.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAiBH;;GAEG;AACH,oBAAY,aAAa;IACvB,YAAY,iBAAiB;IAC7B,YAAY,iBAAiB;IAC7B,YAAY,iBAAiB;IAC7B,qBAAqB,0BAA0B;IAC/C,kBAAkB,uBAAuB;CAC1C;AAED;;GAEG;AACH,oBAAY,aAAa;IACvB,GAAG,QAAQ;IACX,KAAK,UAAU;IACf,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,MAAM,WAAW;CAClB;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,mBAAmB;IAC9B;;;;;;;;;;;;;;OAcG;IAQH,OAAO,EAAG,MAAM,CAAC;IAEjB;;;OAGG;IAKH,IAAI,EAAG,aAAa,CAAC;IAMrB;;;;;;;;;;;;;OAaG;IAUH,IAAI,CAAC,EAAE,MAAM,CAAC;IAMd;;;;;;;;;;;;;OAaG;IAaH,KAAK,CAAC,EAAE,MAAM,CAAC;IAMf;;;;;;;;;;OAUG;IAKH,WAAW,CAAC,EAAE,MAAM,CAAC;IAMrB;;;;;;;;OAQG;IAGH,MAAM,CAAC,EAAE,aAAa,CAAC;IAEvB;;;;;;;OAOG;IAGH,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAErC;;;;;;OAMG;IAIH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAMlB;;;;;;;;;;;;;OAaG;IAGH,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC;AAED;;;;;;;;;;;GAWG;AACH,yBAAiB,0BAA0B,CAAC;IAC1C,SAAgB,mBAAmB,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAErE;IAED,SAAgB,iBAAiB,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAEnE;IAED,SAAgB,mBAAmB,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAErE;IAED,SAAgB,gBAAgB,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAElE;IAED,SAAgB,iBAAiB,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAEnE;IAED,SAAgB,UAAU,CAAC,GAAG,EAAE,mBAAmB,GAAG,OAAO,CAE5D;CACF"}
|
|
@@ -169,6 +169,14 @@ class RespondChallengeDTO {
|
|
|
169
169
|
* - Contains WebAuthn credential from navigator.credentials.get()
|
|
170
170
|
*/
|
|
171
171
|
credential;
|
|
172
|
+
/**
|
|
173
|
+
* Optional device ID for MFA_REQUIRED when method supports multiple devices (TOTP, Passkey)
|
|
174
|
+
*
|
|
175
|
+
* Validation:
|
|
176
|
+
* - Must be a positive integer if provided
|
|
177
|
+
* - Optional field (maintains backward compatibility)
|
|
178
|
+
*/
|
|
179
|
+
deviceId;
|
|
172
180
|
// ============================================================================
|
|
173
181
|
// MFA_SETUP_REQUIRED
|
|
174
182
|
// ============================================================================
|
|
@@ -246,6 +254,12 @@ __decorate([
|
|
|
246
254
|
(0, class_validator_1.IsObject)({ message: 'Credential must be an object' }),
|
|
247
255
|
__metadata("design:type", Object)
|
|
248
256
|
], RespondChallengeDTO.prototype, "credential", void 0);
|
|
257
|
+
__decorate([
|
|
258
|
+
(0, class_validator_1.IsOptional)(),
|
|
259
|
+
(0, class_validator_1.ValidateIf)((o) => o.type === ChallengeType.MFA_REQUIRED),
|
|
260
|
+
(0, class_validator_1.IsInt)({ message: 'Device ID must be a number' }),
|
|
261
|
+
__metadata("design:type", Number)
|
|
262
|
+
], RespondChallengeDTO.prototype, "deviceId", void 0);
|
|
249
263
|
__decorate([
|
|
250
264
|
(0, class_validator_1.ValidateIf)((o) => o.type === ChallengeType.MFA_SETUP_REQUIRED),
|
|
251
265
|
(0, class_validator_1.IsObject)({ message: 'Setup data must be an object' }),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"respond-challenge.dto.js","sourceRoot":"","sources":["../../src/dto/respond-challenge.dto.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;GAeG;;;;;;;;;;;;AAEH,
|
|
1
|
+
{"version":3,"file":"respond-challenge.dto.js","sourceRoot":"","sources":["../../src/dto/respond-challenge.dto.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DTO for setting a user's preferred MFA device.
|
|
3
|
+
*
|
|
4
|
+
* This updates which device is used by default during MFA challenges.
|
|
5
|
+
* The preferred device is marked with `isPrimary` in the database (internal field).
|
|
6
|
+
* API responses expose this as `isPreferred` (outward-facing field).
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```typescript
|
|
10
|
+
* const dto: SetPreferredDeviceDTO = { deviceId: 123 };
|
|
11
|
+
* await mfaService.setPreferredDevice(dto);
|
|
12
|
+
* ```
|
|
13
|
+
*/
|
|
14
|
+
export declare class SetPreferredDeviceDTO {
|
|
15
|
+
/**
|
|
16
|
+
* MFA device ID to set as preferred
|
|
17
|
+
*
|
|
18
|
+
* Validation:
|
|
19
|
+
* - Must be a positive integer
|
|
20
|
+
*
|
|
21
|
+
* Sanitization:
|
|
22
|
+
* - Strings are converted to numbers (useful for path params)
|
|
23
|
+
*
|
|
24
|
+
* @example 123
|
|
25
|
+
*/
|
|
26
|
+
deviceId: number;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Response DTO for setting preferred MFA device.
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* ```typescript
|
|
33
|
+
* {
|
|
34
|
+
* message: "Preferred MFA device updated"
|
|
35
|
+
* }
|
|
36
|
+
* ```
|
|
37
|
+
*/
|
|
38
|
+
export declare class SetPreferredDeviceResponseDTO {
|
|
39
|
+
/**
|
|
40
|
+
* Success message
|
|
41
|
+
*
|
|
42
|
+
* @example "Preferred MFA device updated"
|
|
43
|
+
*/
|
|
44
|
+
message: string;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=set-preferred-device.dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set-preferred-device.dto.d.ts","sourceRoot":"","sources":["../../src/dto/set-preferred-device.dto.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;GAYG;AACH,qBAAa,qBAAqB;IAChC;;;;;;;;;;OAUG;IAUH,QAAQ,EAAG,MAAM,CAAC;CACnB;AAED;;;;;;;;;GASG;AACH,qBAAa,6BAA6B;IACxC;;;;OAIG;IACH,OAAO,EAAG,MAAM,CAAC;CAClB"}
|
|
@@ -0,0 +1,74 @@
|
|
|
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.SetPreferredDeviceResponseDTO = exports.SetPreferredDeviceDTO = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const class_transformer_1 = require("class-transformer");
|
|
15
|
+
/**
|
|
16
|
+
* DTO for setting a user's preferred MFA device.
|
|
17
|
+
*
|
|
18
|
+
* This updates which device is used by default during MFA challenges.
|
|
19
|
+
* The preferred device is marked with `isPrimary` in the database (internal field).
|
|
20
|
+
* API responses expose this as `isPreferred` (outward-facing field).
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* ```typescript
|
|
24
|
+
* const dto: SetPreferredDeviceDTO = { deviceId: 123 };
|
|
25
|
+
* await mfaService.setPreferredDevice(dto);
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
class SetPreferredDeviceDTO {
|
|
29
|
+
/**
|
|
30
|
+
* MFA device ID to set as preferred
|
|
31
|
+
*
|
|
32
|
+
* Validation:
|
|
33
|
+
* - Must be a positive integer
|
|
34
|
+
*
|
|
35
|
+
* Sanitization:
|
|
36
|
+
* - Strings are converted to numbers (useful for path params)
|
|
37
|
+
*
|
|
38
|
+
* @example 123
|
|
39
|
+
*/
|
|
40
|
+
deviceId;
|
|
41
|
+
}
|
|
42
|
+
exports.SetPreferredDeviceDTO = SetPreferredDeviceDTO;
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, class_transformer_1.Transform)(({ value }) => {
|
|
45
|
+
if (typeof value === 'string') {
|
|
46
|
+
const parsed = Number(value);
|
|
47
|
+
return Number.isFinite(parsed) ? parsed : value;
|
|
48
|
+
}
|
|
49
|
+
return value;
|
|
50
|
+
}),
|
|
51
|
+
(0, class_validator_1.IsInt)({ message: 'Device ID must be an integer' }),
|
|
52
|
+
(0, class_validator_1.IsPositive)({ message: 'Device ID must be positive' }),
|
|
53
|
+
__metadata("design:type", Number)
|
|
54
|
+
], SetPreferredDeviceDTO.prototype, "deviceId", void 0);
|
|
55
|
+
/**
|
|
56
|
+
* Response DTO for setting preferred MFA device.
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* ```typescript
|
|
60
|
+
* {
|
|
61
|
+
* message: "Preferred MFA device updated"
|
|
62
|
+
* }
|
|
63
|
+
* ```
|
|
64
|
+
*/
|
|
65
|
+
class SetPreferredDeviceResponseDTO {
|
|
66
|
+
/**
|
|
67
|
+
* Success message
|
|
68
|
+
*
|
|
69
|
+
* @example "Preferred MFA device updated"
|
|
70
|
+
*/
|
|
71
|
+
message;
|
|
72
|
+
}
|
|
73
|
+
exports.SetPreferredDeviceResponseDTO = SetPreferredDeviceResponseDTO;
|
|
74
|
+
//# sourceMappingURL=set-preferred-device.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set-preferred-device.dto.js","sourceRoot":"","sources":["../../src/dto/set-preferred-device.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAoD;AACpD,yDAA8C;AAE9C;;;;;;;;;;;;GAYG;AACH,MAAa,qBAAqB;IAChC;;;;;;;;;;OAUG;IAUH,QAAQ,CAAU;CACnB;AAtBD,sDAsBC;AADC;IATC,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;QACvB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC7B,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;QAClD,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;IACD,IAAA,uBAAK,EAAC,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC;IAClD,IAAA,4BAAU,EAAC,EAAE,OAAO,EAAE,4BAA4B,EAAE,CAAC;;uDACpC;AAGpB;;;;;;;;;GASG;AACH,MAAa,6BAA6B;IACxC;;;;OAIG;IACH,OAAO,CAAU;CAClB;AAPD,sEAOC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup-mfa.dto.d.ts","sourceRoot":"","sources":["../../src/dto/setup-mfa.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAMH;;;;GAIG;AACH,qBAAa,WAAW;
|
|
1
|
+
{"version":3,"file":"setup-mfa.dto.d.ts","sourceRoot":"","sources":["../../src/dto/setup-mfa.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAMH;;;;GAIG;AACH,qBAAa,WAAW;IACtB;;;;;;;;;;;OAWG;IAYH,UAAU,EAAG,MAAM,CAAC;IAEpB;;;;;;;;OAQG;IAGH,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC;AAED;;GAEG;AACH,qBAAa,mBAAmB;IAC9B;;;;;;;OAOG;IACH,SAAS,EAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup-mfa.dto.js","sourceRoot":"","sources":["../../src/dto/setup-mfa.dto.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;GAaG;;;;;;;;;;;;AAEH,qDAAoF;AACpF,yDAA8C;AAC9C,8DAAqD;AAErD;;;;GAIG;AACH,MAAa,WAAW;
|
|
1
|
+
{"version":3,"file":"setup-mfa.dto.js","sourceRoot":"","sources":["../../src/dto/setup-mfa.dto.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;GAaG;;;;;;;;;;;;AAEH,qDAAoF;AACpF,yDAA8C;AAC9C,8DAAqD;AAErD;;;;GAIG;AACH,MAAa,WAAW;IACtB;;;;;;;;;;;OAWG;IAYH,UAAU,CAAU;IAEpB;;;;;;;;OAQG;IAGH,SAAS,CAA2B;CACrC;AAtCD,kCAsCC;AAdC;IAXC,IAAA,0BAAQ,EAAC,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC;IACrD,IAAA,wBAAM,EAAC,CAAC,2BAAS,CAAC,IAAI,EAAE,2BAAS,CAAC,GAAG,EAAE,2BAAS,CAAC,KAAK,EAAE,2BAAS,CAAC,OAAO,CAAC,EAAE;QAC3E,OAAO,EAAE,uDAAuD;KACjE,CAAC;IACD,IAAA,2BAAS,EAAC,EAAE,EAAE,EAAE,OAAO,EAAE,2CAA2C,EAAE,CAAC;IACvE,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;QACvB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;;+CACkB;AAapB;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,EAAC,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC;;8CAClB;AAGtC;;GAEG;AACH,MAAa,mBAAmB;IAC9B;;;;;;;OAOG;IACH,SAAS,CAA2B;CACrC;AAVD,kDAUC"}
|
|
@@ -19,7 +19,7 @@ import { IUser } from '../interfaces/entities.interface';
|
|
|
19
19
|
* return UserResponseDto.fromEntity(user);
|
|
20
20
|
* ```
|
|
21
21
|
*/
|
|
22
|
-
export declare class
|
|
22
|
+
export declare class UserResponseDTO {
|
|
23
23
|
/**
|
|
24
24
|
* External user identifier (UUID v4)
|
|
25
25
|
* This is the 'sub' (subject) field from JWT tokens
|
|
@@ -98,13 +98,13 @@ export declare class UserResponseDto {
|
|
|
98
98
|
* @param user - User entity from database
|
|
99
99
|
* @returns Sanitized user object with external identifier (sub)
|
|
100
100
|
*/
|
|
101
|
-
static fromEntity(user: IUser):
|
|
101
|
+
static fromEntity(user: IUser): UserResponseDTO;
|
|
102
102
|
/**
|
|
103
103
|
* Convert array of User entities to safe response DTOs
|
|
104
104
|
*
|
|
105
105
|
* @param users - Array of User entities
|
|
106
106
|
* @returns Array of sanitized user objects
|
|
107
107
|
*/
|
|
108
|
-
static fromEntities(users: IUser[]):
|
|
108
|
+
static fromEntities(users: IUser[]): UserResponseDTO[];
|
|
109
109
|
}
|
|
110
110
|
//# sourceMappingURL=user-response.dto.d.ts.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.UserResponseDTO = void 0;
|
|
4
4
|
/**
|
|
5
5
|
* User Response DTO
|
|
6
6
|
*
|
|
@@ -21,7 +21,7 @@ exports.UserResponseDto = void 0;
|
|
|
21
21
|
* return UserResponseDto.fromEntity(user);
|
|
22
22
|
* ```
|
|
23
23
|
*/
|
|
24
|
-
class
|
|
24
|
+
class UserResponseDTO {
|
|
25
25
|
/**
|
|
26
26
|
* External user identifier (UUID v4)
|
|
27
27
|
* This is the 'sub' (subject) field from JWT tokens
|
|
@@ -101,7 +101,7 @@ class UserResponseDto {
|
|
|
101
101
|
* @returns Sanitized user object with external identifier (sub)
|
|
102
102
|
*/
|
|
103
103
|
static fromEntity(user) {
|
|
104
|
-
const dto = new
|
|
104
|
+
const dto = new UserResponseDTO();
|
|
105
105
|
// Essential fields only
|
|
106
106
|
dto.sub = user.sub; // External UUID identifier
|
|
107
107
|
dto.email = user.email;
|
|
@@ -128,8 +128,8 @@ class UserResponseDto {
|
|
|
128
128
|
* @returns Array of sanitized user objects
|
|
129
129
|
*/
|
|
130
130
|
static fromEntities(users) {
|
|
131
|
-
return users.map((user) =>
|
|
131
|
+
return users.map((user) => UserResponseDTO.fromEntity(user));
|
|
132
132
|
}
|
|
133
133
|
}
|
|
134
|
-
exports.
|
|
134
|
+
exports.UserResponseDTO = UserResponseDTO;
|
|
135
135
|
//# sourceMappingURL=user-response.dto.js.map
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Response DTO for verifying MFA setup
|
|
3
|
+
*
|
|
4
|
+
* Returned when an authenticated user completes MFA device setup verification.
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```typescript
|
|
8
|
+
* const result = await provider.verifySetup(setupData);
|
|
9
|
+
* // Returns: { deviceId: 123 }
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare class VerifyMFASetupResponseDTO {
|
|
13
|
+
/**
|
|
14
|
+
* ID of the newly created MFA device
|
|
15
|
+
*/
|
|
16
|
+
deviceId: number;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=verify-mfa-setup-response.dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verify-mfa-setup-response.dto.d.ts","sourceRoot":"","sources":["../../src/dto/verify-mfa-setup-response.dto.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,qBAAa,yBAAyB;IACpC;;OAEG;IACH,QAAQ,EAAG,MAAM,CAAC;CACnB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.VerifyMFASetupResponseDTO = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Response DTO for verifying MFA setup
|
|
6
|
+
*
|
|
7
|
+
* Returned when an authenticated user completes MFA device setup verification.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```typescript
|
|
11
|
+
* const result = await provider.verifySetup(setupData);
|
|
12
|
+
* // Returns: { deviceId: 123 }
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
class VerifyMFASetupResponseDTO {
|
|
16
|
+
/**
|
|
17
|
+
* ID of the newly created MFA device
|
|
18
|
+
*/
|
|
19
|
+
deviceId;
|
|
20
|
+
}
|
|
21
|
+
exports.VerifyMFASetupResponseDTO = VerifyMFASetupResponseDTO;
|
|
22
|
+
//# sourceMappingURL=verify-mfa-setup-response.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verify-mfa-setup-response.dto.js","sourceRoot":"","sources":["../../src/dto/verify-mfa-setup-response.dto.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;GAUG;AACH,MAAa,yBAAyB;IACpC;;OAEG;IACH,QAAQ,CAAU;CACnB;AALD,8DAKC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client-info.handler.d.ts","sourceRoot":"","sources":["../../src/handlers/client-info.handler.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,
|
|
1
|
+
{"version":3,"file":"client-info.handler.d.ts","sourceRoot":"","sources":["../../src/handlers/client-info.handler.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAEL,iBAAiB,EAEjB,WAAW,EACX,WAAW,EAEZ,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAErE;;;;;GAKG;AACH,qBAAa,iBAAiB;IAE1B,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,MAAM,CAAC;IACf,OAAO,CAAC,kBAAkB,CAAC;IAC3B,OAAO,CAAC,MAAM,CAAC;gBAHP,iBAAiB,EAAE,iBAAiB,EACpC,MAAM,CAAC,EAAE,WAAW,YAAA,EACpB,kBAAkB,CAAC,EAAE,kBAAkB,YAAA,EACvC,MAAM,CAAC,EAAE,WAAW,YAAA;IAG9B;;;;;OAKG;IACU,MAAM,CAAC,GAAG,EAAE,YAAY,EAAE,GAAG,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAU3G;;OAEG;YACW,eAAe;CAsD9B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client-info.handler.js","sourceRoot":"","sources":["../../src/handlers/client-info.handler.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AAEH,
|
|
1
|
+
{"version":3,"file":"client-info.handler.js","sourceRoot":"","sources":["../../src/handlers/client-info.handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/provider.interface.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"provider.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/provider.interface.ts"],"names":[],"mappings":"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"}
|