@spfn/core 0.1.0-alpha.20 → 0.1.0-alpha.22

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.
@@ -212,11 +212,13 @@ declare function createContractGenerator(config?: ContractGeneratorConfig): Gene
212
212
  */
213
213
 
214
214
  interface CodegenConfig {
215
- generators?: {
216
- contract?: ContractGeneratorConfig & {
217
- enabled?: boolean;
218
- };
219
- };
215
+ generators?: Array<{
216
+ path: string;
217
+ } | ({
218
+ name: 'contract';
219
+ } & ContractGeneratorConfig & {
220
+ enabled?: boolean;
221
+ })>;
220
222
  }
221
223
  /**
222
224
  * Load codegen configuration from .spfnrc.json or package.json
@@ -225,6 +227,6 @@ declare function loadCodegenConfig(cwd: string): CodegenConfig;
225
227
  /**
226
228
  * Create generator instances from configuration
227
229
  */
228
- declare function createGeneratorsFromConfig(config: CodegenConfig): Generator[];
230
+ declare function createGeneratorsFromConfig(config: CodegenConfig, cwd: string): Promise<Generator[]>;
229
231
 
230
232
  export { type ClientGenerationOptions, type CodegenConfig, CodegenOrchestrator, type ContractGeneratorConfig, type GenerationStats, type Generator, type GeneratorOptions, HttpMethod, type OrchestratorOptions, type ResourceRoutes, type RouteContractMapping, createContractGenerator, createGeneratorsFromConfig, generateClient, groupByResource, loadCodegenConfig, scanContracts, watchAndGenerate };
@@ -5,6 +5,7 @@ import { existsSync, mkdirSync, createWriteStream, readFileSync } from 'fs';
5
5
  import { watch } from 'chokidar';
6
6
  import pino from 'pino';
7
7
  import mm from 'micromatch';
8
+ import { createJiti } from 'jiti';
8
9
 
9
10
  // src/codegen/contract-scanner.ts
10
11
  async function scanContracts(routesDir) {
@@ -1201,19 +1202,51 @@ function loadCodegenConfig(cwd) {
1201
1202
  }
1202
1203
  configLogger.info("Using default config");
1203
1204
  return {
1204
- generators: {
1205
- contract: { enabled: true }
1206
- }
1205
+ generators: [
1206
+ { name: "contract", enabled: true }
1207
+ ]
1207
1208
  };
1208
1209
  }
1209
- function createGeneratorsFromConfig(config) {
1210
+ async function createGeneratorsFromConfig(config, cwd) {
1210
1211
  const generators = [];
1211
- if (config.generators?.contract?.enabled !== false) {
1212
- const contractConfig = {
1213
- routesDir: config.generators?.contract?.routesDir,
1214
- outputPath: config.generators?.contract?.outputPath};
1215
- generators.push(createContractGenerator(contractConfig));
1216
- configLogger.info("Contract generator enabled");
1212
+ if (!config.generators || config.generators.length === 0) {
1213
+ return generators;
1214
+ }
1215
+ for (const generatorConfig of config.generators) {
1216
+ try {
1217
+ if ("path" in generatorConfig) {
1218
+ const generatorPath = generatorConfig.path.startsWith(".") ? join(cwd, generatorConfig.path) : generatorConfig.path;
1219
+ configLogger.info(`Loading custom generator: ${generatorPath}`);
1220
+ let module;
1221
+ if (generatorPath.endsWith(".ts")) {
1222
+ const jiti = createJiti(cwd, {
1223
+ interopDefault: true
1224
+ });
1225
+ module = jiti(generatorPath);
1226
+ } else {
1227
+ module = await import(generatorPath);
1228
+ }
1229
+ const createGenerator = module.default || module.createGenerator || module;
1230
+ if (typeof createGenerator === "function") {
1231
+ const generator = createGenerator();
1232
+ generators.push(generator);
1233
+ configLogger.info(`Custom generator loaded: ${generator.name}`);
1234
+ } else {
1235
+ configLogger.warn(`Invalid generator at ${generatorPath}: expected function`);
1236
+ }
1237
+ } else if ("name" in generatorConfig && generatorConfig.name === "contract") {
1238
+ if (generatorConfig.enabled !== false) {
1239
+ const contractConfig = {
1240
+ routesDir: generatorConfig.routesDir,
1241
+ outputPath: generatorConfig.outputPath};
1242
+ generators.push(createContractGenerator(contractConfig));
1243
+ configLogger.info("Contract generator enabled");
1244
+ }
1245
+ }
1246
+ } catch (error) {
1247
+ const err = error instanceof Error ? error : new Error(String(error));
1248
+ configLogger.error("Failed to load generator", err);
1249
+ }
1217
1250
  }
1218
1251
  return generators;
1219
1252
  }