developing-genkit-tooling

Praktik terbaik untuk menulis perangkat Genkit, termasuk perintah CLI dan alat server MCP. Mencakup konvensi penamaan, pola arsitektur, dan konsistensi…

npx skills add https://github.com/firebase/genkit --skill developing-genkit-tooling

Developing Genkit Tooling

Naming Conventions

Consistency in naming helps users and agents navigate the tooling.

CLI Commands

Use kebab-case with colon separators for subcommands.

  • Format: noun:verb or category:action
  • Examples: flow:run, eval:run, init
  • Arguments: Use camelCase in code (flowName) but standard format in help text (<flowName>).

MCP Tools

Use snake_case for tool names to align with MCP standards.

  • Format: verb_noun
  • Examples: list_flows, run_flow, list_genkit_docs, read_genkit_docs

CLI Command Architecture

Commands are implemented in cli/src/commands/ using commander.

Runtime Interaction

Most commands require interacting with the user's project runtime. Use the runWithManager utility to handle the lifecycle of the runtime process.

import { runWithManager } from '../utils/manager-utils';

// ... command definition ...
.action(async (arg, options) => {
  await runWithManager(await findProjectRoot(), async (manager) => {
    // Interact with manager here
    const result = await manager.runAction({ key: arg });
  });
});

Output Formatting

  • Logging: Use logger from @genkit-ai/tools-common/utils.
  • Machine Readable: Provide options for JSON output or file writing when the command produces data.
  • Streaming: If the operation supports streaming (like flow:run), provide a --stream flag and pipe output to stdout.

MCP Tool Architecture

MCP tools in cli/src/mcp/ follow two distinct patterns: Static and Runtime.

Static Tools (e.g., Docs)

These tools do not require a running Genkit project context.

  • Registration: defineDocsTool(server: McpServer)
  • Dependencies: Only the server instance.
  • Use Case: Documentation, usage guides, global configuration.

Runtime Tools (e.g., Flows, Runtime Control)

These tools interact with a specific Genkit project's runtime.

  • Registration: defineRuntimeTools(server: McpServer, options: McpToolOptions)
  • Dependencies: Requires options containing manager (process manager) and projectRoot.
  • Schema: MUST use getCommonSchema(options.explicitProjectRoot, ...) to ensure the tool can accept a projectRoot argument when required (e.g., in multi-project environments).
// Runtime tool definition pattern
server.registerTool(
  'my_runtime_tool',
  {
    inputSchema: getCommonSchema(options.explicitProjectRoot, {
      myArg: z.string(),
    }),
  },
  async (opts) => {
    // Resolve project root before action
    const rootOrError = resolveProjectRoot(
      options.explicitProjectRoot,
      opts,
      options.projectRoot
    );
    if (typeof rootOrError !== 'string') return rootOrError;

    // access manager via options.manager
  }
);

Error Handling

MCP tools should generally catch errors and return them as content blocks with isError: true rather than throwing exceptions, which ensures the client receives a structured error response.

try {
  // operation
} catch (err) {
  const message = err instanceof Error ? err.message : String(err);
  return {
    isError: true,
    content: [{ type: 'text', text: `Error: ${message}` }],
  };
}

Lebih banyak skill dari firebase

firebase-remote-config-basics
firebase
Panduan lengkap untuk Firebase Remote Config, termasuk pengelolaan template dan penggunaan SDK. Gunakan keterampilan ini saat pengguna membutuhkan bantuan dalam menyiapkan Remote Config, mengelola fitur flag, atau memperbarui perilaku aplikasi secara dinamis.
officialdevelopmentapi
developing-genkit-dart
firebase
SDK AI terpadu untuk Dart yang memungkinkan pembuatan kode, output terstruktur, alat, alur, dan agen. Menyediakan API inti untuk pembuatan, definisi alat, orkestrasi alur, embeddings, dan streaming dengan satu antarmuka. Mencakup 8+ plugin untuk penyedia LLM (Google Gemini, Anthropic Claude, OpenAI GPT), Firebase AI, Model Context Protocol, integrasi peramban Chrome, dan hosting server HTTP melalui Shelf. CLI bawaan dengan UI pengembangan lokal untuk eksekusi alur, penelusuran, eksperimen model, dan...
official
developing-genkit-go
firebase
Kembangkan aplikasi bertenaga AI menggunakan Genkit di Go. Gunakan saat pengguna meminta untuk membangun fitur AI, agen, alur, atau alat di Go menggunakan Genkit, atau saat bekerja…
official
developing-genkit-js
firebase
Bangun aplikasi Node.js/TypeScript bertenaga AI dengan alur, alat, dan dukungan multi-model Genkit. Genkit tidak bergantung pada penyedia; mendukung Google AI, OpenAI, Anthropic, Ollama, dan penyedia LLM lainnya melalui plugin. Tentukan alur dengan skema yang aman tipe menggunakan Zod, jalankan permintaan generasi, dan susun alur kerja AI multi-langkah dalam TypeScript. Membutuhkan Genkit CLI v1.29.0+; perubahan API besar baru-baru ini berarti Anda harus merujuk pada genkit docs:read dan common-errors.md untuk pola terkini, bukan pengetahuan sebelumnya...
official
developing-genkit-python
firebase
Kembangkan aplikasi bertenaga AI menggunakan Genkit di Python. Gunakan saat pengguna bertanya tentang Genkit, agen AI, alur, atau alat di Python, atau saat menemui Genkit…
official
firebase-ai-logic
firebase
Integrasi Gemini sisi klien untuk aplikasi web dengan inferensi multimodal, streaming, dan eksekusi hibrida di perangkat. Mendukung input teks saja dan multimodal (gambar, audio, video, PDF); file di atas 20 MB dialihkan melalui Cloud Storage. Menyertakan sesi obrolan dengan riwayat otomatis, respons streaming untuk tampilan real-time, dan penerapan output JSON terstruktur. Menawarkan inferensi hibrida di perangkat melalui Gemini Nano di Chrome, dengan fallback otomatis ke eksekusi cloud. Memerlukan App Check untuk produksi...
official
firebase-ai-logic-basics
firebase
Keterampilan resmi untuk mengintegrasikan Firebase AI Logic (Gemini API) ke dalam aplikasi web. Mencakup pengaturan, inferensi multimodal, keluaran terstruktur, dan keamanan.
official
firebase-app-hosting-basics
firebase
Menyebarkan dan mengelola aplikasi web full-stack dengan Firebase App Hosting menggunakan Next.js, Angular, dan framework lain yang didukung. Membutuhkan proyek Firebase dengan paket harga Blaze; mendukung alur kerja Server-Side Rendering (SSR) dan Incremental Static Regeneration (ISR). Menyebarkan melalui konfigurasi firebase.json dengan apphosting.yaml opsional untuk pengaturan backend, atau mengaktifkan "git push to deploy" otomatis melalui integrasi GitHub. Termasuk manajemen rahasia melalui perintah CLI untuk akses aman ke kunci sensitif...
official