MCP server for Google Play Developer API - deploy apps, manage releases, reviews, and more
Project description
Play Store MCP Server
An MCP (Model Context Protocol) server that connects to the Google Play Developer API. Deploy apps, manage releases, respond to reviews, and monitor app health - all through your AI assistant.
✨ Features
- 🚀 App Deployment: Deploy APK/AAB files to any track (internal, alpha, beta, production)
- ⚡ Batch Operations: Deploy to multiple tracks simultaneously
- 🌍 Multi-Language Support: Deploy with release notes in multiple languages
- ✅ Input Validation: Validate package names, tracks, and text before API calls
- 🔄 Automatic Retries: Built-in retry logic with exponential backoff for transient failures
- 📝 Store Listings: Update app titles, descriptions, and videos for any language
- 📈 Release Management: Promote releases between tracks, manage staged rollouts
- 👥 Tester Management: Add and manage testers for testing tracks
- ⭐ Review Management: Fetch and reply to user reviews
- 📊 Android Vitals: Monitor crashes, ANRs, and app health metrics
- 💳 Subscription Management: List subscriptions and check purchase status
- 🛒 In-App Products: List and manage in-app products
- 📦 Expansion Files: Manage APK expansion files for large apps
- 🧾 Orders: Retrieve detailed transaction information
- 🔐 Secure: Uses Google Cloud service account authentication
🚀 Quick Start
Prerequisites
- Google Cloud Project with the Google Play Developer API enabled
- Service Account with access to your Play Console
- Python 3.11+ or
uvxinstalled
Installation
Using uvx (Recommended)
# Run directly without installation
uvx play-store-mcp
Using pip
pip install play-store-mcp
play-store-mcp
From source
git clone https://github.com/lusky3/play-store-mcp.git
cd play-store-mcp
pip install -e .
play-store-mcp
Configuration
Set the path to your service account key:
export GOOGLE_APPLICATION_CREDENTIALS=/path/to/service-account.json
🔧 MCP Client Configuration
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"play-store": {
"command": "uvx",
"args": ["play-store-mcp"],
"env": {
"GOOGLE_APPLICATION_CREDENTIALS": "/path/to/service-account.json"
}
}
}
}
Gemini / Other MCP Clients
{
"mcpServers": {
"play-store": {
"command": "uvx",
"args": ["play-store-mcp"],
"env": {
"GOOGLE_APPLICATION_CREDENTIALS": "/path/to/service-account.json"
}
}
}
}
🛠️ Available Tools
Publishing Tools
| Tool | Description |
|---|---|
deploy_app |
Deploy an APK/AAB to a track with optional staged rollout and single-language release notes |
deploy_app_multilang |
Deploy an APK/AAB with multi-language release notes |
promote_release |
Promote a release from one track to another |
get_releases |
Get release status for all tracks |
halt_release |
Halt a staged rollout |
update_rollout |
Update rollout percentage for a staged release |
list_apps |
List all apps in the developer account (limited by API) |
get_app_details |
Get app metadata (title, description, etc.) |
Store Listings Tools
| Tool | Description |
|---|---|
get_listing |
Get store listing for a specific language |
update_listing |
Update store listing (title, descriptions, video) |
list_all_listings |
List all store listings for all languages |
Review Tools
| Tool | Description |
|---|---|
get_reviews |
Fetch recent reviews with optional filters |
reply_to_review |
Reply to a user review |
Subscription Tools
| Tool | Description |
|---|---|
list_subscriptions |
List subscription products for an app |
get_subscription_status |
Check subscription purchase status |
list_voided_purchases |
List voided purchases |
In-App Products Tools
| Tool | Description |
|---|---|
list_in_app_products |
List all in-app products for an app |
get_in_app_product |
Get details of a specific in-app product |
Testers Management Tools
| Tool | Description |
|---|---|
get_testers |
Get testers for a specific testing track |
update_testers |
Update testers for a testing track |
Orders Tools
| Tool | Description |
|---|---|
get_order |
Get detailed order/transaction information |
Expansion Files Tools
| Tool | Description |
|---|---|
get_expansion_file |
Get APK expansion file information |
Validation Tools
| Tool | Description |
|---|---|
validate_package_name |
Validate package name format |
validate_track |
Validate track name |
validate_listing_text |
Validate store listing text lengths |
Batch Operations Tools
| Tool | Description |
|---|---|
batch_deploy |
Deploy to multiple tracks simultaneously |
Vitals Tools
| Tool | Description |
|---|---|
get_vitals_overview |
Get Android Vitals overview (crashes, ANRs) |
get_vitals_metrics |
Get specific vitals metrics |
📋 Google Cloud Setup
1. Create a Service Account
- Go to Google Cloud Console
- Create a new project or select an existing one
- Enable the Google Play Developer API
- Go to IAM & Admin > Service Accounts
- Create a new service account
- Download the JSON key file
2. Grant Play Console Access
- Go to Google Play Console
- Navigate to Users and permissions
- Click Invite new users
- Enter the service account email (from the JSON file)
- Grant the following permissions:
- Release apps to testing tracks (for internal/alpha/beta)
- Release apps to production (for production releases)
- Reply to reviews (for review management)
- View app information and download bulk reports (for vitals)
💡 Usage Examples
Deploy an App
# Deploy to internal testing
deploy_app(
package_name="com.example.myapp",
track="internal",
file_path="/path/to/app-release.aab",
release_notes="Bug fixes and performance improvements"
)
# Deploy with multi-language release notes
deploy_app_multilang(
package_name="com.example.myapp",
track="production",
file_path="/path/to/app-release.aab",
release_notes={
"en-US": "Bug fixes and improvements",
"es-ES": "Corrección de errores y mejoras",
"fr-FR": "Corrections de bugs et améliorations"
},
rollout_percentage=10.0 # Staged rollout to 10%
)
Manage Store Listings
# Update app description
update_listing(
package_name="com.example.myapp",
language="en-US",
title="My Awesome App",
short_description="The best app for productivity",
full_description="A comprehensive description of your app..."
)
# Get all listings
listings = list_all_listings(package_name="com.example.myapp")
Manage Testers
# Add testers to beta track
update_testers(
package_name="com.example.myapp",
track="beta",
tester_emails=["beta-testers@example.com", "qa-team@example.com"]
)
# Get current testers
testers = get_testers(package_name="com.example.myapp", track="alpha")
Handle Reviews
# Get recent reviews
reviews = get_reviews(
package_name="com.example.myapp",
max_results=50
)
# Reply to a review
reply_to_review(
package_name="com.example.myapp",
review_id="review-123",
reply_text="Thank you for your feedback! We've fixed this in the latest update."
)
Promote Releases
# Promote from beta to production
promote_release(
package_name="com.example.myapp",
from_track="beta",
to_track="production",
version_code=100,
rollout_percentage=20.0 # Start with 20% rollout
)
# Increase rollout percentage
update_rollout(
package_name="com.example.myapp",
track="production",
version_code=100,
rollout_percentage=50.0
)
Batch Operations
# Deploy to multiple tracks at once
batch_deploy(
package_name="com.example.myapp",
file_path="/path/to/app-release.aab",
tracks=["internal", "alpha"],
release_notes="Testing new features",
rollout_percentages={
"internal": 100.0,
"alpha": 50.0
}
)
Input Validation
# Validate before deploying
validation = validate_package_name("com.example.myapp")
if validation["valid"]:
deploy_app(...)
else:
print("Invalid package name:", validation["errors"])
# Validate listing text
validation = validate_listing_text(
title="My App",
short_description="A great app for productivity"
)
🔒 Environment Variables
| Variable | Description | Required |
|---|---|---|
GOOGLE_APPLICATION_CREDENTIALS |
Path to service account JSON key | Yes |
PLAY_STORE_MCP_LOG_LEVEL |
Log level (DEBUG, INFO, WARNING, ERROR) | No (default: INFO) |
🧪 Development
Setup
git clone https://github.com/lusky3/play-store-mcp.git
cd play-store-mcp
pip install -e ".[dev]"
Running Tests
pytest -v --cov=src/play_store_mcp
Linting
ruff check src/ tests/
ruff format src/ tests/
Type Checking
mypy src/
🐛 Troubleshooting
Error: "Service account key not found"
Ensure GOOGLE_APPLICATION_CREDENTIALS points to a valid JSON file:
ls -la $GOOGLE_APPLICATION_CREDENTIALS
Error: "The caller does not have permission"
Verify the service account has been granted access in Play Console with the required permissions.
Error: "Package name not found"
Ensure the app exists in Play Console and the service account has access to it.
📄 License
MIT License - see LICENSE for details.
🙏 Acknowledgments
- Inspired by antoniolg/play-store-mcp (Kotlin)
- Built with the MCP Python SDK
- Uses the Google Play Developer API
🤖 AI Usage Disclaimer
Portions of this codebase were generated with the assistance of Large Language Models (LLMs). All AI-generated code has been reviewed and tested to ensure quality and correctness.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file play_store_mcp-0.1.0.tar.gz.
File metadata
- Download URL: play_store_mcp-0.1.0.tar.gz
- Upload date:
- Size: 43.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ce062cfe4c09d72f8e47250db29c52ec6d95ef12ba07d57f2e93bc785813191
|
|
| MD5 |
4d64716ff27660854ebd40b1bbe6bddc
|
|
| BLAKE2b-256 |
68b1f8cbf82f499d3b2e9ac89e82f62a4d19c1d46a1d0d5e71944a486aef86f6
|
Provenance
The following attestation bundles were made for play_store_mcp-0.1.0.tar.gz:
Publisher:
release.yml on lusky3/play-store-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
play_store_mcp-0.1.0.tar.gz -
Subject digest:
2ce062cfe4c09d72f8e47250db29c52ec6d95ef12ba07d57f2e93bc785813191 - Sigstore transparency entry: 940076582
- Sigstore integration time:
-
Permalink:
lusky3/play-store-mcp@c670843d308a1bf49fda03061137d86adb47127a -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/lusky3
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c670843d308a1bf49fda03061137d86adb47127a -
Trigger Event:
push
-
Statement type:
File details
Details for the file play_store_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: play_store_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 23.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a7266c5fc77ae2fee566d58379d162b1e41bca1d21fc43456645094e0903ce1
|
|
| MD5 |
c8f3498500ecee977a43802195c8fb05
|
|
| BLAKE2b-256 |
073715b00790969b1f613cf5fafe9d6a4807d6edbd08f32f25357c4ea9096436
|
Provenance
The following attestation bundles were made for play_store_mcp-0.1.0-py3-none-any.whl:
Publisher:
release.yml on lusky3/play-store-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
play_store_mcp-0.1.0-py3-none-any.whl -
Subject digest:
9a7266c5fc77ae2fee566d58379d162b1e41bca1d21fc43456645094e0903ce1 - Sigstore transparency entry: 940076587
- Sigstore integration time:
-
Permalink:
lusky3/play-store-mcp@c670843d308a1bf49fda03061137d86adb47127a -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/lusky3
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c670843d308a1bf49fda03061137d86adb47127a -
Trigger Event:
push
-
Statement type: