@ambushsoftworks/nestjs-auth-graphql 0.1.3

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 (279) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +711 -0
  3. package/dist/auth.module.d.ts +61 -0
  4. package/dist/auth.module.d.ts.map +1 -0
  5. package/dist/auth.module.js +190 -0
  6. package/dist/auth.module.js.map +1 -0
  7. package/dist/decorators/current-user.decorator.d.ts +2 -0
  8. package/dist/decorators/current-user.decorator.d.ts.map +1 -0
  9. package/dist/decorators/current-user.decorator.js +10 -0
  10. package/dist/decorators/current-user.decorator.js.map +1 -0
  11. package/dist/dto/account-lock-status.dto.d.ts +5 -0
  12. package/dist/dto/account-lock-status.dto.d.ts.map +1 -0
  13. package/dist/dto/account-lock-status.dto.js +32 -0
  14. package/dist/dto/account-lock-status.dto.js.map +1 -0
  15. package/dist/dto/auth-response.dto.d.ts +7 -0
  16. package/dist/dto/auth-response.dto.d.ts.map +1 -0
  17. package/dist/dto/auth-response.dto.js +33 -0
  18. package/dist/dto/auth-response.dto.js.map +1 -0
  19. package/dist/dto/biometric-challenge.dto.d.ts +6 -0
  20. package/dist/dto/biometric-challenge.dto.d.ts.map +1 -0
  21. package/dist/dto/biometric-challenge.dto.js +32 -0
  22. package/dist/dto/biometric-challenge.dto.js.map +1 -0
  23. package/dist/dto/biometric-credential.dto.d.ts +10 -0
  24. package/dist/dto/biometric-credential.dto.d.ts.map +1 -0
  25. package/dist/dto/biometric-credential.dto.js +48 -0
  26. package/dist/dto/biometric-credential.dto.js.map +1 -0
  27. package/dist/dto/biometric-login.input.d.ts +5 -0
  28. package/dist/dto/biometric-login.input.d.ts.map +1 -0
  29. package/dist/dto/biometric-login.input.js +33 -0
  30. package/dist/dto/biometric-login.input.js.map +1 -0
  31. package/dist/dto/biometric-status.dto.d.ts +5 -0
  32. package/dist/dto/biometric-status.dto.d.ts.map +1 -0
  33. package/dist/dto/biometric-status.dto.js +28 -0
  34. package/dist/dto/biometric-status.dto.js.map +1 -0
  35. package/dist/dto/complete-facebook-signup.input.d.ts +6 -0
  36. package/dist/dto/complete-facebook-signup.input.d.ts.map +1 -0
  37. package/dist/dto/complete-facebook-signup.input.js +45 -0
  38. package/dist/dto/complete-facebook-signup.input.js.map +1 -0
  39. package/dist/dto/enable-biometric.input.d.ts +5 -0
  40. package/dist/dto/enable-biometric.input.d.ts.map +1 -0
  41. package/dist/dto/enable-biometric.input.js +33 -0
  42. package/dist/dto/enable-biometric.input.js.map +1 -0
  43. package/dist/dto/enroll-biometric.input.d.ts +6 -0
  44. package/dist/dto/enroll-biometric.input.d.ts.map +1 -0
  45. package/dist/dto/enroll-biometric.input.js +41 -0
  46. package/dist/dto/enroll-biometric.input.js.map +1 -0
  47. package/dist/dto/jwt-payload.interface.d.ts +5 -0
  48. package/dist/dto/jwt-payload.interface.d.ts.map +1 -0
  49. package/dist/dto/jwt-payload.interface.js +3 -0
  50. package/dist/dto/jwt-payload.interface.js.map +1 -0
  51. package/dist/dto/link-google-account.input.d.ts +5 -0
  52. package/dist/dto/link-google-account.input.d.ts.map +1 -0
  53. package/dist/dto/link-google-account.input.js +38 -0
  54. package/dist/dto/link-google-account.input.js.map +1 -0
  55. package/dist/dto/login.input.d.ts +5 -0
  56. package/dist/dto/login.input.d.ts.map +1 -0
  57. package/dist/dto/login.input.js +31 -0
  58. package/dist/dto/login.input.js.map +1 -0
  59. package/dist/dto/logout-response.dto.d.ts +9 -0
  60. package/dist/dto/logout-response.dto.d.ts.map +1 -0
  61. package/dist/dto/logout-response.dto.js +42 -0
  62. package/dist/dto/logout-response.dto.js.map +1 -0
  63. package/dist/dto/logout.input.d.ts +4 -0
  64. package/dist/dto/logout.input.d.ts.map +1 -0
  65. package/dist/dto/logout.input.js +27 -0
  66. package/dist/dto/logout.input.js.map +1 -0
  67. package/dist/dto/phone-verification-response.dto.d.ts +24 -0
  68. package/dist/dto/phone-verification-response.dto.d.ts.map +1 -0
  69. package/dist/dto/phone-verification-response.dto.js +98 -0
  70. package/dist/dto/phone-verification-response.dto.js.map +1 -0
  71. package/dist/dto/phone-verification-status.dto.d.ts +9 -0
  72. package/dist/dto/phone-verification-status.dto.d.ts.map +1 -0
  73. package/dist/dto/phone-verification-status.dto.js +44 -0
  74. package/dist/dto/phone-verification-status.dto.js.map +1 -0
  75. package/dist/dto/refresh-token.input.d.ts +4 -0
  76. package/dist/dto/refresh-token.input.d.ts.map +1 -0
  77. package/dist/dto/refresh-token.input.js +27 -0
  78. package/dist/dto/refresh-token.input.js.map +1 -0
  79. package/dist/dto/remove-biometric-device-response.dto.d.ts +5 -0
  80. package/dist/dto/remove-biometric-device-response.dto.d.ts.map +1 -0
  81. package/dist/dto/remove-biometric-device-response.dto.js +28 -0
  82. package/dist/dto/remove-biometric-device-response.dto.js.map +1 -0
  83. package/dist/dto/send-phone-verification.input.d.ts +5 -0
  84. package/dist/dto/send-phone-verification.input.d.ts.map +1 -0
  85. package/dist/dto/send-phone-verification.input.js +36 -0
  86. package/dist/dto/send-phone-verification.input.js.map +1 -0
  87. package/dist/dto/signup.input.d.ts +5 -0
  88. package/dist/dto/signup.input.d.ts.map +1 -0
  89. package/dist/dto/signup.input.js +36 -0
  90. package/dist/dto/signup.input.js.map +1 -0
  91. package/dist/dto/unlink-social-account-response.dto.d.ts +8 -0
  92. package/dist/dto/unlink-social-account-response.dto.d.ts.map +1 -0
  93. package/dist/dto/unlink-social-account-response.dto.js +37 -0
  94. package/dist/dto/unlink-social-account-response.dto.js.map +1 -0
  95. package/dist/dto/unlink-social-account.input.d.ts +4 -0
  96. package/dist/dto/unlink-social-account.input.d.ts.map +1 -0
  97. package/dist/dto/unlink-social-account.input.js +28 -0
  98. package/dist/dto/unlink-social-account.input.js.map +1 -0
  99. package/dist/dto/verify-biometric-signature.input.d.ts +6 -0
  100. package/dist/dto/verify-biometric-signature.input.d.ts.map +1 -0
  101. package/dist/dto/verify-biometric-signature.input.js +39 -0
  102. package/dist/dto/verify-biometric-signature.input.js.map +1 -0
  103. package/dist/dto/verify-email-response.dto.d.ts +5 -0
  104. package/dist/dto/verify-email-response.dto.d.ts.map +1 -0
  105. package/dist/dto/verify-email-response.dto.js +28 -0
  106. package/dist/dto/verify-email-response.dto.js.map +1 -0
  107. package/dist/dto/verify-email.input.d.ts +5 -0
  108. package/dist/dto/verify-email.input.d.ts.map +1 -0
  109. package/dist/dto/verify-email.input.js +33 -0
  110. package/dist/dto/verify-email.input.js.map +1 -0
  111. package/dist/dto/verify-phone.input.d.ts +5 -0
  112. package/dist/dto/verify-phone.input.d.ts.map +1 -0
  113. package/dist/dto/verify-phone.input.js +36 -0
  114. package/dist/dto/verify-phone.input.js.map +1 -0
  115. package/dist/entities/auth-user.entity.d.ts +23 -0
  116. package/dist/entities/auth-user.entity.d.ts.map +1 -0
  117. package/dist/entities/auth-user.entity.js +87 -0
  118. package/dist/entities/auth-user.entity.js.map +1 -0
  119. package/dist/exceptions/account-locked.exception.d.ts +5 -0
  120. package/dist/exceptions/account-locked.exception.d.ts.map +1 -0
  121. package/dist/exceptions/account-locked.exception.js +18 -0
  122. package/dist/exceptions/account-locked.exception.js.map +1 -0
  123. package/dist/exceptions/oauth.exceptions.d.ts +23 -0
  124. package/dist/exceptions/oauth.exceptions.d.ts.map +1 -0
  125. package/dist/exceptions/oauth.exceptions.js +84 -0
  126. package/dist/exceptions/oauth.exceptions.js.map +1 -0
  127. package/dist/exceptions/verification.exceptions.d.ts +14 -0
  128. package/dist/exceptions/verification.exceptions.d.ts.map +1 -0
  129. package/dist/exceptions/verification.exceptions.js +43 -0
  130. package/dist/exceptions/verification.exceptions.js.map +1 -0
  131. package/dist/guards/jwt-auth.guard.d.ts +7 -0
  132. package/dist/guards/jwt-auth.guard.d.ts.map +1 -0
  133. package/dist/guards/jwt-auth.guard.js +23 -0
  134. package/dist/guards/jwt-auth.guard.js.map +1 -0
  135. package/dist/index.d.ts +66 -0
  136. package/dist/index.d.ts.map +1 -0
  137. package/dist/index.js +82 -0
  138. package/dist/index.js.map +1 -0
  139. package/dist/interfaces/auth-lifecycle-hooks.interface.d.ts +11 -0
  140. package/dist/interfaces/auth-lifecycle-hooks.interface.d.ts.map +1 -0
  141. package/dist/interfaces/auth-lifecycle-hooks.interface.js +3 -0
  142. package/dist/interfaces/auth-lifecycle-hooks.interface.js.map +1 -0
  143. package/dist/interfaces/auth-logger.interface.d.ts +45 -0
  144. package/dist/interfaces/auth-logger.interface.d.ts.map +1 -0
  145. package/dist/interfaces/auth-logger.interface.js +42 -0
  146. package/dist/interfaces/auth-logger.interface.js.map +1 -0
  147. package/dist/interfaces/auth-user.interface.d.ts +32 -0
  148. package/dist/interfaces/auth-user.interface.d.ts.map +1 -0
  149. package/dist/interfaces/auth-user.interface.js +17 -0
  150. package/dist/interfaces/auth-user.interface.js.map +1 -0
  151. package/dist/interfaces/biometric-repository.interface.d.ts +22 -0
  152. package/dist/interfaces/biometric-repository.interface.d.ts.map +1 -0
  153. package/dist/interfaces/biometric-repository.interface.js +3 -0
  154. package/dist/interfaces/biometric-repository.interface.js.map +1 -0
  155. package/dist/interfaces/brute-force-repository.interface.d.ts +11 -0
  156. package/dist/interfaces/brute-force-repository.interface.d.ts.map +1 -0
  157. package/dist/interfaces/brute-force-repository.interface.js +3 -0
  158. package/dist/interfaces/brute-force-repository.interface.js.map +1 -0
  159. package/dist/interfaces/email-service.interface.d.ts +10 -0
  160. package/dist/interfaces/email-service.interface.d.ts.map +1 -0
  161. package/dist/interfaces/email-service.interface.js +3 -0
  162. package/dist/interfaces/email-service.interface.js.map +1 -0
  163. package/dist/interfaces/index.d.ts +12 -0
  164. package/dist/interfaces/index.d.ts.map +1 -0
  165. package/dist/interfaces/index.js +28 -0
  166. package/dist/interfaces/index.js.map +1 -0
  167. package/dist/interfaces/refresh-token-repository.interface.d.ts +18 -0
  168. package/dist/interfaces/refresh-token-repository.interface.d.ts.map +1 -0
  169. package/dist/interfaces/refresh-token-repository.interface.js +3 -0
  170. package/dist/interfaces/refresh-token-repository.interface.js.map +1 -0
  171. package/dist/interfaces/sms-service.interface.d.ts +8 -0
  172. package/dist/interfaces/sms-service.interface.d.ts.map +1 -0
  173. package/dist/interfaces/sms-service.interface.js +3 -0
  174. package/dist/interfaces/sms-service.interface.js.map +1 -0
  175. package/dist/interfaces/storage-service.interface.d.ts +5 -0
  176. package/dist/interfaces/storage-service.interface.d.ts.map +1 -0
  177. package/dist/interfaces/storage-service.interface.js +3 -0
  178. package/dist/interfaces/storage-service.interface.js.map +1 -0
  179. package/dist/interfaces/user-repository.interface.d.ts +42 -0
  180. package/dist/interfaces/user-repository.interface.d.ts.map +1 -0
  181. package/dist/interfaces/user-repository.interface.js +3 -0
  182. package/dist/interfaces/user-repository.interface.js.map +1 -0
  183. package/dist/interfaces/verification-repository.interface.d.ts +11 -0
  184. package/dist/interfaces/verification-repository.interface.d.ts.map +1 -0
  185. package/dist/interfaces/verification-repository.interface.js +3 -0
  186. package/dist/interfaces/verification-repository.interface.js.map +1 -0
  187. package/dist/repositories/noop-biometric.repository.d.ts +23 -0
  188. package/dist/repositories/noop-biometric.repository.d.ts.map +1 -0
  189. package/dist/repositories/noop-biometric.repository.js +42 -0
  190. package/dist/repositories/noop-biometric.repository.js.map +1 -0
  191. package/dist/repositories/noop-brute-force.repository.d.ts +12 -0
  192. package/dist/repositories/noop-brute-force.repository.d.ts.map +1 -0
  193. package/dist/repositories/noop-brute-force.repository.js +34 -0
  194. package/dist/repositories/noop-brute-force.repository.js.map +1 -0
  195. package/dist/repositories/noop-verification.repository.d.ts +12 -0
  196. package/dist/repositories/noop-verification.repository.d.ts.map +1 -0
  197. package/dist/repositories/noop-verification.repository.js +30 -0
  198. package/dist/repositories/noop-verification.repository.js.map +1 -0
  199. package/dist/resolvers/auth.resolver.d.ts +66 -0
  200. package/dist/resolvers/auth.resolver.d.ts.map +1 -0
  201. package/dist/resolvers/auth.resolver.js +455 -0
  202. package/dist/resolvers/auth.resolver.js.map +1 -0
  203. package/dist/resolvers/oauth.controller.d.ts +32 -0
  204. package/dist/resolvers/oauth.controller.d.ts.map +1 -0
  205. package/dist/resolvers/oauth.controller.js +216 -0
  206. package/dist/resolvers/oauth.controller.js.map +1 -0
  207. package/dist/services/auth.service.d.ts +104 -0
  208. package/dist/services/auth.service.d.ts.map +1 -0
  209. package/dist/services/auth.service.js +720 -0
  210. package/dist/services/auth.service.js.map +1 -0
  211. package/dist/services/biometric-auth.service.d.ts +26 -0
  212. package/dist/services/biometric-auth.service.d.ts.map +1 -0
  213. package/dist/services/biometric-auth.service.js +108 -0
  214. package/dist/services/biometric-auth.service.js.map +1 -0
  215. package/dist/services/biometric-verification.service.d.ts +9 -0
  216. package/dist/services/biometric-verification.service.d.ts.map +1 -0
  217. package/dist/services/biometric-verification.service.js +78 -0
  218. package/dist/services/biometric-verification.service.js.map +1 -0
  219. package/dist/services/brute-force-protection.service.d.ts +23 -0
  220. package/dist/services/brute-force-protection.service.d.ts.map +1 -0
  221. package/dist/services/brute-force-protection.service.js +105 -0
  222. package/dist/services/brute-force-protection.service.js.map +1 -0
  223. package/dist/services/console-logger.service.d.ts +9 -0
  224. package/dist/services/console-logger.service.d.ts.map +1 -0
  225. package/dist/services/console-logger.service.js +46 -0
  226. package/dist/services/console-logger.service.js.map +1 -0
  227. package/dist/services/encryption.service.d.ts +14 -0
  228. package/dist/services/encryption.service.d.ts.map +1 -0
  229. package/dist/services/encryption.service.js +98 -0
  230. package/dist/services/encryption.service.js.map +1 -0
  231. package/dist/services/noop-email.service.d.ts +12 -0
  232. package/dist/services/noop-email.service.d.ts.map +1 -0
  233. package/dist/services/noop-email.service.js +42 -0
  234. package/dist/services/noop-email.service.js.map +1 -0
  235. package/dist/services/noop-sms.service.d.ts +8 -0
  236. package/dist/services/noop-sms.service.d.ts.map +1 -0
  237. package/dist/services/noop-sms.service.js +38 -0
  238. package/dist/services/noop-sms.service.js.map +1 -0
  239. package/dist/services/oauth-linking-token.service.d.ts +24 -0
  240. package/dist/services/oauth-linking-token.service.d.ts.map +1 -0
  241. package/dist/services/oauth-linking-token.service.js +79 -0
  242. package/dist/services/oauth-linking-token.service.js.map +1 -0
  243. package/dist/services/oauth-state.service.d.ts +19 -0
  244. package/dist/services/oauth-state.service.d.ts.map +1 -0
  245. package/dist/services/oauth-state.service.js +91 -0
  246. package/dist/services/oauth-state.service.js.map +1 -0
  247. package/dist/services/refresh-token.service.d.ts +29 -0
  248. package/dist/services/refresh-token.service.d.ts.map +1 -0
  249. package/dist/services/refresh-token.service.js +106 -0
  250. package/dist/services/refresh-token.service.js.map +1 -0
  251. package/dist/services/sendgrid-email.service.d.ts +33 -0
  252. package/dist/services/sendgrid-email.service.d.ts.map +1 -0
  253. package/dist/services/sendgrid-email.service.js +1002 -0
  254. package/dist/services/sendgrid-email.service.js.map +1 -0
  255. package/dist/services/twilio-sms.service.d.ts +13 -0
  256. package/dist/services/twilio-sms.service.d.ts.map +1 -0
  257. package/dist/services/twilio-sms.service.js +84 -0
  258. package/dist/services/twilio-sms.service.js.map +1 -0
  259. package/dist/services/verification.service.d.ts +27 -0
  260. package/dist/services/verification.service.d.ts.map +1 -0
  261. package/dist/services/verification.service.js +179 -0
  262. package/dist/services/verification.service.js.map +1 -0
  263. package/dist/strategies/facebook.strategy.d.ts +18 -0
  264. package/dist/strategies/facebook.strategy.d.ts.map +1 -0
  265. package/dist/strategies/facebook.strategy.js +96 -0
  266. package/dist/strategies/facebook.strategy.js.map +1 -0
  267. package/dist/strategies/google.strategy.d.ts +17 -0
  268. package/dist/strategies/google.strategy.d.ts.map +1 -0
  269. package/dist/strategies/google.strategy.js +73 -0
  270. package/dist/strategies/google.strategy.js.map +1 -0
  271. package/dist/strategies/jwt.strategy.d.ts +14 -0
  272. package/dist/strategies/jwt.strategy.d.ts.map +1 -0
  273. package/dist/strategies/jwt.strategy.js +45 -0
  274. package/dist/strategies/jwt.strategy.js.map +1 -0
  275. package/dist/utils/provider-helpers.d.ts +12 -0
  276. package/dist/utils/provider-helpers.d.ts.map +1 -0
  277. package/dist/utils/provider-helpers.js +33 -0
  278. package/dist/utils/provider-helpers.js.map +1 -0
  279. package/package.json +109 -0
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.JwtStrategy = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const passport_1 = require("@nestjs/passport");
18
+ const passport_jwt_1 = require("passport-jwt");
19
+ const auth_service_1 = require("../services/auth.service");
20
+ const auth_module_1 = require("../auth.module");
21
+ let JwtStrategy = class JwtStrategy extends (0, passport_1.PassportStrategy)(passport_jwt_1.Strategy) {
22
+ constructor(options, authService) {
23
+ super({
24
+ jwtFromRequest: passport_jwt_1.ExtractJwt.fromAuthHeaderAsBearerToken(),
25
+ ignoreExpiration: false,
26
+ secretOrKey: options.jwtSecret,
27
+ });
28
+ this.options = options;
29
+ this.authService = authService;
30
+ }
31
+ async validate(payload) {
32
+ const user = await this.authService.validateUser(payload);
33
+ if (!user) {
34
+ throw new common_1.UnauthorizedException('Invalid token');
35
+ }
36
+ return user;
37
+ }
38
+ };
39
+ exports.JwtStrategy = JwtStrategy;
40
+ exports.JwtStrategy = JwtStrategy = __decorate([
41
+ (0, common_1.Injectable)(),
42
+ __param(0, (0, common_1.Inject)(auth_module_1.AUTH_MODULE_OPTIONS)),
43
+ __metadata("design:paramtypes", [Object, auth_service_1.AuthService])
44
+ ], JwtStrategy);
45
+ //# sourceMappingURL=jwt.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.strategy.js","sourceRoot":"","sources":["../../src/strategies/jwt.strategy.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA2E;AAC3E,+CAAoD;AACpD,+CAAoD;AACpD,2DAAuD;AAGvD,gDAAwE;AAGjE,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,IAAA,2BAAgB,EAAC,uBAAQ,CAAC;IACzD,YACuC,OAA0B,EACvD,WAAwB;QAEhC,KAAK,CAAC;YACJ,cAAc,EAAE,yBAAU,CAAC,2BAA2B,EAAE;YACxD,gBAAgB,EAAE,KAAK;YACvB,WAAW,EAAE,OAAO,CAAC,SAAS;SAC/B,CAAC,CAAC;QAPkC,YAAO,GAAP,OAAO,CAAmB;QACvD,gBAAW,GAAX,WAAW,CAAa;IAOlC,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,OAAmB;QAChC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAE1D,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,8BAAqB,CAAC,eAAe,CAAC,CAAC;QACnD,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AArBY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,eAAM,EAAC,iCAAmB,CAAC,CAAA;6CACP,0BAAW;GAHvB,WAAW,CAqBvB"}
@@ -0,0 +1,12 @@
1
+ export type SocialProvider = 'google' | 'facebook' | 'apple';
2
+ export type ProviderIdField = 'googleId' | 'facebookId' | 'appleId';
3
+ export interface UserAuthFields {
4
+ passwordHash: string | null;
5
+ googleId: string | null;
6
+ facebookId: string | null;
7
+ appleId: string | null;
8
+ }
9
+ export declare function getProviderField(provider: SocialProvider): ProviderIdField;
10
+ export declare function hasOtherAuthMethods(user: UserAuthFields, excludeProvider: SocialProvider): boolean;
11
+ export declare function countAuthMethods(user: UserAuthFields): number;
12
+ //# sourceMappingURL=provider-helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-helpers.d.ts","sourceRoot":"","sources":["../../src/utils/provider-helpers.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,cAAc,GAAG,QAAQ,GAAG,UAAU,GAAG,OAAO,CAAC;AAC7D,MAAM,MAAM,eAAe,GAAG,UAAU,GAAG,YAAY,GAAG,SAAS,CAAC;AAKpE,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CACxB;AAWD,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,cAAc,GAAG,eAAe,CAO1E;AAYD,wBAAgB,mBAAmB,CACjC,IAAI,EAAE,cAAc,EACpB,eAAe,EAAE,cAAc,GAC9B,OAAO,CAUT;AAQD,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,cAAc,GAAG,MAAM,CAS7D"}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getProviderField = getProviderField;
4
+ exports.hasOtherAuthMethods = hasOtherAuthMethods;
5
+ exports.countAuthMethods = countAuthMethods;
6
+ function getProviderField(provider) {
7
+ const mapping = {
8
+ google: 'googleId',
9
+ facebook: 'facebookId',
10
+ apple: 'appleId',
11
+ };
12
+ return mapping[provider];
13
+ }
14
+ function hasOtherAuthMethods(user, excludeProvider) {
15
+ const hasPassword = user.passwordHash != null && user.passwordHash.length > 0;
16
+ const hasGoogle = excludeProvider !== 'google' && user.googleId != null;
17
+ const hasFacebook = excludeProvider !== 'facebook' && user.facebookId != null;
18
+ const hasApple = excludeProvider !== 'apple' && user.appleId != null;
19
+ return hasPassword || hasGoogle || hasFacebook || hasApple;
20
+ }
21
+ function countAuthMethods(user) {
22
+ let count = 0;
23
+ if (user.passwordHash != null && user.passwordHash.length > 0)
24
+ count++;
25
+ if (user.googleId != null)
26
+ count++;
27
+ if (user.facebookId != null)
28
+ count++;
29
+ if (user.appleId != null)
30
+ count++;
31
+ return count;
32
+ }
33
+ //# sourceMappingURL=provider-helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-helpers.js","sourceRoot":"","sources":["../../src/utils/provider-helpers.ts"],"names":[],"mappings":";;AA0BA,4CAOC;AAYD,kDAaC;AAQD,4CASC;AAjDD,SAAgB,gBAAgB,CAAC,QAAwB;IACvD,MAAM,OAAO,GAA4C;QACvD,MAAM,EAAE,UAAU;QAClB,QAAQ,EAAE,YAAY;QACtB,KAAK,EAAE,SAAS;KACjB,CAAC;IACF,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC;AAC3B,CAAC;AAYD,SAAgB,mBAAmB,CACjC,IAAoB,EACpB,eAA+B;IAG/B,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;IAG9E,MAAM,SAAS,GAAG,eAAe,KAAK,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC;IACxE,MAAM,WAAW,GAAG,eAAe,KAAK,UAAU,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC;IAC9E,MAAM,QAAQ,GAAG,eAAe,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC;IAErE,OAAO,WAAW,IAAI,SAAS,IAAI,WAAW,IAAI,QAAQ,CAAC;AAC7D,CAAC;AAQD,SAAgB,gBAAgB,CAAC,IAAoB;IACnD,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC;QAAE,KAAK,EAAE,CAAC;IACvE,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI;QAAE,KAAK,EAAE,CAAC;IACnC,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI;QAAE,KAAK,EAAE,CAAC;IACrC,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI;QAAE,KAAK,EAAE,CAAC;IAElC,OAAO,KAAK,CAAC;AACf,CAAC"}
package/package.json ADDED
@@ -0,0 +1,109 @@
1
+ {
2
+ "name": "@ambushsoftworks/nestjs-auth-graphql",
3
+ "version": "0.1.3",
4
+ "description": "Production-grade authentication package for NestJS with GraphQL, supporting JWT, OAuth, email/SMS verification, and biometric auth",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist",
9
+ "README.md",
10
+ "LICENSE"
11
+ ],
12
+ "scripts": {
13
+ "build": "tsc",
14
+ "build:watch": "tsc --watch",
15
+ "test": "jest",
16
+ "test:watch": "jest --watch",
17
+ "test:cov": "jest --coverage",
18
+ "lint": "eslint \"{src,tests}/**/*.ts\" --fix",
19
+ "format": "prettier --write \"src/**/*.ts\" \"tests/**/*.ts\"",
20
+ "prepublishOnly": "npm run build"
21
+ },
22
+ "keywords": [
23
+ "nestjs",
24
+ "graphql",
25
+ "authentication",
26
+ "jwt",
27
+ "oauth",
28
+ "email-verification",
29
+ "sms-verification",
30
+ "biometric",
31
+ "social-login",
32
+ "google-oauth",
33
+ "facebook-oauth",
34
+ "refresh-token",
35
+ "brute-force-protection"
36
+ ],
37
+ "author": "Ambush Softworks",
38
+ "license": "MIT",
39
+ "repository": {
40
+ "type": "git",
41
+ "url": "https://gitlab.com/ambushworks/nestjs-auth-graphql.git"
42
+ },
43
+ "peerDependencies": {
44
+ "@nestjs/common": "^10.0.0",
45
+ "@nestjs/config": "^3.0.0",
46
+ "@nestjs/core": "^10.0.0",
47
+ "@nestjs/graphql": "^12.0.0",
48
+ "@nestjs/jwt": "^10.0.0",
49
+ "@nestjs/passport": "^10.0.0",
50
+ "@nestjs/throttler": "^6.0.0",
51
+ "graphql": "^16.0.0",
52
+ "passport": "^0.7.0",
53
+ "passport-jwt": "^4.0.0",
54
+ "reflect-metadata": "^0.2.0",
55
+ "rxjs": "^7.0.0"
56
+ },
57
+ "dependencies": {
58
+ "@sendgrid/mail": "^8.1.6",
59
+ "bcrypt": "^5.1.1",
60
+ "class-transformer": "^0.5.1",
61
+ "class-validator": "^0.14.1",
62
+ "google-auth-library": "^10.5.0",
63
+ "libphonenumber-js": "^1.12.26",
64
+ "passport-google-oauth20": "^2.0.0",
65
+ "twilio": "^5.10.4"
66
+ },
67
+ "devDependencies": {
68
+ "@nestjs/cli": "^10.3.0",
69
+ "@nestjs/config": "^3.3.0",
70
+ "@nestjs/testing": "^10.3.1",
71
+ "@nestjs/throttler": "^6.4.0",
72
+ "@types/bcrypt": "^5.0.2",
73
+ "@types/jest": "^29.5.11",
74
+ "@types/node": "^20.11.5",
75
+ "@types/passport-google-oauth20": "^2.0.17",
76
+ "@types/passport-jwt": "^4.0.0",
77
+ "@typescript-eslint/eslint-plugin": "^6.19.0",
78
+ "@typescript-eslint/parser": "^6.19.0",
79
+ "eslint": "^8.56.0",
80
+ "eslint-config-prettier": "^9.1.0",
81
+ "eslint-plugin-prettier": "^5.1.3",
82
+ "graphql": "^16.12.0",
83
+ "jest": "^29.7.0",
84
+ "passport": "^0.7.0",
85
+ "passport-jwt": "^4.0.1",
86
+ "prettier": "^3.2.4",
87
+ "reflect-metadata": "^0.2.2",
88
+ "rxjs": "^7.8.2",
89
+ "ts-jest": "^29.1.1",
90
+ "typescript": "^5.3.3"
91
+ },
92
+ "jest": {
93
+ "moduleFileExtensions": [
94
+ "js",
95
+ "json",
96
+ "ts"
97
+ ],
98
+ "rootDir": "src",
99
+ "testRegex": ".*\\.spec\\.ts$",
100
+ "transform": {
101
+ "^.+\\.(t|j)s$": "ts-jest"
102
+ },
103
+ "collectCoverageFrom": [
104
+ "**/*.(t|j)s"
105
+ ],
106
+ "coverageDirectory": "../coverage",
107
+ "testEnvironment": "node"
108
+ }
109
+ }