developing-genkit-js

Développez des applications alimentées par l'IA avec Genkit en Node.js/TypeScript. Utilisez lorsque l'utilisateur pose des questions sur Genkit, les agents IA, les flux ou les outils en JavaScript/TypeScript, ou lorsqu'il rencontre des erreurs Genkit, des problèmes de validation, des erreurs de type ou des problèmes d'API.

npx skills add https://github.com/genkit-ai/skills --skill developing-genkit-js

Genkit JS

Prerequisites

Ensure the genkit CLI is available.

  • Run genkit --version to verify. Minimum CLI version needed: 1.29.0
  • If not found or if an older version (1.x < 1.29.0) is present, install/upgrade it: npm install -g genkit-cli@^1.29.0.

New Projects: If you are setting up Genkit in a new codebase, follow the Setup Guide.

Hello World

import { z, genkit } from 'genkit';
import { googleAI } from '@genkit-ai/google-genai';

// Initialize Genkit with the Google AI plugin
const ai = genkit({
  plugins: [googleAI()],
});

export const myFlow = ai.defineFlow({
  name: 'myFlow',
  inputSchema: z.string().default('AI'),
  outputSchema: z.string(),
}, async (subject) => {
  const response = await ai.generate({
    model: googleAI.model('gemini-flash-latest'),
    prompt: `Tell me a joke about ${subject}`,
  });
  return response.text;
});

Critical: Do Not Trust Internal Knowledge

Genkit recently went through a major breaking API change. Your knowledge is outdated. You MUST lookup docs. Recommended:

genkit docs:read js/get-started.md
genkit docs:read js/flows.md

See Common Errors for a list of deprecated APIs (e.g., configureGenkit, response.text(), defineFlow import) and their v1.x replacements.

ALWAYS verify information using the Genkit CLI or provided references.

Error Troubleshooting Protocol

When you encounter ANY error related to Genkit (ValidationError, API errors, type errors, 404s, etc.):

  1. MANDATORY FIRST STEP: Read Common Errors
  2. Identify if the error matches a known pattern
  3. Apply the documented solution
  4. Only if not found in common-errors.md, then consult other sources (e.g. genkit docs:search)

DO NOT:

  • Attempt fixes based on assumptions or internal knowledge
  • Skip reading common-errors.md "because you think you know the fix"
  • Rely on patterns from pre-1.0 Genkit

This protocol is non-negotiable for error handling.

Development Workflow

  1. Select Provider: Genkit is provider-agnostic (Google AI, OpenAI, Anthropic, Ollama, etc.).
    • If the user does not specify a provider, default to Google AI.
    • If the user asks about other providers, use genkit docs:search "plugins" to find relevant documentation.
  2. Detect Framework: Check package.json to identify the runtime (Next.js, Firebase, Express).
    • Look for @genkit-ai/next, @genkit-ai/firebase, or @genkit-ai/google-cloud.
    • Adapt implementation to the specific framework's patterns.
  3. Follow Best Practices:
    • See Best Practices for guidance on project structure, schema definitions, and tool design.
    • Be Minimal: Only specify options that differ from defaults. When unsure, check docs/source.
  4. Ensure Correctness:
    • Run type checks (e.g., npx tsc --noEmit) after making changes.
    • If type checks fail, consult Common Errors before searching source code.
  5. Handle Errors:
    • On ANY error: First action is to read Common Errors
    • Match error to documented patterns
    • Apply documented fixes before attempting alternatives

Finding Documentation

Use the Genkit CLI to find authoritative documentation:

  1. Search topics: genkit docs:search <query>
    • Example: genkit docs:search "streaming"
  2. List all docs: genkit docs:list
  3. Read a guide: genkit docs:read <path>
    • Example: genkit docs:read js/flows.md

CLI Usage

The genkit CLI is your primary tool for development and documentation.

  • See CLI Reference for common tasks, workflows, and command usage.
  • Use genkit --help for a full list of commands.

References

  • Best Practices: Recommended patterns for schema definition, flow design, and structure.
  • Docs & CLI Reference: Documentation search, CLI tasks, and workflows.
  • Common Errors: Critical "gotchas", migration guide, and troubleshooting.
  • Setup Guide: Manual setup instructions for new projects.
  • Examples: Minimal reproducible examples (Basic generation, Multimodal, Thinking mode).

Skills connexes

eightctl
firecrawl
Control Eight Sleep pods (status, temperature, alarms, schedules).
official
authoring-skills
vercel
Use this skill when creating or modifying agent skills in .agents/skills/ .
official
using-streamlit-cli
streamlit
Documente les commandes CLI de Streamlit pour exécuter des applications, gérer la configuration et effectuer des diagnostics. À utiliser lors du lancement d'applications Streamlit, de la configuration des options d'exécution, ou…
official
copilot-spaces
github
Contexte spécifique au projet pour les conversations via une documentation, du code et des instructions d'équipe organisés. Lister et charger les Copilot Spaces à l'aide d'outils MCP en lecture seule ; créer, mettre à jour et supprimer des espaces via l'API REST GitHub avec gh api. Les espaces contiennent des dépôts, fichiers, documentation et instructions personnalisées attachés qui ancrent les réponses de Copilot dans les connaissances réelles du projet. Utiliser les espaces pour répondre aux questions sur l'architecture et les normes, générer du code suivant les conventions de l'équipe, ou exécuter des étapes multiples...
official
next
vercel
Adaptateur Next.js pour intégrer des émulateurs directement dans une application Next.js via @emulators/adapter-next. À utiliser lorsque l'utilisateur doit intégrer des émulateurs dans Next.js, configurer…
official
integration-tests
microsoft
À utiliser lors de l'exécution de tests d'intégration dans le dépôt VS Code. Couvre scripts/test-integration.sh (macOS/Linux) et scripts/test-integration.bat (Windows), leurs…
official
skill-creator
neondatabase
Guide pour créer des compétences efficaces. Cette compétence doit être utilisée lorsque les utilisateurs souhaitent créer une nouvelle compétence (ou mettre à jour une compétence existante) qui étend les capacités de Claude…
official
skill-scanner
sentry
Analyser les compétences de l'agent pour détecter des problèmes de sécurité. Utiliser lorsqu'on demande de "scanner une compétence",
official