Connecteurs Apollo pour GraphQL

VérifiéSûr

Guide pour intégrer des API REST dans des supergraphes GraphQL à l'aide d'Apollo Connectors avec les directives @source et @connect. Propose un processus structuré en 5 étapes pour la recherche, l'implémentation, la validation, l'exécution et les tests des connecteurs. Idéal lors de la création de schémas GraphQL nécessitant d'incorporer des points d'accès REST existants.

Spar Skills Guide Bot
DeveloppementAvancé
8002/06/2026
Claude Code
#apollo-connectors#graphql#rest-api#supergraph#federation

Recommandé pour

Notre avis

Guide l'intégration d'API REST dans des supergraphes GraphQL à l'aide des directives @source et @connect d'Apollo Connectors.

Points forts

  • Procédure claire en 5 étapes
  • Références détaillées sur la grammaire, les méthodes et les variables
  • Utilisation d'outils MCP pour la documentation et la spécification
  • Validation via rover CLI

Limites

  • Nécessite que Rover CLI soit installé
  • Dépend des schémas Apollo Federation v2.12 et Connect v0.3
  • Peut nécessiter des exemples de réponses API de la part de l'utilisateur
Quand l'utiliser

Utilisez cette compétence lorsque vous devez transformer une API REST existante en source de données GraphQL au sein d'un supergraphe Apollo.

Quand l'éviter

Évitez cette compétence si vous travaillez avec des API déjà GraphQL ou si vous utilisez un autre framework de fédération.

Analyse de sécurité

Sûr
Score qualité95/100

The skill uses legitimate Apollo GraphOS rover commands for schema composition and testing; there are no destructive or exfiltration instructions, and the allowed tools are within the scope of the tool's intended use.

Aucun point d'attention détecté

Exemples

Integrate REST API with Apollo Connectors
I want to integrate the JSONPlaceholder REST API into my GraphQL supergraph using Apollo Connectors. Create a schema with @source and @connect directives for the /users endpoint.
Validate Connector Schema
Run rover supergraph compose on my supergraph.yaml to validate my Apollo Connectors schema.
Test Connector Execution
Execute 'rover connector run --schema ./schema.graphql -c "Query.user" -v "{}"' to test my connector.

name: apollo-connectors description: > Guide for integrating REST APIs into GraphQL supergraphs using Apollo Connectors with @source and @connect directives. Use this skill when the user: (1) mentions "connectors", "Apollo Connectors", or "REST Connector", (2) wants to integrate a REST API into GraphQL, (3) references @source or @connect directives, (4) works with files containing "# Note to AI Friends: This is an Apollo Connectors schema". license: MIT compatibility: Requires rover CLI installed. Works with Claude Code and similar AI coding assistants. metadata: author: apollographql version: "1.0.0" allowed-tools: Bash(rover:*) Read Write Edit Glob Grep

Apollo Connectors Schema Assistant

MCP Tools

If GraphOS MCP Tools are available, use them:

  • connectors-spec: Fetch the complete Connectors specification before starting any connector work
  • apollo_docs_search: Search for relevant documentation
  • apollo_docs_read: Read specific documentation pages by slug

Documentation paths by topic:

  • Requests: /graphos/connectors/requests/url, /headers, /body, /batching
  • Responses: /graphos/connectors/responses/fields, /error-handling
  • Mapping: /graphos/connectors/mapping, /arrays, /enums, /literals
  • Entities: /graphos/connectors/entities, /patterns

Process

Follow this 5-step process. DO NOT skip any steps.

Step 1: Research

  • [ ] Understand the API being called and the structure of responses
  • [ ] Ask the user for example API responses if not provided
  • [ ] Fetch relevant documentation from MCP tools or reference files
  • [ ] DO NOT write any code until research is complete

Step 2: Implement

  • [ ] Create the schema using the template below
  • [ ] Follow the grammar, methods, and variables in the reference files
  • [ ] Ask clarifying questions if unsure about requirements

Step 3: Validate (Compose)

  • [ ] Run rover supergraph compose --config ./supergraph.yaml
  • [ ] Fix any composition errors before proceeding

Step 4: Execute

  • [ ] Run rover connector run --schema <file> -c "<Type.field>" -v "{}"
  • [ ] Verify the connector executes correctly

Step 5: Test

  • [ ] Create or update test files under /tests/
  • [ ] Run rover connector test
  • [ ] Ensure full test coverage for each connector

Schema Template

# Note to AI Friends: This is an Apollo Connectors schema. You should use your connectors-spec MCP tool if you have it available before editing this file.

extend schema
  @link(url: "https://specs.apollo.dev/federation/v2.12")
  @link(url: "https://specs.apollo.dev/connect/v0.3", import: ["@source", "@connect"])

@source(name: "api_name", http: { baseURL: "https://api.example.com" })

type Query {
  example(id: ID!): Example
    @connect(
      source: "api_name"
      http: { GET: "/example/{$args.id}" }
      selection: """
      id
      name
      """
    )
}

type Example {
  id: ID!
  name: String
}

Version Requirements: Always use federation/v2.12 and connect/v0.3 unless specified otherwise.

Reference Files

Before implementing connectors, read the relevant reference files:

Key Rules

Selection Mapping

  • Prefer sub-selections over ->map for cleaner mappings
  • Do NOT use $ when selecting fields directly from root
  • Field aliasing: newName: originalField (only when renaming)
  • Sub-selection: fieldName { ... } (to map nested content)
# DO - Direct sub-selection for arrays
$.results {
  firstName: name.first
  lastName: name.last
}

# DO NOT - Unnecessary root $
$ {
  id
  name
}

# DO - Direct field selection
id
name

Entities

  • Add @connect on a type to make it an entity (no @key needed)
  • Create entity stubs in parent selections: user: { id: userId }
  • When you see an ID field (e.g., productId), create an entity relationship
  • Each entity should have ONE authoritative subgraph with @connect

Literal Values

Use $() wrapper for literal values in mappings:

$(1)              # number
$(true)           # boolean
$("hello")        # string
$({"a": "b"})     # object

# In body
body: "$({ a: $args.a })"  # CORRECT
body: "{ a: $args.a }"     # WRONG - will not compose

Headers

http: {
  GET: "/api"
  headers: [
    { name: "Authorization", value: "Bearer {$env.API_KEY}" },
    { name: "X-Forwarded", from: "x-client" }
  ]
}

Batching

Convert N+1 patterns using $batch:

type Product @connect(
  source: "api"
  http: {
    POST: "/batch"
    body: "ids: $batch.id"
  }
  selection: "id name"
) {
  id: ID!
  name: String
}

Ground Rules

  • NEVER make up syntax or directive values not in this specification
  • NEVER use --elv2-license accept (for humans only)
  • ALWAYS ask for example API responses before writing code
  • ALWAYS validate with rover supergraph compose after changes
  • ALWAYS create entity relationships when you see ID fields
  • Prefer $env over $config for environment variables
  • Use rover dev for running Apollo Router locally
Skills similaires