@ackplus/nest-auth 0.0.37 → 0.0.38
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/index.cjs.d.ts +1 -0
- package/index.cjs.js +105236 -0
- package/package.json +2 -2
- package/src/lib/core/entities.d.ts +1 -1
- package/README.md +0 -226
- package/src/index.js +0 -12
- package/src/index.js.map +0 -1
- package/src/lib/auth/auth.module.js +0 -52
- package/src/lib/auth/auth.module.js.map +0 -1
- package/src/lib/auth/controllers/auth.controller.js +0 -189
- package/src/lib/auth/controllers/auth.controller.js.map +0 -1
- package/src/lib/auth/controllers/mfa.controller.js +0 -130
- package/src/lib/auth/controllers/mfa.controller.js.map +0 -1
- package/src/lib/auth/dto/index.js +0 -1
- package/src/lib/auth/dto/index.js.map +0 -1
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js +0 -30
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/login.request.dto.js +0 -34
- package/src/lib/auth/dto/requests/login.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js +0 -15
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/reset-password.request.dto.js +0 -42
- package/src/lib/auth/dto/requests/reset-password.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js +0 -16
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/signup.request.dto.js +0 -37
- package/src/lib/auth/dto/requests/signup.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/social-login.request.dto.js +0 -16
- package/src/lib/auth/dto/requests/social-login.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js +0 -21
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js +0 -20
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js.map +0 -1
- package/src/lib/auth/dto/responses/auth.response.dto.js +0 -50
- package/src/lib/auth/dto/responses/auth.response.dto.js.map +0 -1
- package/src/lib/auth/entities/mfa-secret.entity.js +0 -50
- package/src/lib/auth/entities/mfa-secret.entity.js.map +0 -1
- package/src/lib/auth/entities/otp.entity.js +0 -50
- package/src/lib/auth/entities/otp.entity.js.map +0 -1
- package/src/lib/auth/events/logged-out-all.event.js +0 -10
- package/src/lib/auth/events/logged-out-all.event.js.map +0 -1
- package/src/lib/auth/events/logged-out.event.js +0 -10
- package/src/lib/auth/events/logged-out.event.js.map +0 -1
- package/src/lib/auth/events/password-reset-requested.event.js +0 -10
- package/src/lib/auth/events/password-reset-requested.event.js.map +0 -1
- package/src/lib/auth/events/password-reset.event.js +0 -10
- package/src/lib/auth/events/password-reset.event.js.map +0 -1
- package/src/lib/auth/events/user-2fa-verified.event.js +0 -10
- package/src/lib/auth/events/user-2fa-verified.event.js.map +0 -1
- package/src/lib/auth/events/user-logged-in.event.js +0 -10
- package/src/lib/auth/events/user-logged-in.event.js.map +0 -1
- package/src/lib/auth/events/user-refresh-token.event.js +0 -10
- package/src/lib/auth/events/user-refresh-token.event.js.map +0 -1
- package/src/lib/auth/index.js +0 -20
- package/src/lib/auth/index.js.map +0 -1
- package/src/lib/auth/services/auth.service.js +0 -396
- package/src/lib/auth/services/auth.service.js.map +0 -1
- package/src/lib/auth/services/cookie.service.js +0 -43
- package/src/lib/auth/services/cookie.service.js.map +0 -1
- package/src/lib/auth/services/mfa.service.js +0 -255
- package/src/lib/auth/services/mfa.service.js.map +0 -1
- package/src/lib/auth.constants.js +0 -43
- package/src/lib/auth.constants.js.map +0 -1
- package/src/lib/core/core.module.js +0 -67
- package/src/lib/core/core.module.js.map +0 -1
- package/src/lib/core/decorators/role.decorator.js +0 -14
- package/src/lib/core/decorators/role.decorator.js.map +0 -1
- package/src/lib/core/decorators/skip-mfa.decorator.js +0 -8
- package/src/lib/core/decorators/skip-mfa.decorator.js.map +0 -1
- package/src/lib/core/dto/message.response.dto.js +0 -13
- package/src/lib/core/dto/message.response.dto.js.map +0 -1
- package/src/lib/core/entities.js +0 -34
- package/src/lib/core/entities.js.map +0 -1
- package/src/lib/core/guards/auth.guard.js +0 -135
- package/src/lib/core/guards/auth.guard.js.map +0 -1
- package/src/lib/core/guards/role.guard.js +0 -40
- package/src/lib/core/guards/role.guard.js.map +0 -1
- package/src/lib/core/index.js +0 -27
- package/src/lib/core/index.js.map +0 -1
- package/src/lib/core/interfaces/auth-module-options.interface.js +0 -3
- package/src/lib/core/interfaces/auth-module-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/mfa-options.interface.js +0 -10
- package/src/lib/core/interfaces/mfa-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/otp.interface.js +0 -10
- package/src/lib/core/interfaces/otp.interface.js.map +0 -1
- package/src/lib/core/interfaces/session-options.interface.js +0 -9
- package/src/lib/core/interfaces/session-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/token-payload.interface.js +0 -3
- package/src/lib/core/interfaces/token-payload.interface.js.map +0 -1
- package/src/lib/core/providers/apple-auth.provider.js +0 -58
- package/src/lib/core/providers/apple-auth.provider.js.map +0 -1
- package/src/lib/core/providers/base-auth.provider.js +0 -41
- package/src/lib/core/providers/base-auth.provider.js.map +0 -1
- package/src/lib/core/providers/email-auth.provider.js +0 -42
- package/src/lib/core/providers/email-auth.provider.js.map +0 -1
- package/src/lib/core/providers/facebook-auth.provider.js +0 -58
- package/src/lib/core/providers/facebook-auth.provider.js.map +0 -1
- package/src/lib/core/providers/google-auth.provider.js +0 -60
- package/src/lib/core/providers/google-auth.provider.js.map +0 -1
- package/src/lib/core/providers/jwt-auth.provider.js +0 -51
- package/src/lib/core/providers/jwt-auth.provider.js.map +0 -1
- package/src/lib/core/providers/phone-auth.provider.js +0 -45
- package/src/lib/core/providers/phone-auth.provider.js.map +0 -1
- package/src/lib/core/services/auth-provider-registry.service.js +0 -72
- package/src/lib/core/services/auth-provider-registry.service.js.map +0 -1
- package/src/lib/core/services/jwt.service.js +0 -93
- package/src/lib/core/services/jwt.service.js.map +0 -1
- package/src/lib/nest-auth.module.js +0 -118
- package/src/lib/nest-auth.module.js.map +0 -1
- package/src/lib/request-context/request-context.js +0 -108
- package/src/lib/request-context/request-context.js.map +0 -1
- package/src/lib/request-context/request-context.middleware.js +0 -16
- package/src/lib/request-context/request-context.middleware.js.map +0 -1
- package/src/lib/role/entities/permission.entity.js +0 -42
- package/src/lib/role/entities/permission.entity.js.map +0 -1
- package/src/lib/role/entities/role.entity.js +0 -106
- package/src/lib/role/entities/role.entity.js.map +0 -1
- package/src/lib/role/index.js +0 -6
- package/src/lib/role/index.js.map +0 -1
- package/src/lib/role/role.module.js +0 -22
- package/src/lib/role/role.module.js.map +0 -1
- package/src/lib/role/services/role.service.js +0 -220
- package/src/lib/role/services/role.service.js.map +0 -1
- package/src/lib/session/entities/session.entity.js +0 -63
- package/src/lib/session/entities/session.entity.js.map +0 -1
- package/src/lib/session/index.js +0 -8
- package/src/lib/session/index.js.map +0 -1
- package/src/lib/session/services/base-session.service.js +0 -66
- package/src/lib/session/services/base-session.service.js.map +0 -1
- package/src/lib/session/services/database-session.service.js +0 -55
- package/src/lib/session/services/database-session.service.js.map +0 -1
- package/src/lib/session/services/redis-session.service.js +0 -120
- package/src/lib/session/services/redis-session.service.js.map +0 -1
- package/src/lib/session/session.module.js +0 -33
- package/src/lib/session/session.module.js.map +0 -1
- package/src/lib/tenant/entities/tenant.entity.js +0 -44
- package/src/lib/tenant/entities/tenant.entity.js.map +0 -1
- package/src/lib/tenant/events/tenant-created.event.js +0 -10
- package/src/lib/tenant/events/tenant-created.event.js.map +0 -1
- package/src/lib/tenant/events/tenant-deleted.event.js +0 -10
- package/src/lib/tenant/events/tenant-deleted.event.js.map +0 -1
- package/src/lib/tenant/events/tenant-updated.event.js +0 -10
- package/src/lib/tenant/events/tenant-updated.event.js.map +0 -1
- package/src/lib/tenant/index.js +0 -7
- package/src/lib/tenant/index.js.map +0 -1
- package/src/lib/tenant/services/tenant.service.js +0 -136
- package/src/lib/tenant/services/tenant.service.js.map +0 -1
- package/src/lib/tenant/tenant.module.js +0 -27
- package/src/lib/tenant/tenant.module.js.map +0 -1
- package/src/lib/user/dto/requests/update-user.dto.js +0 -24
- package/src/lib/user/dto/requests/update-user.dto.js.map +0 -1
- package/src/lib/user/entities/access-key.entity.js +0 -63
- package/src/lib/user/entities/access-key.entity.js.map +0 -1
- package/src/lib/user/entities/auth-identity.entity.js +0 -47
- package/src/lib/user/entities/auth-identity.entity.js.map +0 -1
- package/src/lib/user/entities/user.entity.js +0 -189
- package/src/lib/user/entities/user.entity.js.map +0 -1
- package/src/lib/user/events/user-created.event.js +0 -10
- package/src/lib/user/events/user-created.event.js.map +0 -1
- package/src/lib/user/events/user-deleted.event.js +0 -10
- package/src/lib/user/events/user-deleted.event.js.map +0 -1
- package/src/lib/user/events/user-registered.event.js +0 -10
- package/src/lib/user/events/user-registered.event.js.map +0 -1
- package/src/lib/user/events/user-updated.event.js +0 -10
- package/src/lib/user/events/user-updated.event.js.map +0 -1
- package/src/lib/user/index.js +0 -8
- package/src/lib/user/index.js.map +0 -1
- package/src/lib/user/services/access-key.service.js +0 -119
- package/src/lib/user/services/access-key.service.js.map +0 -1
- package/src/lib/user/services/user.service.js +0 -217
- package/src/lib/user/services/user.service.js.map +0 -1
- package/src/lib/user/user.module.js +0 -32
- package/src/lib/user/user.module.js.map +0 -1
- package/src/lib/utils/database.utils.js +0 -8
- package/src/lib/utils/database.utils.js.map +0 -1
- package/src/lib/utils/otp.js +0 -7
- package/src/lib/utils/otp.js.map +0 -1
- package/tsconfig.tsbuildinfo +0 -1
|
@@ -1,255 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MfaService = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const common_1 = require("@nestjs/common");
|
|
6
|
-
const typeorm_1 = require("@nestjs/typeorm");
|
|
7
|
-
const typeorm_2 = require("typeorm");
|
|
8
|
-
const mfa_secret_entity_1 = require("../../auth/entities/mfa-secret.entity");
|
|
9
|
-
const speakeasy_1 = tslib_1.__importDefault(require("speakeasy"));
|
|
10
|
-
const qrcode_1 = tslib_1.__importDefault(require("qrcode"));
|
|
11
|
-
const mfa_options_interface_1 = require("../../core/interfaces/mfa-options.interface");
|
|
12
|
-
const auth_constants_1 = require("../../auth.constants");
|
|
13
|
-
const user_entity_1 = require("../../user/entities/user.entity");
|
|
14
|
-
const otp_entity_1 = require("../../auth/entities/otp.entity");
|
|
15
|
-
const otp_interface_1 = require("../../core/interfaces/otp.interface");
|
|
16
|
-
const otp_1 = require("../../utils/otp");
|
|
17
|
-
const ms_1 = tslib_1.__importDefault(require("ms"));
|
|
18
|
-
let MfaService = class MfaService {
|
|
19
|
-
constructor(mfaSecretRepository, userRepository, otpRepository, options) {
|
|
20
|
-
this.mfaSecretRepository = mfaSecretRepository;
|
|
21
|
-
this.userRepository = userRepository;
|
|
22
|
-
this.otpRepository = otpRepository;
|
|
23
|
-
this.options = options;
|
|
24
|
-
this.mfaConfig = this.options.mfa;
|
|
25
|
-
}
|
|
26
|
-
checkIsMfaEnabledForApp(throwError = true) {
|
|
27
|
-
if (!this.mfaConfig.enabled) {
|
|
28
|
-
if (throwError) {
|
|
29
|
-
throw new common_1.ForbiddenException('MFA is not enabled for the application');
|
|
30
|
-
}
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
return true;
|
|
34
|
-
}
|
|
35
|
-
async getEnabledMethods(userId) {
|
|
36
|
-
this.checkIsMfaEnabledForApp(true);
|
|
37
|
-
const isEnabled = await this.isMfaEnabled(userId);
|
|
38
|
-
if (!isEnabled) {
|
|
39
|
-
return [];
|
|
40
|
-
}
|
|
41
|
-
const enableMethod = [];
|
|
42
|
-
if (this.mfaConfig.methods?.includes(mfa_options_interface_1.MFAMethodEnum.EMAIL)) {
|
|
43
|
-
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.EMAIL);
|
|
44
|
-
}
|
|
45
|
-
if (this.mfaConfig.methods?.includes(mfa_options_interface_1.MFAMethodEnum.SMS)) {
|
|
46
|
-
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.SMS);
|
|
47
|
-
}
|
|
48
|
-
const totpDevice = await this.mfaSecretRepository.findOne({
|
|
49
|
-
where: {
|
|
50
|
-
userId,
|
|
51
|
-
},
|
|
52
|
-
});
|
|
53
|
-
if (totpDevice) {
|
|
54
|
-
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.TOTP);
|
|
55
|
-
}
|
|
56
|
-
return enableMethod;
|
|
57
|
-
}
|
|
58
|
-
async sendMfaCode(userId, method) {
|
|
59
|
-
this.checkIsMfaEnabledForApp(true);
|
|
60
|
-
const code = (0, otp_1.generateOtp)(this.mfaConfig.otpLength);
|
|
61
|
-
const expiresAt = (0, ms_1.default)(this.mfaConfig.otpExpiresIn);
|
|
62
|
-
const otp = await this.otpRepository.create({
|
|
63
|
-
userId,
|
|
64
|
-
type: otp_interface_1.OTPTypeEnum.MFA,
|
|
65
|
-
expiresAt: new Date(Date.now() + expiresAt),
|
|
66
|
-
code,
|
|
67
|
-
});
|
|
68
|
-
await this.otpRepository.save(otp);
|
|
69
|
-
if (method === mfa_options_interface_1.MFAMethodEnum.EMAIL) {
|
|
70
|
-
}
|
|
71
|
-
else if (method === mfa_options_interface_1.MFAMethodEnum.SMS) {
|
|
72
|
-
}
|
|
73
|
-
return true;
|
|
74
|
-
}
|
|
75
|
-
async verifyMfa(userId, inputOtp, method) {
|
|
76
|
-
this.checkIsMfaEnabledForApp(true);
|
|
77
|
-
if (method === mfa_options_interface_1.MFAMethodEnum.TOTP) {
|
|
78
|
-
const devices = await this.mfaSecretRepository.find({
|
|
79
|
-
where: { userId, verified: true }
|
|
80
|
-
});
|
|
81
|
-
for (const device of devices) {
|
|
82
|
-
const isValid = speakeasy_1.default.totp.verify({
|
|
83
|
-
secret: device.secret,
|
|
84
|
-
encoding: 'base32',
|
|
85
|
-
token: inputOtp,
|
|
86
|
-
window: 1
|
|
87
|
-
});
|
|
88
|
-
if (isValid) {
|
|
89
|
-
await this.mfaSecretRepository.update({ id: device.id }, { lastUsedAt: new Date() });
|
|
90
|
-
return true;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
return false;
|
|
94
|
-
}
|
|
95
|
-
if (method === mfa_options_interface_1.MFAMethodEnum.EMAIL || method === mfa_options_interface_1.MFAMethodEnum.SMS) {
|
|
96
|
-
const otp = await this.otpRepository.findOne({
|
|
97
|
-
where: {
|
|
98
|
-
userId,
|
|
99
|
-
type: otp_interface_1.OTPTypeEnum.MFA,
|
|
100
|
-
used: false,
|
|
101
|
-
expiresAt: (0, typeorm_2.MoreThan)(new Date()),
|
|
102
|
-
code: inputOtp
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
if (!otp) {
|
|
106
|
-
return false;
|
|
107
|
-
}
|
|
108
|
-
await this.otpRepository.delete(otp.id);
|
|
109
|
-
return true;
|
|
110
|
-
}
|
|
111
|
-
return false;
|
|
112
|
-
}
|
|
113
|
-
async setupTotpDevice(userId, deviceName) {
|
|
114
|
-
this.checkIsMfaEnabledForApp(true);
|
|
115
|
-
const user = await this.userRepository.findOne({ where: { id: userId } });
|
|
116
|
-
if (!user) {
|
|
117
|
-
throw new Error('User not found');
|
|
118
|
-
}
|
|
119
|
-
const secret = speakeasy_1.default.generateSecret();
|
|
120
|
-
await this.mfaSecretRepository.save({
|
|
121
|
-
userId,
|
|
122
|
-
secret: secret.base32,
|
|
123
|
-
deviceName: deviceName || 'Authenticator',
|
|
124
|
-
verified: false
|
|
125
|
-
});
|
|
126
|
-
const qrCode = await qrcode_1.default.toDataURL(secret.otpauth_url);
|
|
127
|
-
return { secret: secret.base32, qrCode };
|
|
128
|
-
}
|
|
129
|
-
async verifyTotpSetup(userId, secret, inputOtp) {
|
|
130
|
-
this.checkIsMfaEnabledForApp(true);
|
|
131
|
-
const device = await this.mfaSecretRepository.findOne({
|
|
132
|
-
where: { userId, secret }
|
|
133
|
-
});
|
|
134
|
-
if (device) {
|
|
135
|
-
if (device.verified) {
|
|
136
|
-
return true;
|
|
137
|
-
}
|
|
138
|
-
const isValid = speakeasy_1.default.totp.verify({
|
|
139
|
-
secret: device.secret,
|
|
140
|
-
encoding: 'base32',
|
|
141
|
-
token: inputOtp,
|
|
142
|
-
window: 1
|
|
143
|
-
});
|
|
144
|
-
if (isValid) {
|
|
145
|
-
await this.mfaSecretRepository.update({ id: device.id }, { verified: true });
|
|
146
|
-
return true;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return false;
|
|
150
|
-
}
|
|
151
|
-
async getTotpDevices(userId) {
|
|
152
|
-
this.checkIsMfaEnabledForApp(true);
|
|
153
|
-
const devices = await this.mfaSecretRepository.find({
|
|
154
|
-
select: ['id', 'deviceName', 'lastUsedAt', 'verified'],
|
|
155
|
-
where: { userId },
|
|
156
|
-
order: { lastUsedAt: 'DESC' }
|
|
157
|
-
});
|
|
158
|
-
return devices.map(device => ({
|
|
159
|
-
id: device.id,
|
|
160
|
-
deviceName: device.deviceName,
|
|
161
|
-
lastUsedAt: device.lastUsedAt,
|
|
162
|
-
verified: device.verified,
|
|
163
|
-
}));
|
|
164
|
-
}
|
|
165
|
-
async removeDevice(deviceId) {
|
|
166
|
-
this.checkIsMfaEnabledForApp(true);
|
|
167
|
-
await this.mfaSecretRepository.delete({ id: deviceId });
|
|
168
|
-
}
|
|
169
|
-
async isRequiresMfa(userId) {
|
|
170
|
-
if (!this.mfaConfig.enabled) {
|
|
171
|
-
return false;
|
|
172
|
-
}
|
|
173
|
-
if (this.mfaConfig.required) {
|
|
174
|
-
return true;
|
|
175
|
-
}
|
|
176
|
-
const user = await this.userRepository.findOne({
|
|
177
|
-
select: ['id', 'isMfaEnabled'],
|
|
178
|
-
where: { id: userId },
|
|
179
|
-
});
|
|
180
|
-
return !!user?.isMfaEnabled;
|
|
181
|
-
}
|
|
182
|
-
async isMfaEnabled(userId) {
|
|
183
|
-
if (this.mfaConfig.enabled) {
|
|
184
|
-
const user = await this.userRepository.findOne({
|
|
185
|
-
select: ['id', 'isMfaEnabled'],
|
|
186
|
-
where: { id: userId },
|
|
187
|
-
});
|
|
188
|
-
return !!user?.isMfaEnabled;
|
|
189
|
-
}
|
|
190
|
-
return false;
|
|
191
|
-
}
|
|
192
|
-
async markAsVerified(userId, deviceId) {
|
|
193
|
-
this.checkIsMfaEnabledForApp(true);
|
|
194
|
-
await this.mfaSecretRepository.update({ id: deviceId, userId }, { verified: true });
|
|
195
|
-
}
|
|
196
|
-
async enableMFA(userId) {
|
|
197
|
-
this.checkIsMfaEnabledForApp(true);
|
|
198
|
-
if (!this.mfaConfig.allowUserToggle) {
|
|
199
|
-
throw new Error('MFA toggling is not allowed');
|
|
200
|
-
}
|
|
201
|
-
await this.userRepository.update(userId, { isMfaEnabled: true });
|
|
202
|
-
}
|
|
203
|
-
async disableMFA(userId) {
|
|
204
|
-
this.checkIsMfaEnabledForApp(true);
|
|
205
|
-
if (!this.mfaConfig.allowUserToggle) {
|
|
206
|
-
throw new Error('MFA toggling is not allowed');
|
|
207
|
-
}
|
|
208
|
-
await this.userRepository.update(userId, { isMfaEnabled: false });
|
|
209
|
-
}
|
|
210
|
-
async removeTotpDevice(deviceId) {
|
|
211
|
-
this.checkIsMfaEnabledForApp(true);
|
|
212
|
-
await this.mfaSecretRepository.delete({ id: deviceId });
|
|
213
|
-
}
|
|
214
|
-
async generateRecoveryCode(userId) {
|
|
215
|
-
this.checkIsMfaEnabledForApp(true);
|
|
216
|
-
const secret = speakeasy_1.default.generateSecret({
|
|
217
|
-
name: `NestAuth:${userId}`,
|
|
218
|
-
});
|
|
219
|
-
await this.userRepository.update(userId, { mfaRecoveryCode: secret.base32 });
|
|
220
|
-
return secret.base32;
|
|
221
|
-
}
|
|
222
|
-
async resetMfa(userId, code) {
|
|
223
|
-
this.checkIsMfaEnabledForApp(true);
|
|
224
|
-
const user = await this.userRepository.findOne({ where: { id: userId } });
|
|
225
|
-
if (!user) {
|
|
226
|
-
throw new common_1.UnauthorizedException({
|
|
227
|
-
message: 'User not found',
|
|
228
|
-
code: auth_constants_1.USER_NOT_FOUND_EXCEPTION_CODE
|
|
229
|
-
});
|
|
230
|
-
}
|
|
231
|
-
if (user.mfaRecoveryCode === code) {
|
|
232
|
-
await this.userRepository.update(userId, { mfaRecoveryCode: null });
|
|
233
|
-
await this.mfaSecretRepository.delete({ userId });
|
|
234
|
-
return {
|
|
235
|
-
message: 'Recovery code verified',
|
|
236
|
-
};
|
|
237
|
-
}
|
|
238
|
-
throw new common_1.UnauthorizedException({
|
|
239
|
-
message: 'Invalid recovery code',
|
|
240
|
-
code: auth_constants_1.INVALID_MFA_EXCEPTION_CODE
|
|
241
|
-
});
|
|
242
|
-
}
|
|
243
|
-
};
|
|
244
|
-
exports.MfaService = MfaService;
|
|
245
|
-
exports.MfaService = MfaService = tslib_1.__decorate([
|
|
246
|
-
(0, common_1.Injectable)(),
|
|
247
|
-
tslib_1.__param(0, (0, typeorm_1.InjectRepository)(mfa_secret_entity_1.MFASecret)),
|
|
248
|
-
tslib_1.__param(1, (0, typeorm_1.InjectRepository)(user_entity_1.User)),
|
|
249
|
-
tslib_1.__param(2, (0, typeorm_1.InjectRepository)(otp_entity_1.OTP)),
|
|
250
|
-
tslib_1.__param(3, (0, common_1.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
251
|
-
tslib_1.__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
252
|
-
typeorm_2.Repository,
|
|
253
|
-
typeorm_2.Repository, Object])
|
|
254
|
-
], MfaService);
|
|
255
|
-
//# sourceMappingURL=mfa.service.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mfa.service.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/auth/services/mfa.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NestAuthEvents = exports.DEFAULT_GUARD_NAME = exports.REFRESH_TOKEN_COOKIE_NAME = exports.ACCESS_TOKEN_COOKIE_NAME = exports.REFRESH_TOKEN_EXPIRED = exports.REFRESH_TOKEN_INVALID = exports.USER_NOT_ACTIVE_ERROR = exports.SESSION_NOT_FOUND_ERROR = exports.INVALID_REFRESH_TOKEN_EXCEPTION_CODE = exports.INVALID_MFA_EXCEPTION_CODE = exports.UNAUTHORIZED_EXCEPTION_CODE = exports.USER_NOT_FOUND_EXCEPTION_CODE = exports.ENABLED_AUTH_PROVIDERS = exports.PHONE_AUTH_PROVIDER = exports.EMAIL_AUTH_PROVIDER = exports.APPLE_AUTH_PROVIDER = exports.FACEBOOK_AUTH_PROVIDER = exports.GOOGLE_AUTH_PROVIDER = exports.JWT_AUTH_PROVIDER = exports.AUTH_MODULE_OPTIONS = void 0;
|
|
4
|
-
exports.AUTH_MODULE_OPTIONS = 'NEST_AUTH_AUTH_MODULE_OPTIONS';
|
|
5
|
-
exports.JWT_AUTH_PROVIDER = 'jwt';
|
|
6
|
-
exports.GOOGLE_AUTH_PROVIDER = 'google';
|
|
7
|
-
exports.FACEBOOK_AUTH_PROVIDER = 'facebook';
|
|
8
|
-
exports.APPLE_AUTH_PROVIDER = 'apple';
|
|
9
|
-
exports.EMAIL_AUTH_PROVIDER = 'email';
|
|
10
|
-
exports.PHONE_AUTH_PROVIDER = 'phone';
|
|
11
|
-
exports.ENABLED_AUTH_PROVIDERS = 'NEST_AUTH_ENABLED_AUTH_PROVIDERS';
|
|
12
|
-
exports.USER_NOT_FOUND_EXCEPTION_CODE = 'USER_NOT_FOUND';
|
|
13
|
-
exports.UNAUTHORIZED_EXCEPTION_CODE = 'UNAUTHORIZED';
|
|
14
|
-
exports.INVALID_MFA_EXCEPTION_CODE = 'INVALID_MFA';
|
|
15
|
-
exports.INVALID_REFRESH_TOKEN_EXCEPTION_CODE = 'INVALID_REFRESH_TOKEN';
|
|
16
|
-
exports.SESSION_NOT_FOUND_ERROR = 'SESSION_NOT_FOUND';
|
|
17
|
-
exports.USER_NOT_ACTIVE_ERROR = 'USER_NOT_ACTIVE';
|
|
18
|
-
exports.REFRESH_TOKEN_INVALID = 'REFRESH_TOKEN_INVALID';
|
|
19
|
-
exports.REFRESH_TOKEN_EXPIRED = 'REFRESH_TOKEN_EXPIRED';
|
|
20
|
-
exports.ACCESS_TOKEN_COOKIE_NAME = 'accessToken';
|
|
21
|
-
exports.REFRESH_TOKEN_COOKIE_NAME = 'refreshToken';
|
|
22
|
-
exports.DEFAULT_GUARD_NAME = 'web';
|
|
23
|
-
exports.NestAuthEvents = {
|
|
24
|
-
LOGGED_IN: 'nest_auth.logged_in',
|
|
25
|
-
REGISTERED: 'nest_auth.registered',
|
|
26
|
-
TWO_FACTOR_VERIFIED: 'nest_auth.two_factor_verified',
|
|
27
|
-
REFRESH_TOKEN: 'nest_auth.refresh_token',
|
|
28
|
-
PASSWORD_RESET_REQUESTED: 'nest_auth.password_reset_requested',
|
|
29
|
-
PASSWORD_RESET: 'nest_auth.password_reset',
|
|
30
|
-
LOGGED_OUT: 'nest_auth.logged_out',
|
|
31
|
-
LOGGED_OUT_ALL: 'nest_auth.logged_out_all',
|
|
32
|
-
USER_CREATED: 'nest_auth.user.created',
|
|
33
|
-
USER_UPDATED: 'nest_auth.user.updated',
|
|
34
|
-
USER_DELETED: 'nest_auth.user.deleted',
|
|
35
|
-
TENANT_CREATED: 'nest_auth.tenant.created',
|
|
36
|
-
TENANT_UPDATED: 'nest_auth.tenant.updated',
|
|
37
|
-
TENANT_DELETED: 'nest_auth.tenant.deleted',
|
|
38
|
-
ACCESS_KEY_CREATED: 'nest_auth.access_key.created',
|
|
39
|
-
ACCESS_KEY_DELETED: 'nest_auth.access_key.deleted',
|
|
40
|
-
ACCESS_KEY_UPDATED: 'nest_auth.access_key.updated',
|
|
41
|
-
ACCESS_KEY_DEACTIVATED: 'nest_auth.access_key.deactivated',
|
|
42
|
-
};
|
|
43
|
-
//# sourceMappingURL=auth.constants.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.constants.js","sourceRoot":"","sources":["../../../../../packages/nest-auth/src/lib/auth.constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,mBAAmB,GAAG,+BAA+B,CAAC;AAItD,QAAA,iBAAiB,GAAG,KAAK,CAAC;AAC1B,QAAA,oBAAoB,GAAG,QAAQ,CAAC;AAChC,QAAA,sBAAsB,GAAG,UAAU,CAAC;AACpC,QAAA,mBAAmB,GAAG,OAAO,CAAC;AAC9B,QAAA,mBAAmB,GAAG,OAAO,CAAC;AAC9B,QAAA,mBAAmB,GAAG,OAAO,CAAC;AAG9B,QAAA,sBAAsB,GAAG,kCAAkC,CAAC;AAI5D,QAAA,6BAA6B,GAAG,gBAAgB,CAAC;AACjD,QAAA,2BAA2B,GAAG,cAAc,CAAC;AAC7C,QAAA,0BAA0B,GAAG,aAAa,CAAC;AAC3C,QAAA,oCAAoC,GAAG,uBAAuB,CAAC;AAC/D,QAAA,uBAAuB,GAAG,mBAAmB,CAAC;AAC9C,QAAA,qBAAqB,GAAG,iBAAiB,CAAC;AAE1C,QAAA,qBAAqB,GAAG,uBAAuB,CAAC;AAChD,QAAA,qBAAqB,GAAG,uBAAuB,CAAC;AAIhD,QAAA,wBAAwB,GAAG,aAAa,CAAC;AACzC,QAAA,yBAAyB,GAAG,cAAc,CAAC;AAG3C,QAAA,kBAAkB,GAAG,KAAK,CAAC;AAG3B,QAAA,cAAc,GAAG;IAE1B,SAAS,EAAE,qBAAqB;IAChC,UAAU,EAAE,sBAAsB;IAClC,mBAAmB,EAAE,+BAA+B;IACpD,aAAa,EAAE,yBAAyB;IACxC,wBAAwB,EAAE,oCAAoC;IAC9D,cAAc,EAAE,0BAA0B;IAC1C,UAAU,EAAE,sBAAsB;IAClC,cAAc,EAAE,0BAA0B;IAG1C,YAAY,EAAE,wBAAwB;IACtC,YAAY,EAAE,wBAAwB;IACtC,YAAY,EAAE,wBAAwB;IAGtC,cAAc,EAAE,0BAA0B;IAC1C,cAAc,EAAE,0BAA0B;IAC1C,cAAc,EAAE,0BAA0B;IAG1C,kBAAkB,EAAE,8BAA8B;IAClD,kBAAkB,EAAE,8BAA8B;IAClD,kBAAkB,EAAE,8BAA8B;IAClD,sBAAsB,EAAE,kCAAkC;CACpD,CAAC"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var CoreModule_1;
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.CoreModule = void 0;
|
|
5
|
-
const tslib_1 = require("tslib");
|
|
6
|
-
const common_1 = require("@nestjs/common");
|
|
7
|
-
const auth_constants_1 = require("../auth.constants");
|
|
8
|
-
const auth_provider_registry_service_1 = require("./services/auth-provider-registry.service");
|
|
9
|
-
const apple_auth_provider_1 = require("./providers/apple-auth.provider");
|
|
10
|
-
const jwt_auth_provider_1 = require("./providers/jwt-auth.provider");
|
|
11
|
-
const email_auth_provider_1 = require("./providers/email-auth.provider");
|
|
12
|
-
const facebook_auth_provider_1 = require("./providers/facebook-auth.provider");
|
|
13
|
-
const google_auth_provider_1 = require("./providers/google-auth.provider");
|
|
14
|
-
const phone_auth_provider_1 = require("./providers/phone-auth.provider");
|
|
15
|
-
const typeorm_1 = require("@nestjs/typeorm");
|
|
16
|
-
const auth_identity_entity_1 = require("../user/entities/auth-identity.entity");
|
|
17
|
-
const user_entity_1 = require("../user/entities/user.entity");
|
|
18
|
-
const jwt_service_1 = require("./services/jwt.service");
|
|
19
|
-
let CoreModule = CoreModule_1 = class CoreModule {
|
|
20
|
-
static forRoot(options) {
|
|
21
|
-
return {
|
|
22
|
-
imports: [],
|
|
23
|
-
module: CoreModule_1,
|
|
24
|
-
providers: [
|
|
25
|
-
{
|
|
26
|
-
provide: auth_constants_1.AUTH_MODULE_OPTIONS,
|
|
27
|
-
useValue: options,
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
provide: auth_constants_1.ENABLED_AUTH_PROVIDERS,
|
|
31
|
-
useFactory: (registry) => {
|
|
32
|
-
return registry.getAllProviders();
|
|
33
|
-
},
|
|
34
|
-
inject: [auth_provider_registry_service_1.AuthProviderRegistryService],
|
|
35
|
-
},
|
|
36
|
-
],
|
|
37
|
-
exports: [
|
|
38
|
-
auth_constants_1.AUTH_MODULE_OPTIONS,
|
|
39
|
-
auth_constants_1.ENABLED_AUTH_PROVIDERS,
|
|
40
|
-
],
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
exports.CoreModule = CoreModule;
|
|
45
|
-
exports.CoreModule = CoreModule = CoreModule_1 = tslib_1.__decorate([
|
|
46
|
-
(0, common_1.Global)(),
|
|
47
|
-
(0, common_1.Module)({
|
|
48
|
-
imports: [
|
|
49
|
-
typeorm_1.TypeOrmModule.forFeature([user_entity_1.User, auth_identity_entity_1.AuthIdentity])
|
|
50
|
-
],
|
|
51
|
-
providers: [
|
|
52
|
-
jwt_service_1.JwtService,
|
|
53
|
-
auth_provider_registry_service_1.AuthProviderRegistryService,
|
|
54
|
-
email_auth_provider_1.EmailAuthProvider,
|
|
55
|
-
phone_auth_provider_1.PhoneAuthProvider,
|
|
56
|
-
jwt_auth_provider_1.JwtAuthProvider,
|
|
57
|
-
google_auth_provider_1.GoogleAuthProvider,
|
|
58
|
-
facebook_auth_provider_1.FacebookAuthProvider,
|
|
59
|
-
apple_auth_provider_1.AppleAuthProvider,
|
|
60
|
-
],
|
|
61
|
-
exports: [
|
|
62
|
-
jwt_service_1.JwtService,
|
|
63
|
-
auth_provider_registry_service_1.AuthProviderRegistryService,
|
|
64
|
-
],
|
|
65
|
-
})
|
|
66
|
-
], CoreModule);
|
|
67
|
-
//# sourceMappingURL=core.module.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"core.module.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/core/core.module.ts"],"names":[],"mappings":";;;;;AAAA,2CAA+D;AAE/D,sDAAgF;AAChF,8FAAwF;AACxF,yEAAoE;AACpE,qEAAgE;AAChE,yEAAoE;AACpE,+EAA0E;AAC1E,2EAAsE;AACtE,yEAAoE;AACpE,6CAAgD;AAChD,gFAAqE;AACrE,8DAAoD;AACpD,wDAAoD;AAsB7C,IAAM,UAAU,kBAAhB,MAAM,UAAU;IACnB,MAAM,CAAC,OAAO,CAAC,OAA0B;QAErC,OAAO;YACH,OAAO,EAAE,EAER;YACD,MAAM,EAAE,YAAU;YAClB,SAAS,EAAE;gBACP;oBACI,OAAO,EAAE,oCAAmB;oBAC5B,QAAQ,EAAE,OAAO;iBACpB;gBACD;oBACI,OAAO,EAAE,uCAAsB;oBAC/B,UAAU,EAAE,CAAC,QAAqC,EAAE,EAAE;wBAClD,OAAO,QAAQ,CAAC,eAAe,EAAE,CAAC;oBACtC,CAAC;oBACD,MAAM,EAAE,CAAC,4DAA2B,CAAC;iBACxC;aACJ;YACD,OAAO,EAAE;gBACL,oCAAmB;gBACnB,uCAAsB;aACzB;SACJ,CAAC;IACN,CAAC;CACJ,CAAA;AA3BY,gCAAU;qBAAV,UAAU;IApBtB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE;YACL,uBAAa,CAAC,UAAU,CAAC,CAAC,kBAAI,EAAE,mCAAY,CAAC,CAAC;SACjD;QACD,SAAS,EAAE;YACP,wBAAU;YACV,4DAA2B;YAC3B,uCAAiB;YACjB,uCAAiB;YACjB,mCAAe;YACf,yCAAkB;YAClB,6CAAoB;YACpB,uCAAiB;SACpB;QACD,OAAO,EAAE;YACL,wBAAU;YACV,4DAA2B;SAC9B;KACJ,CAAC;GACW,UAAU,CA2BtB"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GUARD_KEY = exports.ROLES_KEY = void 0;
|
|
4
|
-
exports.NestAuthRoles = NestAuthRoles;
|
|
5
|
-
exports.ROLES_KEY = 'nest_auth_roles';
|
|
6
|
-
exports.GUARD_KEY = 'nest_auth_guard';
|
|
7
|
-
function NestAuthRoles(roles, guard) {
|
|
8
|
-
return (target, key, descriptor) => {
|
|
9
|
-
Reflect.defineMetadata(exports.ROLES_KEY, roles, descriptor.value);
|
|
10
|
-
Reflect.defineMetadata(exports.GUARD_KEY, guard, descriptor.value);
|
|
11
|
-
return descriptor;
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=role.decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"role.decorator.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/core/decorators/role.decorator.ts"],"names":[],"mappings":";;;AAKA,sCAMC;AAVY,QAAA,SAAS,GAAG,iBAAiB,CAAC;AAC9B,QAAA,SAAS,GAAG,iBAAiB,CAAC;AAG3C,SAAgB,aAAa,CAAC,KAAwB,EAAE,KAAc;IAClE,OAAO,CAAC,MAAW,EAAE,GAAW,EAAE,UAA8B,EAAE,EAAE;QAChE,OAAO,CAAC,cAAc,CAAC,iBAAS,EAAE,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,CAAC,cAAc,CAAC,iBAAS,EAAE,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,UAAU,CAAC;IACtB,CAAC,CAAC;AACN,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SkipMfa = exports.SKIP_MFA_KEY = void 0;
|
|
4
|
-
const common_1 = require("@nestjs/common");
|
|
5
|
-
exports.SKIP_MFA_KEY = 'skipMfa';
|
|
6
|
-
const SkipMfa = () => (0, common_1.SetMetadata)(exports.SKIP_MFA_KEY, true);
|
|
7
|
-
exports.SkipMfa = SkipMfa;
|
|
8
|
-
//# sourceMappingURL=skip-mfa.decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"skip-mfa.decorator.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/core/decorators/skip-mfa.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEhC,QAAA,YAAY,GAAG,SAAS,CAAC;AAC/B,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,IAAA,oBAAW,EAAC,oBAAY,EAAE,IAAI,CAAC,CAAC;AAAhD,QAAA,OAAO,WAAyC"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MessageResponseDto = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const swagger_1 = require("@nestjs/swagger");
|
|
6
|
-
class MessageResponseDto {
|
|
7
|
-
}
|
|
8
|
-
exports.MessageResponseDto = MessageResponseDto;
|
|
9
|
-
tslib_1.__decorate([
|
|
10
|
-
(0, swagger_1.ApiProperty)({ description: 'Response message' }),
|
|
11
|
-
tslib_1.__metadata("design:type", String)
|
|
12
|
-
], MessageResponseDto.prototype, "message", void 0);
|
|
13
|
-
//# sourceMappingURL=message.response.dto.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"message.response.dto.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/core/dto/message.response.dto.ts"],"names":[],"mappings":";;;;AAAA,6CAA8C;AAE9C,MAAa,kBAAkB;CAG9B;AAHD,gDAGC;AADG;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC;;mDACjC"}
|
package/src/lib/core/entities.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NestAuthEntities = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const user_entity_1 = require("../user/entities/user.entity");
|
|
6
|
-
const auth_identity_entity_1 = require("../user/entities/auth-identity.entity");
|
|
7
|
-
const access_key_entity_1 = require("../user/entities/access-key.entity");
|
|
8
|
-
const tenant_entity_1 = require("../tenant/entities/tenant.entity");
|
|
9
|
-
const role_entity_1 = require("../role/entities/role.entity");
|
|
10
|
-
const permission_entity_1 = require("../role/entities/permission.entity");
|
|
11
|
-
const mfa_secret_entity_1 = require("../auth/entities/mfa-secret.entity");
|
|
12
|
-
const otp_entity_1 = require("../auth/entities/otp.entity");
|
|
13
|
-
const session_entity_1 = require("../session/entities/session.entity");
|
|
14
|
-
tslib_1.__exportStar(require("../user/entities/user.entity"), exports);
|
|
15
|
-
tslib_1.__exportStar(require("../user/entities/auth-identity.entity"), exports);
|
|
16
|
-
tslib_1.__exportStar(require("../user/entities/access-key.entity"), exports);
|
|
17
|
-
tslib_1.__exportStar(require("../tenant/entities/tenant.entity"), exports);
|
|
18
|
-
tslib_1.__exportStar(require("../role/entities/role.entity"), exports);
|
|
19
|
-
tslib_1.__exportStar(require("../role/entities/permission.entity"), exports);
|
|
20
|
-
tslib_1.__exportStar(require("../auth/entities/mfa-secret.entity"), exports);
|
|
21
|
-
tslib_1.__exportStar(require("../auth/entities/otp.entity"), exports);
|
|
22
|
-
tslib_1.__exportStar(require("../session/entities/session.entity"), exports);
|
|
23
|
-
exports.NestAuthEntities = [
|
|
24
|
-
user_entity_1.User,
|
|
25
|
-
auth_identity_entity_1.AuthIdentity,
|
|
26
|
-
role_entity_1.Role,
|
|
27
|
-
permission_entity_1.Permission,
|
|
28
|
-
tenant_entity_1.Tenant,
|
|
29
|
-
mfa_secret_entity_1.MFASecret,
|
|
30
|
-
session_entity_1.Session,
|
|
31
|
-
otp_entity_1.OTP,
|
|
32
|
-
access_key_entity_1.AccessKey,
|
|
33
|
-
];
|
|
34
|
-
//# sourceMappingURL=entities.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"entities.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/core/entities.ts"],"names":[],"mappings":";;;;AAAA,8DAAoD;AACpD,gFAAqE;AACrE,0EAA+D;AAC/D,oEAA0D;AAC1D,8DAAoD;AACpD,0EAAgE;AAChE,0EAA+D;AAC/D,4DAAkD;AAClD,uEAA6D;AAE7D,uEAA6C;AAC7C,gFAAsD;AACtD,6EAAmD;AACnD,2EAAiD;AACjD,uEAA6C;AAC7C,6EAAmD;AACnD,6EAAmD;AACnD,sEAA4C;AAC5C,6EAAmD;AAEtC,QAAA,gBAAgB,GAAG;IAC5B,kBAAI;IACJ,mCAAY;IACZ,kBAAI;IACJ,8BAAU;IACV,sBAAM;IACN,6BAAS;IACT,wBAAO;IACP,gBAAG;IACH,6BAAS;CACZ,CAAC"}
|
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NestAuthAuthGuard = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const common_1 = require("@nestjs/common");
|
|
6
|
-
const auth_constants_1 = require("../../auth.constants");
|
|
7
|
-
const core_1 = require("@nestjs/core");
|
|
8
|
-
const jwt_service_1 = require("../../core/services/jwt.service");
|
|
9
|
-
const auth_service_1 = require("../../auth/services/auth.service");
|
|
10
|
-
const base_session_service_1 = require("../../session/services/base-session.service");
|
|
11
|
-
const cookie_service_1 = require("../../auth/services/cookie.service");
|
|
12
|
-
const access_key_service_1 = require("../../user/services/access-key.service");
|
|
13
|
-
const skip_mfa_decorator_1 = require("../decorators/skip-mfa.decorator");
|
|
14
|
-
let NestAuthAuthGuard = class NestAuthAuthGuard {
|
|
15
|
-
constructor(reflector, jwtService, authService, sessionService, cookieService, accessKeyService) {
|
|
16
|
-
this.reflector = reflector;
|
|
17
|
-
this.jwtService = jwtService;
|
|
18
|
-
this.authService = authService;
|
|
19
|
-
this.sessionService = sessionService;
|
|
20
|
-
this.cookieService = cookieService;
|
|
21
|
-
this.accessKeyService = accessKeyService;
|
|
22
|
-
}
|
|
23
|
-
async canActivate(context) {
|
|
24
|
-
const request = context.switchToHttp().getRequest();
|
|
25
|
-
const response = context.switchToHttp().getResponse();
|
|
26
|
-
const authHeader = request.headers.authorization;
|
|
27
|
-
if (!authHeader) {
|
|
28
|
-
throw new common_1.UnauthorizedException({
|
|
29
|
-
message: 'No authentication provided',
|
|
30
|
-
code: 'NO_AUTH'
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
const [type, token] = authHeader.split(' ');
|
|
34
|
-
switch (type.toLowerCase()) {
|
|
35
|
-
case 'bearer':
|
|
36
|
-
return await this.handleJwtAuth(context, request, response, token);
|
|
37
|
-
case 'apikey':
|
|
38
|
-
return await this.handleApiKeyAuth(request, token);
|
|
39
|
-
default:
|
|
40
|
-
throw new common_1.UnauthorizedException({
|
|
41
|
-
message: 'Invalid authentication type',
|
|
42
|
-
code: 'INVALID_AUTH_TYPE'
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
async handleJwtAuth(context, request, response, token) {
|
|
47
|
-
try {
|
|
48
|
-
const payload = await this.jwtService.verifyToken(token);
|
|
49
|
-
request['user'] = payload;
|
|
50
|
-
request['authType'] = 'jwt';
|
|
51
|
-
const session = await this.sessionService.getSession(payload.sessionId);
|
|
52
|
-
if (!session) {
|
|
53
|
-
throw new common_1.UnauthorizedException({
|
|
54
|
-
message: 'Session not found',
|
|
55
|
-
code: auth_constants_1.UNAUTHORIZED_EXCEPTION_CODE
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
request['session'] = session;
|
|
59
|
-
await this.checkMfa(context, payload);
|
|
60
|
-
return true;
|
|
61
|
-
}
|
|
62
|
-
catch (error) {
|
|
63
|
-
const refreshToken = this.extractRefreshToken(request);
|
|
64
|
-
if (!refreshToken) {
|
|
65
|
-
throw new common_1.UnauthorizedException({
|
|
66
|
-
message: 'Invalid token',
|
|
67
|
-
code: auth_constants_1.UNAUTHORIZED_EXCEPTION_CODE
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
const newSession = await this.authService.refreshToken(refreshToken);
|
|
71
|
-
this.cookieService.setTokens(response, newSession.accessToken, newSession.refreshToken);
|
|
72
|
-
const payload = await this.jwtService.verifyToken(newSession.accessToken);
|
|
73
|
-
await this.checkMfa(context, payload);
|
|
74
|
-
return true;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
async handleApiKeyAuth(request, token) {
|
|
78
|
-
const [publicKey, privateKey] = token.split('.');
|
|
79
|
-
if (!publicKey || !privateKey) {
|
|
80
|
-
throw new common_1.UnauthorizedException({
|
|
81
|
-
message: 'Invalid API key format',
|
|
82
|
-
code: 'INVALID_API_KEY_FORMAT'
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
const isValid = await this.accessKeyService.validateAccessKey(publicKey, privateKey);
|
|
86
|
-
if (!isValid) {
|
|
87
|
-
throw new common_1.UnauthorizedException({
|
|
88
|
-
message: 'Invalid API key',
|
|
89
|
-
code: 'INVALID_API_KEY'
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
const accessKey = await this.accessKeyService.getAccessKey(publicKey);
|
|
93
|
-
await this.accessKeyService.updateAccessKeyLastUsed(publicKey);
|
|
94
|
-
request['user'] = accessKey.user;
|
|
95
|
-
request['accessKey'] = accessKey;
|
|
96
|
-
request['authType'] = 'api-key';
|
|
97
|
-
return true;
|
|
98
|
-
}
|
|
99
|
-
extractRefreshToken(request) {
|
|
100
|
-
const tokenFromCookie = request.cookies?.[auth_constants_1.REFRESH_TOKEN_COOKIE_NAME];
|
|
101
|
-
if (tokenFromCookie) {
|
|
102
|
-
return tokenFromCookie;
|
|
103
|
-
}
|
|
104
|
-
const authHeader = request.headers['x-refresh-token'];
|
|
105
|
-
if (authHeader) {
|
|
106
|
-
return authHeader;
|
|
107
|
-
}
|
|
108
|
-
return null;
|
|
109
|
-
}
|
|
110
|
-
async checkMfa(context, payload) {
|
|
111
|
-
const skipMfa = this.reflector.getAllAndOverride(skip_mfa_decorator_1.SKIP_MFA_KEY, [
|
|
112
|
-
context.getHandler(),
|
|
113
|
-
context.getClass(),
|
|
114
|
-
]);
|
|
115
|
-
const isMfaEnabled = payload.isMfaEnabled;
|
|
116
|
-
const isMfaVerified = payload.isMfaVerified;
|
|
117
|
-
if (isMfaEnabled && !isMfaVerified && !skipMfa) {
|
|
118
|
-
throw new common_1.UnauthorizedException({
|
|
119
|
-
message: 'Multi-factor authentication is required',
|
|
120
|
-
code: auth_constants_1.UNAUTHORIZED_EXCEPTION_CODE
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
exports.NestAuthAuthGuard = NestAuthAuthGuard;
|
|
126
|
-
exports.NestAuthAuthGuard = NestAuthAuthGuard = tslib_1.__decorate([
|
|
127
|
-
(0, common_1.Injectable)(),
|
|
128
|
-
tslib_1.__metadata("design:paramtypes", [core_1.Reflector,
|
|
129
|
-
jwt_service_1.JwtService,
|
|
130
|
-
auth_service_1.AuthService,
|
|
131
|
-
base_session_service_1.BaseSessionService,
|
|
132
|
-
cookie_service_1.CookieService,
|
|
133
|
-
access_key_service_1.AccessKeyService])
|
|
134
|
-
], NestAuthAuthGuard);
|
|
135
|
-
//# sourceMappingURL=auth.guard.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.guard.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/core/guards/auth.guard.ts"],"names":[],"mappings":"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"}
|