@executor-js/plugin-graphql 1.5.6 → 1.5.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/dist/{AddGraphqlSource-P3D3UXRJ.js → AddGraphqlSource-FGT7DNXV.js} +39 -64
  2. package/dist/AddGraphqlSource-FGT7DNXV.js.map +1 -0
  3. package/dist/{EditGraphqlSource-FVF67CTP.js → EditGraphqlSource-QELISUYT.js} +4 -4
  4. package/dist/GraphqlAccountsPanel-U62WSGHR.js +9 -0
  5. package/dist/api/group.d.ts +54 -21
  6. package/dist/api/handlers.d.ts +1 -1
  7. package/dist/api/index.d.ts +55 -22
  8. package/dist/{chunk-N5GJE7R6.js → chunk-732HGFSH.js} +57 -21
  9. package/dist/chunk-732HGFSH.js.map +1 -0
  10. package/dist/{chunk-2Y3J3CVO.js → chunk-HN5FB4DO.js} +35 -55
  11. package/dist/chunk-HN5FB4DO.js.map +1 -0
  12. package/dist/{chunk-VCYDSSIK.js → chunk-OGNJZCEF.js} +27 -28
  13. package/dist/chunk-OGNJZCEF.js.map +1 -0
  14. package/dist/{chunk-ADQTI2OK.js → chunk-OUZI3QNC.js} +119 -124
  15. package/dist/chunk-OUZI3QNC.js.map +1 -0
  16. package/dist/client.js +3 -3
  17. package/dist/core.js +124 -10
  18. package/dist/core.js.map +1 -1
  19. package/dist/index.js +2 -2
  20. package/dist/react/atoms.d.ts +83 -29
  21. package/dist/react/auth-method-config.d.ts +21 -8
  22. package/dist/react/client.d.ts +54 -21
  23. package/dist/react/defaults.d.ts +0 -11
  24. package/dist/sdk/index.d.ts +4 -1
  25. package/dist/sdk/introspection-blob-migration.d.ts +7 -0
  26. package/dist/sdk/migrate-config.d.ts +6 -0
  27. package/dist/sdk/plugin.d.ts +49 -22
  28. package/dist/sdk/store.d.ts +11 -1
  29. package/dist/sdk/types.d.ts +102 -47
  30. package/package.json +3 -3
  31. package/dist/AddGraphqlSource-P3D3UXRJ.js.map +0 -1
  32. package/dist/GraphqlAccountsPanel-GBNFHLFH.js +0 -9
  33. package/dist/chunk-2Y3J3CVO.js.map +0 -1
  34. package/dist/chunk-ADQTI2OK.js.map +0 -1
  35. package/dist/chunk-N5GJE7R6.js.map +0 -1
  36. package/dist/chunk-VCYDSSIK.js.map +0 -1
  37. /package/dist/{EditGraphqlSource-FVF67CTP.js.map → EditGraphqlSource-QELISUYT.js.map} +0 -0
  38. /package/dist/{GraphqlAccountsPanel-GBNFHLFH.js.map → GraphqlAccountsPanel-U62WSGHR.js.map} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/sdk/introspect.ts","../src/sdk/extract.ts","../src/sdk/invoke.ts","../src/sdk/store.ts","../src/sdk/plugin.ts"],"sourcesContent":["import { Effect, Option, Schema } from \"effect\";\nimport { HttpClient, HttpClientRequest } from \"effect/unstable/http\";\n\nimport { GraphqlIntrospectionError } from \"./errors\";\n\n// ---------------------------------------------------------------------------\n// Introspection query — standard GraphQL introspection\n// ---------------------------------------------------------------------------\n\nconst INTROSPECTION_QUERY = `\n query IntrospectionQuery {\n __schema {\n queryType { name }\n mutationType { name }\n types {\n kind\n name\n description\n fields(includeDeprecated: false) {\n name\n description\n args {\n name\n description\n type {\n ...TypeRef\n }\n defaultValue\n }\n type {\n ...TypeRef\n }\n }\n inputFields {\n name\n description\n type {\n ...TypeRef\n }\n defaultValue\n }\n enumValues(includeDeprecated: false) {\n name\n description\n }\n }\n }\n }\n\n fragment TypeRef on __Type {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n }\n }\n }\n }\n }\n }\n }\n`;\n\n// ---------------------------------------------------------------------------\n// Introspection result types\n// ---------------------------------------------------------------------------\n\nconst IntrospectionTypeRefLeaf = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.Null),\n});\n\nconst IntrospectionTypeRef5 = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.NullOr(IntrospectionTypeRefLeaf)),\n});\n\nconst IntrospectionTypeRef4 = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.NullOr(IntrospectionTypeRef5)),\n});\n\nconst IntrospectionTypeRef3 = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.NullOr(IntrospectionTypeRef4)),\n});\n\nconst IntrospectionTypeRef2 = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.NullOr(IntrospectionTypeRef3)),\n});\n\nconst IntrospectionTypeRefSchema = Schema.Struct({\n kind: Schema.String,\n name: Schema.NullOr(Schema.String),\n ofType: Schema.optional(Schema.NullOr(IntrospectionTypeRef2)),\n});\n\nconst IntrospectionInputValueSchema = Schema.Struct({\n name: Schema.String,\n description: Schema.NullOr(Schema.String),\n type: IntrospectionTypeRefSchema,\n defaultValue: Schema.NullOr(Schema.String),\n});\n\nconst IntrospectionFieldSchema = Schema.Struct({\n name: Schema.String,\n description: Schema.NullOr(Schema.String),\n args: Schema.Array(IntrospectionInputValueSchema),\n type: IntrospectionTypeRefSchema,\n});\n\nconst IntrospectionTypeSchema = Schema.Struct({\n kind: Schema.String,\n name: Schema.String,\n description: Schema.NullOr(Schema.String),\n fields: Schema.NullOr(Schema.Array(IntrospectionFieldSchema)),\n inputFields: Schema.NullOr(Schema.Array(IntrospectionInputValueSchema)),\n enumValues: Schema.NullOr(\n Schema.Array(\n Schema.Struct({\n name: Schema.String,\n description: Schema.NullOr(Schema.String),\n }),\n ),\n ),\n});\n\nconst IntrospectionResultSchema = Schema.Struct({\n __schema: Schema.Struct({\n queryType: Schema.NullOr(Schema.Struct({ name: Schema.String })),\n mutationType: Schema.NullOr(Schema.Struct({ name: Schema.String })),\n types: Schema.Array(IntrospectionTypeSchema),\n }),\n});\n\nconst IntrospectionResponseSchema = Schema.Struct({\n data: Schema.optional(IntrospectionResultSchema),\n errors: Schema.optional(Schema.Array(Schema.Unknown)),\n});\n\nconst UpstreamErrorResponseSchema = Schema.Struct({\n message: Schema.optional(Schema.String),\n errors: Schema.optional(\n Schema.Array(\n Schema.Struct({\n message: Schema.optional(Schema.String),\n }),\n ),\n ),\n});\n\nconst IntrospectionJsonSchema = Schema.Union([\n Schema.Struct({ data: IntrospectionResultSchema }),\n IntrospectionResultSchema,\n]);\nconst JsonTextSchema = Schema.fromJsonString(Schema.Unknown);\n\nconst decodeUpstreamErrorResponse = Schema.decodeUnknownOption(UpstreamErrorResponseSchema);\n\nexport type IntrospectionTypeRef = typeof IntrospectionTypeRefSchema.Type;\nexport type IntrospectionInputValue = typeof IntrospectionInputValueSchema.Type;\nexport type IntrospectionField = typeof IntrospectionFieldSchema.Type;\nexport type IntrospectionEnumValue = NonNullable<\n (typeof IntrospectionTypeSchema.Type)[\"enumValues\"]\n>[number];\nexport type IntrospectionType = typeof IntrospectionTypeSchema.Type;\nexport type IntrospectionSchema = (typeof IntrospectionResultSchema.Type)[\"__schema\"];\nexport type IntrospectionResult = typeof IntrospectionResultSchema.Type;\n\nconst firstUpstreamErrorMessage = (value: unknown): string | null => {\n const decoded = decodeUpstreamErrorResponse(value);\n return Option.match(decoded, {\n onNone: () => null,\n onSome: (response) => {\n if (response.message) return response.message;\n for (const entry of response.errors ?? []) {\n const message = entry.message;\n if (message) return message;\n }\n return null;\n },\n });\n};\n\nconst redactUpstreamBody = (body: string): string =>\n body\n .replaceAll(\n /(\"(?:access_token|refresh_token|id_token|client_secret|token|authorization)\"\\s*:\\s*\")[^\"]*(\")/gi,\n \"$1[redacted]$2\",\n )\n .replaceAll(\n /((?:access_token|refresh_token|id_token|client_secret|token|authorization)=)[^&\\s]*/gi,\n \"$1[redacted]\",\n )\n .replaceAll(\n /((?:authorization|access-token|refresh-token|id-token|client-secret|token)\\s*:\\s*)(?:bearer\\s+)?[^\\s,;]+/gi,\n \"$1[redacted]\",\n );\n\nconst upstreamTextMessage = (body: string): string | null => {\n const text = redactUpstreamBody(body.replaceAll(/\\s+/g, \" \").trim());\n if (text.length === 0) return null;\n return text.length > 500 ? `${text.slice(0, 500)}...` : text;\n};\n\n// ---------------------------------------------------------------------------\n// Introspect a GraphQL endpoint\n// ---------------------------------------------------------------------------\n\nexport const introspect = Effect.fn(\"GraphQL.introspect\")(function* (\n endpoint: string,\n headers?: Record<string, string>,\n queryParams?: Record<string, string>,\n) {\n const client = yield* HttpClient.HttpClient;\n const requestEndpoint =\n queryParams && Object.keys(queryParams).length > 0\n ? (() => {\n const url = new URL(endpoint);\n for (const [name, value] of Object.entries(queryParams)) {\n url.searchParams.set(name, value);\n }\n return url.toString();\n })()\n : endpoint;\n\n let request = HttpClientRequest.post(requestEndpoint).pipe(\n HttpClientRequest.setHeader(\"Content-Type\", \"application/json\"),\n HttpClientRequest.setHeader(\"Accept\", \"application/json\"),\n HttpClientRequest.setHeader(\"User-Agent\", \"executor-graphql\"),\n HttpClientRequest.bodyJsonUnsafe({\n query: INTROSPECTION_QUERY,\n }),\n );\n\n if (headers) {\n for (const [k, v] of Object.entries(headers)) {\n request = HttpClientRequest.setHeader(request, k, v);\n }\n }\n\n const response = yield* client.execute(request).pipe(\n Effect.tapCause((cause) => Effect.logError(\"graphql introspection request failed\", cause)),\n Effect.mapError(\n () =>\n new GraphqlIntrospectionError({\n message: \"Failed to reach GraphQL endpoint\",\n }),\n ),\n );\n\n if (response.status !== 200) {\n const responseText = yield* response.text.pipe(Effect.catch(() => Effect.succeed(\"\")));\n const raw = responseText\n ? yield* Schema.decodeUnknownEffect(JsonTextSchema)(responseText).pipe(\n Effect.catch(() => Effect.succeed(null)),\n )\n : null;\n const upstreamMessage = upstreamTextMessage(\n (raw === null ? null : firstUpstreamErrorMessage(raw)) ?? responseText,\n );\n return yield* new GraphqlIntrospectionError({\n message: upstreamMessage\n ? `Introspection failed with status ${response.status}: ${upstreamMessage}`\n : `Introspection failed with status ${response.status}`,\n });\n }\n\n const raw = yield* response.json.pipe(\n Effect.tapCause((cause) => Effect.logError(\"graphql introspection JSON parse failed\", cause)),\n Effect.mapError(\n () =>\n new GraphqlIntrospectionError({\n message: `Failed to parse introspection response as JSON`,\n }),\n ),\n );\n\n const json = yield* Schema.decodeUnknownEffect(IntrospectionResponseSchema)(raw).pipe(\n Effect.mapError(\n () =>\n new GraphqlIntrospectionError({\n message: \"Introspection response has an invalid shape\",\n }),\n ),\n );\n\n if (json.errors && Array.isArray(json.errors) && json.errors.length > 0) {\n const upstreamMessage = firstUpstreamErrorMessage(json);\n return yield* new GraphqlIntrospectionError({\n message: upstreamMessage\n ? `Introspection returned ${json.errors.length} error(s): ${upstreamMessage}`\n : `Introspection returned ${json.errors.length} error(s)`,\n });\n }\n\n if (!json.data?.__schema) {\n return yield* new GraphqlIntrospectionError({\n message: \"Introspection response missing __schema\",\n });\n }\n\n return json.data;\n});\n\n// ---------------------------------------------------------------------------\n// Parse an introspection result from a JSON string (for offline/text input)\n// ---------------------------------------------------------------------------\n\nexport const parseIntrospectionJson = (\n text: string,\n): Effect.Effect<IntrospectionResult, GraphqlIntrospectionError> =>\n Schema.decodeUnknownEffect(Schema.fromJsonString(IntrospectionJsonSchema))(text).pipe(\n Effect.map((parsed) => (\"data\" in parsed ? parsed.data : parsed)),\n Effect.mapError(\n () =>\n new GraphqlIntrospectionError({\n message: \"Failed to parse introspection JSON\",\n }),\n ),\n );\n","import { Effect, Match, Option } from \"effect\";\n\nimport { GraphqlExtractionError } from \"./errors\";\nimport type {\n IntrospectionResult,\n IntrospectionSchema,\n IntrospectionType,\n IntrospectionTypeRef,\n IntrospectionInputValue,\n} from \"./introspect\";\nimport {\n ExtractedField,\n ExtractionResult,\n GraphqlArgument,\n type GraphqlOperationKind,\n} from \"./types\";\n\n// ---------------------------------------------------------------------------\n// Type ref helpers\n// ---------------------------------------------------------------------------\n\n/** Unwrap NON_NULL / LIST wrappers to get the leaf type name */\nconst unwrapTypeName = (ref: IntrospectionTypeRef): string => {\n if (ref.name) return ref.name;\n if (ref.ofType) return unwrapTypeName(ref.ofType);\n return \"Unknown\";\n};\n\n/** Check if a type ref is non-null (required) */\nconst isNonNull = (ref: IntrospectionTypeRef): boolean => ref.kind === \"NON_NULL\";\n\n// ---------------------------------------------------------------------------\n// Build shared definitions from all INPUT_OBJECT and ENUM types\n// ---------------------------------------------------------------------------\n\nconst buildDefinitions = (\n types: ReadonlyMap<string, IntrospectionType>,\n): Record<string, unknown> => {\n const defs: Record<string, unknown> = {};\n\n for (const [name, type] of types) {\n // Skip internal types\n if (name.startsWith(\"__\")) continue;\n\n if (type.kind === \"INPUT_OBJECT\" && type.inputFields) {\n const properties: Record<string, unknown> = {};\n const required: string[] = [];\n\n for (const field of type.inputFields) {\n const schema = typeRefToJsonSchema(field.type, types);\n if (field.description) {\n (schema as Record<string, unknown>).description = field.description;\n }\n properties[field.name] = schema;\n if (isNonNull(field.type)) {\n required.push(field.name);\n }\n }\n\n const def: Record<string, unknown> = { type: \"object\", properties };\n if (required.length > 0) def.required = required;\n if (type.description) def.description = type.description;\n defs[name] = def;\n }\n\n if (type.kind === \"ENUM\" && type.enumValues) {\n defs[name] = {\n type: \"string\",\n enum: type.enumValues.map((v) => v.name),\n ...(type.description ? { description: type.description } : {}),\n };\n }\n }\n\n return defs;\n};\n\n// ---------------------------------------------------------------------------\n// Convert a type ref to JSON Schema using $ref for complex types\n// ---------------------------------------------------------------------------\n\nconst typeRefToJsonSchema = (\n ref: IntrospectionTypeRef,\n // oxlint-disable-next-line only-used-in-recursion\n types: ReadonlyMap<string, IntrospectionType>,\n): Record<string, unknown> =>\n Match.value(ref.kind).pipe(\n Match.when(\n \"NON_NULL\",\n (): Record<string, unknown> => (ref.ofType ? typeRefToJsonSchema(ref.ofType, types) : {}),\n ),\n Match.when(\n \"LIST\",\n (): Record<string, unknown> => ({\n type: \"array\",\n items: ref.ofType ? typeRefToJsonSchema(ref.ofType, types) : {},\n }),\n ),\n Match.when(\"SCALAR\", (): Record<string, unknown> => scalarToJsonSchema(ref.name ?? \"String\")),\n Match.when(\n \"ENUM\",\n (): Record<string, unknown> =>\n ref.name ? { $ref: `#/$defs/${ref.name}` } : { type: \"string\" },\n ),\n Match.when(\n \"INPUT_OBJECT\",\n (): Record<string, unknown> =>\n ref.name ? { $ref: `#/$defs/${ref.name}` } : { type: \"object\" },\n ),\n Match.whenOr(\n \"OBJECT\",\n \"INTERFACE\",\n \"UNION\",\n (): Record<string, unknown> => ({ type: \"object\" }),\n ),\n Match.option,\n Option.getOrElse((): Record<string, unknown> => ({})),\n );\n\nconst scalarToJsonSchema = (name: string): Record<string, unknown> =>\n Match.value(name).pipe(\n Match.whenOr(\"String\", \"ID\", (): Record<string, unknown> => ({ type: \"string\" })),\n Match.when(\"Int\", (): Record<string, unknown> => ({ type: \"integer\" })),\n Match.when(\"Float\", (): Record<string, unknown> => ({ type: \"number\" })),\n Match.when(\"Boolean\", (): Record<string, unknown> => ({ type: \"boolean\" })),\n Match.option,\n Option.getOrElse(\n (): Record<string, unknown> => ({ type: \"string\", description: `Custom scalar: ${name}` }),\n ),\n );\n\n// ---------------------------------------------------------------------------\n// Build input JSON Schema from field arguments\n// ---------------------------------------------------------------------------\n\nconst buildInputSchema = (\n args: readonly IntrospectionInputValue[],\n types: ReadonlyMap<string, IntrospectionType>,\n): Record<string, unknown> | undefined => {\n if (args.length === 0) return undefined;\n\n const properties: Record<string, unknown> = {};\n const required: string[] = [];\n\n for (const arg of args) {\n const schema = typeRefToJsonSchema(arg.type, types);\n if (arg.description) {\n (schema as Record<string, unknown>).description = arg.description;\n }\n properties[arg.name] = schema;\n if (isNonNull(arg.type)) {\n required.push(arg.name);\n }\n }\n\n const inputSchema: Record<string, unknown> = {\n type: \"object\",\n properties,\n };\n if (required.length > 0) inputSchema.required = required;\n return inputSchema;\n};\n\n/** Format a type ref back to GraphQL type notation (e.g. \"[String!]!\") */\nconst formatTypeRef = (ref: IntrospectionTypeRef): string =>\n Match.value(ref.kind).pipe(\n Match.when(\"NON_NULL\", () => (ref.ofType ? `${formatTypeRef(ref.ofType)}!` : \"Unknown!\")),\n Match.when(\"LIST\", () => (ref.ofType ? `[${formatTypeRef(ref.ofType)}]` : \"[Unknown]\")),\n Match.option,\n Option.getOrElse(() => ref.name ?? \"Unknown\"),\n );\n\n// ---------------------------------------------------------------------------\n// Extract fields from schema\n// ---------------------------------------------------------------------------\n\nconst extractFields = (\n _schema: IntrospectionSchema,\n kind: GraphqlOperationKind,\n typeName: string | null | undefined,\n types: ReadonlyMap<string, IntrospectionType>,\n): ExtractedField[] => {\n if (!typeName) return [];\n\n const type = types.get(typeName);\n if (!type?.fields) return [];\n\n return type.fields\n .filter((f) => !f.name.startsWith(\"__\"))\n .map((field) => {\n const args = field.args.map((arg) =>\n GraphqlArgument.make({\n name: arg.name,\n typeName: formatTypeRef(arg.type),\n required: isNonNull(arg.type),\n description: arg.description ? Option.some(arg.description) : Option.none(),\n }),\n );\n\n const inputSchema = buildInputSchema(field.args, types);\n\n return ExtractedField.make({\n fieldName: field.name,\n kind,\n description: field.description ? Option.some(field.description) : Option.none(),\n arguments: args,\n inputSchema: inputSchema ? Option.some(inputSchema) : Option.none(),\n returnTypeName: unwrapTypeName(field.type),\n });\n });\n};\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\nexport interface ExtractionOutput {\n readonly result: ExtractionResult;\n /** Shared JSON Schema definitions for INPUT_OBJECT and ENUM types.\n * Tool input schemas use `$ref` pointers into these. */\n readonly definitions: Record<string, unknown>;\n}\n\nexport const extract = (\n introspection: IntrospectionResult,\n): Effect.Effect<ExtractionOutput, GraphqlExtractionError> =>\n Effect.try({\n try: () => {\n const schema = introspection.__schema;\n const typeMap = new Map<string, IntrospectionType>();\n for (const t of schema.types) {\n typeMap.set(t.name, t);\n }\n\n const definitions = buildDefinitions(typeMap);\n\n const queryFields = extractFields(schema, \"query\", schema.queryType?.name, typeMap);\n const mutationFields = extractFields(schema, \"mutation\", schema.mutationType?.name, typeMap);\n\n return {\n result: ExtractionResult.make({\n schemaName: Option.none(),\n fields: [...queryFields, ...mutationFields],\n }),\n definitions,\n };\n },\n catch: () =>\n new GraphqlExtractionError({\n message: \"Failed to extract GraphQL schema\",\n }),\n });\n","import { Effect, Layer, Option } from \"effect\";\nimport { HttpClient, HttpClientRequest } from \"effect/unstable/http\";\n\nimport { GraphqlInvocationError } from \"./errors\";\nimport { type OperationBinding, InvocationResult } from \"./types\";\n\nconst endpointWithQueryParams = (endpoint: string, queryParams: Record<string, string>): string => {\n if (Object.keys(queryParams).length === 0) return endpoint;\n const url = new URL(endpoint);\n for (const [name, value] of Object.entries(queryParams)) {\n url.searchParams.set(name, value);\n }\n return url.toString();\n};\n\nexport const endpointForTelemetry = (endpoint: string): string => {\n if (!URL.canParse(endpoint)) return endpoint;\n const url = new URL(endpoint);\n url.search = \"\";\n url.hash = \"\";\n return url.toString();\n};\n\n// ---------------------------------------------------------------------------\n// Response helpers\n// ---------------------------------------------------------------------------\n\nconst isJsonContentType = (ct: string | null | undefined): boolean => {\n if (!ct) return false;\n const normalized = ct.split(\";\")[0]?.trim().toLowerCase() ?? \"\";\n return (\n normalized === \"application/json\" || normalized.includes(\"+json\") || normalized.includes(\"json\")\n );\n};\n\n// ---------------------------------------------------------------------------\n// Public API — execute a GraphQL operation\n// ---------------------------------------------------------------------------\n\nexport const invoke = Effect.fn(\"GraphQL.invoke\")(function* (\n operation: OperationBinding,\n args: Record<string, unknown>,\n endpoint: string,\n resolvedHeaders: Record<string, string>,\n resolvedQueryParams: Record<string, string> = {},\n) {\n const client = yield* HttpClient.HttpClient;\n const requestEndpoint = endpointWithQueryParams(endpoint, resolvedQueryParams);\n const telemetryEndpoint = endpointForTelemetry(endpoint);\n\n yield* Effect.annotateCurrentSpan({\n \"http.method\": \"POST\",\n \"http.url\": telemetryEndpoint,\n \"plugin.graphql.endpoint\": telemetryEndpoint,\n \"plugin.graphql.operation_kind\": operation.kind,\n \"plugin.graphql.field_name\": operation.fieldName,\n \"plugin.graphql.headers.resolved_count\": Object.keys(resolvedHeaders).length,\n \"plugin.graphql.query_params.resolved_count\": Object.keys(resolvedQueryParams).length,\n });\n\n // Build the GraphQL request body\n const variables: Record<string, unknown> = {};\n for (const varName of operation.variableNames) {\n if (args[varName] !== undefined) {\n variables[varName] = args[varName];\n }\n }\n\n // Also pick up any variables from a \"variables\" container\n if (typeof args.variables === \"object\" && args.variables !== null) {\n Object.assign(variables, args.variables);\n }\n\n let request = HttpClientRequest.post(requestEndpoint).pipe(\n HttpClientRequest.setHeader(\"Content-Type\", \"application/json\"),\n HttpClientRequest.bodyJsonUnsafe({\n query: operation.operationString,\n variables: Object.keys(variables).length > 0 ? variables : undefined,\n }),\n );\n\n for (const [name, value] of Object.entries(resolvedHeaders)) {\n request = HttpClientRequest.setHeader(request, name, value);\n }\n\n const response = yield* client.execute(request).pipe(\n Effect.mapError(\n (err) =>\n new GraphqlInvocationError({\n message: \"GraphQL request failed\",\n statusCode: Option.none(),\n cause: err,\n }),\n ),\n );\n\n const status = response.status;\n const contentType = response.headers[\"content-type\"] ?? null;\n\n const body: unknown = isJsonContentType(contentType)\n ? yield* response.json.pipe(Effect.catch(() => response.text))\n : yield* response.text;\n\n // GraphQL responses are always 200 with { data, errors }\n const gqlBody = body as { data?: unknown; errors?: unknown[] } | null;\n const hasErrors = Array.isArray(gqlBody?.errors) && gqlBody.errors.length > 0;\n\n yield* Effect.annotateCurrentSpan({\n \"http.status_code\": status,\n \"plugin.graphql.has_errors\": hasErrors,\n \"plugin.graphql.error_count\": hasErrors ? gqlBody!.errors!.length : 0,\n });\n\n return InvocationResult.make({\n status,\n data: gqlBody?.data ?? null,\n errors: hasErrors ? gqlBody!.errors : null,\n });\n});\n\n// ---------------------------------------------------------------------------\n// Invoke a GraphQL operation with a provided HttpClient layer\n// ---------------------------------------------------------------------------\n\nexport const invokeWithLayer = (\n operation: OperationBinding,\n args: Record<string, unknown>,\n endpoint: string,\n resolvedHeaders: Record<string, string>,\n resolvedQueryParams: Record<string, string>,\n httpClientLayer: Layer.Layer<HttpClient.HttpClient>,\n) =>\n invoke(operation, args, endpoint, resolvedHeaders, resolvedQueryParams).pipe(\n Effect.provide(httpClientLayer),\n Effect.withSpan(\"plugin.graphql.invoke\", {\n attributes: {\n \"plugin.graphql.endpoint\": endpointForTelemetry(endpoint),\n \"plugin.graphql.operation_kind\": operation.kind,\n \"plugin.graphql.field_name\": operation.fieldName,\n },\n }),\n );\n","import { Effect, Option, Predicate, Schema } from \"effect\";\n\nimport {\n type Owner,\n type PluginStorageEntry,\n type StorageDeps,\n type StorageFailure,\n} from \"@executor-js/sdk/core\";\n\nimport { OperationBinding } from \"./types\";\n\n// ---------------------------------------------------------------------------\n// Per-integration operation bindings.\n//\n// In v2 the integration's GraphQL operations are derived from introspection and\n// are identical for every connection, so the plugin store keeps one set of\n// operation bindings per integration slug — `invokeTool` reads them back to\n// rebuild the request. Operations are catalog-level metadata, so they live under\n// the shared `owner: \"org\"` partition.\n// ---------------------------------------------------------------------------\n\nconst CATALOG_OWNER: Owner = \"org\";\nconst OPERATION_COLLECTION = \"operation\";\n\nexport interface StoredOperation {\n /** The tool's leaf name, e.g. `query.hello`. */\n readonly toolName: string;\n /** The owning integration slug. */\n readonly integration: string;\n readonly binding: OperationBinding;\n}\n\nconst OperationBindingFromJsonString = Schema.fromJsonString(OperationBinding);\nconst decodeOperationBindingFromJsonString = Schema.decodeUnknownSync(\n OperationBindingFromJsonString,\n);\nconst decodeOperationBinding = Schema.decodeUnknownSync(OperationBinding);\nconst encodeBinding = Schema.encodeSync(OperationBinding);\n\nconst decodeBinding = (value: unknown): OperationBinding => {\n if (typeof value === \"string\") return decodeOperationBindingFromJsonString(value);\n return decodeOperationBinding(value);\n};\n\nconst toJsonRecord = (value: unknown): Record<string, unknown> => value as Record<string, unknown>;\n\nconst OperationStorage = Schema.Struct({\n toolName: Schema.String,\n integration: Schema.String,\n binding: Schema.Unknown,\n});\nconst decodeOperationStorage = Schema.decodeUnknownOption(OperationStorage);\n\nconst operationKey = (integration: string, toolName: string): string =>\n `${integration}.${toolName}`;\n\nconst operationData = (operation: StoredOperation) => ({\n toolName: operation.toolName,\n integration: operation.integration,\n binding: toJsonRecord(encodeBinding(operation.binding)),\n});\n\nconst rowToOperation = (row: PluginStorageEntry): StoredOperation | null => {\n const decoded = decodeOperationStorage(row.data);\n if (Option.isNone(decoded)) return null;\n const operation = decoded.value;\n return {\n toolName: operation.toolName,\n integration: operation.integration,\n binding: decodeBinding(operation.binding),\n };\n};\n\n/** Blob key for an introspection snapshot's content hash. Content-addressed\n * so re-puts are idempotent and identical schemas share one blob per\n * partition. */\nexport const introspectionBlobKey = (introspectionHash: string): string =>\n `introspection/${introspectionHash}`;\n\nexport interface GraphqlStore {\n /** Replace the stored operation bindings for an integration. */\n readonly replaceOperations: (\n integration: string,\n operations: readonly StoredOperation[],\n ) => Effect.Effect<void, StorageFailure>;\n readonly getOperation: (\n integration: string,\n toolName: string,\n ) => Effect.Effect<StoredOperation | null, StorageFailure>;\n readonly listOperations: (\n integration: string,\n ) => Effect.Effect<readonly StoredOperation[], StorageFailure>;\n readonly removeOperations: (integration: string) => Effect.Effect<void, StorageFailure>;\n /** Persist an introspection JSON snapshot under its content hash. Org-owned\n * and content-addressed; never removed on integration removal because\n * another integration in the tenant may share the hash. */\n readonly putIntrospection: (\n introspectionHash: string,\n introspectionJson: string,\n ) => Effect.Effect<void, StorageFailure>;\n /** Load an introspection snapshot by content hash; null when absent. */\n readonly getIntrospection: (\n introspectionHash: string,\n ) => Effect.Effect<string | null, StorageFailure>;\n}\n\nexport const makeDefaultGraphqlStore = ({ pluginStorage, blobs }: StorageDeps): GraphqlStore => {\n const listOperationRows = (integration: string) =>\n pluginStorage\n .list({\n collection: OPERATION_COLLECTION,\n keyPrefix: `${integration}.`,\n })\n .pipe(\n Effect.map((rows) =>\n rows.filter((row) => rowToOperation(row)?.integration === integration),\n ),\n );\n\n const removeOperations = (integration: string) =>\n Effect.gen(function* () {\n const rows = yield* listOperationRows(integration);\n for (const row of rows) {\n yield* pluginStorage.remove({\n owner: CATALOG_OWNER,\n collection: OPERATION_COLLECTION,\n key: row.key,\n });\n }\n });\n\n return {\n replaceOperations: (integration, operations) =>\n Effect.gen(function* () {\n yield* removeOperations(integration);\n for (const operation of operations) {\n yield* pluginStorage.put({\n owner: CATALOG_OWNER,\n collection: OPERATION_COLLECTION,\n key: operationKey(integration, operation.toolName),\n data: operationData(operation),\n });\n }\n }),\n\n getOperation: (integration, toolName) =>\n pluginStorage\n .get({ collection: OPERATION_COLLECTION, key: operationKey(integration, toolName) })\n .pipe(Effect.map((row) => (row ? rowToOperation(row) : null))),\n\n listOperations: (integration) =>\n listOperationRows(integration).pipe(\n Effect.map((rows) => rows.map(rowToOperation).filter(Predicate.isNotNull)),\n ),\n\n removeOperations,\n\n putIntrospection: (introspectionHash, introspectionJson) =>\n blobs.put(introspectionBlobKey(introspectionHash), introspectionJson, {\n owner: CATALOG_OWNER,\n }),\n\n getIntrospection: (introspectionHash) => blobs.get(introspectionBlobKey(introspectionHash)),\n };\n};\n","import { Effect, Match, Option, Schema } from \"effect\";\nimport type { Layer } from \"effect\";\nimport { FetchHttpClient, HttpClient } from \"effect/unstable/http\";\n\nimport {\n authToolFailure,\n AuthTemplateSlug,\n definePlugin,\n IntegrationAlreadyExistsError,\n IntegrationDetectionResult,\n IntegrationSlug,\n mergeAuthTemplates,\n sha256Hex,\n ToolName,\n ToolResult,\n type AuthMethodDescriptor,\n type IntegrationConfig,\n type IntegrationRecord,\n type PluginCtx,\n type StorageFailure,\n type ToolAnnotations,\n type ToolDef,\n} from \"@executor-js/sdk/core\";\n\nimport {\n TOKEN_VARIABLE,\n describeApiKeyAuthMethod,\n describeNoneAuthMethod,\n oauthBearerPlacement,\n renderAuthPlacements,\n requiredPlacementVariables,\n type RenderedAuthPlacements,\n} from \"@executor-js/sdk/http-auth\";\n\nimport {\n introspect,\n parseIntrospectionJson,\n type IntrospectionResult,\n type IntrospectionType,\n type IntrospectionField,\n type IntrospectionTypeRef,\n} from \"./introspect\";\nimport { extract } from \"./extract\";\nimport {\n GraphqlAuthRequiredError,\n GraphqlIntrospectionError,\n GraphqlInvocationError,\n} from \"./errors\";\nimport { invokeWithLayer } from \"./invoke\";\nimport { graphqlPresets } from \"./presets\";\nimport { makeDefaultGraphqlStore, type GraphqlStore, type StoredOperation } from \"./store\";\nimport {\n GraphqlAuthMethodInput,\n decodeGraphqlIntegrationConfig,\n decodeGraphqlIntegrationConfigOption,\n ExtractedField,\n GraphqlIntegrationConfig,\n expandGraphqlAuthMethodInputs,\n normalizeGraphqlAuthMethods,\n OperationBinding,\n type GraphqlAuthMethod,\n type GraphqlOperationKind,\n} from \"./types\";\n\n// ---------------------------------------------------------------------------\n// GraphQL error-body decoding (for invocation responses)\n// ---------------------------------------------------------------------------\n\nconst GraphqlErrorBody = Schema.Struct({ message: Schema.String });\nconst GraphqlErrorsBody = Schema.Array(Schema.Unknown);\nconst decodeGraphqlErrorBody = Schema.decodeUnknownOption(GraphqlErrorBody);\nconst decodeGraphqlErrorsBody = Schema.decodeUnknownOption(GraphqlErrorsBody);\n\nconst decodeGraphqlErrors = (errors: unknown): readonly unknown[] | undefined =>\n Option.getOrUndefined(decodeGraphqlErrorsBody(errors));\n\nconst extractGraphqlErrorMessage = (errors: readonly unknown[]): string | undefined =>\n errors\n .map((error) => Option.getOrUndefined(decodeGraphqlErrorBody(error))?.message)\n .find((message) => message !== undefined && message.length > 0);\n\nconst GRAPHQL_PLUGIN_ID = \"graphql\";\n\n// ---------------------------------------------------------------------------\n// Extension input shapes\n// ---------------------------------------------------------------------------\n\n/** Register a GraphQL integration in the catalog. `endpoint` is the GraphQL URL;\n * `slug` (defaulted from the endpoint) is the catalog id; `introspectionJson`\n * supplies the schema when the endpoint disables live introspection; `headers`\n * / `queryParams` are static and also applied to add-time introspection;\n * `authenticationTemplate` declares the auth methods a connection can apply\n * through. */\nconst GraphqlAddIntegrationInputSchema = Schema.Struct({\n endpoint: Schema.String,\n slug: Schema.optional(Schema.String),\n name: Schema.optional(Schema.String),\n introspectionJson: Schema.optional(Schema.String),\n headers: Schema.optional(Schema.Record(Schema.String, Schema.String)),\n queryParams: Schema.optional(Schema.Record(Schema.String, Schema.String)),\n authenticationTemplate: Schema.optional(Schema.Array(GraphqlAuthMethodInput)),\n});\nexport type GraphqlAddIntegrationInput = typeof GraphqlAddIntegrationInputSchema.Type;\n\nconst GraphqlConfigureInputSchema = Schema.Struct({\n name: Schema.optional(Schema.String),\n endpoint: Schema.optional(Schema.String),\n headers: Schema.optional(Schema.Record(Schema.String, Schema.String)),\n queryParams: Schema.optional(Schema.Record(Schema.String, Schema.String)),\n authenticationTemplate: Schema.optional(Schema.Array(GraphqlAuthMethodInput)),\n});\nexport type GraphqlConfigureInput = typeof GraphqlConfigureInputSchema.Type;\n\n/** Input for the custom-method-create flow (HTTP `POST /graphql/integrations/\n * :slug/config`). Unlike `configure` (which REPLACES the whole config for the\n * generic repair path), `configureAuth` MERGE-APPENDS these methods onto the\n * integration's existing `authenticationTemplate`, mirroring OpenAPI's\n * `configure`. */\nconst GraphqlConfigureAuthInputSchema = Schema.Struct({\n authenticationTemplate: Schema.Array(GraphqlAuthMethodInput),\n mode: Schema.optional(Schema.Literals([\"merge\", \"replace\"])),\n});\nexport type GraphqlConfigureAuthInput = typeof GraphqlConfigureAuthInputSchema.Type;\n\n// ---------------------------------------------------------------------------\n// Static control-tool schemas\n// ---------------------------------------------------------------------------\n\nconst StaticAddIntegrationOutputSchema = Schema.Struct({\n slug: Schema.String,\n name: Schema.String,\n});\nconst StaticGetIntegrationInputSchema = Schema.Struct({\n slug: Schema.String,\n});\nconst StaticGetIntegrationOutputSchema = Schema.Struct({\n integration: Schema.NullOr(Schema.Unknown),\n});\n\nconst StaticAddIntegrationInputStandardSchema = Schema.toStandardSchemaV1(\n Schema.toStandardJSONSchemaV1(GraphqlAddIntegrationInputSchema),\n);\nconst StaticAddIntegrationOutputStandardSchema = Schema.toStandardSchemaV1(\n Schema.toStandardJSONSchemaV1(StaticAddIntegrationOutputSchema),\n);\nconst StaticGetIntegrationInputStandardSchema = Schema.toStandardSchemaV1(\n Schema.toStandardJSONSchemaV1(StaticGetIntegrationInputSchema),\n);\nconst StaticGetIntegrationOutputStandardSchema = Schema.toStandardSchemaV1(\n Schema.toStandardJSONSchemaV1(StaticGetIntegrationOutputSchema),\n);\n\nconst graphqlToolFailure = (code: string, message: string, details?: unknown) =>\n ToolResult.fail({\n code,\n message,\n ...(details === undefined ? {} : { details }),\n });\n\nconst graphqlAuthToolFailure = (failure: GraphqlAuthRequiredError) =>\n authToolFailure({\n code: failure.code,\n message: failure.message,\n source: { id: failure.integration, scope: failure.owner },\n credential: {\n kind: failure.credentialKind,\n ...(failure.credentialLabel ? { label: failure.credentialLabel } : {}),\n connectionId: failure.connection,\n },\n ...(failure.status !== undefined ? { status: failure.status } : {}),\n ...(failure.details !== undefined\n ? {\n upstream: {\n ...(failure.status !== undefined ? { status: failure.status } : {}),\n details: failure.details,\n },\n }\n : {}),\n });\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\n/** Match `token` as a separator-bounded run inside a URL hostname or path,\n * used as a low-confidence detection hint when introspection fails. */\nconst urlMatchesToken = (url: URL, token: string): boolean => {\n const re = new RegExp(`(?:^|[^a-z0-9])${token}(?:$|[^a-z0-9])`, \"i\");\n return re.test(url.hostname) || re.test(url.pathname);\n};\n\n/** Derive an integration slug from an endpoint URL. */\nconst slugFromEndpoint = (endpoint: string): string => {\n // oxlint-disable-next-line executor/no-try-catch-or-throw -- boundary: URL construction throws; this helper intentionally falls back to the stable default slug\n try {\n const url = new URL(endpoint);\n return url.hostname.replace(/[^a-z0-9]+/gi, \"_\").toLowerCase();\n } catch {\n return \"graphql\";\n }\n};\n\nconst formatTypeRef = (ref: IntrospectionTypeRef): string =>\n Match.value(ref.kind).pipe(\n Match.when(\"NON_NULL\", () => (ref.ofType ? `${formatTypeRef(ref.ofType)}!` : \"Unknown!\")),\n Match.when(\"LIST\", () => (ref.ofType ? `[${formatTypeRef(ref.ofType)}]` : \"[Unknown]\")),\n Match.option,\n Option.getOrElse(() => ref.name ?? \"Unknown\"),\n );\n\nconst unwrapTypeName = (ref: IntrospectionTypeRef): string => {\n if (ref.name) return ref.name;\n if (ref.ofType) return unwrapTypeName(ref.ofType);\n return \"Unknown\";\n};\n\nconst buildSelectionSet = (\n ref: IntrospectionTypeRef,\n types: ReadonlyMap<string, IntrospectionType>,\n depth: number,\n seen: Set<string>,\n): string => {\n if (depth > 2) return \"\";\n\n const leafName = unwrapTypeName(ref);\n if (seen.has(leafName)) return \"\";\n\n const objectType = types.get(leafName);\n if (!objectType?.fields) return \"\";\n\n const kind = objectType.kind;\n if (kind === \"SCALAR\" || kind === \"ENUM\") return \"\";\n\n seen.add(leafName);\n\n const subFields = objectType.fields\n .filter((f: IntrospectionField) => !f.name.startsWith(\"__\"))\n .slice(0, 12)\n .map((f: IntrospectionField) => {\n const sub = buildSelectionSet(f.type, types, depth + 1, seen);\n return sub ? `${f.name} ${sub}` : f.name;\n });\n\n seen.delete(leafName);\n\n return subFields.length > 0 ? `{ ${subFields.join(\" \")} }` : \"\";\n};\n\n// Name every generated operation: some servers reject anonymous operations, and\n// APM tooling keys traces off the operation name. Field names are already valid\n// GraphQL name tokens, so the upper-cased field name is a safe operation name.\nconst operationNameForField = (fieldName: string): string =>\n fieldName.charAt(0).toUpperCase() + fieldName.slice(1);\n\nconst buildOperationStringForField = (\n kind: GraphqlOperationKind,\n field: IntrospectionField,\n types: ReadonlyMap<string, IntrospectionType>,\n): string => {\n const opType = kind === \"query\" ? \"query\" : \"mutation\";\n const opName = operationNameForField(field.name);\n\n const varDefs = field.args.map((arg) => {\n const typeName = formatTypeRef(arg.type);\n return `$${arg.name}: ${typeName}`;\n });\n\n const argPasses = field.args.map((arg) => `${arg.name}: $${arg.name}`);\n const selectionSet = buildSelectionSet(field.type, types, 0, new Set());\n\n const varDefsStr = varDefs.length > 0 ? `(${varDefs.join(\", \")})` : \"\";\n const argPassStr = argPasses.length > 0 ? `(${argPasses.join(\", \")})` : \"\";\n\n return `${opType} ${opName}${varDefsStr} { ${field.name}${argPassStr}${selectionSet ? ` ${selectionSet}` : \"\"} }`;\n};\n\ninterface PreparedOperation {\n readonly toolName: string;\n readonly description: string;\n readonly inputSchema: unknown;\n readonly binding: OperationBinding;\n}\n\nconst prepareOperations = (\n fields: readonly ExtractedField[],\n introspection: IntrospectionResult,\n): readonly PreparedOperation[] => {\n const typeMap = new Map<string, IntrospectionType>();\n for (const t of introspection.__schema.types) {\n typeMap.set(t.name, t);\n }\n\n const fieldMap = new Map<string, { kind: GraphqlOperationKind; field: IntrospectionField }>();\n const schema = introspection.__schema;\n for (const rootKind of [\"query\", \"mutation\"] as const) {\n const typeName = rootKind === \"query\" ? schema.queryType?.name : schema.mutationType?.name;\n if (!typeName) continue;\n const rootType = typeMap.get(typeName);\n if (!rootType?.fields) continue;\n for (const f of rootType.fields) {\n if (!f.name.startsWith(\"__\")) {\n fieldMap.set(`${rootKind}.${f.name}`, { kind: rootKind, field: f });\n }\n }\n }\n\n return fields.map((extracted) => {\n const prefix = extracted.kind === \"mutation\" ? \"mutation\" : \"query\";\n // A tool's name keeps its `<kind>.<field>` path (e.g. `query.hello`,\n // `mutation.setGreeting`). The address grammar treats `<tool>` as the\n // trailing remainder (see parseToolAddress), so the dot nests naturally.\n const toolName = `${prefix}.${extracted.fieldName}`;\n const description = Option.getOrElse(\n extracted.description,\n () => `GraphQL ${extracted.kind}: ${extracted.fieldName} -> ${extracted.returnTypeName}`,\n );\n\n const key = `${extracted.kind}.${extracted.fieldName}`;\n const entry = fieldMap.get(key);\n const operationString = entry\n ? buildOperationStringForField(entry.kind, entry.field, typeMap)\n : `${extracted.kind} ${operationNameForField(extracted.fieldName)} { ${extracted.fieldName} }`;\n\n const binding = OperationBinding.make({\n kind: extracted.kind,\n fieldName: extracted.fieldName,\n operationString,\n variableNames: extracted.arguments.map((a) => a.name),\n });\n\n return {\n toolName,\n description,\n inputSchema: Option.getOrUndefined(extracted.inputSchema),\n binding,\n };\n });\n};\n\nconst annotationsFor = (binding: OperationBinding): ToolAnnotations => {\n if (binding.kind === \"mutation\") {\n return {\n requiresApproval: true,\n approvalDescription: `mutation ${binding.fieldName}`,\n };\n }\n return {};\n};\n\n// ---------------------------------------------------------------------------\n// Auth method rendering (D11) — apply the connection's resolved values through\n// the method the connection references. An oauth2 method is the conventional\n// bearer placement (with the method's optional header/prefix override) over\n// the resolved access token; an apikey method renders its declared placements.\n// ---------------------------------------------------------------------------\n\nconst renderGraphqlAuthMethod = (\n method: GraphqlAuthMethod,\n values: Record<string, string | null>,\n): RenderedAuthPlacements => {\n if (method.kind === \"apikey\") return renderAuthPlacements(method.placements, values);\n if (method.kind === \"oauth2\") {\n return renderAuthPlacements([oauthBearerPlacement(method.header, method.prefix)], values);\n }\n return { headers: {}, queryParams: {} };\n};\n\n// ---------------------------------------------------------------------------\n// Introspection — produce operations from a config (live or stored JSON).\n// ---------------------------------------------------------------------------\n\nconst buildToolDefs = (prepared: readonly PreparedOperation[]): readonly ToolDef[] =>\n prepared.map((p) => ({\n name: ToolName.make(p.toolName),\n description: p.description,\n inputSchema: p.inputSchema,\n annotations: annotationsFor(p.binding),\n }));\n\nconst toStoredOperations = (\n slug: IntegrationSlug,\n prepared: readonly PreparedOperation[],\n): StoredOperation[] =>\n prepared.map((p) => ({\n toolName: p.toolName,\n integration: String(slug),\n binding: p.binding,\n }));\n\n/** Render an integration's static + resolved-credential auth onto introspection\n * headers/query params. Connection-create / tool-generation introspection runs\n * with the connection's credential (exactly how its tools are invoked), so an\n * auth-required endpoint introspects successfully here rather than at add-time. */\nconst introspectHeadersForConnection = (\n config: GraphqlIntegrationConfig,\n values: Record<string, string | null>,\n templateSlug: AuthTemplateSlug | null,\n): RenderedAuthPlacements => {\n const headers: Record<string, string> = { ...(config.headers ?? {}) };\n const queryParams: Record<string, string> = { ...(config.queryParams ?? {}) };\n // Render the exact method the connection references; with no slug\n // (connection row not yet persisted) fall back to the first declared.\n const method =\n (templateSlug !== null\n ? config.authenticationTemplate.find(\n (m: GraphqlAuthMethod) => m.slug === String(templateSlug),\n )\n : undefined) ?? config.authenticationTemplate[0];\n if (method) {\n const rendered = renderGraphqlAuthMethod(method, values);\n Object.assign(headers, rendered.headers);\n Object.assign(queryParams, rendered.queryParams);\n }\n return { headers, queryParams };\n};\n\n/** Resolve a config's introspection snapshot text from the plugin blob store\n * (`introspectionHash`). Null when the integration has no snapshot (live\n * introspection territory). Pre-blob rows that inlined the JSON are\n * rewritten by the introspection-to-blob migrations before this code reads\n * them. */\nconst loadIntrospectionJson = (\n storage: GraphqlStore,\n config: GraphqlIntegrationConfig,\n): Effect.Effect<string | null, StorageFailure> =>\n config.introspectionHash != null\n ? storage.getIntrospection(config.introspectionHash)\n : Effect.succeed(null);\n\n/** Introspect a config live or from its stored snapshot, applying connection\n * auth. A non-null `introspectionJson` (loaded via `loadIntrospectionJson`)\n * short-circuits the network; otherwise this introspects the endpoint with\n * the rendered credential. */\nconst introspectForConnection = (\n config: GraphqlIntegrationConfig,\n introspectionJson: string | null,\n values: Record<string, string | null>,\n templateSlug: AuthTemplateSlug | null,\n httpClientLayer: Layer.Layer<HttpClient.HttpClient>,\n): Effect.Effect<IntrospectionResult, GraphqlIntrospectionError> => {\n if (introspectionJson != null) {\n return parseIntrospectionJson(introspectionJson);\n }\n const auth = introspectHeadersForConnection(config, values, templateSlug);\n return introspect(\n config.endpoint,\n Object.keys(auth.headers).length > 0 ? auth.headers : undefined,\n Object.keys(auth.queryParams).length > 0 ? auth.queryParams : undefined,\n ).pipe(Effect.provide(httpClientLayer));\n};\n\n/** Introspect an integration's endpoint (with this connection's credential),\n * prepare its operations, persist the bindings, and return them. Invoked from\n * `invokeTool` on a cache miss — i.e. when an integration was registered\n * without an add-time schema and its bindings haven't been produced yet. */\nconst materializeOperations = (\n ctx: PluginCtx<GraphqlStore>,\n integration: string,\n config: GraphqlIntegrationConfig,\n credential: {\n readonly template: AuthTemplateSlug;\n readonly values: Record<string, string | null>;\n },\n httpClientLayer: Layer.Layer<HttpClient.HttpClient>,\n): Effect.Effect<readonly StoredOperation[], GraphqlIntrospectionError | StorageFailure> =>\n Effect.gen(function* () {\n // Render the exact method this connection references (we have its slug\n // here, unlike `resolveTools`) so an auth-required endpoint introspects.\n const method = config.authenticationTemplate.find(\n (m: GraphqlAuthMethod) => m.slug === String(credential.template),\n );\n const headers: Record<string, string> = { ...(config.headers ?? {}) };\n const queryParams: Record<string, string> = {\n ...(config.queryParams ?? {}),\n };\n if (method) {\n const rendered = renderGraphqlAuthMethod(method, credential.values);\n Object.assign(headers, rendered.headers);\n Object.assign(queryParams, rendered.queryParams);\n }\n\n const introspectionJson = yield* loadIntrospectionJson(ctx.storage, config);\n const introspection =\n introspectionJson != null\n ? yield* parseIntrospectionJson(introspectionJson)\n : yield* introspect(\n config.endpoint,\n Object.keys(headers).length > 0 ? headers : undefined,\n Object.keys(queryParams).length > 0 ? queryParams : undefined,\n ).pipe(Effect.provide(httpClientLayer));\n\n const { result } = yield* extract(introspection).pipe(\n Effect.catch(() =>\n Effect.succeed({\n result: { fields: [] as readonly ExtractedField[] },\n } as {\n readonly result: { readonly fields: readonly ExtractedField[] };\n }),\n ),\n );\n const prepared = prepareOperations(result.fields, introspection);\n const stored = toStoredOperations(IntegrationSlug.make(integration), prepared);\n yield* ctx.storage.replaceOperations(integration, stored);\n return stored;\n });\n\n// ---------------------------------------------------------------------------\n// Declared auth methods — project the stored `authenticationTemplate` into the\n// catalog's plugin-agnostic `AuthMethodDescriptor[]`. Pure/sync and tolerant of\n// a malformed or foreign config blob (returns `[]`). GraphQL has no accounts\n// slot of its own, so this projection is what surfaces declared + custom methods\n// through the catalog's `authMethods` to the hub / Add-account flows. Exported\n// for tests.\n//\n// none → a no-auth method carrying no credential inputs\n// apikey → carried placements (headers / query params) verbatim\n// oauth2 → one oauth method (no resolved endpoints; graphql renders the\n// connection value as a bearer at invoke time).\n// ---------------------------------------------------------------------------\n\nexport const describeGraphqlAuthMethods = (\n record: IntegrationRecord,\n): readonly AuthMethodDescriptor[] => {\n const config = Option.getOrUndefined(decodeGraphqlIntegrationConfigOption(record.config));\n if (!config) return [];\n return config.authenticationTemplate.map((method: GraphqlAuthMethod): AuthMethodDescriptor => {\n if (method.kind === \"apikey\") return describeApiKeyAuthMethod(method);\n if (method.kind === \"oauth2\") {\n return {\n id: method.slug,\n label: \"OAuth\",\n kind: \"oauth\",\n template: method.slug,\n oauth: {},\n };\n }\n return describeNoneAuthMethod(method.slug);\n });\n};\n\nexport const describeGraphqlIntegrationDisplay = (\n record: IntegrationRecord,\n): { readonly url?: string } => {\n const config = Option.getOrUndefined(decodeGraphqlIntegrationConfigOption(record.config));\n return { url: config?.endpoint };\n};\n\n// ---------------------------------------------------------------------------\n// Plugin extension\n// ---------------------------------------------------------------------------\n\n// The extension only registers integrations (and parses any pre-supplied\n// introspection JSON offline). Live introspection — the only thing that needed\n// an HTTP layer — is deferred to `resolveTools` / `invokeTool`, so the extension\n// no longer takes one.\nconst makeGraphqlExtension = (ctx: PluginCtx<GraphqlStore>) => {\n const buildConfig = (input: GraphqlAddIntegrationInput): GraphqlIntegrationConfig =>\n GraphqlIntegrationConfig.make({\n endpoint: input.endpoint,\n name: input.name?.trim() || slugFromEndpoint(input.endpoint),\n ...(input.headers !== undefined ? { headers: input.headers } : {}),\n ...(input.queryParams !== undefined ? { queryParams: input.queryParams } : {}),\n authenticationTemplate: input.authenticationTemplate\n ? normalizeGraphqlAuthMethods(input.authenticationTemplate)\n : [],\n });\n\n /** Register the integration in the catalog. Registering a source is a\n * catalog statement (\"we use this GraphQL endpoint now\") and MUST NOT make a\n * network call or require auth — exactly like MCP defers discovery. Live\n * introspection (and the operation bindings it yields) is deferred to\n * connection-create / tool-generation (`resolveTools`) and tool invocation\n * (`invokeTool`), where a connection's credential is available.\n *\n * When the caller pre-supplies `introspectionJson`, the schema is already in\n * hand, so we parse it offline (no network) and persist the operation\n * bindings up front. */\n const addIntegrationInternal = (input: GraphqlAddIntegrationInput) =>\n Effect.gen(function* () {\n const slug = IntegrationSlug.make(input.slug ?? slugFromEndpoint(input.endpoint));\n\n // Block re-adding an existing slug. The core `integrations.register`\n // primitive upserts (so boot re-registration is idempotent), but an\n // explicit add must NOT silently clobber an existing integration's tools,\n // connections, and policies. To add more auth, update the existing one.\n const existing = yield* ctx.core.integrations.get(slug);\n if (existing) {\n return yield* new IntegrationAlreadyExistsError({ slug });\n }\n\n return yield* addIntegrationTransaction(input, slug);\n });\n\n const addIntegrationTransaction = (input: GraphqlAddIntegrationInput, slug: IntegrationSlug) =>\n Effect.gen(function* () {\n const baseConfig = buildConfig(input);\n\n // No pre-supplied schema → register WITHOUT introspecting. Tools (and\n // their operation bindings) are produced lazily when a connection is\n // created (`resolveTools`) / a tool is first invoked (`invokeTool`),\n // using that connection's credential.\n if (input.introspectionJson === undefined) {\n yield* ctx.transaction(\n ctx.core.integrations.register({\n slug,\n description: baseConfig.name,\n config: baseConfig,\n canRemove: true,\n canRefresh: true,\n }),\n );\n return { slug: String(slug), name: baseConfig.name, toolCount: 0 };\n }\n\n // Pre-supplied introspection JSON: parse it offline (no network) and\n // persist the operation bindings + snapshot so production stays offline.\n const introspection = yield* parseIntrospectionJson(input.introspectionJson);\n const { result } = yield* extract(introspection);\n const prepared = prepareOperations(result.fields, introspection);\n\n // Snapshot the resolved schema so tool production never needs a live\n // HTTP layer (D6: tools are spec-derived and identical per connection).\n // The snapshot text goes to the plugin blob store (content-addressed,\n // written OUTSIDE the transaction — re-puts are idempotent and an\n // aborted register leaves only an unreferenced blob), and the config\n // carries only its hash.\n const snapshotJson = JSON.stringify({ data: introspection });\n const introspectionHash = yield* sha256Hex(snapshotJson);\n const config = GraphqlIntegrationConfig.make({\n ...baseConfig,\n introspectionHash,\n });\n\n yield* ctx.storage.putIntrospection(introspectionHash, snapshotJson);\n\n yield* ctx.transaction(\n Effect.gen(function* () {\n yield* ctx.storage.replaceOperations(String(slug), toStoredOperations(slug, prepared));\n\n yield* ctx.core.integrations.register({\n slug,\n description: config.name,\n config,\n canRemove: true,\n canRefresh: true,\n });\n }),\n );\n\n return {\n slug: String(slug),\n name: config.name,\n toolCount: prepared.length,\n };\n });\n\n const configureIntegration = (slug: string, input: GraphqlConfigureInput) =>\n Effect.gen(function* () {\n const record = yield* ctx.core.integrations.get(IntegrationSlug.make(slug));\n if (!record) return;\n const current = Option.getOrElse(\n // best-effort: re-decode the stored config, falling back to an\n // endpoint-only config if it was never set.\n yield* decodeGraphqlIntegrationConfig(record.config).pipe(Effect.option),\n () =>\n GraphqlIntegrationConfig.make({\n endpoint: \"\",\n name: record.description,\n authenticationTemplate: [],\n }),\n );\n\n const next = GraphqlIntegrationConfig.make({\n endpoint: input.endpoint ?? current.endpoint,\n name: input.name?.trim() || current.name,\n ...(current.introspectionHash !== undefined\n ? { introspectionHash: current.introspectionHash }\n : {}),\n ...((input.headers ?? current.headers) !== undefined\n ? { headers: input.headers ?? current.headers }\n : {}),\n ...((input.queryParams ?? current.queryParams) !== undefined\n ? { queryParams: input.queryParams ?? current.queryParams }\n : {}),\n authenticationTemplate: input.authenticationTemplate\n ? normalizeGraphqlAuthMethods(input.authenticationTemplate)\n : current.authenticationTemplate,\n });\n\n yield* ctx.core.integrations.update(IntegrationSlug.make(slug), {\n description: next.name,\n config: next,\n });\n });\n\n /** Read the integration's decoded config (or `null` when absent / malformed).\n * Surfaces `authenticationTemplate` for the configure / custom-method UX. */\n const getConfig = (\n slug: string,\n ): Effect.Effect<GraphqlIntegrationConfig | null, StorageFailure> =>\n ctx.core.integrations\n .get(IntegrationSlug.make(slug))\n .pipe(\n Effect.map((record) =>\n record ? Option.getOrNull(decodeGraphqlIntegrationConfigOption(record.config)) : null,\n ),\n );\n\n /** Merge-append custom auth methods onto the integration's existing\n * `authenticationTemplate`. Returns the merged array. A no-op (returns `[]`)\n * for an unknown slug or undecodable config. */\n const configureAuthMethods = (\n slug: string,\n input: GraphqlConfigureAuthInput,\n ): Effect.Effect<readonly GraphqlAuthMethod[], StorageFailure> =>\n ctx.transaction(\n Effect.gen(function* () {\n const record = yield* ctx.core.integrations.get(IntegrationSlug.make(slug));\n if (!record) return [] as readonly GraphqlAuthMethod[];\n const current = Option.getOrNull(decodeGraphqlIntegrationConfigOption(record.config));\n if (!current) return [] as readonly GraphqlAuthMethod[];\n\n // Replace mode declares the full set — backfill kind-based slugs.\n // Merge mode appends: `mergeAuthTemplates` replaces on slug match and\n // assigns fresh `custom_<id>` slugs to slug-less entries, so a custom\n // method never silently displaces a declared one.\n const merged =\n input.mode === \"replace\"\n ? normalizeGraphqlAuthMethods(input.authenticationTemplate)\n : mergeAuthTemplates(\n current.authenticationTemplate,\n expandGraphqlAuthMethodInputs(\n input.authenticationTemplate,\n ) as readonly GraphqlAuthMethod[],\n );\n\n const next = GraphqlIntegrationConfig.make({\n ...current,\n authenticationTemplate: merged,\n });\n\n yield* ctx.core.integrations.update(IntegrationSlug.make(slug), {\n config: next,\n });\n\n return merged;\n }),\n );\n\n return {\n /** Register a GraphQL integration (introspects + persists operations). */\n addIntegration: (input: GraphqlAddIntegrationInput) => addIntegrationInternal(input),\n\n /** Read the integration's stored config. */\n getIntegration: (slug: string) =>\n ctx.core.integrations\n .get(IntegrationSlug.make(slug))\n .pipe(Effect.map((record) => (record ? record.config : null))),\n\n /** Read the integration's decoded config (auth templates surfaced). */\n getConfig,\n\n /** Merge-append custom auth methods (custom-method-create flow). */\n configureAuth: configureAuthMethods,\n\n removeIntegration: (slug: string) =>\n ctx.transaction(\n Effect.gen(function* () {\n yield* ctx.storage.removeOperations(slug);\n yield* ctx.core.integrations\n .remove(IntegrationSlug.make(slug))\n .pipe(Effect.catchTag(\"IntegrationRemovalNotAllowedError\", () => Effect.void));\n }),\n ),\n\n configure: configureIntegration,\n };\n};\n\nexport type GraphqlPluginExtension = ReturnType<typeof makeGraphqlExtension>;\n\n// ---------------------------------------------------------------------------\n// Plugin factory\n// ---------------------------------------------------------------------------\n\nexport interface GraphqlPluginOptions {\n readonly httpClientLayer?: Layer.Layer<HttpClient.HttpClient>;\n}\n\nexport const graphqlPlugin = definePlugin((options?: GraphqlPluginOptions) => {\n return {\n id: GRAPHQL_PLUGIN_ID as \"graphql\",\n packageName: \"@executor-js/plugin-graphql\",\n integrationPresets: graphqlPresets.map((preset) => ({\n id: preset.id,\n name: preset.name,\n summary: preset.summary,\n url: preset.url,\n endpoint: preset.endpoint,\n ...(preset.icon ? { icon: preset.icon } : {}),\n ...(preset.featured ? { featured: preset.featured } : {}),\n })),\n storage: (deps): GraphqlStore => makeDefaultGraphqlStore(deps),\n\n extension: (ctx: PluginCtx<GraphqlStore>) => makeGraphqlExtension(ctx),\n\n integrationConfigure: {\n type: \"graphql\",\n schema: GraphqlConfigureInputSchema,\n configure: ({ ctx, integration, config }) =>\n makeGraphqlExtension(ctx).configure(String(integration), config as GraphqlConfigureInput),\n },\n\n describeAuthMethods: describeGraphqlAuthMethods,\n describeIntegrationDisplay: describeGraphqlIntegrationDisplay,\n\n staticSources: (self: GraphqlPluginExtension) => [\n {\n id: \"graphql\",\n kind: \"executor\",\n name: \"GraphQL\",\n tools: [\n {\n name: \"getIntegration\",\n description:\n \"Inspect an existing GraphQL integration, including endpoint, static headers/query params, and auth templates. Use this before repairing an integration with `graphql.configure` or creating a connection.\",\n inputSchema: StaticGetIntegrationInputStandardSchema,\n outputSchema: StaticGetIntegrationOutputStandardSchema,\n handler: ({ args }) => {\n const input = args as typeof StaticGetIntegrationInputSchema.Type;\n return Effect.map(self.getIntegration(input.slug), (integration) =>\n ToolResult.ok({ integration }),\n );\n },\n },\n {\n name: \"addIntegration\",\n description:\n \"Add a GraphQL endpoint to the catalog and register its operations. Introspects the endpoint (or uses provided introspection JSON). After adding, create an owner-scoped connection against the integration to materialize its per-connection tools. For API keys / bearer tokens, declare an `authenticationTemplate` and create a connection whose value is the token.\",\n annotations: {\n requiresApproval: true,\n approvalDescription: \"Add a GraphQL integration\",\n },\n inputSchema: StaticAddIntegrationInputStandardSchema,\n outputSchema: StaticAddIntegrationOutputStandardSchema,\n handler: ({ args }) => {\n const input = args as GraphqlAddIntegrationInput;\n return self.addIntegration(input).pipe(\n Effect.map((result) => ToolResult.ok({ slug: result.slug, name: result.name })),\n Effect.catchTags({\n GraphqlIntrospectionError: ({ message }) =>\n Effect.succeed(graphqlToolFailure(\"graphql_introspection_failed\", message)),\n GraphqlExtractionError: ({ message }) =>\n Effect.succeed(graphqlToolFailure(\"graphql_extraction_failed\", message)),\n IntegrationAlreadyExistsError: ({ slug }: IntegrationAlreadyExistsError) =>\n Effect.succeed(\n graphqlToolFailure(\n \"integration_already_exists\",\n `Integration ${slug} already exists; update it instead of re-adding.`,\n ),\n ),\n }),\n );\n },\n },\n ],\n },\n ],\n\n // -----------------------------------------------------------------------\n // Per-connection tool production. THIS is where a GraphQL integration is\n // introspected — when a connection is created (or refreshed), with that\n // connection's credential — yielding one ToolDef per operation. Registering\n // the integration in the catalog makes no network call; discovery is\n // deferred to here, exactly how MCP defers tool discovery to connect time.\n // The introspected schema is identical across connections, so `invokeTool`\n // re-derives the same operation bindings; only the credential differs.\n // -----------------------------------------------------------------------\n resolveTools: ({\n config,\n template,\n storage,\n getValues,\n }: {\n readonly config: IntegrationConfig;\n readonly template: AuthTemplateSlug | null;\n readonly storage: GraphqlStore;\n readonly getValues: () => Effect.Effect<Record<string, string | null>, unknown>;\n }) =>\n Effect.gen(function* () {\n const decoded = yield* decodeGraphqlIntegrationConfig(config).pipe(Effect.option);\n if (Option.isNone(decoded)) return { tools: [] };\n const graphqlConfig = decoded.value;\n const introspectionJson = yield* loadIntrospectionJson(storage, graphqlConfig);\n // Live introspection (no stored snapshot) needs the connection's\n // credential inputs for auth-required endpoints; resolve them lazily.\n const values =\n introspectionJson == null\n ? yield* getValues().pipe(\n Effect.catch(() => Effect.succeed({} as Record<string, string | null>)),\n )\n : ({} as Record<string, string | null>);\n const introspection = yield* introspectForConnection(\n graphqlConfig,\n introspectionJson,\n values,\n template,\n options?.httpClientLayer ?? httpClientLayerFallback,\n ).pipe(Effect.option);\n if (Option.isNone(introspection)) return { tools: [] };\n const extracted = yield* extract(introspection.value).pipe(Effect.option);\n if (Option.isNone(extracted)) return { tools: [] };\n const prepared = prepareOperations(extracted.value.result.fields, introspection.value);\n return {\n tools: buildToolDefs(prepared),\n definitions: extracted.value.definitions,\n };\n }).pipe(Effect.catch(() => Effect.succeed({ tools: [] as readonly ToolDef[] }))),\n\n // -----------------------------------------------------------------------\n // Invoke one of a connection's tools. Look up the operation by integration\n // + tool name, render the credential through the connection's auth\n // template, and execute the GraphQL request.\n // -----------------------------------------------------------------------\n invokeTool: ({ ctx, toolRow, credential, args }) =>\n Effect.gen(function* () {\n const httpClientLayer = options?.httpClientLayer ?? ctx.httpClientLayer;\n const integration = toolRow.integration;\n const toolName = toolRow.name;\n\n const config = yield* decodeGraphqlIntegrationConfig(credential.config).pipe(\n Effect.mapError(\n () =>\n new GraphqlInvocationError({\n message: `Invalid GraphQL integration config for \"${integration}\"`,\n statusCode: Option.none(),\n }),\n ),\n );\n\n // Operation bindings are produced lazily for integrations registered\n // without an add-time schema (no network at catalog registration). On a\n // cache miss, introspect with this connection's credential, persist the\n // bindings, then resolve the requested tool — discovery/persistence are\n // deferred to first use, mirroring MCP.\n let op = yield* ctx.storage.getOperation(integration, toolName);\n if (!op) {\n op = yield* materializeOperations(\n ctx,\n integration,\n config,\n credential,\n httpClientLayer,\n ).pipe(Effect.map((ops) => ops.find((o) => o.toolName === toolName) ?? null));\n }\n if (!op) {\n return yield* new GraphqlInvocationError({\n message: `No GraphQL operation found for tool \"${integration}.${toolName}\"`,\n statusCode: Option.none(),\n });\n }\n\n const headers: Record<string, string> = { ...(config.headers ?? {}) };\n const queryParams: Record<string, string> = {\n ...(config.queryParams ?? {}),\n };\n\n const method = config.authenticationTemplate.find(\n (m: GraphqlAuthMethod) => m.slug === String(credential.template),\n );\n if (method && method.kind !== \"none\") {\n // A method with unresolved inputs fails the invocation explicitly\n // instead of dialing unauthenticated. oauth2 requires the resolved\n // access token (`token`); apikey requires every placement variable.\n const missing = (\n method.kind === \"oauth2\"\n ? [TOKEN_VARIABLE]\n : requiredPlacementVariables(method.placements)\n ).filter((variable) => credential.values[variable] == null);\n if (missing.length > 0) {\n return yield* new GraphqlAuthRequiredError({\n code:\n method.kind === \"oauth2\" ? \"oauth_connection_missing\" : \"connection_value_missing\",\n message:\n method.kind === \"oauth2\"\n ? `Missing OAuth connection value for GraphQL integration \"${integration}\" (connection \"${credential.connection}\")`\n : `Missing credential value for GraphQL integration \"${integration}\" (connection \"${credential.connection}\") for input(s): ${missing.join(\", \")}`,\n owner: credential.owner,\n integration,\n connection: String(credential.connection),\n credentialKind: method.kind === \"oauth2\" ? \"oauth\" : \"secret\",\n credentialLabel: method.kind === \"oauth2\" ? \"OAuth sign-in\" : \"API key\",\n template: String(credential.template),\n });\n }\n const rendered = renderGraphqlAuthMethod(method, credential.values);\n Object.assign(headers, rendered.headers);\n Object.assign(queryParams, rendered.queryParams);\n }\n\n const result = yield* invokeWithLayer(\n op.binding,\n (args ?? {}) as Record<string, unknown>,\n config.endpoint,\n headers,\n queryParams,\n httpClientLayer,\n );\n\n const errors = decodeGraphqlErrors(result.errors);\n if (errors !== undefined && errors.length > 0) {\n const firstMessage = extractGraphqlErrorMessage(errors);\n return ToolResult.fail({\n code: \"graphql_errors\",\n message: firstMessage !== undefined ? firstMessage : \"GraphQL request returned errors\",\n details: { errors },\n });\n }\n if (result.status < 200 || result.status >= 300) {\n if (result.status === 401 || result.status === 403) {\n return authToolFailure({\n code: \"connection_rejected\",\n status: result.status,\n message: `Upstream rejected credentials for GraphQL integration \"${integration}\" with HTTP ${result.status}. Re-authenticate or update the connection before retrying this tool.`,\n source: { id: integration, scope: credential.owner },\n credential: { kind: \"upstream\", label: \"Upstream authorization\" },\n upstream: {\n status: result.status,\n details: {\n data: result.data,\n errors: result.errors,\n },\n },\n });\n }\n return ToolResult.fail({\n code: \"graphql_http_error\",\n status: result.status,\n message: `GraphQL request failed with HTTP ${result.status}`,\n details: {\n status: result.status,\n data: result.data,\n errors: result.errors,\n },\n });\n }\n return ToolResult.ok(result.data);\n }).pipe(\n Effect.catchTag(\"GraphqlAuthRequiredError\", (error) =>\n Effect.succeed(graphqlAuthToolFailure(error)),\n ),\n ),\n\n // Per-connection cleanup. Operation bindings are catalog-level (shared\n // across an integration's connections), so removing a single connection\n // leaves them in place; the executor drops the connection's tool rows.\n removeConnection: () => Effect.void,\n\n detect: ({ ctx, url }: { readonly ctx: PluginCtx<GraphqlStore>; readonly url: string }) =>\n Effect.gen(function* () {\n const httpClientLayer = options?.httpClientLayer ?? ctx.httpClientLayer;\n const trimmed = url.trim();\n if (!trimmed) return null;\n const parsed = yield* Effect.try({\n try: () => new URL(trimmed),\n catch: (cause) => cause,\n }).pipe(Effect.option);\n if (Option.isNone(parsed)) return null;\n\n const ok = yield* introspect(trimmed).pipe(\n Effect.provide(httpClientLayer),\n Effect.map(() => true),\n Effect.catch(() => Effect.succeed(false)),\n );\n\n const slug = slugFromEndpoint(trimmed);\n\n if (ok) {\n return IntegrationDetectionResult.make({\n kind: \"graphql\",\n confidence: \"high\",\n endpoint: trimmed,\n name: slug,\n slug,\n });\n }\n\n // Low-confidence URL-token fallback. Introspection can fail for many\n // reasons (auth, CORS, the endpoint disabled introspection, transport\n // errors). When the URL itself strongly implies GraphQL, surface a\n // candidate so the user can still pick it.\n if (urlMatchesToken(parsed.value, \"graphql\")) {\n return IntegrationDetectionResult.make({\n kind: \"graphql\",\n confidence: \"low\",\n endpoint: trimmed,\n name: slug,\n slug,\n });\n }\n\n return null;\n }),\n };\n // HTTP transport (routes/handlers/extensionService) is layered on by the\n // api-aware factory in `@executor-js/plugin-graphql/api`.\n});\n\n// The fallback HTTP layer for `resolveTools`. The hook input carries no `ctx`,\n// so when no explicit layer is passed to the plugin we use the same default the\n// executor wires into `ctx.httpClientLayer` (`FetchHttpClient.layer`). Hosts/\n// tests that need a custom transport pass `options.httpClientLayer`.\nconst httpClientLayerFallback: Layer.Layer<HttpClient.HttpClient> = FetchHttpClient.layer;\n"],"mappings":"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","names":["raw","Effect","Option","Option","Effect","Effect","Option","HttpClient","HttpClientRequest","Effect","HttpClient","HttpClientRequest","Option","Effect","Option","Schema","Schema","Option","Effect","Effect","Match","Option","Schema","Schema","Option","formatTypeRef","Match","unwrapTypeName","Effect"]}
package/dist/client.js CHANGED
@@ -7,9 +7,9 @@ import { defineClientPlugin } from "@executor-js/sdk/client";
7
7
 
8
8
  // src/react/source-plugin.ts
9
9
  import { lazy } from "react";
10
- var importAdd = () => import("./AddGraphqlSource-P3D3UXRJ.js");
11
- var importEdit = () => import("./EditGraphqlSource-FVF67CTP.js");
12
- var importAccounts = () => import("./GraphqlAccountsPanel-GBNFHLFH.js");
10
+ var importAdd = () => import("./AddGraphqlSource-FGT7DNXV.js");
11
+ var importEdit = () => import("./EditGraphqlSource-QELISUYT.js");
12
+ var importAccounts = () => import("./GraphqlAccountsPanel-U62WSGHR.js");
13
13
  var graphqlIntegrationPlugin = {
14
14
  key: "graphql",
15
15
  label: "GraphQL",
package/dist/core.js CHANGED
@@ -7,50 +7,164 @@ import {
7
7
  invokeWithLayer,
8
8
  makeDefaultGraphqlStore,
9
9
  parseIntrospectionJson
10
- } from "./chunk-ADQTI2OK.js";
10
+ } from "./chunk-OUZI3QNC.js";
11
11
  import "./chunk-D6E4WAYW.js";
12
12
  import {
13
- ApiKeyAuthTemplate,
14
- AuthTemplate,
15
13
  ExtractedField,
16
14
  ExtractionResult,
17
15
  GraphqlArgument,
16
+ GraphqlAuthMethod,
17
+ GraphqlAuthMethodInput,
18
18
  GraphqlAuthRequiredError,
19
19
  GraphqlExtractionError,
20
20
  GraphqlIntegrationConfig,
21
21
  GraphqlIntrospectionError,
22
22
  GraphqlInvocationError,
23
+ GraphqlOAuthMethod,
23
24
  GraphqlOperationKind,
24
25
  InvocationResult,
25
- OAuthAuthTemplate,
26
26
  OperationBinding,
27
27
  decodeGraphqlIntegrationConfig,
28
- decodeGraphqlIntegrationConfigOption
29
- } from "./chunk-N5GJE7R6.js";
28
+ decodeGraphqlIntegrationConfigOption,
29
+ normalizeGraphqlAuthMethods
30
+ } from "./chunk-732HGFSH.js";
31
+
32
+ // src/sdk/migrate-config.ts
33
+ import { Option, Schema } from "effect";
34
+ import {
35
+ apiKeyMethodFromLegacyTemplate,
36
+ decodeLegacyApiKeyTemplate
37
+ } from "@executor-js/sdk/http-auth";
38
+ var LegacySingleAuth = Schema.Union([
39
+ Schema.Struct({ kind: Schema.Literal("none") }),
40
+ Schema.Struct({ kind: Schema.Literal("oauth2") })
41
+ ]);
42
+ var decodeLegacySingleAuth = Schema.decodeUnknownOption(LegacySingleAuth);
43
+ var LegacyNativeApiKey = Schema.Struct({
44
+ slug: Schema.String,
45
+ kind: Schema.Literal("apiKey"),
46
+ in: Schema.Literals(["header", "query"]),
47
+ name: Schema.String,
48
+ prefix: Schema.optional(Schema.String)
49
+ });
50
+ var LegacyOAuthTemplate = Schema.Struct({
51
+ slug: Schema.String,
52
+ type: Schema.Literal("oauth")
53
+ });
54
+ var decodeLegacyNativeApiKey = Schema.decodeUnknownOption(LegacyNativeApiKey);
55
+ var decodeLegacyOAuthTemplate = Schema.decodeUnknownOption(LegacyOAuthTemplate);
56
+ var CanonicalMethod = Schema.decodeUnknownOption(
57
+ Schema.Union([
58
+ Schema.Struct({ slug: Schema.String, kind: Schema.Literals(["none", "oauth2"]) }),
59
+ Schema.Struct({
60
+ slug: Schema.String,
61
+ kind: Schema.Literal("apikey"),
62
+ label: Schema.optional(Schema.String),
63
+ placements: Schema.Array(Schema.Unknown)
64
+ })
65
+ ])
66
+ );
67
+ var migrateMethodEntry = (entry) => {
68
+ const canonical = Option.getOrNull(CanonicalMethod(entry));
69
+ if (canonical !== null) return entry;
70
+ const native = Option.getOrNull(decodeLegacyNativeApiKey(entry));
71
+ if (native !== null) {
72
+ return {
73
+ slug: native.slug,
74
+ kind: "apikey",
75
+ placements: [
76
+ {
77
+ carrier: native.in,
78
+ name: native.name,
79
+ ...native.prefix !== void 0 ? { prefix: native.prefix } : {}
80
+ }
81
+ ]
82
+ };
83
+ }
84
+ const legacyApiKey = Option.getOrNull(decodeLegacyApiKeyTemplate(entry));
85
+ if (legacyApiKey !== null) return apiKeyMethodFromLegacyTemplate(legacyApiKey);
86
+ const legacyOAuth = Option.getOrNull(decodeLegacyOAuthTemplate(entry));
87
+ if (legacyOAuth !== null) return { slug: legacyOAuth.slug, kind: "oauth2" };
88
+ return null;
89
+ };
90
+ var parseConfig = (config) => Option.isSome(decodeGraphqlIntegrationConfigOption(config)) ? config : null;
91
+ var migrateGraphqlAuthConfig = (config) => {
92
+ if (typeof config !== "object" || config === null) return null;
93
+ if (!("endpoint" in config) || typeof config.endpoint !== "string") return null;
94
+ if ("transport" in config) return null;
95
+ const legacyAuth = "auth" in config ? Option.getOrNull(decodeLegacySingleAuth(config.auth)) : null;
96
+ if (!("authenticationTemplate" in config)) {
97
+ if ("auth" in config && legacyAuth === null) return null;
98
+ const kind = legacyAuth?.kind ?? "none";
99
+ const { auth: _auth2, ...rest } = config;
100
+ const migrated2 = { ...rest, authenticationTemplate: [{ slug: kind, kind }] };
101
+ return parseConfig(migrated2);
102
+ }
103
+ const entries = config.authenticationTemplate;
104
+ if (!Array.isArray(entries)) return null;
105
+ const migrated = entries.map(migrateMethodEntry);
106
+ if (migrated.some((entry) => entry === null)) return null;
107
+ const methods = migrated;
108
+ if (legacyAuth?.kind === "oauth2" && !methods.some((method) => method.kind === "oauth2")) {
109
+ methods.push({ slug: "oauth2", kind: "oauth2" });
110
+ }
111
+ const entriesChanged = methods.length !== entries.length || methods.some((entry, index) => entry !== entries[index]);
112
+ if (!entriesChanged && legacyAuth === null) return null;
113
+ const { auth: _auth, ...withoutAuth } = config;
114
+ const next = {
115
+ ...legacyAuth !== null ? withoutAuth : config,
116
+ authenticationTemplate: methods
117
+ };
118
+ return parseConfig(next);
119
+ };
120
+
121
+ // src/sdk/introspection-blob-migration.ts
122
+ import { Effect } from "effect";
123
+ import {
124
+ runSqliteConfigBlobMigration
125
+ } from "@executor-js/sdk/core";
126
+ var MIGRATION_NAME = "2026-06-12-graphql-introspection-to-blob";
127
+ var graphqlIntrospectionBlobDataMigration = {
128
+ name: MIGRATION_NAME,
129
+ run: (client) => runSqliteConfigBlobMigration(client, {
130
+ migrationName: MIGRATION_NAME,
131
+ pluginId: "graphql",
132
+ inlineField: "introspectionJson",
133
+ hashField: "introspectionHash",
134
+ blobKeyPrefix: "introspection"
135
+ }).pipe(Effect.asVoid)
136
+ };
137
+
138
+ // src/sdk/index.ts
139
+ import { variable } from "@executor-js/sdk/http-auth";
30
140
  export {
31
- ApiKeyAuthTemplate,
32
- AuthTemplate,
33
141
  ExtractedField,
34
142
  ExtractionResult,
35
143
  GraphqlArgument,
144
+ GraphqlAuthMethod,
145
+ GraphqlAuthMethodInput,
36
146
  GraphqlAuthRequiredError,
37
147
  GraphqlExtractionError,
38
148
  GraphqlIntegrationConfig,
39
149
  GraphqlIntrospectionError,
40
150
  GraphqlInvocationError,
151
+ GraphqlOAuthMethod,
41
152
  GraphqlOperationKind,
42
153
  InvocationResult,
43
- OAuthAuthTemplate,
44
154
  OperationBinding,
45
155
  decodeGraphqlIntegrationConfig,
46
156
  decodeGraphqlIntegrationConfigOption,
47
157
  describeGraphqlAuthMethods,
48
158
  extract,
159
+ graphqlIntrospectionBlobDataMigration,
49
160
  graphqlPlugin,
50
161
  introspect,
51
162
  invoke,
52
163
  invokeWithLayer,
53
164
  makeDefaultGraphqlStore,
54
- parseIntrospectionJson
165
+ migrateGraphqlAuthConfig,
166
+ normalizeGraphqlAuthMethods,
167
+ parseIntrospectionJson,
168
+ variable
55
169
  };
56
170
  //# sourceMappingURL=core.js.map
package/dist/core.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"sources":["../src/sdk/migrate-config.ts","../src/sdk/introspection-blob-migration.ts","../src/sdk/index.ts"],"sourcesContent":["// ---------------------------------------------------------------------------\n// One-off config migration — rewrite pre-canonical GraphQL integration\n// `config` blobs into the canonical placements model. Runs once per database\n// (boot for local/selfhost, out-of-band script for cloud); runtime code\n// decodes ONLY the canonical shape (`decodeGraphqlIntegrationConfig*`).\n//\n// Stored legacy families (all observed in real databases):\n// 1. the v1→v2 migration's singular `auth: {kind:\"none\"|\"oauth2\"}` (the\n// graphql config had no `authenticationTemplate` unless v1 carried\n// credential placements), or a config with no auth fields at all\n// 2. `authenticationTemplate` entries of the retired native shape:\n// `{kind:\"apiKey\", slug, in:\"header\"|\"query\", name, prefix?}`\n// 3. openapi-shaped entries the v1→v2 migration wrote:\n// `{slug, type:\"apiKey\", headers/queryParams: <template values>}` and\n// `{slug, type:\"oauth\", …}`\n//\n// Invariants: slugs are preserved verbatim (`connection.template` binds by\n// them) and so are variable names (they key the connections' stored\n// `item_ids`).\n// ---------------------------------------------------------------------------\n\nimport { Option, Schema } from \"effect\";\nimport {\n apiKeyMethodFromLegacyTemplate,\n decodeLegacyApiKeyTemplate,\n} from \"@executor-js/sdk/http-auth\";\n\nimport { decodeGraphqlIntegrationConfigOption, type GraphqlAuthMethod } from \"./types\";\n\nconst LegacySingleAuth = Schema.Union([\n Schema.Struct({ kind: Schema.Literal(\"none\") }),\n Schema.Struct({ kind: Schema.Literal(\"oauth2\") }),\n]);\nconst decodeLegacySingleAuth = Schema.decodeUnknownOption(LegacySingleAuth);\n\nconst LegacyNativeApiKey = Schema.Struct({\n slug: Schema.String,\n kind: Schema.Literal(\"apiKey\"),\n in: Schema.Literals([\"header\", \"query\"]),\n name: Schema.String,\n prefix: Schema.optional(Schema.String),\n});\nconst LegacyOAuthTemplate = Schema.Struct({\n slug: Schema.String,\n type: Schema.Literal(\"oauth\"),\n});\nconst decodeLegacyNativeApiKey = Schema.decodeUnknownOption(LegacyNativeApiKey);\nconst decodeLegacyOAuthTemplate = Schema.decodeUnknownOption(LegacyOAuthTemplate);\n\nconst CanonicalMethod = Schema.decodeUnknownOption(\n Schema.Union([\n Schema.Struct({ slug: Schema.String, kind: Schema.Literals([\"none\", \"oauth2\"]) }),\n Schema.Struct({\n slug: Schema.String,\n kind: Schema.Literal(\"apikey\"),\n label: Schema.optional(Schema.String),\n placements: Schema.Array(Schema.Unknown),\n }),\n ]),\n);\n\n/** Rewrite one stored method entry to canonical, or null when undecodable. */\nconst migrateMethodEntry = (entry: unknown): GraphqlAuthMethod | null => {\n const canonical = Option.getOrNull(CanonicalMethod(entry));\n if (canonical !== null) return entry as GraphqlAuthMethod;\n\n const native = Option.getOrNull(decodeLegacyNativeApiKey(entry));\n if (native !== null) {\n return {\n slug: native.slug,\n kind: \"apikey\",\n placements: [\n {\n carrier: native.in,\n name: native.name,\n ...(native.prefix !== undefined ? { prefix: native.prefix } : {}),\n },\n ],\n };\n }\n\n const legacyApiKey = Option.getOrNull(decodeLegacyApiKeyTemplate(entry));\n if (legacyApiKey !== null) return apiKeyMethodFromLegacyTemplate(legacyApiKey);\n\n const legacyOAuth = Option.getOrNull(decodeLegacyOAuthTemplate(entry));\n if (legacyOAuth !== null) return { slug: legacyOAuth.slug, kind: \"oauth2\" };\n\n return null;\n};\n\nconst parseConfig = (config: unknown): unknown | null =>\n Option.isSome(decodeGraphqlIntegrationConfigOption(config)) ? config : null;\n\n/** Rewrite a stored GraphQL integration config blob into the canonical shape.\n * Returns the rewritten config, or `null` when no rewrite is needed (already\n * canonical, or not this plugin's shape at all). Throws nothing: an\n * unmigratable blob also returns `null` and stays untouched. Idempotent —\n * feeding the output back returns `null`. */\nexport const migrateGraphqlAuthConfig = (config: unknown): unknown | null => {\n if (typeof config !== \"object\" || config === null) return null;\n // A GraphQL config is keyed by its endpoint; `transport` marks MCP blobs.\n if (!(\"endpoint\" in config) || typeof config.endpoint !== \"string\") return null;\n if (\"transport\" in config) return null;\n\n const legacyAuth =\n \"auth\" in config\n ? Option.getOrNull(decodeLegacySingleAuth((config as { auth: unknown }).auth))\n : null;\n\n if (!(\"authenticationTemplate\" in config)) {\n // Family 1: singular `auth`, or an open endpoint with no auth field.\n if (\"auth\" in config && legacyAuth === null) return null;\n const kind = legacyAuth?.kind ?? \"none\";\n const { auth: _auth, ...rest } = config as { auth?: unknown };\n const migrated = { ...rest, authenticationTemplate: [{ slug: kind, kind }] };\n return parseConfig(migrated);\n }\n\n const entries = (config as { authenticationTemplate: unknown }).authenticationTemplate;\n if (!Array.isArray(entries)) return null;\n\n const migrated = entries.map(migrateMethodEntry);\n if (migrated.some((entry) => entry === null)) return null;\n const methods = migrated as GraphqlAuthMethod[];\n\n // The v1→v2 migration wrote BOTH `auth: {kind:\"oauth2\"}` and an apiKey\n // `authenticationTemplate` when a source had credential placements and\n // oauth; fold the singular auth into the declared set (slug = kind, the\n // slug the connection migration bound oauth connections to).\n if (\n legacyAuth?.kind === \"oauth2\" &&\n !methods.some((method: GraphqlAuthMethod) => method.kind === \"oauth2\")\n ) {\n methods.push({ slug: \"oauth2\", kind: \"oauth2\" });\n }\n\n const entriesChanged =\n methods.length !== entries.length ||\n methods.some((entry: GraphqlAuthMethod, index: number) => entry !== entries[index]);\n if (!entriesChanged && legacyAuth === null) return null;\n\n const { auth: _auth, ...withoutAuth } = config as { auth?: unknown };\n const next = {\n ...(legacyAuth !== null ? withoutAuth : config),\n authenticationTemplate: methods,\n };\n return parseConfig(next);\n};\n","// ---------------------------------------------------------------------------\n// Data migration: move inline GraphQL introspection snapshots out of\n// `integration.config` into the blob table (`introspection/<sha256>`, config\n// keeps `introspectionHash`) — the libSQL-ledger counterpart of cloud's\n// out-of-band migrate-specs-to-blobs script. Runs once per database through\n// the data-migration ledger; the shared body lives in @executor-js/sdk\n// (`runSqliteConfigBlobMigration`).\n// ---------------------------------------------------------------------------\n\nimport { Effect } from \"effect\";\nimport {\n runSqliteConfigBlobMigration,\n type SqliteDataMigrationClient,\n} from \"@executor-js/sdk/core\";\n\nconst MIGRATION_NAME = \"2026-06-12-graphql-introspection-to-blob\";\n\n/** Registry entry for the boot-time data-migration ledger. */\nexport const graphqlIntrospectionBlobDataMigration = {\n name: MIGRATION_NAME,\n run: (client: SqliteDataMigrationClient) =>\n runSqliteConfigBlobMigration(client, {\n migrationName: MIGRATION_NAME,\n pluginId: \"graphql\",\n inlineField: \"introspectionJson\",\n hashField: \"introspectionHash\",\n blobKeyPrefix: \"introspection\",\n }).pipe(Effect.asVoid),\n};\n","export { introspect, parseIntrospectionJson } from \"./introspect\";\nexport { extract, type ExtractionOutput } from \"./extract\";\nexport { invoke, invokeWithLayer } from \"./invoke\";\nexport {\n describeGraphqlAuthMethods,\n graphqlPlugin,\n type GraphqlPluginExtension,\n type GraphqlPluginOptions,\n type GraphqlAddIntegrationInput,\n type GraphqlConfigureInput,\n type GraphqlConfigureAuthInput,\n} from \"./plugin\";\nexport { makeDefaultGraphqlStore, type GraphqlStore, type StoredOperation } from \"./store\";\n\nexport {\n GraphqlIntrospectionError,\n GraphqlExtractionError,\n GraphqlInvocationError,\n GraphqlAuthRequiredError,\n} from \"./errors\";\n\nexport {\n decodeGraphqlIntegrationConfig,\n decodeGraphqlIntegrationConfigOption,\n ExtractedField,\n ExtractionResult,\n GraphqlArgument,\n GraphqlAuthMethod,\n GraphqlAuthMethodInput,\n GraphqlIntegrationConfig,\n GraphqlOAuthMethod,\n GraphqlOperationKind,\n InvocationResult,\n normalizeGraphqlAuthMethods,\n OperationBinding,\n} from \"./types\";\n\nexport { migrateGraphqlAuthConfig } from \"./migrate-config\";\n\nexport { graphqlIntrospectionBlobDataMigration } from \"./introspection-blob-migration\";\n\n// Request-shaped authoring: `headers: { Authorization: [\"Bearer \", variable(\"token\")] }`.\nexport { variable, type ApiKeyAuthTemplate } from \"@executor-js/sdk/http-auth\";\n"],"mappings":"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","names":["_auth","migrated"]}
package/dist/index.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  graphqlPlugin
3
- } from "./chunk-ADQTI2OK.js";
3
+ } from "./chunk-OUZI3QNC.js";
4
4
  import "./chunk-D6E4WAYW.js";
5
- import "./chunk-N5GJE7R6.js";
5
+ import "./chunk-732HGFSH.js";
6
6
  export {
7
7
  graphqlPlugin
8
8
  };