Google Play Store MCP
Manages Google Play Store listing text through the official Android Publisher API with dry-run-first safety, supporting CLI for humans/CI and MCP tools for agents.
README
Google Play Store MCP
Secure, dry-run-first Google Play Store listing automation for humans, CI, and MCP agents.
This project manages Google Play Store listing text through the official Android Publisher API. It is intentionally not a browser automation tool and does not depend on fastlane at runtime.
Why This Exists
Google Play listing work has two very different operators:
- Humans and CI need a CLI that can export, diff, validate, and apply listing metadata.
- Agents need an MCP server with safe tools that preview changes before committing them.
Both surfaces share one core library so security behavior, diffing, validation, and apply semantics stay consistent.
Repo Layout
packages/core Typed Android Publisher API client, listing manifests, diff, validate, apply
packages/cli gpstore command for humans and CI
packages/mcp MCP stdio server for agent tools
examples Safe example metadata, with no credentials
docs Security and operating notes
Roadmap
Read ROADMAP.md for the current plan. Screenshot and media replacement details live in docs/media-roadmap.md.
Current Capabilities
- Export current localized listing text from Google Play.
- Load fastlane/supply-style metadata directories.
- Preview exact localized text changes.
- Stage and validate Google Play edits without committing them.
- Commit listing text only with explicit confirmation.
- Use service-account JSON from a local file path only.
- Redact and avoid logging secrets.
Screenshots and media asset replacement are designed into the core client as Android Publisher image primitives, but the first public workflow focuses on listing text. The screenshot pipeline should come next as a manifest-driven media diff/apply flow.
Install
This repo is scaffolded as an npm workspace. After cloning:
npm install
npm run build
For local MCP usage after build:
{
"mcpServers": {
"google-play-store": {
"command": "node",
"args": ["/absolute/path/to/google-play-store-mcp/packages/mcp/dist/index.js"],
"env": {
"GOOGLE_APPLICATION_CREDENTIALS": "/absolute/path/to/service-account.json"
}
}
}
}
CLI Usage
Use a fastlane/supply-style metadata directory:
metadata/android/en-US/title.txt
metadata/android/en-US/short_description.txt
metadata/android/en-US/full_description.txt
metadata/android/es-US/title.txt
metadata/android/es-US/short_description.txt
metadata/android/es-US/full_description.txt
Preview changes:
gpstore diff \
--package-name com.example.app \
--metadata-dir ./metadata/android \
--credentials /absolute/path/to/service-account.json
Validate with Google Play and discard the edit:
gpstore validate \
--package-name com.example.app \
--metadata-dir ./metadata/android \
--credentials /absolute/path/to/service-account.json
Apply only after review:
gpstore apply \
--package-name com.example.app \
--metadata-dir ./metadata/android \
--credentials /absolute/path/to/service-account.json \
--confirm APPLY_GOOGLE_PLAY_LISTING_CHANGES
Export current listing metadata:
gpstore export \
--package-name com.example.app \
--out ./metadata/android \
--credentials /absolute/path/to/service-account.json
MCP Tools
play_listing_diff: dry-run listing diff.play_listing_validate: stages listing changes in a Google Play edit, validates them, then deletes the edit.play_listing_apply: commits listing changes only whenconfirmis exactlyAPPLY_GOOGLE_PLAY_LISTING_CHANGES.play_listing_export: returns current localized listing text as structured JSON.
MCP clients should still ask the user before calling play_listing_apply, because it modifies a cloud-managed public store listing.
Security Model
Read docs/security.md before using this with a real app.
Short version:
- No browser scraping.
- No credential upload.
- No credential persistence.
- No raw service-account JSON in config files.
- Dry-run and validation before apply.
- Apply requires explicit confirmation.
- Use least-privilege Play Console service accounts.
Official API References
- Android Publisher API overview: https://developer.android.com/google/play/developer-api
- Localized listing updates: https://developers.google.com/android-publisher/api-ref/rest/v3/edits.listings/update
- Android Publisher media uploads: https://developers.google.com/android-publisher/upload
- MCP TypeScript SDK: https://modelcontextprotocol.io/docs/sdk
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
E2B
Using MCP to run code via e2b.