npx skills add https://github.com/obra/superpowers --skill brainstormingHow Developing Genkit Go fits into a Paperclip company.
Developing Genkit Go drops into any Paperclip agent that handles this kind of work. Assign it to a specialist inside a pre-configured PaperclipOrg company and the skill becomes available on every heartbeat — no prompt engineering, no tool wiring.
Pre-configured AI company — 18 agents, 18 skills, one-time purchase.
SKILL.md97 linesExpandCollapse
---name: developing-genkit-godescription: Develop AI-powered applications using Genkit in Go. Use when the user asks to build AI features, agents, flows, or tools in Go using Genkit, or when working with Genkit Go code involving generation, prompts, streaming, tool calling, or model providers.metadata: genkit-managed: true--- # Genkit Go Genkit Go is an AI SDK for Go that provides generation, structured output, streaming, tool calling, prompts, and flows with a unified interface across model providers. ## Hello World ```gopackage main import ( "context" "fmt" "log" "net/http" "github.com/genkit-ai/genkit/go/ai" "github.com/genkit-ai/genkit/go/genkit" "github.com/genkit-ai/genkit/go/plugins/googlegenai" "github.com/genkit-ai/genkit/go/plugins/server") func main() { ctx := context.Background() g := genkit.Init(ctx, genkit.WithPlugins(&googlegenai.GoogleAI{})) genkit.DefineFlow(g, "jokeFlow", func(ctx context.Context, topic string) (string, error) { return genkit.GenerateText(ctx, g, ai.WithModelName("googleai/gemini-flash-latest"), ai.WithPrompt("Tell me a joke about %s", topic), ) }) mux := http.NewServeMux() for _, f := range genkit.ListFlows(g) { mux.HandleFunc("POST /"+f.Name(), genkit.Handler(f)) } log.Fatal(server.Start(ctx, "127.0.0.1:8080", mux))}``` ## Core Features Load the appropriate reference based on what you need: | Feature | Reference | When to load || --- | --- | --- || Initialization | [references/getting-started.md](references/getting-started.md) | Setting up `genkit.Init`, plugins, the `*Genkit` instance pattern || Generation | [references/generation.md](references/generation.md) | `Generate`, `GenerateText`, `GenerateData`, streaming, output formats || Prompts | [references/prompts.md](references/prompts.md) | `DefinePrompt`, `DefineDataPrompt`, `.prompt` files, schemas || Tools | [references/tools.md](references/tools.md) | `DefineTool`, tool interrupts, `RestartWith`/`RespondWith` || Flows & HTTP | [references/flows-and-http.md](references/flows-and-http.md) | `DefineFlow`, `DefineStreamingFlow`, `genkit.Handler`, HTTP serving || Model Providers | [references/providers.md](references/providers.md) | Google AI, Vertex AI, Anthropic, OpenAI-compatible, Ollama setup | ## Genkit CLI Check if installed: `genkit --version` **Installation:**```bashcurl -sL cli.genkit.dev | bash``` **Key commands:** ```bash# Start app with Developer UI (tracing, flow testing) at http://localhost:4000genkit start -- go run .genkit start -o -- go run . # also opens browser # Run a flow directly from the CLIgenkit flow:run myFlow '{"data": "input"}'genkit flow:run myFlow '{"data": "input"}' --stream # with streaminggenkit flow:run myFlow '{"data": "input"}' --wait # wait for completion # Look up Genkit documentationgenkit docs:search "streaming" gogenkit docs:list gogenkit docs:read go/flows.md``` See [references/getting-started.md](references/getting-started.md) for full CLI and Developer UI details. ## Key Guidance - **Pass `g` explicitly.** The `*Genkit` instance returned by `genkit.Init` is the central registry. Pass it to all Genkit functions rather than storing it as a global. This is a core pattern throughout the SDK.- **Wrap AI logic in flows.** Flows give you tracing, observability, HTTP deployment via `genkit.Handler`, and the ability to test from the Developer UI and CLI. Any generation call worth keeping should live in a flow.- **Use `jsonschema:"description=..."` struct tags on output types.** The model uses these descriptions to understand what each field should contain. Without them, structured output quality drops significantly.- **Write good tool descriptions.** The model decides which tools to call based on their description string. Vague descriptions lead to missed or incorrect tool calls.- **Use `.prompt` files for complex prompts.** They separate prompt content from Go code, support Handlebars templating, and can be iterated on without recompilation. Code-defined prompts are better for simple, single-line cases.- **Look up the latest model IDs.** Model names change frequently. Check provider documentation for current model IDs rather than relying on hardcoded names. See [references/providers.md](references/providers.md).Developing Genkit Dart
This handles Genkit Dart SDK integration for building AI agents and LLM-powered Dart/Flutter apps. It knows the plugin ecosystem well, from Google Gemini and Op
Developing Genkit Js
Built for the post-1.0 Genkit world where the APIs completely changed and most online examples are broken. This skill forces you to check common-errors.md befor
Firebase Ai Logic
Integrates Google's Gemini AI models directly into web apps through Firebase's client-side SDK, handling everything from basic text generation to multimodal inp