@ackplus/nest-auth 0.0.39 → 0.0.41
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 +226 -0
- package/package.json +2 -2
- package/src/index.js +12 -0
- package/src/index.js.map +1 -0
- package/src/lib/auth/auth.module.js +52 -0
- package/src/lib/auth/auth.module.js.map +1 -0
- package/src/lib/auth/controllers/auth.controller.js +189 -0
- package/src/lib/auth/controllers/auth.controller.js.map +1 -0
- package/src/lib/auth/controllers/mfa.controller.js +130 -0
- package/src/lib/auth/controllers/mfa.controller.js.map +1 -0
- package/src/lib/auth/dto/index.js +1 -0
- package/src/lib/auth/dto/index.js.map +1 -0
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js +30 -0
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/login.request.dto.js +34 -0
- package/src/lib/auth/dto/requests/login.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js +15 -0
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/reset-password.request.dto.js +42 -0
- package/src/lib/auth/dto/requests/reset-password.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js +16 -0
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/signup.request.dto.js +37 -0
- package/src/lib/auth/dto/requests/signup.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/social-login.request.dto.js +16 -0
- package/src/lib/auth/dto/requests/social-login.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js +21 -0
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js.map +1 -0
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js +20 -0
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js.map +1 -0
- package/src/lib/auth/dto/responses/auth.response.dto.js +50 -0
- package/src/lib/auth/dto/responses/auth.response.dto.js.map +1 -0
- package/src/lib/auth/entities/mfa-secret.entity.js +50 -0
- package/src/lib/auth/entities/mfa-secret.entity.js.map +1 -0
- package/src/lib/auth/entities/otp.entity.js +50 -0
- package/src/lib/auth/entities/otp.entity.js.map +1 -0
- package/src/lib/auth/events/logged-out-all.event.js +10 -0
- package/src/lib/auth/events/logged-out-all.event.js.map +1 -0
- package/src/lib/auth/events/logged-out.event.js +10 -0
- package/src/lib/auth/events/logged-out.event.js.map +1 -0
- package/src/lib/auth/events/password-reset-requested.event.js +10 -0
- package/src/lib/auth/events/password-reset-requested.event.js.map +1 -0
- package/src/lib/auth/events/password-reset.event.js +10 -0
- package/src/lib/auth/events/password-reset.event.js.map +1 -0
- package/src/lib/auth/events/user-2fa-verified.event.js +10 -0
- package/src/lib/auth/events/user-2fa-verified.event.js.map +1 -0
- package/src/lib/auth/events/user-logged-in.event.js +10 -0
- package/src/lib/auth/events/user-logged-in.event.js.map +1 -0
- package/src/lib/auth/events/user-refresh-token.event.js +10 -0
- package/src/lib/auth/events/user-refresh-token.event.js.map +1 -0
- package/src/lib/auth/index.js +20 -0
- package/src/lib/auth/index.js.map +1 -0
- package/src/lib/auth/services/auth.service.js +396 -0
- package/src/lib/auth/services/auth.service.js.map +1 -0
- package/src/lib/auth/services/cookie.service.js +43 -0
- package/src/lib/auth/services/cookie.service.js.map +1 -0
- package/src/lib/auth/services/mfa.service.js +255 -0
- package/src/lib/auth/services/mfa.service.js.map +1 -0
- package/src/lib/auth.constants.js +43 -0
- package/src/lib/auth.constants.js.map +1 -0
- package/src/lib/core/core.module.js +67 -0
- package/src/lib/core/core.module.js.map +1 -0
- package/src/lib/core/decorators/role.decorator.js +14 -0
- package/src/lib/core/decorators/role.decorator.js.map +1 -0
- package/src/lib/core/decorators/skip-mfa.decorator.js +8 -0
- package/src/lib/core/decorators/skip-mfa.decorator.js.map +1 -0
- package/src/lib/core/dto/message.response.dto.js +13 -0
- package/src/lib/core/dto/message.response.dto.js.map +1 -0
- package/src/lib/core/entities.d.ts +1 -1
- package/src/lib/core/entities.js +34 -0
- package/src/lib/core/entities.js.map +1 -0
- package/src/lib/core/guards/auth.guard.js +135 -0
- package/src/lib/core/guards/auth.guard.js.map +1 -0
- package/src/lib/core/guards/role.guard.js +40 -0
- package/src/lib/core/guards/role.guard.js.map +1 -0
- package/src/lib/core/index.js +27 -0
- package/src/lib/core/index.js.map +1 -0
- package/src/lib/core/interfaces/auth-module-options.interface.js +3 -0
- package/src/lib/core/interfaces/auth-module-options.interface.js.map +1 -0
- package/src/lib/core/interfaces/mfa-options.interface.js +10 -0
- package/src/lib/core/interfaces/mfa-options.interface.js.map +1 -0
- package/src/lib/core/interfaces/otp.interface.js +10 -0
- package/src/lib/core/interfaces/otp.interface.js.map +1 -0
- package/src/lib/core/interfaces/session-options.interface.js +9 -0
- package/src/lib/core/interfaces/session-options.interface.js.map +1 -0
- package/src/lib/core/interfaces/token-payload.interface.js +3 -0
- package/src/lib/core/interfaces/token-payload.interface.js.map +1 -0
- package/src/lib/core/providers/apple-auth.provider.js +58 -0
- package/src/lib/core/providers/apple-auth.provider.js.map +1 -0
- package/src/lib/core/providers/base-auth.provider.js +41 -0
- package/src/lib/core/providers/base-auth.provider.js.map +1 -0
- package/src/lib/core/providers/email-auth.provider.js +42 -0
- package/src/lib/core/providers/email-auth.provider.js.map +1 -0
- package/src/lib/core/providers/facebook-auth.provider.js +58 -0
- package/src/lib/core/providers/facebook-auth.provider.js.map +1 -0
- package/src/lib/core/providers/google-auth.provider.js +60 -0
- package/src/lib/core/providers/google-auth.provider.js.map +1 -0
- package/src/lib/core/providers/jwt-auth.provider.js +51 -0
- package/src/lib/core/providers/jwt-auth.provider.js.map +1 -0
- package/src/lib/core/providers/phone-auth.provider.js +45 -0
- package/src/lib/core/providers/phone-auth.provider.js.map +1 -0
- package/src/lib/core/services/auth-provider-registry.service.js +72 -0
- package/src/lib/core/services/auth-provider-registry.service.js.map +1 -0
- package/src/lib/core/services/jwt.service.js +93 -0
- package/src/lib/core/services/jwt.service.js.map +1 -0
- package/src/lib/nest-auth.module.js +118 -0
- package/src/lib/nest-auth.module.js.map +1 -0
- package/src/lib/request-context/request-context.js +108 -0
- package/src/lib/request-context/request-context.js.map +1 -0
- package/src/lib/request-context/request-context.middleware.js +16 -0
- package/src/lib/request-context/request-context.middleware.js.map +1 -0
- package/src/lib/role/entities/permission.entity.js +42 -0
- package/src/lib/role/entities/permission.entity.js.map +1 -0
- package/src/lib/role/entities/role.entity.js +106 -0
- package/src/lib/role/entities/role.entity.js.map +1 -0
- package/src/lib/role/index.js +6 -0
- package/src/lib/role/index.js.map +1 -0
- package/src/lib/role/role.module.js +22 -0
- package/src/lib/role/role.module.js.map +1 -0
- package/src/lib/role/services/role.service.js +220 -0
- package/src/lib/role/services/role.service.js.map +1 -0
- package/src/lib/session/entities/session.entity.js +63 -0
- package/src/lib/session/entities/session.entity.js.map +1 -0
- package/src/lib/session/index.js +8 -0
- package/src/lib/session/index.js.map +1 -0
- package/src/lib/session/services/base-session.service.js +66 -0
- package/src/lib/session/services/base-session.service.js.map +1 -0
- package/src/lib/session/services/database-session.service.js +55 -0
- package/src/lib/session/services/database-session.service.js.map +1 -0
- package/src/lib/session/services/redis-session.service.js +120 -0
- package/src/lib/session/services/redis-session.service.js.map +1 -0
- package/src/lib/session/session.module.js +33 -0
- package/src/lib/session/session.module.js.map +1 -0
- package/src/lib/tenant/entities/tenant.entity.js +44 -0
- package/src/lib/tenant/entities/tenant.entity.js.map +1 -0
- package/src/lib/tenant/events/tenant-created.event.js +10 -0
- package/src/lib/tenant/events/tenant-created.event.js.map +1 -0
- package/src/lib/tenant/events/tenant-deleted.event.js +10 -0
- package/src/lib/tenant/events/tenant-deleted.event.js.map +1 -0
- package/src/lib/tenant/events/tenant-updated.event.js +10 -0
- package/src/lib/tenant/events/tenant-updated.event.js.map +1 -0
- package/src/lib/tenant/index.js +7 -0
- package/src/lib/tenant/index.js.map +1 -0
- package/src/lib/tenant/services/tenant.service.js +136 -0
- package/src/lib/tenant/services/tenant.service.js.map +1 -0
- package/src/lib/tenant/tenant.module.js +27 -0
- package/src/lib/tenant/tenant.module.js.map +1 -0
- package/src/lib/user/dto/requests/update-user.dto.js +24 -0
- package/src/lib/user/dto/requests/update-user.dto.js.map +1 -0
- package/src/lib/user/entities/access-key.entity.js +63 -0
- package/src/lib/user/entities/access-key.entity.js.map +1 -0
- package/src/lib/user/entities/auth-identity.entity.js +47 -0
- package/src/lib/user/entities/auth-identity.entity.js.map +1 -0
- package/src/lib/user/entities/user.entity.d.ts +1 -1
- package/src/lib/user/entities/user.entity.js +192 -0
- package/src/lib/user/entities/user.entity.js.map +1 -0
- package/src/lib/user/events/user-created.event.js +10 -0
- package/src/lib/user/events/user-created.event.js.map +1 -0
- package/src/lib/user/events/user-deleted.event.js +10 -0
- package/src/lib/user/events/user-deleted.event.js.map +1 -0
- package/src/lib/user/events/user-registered.event.js +10 -0
- package/src/lib/user/events/user-registered.event.js.map +1 -0
- package/src/lib/user/events/user-updated.event.js +10 -0
- package/src/lib/user/events/user-updated.event.js.map +1 -0
- package/src/lib/user/index.js +8 -0
- package/src/lib/user/index.js.map +1 -0
- package/src/lib/user/services/access-key.service.js +119 -0
- package/src/lib/user/services/access-key.service.js.map +1 -0
- package/src/lib/user/services/user.service.js +217 -0
- package/src/lib/user/services/user.service.js.map +1 -0
- package/src/lib/user/user.module.js +32 -0
- package/src/lib/user/user.module.js.map +1 -0
- package/src/lib/utils/database.utils.js +8 -0
- package/src/lib/utils/database.utils.js.map +1 -0
- package/src/lib/utils/otp.js +7 -0
- package/src/lib/utils/otp.js.map +1 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/index.cjs.d.ts +0 -1
- package/index.cjs.js +0 -28350
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserCreatedEvent = void 0;
|
|
4
|
+
class UserCreatedEvent {
|
|
5
|
+
constructor(payload) {
|
|
6
|
+
this.payload = payload;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.UserCreatedEvent = UserCreatedEvent;
|
|
10
|
+
//# sourceMappingURL=user-created.event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-created.event.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/events/user-created.event.ts"],"names":[],"mappings":";;;AAOA,MAAa,gBAAgB;IACzB,YAA4B,OAAgC;QAAhC,YAAO,GAAP,OAAO,CAAyB;IAAI,CAAC;CACpE;AAFD,4CAEC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserDeletedEvent = void 0;
|
|
4
|
+
class UserDeletedEvent {
|
|
5
|
+
constructor(payload) {
|
|
6
|
+
this.payload = payload;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.UserDeletedEvent = UserDeletedEvent;
|
|
10
|
+
//# sourceMappingURL=user-deleted.event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-deleted.event.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/events/user-deleted.event.ts"],"names":[],"mappings":";;;AAOA,MAAa,gBAAgB;IACzB,YACoB,OAAgC;QAAhC,YAAO,GAAP,OAAO,CAAyB;IAChD,CAAC;CACR;AAJD,4CAIC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserRegisteredEvent = void 0;
|
|
4
|
+
class UserRegisteredEvent {
|
|
5
|
+
constructor(payload) {
|
|
6
|
+
this.payload = payload;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.UserRegisteredEvent = UserRegisteredEvent;
|
|
10
|
+
//# sourceMappingURL=user-registered.event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-registered.event.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/events/user-registered.event.ts"],"names":[],"mappings":";;;AAiBA,MAAa,mBAAmB;IAC5B,YACoB,OAAmC;QAAnC,YAAO,GAAP,OAAO,CAA4B;IACnD,CAAC;CACR;AAJD,kDAIC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserUpdatedEvent = void 0;
|
|
4
|
+
class UserUpdatedEvent {
|
|
5
|
+
constructor(payload) {
|
|
6
|
+
this.payload = payload;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.UserUpdatedEvent = UserUpdatedEvent;
|
|
10
|
+
//# sourceMappingURL=user-updated.event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-updated.event.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/events/user-updated.event.ts"],"names":[],"mappings":";;;AAQA,MAAa,gBAAgB;IACzB,YACoB,OAAgC;QAAhC,YAAO,GAAP,OAAO,CAAyB;IAChD,CAAC;CACR;AAJD,4CAIC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./dto/requests/update-user.dto"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./services/user.service"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./services/access-key.service"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./user.module"), exports);
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/user/index.ts"],"names":[],"mappings":";;;AACA,yEAA+C;AAQ/C,kEAAwC;AACxC,wEAA8C;AAG9C,wDAA8B"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AccessKeyService = 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 access_key_entity_1 = require("../entities/access-key.entity");
|
|
9
|
+
const user_entity_1 = require("../entities/user.entity");
|
|
10
|
+
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
11
|
+
const crypto_1 = require("crypto");
|
|
12
|
+
const auth_constants_1 = require("../../auth.constants");
|
|
13
|
+
let AccessKeyService = class AccessKeyService {
|
|
14
|
+
constructor(accessKeyRepository, userRepository, eventEmitter) {
|
|
15
|
+
this.accessKeyRepository = accessKeyRepository;
|
|
16
|
+
this.userRepository = userRepository;
|
|
17
|
+
this.eventEmitter = eventEmitter;
|
|
18
|
+
}
|
|
19
|
+
generateKeyPair() {
|
|
20
|
+
const privateKey = (0, crypto_1.randomBytes)(32).toString('hex');
|
|
21
|
+
const publicKey = (0, crypto_1.createHash)('sha256').update(privateKey).digest('hex');
|
|
22
|
+
return { publicKey, privateKey };
|
|
23
|
+
}
|
|
24
|
+
async createAccessKey(userId, name, metadata) {
|
|
25
|
+
const user = await this.userRepository.findOne({ where: { id: userId } });
|
|
26
|
+
if (!user) {
|
|
27
|
+
throw new common_1.NotFoundException({
|
|
28
|
+
message: `User with ID ${userId} not found`,
|
|
29
|
+
code: 'USER_NOT_FOUND'
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
const { publicKey, privateKey } = this.generateKeyPair();
|
|
33
|
+
const accessKey = this.accessKeyRepository.create({
|
|
34
|
+
name,
|
|
35
|
+
publicKey,
|
|
36
|
+
privateKey,
|
|
37
|
+
userId,
|
|
38
|
+
});
|
|
39
|
+
const savedKey = await this.accessKeyRepository.save(accessKey);
|
|
40
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.ACCESS_KEY_CREATED, {
|
|
41
|
+
accessKey: savedKey,
|
|
42
|
+
userId
|
|
43
|
+
});
|
|
44
|
+
return savedKey;
|
|
45
|
+
}
|
|
46
|
+
async getAccessKey(publicKey) {
|
|
47
|
+
const accessKey = await this.accessKeyRepository.findOne({
|
|
48
|
+
where: { publicKey },
|
|
49
|
+
relations: ['user']
|
|
50
|
+
});
|
|
51
|
+
if (!accessKey) {
|
|
52
|
+
throw new common_1.NotFoundException({
|
|
53
|
+
message: 'Invalid access key',
|
|
54
|
+
code: 'INVALID_ACCESS_KEY'
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
if (!accessKey.isActive) {
|
|
58
|
+
throw new common_1.BadRequestException({
|
|
59
|
+
message: 'Access key is inactive',
|
|
60
|
+
code: 'INACTIVE_ACCESS_KEY'
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
if (accessKey.expiresAt && accessKey.expiresAt < new Date()) {
|
|
64
|
+
throw new common_1.BadRequestException({
|
|
65
|
+
message: 'Access key has expired',
|
|
66
|
+
code: 'EXPIRED_ACCESS_KEY'
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return accessKey;
|
|
70
|
+
}
|
|
71
|
+
async validateAccessKey(publicKey, privateKey) {
|
|
72
|
+
const accessKey = await this.getAccessKey(publicKey);
|
|
73
|
+
return accessKey.privateKey === privateKey;
|
|
74
|
+
}
|
|
75
|
+
async getUserAccessKeys(userId) {
|
|
76
|
+
return this.accessKeyRepository.find({
|
|
77
|
+
where: { userId },
|
|
78
|
+
order: { createdAt: 'DESC' }
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
async deactivateAccessKey(publicKey) {
|
|
82
|
+
const accessKey = await this.getAccessKey(publicKey);
|
|
83
|
+
accessKey.isActive = false;
|
|
84
|
+
const updatedKey = await this.accessKeyRepository.save(accessKey);
|
|
85
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.ACCESS_KEY_DEACTIVATED, {
|
|
86
|
+
accessKey: updatedKey,
|
|
87
|
+
userId: updatedKey.userId
|
|
88
|
+
});
|
|
89
|
+
return updatedKey;
|
|
90
|
+
}
|
|
91
|
+
async updateAccessKeyLastUsed(publicKey) {
|
|
92
|
+
const accessKey = await this.getAccessKey(publicKey);
|
|
93
|
+
accessKey.lastUsedAt = new Date();
|
|
94
|
+
await this.accessKeyRepository.save(accessKey);
|
|
95
|
+
}
|
|
96
|
+
async setAccessKeyExpiry(publicKey, expiresAt) {
|
|
97
|
+
const accessKey = await this.getAccessKey(publicKey);
|
|
98
|
+
accessKey.expiresAt = expiresAt;
|
|
99
|
+
return this.accessKeyRepository.save(accessKey);
|
|
100
|
+
}
|
|
101
|
+
async deleteAccessKey(publicKey) {
|
|
102
|
+
const accessKey = await this.getAccessKey(publicKey);
|
|
103
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.ACCESS_KEY_DELETED, {
|
|
104
|
+
accessKey,
|
|
105
|
+
userId: accessKey.userId
|
|
106
|
+
});
|
|
107
|
+
await this.accessKeyRepository.remove(accessKey);
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
exports.AccessKeyService = AccessKeyService;
|
|
111
|
+
exports.AccessKeyService = AccessKeyService = tslib_1.__decorate([
|
|
112
|
+
(0, common_1.Injectable)(),
|
|
113
|
+
tslib_1.__param(0, (0, typeorm_1.InjectRepository)(access_key_entity_1.AccessKey)),
|
|
114
|
+
tslib_1.__param(1, (0, typeorm_1.InjectRepository)(user_entity_1.User)),
|
|
115
|
+
tslib_1.__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
116
|
+
typeorm_2.Repository,
|
|
117
|
+
event_emitter_1.EventEmitter2])
|
|
118
|
+
], AccessKeyService);
|
|
119
|
+
//# sourceMappingURL=access-key.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"access-key.service.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/services/access-key.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserService = 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 user_entity_1 = require("../entities/user.entity");
|
|
9
|
+
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
10
|
+
const auth_constants_1 = require("../../auth.constants");
|
|
11
|
+
const user_updated_event_1 = require("../events/user-updated.event");
|
|
12
|
+
const user_deleted_event_1 = require("../events/user-deleted.event");
|
|
13
|
+
const user_created_event_1 = require("../events/user-created.event");
|
|
14
|
+
let UserService = class UserService {
|
|
15
|
+
constructor(userRepository, eventEmitter) {
|
|
16
|
+
this.userRepository = userRepository;
|
|
17
|
+
this.eventEmitter = eventEmitter;
|
|
18
|
+
}
|
|
19
|
+
async createUser(data) {
|
|
20
|
+
const { email, phone, tenantId } = data;
|
|
21
|
+
if (!tenantId) {
|
|
22
|
+
throw new common_1.BadRequestException('Tenant ID is required');
|
|
23
|
+
}
|
|
24
|
+
if (!email && !phone) {
|
|
25
|
+
throw new common_1.BadRequestException('Either email or phone must be provided');
|
|
26
|
+
}
|
|
27
|
+
let existingUser = null;
|
|
28
|
+
if (phone) {
|
|
29
|
+
existingUser = await this.userRepository.findOne({
|
|
30
|
+
where: { phone, tenantId: tenantId || (0, typeorm_2.IsNull)() }
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
if (!existingUser && email) {
|
|
34
|
+
existingUser = await this.userRepository.findOne({
|
|
35
|
+
where: { email, tenantId: tenantId || (0, typeorm_2.IsNull)() }
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
if (existingUser) {
|
|
39
|
+
throw new common_1.ConflictException({
|
|
40
|
+
message: `User with ${email ? `email ${email}` : ''}${email && phone ? ' or ' : ''}${phone ? `phone ${phone}` : ''} already exists in tenant ${tenantId}`,
|
|
41
|
+
code: 'USER_ALREADY_EXISTS'
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
const user = this.userRepository.create(data);
|
|
45
|
+
await this.userRepository.save(user);
|
|
46
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.USER_CREATED, new user_created_event_1.UserCreatedEvent({
|
|
47
|
+
user
|
|
48
|
+
}));
|
|
49
|
+
return user;
|
|
50
|
+
}
|
|
51
|
+
async getUserById(id, options) {
|
|
52
|
+
if (!id) {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
const user = await this.userRepository.findOne({
|
|
56
|
+
...(options ? options : {}),
|
|
57
|
+
where: { id }
|
|
58
|
+
});
|
|
59
|
+
if (!user) {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
return user;
|
|
63
|
+
}
|
|
64
|
+
async getUserByEmail(email, tenantId, options) {
|
|
65
|
+
if (!email) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
return this.userRepository.findOne({
|
|
69
|
+
...(options ? options : {}),
|
|
70
|
+
where: {
|
|
71
|
+
email,
|
|
72
|
+
tenantId: tenantId || (0, typeorm_2.IsNull)()
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
async getUserByPhone(phone, tenantId, options) {
|
|
77
|
+
if (!phone) {
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
return this.userRepository.findOne({
|
|
81
|
+
...(options ? options : {}),
|
|
82
|
+
where: {
|
|
83
|
+
phone,
|
|
84
|
+
tenantId: tenantId || (0, typeorm_2.IsNull)()
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
async getUsers(options) {
|
|
89
|
+
return this.userRepository.find(options);
|
|
90
|
+
}
|
|
91
|
+
async getUsersByTenant(tenantId, options) {
|
|
92
|
+
if (!tenantId) {
|
|
93
|
+
return [];
|
|
94
|
+
}
|
|
95
|
+
return this.userRepository.find({
|
|
96
|
+
...(options ? options : {}),
|
|
97
|
+
where: {
|
|
98
|
+
tenantId,
|
|
99
|
+
...(options?.where ? options.where : {})
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
async updateUser(id, data) {
|
|
104
|
+
const user = await this.getUserById(id);
|
|
105
|
+
if (!user) {
|
|
106
|
+
throw new common_1.NotFoundException({
|
|
107
|
+
message: `User with ID ${id} not found`,
|
|
108
|
+
code: 'USER_NOT_FOUND'
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
if (data.email || data.phone) {
|
|
112
|
+
const existingUser = await this.userRepository.findOne({
|
|
113
|
+
where: [
|
|
114
|
+
{ email: data.email || user.email, tenantId: user.tenantId },
|
|
115
|
+
{ phone: data.phone || user.phone, tenantId: user.tenantId }
|
|
116
|
+
]
|
|
117
|
+
});
|
|
118
|
+
if (existingUser && existingUser.id !== user.id) {
|
|
119
|
+
throw new common_1.ConflictException({
|
|
120
|
+
message: `User with email '${data.email || user.email}' or phone '${data.phone || user.phone}' already exists in tenant '${user.tenantId}'`,
|
|
121
|
+
code: 'USER_ALREADY_EXISTS'
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
delete data.tenantId;
|
|
126
|
+
Object.assign(user, data);
|
|
127
|
+
const updatedUser = await this.userRepository.save(user);
|
|
128
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.USER_UPDATED, new user_updated_event_1.UserUpdatedEvent({
|
|
129
|
+
user: updatedUser,
|
|
130
|
+
tenantId: updatedUser.tenantId,
|
|
131
|
+
updatedFields: Object.keys(data)
|
|
132
|
+
}));
|
|
133
|
+
return updatedUser;
|
|
134
|
+
}
|
|
135
|
+
async deleteUser(id) {
|
|
136
|
+
const user = await this.getUserById(id);
|
|
137
|
+
if (!user) {
|
|
138
|
+
throw new common_1.NotFoundException({
|
|
139
|
+
message: `User with ID ${id} not found`,
|
|
140
|
+
code: 'USER_NOT_FOUND'
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
await this.eventEmitter.emitAsync(auth_constants_1.NestAuthEvents.USER_DELETED, new user_deleted_event_1.UserDeletedEvent({
|
|
144
|
+
user,
|
|
145
|
+
tenantId: user.tenantId
|
|
146
|
+
}));
|
|
147
|
+
await this.userRepository.remove(user);
|
|
148
|
+
}
|
|
149
|
+
async verifyUser(id, verificationType) {
|
|
150
|
+
const user = await this.getUserById(id);
|
|
151
|
+
if (!user) {
|
|
152
|
+
throw new common_1.NotFoundException({
|
|
153
|
+
message: `User with ID ${id} not found`,
|
|
154
|
+
code: 'USER_NOT_FOUND'
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
if (verificationType === 'email') {
|
|
158
|
+
user.emailVerifiedAt = new Date();
|
|
159
|
+
}
|
|
160
|
+
else if (verificationType === 'phone') {
|
|
161
|
+
user.phoneVerifiedAt = new Date();
|
|
162
|
+
}
|
|
163
|
+
user.isVerified = true;
|
|
164
|
+
return this.userRepository.save(user);
|
|
165
|
+
}
|
|
166
|
+
async unverifyUser(id, verificationType) {
|
|
167
|
+
const user = await this.getUserById(id);
|
|
168
|
+
if (!user) {
|
|
169
|
+
throw new common_1.NotFoundException({
|
|
170
|
+
message: `User with ID ${id} not found`,
|
|
171
|
+
code: 'USER_NOT_FOUND'
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
if (verificationType === 'email') {
|
|
175
|
+
user.emailVerifiedAt = null;
|
|
176
|
+
}
|
|
177
|
+
else if (verificationType === 'phone') {
|
|
178
|
+
user.phoneVerifiedAt = null;
|
|
179
|
+
}
|
|
180
|
+
user.isVerified = false;
|
|
181
|
+
user.isVerified = Boolean(user.emailVerifiedAt || user.phoneVerifiedAt);
|
|
182
|
+
return this.userRepository.save(user);
|
|
183
|
+
}
|
|
184
|
+
async updateUserStatus(id, isActive) {
|
|
185
|
+
const user = await this.getUserById(id);
|
|
186
|
+
if (!user) {
|
|
187
|
+
throw new common_1.NotFoundException({
|
|
188
|
+
message: `User with ID ${id} not found`,
|
|
189
|
+
code: 'USER_NOT_FOUND'
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
user.isActive = isActive;
|
|
193
|
+
return this.userRepository.save(user);
|
|
194
|
+
}
|
|
195
|
+
async updateUserMetadata(id, metadata) {
|
|
196
|
+
const user = await this.getUserById(id);
|
|
197
|
+
if (!user) {
|
|
198
|
+
throw new common_1.NotFoundException({
|
|
199
|
+
message: `User with ID ${id} not found`,
|
|
200
|
+
code: 'USER_NOT_FOUND'
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
user.metadata = {
|
|
204
|
+
...user.metadata,
|
|
205
|
+
...metadata
|
|
206
|
+
};
|
|
207
|
+
return this.userRepository.save(user);
|
|
208
|
+
}
|
|
209
|
+
};
|
|
210
|
+
exports.UserService = UserService;
|
|
211
|
+
exports.UserService = UserService = tslib_1.__decorate([
|
|
212
|
+
(0, common_1.Injectable)(),
|
|
213
|
+
tslib_1.__param(0, (0, typeorm_1.InjectRepository)(user_entity_1.User)),
|
|
214
|
+
tslib_1.__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
215
|
+
event_emitter_1.EventEmitter2])
|
|
216
|
+
], UserService);
|
|
217
|
+
//# sourceMappingURL=user.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/user/services/user.service.ts"],"names":[],"mappings":";;;;AAAA,2CAAuG;AACvG,6CAAmD;AACnD,qCAA8E;AAC9E,yDAA+C;AAC/C,yDAAsD;AACtD,yDAAsD;AACtD,qEAAgE;AAChE,qEAAgE;AAChE,qEAAgE;AAGzD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACpB,YAEY,cAAgC,EAChC,YAA2B;QAD3B,mBAAc,GAAd,cAAc,CAAkB;QAChC,iBAAY,GAAZ,YAAY,CAAe;IACnC,CAAC;IAEL,KAAK,CAAC,UAAU,CAAC,IAAmB;QAChC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;QAExC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACZ,MAAM,IAAI,4BAAmB,CAAC,uBAAuB,CAAC,CAAC;QAC3D,CAAC;QAED,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;YACnB,MAAM,IAAI,4BAAmB,CAAC,wCAAwC,CAAC,CAAC;QAC5E,CAAC;QAGD,IAAI,YAAY,GAAG,IAAI,CAAC;QAExB,IAAI,KAAK,EAAE,CAAC;YACR,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;gBAC7C,KAAK,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,IAAI,IAAA,gBAAM,GAAE,EAAE;aACnD,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,YAAY,IAAI,KAAK,EAAE,CAAC;YACzB,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;gBAC7C,KAAK,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,IAAI,IAAA,gBAAM,GAAE,EAAE;aACnD,CAAC,CAAC;QACP,CAAC;QAED,IAAI,YAAY,EAAE,CAAC;YACf,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,aAAa,KAAK,CAAC,CAAC,CAAC,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,6BAA6B,QAAQ,EAAE;gBACzJ,IAAI,EAAE,qBAAqB;aAC9B,CAAC,CAAC;QACP,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAGrC,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAC7B,+BAAc,CAAC,YAAY,EAC3B,IAAI,qCAAgB,CAAC;YACjB,IAAI;SACP,CAAC,CACL,CAAC;QACF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,EAAU,EAAE,OAA8B;QACxD,IAAI,CAAC,EAAE,EAAE,CAAC;YACN,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YAC3C,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE,EAAE,EAAE,EAAE;SAChB,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,KAAa,EAAE,QAAiB,EAAE,OAA8B;QACjF,IAAI,CAAC,KAAK,EAAE,CAAC;YACT,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YAC/B,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE;gBACH,KAAK;gBACL,QAAQ,EAAE,QAAQ,IAAI,IAAA,gBAAM,GAAE;aACjC;SACJ,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,KAAa,EAAE,QAAiB,EAAE,OAA8B;QACjF,IAAI,CAAC,KAAK,EAAE,CAAC;YACT,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YAC/B,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE;gBACH,KAAK;gBACL,QAAQ,EAAE,QAAQ,IAAI,IAAA,gBAAM,GAAE;aACjC;SACJ,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,OAA+B;QAC1C,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,QAAgB,EAAE,OAA+B;QACpE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACZ,OAAO,EAAE,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YAC5B,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE;gBACH,QAAQ;gBACR,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;aAC3C;SACJ,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU,EAAE,IAAmB;QAC5C,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAGD,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;gBACnD,KAAK,EAAE;oBACH,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;oBAC5D,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;iBAC/D;aACJ,CAAC,CAAC;YAEH,IAAI,YAAY,IAAI,YAAY,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;gBAC9C,MAAM,IAAI,0BAAiB,CAAC;oBACxB,OAAO,EAAE,oBAAoB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,eAAe,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,+BAA+B,IAAI,CAAC,QAAQ,GAAG;oBAC3I,IAAI,EAAE,qBAAqB;iBAC9B,CAAC,CAAC;YACP,CAAC;QACL,CAAC;QAGD,OAAO,IAAI,CAAC,QAAQ,CAAC;QAErB,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC1B,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAGzD,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAC7B,+BAAc,CAAC,YAAY,EAC3B,IAAI,qCAAgB,CAAC;YACjB,IAAI,EAAE,WAAW;YACjB,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;SACnC,CAAC,CACL,CAAC;QAEF,OAAO,WAAW,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU;QACvB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAGD,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAC7B,+BAAc,CAAC,YAAY,EAC3B,IAAI,qCAAgB,CAAC;YACjB,IAAI;YACJ,QAAQ,EAAE,IAAI,CAAC,QAAQ;SAC1B,CAAC,CACL,CAAC;QAEF,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU,EAAE,gBAA6C;QACtE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAED,IAAI,gBAAgB,KAAK,OAAO,EAAE,CAAC;YAC/B,IAAI,CAAC,eAAe,GAAG,IAAI,IAAI,EAAE,CAAC;QACtC,CAAC;aAAM,IAAI,gBAAgB,KAAK,OAAO,EAAE,CAAC;YACtC,IAAI,CAAC,eAAe,GAAG,IAAI,IAAI,EAAE,CAAC;QACtC,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAU,EAAE,gBAA6C;QACxE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAED,IAAI,gBAAgB,KAAK,OAAO,EAAE,CAAC;YAC/B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAChC,CAAC;aAAM,IAAI,gBAAgB,KAAK,OAAO,EAAE,CAAC;YACtC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAGxB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC;QAExE,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,EAAU,EAAE,QAAiB;QAChD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,EAAU,EAAE,QAA6B;QAC9D,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,0BAAiB,CAAC;gBACxB,OAAO,EAAE,gBAAgB,EAAE,YAAY;gBACvC,IAAI,EAAE,gBAAgB;aACzB,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,QAAQ,GAAG;YACZ,GAAG,IAAI,CAAC,QAAQ;YAChB,GAAG,QAAQ;SACd,CAAC;QAEF,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;CACJ,CAAA;AAnQY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;IAGJ,mBAAA,IAAA,0BAAgB,EAAC,kBAAI,CAAC,CAAA;6CACC,oBAAU;QACZ,6BAAa;GAJ9B,WAAW,CAmQvB"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserModule = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
7
|
+
const user_entity_1 = require("./entities/user.entity");
|
|
8
|
+
const user_service_1 = require("./services/user.service");
|
|
9
|
+
const access_key_service_1 = require("./services/access-key.service");
|
|
10
|
+
const auth_module_1 = require("../auth/auth.module");
|
|
11
|
+
const access_key_entity_1 = require("./entities/access-key.entity");
|
|
12
|
+
const auth_identity_entity_1 = require("./entities/auth-identity.entity");
|
|
13
|
+
let UserModule = class UserModule {
|
|
14
|
+
};
|
|
15
|
+
exports.UserModule = UserModule;
|
|
16
|
+
exports.UserModule = UserModule = tslib_1.__decorate([
|
|
17
|
+
(0, common_1.Module)({
|
|
18
|
+
imports: [
|
|
19
|
+
typeorm_1.TypeOrmModule.forFeature([user_entity_1.User, access_key_entity_1.AccessKey, auth_identity_entity_1.AuthIdentity]),
|
|
20
|
+
(0, common_1.forwardRef)(() => auth_module_1.AuthModule),
|
|
21
|
+
],
|
|
22
|
+
providers: [
|
|
23
|
+
user_service_1.UserService,
|
|
24
|
+
access_key_service_1.AccessKeyService,
|
|
25
|
+
],
|
|
26
|
+
exports: [
|
|
27
|
+
user_service_1.UserService,
|
|
28
|
+
access_key_service_1.AccessKeyService,
|
|
29
|
+
],
|
|
30
|
+
})
|
|
31
|
+
], UserModule);
|
|
32
|
+
//# sourceMappingURL=user.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.module.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/user/user.module.ts"],"names":[],"mappings":";;;;AAAA,2CAAoD;AACpD,6CAAgD;AAChD,wDAA8C;AAC9C,0DAAsD;AACtD,sEAAiE;AACjE,qDAAiD;AACjD,oEAAyD;AACzD,0EAA+D;AAgBxD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAI,CAAA;AAAd,gCAAU;qBAAV,UAAU;IAdtB,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE;YACL,uBAAa,CAAC,UAAU,CAAC,CAAC,kBAAI,EAAE,6BAAS,EAAE,mCAAY,CAAC,CAAC;YACzD,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;SAC/B;QACD,SAAS,EAAE;YACP,0BAAW;YACX,qCAAgB;SACnB;QACD,OAAO,EAAE;YACL,0BAAW;YACX,qCAAgB;SACnB;KACJ,CAAC;GACW,UAAU,CAAI"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getJsonColumnType = getJsonColumnType;
|
|
4
|
+
function getJsonColumnType(dataSource) {
|
|
5
|
+
const driver = dataSource.driver;
|
|
6
|
+
return driver.options.type === 'sqlite' ? 'simple-json' : 'jsonb';
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=database.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.utils.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/utils/database.utils.ts"],"names":[],"mappings":";;AAEA,8CAGC;AAHD,SAAgB,iBAAiB,CAAC,UAAsB;IACpD,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IACjC,OAAO,MAAM,CAAC,OAAO,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC;AACtE,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.generateOtp = generateOtp;
|
|
4
|
+
function generateOtp(length = 6) {
|
|
5
|
+
return Math.floor(10 ** (length - 1) + Math.random() * (10 ** length - 10 ** (length - 1) - 1)).toString();
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=otp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"otp.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/utils/otp.ts"],"names":[],"mappings":";;AAAA,kCAEC;AAFD,SAAgB,WAAW,CAAC,SAAiB,CAAC;IAC1C,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,IAAI,MAAM,GAAG,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;AAC/G,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":"5.7.3"}
|
package/index.cjs.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./src/index";
|