@ackplus/nest-auth 0.0.38 → 0.0.40

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.
Files changed (178) hide show
  1. package/README.md +226 -0
  2. package/package.json +2 -2
  3. package/src/index.js +12 -0
  4. package/src/index.js.map +1 -0
  5. package/src/lib/auth/auth.module.js +52 -0
  6. package/src/lib/auth/auth.module.js.map +1 -0
  7. package/src/lib/auth/controllers/auth.controller.js +189 -0
  8. package/src/lib/auth/controllers/auth.controller.js.map +1 -0
  9. package/src/lib/auth/controllers/mfa.controller.js +130 -0
  10. package/src/lib/auth/controllers/mfa.controller.js.map +1 -0
  11. package/src/lib/auth/dto/index.js +1 -0
  12. package/src/lib/auth/dto/index.js.map +1 -0
  13. package/src/lib/auth/dto/requests/forgot-password.request.dto.js +30 -0
  14. package/src/lib/auth/dto/requests/forgot-password.request.dto.js.map +1 -0
  15. package/src/lib/auth/dto/requests/login.request.dto.js +34 -0
  16. package/src/lib/auth/dto/requests/login.request.dto.js.map +1 -0
  17. package/src/lib/auth/dto/requests/refresh-token.request.dto.js +15 -0
  18. package/src/lib/auth/dto/requests/refresh-token.request.dto.js.map +1 -0
  19. package/src/lib/auth/dto/requests/reset-password.request.dto.js +42 -0
  20. package/src/lib/auth/dto/requests/reset-password.request.dto.js.map +1 -0
  21. package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js +16 -0
  22. package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js.map +1 -0
  23. package/src/lib/auth/dto/requests/signup.request.dto.js +37 -0
  24. package/src/lib/auth/dto/requests/signup.request.dto.js.map +1 -0
  25. package/src/lib/auth/dto/requests/social-login.request.dto.js +16 -0
  26. package/src/lib/auth/dto/requests/social-login.request.dto.js.map +1 -0
  27. package/src/lib/auth/dto/requests/verify-2fa.request.dto.js +21 -0
  28. package/src/lib/auth/dto/requests/verify-2fa.request.dto.js.map +1 -0
  29. package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js +20 -0
  30. package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js.map +1 -0
  31. package/src/lib/auth/dto/responses/auth.response.dto.js +50 -0
  32. package/src/lib/auth/dto/responses/auth.response.dto.js.map +1 -0
  33. package/src/lib/auth/entities/mfa-secret.entity.js +50 -0
  34. package/src/lib/auth/entities/mfa-secret.entity.js.map +1 -0
  35. package/src/lib/auth/entities/otp.entity.js +50 -0
  36. package/src/lib/auth/entities/otp.entity.js.map +1 -0
  37. package/src/lib/auth/events/logged-out-all.event.js +10 -0
  38. package/src/lib/auth/events/logged-out-all.event.js.map +1 -0
  39. package/src/lib/auth/events/logged-out.event.js +10 -0
  40. package/src/lib/auth/events/logged-out.event.js.map +1 -0
  41. package/src/lib/auth/events/password-reset-requested.event.js +10 -0
  42. package/src/lib/auth/events/password-reset-requested.event.js.map +1 -0
  43. package/src/lib/auth/events/password-reset.event.js +10 -0
  44. package/src/lib/auth/events/password-reset.event.js.map +1 -0
  45. package/src/lib/auth/events/user-2fa-verified.event.js +10 -0
  46. package/src/lib/auth/events/user-2fa-verified.event.js.map +1 -0
  47. package/src/lib/auth/events/user-logged-in.event.js +10 -0
  48. package/src/lib/auth/events/user-logged-in.event.js.map +1 -0
  49. package/src/lib/auth/events/user-refresh-token.event.js +10 -0
  50. package/src/lib/auth/events/user-refresh-token.event.js.map +1 -0
  51. package/src/lib/auth/index.js +20 -0
  52. package/src/lib/auth/index.js.map +1 -0
  53. package/src/lib/auth/services/auth.service.js +396 -0
  54. package/src/lib/auth/services/auth.service.js.map +1 -0
  55. package/src/lib/auth/services/cookie.service.js +43 -0
  56. package/src/lib/auth/services/cookie.service.js.map +1 -0
  57. package/src/lib/auth/services/mfa.service.js +255 -0
  58. package/src/lib/auth/services/mfa.service.js.map +1 -0
  59. package/src/lib/auth.constants.js +43 -0
  60. package/src/lib/auth.constants.js.map +1 -0
  61. package/src/lib/core/core.module.js +67 -0
  62. package/src/lib/core/core.module.js.map +1 -0
  63. package/src/lib/core/decorators/role.decorator.js +14 -0
  64. package/src/lib/core/decorators/role.decorator.js.map +1 -0
  65. package/src/lib/core/decorators/skip-mfa.decorator.js +8 -0
  66. package/src/lib/core/decorators/skip-mfa.decorator.js.map +1 -0
  67. package/src/lib/core/dto/message.response.dto.js +13 -0
  68. package/src/lib/core/dto/message.response.dto.js.map +1 -0
  69. package/src/lib/core/entities.d.ts +1 -1
  70. package/src/lib/core/entities.js +34 -0
  71. package/src/lib/core/entities.js.map +1 -0
  72. package/src/lib/core/guards/auth.guard.js +135 -0
  73. package/src/lib/core/guards/auth.guard.js.map +1 -0
  74. package/src/lib/core/guards/role.guard.js +40 -0
  75. package/src/lib/core/guards/role.guard.js.map +1 -0
  76. package/src/lib/core/index.js +27 -0
  77. package/src/lib/core/index.js.map +1 -0
  78. package/src/lib/core/interfaces/auth-module-options.interface.js +3 -0
  79. package/src/lib/core/interfaces/auth-module-options.interface.js.map +1 -0
  80. package/src/lib/core/interfaces/mfa-options.interface.js +10 -0
  81. package/src/lib/core/interfaces/mfa-options.interface.js.map +1 -0
  82. package/src/lib/core/interfaces/otp.interface.js +10 -0
  83. package/src/lib/core/interfaces/otp.interface.js.map +1 -0
  84. package/src/lib/core/interfaces/session-options.interface.js +9 -0
  85. package/src/lib/core/interfaces/session-options.interface.js.map +1 -0
  86. package/src/lib/core/interfaces/token-payload.interface.js +3 -0
  87. package/src/lib/core/interfaces/token-payload.interface.js.map +1 -0
  88. package/src/lib/core/providers/apple-auth.provider.js +58 -0
  89. package/src/lib/core/providers/apple-auth.provider.js.map +1 -0
  90. package/src/lib/core/providers/base-auth.provider.js +41 -0
  91. package/src/lib/core/providers/base-auth.provider.js.map +1 -0
  92. package/src/lib/core/providers/email-auth.provider.js +42 -0
  93. package/src/lib/core/providers/email-auth.provider.js.map +1 -0
  94. package/src/lib/core/providers/facebook-auth.provider.js +58 -0
  95. package/src/lib/core/providers/facebook-auth.provider.js.map +1 -0
  96. package/src/lib/core/providers/google-auth.provider.js +60 -0
  97. package/src/lib/core/providers/google-auth.provider.js.map +1 -0
  98. package/src/lib/core/providers/jwt-auth.provider.js +51 -0
  99. package/src/lib/core/providers/jwt-auth.provider.js.map +1 -0
  100. package/src/lib/core/providers/phone-auth.provider.js +45 -0
  101. package/src/lib/core/providers/phone-auth.provider.js.map +1 -0
  102. package/src/lib/core/services/auth-provider-registry.service.js +72 -0
  103. package/src/lib/core/services/auth-provider-registry.service.js.map +1 -0
  104. package/src/lib/core/services/jwt.service.js +93 -0
  105. package/src/lib/core/services/jwt.service.js.map +1 -0
  106. package/src/lib/nest-auth.module.js +118 -0
  107. package/src/lib/nest-auth.module.js.map +1 -0
  108. package/src/lib/request-context/request-context.js +108 -0
  109. package/src/lib/request-context/request-context.js.map +1 -0
  110. package/src/lib/request-context/request-context.middleware.js +16 -0
  111. package/src/lib/request-context/request-context.middleware.js.map +1 -0
  112. package/src/lib/role/entities/permission.entity.js +42 -0
  113. package/src/lib/role/entities/permission.entity.js.map +1 -0
  114. package/src/lib/role/entities/role.entity.js +106 -0
  115. package/src/lib/role/entities/role.entity.js.map +1 -0
  116. package/src/lib/role/index.js +6 -0
  117. package/src/lib/role/index.js.map +1 -0
  118. package/src/lib/role/role.module.js +22 -0
  119. package/src/lib/role/role.module.js.map +1 -0
  120. package/src/lib/role/services/role.service.js +220 -0
  121. package/src/lib/role/services/role.service.js.map +1 -0
  122. package/src/lib/session/entities/session.entity.js +63 -0
  123. package/src/lib/session/entities/session.entity.js.map +1 -0
  124. package/src/lib/session/index.js +8 -0
  125. package/src/lib/session/index.js.map +1 -0
  126. package/src/lib/session/services/base-session.service.js +66 -0
  127. package/src/lib/session/services/base-session.service.js.map +1 -0
  128. package/src/lib/session/services/database-session.service.js +55 -0
  129. package/src/lib/session/services/database-session.service.js.map +1 -0
  130. package/src/lib/session/services/redis-session.service.js +120 -0
  131. package/src/lib/session/services/redis-session.service.js.map +1 -0
  132. package/src/lib/session/session.module.js +33 -0
  133. package/src/lib/session/session.module.js.map +1 -0
  134. package/src/lib/tenant/entities/tenant.entity.js +44 -0
  135. package/src/lib/tenant/entities/tenant.entity.js.map +1 -0
  136. package/src/lib/tenant/events/tenant-created.event.js +10 -0
  137. package/src/lib/tenant/events/tenant-created.event.js.map +1 -0
  138. package/src/lib/tenant/events/tenant-deleted.event.js +10 -0
  139. package/src/lib/tenant/events/tenant-deleted.event.js.map +1 -0
  140. package/src/lib/tenant/events/tenant-updated.event.js +10 -0
  141. package/src/lib/tenant/events/tenant-updated.event.js.map +1 -0
  142. package/src/lib/tenant/index.js +7 -0
  143. package/src/lib/tenant/index.js.map +1 -0
  144. package/src/lib/tenant/services/tenant.service.js +136 -0
  145. package/src/lib/tenant/services/tenant.service.js.map +1 -0
  146. package/src/lib/tenant/tenant.module.js +27 -0
  147. package/src/lib/tenant/tenant.module.js.map +1 -0
  148. package/src/lib/user/dto/requests/update-user.dto.js +24 -0
  149. package/src/lib/user/dto/requests/update-user.dto.js.map +1 -0
  150. package/src/lib/user/entities/access-key.entity.js +63 -0
  151. package/src/lib/user/entities/access-key.entity.js.map +1 -0
  152. package/src/lib/user/entities/auth-identity.entity.js +47 -0
  153. package/src/lib/user/entities/auth-identity.entity.js.map +1 -0
  154. package/src/lib/user/entities/user.entity.js +189 -0
  155. package/src/lib/user/entities/user.entity.js.map +1 -0
  156. package/src/lib/user/events/user-created.event.js +10 -0
  157. package/src/lib/user/events/user-created.event.js.map +1 -0
  158. package/src/lib/user/events/user-deleted.event.js +10 -0
  159. package/src/lib/user/events/user-deleted.event.js.map +1 -0
  160. package/src/lib/user/events/user-registered.event.js +10 -0
  161. package/src/lib/user/events/user-registered.event.js.map +1 -0
  162. package/src/lib/user/events/user-updated.event.js +10 -0
  163. package/src/lib/user/events/user-updated.event.js.map +1 -0
  164. package/src/lib/user/index.js +8 -0
  165. package/src/lib/user/index.js.map +1 -0
  166. package/src/lib/user/services/access-key.service.js +119 -0
  167. package/src/lib/user/services/access-key.service.js.map +1 -0
  168. package/src/lib/user/services/user.service.js +217 -0
  169. package/src/lib/user/services/user.service.js.map +1 -0
  170. package/src/lib/user/user.module.js +32 -0
  171. package/src/lib/user/user.module.js.map +1 -0
  172. package/src/lib/utils/database.utils.js +8 -0
  173. package/src/lib/utils/database.utils.js.map +1 -0
  174. package/src/lib/utils/otp.js +7 -0
  175. package/src/lib/utils/otp.js.map +1 -0
  176. package/tsconfig.tsbuildinfo +1 -0
  177. package/index.cjs.d.ts +0 -1
  178. package/index.cjs.js +0 -105236
@@ -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":"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"}
@@ -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";