Loading...
Loading...
This skill should be used when the user wants to "write agent code", "build an agent with ADK", "add a tool", "create a callback", "define an agent", "use state management", or needs ADK (Agent Development Kit) Python API patterns and code examples. Part of the Google ADK skills suite. It provides a quick reference for agent types, tool definitions, orchestration patterns, callbacks, and state management. Do NOT use for creating new projects (use google-agents-cli-scaffold) or deployment (use google-agents-cli-deploy).
npx skill4agent add google/agents-cli google-agents-cli-adk-codeBefore using this skill, activatefirst — it contains the required development phases and scaffolding steps./google-agents-cli-workflow
agents-cli infoagents-cli scaffold create <name>agents-cli scaffold enhance .Python only for now. This cheatsheet currently covers the Python ADK SDK. Support for other languages is coming soon.
from google.adk.agents import Agent
root_agent = Agent(
name="my_agent",
model="gemini-flash-latest",
instruction="You are a helpful assistant that ...",
tools=[my_tool],
)NEVER change an existing agent'svalue unless the user explicitly asks. If a Gemini model returns a 404, it's almost always amodel=issue — run the listing command to verify availability before changing anything. For model docs, fetchGOOGLE_CLOUD_LOCATION.https://adk.dev/agents/models/google-gemini/index.mdbashuv run --with google-genai python -c " from google import genai client = genai.Client(vertexai=True, location='global') for m in client.models.list(): print(m.name) "
from google.adk.tools import FunctionTool
def get_weather(city: str) -> dict:
"""Get current weather for a city."""
return {"city": city, "temp": "22°C", "condition": "sunny"}
weather_tool = FunctionTool(func=get_weather)ADK built-in tool imports: Import the tool instance, not the module.pythonfrom google.adk.tools.load_web_page import load_web_page # CORRECT from google.adk.tools import load_web_page # WRONG
from google.adk.agents.callback_context import CallbackContext
async def initialize_state(callback_context: CallbackContext) -> None:
state = callback_context.state
if "history" not in state:
state["history"] = []
root_agent = Agent(
name="my_agent",
model="gemini-flash-latest",
instruction="...",
before_agent_callback=initialize_state,
)| File | When to read |
|---|---|
| ADK Python API — agents, tools, callbacks, plugins, state, artifacts, context caching, session rewind |
| ADK 2.0 Workflow API (experimental pre-GA, opt-in) — graph-based workflows, nodes, edges, HITL, parallel processing |
The Workflow API is experimental, pre-GA (ADK 2.0). Do NOT recommend it by default.Before suggesting workflow patterns, explain the following to the user and ask if they want to proceed:
- What it is: ADK 2.0 introduces a graph-based Workflow API — nodes (functions, LLM agents, tools) connected by edges with conditional routing, fan-out/fan-in parallelism, and human-in-the-loop interrupts.
- When it helps: Complex multi-step pipelines needing deterministic control flow, parallel processing of list items, structured approval gates, or retry logic — cases where SequentialAgent/ParallelAgent/LoopAgent feel limiting.
- Risks: Pre-GA — APIs may change before GA. Requires
and Python >= 3.11. Incompatible with Live Streaming. Scaffolded projects needgoogle-adk >= 2.0.0changes before upgrade — see the reference file for step-by-step instructions.pyproject.tomlOnly readafter the user explicitly opts in. If they decline or are unsure, use the standard ADK 1.x orchestration patterns fromreferences/adk-2.0.md(SequentialAgent, ParallelAgent, LoopAgent, BaseAgent).references/adk-python.md
curl https://adk.dev/llms.txt/google-agents-cli-workflow/google-agents-cli-scaffoldagents-cli scaffold createscaffold enhance/google-agents-cli-eval/google-agents-cli-deploy