Skip to main content

Model Context Protocol (MCP) server for Google Analytics 4 (GA4)

Project description

MCP Server for Google Analytics 4

A Model Context Protocol (MCP) server that allows Large Language Models (LLMs) to interact with Google Analytics 4 (GA4) data through the Google Analytics Data API.

Features

  • Run standard GA4 reports with customizable dimensions, metrics, and date ranges
  • Get real-time data for the past 30 minutes
  • Retrieve metadata about available metrics and dimensions
  • Secure authentication using Google Cloud's Application Default Credentials
  • Configurable for easy deployment via Smithery

Installation

Using pip

pip install mcp-server-ga4

From source

git clone https://github.com/yourusername/mcp-server-ga4.git
cd mcp-server-ga4
pip install -e .

Authentication

This server uses Google Cloud's Application Default Credentials (ADC) for authentication. Before using the server, you'll need to:

  1. Create a Google Cloud project
  2. Enable the Google Analytics Data API
  3. Set up authentication:
gcloud auth application-default login

For more details, see the Google Cloud Authentication documentation.

Usage

Command Line

Start the server with your GA4 property ID:

mcp-server-ga4 --property-id YOUR_GA4_PROPERTY_ID

The server will use the standard MCP stdio transport by default.

Environment Variables

You can also set configuration via environment variables:

  • GA4_PROPERTY_ID: Your Google Analytics 4 property ID

Using with Claude Desktop

  1. Install the server globally: pip install mcp-server-ga4
  2. Set up your Google Cloud authentication: gcloud auth application-default login
  3. Edit your Claude Desktop configuration:
{
    "mcpServers": {
        "ga4": {
            "command": "mcp-server-ga4",
            "args": ["--property-id", "YOUR_GA4_PROPERTY_ID"]
        }
    }
}

Available Tools

run-report

Runs a standard GA4 report with configurable metrics, dimensions, and date ranges.

Parameters:

  • property_id (optional): GA4 property ID (overrides the default)
  • metrics: List of metric names (e.g., ["activeUsers", "sessions"])
  • dimensions (optional): List of dimension names (e.g., ["date", "country"])
  • date_range: Date range in one of these formats:
    • {"start_date": "YYYY-MM-DD", "end_date": "YYYY-MM-DD"}
    • "last7days", "last30days", "today", "yesterday"
  • limit (optional): Number of rows to return (default: 10)

run-realtime-report

Gets real-time data for the past 30 minutes.

Parameters:

  • property_id (optional): GA4 property ID (overrides the default)
  • metrics: List of metric names (e.g., ["activeUsers", "screenPageViews"])
  • dimensions (optional): List of dimension names (e.g., ["country", "city"])
  • limit (optional): Number of rows to return (default: 10)

get-metadata

Retrieves available metrics and dimensions for a GA4 property.

Parameters:

  • property_id (optional): GA4 property ID (overrides the default)
  • type (optional): Type of metadata to retrieve ("metrics", "dimensions", or "all", default: "all")

Examples

Running a standard report

What were the top 5 countries by active users in the last 30 days?

Checking real-time data

How many users are currently active on the site?

Getting metadata information

What metrics are available for me to query in GA4?

Development

  1. Clone the repository
  2. Install development dependencies: pip install -e ".[dev]"
  3. Run tests: pytest

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iflow_mcp_harshfolio_mcp_server_ga4-0.1.0.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file iflow_mcp_harshfolio_mcp_server_ga4-0.1.0.tar.gz.

File metadata

  • Download URL: iflow_mcp_harshfolio_mcp_server_ga4-0.1.0.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_harshfolio_mcp_server_ga4-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4ad08cdbe22fe6604e9b8aa9c0b442cba995ed698419654dcdfe31e1501363ac
MD5 4f86a9697a5d6d8cef15e3f5e59c400d
BLAKE2b-256 dc8078293b548dd23596c0dacffb0587456b8a9567b39eae832d5fed5790489c

See more details on using hashes here.

File details

Details for the file iflow_mcp_harshfolio_mcp_server_ga4-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_harshfolio_mcp_server_ga4-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_harshfolio_mcp_server_ga4-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3dc400a1c0cc4579a2b121f56a96f5f037470983d63e6295a2963def4f719c69
MD5 f87566f15664d2efe84c69775c93a012
BLAKE2b-256 e0ad9c7cd542b3d318412188ea08f5467b3e5615f9277a592974b6dfbd873e45

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page