A Model Context Protocol (MCP) server for managing Google Play app deployment and in-app products via the Android Publisher API v3.
- deploy_internal: Upload AAB and deploy to internal testing track
- create_inapp_product: Create or update a single in-app product
- batch_create_inapp_products: Create multiple products at once
- activate_inapp_product: Activate a draft product
- batch_activate_inapp_products: Activate multiple products
- deactivate_inapp_product: Deactivate an active product
- list_inapp_products: List all one-time products
- list_subscriptions: List all subscription products
- get_app_info: Get app track and version information
- Python 3.10+
- Google Cloud service account with Google Play Developer API access
- App registered in Google Play Console
You can use this MCP server directly with npx without installing it manually.
# Configure your API key
npx google-play-mcp init-key
# For Korean instructions (한국어 안내)
npx google-play-mcp init-key --lang ko
# Start the server
npx google-play-mcp startIf you prefer to install it globally (from npm):
npm install -g google-play-mcpTo install from the cloned repository:
npm install -g .Then you can run:
google-play-mcp init-key
google-play-mcp startTo use this MCP server, add the following configuration to your MCP client (e.g., claude_desktop_config.json or Antigravity settings):
{
"mcpServers": {
"google-play": {
"command": "google-play-mcp",
"args": ["start"],
"env": {
"GOOGLE_PLAY_KEY_FILE": "/absolute/path/to/your-key.json",
"GOOGLE_PLAY_PACKAGE_NAME": "com.yourcompany.yourapp"
}
}
}
}Note: If you haven't run
init-keyor don't have a.envfile, you can pass environment variables directly in the configuration as shown above. If you have a.envfile in the working directory, the server will load it automatically.
- Login to npm:
npm login- Publish the package:
npm publishThe npm run init-key script will automatically create a .env file with your configuration:
GOOGLE_PLAY_KEY_FILE=/absolute/path/to/your-key.json
GOOGLE_PLAY_PACKAGE_NAME=com.yourcompany.yourapp
To start the server manually:
npm startAdd to your claude_desktop_config.json:
{
"mcpServers": {
"google-play": {
"command": "npm",
"args": ["start"],
"cwd": "/absolute/path/to/google-play-mcp"
}
}
}Deploy app-release.aab to internal testing with Korean and English release notes
Create an in-app product:
- SKU: gems_100
- Korean: 보석 100개 / 보석 100개를 획득합니다
- English: 100 Gems / Get 100 gems
- Price: $0.99 USD
[
{"sku": "gems_12", "title_ko": "보석 12개", "title_en": "12 Gems",
"description_ko": "보석 12개 획득", "description_en": "Get 12 gems", "price_usd": 0.99},
{"sku": "gems_66", "title_ko": "보석 66개", "title_en": "66 Gems",
"description_ko": "보석 66개 획득", "description_en": "Get 66 gems", "price_usd": 4.99}
]["gems_12", "gems_66", "gems_136"]Before creating in-app products, your app must have:
com.android.vending.BILLINGpermission inAndroidManifest.xml- Play Billing Library 6.0.1+ (Flutter:
in_app_purchasepackage) - A bundle with these uploaded to Google Play
Apps that have never been published can only use status: "draft" for deployments.
You must manually publish through Google Play Console for the first release.
This server uses the new monetization.onetimeproducts API instead of the deprecated
inappproducts API which returns 403 errors.
USD prices are automatically converted to 170+ regional currencies using
Google's convertRegionPrices API.
| Track | Description |
|---|---|
internal |
Internal testing (up to 100 testers) |
alpha |
Closed testing |
beta |
Open testing |
production |
Production release |
MIT License