Skip to main content
Glama
WacLabs

google-play-mcp-server

by WacLabs

🎮 Google Play MCP Server

Node.js TypeScript MCP License: MIT

An MCP (Model Context Protocol) server that connects AI assistants to the Google Play Developer API v3 — enabling automated app publishing, subscription management, review monitoring, and tester management.

✨ Features

  • 📦 Publishing — List release tracks, upload AAB bundles, get store listings

  • 💰 Subscriptions & IAP — Query subscription products, base plans, pricing, and in-app products

  • ⭐ Reviews — List user reviews with ratings/device info, reply to reviews directly

  • 👥 Testers — Manage tester groups per release track

  • 🔒 Secure — Service account auth (server-to-server, no OAuth flow needed)

  • 🤖 LLM-Optimized — Markdown responses, clear error messages, proper isError flags

Related MCP server: appstore-intel-mcp

📋 Tools Reference

Publishing

Tool

Description

Read-only

gplay_list_tracks

List all release tracks (internal/alpha/beta/production) with version codes, status, rollout %, and release notes

gplay_upload_bundle

Upload .aab bundle → assign to track → commit. Supports draft mode and staged rollout

gplay_get_app_details

Get store listing (title, descriptions, contact info) for any language

Subscriptions & IAP

Tool

Description

Read-only

gplay_list_subscriptions

List all subscription products with base plans, billing periods, and pricing

gplay_get_subscription

Get detailed subscription info including all listings, base plans, regional pricing, and offer tags

gplay_list_inapp_products

List all one-time in-app products (consumable and non-consumable) with pricing

Reviews

Tool

Description

Read-only

gplay_list_reviews

List user reviews with star ratings, review text, device info, app version, and developer replies. Supports translation

gplay_reply_review

Post a developer reply to a user review (max 350 chars)

Testers

Tool

Description

Read-only

gplay_get_testers

Get Google Group testers for a release track

gplay_update_testers

Update tester Google Groups for a release track

🚀 Quick Start

1. Prerequisites

2. Google Cloud Setup

  1. Create a Google Cloud project (or use an existing one)

  2. Enable the API

    • Navigate to APIs & Services → Library

    • Search for Google Play Android Developer API

    • Click Enable

  3. Create a Service Account

    • Go to IAM & Admin → Service Accounts

    • Click Create Service Account

    • Give it a name (e.g., play-console-mcp)

    • Click Create and ContinueDone

  4. Download the JSON key

    • Click on the service account you just created

    • Go to Keys tab → Add Key → Create new key → JSON

    • Save the downloaded file securely

  5. Grant Play Console access

    • Go to Google Play Console

    • Navigate to Settings → API access

    • Link your Google Cloud project (if not already linked)

    • Find your service account and click Manage permissions

    • Grant the required permissions:

      • App information (read/write) — for store listings

      • Release management (read/write) — for tracks and uploads

      • Monetization management (read-only) — for subscriptions and IAP

      • Reviews (read + reply) — for review management

    • Click Invite userSend invitation

3. Installation

# Clone the repository
git clone https://github.com/quan7794/google-play-mcp-server.git
cd google-play-mcp-server

# Install dependencies
npm install

# Build
npm run build

Or install globally via npm (once published):

npm install -g google-play-mcp-server

4. Configuration

The server requires two environment variables:

Variable

Description

Example

GOOGLE_SERVICE_ACCOUNT_KEY

Absolute path to your service account JSON key file

/home/user/.config/gcloud/play-console-key.json

GOOGLE_PLAY_PACKAGE_NAME

Default Android package name for your app

com.example.myapp

NOTE

Thepackage_name parameter can be overridden per tool call, so you can manage multiple apps with a single server instance.

5. Add to Your MCP Client

Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "google-play": {
      "command": "node",
      "args": ["/absolute/path/to/google-play-mcp-server/dist/index.js"],
      "env": {
        "GOOGLE_SERVICE_ACCOUNT_KEY": "/path/to/service-account-key.json",
        "GOOGLE_PLAY_PACKAGE_NAME": "com.example.myapp"
      }
    }
  }
}

Add to your .vscode/mcp.json or the extension's MCP config:

{
  "servers": {
    "google-play": {
      "command": "node",
      "args": ["/absolute/path/to/google-play-mcp-server/dist/index.js"],
      "env": {
        "GOOGLE_SERVICE_ACCOUNT_KEY": "/path/to/service-account-key.json",
        "GOOGLE_PLAY_PACKAGE_NAME": "com.example.myapp"
      }
    }
  }
}

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "google-play": {
      "command": "node",
      "args": ["/absolute/path/to/google-play-mcp-server/dist/index.js"],
      "env": {
        "GOOGLE_SERVICE_ACCOUNT_KEY": "/path/to/service-account-key.json",
        "GOOGLE_PLAY_PACKAGE_NAME": "com.example.myapp"
      }
    }
  }
}

Add to .gemini/settings.json:

{
  "mcpServers": {
    "google-play": {
      "command": "node",
      "args": ["/absolute/path/to/google-play-mcp-server/dist/index.js"],
      "env": {
        "GOOGLE_SERVICE_ACCOUNT_KEY": "/path/to/service-account-key.json",
        "GOOGLE_PLAY_PACKAGE_NAME": "com.example.myapp"
      }
    }
  }
}

💬 Usage Examples

Once connected, you can ask your AI assistant things like:

"Show me all release tracks and their current versions"
"Upload the bundle at ~/build/app-release.aab to internal testing"
"What subscriptions are configured for my app?"
"Show me recent 1-star reviews"
"Reply to review abc123 thanking them for the feedback"
"What testers are on the beta track?"

🔧 Development

npm run dev    # Watch mode with hot reload (tsx)
npm run build  # Compile TypeScript to dist/
npm run clean  # Remove dist/
npm start      # Run compiled server

Project Structure

src/
├── index.ts              # Entry point — registers tools, connects stdio
├── auth.ts               # Google Auth (service account, cached client)
├── constants.ts          # Shared constants (CHARACTER_LIMIT, tracks)
├── schemas.ts            # Shared Zod schemas (PackageNameSchema)
├── tools/
│   ├── publishing.ts     # list_tracks, upload_bundle, get_app_details
│   ├── subscriptions.ts  # list/get subscriptions, list IAP
│   ├── reviews.ts        # list/reply reviews
│   └── testers.ts        # get/update testers
└── utils/
    ├── errors.ts         # GaxiosError → LLM-friendly error messages
    └── formatter.ts      # Truncation, text content helpers

❓ Troubleshooting

  • Verify GOOGLE_SERVICE_ACCOUNT_KEY points to a valid JSON key file

  • Make sure the Google Play Android Developer API is enabled in your Cloud project

  • Check that the service account hasn't been deleted or disabled

  • Go to Play Console → Settings → API access

  • Ensure the service account is listed and has been granted appropriate permissions

  • After granting permissions, it may take a few minutes to propagate

  • If you just invited the service account, make sure the invitation was accepted

  • Double-check GOOGLE_PLAY_PACKAGE_NAME matches your app's actual package name

  • Make sure the app has been published at least once (even to internal testing)

  • For subscription/IAP tools, ensure the products exist in Play Console

  • Another edit may be in progress — wait a few seconds and retry

  • Edits are automatically cleaned up on failure, but a manually created edit in Play Console could conflict

🔒 Security

  • Service account keys should never be committed to version control

  • Use minimal permissions — only grant what you need

  • The server runs locally via stdio — no network ports are opened

  • All API calls use OAuth 2.0 with the androidpublisher scope

🤝 Contributing

Contributions are welcome! Please:

  1. Fork the repository

  2. Create a feature branch (git checkout -b feature/amazing-tool)

  3. Make your changes, ensuring npm run build passes

  4. Submit a Pull Request

Adding a New Tool

  1. Add the tool registration in the appropriate file under src/tools/

  2. Use withErrorHandling() wrapper for consistent error handling

  3. Use textContent() and truncateIfNeeded() for responses

  4. Add proper Zod schemas with .describe() for all parameters

  5. Set correct annotations (readOnlyHint, destructiveHint, etc.)

  6. Update this README

📄 License

MIT © Waclabs


Built with ❤️ using Model Context Protocol and the Google Play Developer API v3.

A
license - permissive license
-
quality - not tested
D
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

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/WacLabs/Google-Play-MCP-server'

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