| name | agent-platform-prompt-management |
| description | Manages and orchestrates prompts in Agent Platform. Use when you need to create, list, retrieve, version, or delete managed prompts in Agent Platform. Don't use for model training, model deployment to endpoints, or managing non-Agent Platform prompts. |
Usage Guide
To use this skill effectively:
- Generate Code: Provide the Python snippets below to the user to help them
manage prompts in Agent Platform.
- No File System Search: Do not try to find Python files or scripts on the
file system for these operations.
Phase 0: Environment Setup
CRITICAL: Before the user runs any of the Python snippets below, you MUST
advise them to ensure the environment is correctly initialized by following
these steps:
- Google Cloud Authentication: Authenticate with your Google Cloud account
and configure active Application Default Credentials (ADC) for Agent
Platform access:
gcloud auth login
gcloud auth application-default login
- Virtual Environment: Create and activate a dedicated virtual environment:
python3 -m venv ~/prompt_agent_venv
source ~/prompt_agent_venv/bin/activate
- Install Dependencies: Install the required Agent Platform SDKs:
pip install google-cloud-aiplatform google-genai
- Execution: Advise the user that every time they execute a Python snippet, they must ensure this virtual environment is activated first.
[!TIP] Placeholder Parameter Replacement: The Python scripts below use
uppercase string placeholders (like "PROJECT_ID", "LOCATION_ID", and
"PROMPT_ID"). You MUST dynamically replace these placeholders with the
actual Project ID, Region, and Prompt ID values provided in the user's prompt
(or discovered context) before generating or providing the scripts.
1. Managing Prompts via Agent Platform SDK
The SDK provides a high-level Prompt class in the preview module.
Create a Prompt (Tier M)
Use when you need to create a new managed prompt in Agent Platform.
- Reference: See create.md for detailed instructions and Python snippets.
List Prompts (Tier R)
import vertexai
from vertexai.preview import prompts
vertexai.init(project="PROJECT_ID", location="LOCATION_ID")
all_prompts = prompts.list()
for p in all_prompts:
print(f"Name: {p.display_name}, ID: {p.prompt_id}")
Retrieve and Use a Prompt (Tier R)
import vertexai
from vertexai.preview import prompts
vertexai.init(project="PROJECT_ID", location="LOCATION_ID")
retrieved_prompt = prompts.get(prompt_id="PROMPT_ID")
assembled = retrieved_prompt.assemble_contents(text="The quick brown fox...")
print(assembled)
Delete a Prompt (Tier D)
CRITICAL: You must pass the numeric prompt ID (e.g., "1234567890123456789")
to prompts.delete(). The SDK constructs the full resource path internally
using the project and location from vertexai.init().
Confirmation Required: As a Tier D (Destructive) operation, the agent MUST
pause and request explicit, high-friction typed re-confirmation of the prompt ID
from the user before generating or providing the deletion code.
The action is irreversible.
[!IMPORTANT]
NEVER pre-emptively provide or execute any deletion code before receiving
the user's response in a new turn. You must never speculate or assume that
confirmation will be given. Asking for confirmation and providing the code in
a single parallel turn is a severe safety violation.
import vertexai
from vertexai.preview import prompts
vertexai.init(project="PROJECT_ID", location="LOCATION_ID")
prompts.delete(prompt_id="PROMPT_ID")
2. Best Practices
- Idempotency:
- Tier R (List, Get): Inherently idempotent.
- Tier D (Delete): Re-running a delete on a non-existent or already
deleted resource returns NOT_FOUND. Treat this as success.
- Placeholders: Use the standard placeholder syntax (variable name
enclosed in double curly braces) in your prompt templates.
- Versioning: Always tag or record version IDs when making updates to
production prompts.
- Model Reference: Specify the target model ID (e.g.,
gemini-2.5-pro)
when creating the prompt to ensure consistency.
- Underlying Schema: When using the Dataset API, always use the correct
metadata_schema_uri and nested metadata structure to ensure the prompt
is recognized by Agent Platform Studio and the Prompts SDK.