@veloxts/cli 0.4.2 → 0.4.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +4 -0
- package/dist/cli.js.map +1 -1
- package/dist/commands/db.d.ts +12 -0
- package/dist/commands/db.d.ts.map +1 -0
- package/dist/commands/db.js +18 -0
- package/dist/commands/db.js.map +1 -0
- package/dist/commands/dev.d.ts.map +1 -1
- package/dist/commands/dev.js +29 -3
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/procedures.d.ts +12 -0
- package/dist/commands/procedures.d.ts.map +1 -0
- package/dist/commands/procedures.js +153 -0
- package/dist/commands/procedures.js.map +1 -0
- package/dist/dev/hmr-runner.d.ts +52 -0
- package/dist/dev/hmr-runner.d.ts.map +1 -0
- package/dist/dev/hmr-runner.js +153 -0
- package/dist/dev/hmr-runner.js.map +1 -0
- package/dist/dev/index.d.ts +6 -0
- package/dist/dev/index.d.ts.map +1 -0
- package/dist/dev/index.js +6 -0
- package/dist/dev/index.js.map +1 -0
- package/dist/dev/watch-config.d.ts +32 -0
- package/dist/dev/watch-config.d.ts.map +1 -0
- package/dist/dev/watch-config.js +74 -0
- package/dist/dev/watch-config.js.map +1 -0
- package/dist/generators/generators/factory.d.ts +36 -0
- package/dist/generators/generators/factory.d.ts.map +1 -0
- package/dist/generators/generators/factory.js +85 -0
- package/dist/generators/generators/factory.js.map +1 -0
- package/dist/generators/generators/index.d.ts +2 -0
- package/dist/generators/generators/index.d.ts.map +1 -1
- package/dist/generators/generators/index.js +8 -0
- package/dist/generators/generators/index.js.map +1 -1
- package/dist/generators/generators/seeder.d.ts +36 -0
- package/dist/generators/generators/seeder.d.ts.map +1 -0
- package/dist/generators/generators/seeder.js +99 -0
- package/dist/generators/generators/seeder.js.map +1 -0
- package/dist/generators/templates/factory.d.ts +26 -0
- package/dist/generators/templates/factory.d.ts.map +1 -0
- package/dist/generators/templates/factory.js +125 -0
- package/dist/generators/templates/factory.js.map +1 -0
- package/dist/generators/templates/seeder.d.ts +34 -0
- package/dist/generators/templates/seeder.d.ts.map +1 -0
- package/dist/generators/templates/seeder.js +129 -0
- package/dist/generators/templates/seeder.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/seeding/commands/seed.d.ts +11 -0
- package/dist/seeding/commands/seed.d.ts.map +1 -0
- package/dist/seeding/commands/seed.js +268 -0
- package/dist/seeding/commands/seed.js.map +1 -0
- package/dist/seeding/errors.d.ts +119 -0
- package/dist/seeding/errors.d.ts.map +1 -0
- package/dist/seeding/errors.js +191 -0
- package/dist/seeding/errors.js.map +1 -0
- package/dist/seeding/factory.d.ts +162 -0
- package/dist/seeding/factory.d.ts.map +1 -0
- package/dist/seeding/factory.js +250 -0
- package/dist/seeding/factory.js.map +1 -0
- package/dist/seeding/index.d.ts +31 -0
- package/dist/seeding/index.d.ts.map +1 -0
- package/dist/seeding/index.js +41 -0
- package/dist/seeding/index.js.map +1 -0
- package/dist/seeding/loader.d.ts +41 -0
- package/dist/seeding/loader.d.ts.map +1 -0
- package/dist/seeding/loader.js +210 -0
- package/dist/seeding/loader.js.map +1 -0
- package/dist/seeding/registry.d.ts +116 -0
- package/dist/seeding/registry.d.ts.map +1 -0
- package/dist/seeding/registry.js +298 -0
- package/dist/seeding/registry.js.map +1 -0
- package/dist/seeding/runner.d.ts +88 -0
- package/dist/seeding/runner.d.ts.map +1 -0
- package/dist/seeding/runner.js +254 -0
- package/dist/seeding/runner.js.map +1 -0
- package/dist/seeding/types.d.ts +247 -0
- package/dist/seeding/types.d.ts.map +1 -0
- package/dist/seeding/types.js +7 -0
- package/dist/seeding/types.js.map +1 -0
- package/dist/utils/output.d.ts +12 -0
- package/dist/utils/output.d.ts.map +1 -1
- package/dist/utils/output.js +21 -0
- package/dist/utils/output.js.map +1 -1
- package/package.json +18 -17
- package/LICENSE +0 -21
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @veloxts/cli - Database Seeding Module
|
|
3
|
+
*
|
|
4
|
+
* Laravel-inspired database seeding system with factories and seeders.
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```typescript
|
|
8
|
+
* // In a seeder file (src/database/seeders/UserSeeder.ts)
|
|
9
|
+
* import type { Seeder, SeederContext } from '@veloxts/cli';
|
|
10
|
+
* import { UserFactory } from '../factories/UserFactory.js';
|
|
11
|
+
*
|
|
12
|
+
* export const UserSeeder: Seeder = {
|
|
13
|
+
* name: 'UserSeeder',
|
|
14
|
+
* dependencies: [],
|
|
15
|
+
*
|
|
16
|
+
* async run({ db, factory, log }) {
|
|
17
|
+
* await factory.get(UserFactory).createMany(10);
|
|
18
|
+
* log.success('Created 10 users');
|
|
19
|
+
* },
|
|
20
|
+
* };
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @module @veloxts/cli/seeding
|
|
24
|
+
*/
|
|
25
|
+
// ============================================================================
|
|
26
|
+
// Errors
|
|
27
|
+
// ============================================================================
|
|
28
|
+
export { circularDependency, dependencyNotFound, executionFailed, FactoryError, factoryCreateFailed, factoryNotFound, filesystemError, invalidExport, noSeedersFound, SeederError, SeederErrorCode, seederDatabaseError,
|
|
29
|
+
// Error factory functions
|
|
30
|
+
seederNotFound, stateNotFound, truncationFailed, } from './errors.js';
|
|
31
|
+
// ============================================================================
|
|
32
|
+
// Factory System
|
|
33
|
+
// ============================================================================
|
|
34
|
+
export { BaseFactory, createFactoryRegistry } from './factory.js';
|
|
35
|
+
// ============================================================================
|
|
36
|
+
// Seeder Infrastructure
|
|
37
|
+
// ============================================================================
|
|
38
|
+
export { loadSeeders, seedersDirectoryExists } from './loader.js';
|
|
39
|
+
export { SeederRegistry } from './registry.js';
|
|
40
|
+
export { SeederRunner } from './runner.js';
|
|
41
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/seeding/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AA+BH,+EAA+E;AAC/E,SAAS;AACT,+EAA+E;AAE/E,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,eAAe,EACf,YAAY,EACZ,mBAAmB,EACnB,eAAe,EACf,eAAe,EACf,aAAa,EACb,cAAc,EACd,WAAW,EACX,eAAe,EACf,mBAAmB;AACnB,0BAA0B;AAC1B,cAAc,EACd,aAAa,EACb,gBAAgB,GACjB,MAAM,aAAa,CAAC;AAErB,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAElE,+EAA+E;AAC/E,wBAAwB;AACxB,+EAA+E;AAE/E,OAAO,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Seeder Loader
|
|
3
|
+
*
|
|
4
|
+
* Load seeder files from the filesystem.
|
|
5
|
+
*/
|
|
6
|
+
import type { Seeder, SeederLoadResult } from './types.js';
|
|
7
|
+
/**
|
|
8
|
+
* Default path for seeders relative to project root
|
|
9
|
+
*/
|
|
10
|
+
export declare const DEFAULT_SEEDERS_PATH = "src/database/seeders";
|
|
11
|
+
/**
|
|
12
|
+
* Check if seeders directory exists.
|
|
13
|
+
*
|
|
14
|
+
* @param cwd - Project root directory
|
|
15
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
16
|
+
*/
|
|
17
|
+
export declare function seedersDirectoryExists(cwd: string, seedersPath?: string): Promise<boolean>;
|
|
18
|
+
/**
|
|
19
|
+
* Load all seeders from the filesystem.
|
|
20
|
+
*
|
|
21
|
+
* @param cwd - Project root directory
|
|
22
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
23
|
+
* @returns Load result with seeders and any errors
|
|
24
|
+
*/
|
|
25
|
+
export declare function loadSeeders(cwd: string, seedersPath?: string): Promise<SeederLoadResult>;
|
|
26
|
+
/**
|
|
27
|
+
* Load the main DatabaseSeeder entry point.
|
|
28
|
+
*
|
|
29
|
+
* @param cwd - Project root directory
|
|
30
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
31
|
+
* @returns DatabaseSeeder if found, null otherwise
|
|
32
|
+
*/
|
|
33
|
+
export declare function loadDatabaseSeeder(cwd: string, seedersPath?: string): Promise<Seeder | null>;
|
|
34
|
+
/**
|
|
35
|
+
* Get all seeder file paths from directory.
|
|
36
|
+
*
|
|
37
|
+
* @param cwd - Project root directory
|
|
38
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
39
|
+
*/
|
|
40
|
+
export declare function getSeederFiles(cwd: string, seedersPath?: string): Promise<string[]>;
|
|
41
|
+
//# sourceMappingURL=loader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/seeding/loader.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAOH,OAAO,KAAK,EAAgB,MAAM,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAMzE;;GAEG;AACH,eAAO,MAAM,oBAAoB,yBAAyB,CAAC;AAgB3D;;;;;GAKG;AACH,wBAAsB,sBAAsB,CAC1C,GAAG,EAAE,MAAM,EACX,WAAW,GAAE,MAA6B,GACzC,OAAO,CAAC,OAAO,CAAC,CAQlB;AAED;;;;;;GAMG;AACH,wBAAsB,WAAW,CAC/B,GAAG,EAAE,MAAM,EACX,WAAW,GAAE,MAA6B,GACzC,OAAO,CAAC,gBAAgB,CAAC,CA0C3B;AAED;;;;;;GAMG;AACH,wBAAsB,kBAAkB,CACtC,GAAG,EAAE,MAAM,EACX,WAAW,GAAE,MAA6B,GACzC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAkBxB;AAiGD;;;;;GAKG;AACH,wBAAsB,cAAc,CAClC,GAAG,EAAE,MAAM,EACX,WAAW,GAAE,MAA6B,GACzC,OAAO,CAAC,MAAM,EAAE,CAAC,CAenB"}
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Seeder Loader
|
|
3
|
+
*
|
|
4
|
+
* Load seeder files from the filesystem.
|
|
5
|
+
*/
|
|
6
|
+
import fs from 'node:fs/promises';
|
|
7
|
+
import path from 'node:path';
|
|
8
|
+
import { pathToFileURL } from 'node:url';
|
|
9
|
+
import { filesystemError, invalidExport } from './errors.js';
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// Constants
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Default path for seeders relative to project root
|
|
15
|
+
*/
|
|
16
|
+
export const DEFAULT_SEEDERS_PATH = 'src/database/seeders';
|
|
17
|
+
/**
|
|
18
|
+
* File patterns that indicate a seeder file
|
|
19
|
+
*/
|
|
20
|
+
const SEEDER_FILE_PATTERNS = [/Seeder\.(ts|js)$/, /\.seeder\.(ts|js)$/];
|
|
21
|
+
/**
|
|
22
|
+
* Files to skip
|
|
23
|
+
*/
|
|
24
|
+
const SKIP_FILES = ['index.ts', 'index.js', 'DatabaseSeeder.ts', 'DatabaseSeeder.js'];
|
|
25
|
+
// ============================================================================
|
|
26
|
+
// Loader Functions
|
|
27
|
+
// ============================================================================
|
|
28
|
+
/**
|
|
29
|
+
* Check if seeders directory exists.
|
|
30
|
+
*
|
|
31
|
+
* @param cwd - Project root directory
|
|
32
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
33
|
+
*/
|
|
34
|
+
export async function seedersDirectoryExists(cwd, seedersPath = DEFAULT_SEEDERS_PATH) {
|
|
35
|
+
const fullPath = path.join(cwd, seedersPath);
|
|
36
|
+
try {
|
|
37
|
+
const stat = await fs.stat(fullPath);
|
|
38
|
+
return stat.isDirectory();
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Load all seeders from the filesystem.
|
|
46
|
+
*
|
|
47
|
+
* @param cwd - Project root directory
|
|
48
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
49
|
+
* @returns Load result with seeders and any errors
|
|
50
|
+
*/
|
|
51
|
+
export async function loadSeeders(cwd, seedersPath = DEFAULT_SEEDERS_PATH) {
|
|
52
|
+
const fullPath = path.join(cwd, seedersPath);
|
|
53
|
+
const seeders = [];
|
|
54
|
+
const errors = [];
|
|
55
|
+
// Check directory exists
|
|
56
|
+
if (!(await seedersDirectoryExists(cwd, seedersPath))) {
|
|
57
|
+
return { seeders: [], errors: [] };
|
|
58
|
+
}
|
|
59
|
+
// List files
|
|
60
|
+
let files;
|
|
61
|
+
try {
|
|
62
|
+
files = await fs.readdir(fullPath);
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
66
|
+
throw filesystemError('reading seeders directory', fullPath, err);
|
|
67
|
+
}
|
|
68
|
+
// Filter to seeder files
|
|
69
|
+
const seederFiles = files.filter((file) => {
|
|
70
|
+
// Skip non-seeder files
|
|
71
|
+
if (SKIP_FILES.includes(file))
|
|
72
|
+
return false;
|
|
73
|
+
// Check if matches seeder pattern
|
|
74
|
+
return SEEDER_FILE_PATTERNS.some((pattern) => pattern.test(file));
|
|
75
|
+
});
|
|
76
|
+
// Load each seeder
|
|
77
|
+
for (const file of seederFiles) {
|
|
78
|
+
const filePath = path.join(fullPath, file);
|
|
79
|
+
try {
|
|
80
|
+
const seeder = await loadSeederFile(filePath);
|
|
81
|
+
seeders.push({ seeder, filePath });
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
85
|
+
errors.push({ filePath, error: err.message });
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return { seeders, errors };
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Load the main DatabaseSeeder entry point.
|
|
92
|
+
*
|
|
93
|
+
* @param cwd - Project root directory
|
|
94
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
95
|
+
* @returns DatabaseSeeder if found, null otherwise
|
|
96
|
+
*/
|
|
97
|
+
export async function loadDatabaseSeeder(cwd, seedersPath = DEFAULT_SEEDERS_PATH) {
|
|
98
|
+
const fullPath = path.join(cwd, seedersPath);
|
|
99
|
+
// Try both .ts and .js extensions
|
|
100
|
+
for (const ext of ['ts', 'js']) {
|
|
101
|
+
const filePath = path.join(fullPath, `DatabaseSeeder.${ext}`);
|
|
102
|
+
try {
|
|
103
|
+
const stat = await fs.stat(filePath);
|
|
104
|
+
if (stat.isFile()) {
|
|
105
|
+
return await loadSeederFile(filePath);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
catch {
|
|
109
|
+
// File doesn't exist, try next
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Load a single seeder file.
|
|
116
|
+
*
|
|
117
|
+
* @param filePath - Absolute path to seeder file
|
|
118
|
+
* @returns Loaded seeder
|
|
119
|
+
*/
|
|
120
|
+
async function loadSeederFile(filePath) {
|
|
121
|
+
// Convert to file URL for dynamic import
|
|
122
|
+
const fileUrl = pathToFileURL(filePath).href;
|
|
123
|
+
// Dynamic import
|
|
124
|
+
let module;
|
|
125
|
+
try {
|
|
126
|
+
module = (await import(fileUrl));
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
130
|
+
throw invalidExport(filePath, `Failed to import: ${err.message}`);
|
|
131
|
+
}
|
|
132
|
+
// Look for seeder export
|
|
133
|
+
const seeder = findSeederExport(module);
|
|
134
|
+
if (!seeder) {
|
|
135
|
+
throw invalidExport(filePath, 'No valid seeder export found. Export a const named *Seeder or use default export.');
|
|
136
|
+
}
|
|
137
|
+
// Validate seeder shape
|
|
138
|
+
validateSeeder(seeder, filePath);
|
|
139
|
+
return seeder;
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Find a seeder export in a module.
|
|
143
|
+
*/
|
|
144
|
+
function findSeederExport(module) {
|
|
145
|
+
// Check default export first
|
|
146
|
+
if (module.default && isSeederLike(module.default)) {
|
|
147
|
+
return module.default;
|
|
148
|
+
}
|
|
149
|
+
// Look for named export ending in 'Seeder'
|
|
150
|
+
for (const [key, value] of Object.entries(module)) {
|
|
151
|
+
if (key.endsWith('Seeder') && isSeederLike(value)) {
|
|
152
|
+
return value;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return null;
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Check if a value looks like a seeder.
|
|
159
|
+
*/
|
|
160
|
+
function isSeederLike(value) {
|
|
161
|
+
if (!value || typeof value !== 'object')
|
|
162
|
+
return false;
|
|
163
|
+
const obj = value;
|
|
164
|
+
return typeof obj.name === 'string' && typeof obj.run === 'function';
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* Validate a seeder has the required shape.
|
|
168
|
+
*/
|
|
169
|
+
function validateSeeder(seeder, filePath) {
|
|
170
|
+
if (!seeder || typeof seeder !== 'object') {
|
|
171
|
+
throw invalidExport(filePath, 'Seeder must be an object');
|
|
172
|
+
}
|
|
173
|
+
const obj = seeder;
|
|
174
|
+
if (typeof obj.name !== 'string' || obj.name.length === 0) {
|
|
175
|
+
throw invalidExport(filePath, "Seeder must have a non-empty 'name' property");
|
|
176
|
+
}
|
|
177
|
+
if (typeof obj.run !== 'function') {
|
|
178
|
+
throw invalidExport(filePath, "Seeder must have a 'run' function");
|
|
179
|
+
}
|
|
180
|
+
if (obj.dependencies !== undefined && !Array.isArray(obj.dependencies)) {
|
|
181
|
+
throw invalidExport(filePath, "'dependencies' must be an array of strings");
|
|
182
|
+
}
|
|
183
|
+
if (obj.environments !== undefined && !Array.isArray(obj.environments)) {
|
|
184
|
+
throw invalidExport(filePath, "'environments' must be an array");
|
|
185
|
+
}
|
|
186
|
+
if (obj.truncate !== undefined && typeof obj.truncate !== 'function') {
|
|
187
|
+
throw invalidExport(filePath, "'truncate' must be a function");
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Get all seeder file paths from directory.
|
|
192
|
+
*
|
|
193
|
+
* @param cwd - Project root directory
|
|
194
|
+
* @param seedersPath - Path to seeders directory (relative to cwd)
|
|
195
|
+
*/
|
|
196
|
+
export async function getSeederFiles(cwd, seedersPath = DEFAULT_SEEDERS_PATH) {
|
|
197
|
+
const fullPath = path.join(cwd, seedersPath);
|
|
198
|
+
if (!(await seedersDirectoryExists(cwd, seedersPath))) {
|
|
199
|
+
return [];
|
|
200
|
+
}
|
|
201
|
+
const files = await fs.readdir(fullPath);
|
|
202
|
+
return files
|
|
203
|
+
.filter((file) => {
|
|
204
|
+
if (SKIP_FILES.includes(file))
|
|
205
|
+
return false;
|
|
206
|
+
return SEEDER_FILE_PATTERNS.some((pattern) => pattern.test(file));
|
|
207
|
+
})
|
|
208
|
+
.map((file) => path.join(fullPath, file));
|
|
209
|
+
}
|
|
210
|
+
//# sourceMappingURL=loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/seeding/loader.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Seeder Registry
|
|
3
|
+
*
|
|
4
|
+
* Manages seeder registration and dependency resolution with topological sorting.
|
|
5
|
+
*/
|
|
6
|
+
import type { Environment, Seeder } from './types.js';
|
|
7
|
+
/**
|
|
8
|
+
* Registry for managing seeders with dependency resolution.
|
|
9
|
+
*
|
|
10
|
+
* Handles seeder registration, retrieval, and ordering based on dependencies
|
|
11
|
+
* using topological sorting.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```typescript
|
|
15
|
+
* const registry = new SeederRegistry();
|
|
16
|
+
*
|
|
17
|
+
* registry.register(UserSeeder);
|
|
18
|
+
* registry.register(PostSeeder); // depends on UserSeeder
|
|
19
|
+
*
|
|
20
|
+
* // Get seeders in correct execution order
|
|
21
|
+
* const ordered = registry.getInOrder();
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export declare class SeederRegistry {
|
|
25
|
+
private seeders;
|
|
26
|
+
/**
|
|
27
|
+
* Register a seeder in the registry.
|
|
28
|
+
*
|
|
29
|
+
* @param seeder - Seeder to register
|
|
30
|
+
* @throws Error if seeder with same name already exists
|
|
31
|
+
*/
|
|
32
|
+
register(seeder: Seeder): void;
|
|
33
|
+
/**
|
|
34
|
+
* Register multiple seeders.
|
|
35
|
+
*
|
|
36
|
+
* @param seeders - Seeders to register
|
|
37
|
+
*/
|
|
38
|
+
registerMany(seeders: Seeder[]): void;
|
|
39
|
+
/**
|
|
40
|
+
* Get a seeder by name.
|
|
41
|
+
*
|
|
42
|
+
* @param name - Seeder name
|
|
43
|
+
* @returns Seeder if found, undefined otherwise
|
|
44
|
+
*/
|
|
45
|
+
get(name: string): Seeder | undefined;
|
|
46
|
+
/**
|
|
47
|
+
* Get a seeder by name, throwing if not found.
|
|
48
|
+
*
|
|
49
|
+
* @param name - Seeder name
|
|
50
|
+
* @returns Seeder
|
|
51
|
+
* @throws SeederError if not found
|
|
52
|
+
*/
|
|
53
|
+
getOrThrow(name: string): Seeder;
|
|
54
|
+
/**
|
|
55
|
+
* Check if a seeder exists.
|
|
56
|
+
*
|
|
57
|
+
* @param name - Seeder name
|
|
58
|
+
*/
|
|
59
|
+
has(name: string): boolean;
|
|
60
|
+
/**
|
|
61
|
+
* Get all registered seeder names.
|
|
62
|
+
*/
|
|
63
|
+
getNames(): string[];
|
|
64
|
+
/**
|
|
65
|
+
* Get all registered seeders.
|
|
66
|
+
*/
|
|
67
|
+
getAll(): Seeder[];
|
|
68
|
+
/**
|
|
69
|
+
* Get seeder count.
|
|
70
|
+
*/
|
|
71
|
+
get size(): number;
|
|
72
|
+
/**
|
|
73
|
+
* Clear all registered seeders.
|
|
74
|
+
*/
|
|
75
|
+
clear(): void;
|
|
76
|
+
/**
|
|
77
|
+
* Validate all seeder dependencies exist and there are no circular dependencies.
|
|
78
|
+
*
|
|
79
|
+
* @throws SeederError if dependencies are invalid
|
|
80
|
+
*/
|
|
81
|
+
validateDependencies(): void;
|
|
82
|
+
/**
|
|
83
|
+
* Get all seeders in dependency order (topological sort).
|
|
84
|
+
*
|
|
85
|
+
* Seeders with no dependencies come first, then seeders that depend on them, etc.
|
|
86
|
+
*
|
|
87
|
+
* @param environment - Optional environment filter
|
|
88
|
+
* @returns Seeders in execution order
|
|
89
|
+
* @throws SeederError if circular dependency detected
|
|
90
|
+
*/
|
|
91
|
+
getInOrder(environment?: Environment): Seeder[];
|
|
92
|
+
/**
|
|
93
|
+
* Get seeders filtered by names in dependency order.
|
|
94
|
+
*
|
|
95
|
+
* @param names - Seeder names to include (and their dependencies)
|
|
96
|
+
* @param environment - Optional environment filter
|
|
97
|
+
*/
|
|
98
|
+
getByNames(names: string[], environment?: Environment): Seeder[];
|
|
99
|
+
/**
|
|
100
|
+
* Check if seeder should run in given environment.
|
|
101
|
+
*/
|
|
102
|
+
private shouldRunInEnvironment;
|
|
103
|
+
/**
|
|
104
|
+
* Detect circular dependencies using DFS.
|
|
105
|
+
*/
|
|
106
|
+
private detectCircularDependencies;
|
|
107
|
+
/**
|
|
108
|
+
* DFS helper for cycle detection.
|
|
109
|
+
*/
|
|
110
|
+
private detectCycleDFS;
|
|
111
|
+
/**
|
|
112
|
+
* Find and return a cycle starting from the given node.
|
|
113
|
+
*/
|
|
114
|
+
private findCycle;
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/seeding/registry.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAMtD;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAkC;IAEjD;;;;;OAKG;IACH,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAO9B;;;;OAIG;IACH,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI;IAMrC;;;;;OAKG;IACH,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAIrC;;;;;;OAMG;IACH,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAQhC;;;;OAIG;IACH,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI1B;;OAEG;IACH,QAAQ,IAAI,MAAM,EAAE;IAIpB;;OAEG;IACH,MAAM,IAAI,MAAM,EAAE;IAIlB;;OAEG;IACH,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED;;OAEG;IACH,KAAK,IAAI,IAAI;IAQb;;;;OAIG;IACH,oBAAoB,IAAI,IAAI;IAc5B;;;;;;;;OAQG;IACH,UAAU,CAAC,WAAW,CAAC,EAAE,WAAW,GAAG,MAAM,EAAE;IAmE/C;;;;;OAKG;IACH,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,WAAW,CAAC,EAAE,WAAW,GAAG,MAAM,EAAE;IAgChE;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAQ9B;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAWlC;;OAEG;IACH,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,OAAO,CAAC,SAAS;CAgClB"}
|