Skip to main content
Glama

Play Store MCP Server

CI codecov Security Rating Reliability Rating Maintainability Rating Vulnerabilities

PyPI version Docker Python 3.11+ Lines of Code License: MIT

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.

๐Ÿ“– Full Documentation

โœจ 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

  • ๐Ÿณ Docker Support โ€” Run as a container with health checks

  • ๐Ÿ”‘ Per-Request Credentials โ€” Bring-your-own-credentials for multi-tenant deployments

  • ๐Ÿ”’ Secure โ€” Google Cloud service account authentication

๐Ÿš€ Quick Start

Prerequisites

  1. Google Cloud Project with the Google Play Developer API enabled

  2. Service Account with access to your Play Console

  3. Python 3.11+, uvx, or Docker installed

Installation

# Run directly without installation
uvx play-store-mcp

Using pip

pip install play-store-mcp
play-store-mcp

Using Docker

docker run -e GOOGLE_APPLICATION_CREDENTIALS=/creds/key.json \
  -v /path/to/service-account.json:/creds/key.json:ro \
  ghcr.io/lusky3/play-store-mcp:latest

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

Running with HTTP Transport

For remote access or public deployments, run the server with streamable-http transport:

play-store-mcp --transport streamable-http --host 0.0.0.0 --port 8000

The server exposes a /health endpoint for monitoring.

For public deployments where users bring their own credentials, configure your MCP client to pass credentials in headers:

{
  "mcpServers": {
    "play-store": {
      "url": "https://your-server.com/mcp",
      "transport": "http",
      "headers": {
        "X-Google-Credentials-Base64": "YOUR_BASE64_ENCODED_CREDENTIALS"
      }
    }
  }
}

To get your base64-encoded credentials:

base64 -w 0 < service-account.json

Per-request credentials are isolated โ€” each request uses only the credentials provided in its headers. No credentials are stored server-side or shared between requests.

Server-Side Credentials (For Private/Trusted Deployments)

For private deployments, set credentials via environment variable at server startup:

export GOOGLE_PLAY_STORE_CREDENTIALS='{"type":"service_account",...}'
# or
export GOOGLE_APPLICATION_CREDENTIALS=/path/to/service-account.json

play-store-mcp --transport streamable-http --host 0.0.0.0 --port 8000

๐Ÿ”ง 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"
      }
    }
  }
}

Kiro

Add to .kiro/settings/mcp.json:

{
  "mcpServers": {
    "play-store": {
      "command": "uvx",
      "args": ["play-store-mcp"],
      "env": {
        "GOOGLE_APPLICATION_CREDENTIALS": "/path/to/service-account.json"
      }
    }
  }
}

Gemini CLI / 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

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

  1. Go to Google Cloud Console

  2. Create a new project or select an existing one

  3. Enable the Google Play Developer API

  4. Go to IAM & Admin > Service Accounts

  5. Create a new service account

  6. Download the JSON key file

2. Grant Play Console Access

  1. Go to Google Play Console

  2. Navigate to Users and permissions

  3. Click Invite new users

  4. Enter the service account email (from the JSON file)

  5. 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)

๐Ÿ”’ Environment Variables

Variable

Description

Required

GOOGLE_APPLICATION_CREDENTIALS

Path to service account JSON key

Yes (or use per-request credentials)

GOOGLE_PLAY_STORE_CREDENTIALS

Inline JSON credentials string

Alternative to file path

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
uv sync --dev

Running Tests

uv run 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

๐Ÿค– 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.

Install Server
A
license - permissive license
A
quality
C
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
5wRelease cycle
3Releases (12mo)

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/lusky3/play-store-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server