coding-agent-benchmarks 0.2.0 → 0.3.0

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 (176) hide show
  1. package/README.md +225 -10
  2. package/dist/adapters/claudeCodeCLI.d.ts +1 -1
  3. package/dist/adapters/claudeCodeCLI.d.ts.map +1 -1
  4. package/dist/adapters/claudeCodeCLI.js +44 -32
  5. package/dist/adapters/claudeCodeCLI.js.map +1 -1
  6. package/dist/adapters/copilotCLI.d.ts.map +1 -1
  7. package/dist/adapters/copilotCLI.js +28 -16
  8. package/dist/adapters/copilotCLI.js.map +1 -1
  9. package/dist/config/environment.d.ts +51 -0
  10. package/dist/config/environment.d.ts.map +1 -0
  11. package/dist/config/environment.js +57 -0
  12. package/dist/config/environment.js.map +1 -0
  13. package/dist/config/parser.d.ts +6 -0
  14. package/dist/config/parser.d.ts.map +1 -0
  15. package/dist/config/parser.js +87 -0
  16. package/dist/config/parser.js.map +1 -0
  17. package/dist/evaluator.d.ts +4 -9
  18. package/dist/evaluator.d.ts.map +1 -1
  19. package/dist/evaluator.js +4 -12
  20. package/dist/evaluator.js.map +1 -1
  21. package/dist/examples/file-upload-example.d.ts +2 -0
  22. package/dist/examples/file-upload-example.d.ts.map +1 -0
  23. package/dist/examples/file-upload-example.js +37 -0
  24. package/dist/examples/file-upload-example.js.map +1 -0
  25. package/dist/examples/typedEventEmitterExample.d.ts +5 -0
  26. package/dist/examples/typedEventEmitterExample.d.ts.map +1 -0
  27. package/dist/examples/typedEventEmitterExample.js +44 -0
  28. package/dist/examples/typedEventEmitterExample.js.map +1 -0
  29. package/dist/index.d.ts +13 -12
  30. package/dist/index.d.ts.map +1 -1
  31. package/dist/index.js +3 -1
  32. package/dist/index.js.map +1 -1
  33. package/dist/registration/database.d.ts +13 -0
  34. package/dist/registration/database.d.ts.map +1 -0
  35. package/dist/registration/database.js +35 -0
  36. package/dist/registration/database.js.map +1 -0
  37. package/dist/registration/email.d.ts +17 -0
  38. package/dist/registration/email.d.ts.map +1 -0
  39. package/dist/registration/email.js +40 -0
  40. package/dist/registration/email.js.map +1 -0
  41. package/dist/registration/emailService.d.ts +13 -0
  42. package/dist/registration/emailService.d.ts.map +1 -0
  43. package/dist/registration/emailService.js +26 -0
  44. package/dist/registration/emailService.js.map +1 -0
  45. package/dist/registration/example.d.ts +2 -0
  46. package/dist/registration/example.d.ts.map +1 -0
  47. package/dist/registration/example.js +37 -0
  48. package/dist/registration/example.js.map +1 -0
  49. package/dist/registration/index.d.ts +7 -0
  50. package/dist/registration/index.d.ts.map +1 -0
  51. package/dist/registration/index.js +15 -0
  52. package/dist/registration/index.js.map +1 -0
  53. package/dist/registration/password.d.ts +3 -0
  54. package/dist/registration/password.d.ts.map +1 -0
  55. package/dist/registration/password.js +27 -0
  56. package/dist/registration/password.js.map +1 -0
  57. package/dist/registration/passwordHasher.d.ts +8 -0
  58. package/dist/registration/passwordHasher.d.ts.map +1 -0
  59. package/dist/registration/passwordHasher.js +39 -0
  60. package/dist/registration/passwordHasher.js.map +1 -0
  61. package/dist/registration/registrationService.d.ts +14 -0
  62. package/dist/registration/registrationService.d.ts.map +1 -0
  63. package/dist/registration/registrationService.js +49 -0
  64. package/dist/registration/registrationService.js.map +1 -0
  65. package/dist/registration/service.d.ts +14 -0
  66. package/dist/registration/service.d.ts.map +1 -0
  67. package/dist/registration/service.js +48 -0
  68. package/dist/registration/service.js.map +1 -0
  69. package/dist/registration/types.d.ts +22 -0
  70. package/dist/registration/types.d.ts.map +1 -0
  71. package/dist/registration/types.js +3 -0
  72. package/dist/registration/types.js.map +1 -0
  73. package/dist/registration/userRepository.d.ts +12 -0
  74. package/dist/registration/userRepository.d.ts.map +1 -0
  75. package/dist/registration/userRepository.js +28 -0
  76. package/dist/registration/userRepository.js.map +1 -0
  77. package/dist/registration/validator.d.ts +7 -0
  78. package/dist/registration/validator.d.ts.map +1 -0
  79. package/dist/registration/validator.js +44 -0
  80. package/dist/registration/validator.js.map +1 -0
  81. package/dist/registration/validators.d.ts +5 -0
  82. package/dist/registration/validators.d.ts.map +1 -0
  83. package/dist/registration/validators.js +60 -0
  84. package/dist/registration/validators.js.map +1 -0
  85. package/dist/reporter.d.ts.map +1 -1
  86. package/dist/reporter.js +59 -29
  87. package/dist/reporter.js.map +1 -1
  88. package/dist/runner.js +2 -1
  89. package/dist/runner.js.map +1 -1
  90. package/dist/sync/cache.d.ts +14 -0
  91. package/dist/sync/cache.d.ts.map +1 -0
  92. package/dist/sync/cache.js +73 -0
  93. package/dist/sync/cache.js.map +1 -0
  94. package/dist/sync/index.d.ts +7 -0
  95. package/dist/sync/index.d.ts.map +1 -0
  96. package/dist/sync/index.js +20 -0
  97. package/dist/sync/index.js.map +1 -0
  98. package/dist/sync/resolver.d.ts +12 -0
  99. package/dist/sync/resolver.d.ts.map +1 -0
  100. package/dist/sync/resolver.js +43 -0
  101. package/dist/sync/resolver.js.map +1 -0
  102. package/dist/sync/service.d.ts +20 -0
  103. package/dist/sync/service.d.ts.map +1 -0
  104. package/dist/sync/service.js +162 -0
  105. package/dist/sync/service.js.map +1 -0
  106. package/dist/sync/source.d.ts +21 -0
  107. package/dist/sync/source.d.ts.map +1 -0
  108. package/dist/sync/source.js +58 -0
  109. package/dist/sync/source.js.map +1 -0
  110. package/dist/sync/types.d.ts +56 -0
  111. package/dist/sync/types.d.ts.map +1 -0
  112. package/dist/sync/types.js +21 -0
  113. package/dist/sync/types.js.map +1 -0
  114. package/dist/types.d.ts +6 -6
  115. package/dist/types.d.ts.map +1 -1
  116. package/dist/utils/baselineManager.d.ts +2 -1
  117. package/dist/utils/baselineManager.d.ts.map +1 -1
  118. package/dist/utils/baselineManager.js +1 -0
  119. package/dist/utils/baselineManager.js.map +1 -1
  120. package/dist/utils/cache.d.ts +11 -0
  121. package/dist/utils/cache.d.ts.map +1 -0
  122. package/dist/utils/cache.js +28 -0
  123. package/dist/utils/cache.js.map +1 -0
  124. package/dist/utils/config-merger.d.ts +11 -0
  125. package/dist/utils/config-merger.d.ts.map +1 -0
  126. package/dist/utils/config-merger.js +36 -0
  127. package/dist/utils/config-merger.js.map +1 -0
  128. package/dist/utils/configParser.d.ts +9 -0
  129. package/dist/utils/configParser.d.ts.map +1 -0
  130. package/dist/utils/configParser.js +51 -0
  131. package/dist/utils/configParser.js.map +1 -0
  132. package/dist/utils/database-providers.d.ts +23 -0
  133. package/dist/utils/database-providers.d.ts.map +1 -0
  134. package/dist/utils/database-providers.js +48 -0
  135. package/dist/utils/database-providers.js.map +1 -0
  136. package/dist/utils/errorHandler.d.ts +10 -0
  137. package/dist/utils/errorHandler.d.ts.map +1 -0
  138. package/dist/utils/errorHandler.js +58 -0
  139. package/dist/utils/errorHandler.js.map +1 -0
  140. package/dist/utils/fetchUserData.d.ts +11 -0
  141. package/dist/utils/fetchUserData.d.ts.map +1 -0
  142. package/dist/utils/fetchUserData.js +31 -0
  143. package/dist/utils/fetchUserData.js.map +1 -0
  144. package/dist/utils/file-upload-handler.d.ts +46 -0
  145. package/dist/utils/file-upload-handler.d.ts.map +1 -0
  146. package/dist/utils/file-upload-handler.js +110 -0
  147. package/dist/utils/file-upload-handler.js.map +1 -0
  148. package/dist/utils/gitUtils.d.ts +2 -1
  149. package/dist/utils/gitUtils.d.ts.map +1 -1
  150. package/dist/utils/gitUtils.js +85 -18
  151. package/dist/utils/gitUtils.js.map +1 -1
  152. package/dist/utils/statistics.d.ts +9 -0
  153. package/dist/utils/statistics.d.ts.map +1 -0
  154. package/dist/utils/statistics.js +26 -0
  155. package/dist/utils/statistics.js.map +1 -0
  156. package/dist/utils/storage-providers.d.ts +24 -0
  157. package/dist/utils/storage-providers.d.ts.map +1 -0
  158. package/dist/utils/storage-providers.js +38 -0
  159. package/dist/utils/storage-providers.js.map +1 -0
  160. package/dist/utils/transformArray.d.ts +18 -0
  161. package/dist/utils/transformArray.d.ts.map +1 -0
  162. package/dist/utils/transformArray.js +21 -0
  163. package/dist/utils/transformArray.js.map +1 -0
  164. package/dist/utils/typedEventEmitter.d.ts +18 -0
  165. package/dist/utils/typedEventEmitter.d.ts.map +1 -0
  166. package/dist/utils/typedEventEmitter.js +62 -0
  167. package/dist/utils/typedEventEmitter.js.map +1 -0
  168. package/dist/utils/userUtils.d.ts +9 -0
  169. package/dist/utils/userUtils.d.ts.map +1 -0
  170. package/dist/utils/userUtils.js +14 -0
  171. package/dist/utils/userUtils.js.map +1 -0
  172. package/dist/validators/llmJudge.d.ts +1 -1
  173. package/dist/validators/llmJudge.d.ts.map +1 -1
  174. package/dist/validators/llmJudge.js +40 -41
  175. package/dist/validators/llmJudge.js.map +1 -1
  176. package/package.json +2 -2
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const index_1 = require("./index");
4
+ const runExample = async () => {
5
+ const validator = new index_1.InputValidator();
6
+ const passwordHasher = new index_1.PasswordHasher();
7
+ const userRepository = new index_1.InMemoryUserRepository();
8
+ const emailService = new index_1.ConsoleEmailService();
9
+ const registrationService = new index_1.RegistrationService(validator, passwordHasher, userRepository, emailService);
10
+ const validUser = {
11
+ email: 'user@example.com',
12
+ password: 'SecureP@ss123',
13
+ name: 'John Doe',
14
+ };
15
+ console.log('Attempting to register user:', validUser.email);
16
+ const result = await registrationService.register(validUser);
17
+ if (result.success) {
18
+ console.log('✓ Registration successful!');
19
+ console.log('User ID:', result.user?.id);
20
+ }
21
+ else {
22
+ console.log('✗ Registration failed:', result.errors);
23
+ }
24
+ console.log('\nAttempting duplicate registration...');
25
+ const duplicateResult = await registrationService.register(validUser);
26
+ console.log('Duplicate result:', duplicateResult.errors);
27
+ const invalidUser = {
28
+ email: 'invalid-email',
29
+ password: 'weak',
30
+ name: '',
31
+ };
32
+ console.log('\nAttempting to register invalid user...');
33
+ const invalidResult = await registrationService.register(invalidUser);
34
+ console.log('Validation errors:', invalidResult.errors);
35
+ };
36
+ runExample().catch(console.error);
37
+ //# sourceMappingURL=example.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"example.js","sourceRoot":"","sources":["../../src/registration/example.ts"],"names":[],"mappings":";;AAAA,mCAOiB;AAEjB,MAAM,UAAU,GAAG,KAAK,IAAmB,EAAE;IAC3C,MAAM,SAAS,GAAG,IAAI,sBAAc,EAAE,CAAC;IACvC,MAAM,cAAc,GAAG,IAAI,sBAAc,EAAE,CAAC;IAC5C,MAAM,cAAc,GAAG,IAAI,8BAAsB,EAAE,CAAC;IACpD,MAAM,YAAY,GAAG,IAAI,2BAAmB,EAAE,CAAC;IAE/C,MAAM,mBAAmB,GAAG,IAAI,2BAAmB,CACjD,SAAS,EACT,cAAc,EACd,cAAc,EACd,YAAY,CACb,CAAC;IAEF,MAAM,SAAS,GAAc;QAC3B,KAAK,EAAE,kBAAkB;QACzB,QAAQ,EAAE,eAAe;QACzB,IAAI,EAAE,UAAU;KACjB,CAAC;IAEF,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7D,MAAM,MAAM,GAAG,MAAM,mBAAmB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAE7D,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC;QAC1C,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IAC3C,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;IACtD,MAAM,eAAe,GAAG,MAAM,mBAAmB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IACtE,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;IAEzD,MAAM,WAAW,GAAc;QAC7B,KAAK,EAAE,eAAe;QACtB,QAAQ,EAAE,MAAM;QAChB,IAAI,EAAE,EAAE;KACT,CAAC;IAEF,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,CAAC;IACxD,MAAM,aAAa,GAAG,MAAM,mBAAmB,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACtE,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;AAC1D,CAAC,CAAC;AAEF,UAAU,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ export { RegistrationService } from './registrationService';
2
+ export { InputValidator } from './validator';
3
+ export { PasswordHasher } from './passwordHasher';
4
+ export { InMemoryUserRepository, UserRepository } from './userRepository';
5
+ export { ConsoleEmailService, MockEmailService, EmailService } from './emailService';
6
+ export { UserInput, User, ValidationResult, RegistrationResult } from './types';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/registration/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACrF,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MockEmailService = exports.ConsoleEmailService = exports.InMemoryUserRepository = exports.PasswordHasher = exports.InputValidator = exports.RegistrationService = void 0;
4
+ var registrationService_1 = require("./registrationService");
5
+ Object.defineProperty(exports, "RegistrationService", { enumerable: true, get: function () { return registrationService_1.RegistrationService; } });
6
+ var validator_1 = require("./validator");
7
+ Object.defineProperty(exports, "InputValidator", { enumerable: true, get: function () { return validator_1.InputValidator; } });
8
+ var passwordHasher_1 = require("./passwordHasher");
9
+ Object.defineProperty(exports, "PasswordHasher", { enumerable: true, get: function () { return passwordHasher_1.PasswordHasher; } });
10
+ var userRepository_1 = require("./userRepository");
11
+ Object.defineProperty(exports, "InMemoryUserRepository", { enumerable: true, get: function () { return userRepository_1.InMemoryUserRepository; } });
12
+ var emailService_1 = require("./emailService");
13
+ Object.defineProperty(exports, "ConsoleEmailService", { enumerable: true, get: function () { return emailService_1.ConsoleEmailService; } });
14
+ Object.defineProperty(exports, "MockEmailService", { enumerable: true, get: function () { return emailService_1.MockEmailService; } });
15
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/registration/index.ts"],"names":[],"mappings":";;;AAAA,6DAA4D;AAAnD,0HAAA,mBAAmB,OAAA;AAC5B,yCAA6C;AAApC,2GAAA,cAAc,OAAA;AACvB,mDAAkD;AAAzC,gHAAA,cAAc,OAAA;AACvB,mDAA0E;AAAjE,wHAAA,sBAAsB,OAAA;AAC/B,+CAAqF;AAA5E,mHAAA,mBAAmB,OAAA;AAAE,gHAAA,gBAAgB,OAAA"}
@@ -0,0 +1,3 @@
1
+ export declare const hashPassword: (password: string) => Promise<string>;
2
+ export declare const verifyPassword: (password: string, storedHash: string) => Promise<boolean>;
3
+ //# sourceMappingURL=password.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password.d.ts","sourceRoot":"","sources":["../../src/registration/password.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,YAAY,GAAU,UAAU,MAAM,KAAG,OAAO,CAAC,MAAM,CAKnE,CAAC;AAEF,eAAO,MAAM,cAAc,GACzB,UAAU,MAAM,EAChB,YAAY,MAAM,KACjB,OAAO,CAAC,OAAO,CAWjB,CAAC"}
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.verifyPassword = exports.hashPassword = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const util_1 = require("util");
6
+ const pbkdf2Async = (0, util_1.promisify)(crypto_1.pbkdf2);
7
+ const SALT_LENGTH = 32;
8
+ const ITERATIONS = 100000;
9
+ const KEY_LENGTH = 64;
10
+ const DIGEST = 'sha512';
11
+ const hashPassword = async (password) => {
12
+ const salt = (0, crypto_1.randomBytes)(SALT_LENGTH);
13
+ const hash = await pbkdf2Async(password, salt, ITERATIONS, KEY_LENGTH, DIGEST);
14
+ return `${salt.toString('hex')}:${hash.toString('hex')}`;
15
+ };
16
+ exports.hashPassword = hashPassword;
17
+ const verifyPassword = async (password, storedHash) => {
18
+ const [saltHex, hashHex] = storedHash.split(':');
19
+ if (!saltHex || !hashHex) {
20
+ return false;
21
+ }
22
+ const salt = Buffer.from(saltHex, 'hex');
23
+ const hash = await pbkdf2Async(password, salt, ITERATIONS, KEY_LENGTH, DIGEST);
24
+ return hash.toString('hex') === hashHex;
25
+ };
26
+ exports.verifyPassword = verifyPassword;
27
+ //# sourceMappingURL=password.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password.js","sourceRoot":"","sources":["../../src/registration/password.ts"],"names":[],"mappings":";;;AAAA,mCAA6C;AAC7C,+BAAiC;AAEjC,MAAM,WAAW,GAAG,IAAA,gBAAS,EAAC,eAAM,CAAC,CAAC;AAEtC,MAAM,WAAW,GAAG,EAAE,CAAC;AACvB,MAAM,UAAU,GAAG,MAAM,CAAC;AAC1B,MAAM,UAAU,GAAG,EAAE,CAAC;AACtB,MAAM,MAAM,GAAG,QAAQ,CAAC;AAEjB,MAAM,YAAY,GAAG,KAAK,EAAE,QAAgB,EAAmB,EAAE;IACtE,MAAM,IAAI,GAAG,IAAA,oBAAW,EAAC,WAAW,CAAC,CAAC;IACtC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAE/E,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;AAC3D,CAAC,CAAC;AALW,QAAA,YAAY,gBAKvB;AAEK,MAAM,cAAc,GAAG,KAAK,EACjC,QAAgB,EAChB,UAAkB,EACA,EAAE;IACpB,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAEjD,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IACzC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAE/E,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,OAAO,CAAC;AAC1C,CAAC,CAAC;AAdW,QAAA,cAAc,kBAczB"}
@@ -0,0 +1,8 @@
1
+ export declare class PasswordHasher {
2
+ private readonly iterations;
3
+ private readonly keyLength;
4
+ private readonly digest;
5
+ hash(password: string): Promise<string>;
6
+ verify(password: string, storedHash: string): Promise<boolean>;
7
+ }
8
+ //# sourceMappingURL=passwordHasher.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passwordHasher.d.ts","sourceRoot":"","sources":["../../src/registration/passwordHasher.ts"],"names":[],"mappings":"AAEA,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAU;IACrC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAM;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAY;IAE7B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAgBvC,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAerE"}
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PasswordHasher = void 0;
4
+ const crypto_1 = require("crypto");
5
+ class PasswordHasher {
6
+ constructor() {
7
+ this.iterations = 100000;
8
+ this.keyLength = 64;
9
+ this.digest = 'sha512';
10
+ }
11
+ async hash(password) {
12
+ return new Promise((resolve, reject) => {
13
+ const salt = (0, crypto_1.randomBytes)(32).toString('hex');
14
+ (0, crypto_1.pbkdf2)(password, salt, this.iterations, this.keyLength, this.digest, (err, derivedKey) => {
15
+ if (err) {
16
+ reject(err);
17
+ return;
18
+ }
19
+ const hash = derivedKey.toString('hex');
20
+ resolve(`${salt}:${hash}`);
21
+ });
22
+ });
23
+ }
24
+ async verify(password, storedHash) {
25
+ return new Promise((resolve, reject) => {
26
+ const [salt, originalHash] = storedHash.split(':');
27
+ (0, crypto_1.pbkdf2)(password, salt, this.iterations, this.keyLength, this.digest, (err, derivedKey) => {
28
+ if (err) {
29
+ reject(err);
30
+ return;
31
+ }
32
+ const hash = derivedKey.toString('hex');
33
+ resolve(hash === originalHash);
34
+ });
35
+ });
36
+ }
37
+ }
38
+ exports.PasswordHasher = PasswordHasher;
39
+ //# sourceMappingURL=passwordHasher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passwordHasher.js","sourceRoot":"","sources":["../../src/registration/passwordHasher.ts"],"names":[],"mappings":";;;AAAA,mCAAyD;AAEzD,MAAa,cAAc;IAA3B;QACmB,eAAU,GAAG,MAAM,CAAC;QACpB,cAAS,GAAG,EAAE,CAAC;QACf,WAAM,GAAG,QAAQ,CAAC;IAiCrC,CAAC;IA/BC,KAAK,CAAC,IAAI,CAAC,QAAgB;QACzB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,MAAM,IAAI,GAAG,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAE7C,IAAA,eAAM,EAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE;gBACvF,IAAI,GAAG,EAAE,CAAC;oBACR,MAAM,CAAC,GAAG,CAAC,CAAC;oBACZ,OAAO;gBACT,CAAC;gBAED,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACxC,OAAO,CAAC,GAAG,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,QAAgB,EAAE,UAAkB;QAC/C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,MAAM,CAAC,IAAI,EAAE,YAAY,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEnD,IAAA,eAAM,EAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE;gBACvF,IAAI,GAAG,EAAE,CAAC;oBACR,MAAM,CAAC,GAAG,CAAC,CAAC;oBACZ,OAAO;gBACT,CAAC;gBAED,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACxC,OAAO,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AApCD,wCAoCC"}
@@ -0,0 +1,14 @@
1
+ import { UserInput, RegistrationResult } from './types';
2
+ import { InputValidator } from './validator';
3
+ import { PasswordHasher } from './passwordHasher';
4
+ import { UserRepository } from './userRepository';
5
+ import { EmailService } from './emailService';
6
+ export declare class RegistrationService {
7
+ private readonly validator;
8
+ private readonly passwordHasher;
9
+ private readonly userRepository;
10
+ private readonly emailService;
11
+ constructor(validator: InputValidator, passwordHasher: PasswordHasher, userRepository: UserRepository, emailService: EmailService);
12
+ register(input: UserInput): Promise<RegistrationResult>;
13
+ }
14
+ //# sourceMappingURL=registrationService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registrationService.d.ts","sourceRoot":"","sources":["../../src/registration/registrationService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,qBAAa,mBAAmB;IAE5B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAHZ,SAAS,EAAE,cAAc,EACzB,cAAc,EAAE,cAAc,EAC9B,cAAc,EAAE,cAAc,EAC9B,YAAY,EAAE,YAAY;IAGvC,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAwC9D"}
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RegistrationService = void 0;
4
+ class RegistrationService {
5
+ constructor(validator, passwordHasher, userRepository, emailService) {
6
+ this.validator = validator;
7
+ this.passwordHasher = passwordHasher;
8
+ this.userRepository = userRepository;
9
+ this.emailService = emailService;
10
+ }
11
+ async register(input) {
12
+ const validationResult = this.validator.validate(input);
13
+ if (!validationResult.isValid) {
14
+ return {
15
+ success: false,
16
+ errors: validationResult.errors,
17
+ };
18
+ }
19
+ const existingUser = await this.userRepository.findByEmail(input.email);
20
+ if (existingUser) {
21
+ return {
22
+ success: false,
23
+ errors: ['Email already registered'],
24
+ };
25
+ }
26
+ try {
27
+ const passwordHash = await this.passwordHasher.hash(input.password);
28
+ const user = await this.userRepository.save({
29
+ email: input.email,
30
+ passwordHash,
31
+ name: input.name,
32
+ });
33
+ await this.emailService.sendWelcomeEmail(user);
34
+ return {
35
+ success: true,
36
+ user,
37
+ errors: [],
38
+ };
39
+ }
40
+ catch (error) {
41
+ return {
42
+ success: false,
43
+ errors: [`Registration failed: ${error}`],
44
+ };
45
+ }
46
+ }
47
+ }
48
+ exports.RegistrationService = RegistrationService;
49
+ //# sourceMappingURL=registrationService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registrationService.js","sourceRoot":"","sources":["../../src/registration/registrationService.ts"],"names":[],"mappings":";;;AAMA,MAAa,mBAAmB;IAC9B,YACmB,SAAyB,EACzB,cAA8B,EAC9B,cAA8B,EAC9B,YAA0B;QAH1B,cAAS,GAAT,SAAS,CAAgB;QACzB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAc;IAC1C,CAAC;IAEJ,KAAK,CAAC,QAAQ,CAAC,KAAgB;QAC7B,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACxD,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC9B,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,gBAAgB,CAAC,MAAM;aAChC,CAAC;QACJ,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACxE,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,CAAC,0BAA0B,CAAC;aACrC,CAAC;QACJ,CAAC;QAED,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAEpE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;gBAC1C,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,YAAY;gBACZ,IAAI,EAAE,KAAK,CAAC,IAAI;aACjB,CAAC,CAAC;YAEH,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAE/C,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,IAAI;gBACJ,MAAM,EAAE,EAAE;aACX,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,CAAC,wBAAwB,KAAK,EAAE,CAAC;aAC1C,CAAC;QACJ,CAAC;IACH,CAAC;CACF;AAhDD,kDAgDC"}
@@ -0,0 +1,14 @@
1
+ import { UserInput, RegistrationResult } from './types';
2
+ import { UserDatabase } from './database';
3
+ import { EmailService } from './email';
4
+ export interface RegistrationServiceOptions {
5
+ database: UserDatabase;
6
+ emailService: EmailService;
7
+ }
8
+ export declare class RegistrationService {
9
+ private database;
10
+ private emailService;
11
+ constructor(options: RegistrationServiceOptions);
12
+ registerUser(input: UserInput): Promise<RegistrationResult>;
13
+ }
14
+ //# sourceMappingURL=service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../src/registration/service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAGxD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,WAAW,0BAA0B;IACzC,QAAQ,EAAE,YAAY,CAAC;IACvB,YAAY,EAAE,YAAY,CAAC;CAC5B;AAED,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,QAAQ,CAAe;IAC/B,OAAO,CAAC,YAAY,CAAe;gBAEvB,OAAO,EAAE,0BAA0B;IAKzC,YAAY,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAuClE"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RegistrationService = void 0;
4
+ const validators_1 = require("./validators");
5
+ const password_1 = require("./password");
6
+ class RegistrationService {
7
+ constructor(options) {
8
+ this.database = options.database;
9
+ this.emailService = options.emailService;
10
+ }
11
+ async registerUser(input) {
12
+ try {
13
+ const validation = (0, validators_1.validateUserInput)(input);
14
+ if (!validation.isValid) {
15
+ return {
16
+ success: false,
17
+ error: validation.errors.join('; '),
18
+ };
19
+ }
20
+ const existingUser = await this.database.findByEmail(input.email);
21
+ if (existingUser) {
22
+ return {
23
+ success: false,
24
+ error: 'Email already registered',
25
+ };
26
+ }
27
+ const passwordHash = await (0, password_1.hashPassword)(input.password);
28
+ const user = await this.database.save({
29
+ email: input.email,
30
+ name: input.name.trim(),
31
+ passwordHash,
32
+ });
33
+ await this.emailService.sendWelcomeEmail(user);
34
+ return {
35
+ success: true,
36
+ user,
37
+ };
38
+ }
39
+ catch (error) {
40
+ return {
41
+ success: false,
42
+ error: error instanceof Error ? error.message : 'Registration failed',
43
+ };
44
+ }
45
+ }
46
+ }
47
+ exports.RegistrationService = RegistrationService;
48
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.js","sourceRoot":"","sources":["../../src/registration/service.ts"],"names":[],"mappings":";;;AACA,6CAAiD;AACjD,yCAA0C;AAS1C,MAAa,mBAAmB;IAI9B,YAAY,OAAmC;QAC7C,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,KAAgB;QACjC,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAA,8BAAiB,EAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;iBACpC,CAAC;YACJ,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAClE,IAAI,YAAY,EAAE,CAAC;gBACjB,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,0BAA0B;iBAClC,CAAC;YACJ,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,IAAA,uBAAY,EAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAExD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACpC,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;gBACvB,YAAY;aACb,CAAC,CAAC;YAEH,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAE/C,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,IAAI;aACL,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,qBAAqB;aACtE,CAAC;QACJ,CAAC;IACH,CAAC;CACF;AAhDD,kDAgDC"}
@@ -0,0 +1,22 @@
1
+ export interface UserInput {
2
+ readonly email: string;
3
+ readonly password: string;
4
+ readonly name: string;
5
+ }
6
+ export interface User {
7
+ readonly id: string;
8
+ readonly email: string;
9
+ readonly passwordHash: string;
10
+ readonly name: string;
11
+ readonly createdAt: Date;
12
+ }
13
+ export interface ValidationResult {
14
+ readonly isValid: boolean;
15
+ readonly errors: readonly string[];
16
+ }
17
+ export interface RegistrationResult {
18
+ readonly success: boolean;
19
+ readonly user?: User;
20
+ readonly errors: readonly string[];
21
+ }
22
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/registration/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,SAAS;IACxB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,IAAI;IACnB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;CACpC;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;CACpC"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/registration/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ import { User } from './types';
2
+ export interface UserRepository {
3
+ findByEmail(email: string): Promise<User | null>;
4
+ save(user: Omit<User, 'id' | 'createdAt'>): Promise<User>;
5
+ }
6
+ export declare class InMemoryUserRepository implements UserRepository {
7
+ private readonly users;
8
+ findByEmail(email: string): Promise<User | null>;
9
+ save(userData: Omit<User, 'id' | 'createdAt'>): Promise<User>;
10
+ private generateId;
11
+ }
12
+ //# sourceMappingURL=userRepository.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"userRepository.d.ts","sourceRoot":"","sources":["../../src/registration/userRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAE/B,MAAM,WAAW,cAAc;IAC7B,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IACjD,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3D;AAED,qBAAa,sBAAuB,YAAW,cAAc;IAC3D,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAgC;IAEhD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;IAMhD,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAWnE,OAAO,CAAC,UAAU;CAGnB"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryUserRepository = void 0;
4
+ const crypto_1 = require("crypto");
5
+ class InMemoryUserRepository {
6
+ constructor() {
7
+ this.users = new Map();
8
+ }
9
+ async findByEmail(email) {
10
+ const users = Array.from(this.users.values());
11
+ const user = users.find((u) => u.email.toLowerCase() === email.toLowerCase());
12
+ return user ?? null;
13
+ }
14
+ async save(userData) {
15
+ const user = {
16
+ id: this.generateId(),
17
+ createdAt: new Date(),
18
+ ...userData,
19
+ };
20
+ this.users.set(user.id, user);
21
+ return user;
22
+ }
23
+ generateId() {
24
+ return (0, crypto_1.randomBytes)(16).toString('hex');
25
+ }
26
+ }
27
+ exports.InMemoryUserRepository = InMemoryUserRepository;
28
+ //# sourceMappingURL=userRepository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"userRepository.js","sourceRoot":"","sources":["../../src/registration/userRepository.ts"],"names":[],"mappings":";;;AAAA,mCAAqC;AAQrC,MAAa,sBAAsB;IAAnC;QACmB,UAAK,GAAsB,IAAI,GAAG,EAAE,CAAC;IAsBxD,CAAC;IApBC,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QAC9C,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;QAC9E,OAAO,IAAI,IAAI,IAAI,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,QAAwC;QACjD,MAAM,IAAI,GAAS;YACjB,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE;YACrB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,GAAG,QAAQ;SACZ,CAAC;QAEF,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,UAAU;QAChB,OAAO,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;CACF;AAvBD,wDAuBC"}
@@ -0,0 +1,7 @@
1
+ import { UserInput, ValidationResult } from './types';
2
+ export declare class InputValidator {
3
+ validate(input: UserInput): ValidationResult;
4
+ private isValidEmail;
5
+ private isStrongPassword;
6
+ }
7
+ //# sourceMappingURL=validator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../../src/registration/validator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAKtD,qBAAa,cAAc;IACzB,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,gBAAgB;IA2B5C,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,gBAAgB;CAYzB"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InputValidator = void 0;
4
+ const EMAIL_REGEX = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
5
+ const MIN_PASSWORD_LENGTH = 8;
6
+ class InputValidator {
7
+ validate(input) {
8
+ const errors = [];
9
+ if (!input.email) {
10
+ errors.push('Email is required');
11
+ }
12
+ else if (!this.isValidEmail(input.email)) {
13
+ errors.push('Invalid email format');
14
+ }
15
+ if (!input.password) {
16
+ errors.push('Password is required');
17
+ }
18
+ else if (!this.isStrongPassword(input.password)) {
19
+ errors.push(`Password must be at least ${MIN_PASSWORD_LENGTH} characters and contain uppercase, lowercase, number, and special character`);
20
+ }
21
+ if (!input.name) {
22
+ errors.push('Name is required');
23
+ }
24
+ return {
25
+ isValid: errors.length === 0,
26
+ errors,
27
+ };
28
+ }
29
+ isValidEmail(email) {
30
+ return EMAIL_REGEX.test(email);
31
+ }
32
+ isStrongPassword(password) {
33
+ if (password.length < MIN_PASSWORD_LENGTH) {
34
+ return false;
35
+ }
36
+ const hasUppercase = /[A-Z]/.test(password);
37
+ const hasLowercase = /[a-z]/.test(password);
38
+ const hasNumber = /\d/.test(password);
39
+ const hasSpecialChar = /[!@#$%^&*(),.?":{}|<>]/.test(password);
40
+ return hasUppercase && hasLowercase && hasNumber && hasSpecialChar;
41
+ }
42
+ }
43
+ exports.InputValidator = InputValidator;
44
+ //# sourceMappingURL=validator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validator.js","sourceRoot":"","sources":["../../src/registration/validator.ts"],"names":[],"mappings":";;;AAEA,MAAM,WAAW,GAAG,4BAA4B,CAAC;AACjD,MAAM,mBAAmB,GAAG,CAAC,CAAC;AAE9B,MAAa,cAAc;IACzB,QAAQ,CAAC,KAAgB;QACvB,MAAM,MAAM,GAAa,EAAE,CAAC;QAE5B,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YACjB,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACnC,CAAC;aAAM,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3C,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACtC,CAAC;aAAM,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YAClD,MAAM,CAAC,IAAI,CACT,6BAA6B,mBAAmB,6EAA6E,CAC9H,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAChB,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAClC,CAAC;QAED,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,MAAM,KAAK,CAAC;YAC5B,MAAM;SACP,CAAC;IACJ,CAAC;IAEO,YAAY,CAAC,KAAa;QAChC,OAAO,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAEO,gBAAgB,CAAC,QAAgB;QACvC,IAAI,QAAQ,CAAC,MAAM,GAAG,mBAAmB,EAAE,CAAC;YAC1C,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,cAAc,GAAG,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE/D,OAAO,YAAY,IAAI,YAAY,IAAI,SAAS,IAAI,cAAc,CAAC;IACrE,CAAC;CACF;AA5CD,wCA4CC"}
@@ -0,0 +1,5 @@
1
+ import { UserInput, ValidationResult } from './types';
2
+ export declare const validateEmail: (email: string) => boolean;
3
+ export declare const validatePassword: (password: string) => string[];
4
+ export declare const validateUserInput: (input: UserInput) => ValidationResult;
5
+ //# sourceMappingURL=validators.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../../src/registration/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAWtD,eAAO,MAAM,aAAa,GAAI,OAAO,MAAM,KAAG,OAE7C,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,UAAU,MAAM,KAAG,MAAM,EAwBzD,CAAC;AAEF,eAAO,MAAM,iBAAiB,GAAI,OAAO,SAAS,KAAG,gBAwBpD,CAAC"}
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateUserInput = exports.validatePassword = exports.validateEmail = void 0;
4
+ const EMAIL_REGEX = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
5
+ const MIN_PASSWORD_LENGTH = 8;
6
+ const PASSWORD_REQUIREMENTS = {
7
+ uppercase: /[A-Z]/,
8
+ lowercase: /[a-z]/,
9
+ number: /[0-9]/,
10
+ special: /[!@#$%^&*(),.?":{}|<>]/,
11
+ };
12
+ const validateEmail = (email) => {
13
+ return EMAIL_REGEX.test(email);
14
+ };
15
+ exports.validateEmail = validateEmail;
16
+ const validatePassword = (password) => {
17
+ const errors = [];
18
+ if (password.length < MIN_PASSWORD_LENGTH) {
19
+ errors.push(`Password must be at least ${MIN_PASSWORD_LENGTH} characters long`);
20
+ }
21
+ if (!PASSWORD_REQUIREMENTS.uppercase.test(password)) {
22
+ errors.push('Password must contain at least one uppercase letter');
23
+ }
24
+ if (!PASSWORD_REQUIREMENTS.lowercase.test(password)) {
25
+ errors.push('Password must contain at least one lowercase letter');
26
+ }
27
+ if (!PASSWORD_REQUIREMENTS.number.test(password)) {
28
+ errors.push('Password must contain at least one number');
29
+ }
30
+ if (!PASSWORD_REQUIREMENTS.special.test(password)) {
31
+ errors.push('Password must contain at least one special character');
32
+ }
33
+ return errors;
34
+ };
35
+ exports.validatePassword = validatePassword;
36
+ const validateUserInput = (input) => {
37
+ const errors = [];
38
+ if (!input.name || input.name.trim().length === 0) {
39
+ errors.push('Name is required');
40
+ }
41
+ if (!input.email || input.email.trim().length === 0) {
42
+ errors.push('Email is required');
43
+ }
44
+ else if (!(0, exports.validateEmail)(input.email)) {
45
+ errors.push('Email format is invalid');
46
+ }
47
+ if (!input.password || input.password.length === 0) {
48
+ errors.push('Password is required');
49
+ }
50
+ else {
51
+ const passwordErrors = (0, exports.validatePassword)(input.password);
52
+ errors.push(...passwordErrors);
53
+ }
54
+ return {
55
+ isValid: errors.length === 0,
56
+ errors,
57
+ };
58
+ };
59
+ exports.validateUserInput = validateUserInput;
60
+ //# sourceMappingURL=validators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/registration/validators.ts"],"names":[],"mappings":";;;AAEA,MAAM,WAAW,GAAG,4BAA4B,CAAC;AACjD,MAAM,mBAAmB,GAAG,CAAC,CAAC;AAC9B,MAAM,qBAAqB,GAAG;IAC5B,SAAS,EAAE,OAAO;IAClB,SAAS,EAAE,OAAO;IAClB,MAAM,EAAE,OAAO;IACf,OAAO,EAAE,wBAAwB;CAClC,CAAC;AAEK,MAAM,aAAa,GAAG,CAAC,KAAa,EAAW,EAAE;IACtD,OAAO,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACjC,CAAC,CAAC;AAFW,QAAA,aAAa,iBAExB;AAEK,MAAM,gBAAgB,GAAG,CAAC,QAAgB,EAAY,EAAE;IAC7D,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,IAAI,QAAQ,CAAC,MAAM,GAAG,mBAAmB,EAAE,CAAC;QAC1C,MAAM,CAAC,IAAI,CAAC,6BAA6B,mBAAmB,kBAAkB,CAAC,CAAC;IAClF,CAAC;IAED,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACpD,MAAM,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;IACrE,CAAC;IAED,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACpD,MAAM,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;IACrE,CAAC;IAED,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjD,MAAM,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;IAC3D,CAAC;IAED,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,sDAAsD,CAAC,CAAC;IACtE,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAxBW,QAAA,gBAAgB,oBAwB3B;AAEK,MAAM,iBAAiB,GAAG,CAAC,KAAgB,EAAoB,EAAE;IACtE,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACnC,CAAC;SAAM,IAAI,CAAC,IAAA,qBAAa,EAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnD,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,MAAM,cAAc,GAAG,IAAA,wBAAgB,EAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACxD,MAAM,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;IACjC,CAAC;IAED,OAAO;QACL,OAAO,EAAE,MAAM,CAAC,MAAM,KAAK,CAAC;QAC5B,MAAM;KACP,CAAC;AACJ,CAAC,CAAC;AAxBW,QAAA,iBAAiB,qBAwB5B"}
@@ -1 +1 @@
1
- {"version":3,"file":"reporter.d.ts","sourceRoot":"","sources":["../src/reporter.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,EAEjB,MAAM,SAAS,CAAC;AAEjB,MAAM,MAAM,cAAc,GACtB,SAAS,GACT,YAAY,GACZ,YAAY,GACZ,UAAU,CAAC;AAEf,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAY/D,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,SAAS,CAAyC;IAC1D,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,eAAe,CAAC,CAAiC;IACzD,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,YAAY,CAAU;IAC9B,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,OAAO,CAAS;gBAEZ,OAAO,GAAE;QACnB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,YAAY,CAAC,EAAE,OAAO,CAAC;QACvB,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;KACb;IAQN,KAAK,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,IAAI;IAsBtC,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAoBzC,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAa9C,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAwBrF,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAQ1B,MAAM,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI;IAUtC,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,WAAW;IAOnB,OAAO,CAAC,MAAM;IAgBd,OAAO,CAAC,kBAAkB;IAkC1B,OAAO,CAAC,mBAAmB;IAuB3B,OAAO,CAAC,eAAe;IAevB,OAAO,CAAC,kBAAkB;IAW1B,OAAO,CAAC,YAAY;IAkCpB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,wBAAwB;IAoChC,OAAO,CAAC,kBAAkB;CAI3B"}
1
+ {"version":3,"file":"reporter.d.ts","sourceRoot":"","sources":["../src/reporter.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,EAEjB,MAAM,SAAS,CAAC;AAEjB,MAAM,MAAM,cAAc,GACtB,SAAS,GACT,YAAY,GACZ,YAAY,GACZ,UAAU,CAAC;AAEf,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAa/D,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,SAAS,CAAyC;IAC1D,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,eAAe,CAAC,CAAiC;IACzD,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,YAAY,CAAU;IAC9B,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,OAAO,CAAS;gBAGtB,OAAO,GAAE;QACP,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,YAAY,CAAC,EAAE,OAAO,CAAC;QACvB,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;KACb;IASR,KAAK,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,IAAI;IAsBtC,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAoBzC,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAa9C,kBAAkB,CAChB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,gBAAgB,EACxB,KAAK,EAAE,MAAM,GACZ,IAAI;IAkBP,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAQ1B,MAAM,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI;IAUtC,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,WAAW;IAOnB,OAAO,CAAC,MAAM;IAgBd,OAAO,CAAC,kBAAkB;IA4D1B,OAAO,CAAC,mBAAmB;IAwB3B,OAAO,CAAC,eAAe;IAevB,OAAO,CAAC,kBAAkB;IAW1B,OAAO,CAAC,YAAY;IA+BpB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,wBAAwB;IAuDhC,OAAO,CAAC,kBAAkB;CAI3B"}