@soda-gql/codegen 0.1.0 → 0.2.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.
package/README.md CHANGED
@@ -27,15 +27,17 @@ This package provides the code generation engine that transforms GraphQL schemas
27
27
  For advanced use cases where you need to integrate code generation into your own build pipeline:
28
28
 
29
29
  ```typescript
30
- import { runMultiSchemaCodegen } from "@soda-gql/codegen";
30
+ import { runCodegen } from "@soda-gql/codegen";
31
31
 
32
- const result = await runMultiSchemaCodegen({
33
- outdir: "./src/graphql-system",
32
+ const result = await runCodegen({
33
+ outPath: "./src/graphql-system/index.ts",
34
+ format: "json",
34
35
  schemas: {
35
36
  default: {
36
- schemaPath: "./schema.graphql",
37
- runtimeAdapterPath: "./runtime-adapter.ts",
38
- scalarsPath: "./scalars.ts",
37
+ schema: "./schema.graphql",
38
+ inject: {
39
+ scalars: "./scalars.ts",
40
+ },
39
41
  },
40
42
  },
41
43
  });
@@ -1,4 +1,4 @@
1
- const require_generator = require('./generator-BFFlsKNR.cjs');
1
+ const require_generator = require('./generator-yvSYKjbW.cjs');
2
2
 
3
3
  exports.createSchemaIndex = require_generator.createSchemaIndex;
4
4
  exports.generateMultiSchemaModule = require_generator.generateMultiSchemaModule;
@@ -0,0 +1,3 @@
1
+ import { n as generateMultiSchemaModule, t as createSchemaIndex } from "./generator-HYfj5Qkm.mjs";
2
+
3
+ export { createSchemaIndex, generateMultiSchemaModule };
@@ -369,44 +369,26 @@ const collectUnionTypeNames = (schema) => Array.from(schema.unions.keys()).filte
369
369
  const collectScalarNames = (schema) => Array.from(schema.scalars.keys()).filter((name) => !name.startsWith("__")).sort((left, right) => left.localeCompare(right));
370
370
  const multiRuntimeTemplate = ($$) => {
371
371
  const imports = [];
372
- const adapterAliases = new Map();
373
372
  const scalarAliases = new Map();
374
- const metadataAdapterAliases = new Map();
375
- const helpersAliases = new Map();
373
+ const adapterAliases = new Map();
376
374
  if ($$.injection.mode === "inject") {
377
375
  const importsByPath = new Map();
378
376
  for (const [schemaName, injection] of $$.injection.perSchema) {
379
- const adapterAlias = `adapter_${schemaName}`;
380
377
  const scalarAlias = `scalar_${schemaName}`;
381
- adapterAliases.set(schemaName, adapterAlias);
382
378
  scalarAliases.set(schemaName, scalarAlias);
383
- const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];
384
- if (!importsByPath.has(injection.adapterImportPath)) {
385
- importsByPath.set(injection.adapterImportPath, adapterSpecifiers);
386
- }
387
- adapterSpecifiers.push(`adapter as ${adapterAlias}`);
388
379
  const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];
389
380
  if (!importsByPath.has(injection.scalarImportPath)) {
390
381
  importsByPath.set(injection.scalarImportPath, scalarSpecifiers);
391
382
  }
392
383
  scalarSpecifiers.push(`scalar as ${scalarAlias}`);
393
- if (injection.metadataAdapterImportPath) {
394
- const metadataAdapterAlias = `metadataAdapter_${schemaName}`;
395
- metadataAdapterAliases.set(schemaName, metadataAdapterAlias);
396
- const metadataAdapterSpecifiers = importsByPath.get(injection.metadataAdapterImportPath) ?? [];
397
- if (!importsByPath.has(injection.metadataAdapterImportPath)) {
398
- importsByPath.set(injection.metadataAdapterImportPath, metadataAdapterSpecifiers);
384
+ if (injection.adapterImportPath) {
385
+ const adapterAlias = `adapter_${schemaName}`;
386
+ adapterAliases.set(schemaName, adapterAlias);
387
+ const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];
388
+ if (!importsByPath.has(injection.adapterImportPath)) {
389
+ importsByPath.set(injection.adapterImportPath, adapterSpecifiers);
399
390
  }
400
- metadataAdapterSpecifiers.push(`metadataAdapter as ${metadataAdapterAlias}`);
401
- }
402
- if (injection.helpersImportPath) {
403
- const helpersAlias = `helpers_${schemaName}`;
404
- helpersAliases.set(schemaName, helpersAlias);
405
- const helpersSpecifiers = importsByPath.get(injection.helpersImportPath) ?? [];
406
- if (!importsByPath.has(injection.helpersImportPath)) {
407
- importsByPath.set(injection.helpersImportPath, helpersSpecifiers);
408
- }
409
- helpersSpecifiers.push(`helpers as ${helpersAlias}`);
391
+ adapterSpecifiers.push(`adapter as ${adapterAlias}`);
410
392
  }
411
393
  }
412
394
  for (const [path, specifiers] of importsByPath) {
@@ -422,16 +404,13 @@ const multiRuntimeTemplate = ($$) => {
422
404
  const gqlEntries = [];
423
405
  for (const [name, config] of Object.entries($$.schemas)) {
424
406
  const schemaVar = `${name}Schema`;
425
- const adapterVar = $$.injection.mode === "inject" ? adapterAliases.get(name) : `adapter_${name}`;
426
407
  const scalarBlock = $$.injection.mode === "inject" ? scalarAliases.get(name) : config.scalarBlock;
427
- const adapterDefinition = $$.injection.mode === "inject" ? "" : `const ${adapterVar} = createRuntimeAdapter(({ type }) => ({\n nonGraphqlErrorType: type<{ type: "non-graphql-error"; cause: unknown }>(),\n}));\n`;
428
- const metadataAdapterVar = metadataAdapterAliases.get(name);
429
- const helpersVar = helpersAliases.get(name);
430
- const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`, `export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`];
431
- if (helpersVar) {
432
- typeExports.push(`export type Helpers_${name} = typeof ${helpersVar} & { _?: never };`);
408
+ const adapterVar = adapterAliases.get(name);
409
+ const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];
410
+ if (adapterVar) {
411
+ typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);
433
412
  }
434
- schemaBlocks.push(`${adapterDefinition}
413
+ schemaBlocks.push(`
435
414
  const ${schemaVar} = {
436
415
  label: "${name}" as const,
437
416
  operations: defineOperationRoots({
@@ -447,22 +426,13 @@ const ${schemaVar} = {
447
426
  } satisfies AnyGraphqlSchema;
448
427
 
449
428
  ${typeExports.join("\n")}`);
450
- const hasOptions = metadataAdapterVar || helpersVar;
451
- if (hasOptions) {
452
- const optionsEntries = [];
453
- if (metadataAdapterVar) {
454
- optionsEntries.push(`metadataAdapter: ${metadataAdapterVar}`);
455
- }
456
- if (helpersVar) {
457
- optionsEntries.push(`helpers: ${helpersVar}`);
458
- }
459
- const helpersGeneric = helpersVar ? `, Helpers_${name}` : "";
460
- gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}, Adapter_${name}${helpersGeneric}>(${schemaVar}, { ${optionsEntries.join(", ")} })`);
429
+ if (adapterVar) {
430
+ const typeParams = `<Schema_${name}, Adapter_${name}>`;
431
+ gqlEntries.push(` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar} })`);
461
432
  } else {
462
- gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}, Adapter_${name}>(${schemaVar})`);
433
+ gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}>(${schemaVar})`);
463
434
  }
464
435
  }
465
- const runtimeImport = $$.injection.mode === "inline" ? "\nimport { createRuntimeAdapter } from \"@soda-gql/runtime\";" : "";
466
436
  return `\
467
437
  import {
468
438
  type AnyGraphqlSchema,
@@ -471,7 +441,7 @@ import {
471
441
  defineOperationRoots,
472
442
  unsafeInputType,
473
443
  unsafeOutputType,
474
- } from "@soda-gql/core";${runtimeImport}
444
+ } from "@soda-gql/core";
475
445
  ${extraImports}
476
446
  ${schemaBlocks.join("\n")}
477
447
 
@@ -561,4 +531,4 @@ const generateMultiSchemaModule = (schemas, options) => {
561
531
 
562
532
  //#endregion
563
533
  export { generateMultiSchemaModule as n, createSchemaIndex as t };
564
- //# sourceMappingURL=generator-D3aMXV0i.mjs.map
534
+ //# sourceMappingURL=generator-HYfj5Qkm.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generator-HYfj5Qkm.mjs","names":["operationTypes: OperationTypeNames","modifier: TypeModifier","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","name","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import type { TypeModifier } from \"@soda-gql/core\";\nimport {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): TypeModifier => {\n let modifier: TypeModifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}` as TypeModifier;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst renderType = (name: string, modifier: string): string => JSON.stringify(`${name}:${modifier}`);\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const tuple = renderType(name, modifier);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n if (isScalarName(schema, name)) {\n return `unsafeInputType.scalar(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n }\n\n if (isEnumName(schema, name)) {\n return `unsafeInputType.enum(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n }\n\n return `unsafeInputType.input(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const modifiedType = renderType(name, modifier);\n const argumentMap = renderArgumentMap(schema, args);\n\n if (isScalarName(schema, name)) {\n return `unsafeOutputType.scalar(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isEnumName(schema, name)) {\n return `unsafeOutputType.enum(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isUnionName(schema, name)) {\n return `unsafeOutputType.union(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isObjectName(schema, name)) {\n return `unsafeOutputType.object(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n return `unsafeOutputType.scalar(${modifiedType}, { arguments: ${argumentMap} })`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderScalarDefinition = (record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n const scalarType = `type<{ input: ${typeInfo.input}; output: ${typeInfo.output} }>()`;\n return `${record.name}: define(\"${record.name}\").scalar(${scalarType})`;\n};\n\nconst renderObjectDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.objects.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderObjectFields(schema, record.fields);\n return `${record.name}: define(\"${record.name}\").object(${fields})`;\n};\n\nconst renderInputDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.inputs.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderInputFields(schema, record.fields);\n return `${record.name}: define(\"${record.name}\").input(${fields})`;\n};\n\nconst renderEnumDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.enums.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const values = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => `${value.name.value}: true`)\n .join(\", \");\n const body = values.length === 0 ? \"{}\" : `{ ${values} }`;\n\n return `${record.name}: define(\"${record.name}\").enum(${body})`;\n};\n\nconst renderUnionDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.unions.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const members = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => `${member.name.value}: true`)\n .join(\", \");\n const body = members.length === 0 ? \"{}\" : `{ ${members} }`;\n\n return `${record.name}: define(\"${record.name}\").union(${body})`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n readonly scalarBlock: string;\n readonly enumBlock: string;\n readonly inputBlock: string;\n readonly objectBlock: string;\n readonly unionBlock: string;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n const scalarBlock = $$.injection.mode === \"inject\" ? scalarAliases.get(name) : config.scalarBlock;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n\n schemaBlocks.push(`\nconst ${schemaVar} = {\n label: \"${name}\" as const,\n operations: defineOperationRoots({\n query: \"${config.queryType}\",\n mutation: \"${config.mutationType}\",\n subscription: \"${config.subscriptionType}\",\n }),\n scalar: ${scalarBlock},\n enum: ${config.enumBlock},\n input: ${config.inputBlock},\n object: ${config.objectBlock},\n union: ${config.unionBlock},\n} satisfies AnyGraphqlSchema;\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options if needed\n if (adapterVar) {\n const typeParams = `<Schema_${name}, Adapter_${name}>`;\n gqlEntries.push(` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar} })`);\n } else {\n gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}>(${schemaVar})`);\n }\n }\n\n return `\\\nimport {\n type AnyGraphqlSchema,\n createGqlElementComposer,\n define,\n defineOperationRoots,\n unsafeInputType,\n unsafeOutputType,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name) =>\n renderScalarDefinition(schema.scalars.get(name) ?? { name, directives: [] }),\n );\n\n const customScalarDefinitions = collectScalarNames(schema)\n .filter((name) => !builtinScalarTypes.has(name))\n .map((name) => {\n const record = schema.scalars.get(name);\n return record ? renderScalarDefinition(record) : \"\";\n })\n .filter((definition) => definition.length > 0);\n\n const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);\n\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n\n const scalarBlock = renderPropertyLines({ entries: allScalarDefinitions, indentSize: 4 });\n const enumDefinitions = enumTypeNames\n .map((name) => renderEnumDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const enumBlock = renderPropertyLines({ entries: enumDefinitions, indentSize: 4 });\n const inputDefinitions = inputTypeNames\n .map((name) => renderInputDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const inputBlock = renderPropertyLines({ entries: inputDefinitions, indentSize: 4 });\n const objectDefinitions = objectTypeNames\n .map((name) => renderObjectDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const objectBlock = renderPropertyLines({ entries: objectDefinitions, indentSize: 4 });\n const unionDefinitions = unionTypeNames\n .map((name) => renderUnionDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const unionBlock = renderPropertyLines({ entries: unionDefinitions, indentSize: 4 });\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n scalarBlock,\n enumBlock,\n inputBlock,\n objectBlock,\n unionBlock,\n };\n\n // Accumulate stats\n allStats.objects += objectDefinitions.length;\n allStats.enums += enumDefinitions.length;\n allStats.inputs += inputDefinitions.length;\n allStats.unions += unionDefinitions.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
@@ -369,44 +369,26 @@ const collectUnionTypeNames = (schema) => Array.from(schema.unions.keys()).filte
369
369
  const collectScalarNames = (schema) => Array.from(schema.scalars.keys()).filter((name) => !name.startsWith("__")).sort((left, right) => left.localeCompare(right));
370
370
  const multiRuntimeTemplate = ($$) => {
371
371
  const imports = [];
372
- const adapterAliases = new Map();
373
372
  const scalarAliases = new Map();
374
- const metadataAdapterAliases = new Map();
375
- const helpersAliases = new Map();
373
+ const adapterAliases = new Map();
376
374
  if ($$.injection.mode === "inject") {
377
375
  const importsByPath = new Map();
378
376
  for (const [schemaName, injection] of $$.injection.perSchema) {
379
- const adapterAlias = `adapter_${schemaName}`;
380
377
  const scalarAlias = `scalar_${schemaName}`;
381
- adapterAliases.set(schemaName, adapterAlias);
382
378
  scalarAliases.set(schemaName, scalarAlias);
383
- const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];
384
- if (!importsByPath.has(injection.adapterImportPath)) {
385
- importsByPath.set(injection.adapterImportPath, adapterSpecifiers);
386
- }
387
- adapterSpecifiers.push(`adapter as ${adapterAlias}`);
388
379
  const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];
389
380
  if (!importsByPath.has(injection.scalarImportPath)) {
390
381
  importsByPath.set(injection.scalarImportPath, scalarSpecifiers);
391
382
  }
392
383
  scalarSpecifiers.push(`scalar as ${scalarAlias}`);
393
- if (injection.metadataAdapterImportPath) {
394
- const metadataAdapterAlias = `metadataAdapter_${schemaName}`;
395
- metadataAdapterAliases.set(schemaName, metadataAdapterAlias);
396
- const metadataAdapterSpecifiers = importsByPath.get(injection.metadataAdapterImportPath) ?? [];
397
- if (!importsByPath.has(injection.metadataAdapterImportPath)) {
398
- importsByPath.set(injection.metadataAdapterImportPath, metadataAdapterSpecifiers);
399
- }
400
- metadataAdapterSpecifiers.push(`metadataAdapter as ${metadataAdapterAlias}`);
401
- }
402
- if (injection.helpersImportPath) {
403
- const helpersAlias = `helpers_${schemaName}`;
404
- helpersAliases.set(schemaName, helpersAlias);
405
- const helpersSpecifiers = importsByPath.get(injection.helpersImportPath) ?? [];
406
- if (!importsByPath.has(injection.helpersImportPath)) {
407
- importsByPath.set(injection.helpersImportPath, helpersSpecifiers);
384
+ if (injection.adapterImportPath) {
385
+ const adapterAlias = `adapter_${schemaName}`;
386
+ adapterAliases.set(schemaName, adapterAlias);
387
+ const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];
388
+ if (!importsByPath.has(injection.adapterImportPath)) {
389
+ importsByPath.set(injection.adapterImportPath, adapterSpecifiers);
408
390
  }
409
- helpersSpecifiers.push(`helpers as ${helpersAlias}`);
391
+ adapterSpecifiers.push(`adapter as ${adapterAlias}`);
410
392
  }
411
393
  }
412
394
  for (const [path, specifiers] of importsByPath) {
@@ -422,16 +404,13 @@ const multiRuntimeTemplate = ($$) => {
422
404
  const gqlEntries = [];
423
405
  for (const [name, config] of Object.entries($$.schemas)) {
424
406
  const schemaVar = `${name}Schema`;
425
- const adapterVar = $$.injection.mode === "inject" ? adapterAliases.get(name) : `adapter_${name}`;
426
407
  const scalarBlock = $$.injection.mode === "inject" ? scalarAliases.get(name) : config.scalarBlock;
427
- const adapterDefinition = $$.injection.mode === "inject" ? "" : `const ${adapterVar} = createRuntimeAdapter(({ type }) => ({\n nonGraphqlErrorType: type<{ type: "non-graphql-error"; cause: unknown }>(),\n}));\n`;
428
- const metadataAdapterVar = metadataAdapterAliases.get(name);
429
- const helpersVar = helpersAliases.get(name);
430
- const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`, `export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`];
431
- if (helpersVar) {
432
- typeExports.push(`export type Helpers_${name} = typeof ${helpersVar} & { _?: never };`);
408
+ const adapterVar = adapterAliases.get(name);
409
+ const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];
410
+ if (adapterVar) {
411
+ typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);
433
412
  }
434
- schemaBlocks.push(`${adapterDefinition}
413
+ schemaBlocks.push(`
435
414
  const ${schemaVar} = {
436
415
  label: "${name}" as const,
437
416
  operations: defineOperationRoots({
@@ -447,22 +426,13 @@ const ${schemaVar} = {
447
426
  } satisfies AnyGraphqlSchema;
448
427
 
449
428
  ${typeExports.join("\n")}`);
450
- const hasOptions = metadataAdapterVar || helpersVar;
451
- if (hasOptions) {
452
- const optionsEntries = [];
453
- if (metadataAdapterVar) {
454
- optionsEntries.push(`metadataAdapter: ${metadataAdapterVar}`);
455
- }
456
- if (helpersVar) {
457
- optionsEntries.push(`helpers: ${helpersVar}`);
458
- }
459
- const helpersGeneric = helpersVar ? `, Helpers_${name}` : "";
460
- gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}, Adapter_${name}${helpersGeneric}>(${schemaVar}, { ${optionsEntries.join(", ")} })`);
429
+ if (adapterVar) {
430
+ const typeParams = `<Schema_${name}, Adapter_${name}>`;
431
+ gqlEntries.push(` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar} })`);
461
432
  } else {
462
- gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}, Adapter_${name}>(${schemaVar})`);
433
+ gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}>(${schemaVar})`);
463
434
  }
464
435
  }
465
- const runtimeImport = $$.injection.mode === "inline" ? "\nimport { createRuntimeAdapter } from \"@soda-gql/runtime\";" : "";
466
436
  return `\
467
437
  import {
468
438
  type AnyGraphqlSchema,
@@ -471,7 +441,7 @@ import {
471
441
  defineOperationRoots,
472
442
  unsafeInputType,
473
443
  unsafeOutputType,
474
- } from "@soda-gql/core";${runtimeImport}
444
+ } from "@soda-gql/core";
475
445
  ${extraImports}
476
446
  ${schemaBlocks.join("\n")}
477
447
 
@@ -571,4 +541,5 @@ Object.defineProperty(exports, 'generateMultiSchemaModule', {
571
541
  get: function () {
572
542
  return generateMultiSchemaModule;
573
543
  }
574
- });
544
+ });
545
+ //# sourceMappingURL=generator-yvSYKjbW.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generator-yvSYKjbW.cjs","names":["operationTypes: OperationTypeNames","Kind","modifier: TypeModifier","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","name","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import type { TypeModifier } from \"@soda-gql/core\";\nimport {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): TypeModifier => {\n let modifier: TypeModifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}` as TypeModifier;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst renderType = (name: string, modifier: string): string => JSON.stringify(`${name}:${modifier}`);\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const tuple = renderType(name, modifier);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n if (isScalarName(schema, name)) {\n return `unsafeInputType.scalar(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n }\n\n if (isEnumName(schema, name)) {\n return `unsafeInputType.enum(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n }\n\n return `unsafeInputType.input(${tuple}, { default: ${defaultValue}, directives: ${directives} })`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const modifiedType = renderType(name, modifier);\n const argumentMap = renderArgumentMap(schema, args);\n\n if (isScalarName(schema, name)) {\n return `unsafeOutputType.scalar(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isEnumName(schema, name)) {\n return `unsafeOutputType.enum(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isUnionName(schema, name)) {\n return `unsafeOutputType.union(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n if (isObjectName(schema, name)) {\n return `unsafeOutputType.object(${modifiedType}, { arguments: ${argumentMap} })`;\n }\n\n return `unsafeOutputType.scalar(${modifiedType}, { arguments: ${argumentMap} })`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderScalarDefinition = (record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n const scalarType = `type<{ input: ${typeInfo.input}; output: ${typeInfo.output} }>()`;\n return `${record.name}: define(\"${record.name}\").scalar(${scalarType})`;\n};\n\nconst renderObjectDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.objects.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderObjectFields(schema, record.fields);\n return `${record.name}: define(\"${record.name}\").object(${fields})`;\n};\n\nconst renderInputDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.inputs.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderInputFields(schema, record.fields);\n return `${record.name}: define(\"${record.name}\").input(${fields})`;\n};\n\nconst renderEnumDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.enums.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const values = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => `${value.name.value}: true`)\n .join(\", \");\n const body = values.length === 0 ? \"{}\" : `{ ${values} }`;\n\n return `${record.name}: define(\"${record.name}\").enum(${body})`;\n};\n\nconst renderUnionDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.unions.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const members = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => `${member.name.value}: true`)\n .join(\", \");\n const body = members.length === 0 ? \"{}\" : `{ ${members} }`;\n\n return `${record.name}: define(\"${record.name}\").union(${body})`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n readonly scalarBlock: string;\n readonly enumBlock: string;\n readonly inputBlock: string;\n readonly objectBlock: string;\n readonly unionBlock: string;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n const scalarBlock = $$.injection.mode === \"inject\" ? scalarAliases.get(name) : config.scalarBlock;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n\n schemaBlocks.push(`\nconst ${schemaVar} = {\n label: \"${name}\" as const,\n operations: defineOperationRoots({\n query: \"${config.queryType}\",\n mutation: \"${config.mutationType}\",\n subscription: \"${config.subscriptionType}\",\n }),\n scalar: ${scalarBlock},\n enum: ${config.enumBlock},\n input: ${config.inputBlock},\n object: ${config.objectBlock},\n union: ${config.unionBlock},\n} satisfies AnyGraphqlSchema;\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options if needed\n if (adapterVar) {\n const typeParams = `<Schema_${name}, Adapter_${name}>`;\n gqlEntries.push(` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar} })`);\n } else {\n gqlEntries.push(` ${name}: createGqlElementComposer<Schema_${name}>(${schemaVar})`);\n }\n }\n\n return `\\\nimport {\n type AnyGraphqlSchema,\n createGqlElementComposer,\n define,\n defineOperationRoots,\n unsafeInputType,\n unsafeOutputType,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name) =>\n renderScalarDefinition(schema.scalars.get(name) ?? { name, directives: [] }),\n );\n\n const customScalarDefinitions = collectScalarNames(schema)\n .filter((name) => !builtinScalarTypes.has(name))\n .map((name) => {\n const record = schema.scalars.get(name);\n return record ? renderScalarDefinition(record) : \"\";\n })\n .filter((definition) => definition.length > 0);\n\n const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);\n\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n\n const scalarBlock = renderPropertyLines({ entries: allScalarDefinitions, indentSize: 4 });\n const enumDefinitions = enumTypeNames\n .map((name) => renderEnumDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const enumBlock = renderPropertyLines({ entries: enumDefinitions, indentSize: 4 });\n const inputDefinitions = inputTypeNames\n .map((name) => renderInputDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const inputBlock = renderPropertyLines({ entries: inputDefinitions, indentSize: 4 });\n const objectDefinitions = objectTypeNames\n .map((name) => renderObjectDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const objectBlock = renderPropertyLines({ entries: objectDefinitions, indentSize: 4 });\n const unionDefinitions = unionTypeNames\n .map((name) => renderUnionDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const unionBlock = renderPropertyLines({ entries: unionDefinitions, indentSize: 4 });\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n scalarBlock,\n enumBlock,\n inputBlock,\n objectBlock,\n unionBlock,\n };\n\n // Accumulate stats\n allStats.objects += objectDefinitions.length;\n allStats.enums += enumDefinitions.length;\n allStats.inputs += inputDefinitions.length;\n allStats.unions += unionDefinitions.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
package/dist/index.cjs CHANGED
@@ -1,4 +1,4 @@
1
- const require_generator = require('./generator-BFFlsKNR.cjs');
1
+ const require_generator = require('./generator-yvSYKjbW.cjs');
2
2
  let node_fs = require("node:fs");
3
3
  let node_path = require("node:path");
4
4
  let neverthrow = require("neverthrow");
@@ -9,39 +9,14 @@ let tsdown = require("tsdown");
9
9
  //#region packages/codegen/src/inject-template.ts
10
10
  const templateContents = `\
11
11
  import { defineScalar } from "@soda-gql/core";
12
- import { createRuntimeAdapter } from "@soda-gql/runtime";
13
12
 
14
13
  export const scalar = {
15
- ...defineScalar("ID", ({ type }) => ({
16
- input: type<string>(),
17
- output: type<string>(),
18
- directives: {},
19
- })),
20
- ...defineScalar("String", ({ type }) => ({
21
- input: type<string>(),
22
- output: type<string>(),
23
- directives: {},
24
- })),
25
- ...defineScalar("Int", ({ type }) => ({
26
- input: type<number>(),
27
- output: type<number>(),
28
- directives: {},
29
- })),
30
- ...defineScalar("Float", ({ type }) => ({
31
- input: type<number>(),
32
- output: type<number>(),
33
- directives: {},
34
- })),
35
- ...defineScalar("Boolean", ({ type }) => ({
36
- input: type<boolean>(),
37
- output: type<boolean>(),
38
- directives: {},
39
- })),
14
+ ...defineScalar<"ID", string, string>("ID"),
15
+ ...defineScalar<"String", string, string>("String"),
16
+ ...defineScalar<"Int", number, number>("Int"),
17
+ ...defineScalar<"Float", number, number>("Float"),
18
+ ...defineScalar<"Boolean", boolean, boolean>("Boolean"),
40
19
  } as const;
41
-
42
- export const adapter = createRuntimeAdapter(({ type }) => ({
43
- nonGraphqlErrorType: type<{ type: "non-graphql-error"; cause: unknown }>(),
44
- }));
45
20
  `;
46
21
  const writeInjectTemplate = (outPath) => {
47
22
  const targetPath = (0, node_path.resolve)(outPath);
@@ -182,94 +157,49 @@ const toImportSpecifier = (fromPath, targetPath, options) => {
182
157
  const withoutExt = currentExt ? withPrefix.slice(0, -currentExt.length) : withPrefix;
183
158
  return `${withoutExt}${runtimeExt}`;
184
159
  };
185
- const runMultiSchemaCodegen = async (options) => {
160
+ const runCodegen = async (options) => {
186
161
  const outPath = (0, node_path.resolve)(options.outPath);
187
- const runtimeAdapters = options.runtimeAdapters ?? (options.injectFromPath ? { default: options.injectFromPath } : {});
188
- const scalars = options.scalars ?? (options.injectFromPath ? { default: options.injectFromPath } : {});
189
- const adapterPaths = new Map();
190
- const scalarPaths = new Map();
191
- const metadataAdapterPaths = new Map();
192
- const helpersPaths = new Map();
193
- for (const [schemaName, adapterPath] of Object.entries(runtimeAdapters)) {
194
- const resolvedPath = (0, node_path.resolve)(adapterPath);
195
- if (!(0, node_fs.existsSync)(resolvedPath)) {
196
- return (0, neverthrow.err)({
197
- code: "INJECT_MODULE_NOT_FOUND",
198
- message: `Runtime adapter module not found for schema '${schemaName}': ${resolvedPath}`,
199
- injectPath: resolvedPath
200
- });
201
- }
202
- adapterPaths.set(schemaName, resolvedPath);
203
- }
204
- for (const [schemaName, scalarPath] of Object.entries(scalars)) {
205
- const resolvedPath = (0, node_path.resolve)(scalarPath);
206
- if (!(0, node_fs.existsSync)(resolvedPath)) {
162
+ const importSpecifierOptions = { includeExtension: options.importExtension };
163
+ for (const [schemaName, schemaConfig] of Object.entries(options.schemas)) {
164
+ const scalarPath = (0, node_path.resolve)(schemaConfig.inject.scalars);
165
+ if (!(0, node_fs.existsSync)(scalarPath)) {
207
166
  return (0, neverthrow.err)({
208
167
  code: "INJECT_MODULE_NOT_FOUND",
209
- message: `Scalar module not found for schema '${schemaName}': ${resolvedPath}`,
210
- injectPath: resolvedPath
168
+ message: `Scalar module not found for schema '${schemaName}': ${scalarPath}`,
169
+ injectPath: scalarPath
211
170
  });
212
171
  }
213
- scalarPaths.set(schemaName, resolvedPath);
214
- }
215
- if (options.metadataAdapters) {
216
- for (const [schemaName, metadataAdapterPath] of Object.entries(options.metadataAdapters)) {
217
- const resolvedPath = (0, node_path.resolve)(metadataAdapterPath);
218
- if (!(0, node_fs.existsSync)(resolvedPath)) {
219
- return (0, neverthrow.err)({
220
- code: "INJECT_MODULE_NOT_FOUND",
221
- message: `Metadata adapter module not found for schema '${schemaName}': ${resolvedPath}`,
222
- injectPath: resolvedPath
223
- });
224
- }
225
- metadataAdapterPaths.set(schemaName, resolvedPath);
226
- }
227
- }
228
- if (options.helpers) {
229
- for (const [schemaName, helpersPath] of Object.entries(options.helpers)) {
230
- const resolvedPath = (0, node_path.resolve)(helpersPath);
231
- if (!(0, node_fs.existsSync)(resolvedPath)) {
172
+ if (schemaConfig.inject.adapter) {
173
+ const adapterPath = (0, node_path.resolve)(schemaConfig.inject.adapter);
174
+ if (!(0, node_fs.existsSync)(adapterPath)) {
232
175
  return (0, neverthrow.err)({
233
176
  code: "INJECT_MODULE_NOT_FOUND",
234
- message: `Helpers module not found for schema '${schemaName}': ${resolvedPath}`,
235
- injectPath: resolvedPath
177
+ message: `Adapter module not found for schema '${schemaName}': ${adapterPath}`,
178
+ injectPath: adapterPath
236
179
  });
237
180
  }
238
- helpersPaths.set(schemaName, resolvedPath);
239
181
  }
240
182
  }
241
183
  const schemas = new Map();
242
184
  const schemaHashes = {};
243
- for (const [name, schemaPath] of Object.entries(options.schemas)) {
244
- const result = await loadSchema(schemaPath).match((doc) => Promise.resolve((0, neverthrow.ok)(doc)), (error) => Promise.resolve((0, neverthrow.err)(error)));
185
+ for (const [name, schemaConfig] of Object.entries(options.schemas)) {
186
+ const result = await loadSchema(schemaConfig.schema).match((doc) => Promise.resolve((0, neverthrow.ok)(doc)), (error) => Promise.resolve((0, neverthrow.err)(error)));
245
187
  if (result.isErr()) {
246
188
  return (0, neverthrow.err)(result.error);
247
189
  }
248
190
  schemas.set(name, result.value);
249
191
  }
250
192
  const injectionConfig = new Map();
251
- for (const schemaName of schemas.keys()) {
252
- const adapterPath = adapterPaths.get(schemaName);
253
- const scalarPath = scalarPaths.get(schemaName);
254
- if (!adapterPath || !scalarPath) {
255
- return (0, neverthrow.err)({
256
- code: "INJECT_MODULE_REQUIRED",
257
- message: `Missing adapter or scalar configuration for schema '${schemaName}'`
258
- });
259
- }
260
- const importSpecifierOptions = { includeExtension: options.importExtension };
261
- const metadataAdapterPath = metadataAdapterPaths.get(schemaName);
262
- const helpersPath = helpersPaths.get(schemaName);
193
+ for (const [schemaName, schemaConfig] of Object.entries(options.schemas)) {
194
+ const injectConfig = schemaConfig.inject;
263
195
  injectionConfig.set(schemaName, {
264
- adapterImportPath: toImportSpecifier(outPath, adapterPath, importSpecifierOptions),
265
- scalarImportPath: toImportSpecifier(outPath, scalarPath, importSpecifierOptions),
266
- ...metadataAdapterPath ? { metadataAdapterImportPath: toImportSpecifier(outPath, metadataAdapterPath, importSpecifierOptions) } : {},
267
- ...helpersPath ? { helpersImportPath: toImportSpecifier(outPath, helpersPath, importSpecifierOptions) } : {}
196
+ scalarImportPath: toImportSpecifier(outPath, (0, node_path.resolve)(injectConfig.scalars), importSpecifierOptions),
197
+ ...injectConfig.adapter ? { adapterImportPath: toImportSpecifier(outPath, (0, node_path.resolve)(injectConfig.adapter), importSpecifierOptions) } : {}
268
198
  });
269
199
  }
270
200
  const { code } = require_generator.generateMultiSchemaModule(schemas, { injection: injectionConfig });
271
201
  for (const [name, document] of schemas.entries()) {
272
- const schemaIndex = (await Promise.resolve().then(() => require("./generator-BSnmtzFQ.cjs"))).createSchemaIndex(document);
202
+ const schemaIndex = (await Promise.resolve().then(() => require("./generator-9N1ZJrzm.cjs"))).createSchemaIndex(document);
273
203
  const objects = Array.from(schemaIndex.objects.keys()).filter((n) => !n.startsWith("__")).length;
274
204
  const enums = Array.from(schemaIndex.enums.keys()).filter((n) => !n.startsWith("__")).length;
275
205
  const inputs = Array.from(schemaIndex.inputs.keys()).filter((n) => !n.startsWith("__")).length;
@@ -301,5 +231,6 @@ const runMultiSchemaCodegen = async (options) => {
301
231
  //#endregion
302
232
  exports.hashSchema = hashSchema;
303
233
  exports.loadSchema = loadSchema;
304
- exports.runMultiSchemaCodegen = runMultiSchemaCodegen;
305
- exports.writeInjectTemplate = writeInjectTemplate;
234
+ exports.runCodegen = runCodegen;
235
+ exports.writeInjectTemplate = writeInjectTemplate;
236
+ //# sourceMappingURL=index.cjs.map