gtm-mcp
Provides tools for managing Google Tag Manager accounts, containers, tags, triggers, variables, and versions.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@gtm-mcpList my GTM accounts"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
GTM MCP Server
A Model Context Protocol (MCP) server that enables Claude to interact with Google Tag Manager.
Table of Contents
Features
List GTM accounts and containers
Manage tags, triggers, and variables
Create and publish container versions
Full workspace management
🚀 Quick Start
Prerequisites
Python 3.10 or higher
Claude Desktop (or any MCP-compatible client like Cursor)
A Google account with access to Google Tag Manager
🔧 Setup Instructions
Configure Python
Install the package using pip or pipx:
pip install gtm-mcpSee PyPi
Enable Tag Manager API
Go to Google Cloud Console
Create a new project or select an existing one
Go to "APIs & Services" → "Library"
Search for "Tag Manager API"
Click on it and click "Enable"
Configure Credentials
This server uses Application Default Credentials (ADC) for authentication. You need to set up credentials that have access to your Google Tag Manager accounts.
Step 1: Create a Service Account
Go to Google Cloud Console
Navigate to "APIs & Services" → "Credentials"
Click "Create Credentials" → "Service Account"
Fill in the service account details:
Service account name: gtm-mcp-service
Description: Service account for GTM MCP Server
Click "Create and Continue"
Skip optional steps and click "Done"
Step 2: Create and Download Service Account Key
Click on the service account you just created
Go to the "Keys" tab
Click "Add Key" → "Create New Key"
Select "JSON" format
Click "Create"
The JSON file will download automatically
Save this file securely - you'll need its path later
Copy the service account email (looks like:
gtm-mcp-service@your-project.iam.gserviceaccount.com)
Step 3: Grant Service Account Access to GTM
Go to Google Tag Manager
Select your GTM account
Click "Admin" in the top navigation
Under "Account", click "User Management"
Click the "+" button to add a user
Enter the service account email from Step 2
Select appropriate permissions:
Read: For read-only access
Edit: For creating/modifying tags, triggers, variables
Approve: For publishing container versions
Publish: For full publishing rights
Click "Invite"
Configure Claude Desktop
Edit your Claude Desktop config file:
Linux:
~/.config/Claude/claude_desktop_config.jsonmacOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Add your configuration:
{
"mcpServers": {
"gtm-mcp": {
"command": "gtm-mcp",
"env": {
"GOOGLE_APPLICATION_CREDENTIALS": "/path/to/your/service-account-key.json",
"GOOGLE_PROJECT_ID": "your-project-id"
}
}
}
}Important: Replace the values with your actual paths and project ID.
Example paths:
Linux/macOS:
/home/username/gtm-service-account.jsonWindows:
C:\\Users\\YourName\\gtm-service-account.json
To find your Project ID:
Look in the Google Cloud Console top bar, next to your project name
Or find it in your service account JSON file under the
"project_id"field
Try It Out
Restart Claude Desktop completely (close and reopen)
Ask Claude: "List my GTM accounts"
Authentication will happen automatically using the service account credentials!
🛠️ Available Tools
Once configured, Claude will have access to these GTM tools:
Tool | Description |
| List all your GTM accounts |
| List containers in an account |
| List tags in a workspace |
| Get detailed configuration of a specific tag |
| Create a new tag |
| Update an existing tag |
| List triggers in a workspace |
| Create a new trigger |
| List variables in a workspace |
| Get detailed configuration of a specific variable |
| Create a new variable (constant, data layer, cookie, URL, etc.) |
| Create and publish a new container version |
| List all versions of a container |
| Get detailed information about a specific version |
| Get the currently published (live) version |
| Get the latest version (may not be published) |
| Delete (archive) a container version |
| Restore a deleted version |
| Update version metadata (name, description, notes) |
| Mark a version as the latest |
❓ Troubleshooting
"Missing required environment variable" Error
Problem: The MCP server can't find the required environment variables.
Solution:
Ensure both
GOOGLE_APPLICATION_CREDENTIALSandGOOGLE_PROJECT_IDare set in your Claude Desktop configVerify the path to your service account JSON file is correct and absolute
On Windows, use double backslashes:
C:\\Users\\...Restart Claude Desktop after editing the config
"Failed to load Application Default Credentials" Error
Problem: The credentials file cannot be loaded or is invalid.
Solution:
Verify the service account JSON file exists at the specified path
Check that the JSON file is valid and not corrupted
Ensure the file has proper read permissions
Try downloading a new key from Google Cloud Console
"Service account has no access" Error
Problem: The service account doesn't have permission to access your GTM account.
Solution:
Go to GTM → Admin → User Management
Verify the service account email is listed with appropriate permissions
Grant at least "Read" permission (or higher based on your needs)
Can't Access GTM Accounts
Possible causes:
Service account doesn't have GTM permissions
Tag Manager API isn't enabled in your Google Cloud project
Wrong service account email was added to GTM
Solution:
Verify Tag Manager API is enabled in Google Cloud Console
Check that the service account email is added to your GTM account
Ensure proper permissions are granted in GTM User Management
Package Not Found After Install
Problem: gtm-mcp command not found after installation.
Solution:
# Ensure pip install location is in PATH
pip install --user gtm-mcp
# Or use pipx for isolated installation
pipx install gtm-mcp🔒 Security Notes
Keep your JSON key file secure - it provides full access to whatever permissions you've granted
Never commit the JSON file to version control - add it to
.gitignoreUse restrictive file permissions -
chmod 600 service-account.jsonon Unix/LinuxStore the file in a secure location with limited access
You can create new keys and delete old ones in Google Cloud Console
Regularly rotate service account keys for better security
This server only accesses GTM - no other Google services
Credentials are only used for Google Tag Manager API authentication
No credentials are sent to any third-party services
💻 Development
Running Tests
pip install -e ".[dev]"
pytest📝 License
See LICENSE file for details
🤝 Contributing
Contributions are welcome! Please:
Fork the repository
Create a feature branch
Make your changes
Submit a pull request
For bugs and feature requests, please open an issue.
🆘 Getting Help
If you encounter issues:
Check the Troubleshooting section above
Review Claude Desktop logs for error messages
Verify your Google Cloud project has Tag Manager API enabled
Ensure environment variables are set correctly in the config
Open an issue on GitHub with:
Your operating system
Python version (
python --version)Error messages from Claude Desktop logs
Steps to reproduce the issue
This server cannot be installed
Maintenance
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/tijevlam/gtm-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server