@veloxts/cli 0.4.2 → 0.4.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 (67) hide show
  1. package/dist/cli.js +4 -0
  2. package/dist/cli.js.map +1 -1
  3. package/dist/commands/db.d.ts +12 -0
  4. package/dist/commands/db.d.ts.map +1 -0
  5. package/dist/commands/db.js +18 -0
  6. package/dist/commands/db.js.map +1 -0
  7. package/dist/commands/procedures.d.ts +12 -0
  8. package/dist/commands/procedures.d.ts.map +1 -0
  9. package/dist/commands/procedures.js +153 -0
  10. package/dist/commands/procedures.js.map +1 -0
  11. package/dist/generators/generators/factory.d.ts +36 -0
  12. package/dist/generators/generators/factory.d.ts.map +1 -0
  13. package/dist/generators/generators/factory.js +85 -0
  14. package/dist/generators/generators/factory.js.map +1 -0
  15. package/dist/generators/generators/index.d.ts +2 -0
  16. package/dist/generators/generators/index.d.ts.map +1 -1
  17. package/dist/generators/generators/index.js +8 -0
  18. package/dist/generators/generators/index.js.map +1 -1
  19. package/dist/generators/generators/seeder.d.ts +36 -0
  20. package/dist/generators/generators/seeder.d.ts.map +1 -0
  21. package/dist/generators/generators/seeder.js +99 -0
  22. package/dist/generators/generators/seeder.js.map +1 -0
  23. package/dist/generators/templates/factory.d.ts +26 -0
  24. package/dist/generators/templates/factory.d.ts.map +1 -0
  25. package/dist/generators/templates/factory.js +125 -0
  26. package/dist/generators/templates/factory.js.map +1 -0
  27. package/dist/generators/templates/seeder.d.ts +34 -0
  28. package/dist/generators/templates/seeder.d.ts.map +1 -0
  29. package/dist/generators/templates/seeder.js +129 -0
  30. package/dist/generators/templates/seeder.js.map +1 -0
  31. package/dist/index.d.ts +5 -0
  32. package/dist/index.d.ts.map +1 -1
  33. package/dist/index.js +5 -0
  34. package/dist/index.js.map +1 -1
  35. package/dist/seeding/commands/seed.d.ts +11 -0
  36. package/dist/seeding/commands/seed.d.ts.map +1 -0
  37. package/dist/seeding/commands/seed.js +268 -0
  38. package/dist/seeding/commands/seed.js.map +1 -0
  39. package/dist/seeding/errors.d.ts +119 -0
  40. package/dist/seeding/errors.d.ts.map +1 -0
  41. package/dist/seeding/errors.js +191 -0
  42. package/dist/seeding/errors.js.map +1 -0
  43. package/dist/seeding/factory.d.ts +162 -0
  44. package/dist/seeding/factory.d.ts.map +1 -0
  45. package/dist/seeding/factory.js +250 -0
  46. package/dist/seeding/factory.js.map +1 -0
  47. package/dist/seeding/index.d.ts +31 -0
  48. package/dist/seeding/index.d.ts.map +1 -0
  49. package/dist/seeding/index.js +41 -0
  50. package/dist/seeding/index.js.map +1 -0
  51. package/dist/seeding/loader.d.ts +41 -0
  52. package/dist/seeding/loader.d.ts.map +1 -0
  53. package/dist/seeding/loader.js +210 -0
  54. package/dist/seeding/loader.js.map +1 -0
  55. package/dist/seeding/registry.d.ts +116 -0
  56. package/dist/seeding/registry.d.ts.map +1 -0
  57. package/dist/seeding/registry.js +298 -0
  58. package/dist/seeding/registry.js.map +1 -0
  59. package/dist/seeding/runner.d.ts +88 -0
  60. package/dist/seeding/runner.d.ts.map +1 -0
  61. package/dist/seeding/runner.js +254 -0
  62. package/dist/seeding/runner.js.map +1 -0
  63. package/dist/seeding/types.d.ts +247 -0
  64. package/dist/seeding/types.d.ts.map +1 -0
  65. package/dist/seeding/types.js +7 -0
  66. package/dist/seeding/types.js.map +1 -0
  67. package/package.json +6 -6
@@ -0,0 +1,119 @@
1
+ /**
2
+ * Seeding Errors
3
+ *
4
+ * Structured error classes for the VeloxTS database seeding system.
5
+ */
6
+ /**
7
+ * Error codes for seeding errors (for AI/tooling integration)
8
+ */
9
+ export declare enum SeederErrorCode {
10
+ /** Seeder not found in registry */
11
+ SEEDER_NOT_FOUND = "E3001",
12
+ /** Circular dependency detected between seeders */
13
+ CIRCULAR_DEPENDENCY = "E3002",
14
+ /** Seeder execution failed */
15
+ EXECUTION_FAILED = "E3003",
16
+ /** Truncation failed */
17
+ TRUNCATION_FAILED = "E3004",
18
+ /** Invalid seeder configuration */
19
+ INVALID_CONFIG = "E3005",
20
+ /** Seeder dependency not found */
21
+ DEPENDENCY_NOT_FOUND = "E3006",
22
+ /** No seeders found in project */
23
+ NO_SEEDERS_FOUND = "E3007",
24
+ /** Database connection failed */
25
+ DATABASE_ERROR = "E3008",
26
+ /** Factory not found in registry */
27
+ FACTORY_NOT_FOUND = "E3010",
28
+ /** Factory state not found */
29
+ STATE_NOT_FOUND = "E3011",
30
+ /** Factory creation failed */
31
+ FACTORY_CREATE_FAILED = "E3012",
32
+ /** Invalid factory configuration */
33
+ INVALID_FACTORY = "E3013",
34
+ /** File system error during seeder loading */
35
+ FILESYSTEM_ERROR = "E3020",
36
+ /** Invalid seeder export */
37
+ INVALID_EXPORT = "E3021"
38
+ }
39
+ /**
40
+ * Structured error for seeding operations
41
+ */
42
+ export declare class SeederError extends Error {
43
+ readonly code: SeederErrorCode;
44
+ readonly fix?: string | undefined;
45
+ constructor(code: SeederErrorCode, message: string, fix?: string | undefined);
46
+ /**
47
+ * Format error for display
48
+ */
49
+ format(): string;
50
+ /**
51
+ * Convert to JSON for --json output
52
+ */
53
+ toJSON(): Record<string, unknown>;
54
+ }
55
+ /**
56
+ * Structured error for factory operations
57
+ */
58
+ export declare class FactoryError extends Error {
59
+ readonly code: SeederErrorCode;
60
+ readonly fix?: string | undefined;
61
+ constructor(code: SeederErrorCode, message: string, fix?: string | undefined);
62
+ /**
63
+ * Format error for display
64
+ */
65
+ format(): string;
66
+ /**
67
+ * Convert to JSON for --json output
68
+ */
69
+ toJSON(): Record<string, unknown>;
70
+ }
71
+ /**
72
+ * Create error for seeder not found
73
+ */
74
+ export declare function seederNotFound(name: string): SeederError;
75
+ /**
76
+ * Create error for circular dependency
77
+ */
78
+ export declare function circularDependency(cycle: string[]): SeederError;
79
+ /**
80
+ * Create error for seeder execution failure
81
+ */
82
+ export declare function executionFailed(name: string, cause: Error): SeederError;
83
+ /**
84
+ * Create error for truncation failure
85
+ */
86
+ export declare function truncationFailed(name: string, cause: Error): SeederError;
87
+ /**
88
+ * Create error for dependency not found
89
+ */
90
+ export declare function dependencyNotFound(seederName: string, dependencyName: string): SeederError;
91
+ /**
92
+ * Create error for no seeders found
93
+ */
94
+ export declare function noSeedersFound(path: string): SeederError;
95
+ /**
96
+ * Create error for database connection issue
97
+ */
98
+ export declare function seederDatabaseError(operation: string, cause: Error): SeederError;
99
+ /**
100
+ * Create error for factory not found
101
+ */
102
+ export declare function factoryNotFound(name: string): FactoryError;
103
+ /**
104
+ * Create error for state not found
105
+ */
106
+ export declare function stateNotFound(factoryName: string, stateName: string, available: string[]): FactoryError;
107
+ /**
108
+ * Create error for factory creation failure
109
+ */
110
+ export declare function factoryCreateFailed(modelName: string, cause: Error): FactoryError;
111
+ /**
112
+ * Create error for invalid seeder export
113
+ */
114
+ export declare function invalidExport(filePath: string, reason: string): SeederError;
115
+ /**
116
+ * Create error for filesystem issue
117
+ */
118
+ export declare function filesystemError(operation: string, path: string, cause: Error): SeederError;
119
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/seeding/errors.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAMH;;GAEG;AACH,oBAAY,eAAe;IACzB,mCAAmC;IACnC,gBAAgB,UAAU;IAE1B,mDAAmD;IACnD,mBAAmB,UAAU;IAE7B,8BAA8B;IAC9B,gBAAgB,UAAU;IAE1B,wBAAwB;IACxB,iBAAiB,UAAU;IAE3B,mCAAmC;IACnC,cAAc,UAAU;IAExB,kCAAkC;IAClC,oBAAoB,UAAU;IAE9B,kCAAkC;IAClC,gBAAgB,UAAU;IAE1B,iCAAiC;IACjC,cAAc,UAAU;IAExB,oCAAoC;IACpC,iBAAiB,UAAU;IAE3B,8BAA8B;IAC9B,eAAe,UAAU;IAEzB,8BAA8B;IAC9B,qBAAqB,UAAU;IAE/B,oCAAoC;IACpC,eAAe,UAAU;IAEzB,8CAA8C;IAC9C,gBAAgB,UAAU;IAE1B,4BAA4B;IAC5B,cAAc,UAAU;CACzB;AAMD;;GAEG;AACH,qBAAa,WAAY,SAAQ,KAAK;aAElB,IAAI,EAAE,eAAe;aAErB,GAAG,CAAC,EAAE,MAAM;gBAFZ,IAAI,EAAE,eAAe,EACrC,OAAO,EAAE,MAAM,EACC,GAAG,CAAC,EAAE,MAAM,YAAA;IAM9B;;OAEG;IACH,MAAM,IAAI,MAAM;IAQhB;;OAEG;IACH,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOlC;AAMD;;GAEG;AACH,qBAAa,YAAa,SAAQ,KAAK;aAEnB,IAAI,EAAE,eAAe;aAErB,GAAG,CAAC,EAAE,MAAM;gBAFZ,IAAI,EAAE,eAAe,EACrC,OAAO,EAAE,MAAM,EACC,GAAG,CAAC,EAAE,MAAM,YAAA;IAM9B;;OAEG;IACH,MAAM,IAAI,MAAM;IAQhB;;OAEG;IACH,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOlC;AAMD;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,CAMxD;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,WAAW,CAM/D;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,WAAW,CAMvE;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,WAAW,CAMxE;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,WAAW,CAM1F;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,CAMxD;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,WAAW,CAMhF;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,CAM1D;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EAAE,GAClB,YAAY,CAOd;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,YAAY,CAMjF;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,WAAW,CAM3E;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,WAAW,CAM1F"}
@@ -0,0 +1,191 @@
1
+ /**
2
+ * Seeding Errors
3
+ *
4
+ * Structured error classes for the VeloxTS database seeding system.
5
+ */
6
+ // ============================================================================
7
+ // Error Codes
8
+ // ============================================================================
9
+ /**
10
+ * Error codes for seeding errors (for AI/tooling integration)
11
+ */
12
+ export var SeederErrorCode;
13
+ (function (SeederErrorCode) {
14
+ /** Seeder not found in registry */
15
+ SeederErrorCode["SEEDER_NOT_FOUND"] = "E3001";
16
+ /** Circular dependency detected between seeders */
17
+ SeederErrorCode["CIRCULAR_DEPENDENCY"] = "E3002";
18
+ /** Seeder execution failed */
19
+ SeederErrorCode["EXECUTION_FAILED"] = "E3003";
20
+ /** Truncation failed */
21
+ SeederErrorCode["TRUNCATION_FAILED"] = "E3004";
22
+ /** Invalid seeder configuration */
23
+ SeederErrorCode["INVALID_CONFIG"] = "E3005";
24
+ /** Seeder dependency not found */
25
+ SeederErrorCode["DEPENDENCY_NOT_FOUND"] = "E3006";
26
+ /** No seeders found in project */
27
+ SeederErrorCode["NO_SEEDERS_FOUND"] = "E3007";
28
+ /** Database connection failed */
29
+ SeederErrorCode["DATABASE_ERROR"] = "E3008";
30
+ /** Factory not found in registry */
31
+ SeederErrorCode["FACTORY_NOT_FOUND"] = "E3010";
32
+ /** Factory state not found */
33
+ SeederErrorCode["STATE_NOT_FOUND"] = "E3011";
34
+ /** Factory creation failed */
35
+ SeederErrorCode["FACTORY_CREATE_FAILED"] = "E3012";
36
+ /** Invalid factory configuration */
37
+ SeederErrorCode["INVALID_FACTORY"] = "E3013";
38
+ /** File system error during seeder loading */
39
+ SeederErrorCode["FILESYSTEM_ERROR"] = "E3020";
40
+ /** Invalid seeder export */
41
+ SeederErrorCode["INVALID_EXPORT"] = "E3021";
42
+ })(SeederErrorCode || (SeederErrorCode = {}));
43
+ // ============================================================================
44
+ // Seeder Error
45
+ // ============================================================================
46
+ /**
47
+ * Structured error for seeding operations
48
+ */
49
+ export class SeederError extends Error {
50
+ code;
51
+ fix;
52
+ constructor(code, message, fix) {
53
+ super(message);
54
+ this.code = code;
55
+ this.fix = fix;
56
+ this.name = 'SeederError';
57
+ }
58
+ /**
59
+ * Format error for display
60
+ */
61
+ format() {
62
+ let output = `SeederError[${this.code}]: ${this.message}`;
63
+ if (this.fix) {
64
+ output += `\n\n Fix: ${this.fix}`;
65
+ }
66
+ return output;
67
+ }
68
+ /**
69
+ * Convert to JSON for --json output
70
+ */
71
+ toJSON() {
72
+ return {
73
+ code: this.code,
74
+ message: this.message,
75
+ fix: this.fix,
76
+ };
77
+ }
78
+ }
79
+ // ============================================================================
80
+ // Factory Error
81
+ // ============================================================================
82
+ /**
83
+ * Structured error for factory operations
84
+ */
85
+ export class FactoryError extends Error {
86
+ code;
87
+ fix;
88
+ constructor(code, message, fix) {
89
+ super(message);
90
+ this.code = code;
91
+ this.fix = fix;
92
+ this.name = 'FactoryError';
93
+ }
94
+ /**
95
+ * Format error for display
96
+ */
97
+ format() {
98
+ let output = `FactoryError[${this.code}]: ${this.message}`;
99
+ if (this.fix) {
100
+ output += `\n\n Fix: ${this.fix}`;
101
+ }
102
+ return output;
103
+ }
104
+ /**
105
+ * Convert to JSON for --json output
106
+ */
107
+ toJSON() {
108
+ return {
109
+ code: this.code,
110
+ message: this.message,
111
+ fix: this.fix,
112
+ };
113
+ }
114
+ }
115
+ // ============================================================================
116
+ // Error Factory Functions
117
+ // ============================================================================
118
+ /**
119
+ * Create error for seeder not found
120
+ */
121
+ export function seederNotFound(name) {
122
+ return new SeederError(SeederErrorCode.SEEDER_NOT_FOUND, `Seeder '${name}' not found.`, `Check that the seeder exists in src/database/seeders/ and is properly exported.`);
123
+ }
124
+ /**
125
+ * Create error for circular dependency
126
+ */
127
+ export function circularDependency(cycle) {
128
+ return new SeederError(SeederErrorCode.CIRCULAR_DEPENDENCY, `Circular dependency detected: ${cycle.join(' -> ')}`, `Review seeder dependencies and remove the circular reference.`);
129
+ }
130
+ /**
131
+ * Create error for seeder execution failure
132
+ */
133
+ export function executionFailed(name, cause) {
134
+ return new SeederError(SeederErrorCode.EXECUTION_FAILED, `Seeder '${name}' failed: ${cause.message}`, `Check the seeder implementation and database state.`);
135
+ }
136
+ /**
137
+ * Create error for truncation failure
138
+ */
139
+ export function truncationFailed(name, cause) {
140
+ return new SeederError(SeederErrorCode.TRUNCATION_FAILED, `Truncation failed for seeder '${name}': ${cause.message}`, `Check for foreign key constraints that may prevent truncation.`);
141
+ }
142
+ /**
143
+ * Create error for dependency not found
144
+ */
145
+ export function dependencyNotFound(seederName, dependencyName) {
146
+ return new SeederError(SeederErrorCode.DEPENDENCY_NOT_FOUND, `Seeder '${seederName}' depends on '${dependencyName}' which was not found.`, `Ensure '${dependencyName}' exists in src/database/seeders/ and is registered.`);
147
+ }
148
+ /**
149
+ * Create error for no seeders found
150
+ */
151
+ export function noSeedersFound(path) {
152
+ return new SeederError(SeederErrorCode.NO_SEEDERS_FOUND, `No seeders found in ${path}`, `Create a seeder with: velox generate seeder <name>`);
153
+ }
154
+ /**
155
+ * Create error for database connection issue
156
+ */
157
+ export function seederDatabaseError(operation, cause) {
158
+ return new SeederError(SeederErrorCode.DATABASE_ERROR, `Database error during ${operation}: ${cause.message}`, `Check your database connection and ensure it's running.`);
159
+ }
160
+ /**
161
+ * Create error for factory not found
162
+ */
163
+ export function factoryNotFound(name) {
164
+ return new FactoryError(SeederErrorCode.FACTORY_NOT_FOUND, `Factory '${name}' not found in registry.`, `Ensure the factory is properly instantiated before use.`);
165
+ }
166
+ /**
167
+ * Create error for state not found
168
+ */
169
+ export function stateNotFound(factoryName, stateName, available) {
170
+ const availableStr = available.length > 0 ? available.join(', ') : 'none';
171
+ return new FactoryError(SeederErrorCode.STATE_NOT_FOUND, `State '${stateName}' not found on factory '${factoryName}'.`, `Available states: ${availableStr}. Register states using registerState().`);
172
+ }
173
+ /**
174
+ * Create error for factory creation failure
175
+ */
176
+ export function factoryCreateFailed(modelName, cause) {
177
+ return new FactoryError(SeederErrorCode.FACTORY_CREATE_FAILED, `Failed to create '${modelName}': ${cause.message}`, `Check the factory definition and ensure all required fields are provided.`);
178
+ }
179
+ /**
180
+ * Create error for invalid seeder export
181
+ */
182
+ export function invalidExport(filePath, reason) {
183
+ return new SeederError(SeederErrorCode.INVALID_EXPORT, `Invalid seeder export in '${filePath}': ${reason}`, `Ensure the file exports a valid Seeder object with 'name' and 'run' properties.`);
184
+ }
185
+ /**
186
+ * Create error for filesystem issue
187
+ */
188
+ export function filesystemError(operation, path, cause) {
189
+ return new SeederError(SeederErrorCode.FILESYSTEM_ERROR, `Filesystem error during ${operation} at '${path}': ${cause.message}`, `Check file permissions and path validity.`);
190
+ }
191
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/seeding/errors.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAN,IAAY,eA0CX;AA1CD,WAAY,eAAe;IACzB,mCAAmC;IACnC,6CAA0B,CAAA;IAE1B,mDAAmD;IACnD,gDAA6B,CAAA;IAE7B,8BAA8B;IAC9B,6CAA0B,CAAA;IAE1B,wBAAwB;IACxB,8CAA2B,CAAA;IAE3B,mCAAmC;IACnC,2CAAwB,CAAA;IAExB,kCAAkC;IAClC,iDAA8B,CAAA;IAE9B,kCAAkC;IAClC,6CAA0B,CAAA;IAE1B,iCAAiC;IACjC,2CAAwB,CAAA;IAExB,oCAAoC;IACpC,8CAA2B,CAAA;IAE3B,8BAA8B;IAC9B,4CAAyB,CAAA;IAEzB,8BAA8B;IAC9B,kDAA+B,CAAA;IAE/B,oCAAoC;IACpC,4CAAyB,CAAA;IAEzB,8CAA8C;IAC9C,6CAA0B,CAAA;IAE1B,4BAA4B;IAC5B,2CAAwB,CAAA;AAC1B,CAAC,EA1CW,eAAe,KAAf,eAAe,QA0C1B;AAED,+EAA+E;AAC/E,eAAe;AACf,+EAA+E;AAE/E;;GAEG;AACH,MAAM,OAAO,WAAY,SAAQ,KAAK;IAElB;IAEA;IAHlB,YACkB,IAAqB,EACrC,OAAe,EACC,GAAY;QAE5B,KAAK,CAAC,OAAO,CAAC,CAAC;QAJC,SAAI,GAAJ,IAAI,CAAiB;QAErB,QAAG,GAAH,GAAG,CAAS;QAG5B,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,IAAI,MAAM,GAAG,eAAe,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;QAC1D,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;YACb,MAAM,IAAI,cAAc,IAAI,CAAC,GAAG,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;CACF;AAED,+EAA+E;AAC/E,gBAAgB;AAChB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,OAAO,YAAa,SAAQ,KAAK;IAEnB;IAEA;IAHlB,YACkB,IAAqB,EACrC,OAAe,EACC,GAAY;QAE5B,KAAK,CAAC,OAAO,CAAC,CAAC;QAJC,SAAI,GAAJ,IAAI,CAAiB;QAErB,QAAG,GAAH,GAAG,CAAS;QAG5B,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,IAAI,MAAM,GAAG,gBAAgB,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;QAC3D,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;YACb,MAAM,IAAI,cAAc,IAAI,CAAC,GAAG,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;CACF;AAED,+EAA+E;AAC/E,0BAA0B;AAC1B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,IAAY;IACzC,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,gBAAgB,EAChC,WAAW,IAAI,cAAc,EAC7B,iFAAiF,CAClF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,KAAe;IAChD,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,mBAAmB,EACnC,iCAAiC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EACrD,+DAA+D,CAChE,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,IAAY,EAAE,KAAY;IACxD,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,gBAAgB,EAChC,WAAW,IAAI,aAAa,KAAK,CAAC,OAAO,EAAE,EAC3C,qDAAqD,CACtD,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,IAAY,EAAE,KAAY;IACzD,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,iBAAiB,EACjC,iCAAiC,IAAI,MAAM,KAAK,CAAC,OAAO,EAAE,EAC1D,gEAAgE,CACjE,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,UAAkB,EAAE,cAAsB;IAC3E,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,oBAAoB,EACpC,WAAW,UAAU,iBAAiB,cAAc,wBAAwB,EAC5E,WAAW,cAAc,sDAAsD,CAChF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,IAAY;IACzC,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,gBAAgB,EAChC,uBAAuB,IAAI,EAAE,EAC7B,oDAAoD,CACrD,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,KAAY;IACjE,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,cAAc,EAC9B,yBAAyB,SAAS,KAAK,KAAK,CAAC,OAAO,EAAE,EACtD,yDAAyD,CAC1D,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,IAAY;IAC1C,OAAO,IAAI,YAAY,CACrB,eAAe,CAAC,iBAAiB,EACjC,YAAY,IAAI,0BAA0B,EAC1C,yDAAyD,CAC1D,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAC3B,WAAmB,EACnB,SAAiB,EACjB,SAAmB;IAEnB,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAC1E,OAAO,IAAI,YAAY,CACrB,eAAe,CAAC,eAAe,EAC/B,UAAU,SAAS,2BAA2B,WAAW,IAAI,EAC7D,qBAAqB,YAAY,0CAA0C,CAC5E,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,KAAY;IACjE,OAAO,IAAI,YAAY,CACrB,eAAe,CAAC,qBAAqB,EACrC,qBAAqB,SAAS,MAAM,KAAK,CAAC,OAAO,EAAE,EACnD,2EAA2E,CAC5E,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,QAAgB,EAAE,MAAc;IAC5D,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,cAAc,EAC9B,6BAA6B,QAAQ,MAAM,MAAM,EAAE,EACnD,iFAAiF,CAClF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,SAAiB,EAAE,IAAY,EAAE,KAAY;IAC3E,OAAO,IAAI,WAAW,CACpB,eAAe,CAAC,gBAAgB,EAChC,2BAA2B,SAAS,QAAQ,IAAI,MAAM,KAAK,CAAC,OAAO,EAAE,EACrE,2CAA2C,CAC5C,CAAC;AACJ,CAAC"}
@@ -0,0 +1,162 @@
1
+ /**
2
+ * Factory System
3
+ *
4
+ * Base factory class and registry for generating fake data.
5
+ */
6
+ import type { Factory, FactoryRegistry, PrismaClientLike, StateModifier } from './types.js';
7
+ /**
8
+ * Abstract base class for model factories.
9
+ *
10
+ * Provides a fluent API for creating model instances with fake data
11
+ * and named state variations.
12
+ *
13
+ * @template TInput - The input type for creating records
14
+ * @template TOutput - The output type returned from database (defaults to TInput)
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * import { BaseFactory } from '@veloxts/cli';
19
+ * import { faker } from '@faker-js/faker';
20
+ *
21
+ * interface UserInput {
22
+ * email: string;
23
+ * name: string;
24
+ * role: 'admin' | 'user';
25
+ * }
26
+ *
27
+ * export class UserFactory extends BaseFactory<UserInput> {
28
+ * modelName = 'user';
29
+ *
30
+ * definition(): UserInput {
31
+ * return {
32
+ * email: faker.internet.email(),
33
+ * name: faker.person.fullName(),
34
+ * role: 'user',
35
+ * };
36
+ * }
37
+ *
38
+ * admin(): this {
39
+ * return this.state('admin');
40
+ * }
41
+ *
42
+ * constructor(prisma: PrismaClientLike) {
43
+ * super(prisma);
44
+ * this.registerState('admin', (attrs) => ({ ...attrs, role: 'admin' }));
45
+ * }
46
+ * }
47
+ * ```
48
+ */
49
+ export declare abstract class BaseFactory<TInput extends Record<string, unknown>, TOutput = TInput> implements Factory<TInput, TOutput> {
50
+ /** Map of registered state modifiers */
51
+ protected states: Map<string, StateModifier<TInput>>;
52
+ /** Currently active state names */
53
+ protected activeStates: string[];
54
+ /** Prisma client for database operations */
55
+ protected readonly prisma: PrismaClientLike;
56
+ /**
57
+ * Model name for Prisma operations (e.g., 'user', 'post').
58
+ * Must match the lowercase model name in your Prisma schema.
59
+ */
60
+ abstract readonly modelName: string;
61
+ /**
62
+ * Define default attributes for new instances.
63
+ * Override this method to provide fake data generation.
64
+ */
65
+ abstract definition(): TInput;
66
+ constructor(prisma: PrismaClientLike);
67
+ /**
68
+ * Register a named state modifier.
69
+ *
70
+ * @param name - State name (e.g., 'admin', 'verified')
71
+ * @param modifier - Function that modifies attributes
72
+ * @returns this for chaining during construction
73
+ *
74
+ * @example
75
+ * ```typescript
76
+ * constructor(prisma: PrismaClientLike) {
77
+ * super(prisma);
78
+ * this.registerState('admin', (attrs) => ({ ...attrs, role: 'admin' }));
79
+ * this.registerState('unverified', (attrs) => ({ ...attrs, emailVerified: null }));
80
+ * }
81
+ * ```
82
+ */
83
+ protected registerState(name: string, modifier: StateModifier<TInput>): this;
84
+ /**
85
+ * Apply a named state modifier.
86
+ * Returns a new factory instance with the state applied.
87
+ *
88
+ * @param name - State name to apply
89
+ * @returns New factory instance with state active (preserves subclass type)
90
+ *
91
+ * @example
92
+ * ```typescript
93
+ * // Create an admin user
94
+ * await factory.get(UserFactory).state('admin').create();
95
+ *
96
+ * // Chain multiple states
97
+ * await factory.get(UserFactory).state('admin').state('verified').create();
98
+ *
99
+ * // Subclass methods preserved after state()
100
+ * const factory = new UserFactory(prisma);
101
+ * await factory.state('verified').admin().create(); // admin() still accessible
102
+ * ```
103
+ */
104
+ state(name: string): this;
105
+ /**
106
+ * Get list of available state names.
107
+ */
108
+ getAvailableStates(): ReadonlyArray<string>;
109
+ /**
110
+ * Make a single instance without persisting to database.
111
+ *
112
+ * @param overrides - Attributes to override defaults
113
+ * @returns Generated attributes
114
+ */
115
+ make(overrides?: Partial<TInput>): TInput;
116
+ /**
117
+ * Make multiple instances without persisting to database.
118
+ *
119
+ * @param count - Number of instances to make
120
+ * @param overrides - Attributes to override defaults for all instances
121
+ * @returns Array of generated attributes
122
+ */
123
+ makeMany(count: number, overrides?: Partial<TInput>): TInput[];
124
+ /**
125
+ * Create a single instance in the database.
126
+ *
127
+ * @param overrides - Attributes to override defaults
128
+ * @returns Created database record
129
+ */
130
+ create(overrides?: Partial<TInput>): Promise<TOutput>;
131
+ /**
132
+ * Create multiple instances in the database.
133
+ *
134
+ * @param count - Number of instances to create
135
+ * @param overrides - Attributes to override defaults for all instances
136
+ * @returns Array of created database records
137
+ */
138
+ createMany(count: number, overrides?: Partial<TInput>): Promise<TOutput[]>;
139
+ /**
140
+ * Build attributes by applying definition, states, and overrides.
141
+ */
142
+ private buildAttributes;
143
+ }
144
+ /**
145
+ * Create a factory registry for managing factory instances.
146
+ *
147
+ * The registry caches factory instances and provides type-safe access.
148
+ *
149
+ * @param prisma - Prisma client to inject into factories
150
+ * @returns Factory registry instance
151
+ *
152
+ * @example
153
+ * ```typescript
154
+ * const registry = createFactoryRegistry(prisma);
155
+ *
156
+ * // Get or create factory instance
157
+ * const userFactory = registry.get(UserFactory);
158
+ * await userFactory.create();
159
+ * ```
160
+ */
161
+ export declare function createFactoryRegistry(prisma: PrismaClientLike): FactoryRegistry;
162
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/seeding/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,EACV,OAAO,EAEP,eAAe,EACf,gBAAgB,EAChB,aAAa,EACd,MAAM,YAAY,CAAC;AA2BpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,8BAAsB,WAAW,CAAC,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,MAAM,CACxF,YAAW,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC;IAEnC,wCAAwC;IACxC,SAAS,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC,CAAa;IAEjE,mCAAmC;IACnC,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAM;IAEtC,4CAA4C;IAC5C,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,CAAC;IAE5C;;;OAGG;IACH,QAAQ,CAAC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAEpC;;;OAGG;IACH,QAAQ,CAAC,UAAU,IAAI,MAAM;gBAEjB,MAAM,EAAE,gBAAgB;IAQpC;;;;;;;;;;;;;;;OAeG;IACH,SAAS,CAAC,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,CAAC,MAAM,CAAC,GAAG,IAAI;IAK5E;;;;;;;;;;;;;;;;;;;OAmBG;IACH,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAazB;;OAEG;IACH,kBAAkB,IAAI,aAAa,CAAC,MAAM,CAAC;IAQ3C;;;;;OAKG;IACH,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM;IAIzC;;;;;;OAMG;IACH,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE;IAQ9D;;;;;OAKG;IACG,MAAM,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAoB3D;;;;;;OAMG;IACG,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAiBhF;;OAEG;IACH,OAAO,CAAC,eAAe;CAmBxB;AAMD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,GAAG,eAAe,CAyB/E"}