pypi-query-mcp/PROMPT_TEMPLATES.md
longhao d63ef02ef3 feat: add comprehensive environment and trending analysis prompt templates
Environment Analysis Templates:
- analyze_environment_dependencies: Analyze current Python environment and dependencies
- check_outdated_packages: Check for outdated packages with update priorities
- generate_update_plan: Create comprehensive package update plans with strategies

Trending Analysis Templates:
- analyze_daily_trends: Analyze daily PyPI download trends and popular packages
- find_trending_packages: Discover trending packages over different time periods
- track_package_updates: Track recent package updates and releases

Key Features:
- Follow standard MCP workflow with {{parameter}} template variables
- Support environment analysis (uvx pip list integration ready)
- Enable trending package discovery and popularity analysis
- Provide structured update planning with different strategies
- Include comprehensive parameter validation and documentation
- Add usage examples and integration guides

All templates follow the established MCP prompt workflow:
1. User calls tool → MCP client sends request
2. Tool function executes → Collects necessary data and parameters
3. Call Prompt generator → Pass parameters to corresponding generator
4. Load template → Get template with {{parameter}} placeholders
5. Parameter replacement → Replace {{parameter_name}} with actual values
6. Return final prompt → As tool's response back to AI

Updated documentation and README with new template examples and usage patterns.

Signed-off-by: longhao <hal.long@outlook.com>
2025-05-29 18:47:15 +08:00

380 lines
11 KiB
Markdown

# PyPI Query MCP Server - Prompt Templates
This document describes the MCP prompt templates available in the PyPI Query MCP Server. These templates provide structured guidance for common PyPI package analysis, dependency management, and migration scenarios.
## 🎯 Overview
Prompt templates are reusable message templates that help you get structured guidance from LLMs for specific PyPI package management tasks. They provide comprehensive frameworks for analysis and decision-making.
### 🔄 MCP Workflow Implementation
Our prompt templates follow the standard MCP (Model Context Protocol) workflow:
1. **User calls tool** → MCP client sends request
2. **Tool function executes** → Collects necessary data and parameters
3. **Call Prompt generator** → Pass parameters to corresponding generator
4. **Load template** → Get template with `{{parameter}}` placeholders
5. **Parameter replacement** → Replace `{{parameter_name}}` with actual values
6. **Environment variable customization** → Apply user's custom prompt words (optional)
7. **Return final prompt** → As tool's response back to AI
This ensures consistent, reliable prompt generation that integrates seamlessly with MCP clients.
## 📋 Available Prompt Templates
### Package Analysis Templates
#### 1. `analyze_package_quality`
Generate a comprehensive quality analysis prompt for a PyPI package.
**Parameters:**
- `package_name` (required): Name of the PyPI package to analyze
- `version` (optional): Specific version to analyze
**Use Case:** When you need to evaluate a package's quality, maintenance status, security, and suitability for your project.
**Example:**
```json
{
"package_name": "requests",
"version": "2.31.0"
}
```
#### 2. `compare_packages`
Generate a detailed comparison prompt for multiple PyPI packages.
**Parameters:**
- `packages` (required): List of package names to compare (2-5 packages)
- `use_case` (required): Specific use case or project context
- `criteria` (optional): Specific criteria to focus on
**Use Case:** When choosing between multiple packages that serve similar purposes.
**Example:**
```json
{
"packages": ["requests", "httpx", "aiohttp"],
"use_case": "Building a high-performance web API client",
"criteria": ["performance", "async support", "ease of use"]
}
```
#### 3. `suggest_alternatives`
Generate a prompt for finding package alternatives.
**Parameters:**
- `package_name` (required): Package to find alternatives for
- `reason` (required): Reason for seeking alternatives (deprecated, security, performance, licensing, maintenance, features)
- `requirements` (optional): Specific requirements for alternatives
**Use Case:** When you need to replace a package due to specific concerns.
**Example:**
```json
{
"package_name": "flask",
"reason": "performance",
"requirements": "Need async support and better performance"
}
```
### Dependency Management Templates
#### 4. `resolve_dependency_conflicts`
Generate a prompt for resolving dependency conflicts.
**Parameters:**
- `conflicts` (required): List of conflicting dependencies or error messages
- `python_version` (optional): Target Python version
- `project_context` (optional): Brief project description
**Use Case:** When facing dependency version conflicts that need resolution.
**Example:**
```json
{
"conflicts": [
"django 4.2.0 requires sqlparse>=0.3.1, but you have sqlparse 0.2.4"
],
"python_version": "3.10",
"project_context": "Django web application"
}
```
#### 5. `plan_version_upgrade`
Generate a prompt for planning package version upgrades.
**Parameters:**
- `package_name` (required): Package to upgrade
- `current_version` (required): Current version being used
- `target_version` (optional): Target version or 'latest'
- `project_size` (optional): Project size context (small/medium/large/enterprise)
**Use Case:** When planning major version upgrades that might have breaking changes.
**Example:**
```json
{
"package_name": "django",
"current_version": "3.2.0",
"target_version": "4.2.0",
"project_size": "large"
}
```
#### 6. `audit_security_risks`
Generate a prompt for security risk auditing of packages.
**Parameters:**
- `packages` (required): List of packages to audit
- `environment` (optional): Environment context (development/staging/production)
- `compliance_requirements` (optional): Specific compliance requirements
**Use Case:** When conducting security audits or compliance assessments.
**Example:**
```json
{
"packages": ["django", "requests", "pillow"],
"environment": "production",
"compliance_requirements": "SOC2, GDPR compliance"
}
```
### Migration Planning Templates
#### 7. `plan_package_migration`
Generate a comprehensive package migration plan prompt.
**Parameters:**
- `from_package` (required): Package to migrate from
- `to_package` (required): Package to migrate to
- `codebase_size` (optional): Size of codebase (small/medium/large/enterprise)
- `timeline` (optional): Desired timeline
- `team_size` (optional): Number of developers involved
**Use Case:** When planning to migrate from one package to another.
**Example:**
```json
{
"from_package": "flask",
"to_package": "fastapi",
"codebase_size": "medium",
"timeline": "2 months",
"team_size": 4
}
```
#### 8. `generate_migration_checklist`
Generate a detailed migration checklist prompt.
**Parameters:**
- `migration_type` (required): Type of migration (package_replacement, version_upgrade, framework_migration, dependency_cleanup)
- `packages_involved` (required): List of packages involved
- `environment` (optional): Target environment (development/staging/production/all)
**Use Case:** When you need a comprehensive checklist for migration tasks.
**Example:**
```json
{
"migration_type": "package_replacement",
"packages_involved": ["flask", "fastapi"],
"environment": "production"
}
```
### Environment Analysis Templates
#### 9. `analyze_environment_dependencies`
Generate a prompt for analyzing current environment dependencies.
**Parameters:**
- `environment_type` (optional): Type of environment (local, virtual, docker, conda)
- `python_version` (optional): Python version in the environment
- `project_path` (optional): Path to the project directory
**Use Case:** When you need to analyze your current Python environment and check for outdated packages.
**Example:**
```json
{
"environment_type": "virtual",
"python_version": "3.11",
"project_path": "/path/to/project"
}
```
#### 10. `check_outdated_packages`
Generate a prompt for checking outdated packages with update priorities.
**Parameters:**
- `package_filter` (optional): Filter packages by name pattern
- `severity_level` (optional): Focus level (all, security, major, minor)
- `include_dev_dependencies` (optional): Include development dependencies
**Use Case:** When you want to identify and prioritize package updates.
**Example:**
```json
{
"package_filter": "django*",
"severity_level": "security",
"include_dev_dependencies": true
}
```
#### 11. `generate_update_plan`
Generate a prompt for creating comprehensive package update plans.
**Parameters:**
- `update_strategy` (optional): Update strategy (conservative, balanced, aggressive)
- `environment_constraints` (optional): Environment constraints or requirements
- `testing_requirements` (optional): Testing requirements before updates
**Use Case:** When you need a structured plan for updating packages in your environment.
**Example:**
```json
{
"update_strategy": "balanced",
"environment_constraints": "Production environment, zero downtime required",
"testing_requirements": "Full test suite + integration tests"
}
```
### Trending Analysis Templates
#### 12. `analyze_daily_trends`
Generate a prompt for analyzing daily PyPI download trends.
**Parameters:**
- `date` (optional): Specific date to analyze (YYYY-MM-DD) or 'today'
- `category` (optional): Package category to focus on (web, data, ml, etc.)
- `limit` (optional): Number of top packages to analyze (5-50)
**Use Case:** When you want to understand what packages are trending on PyPI.
**Example:**
```json
{
"date": "today",
"category": "machine-learning",
"limit": 20
}
```
#### 13. `find_trending_packages`
Generate a prompt for discovering trending packages over time periods.
**Parameters:**
- `time_period` (optional): Time period for trend analysis (daily, weekly, monthly)
- `trend_type` (optional): Type of trends to focus on (rising, declining, new, all)
- `domain` (optional): Specific domain or category (web, ai, data, etc.)
**Use Case:** When you want to discover packages that are gaining or losing popularity.
**Example:**
```json
{
"time_period": "weekly",
"trend_type": "rising",
"domain": "web-development"
}
```
#### 14. `track_package_updates`
Generate a prompt for tracking recent package updates and releases.
**Parameters:**
- `time_range` (optional): Time range for update tracking (today, week, month)
- `update_type` (optional): Type of updates to track (all, major, security, new)
- `popular_only` (optional): Focus only on popular packages (>1M downloads)
**Use Case:** When you want to stay informed about recent package updates and releases.
**Example:**
```json
{
"time_range": "week",
"update_type": "security",
"popular_only": true
}
```
## 🚀 Usage Examples
### In Claude Desktop
Add the PyPI Query MCP Server to your Claude Desktop configuration, then use prompts like:
```
Use the "analyze_package_quality" prompt template to analyze the requests package version 2.31.0
```
### In Cursor
Configure the MCP server in Cursor, then access prompts through the command palette or by typing:
```
@pypi-query analyze_package_quality requests 2.31.0
```
### Programmatic Usage
```python
from fastmcp import Client
async def use_prompt_template():
client = Client("pypi_query_mcp.server:mcp")
async with client:
# Get a prompt template
result = await client.get_prompt(
"analyze_package_quality",
{"package_name": "requests", "version": "2.31.0"}
)
# The result contains structured messages for the LLM
print(result.messages[0].content.text)
```
## 🎨 Customization
The prompt templates are designed to be comprehensive but can be customized by:
1. **Modifying parameters**: Adjust the input parameters to focus on specific aspects
2. **Combining templates**: Use multiple templates for complex scenarios
3. **Extending context**: Add project-specific context through optional parameters
## 🔧 Development
To add new prompt templates:
1. Create the template function in the appropriate module under `pypi_query_mcp/prompts/`
2. Register it in `pypi_query_mcp/server.py` using the `@mcp.prompt()` decorator
3. Add it to the `__all__` list in `pypi_query_mcp/prompts/__init__.py`
4. Update this documentation
## 📚 Best Practices
1. **Be Specific**: Provide detailed context in the parameters for better results
2. **Use Appropriate Templates**: Choose the template that best matches your scenario
3. **Combine with Tools**: Use prompt templates alongside the MCP tools for comprehensive analysis
4. **Iterate**: Refine your parameters based on the LLM responses to get better guidance
## 🤝 Contributing
We welcome contributions to improve existing templates or add new ones. Please:
1. Follow the existing template structure and patterns
2. Include comprehensive parameter validation
3. Add examples and documentation
4. Test with various scenarios
## 📄 License
These prompt templates are part of the PyPI Query MCP Server and are licensed under the same terms.