Skip to main content

Command-line interface for Google Analytics 4

Project description

GA CLI - Google Analytics Command Line Interface

A command-line interface tool for managing Google Analytics 4 properties, accounts, and data streams.

Note: The package is published as ga4-cli on PyPI, but the command is ga-cli.

Features

  • List and manage Google Analytics accounts
  • Create and manage GA4 properties
  • Manage data streams and retrieve measurement IDs
  • Beautiful table output with Rich
  • JSON output support
  • Authentication via service account credentials

Installation

Using pip

pip install ga4-cli

After installation, the command is available as ga-cli:

ga-cli --version
ga-cli --help

Using Docker

# Pull from Docker Hub
docker pull sulimanbenhalim/ga-cli:latest

# Or build locally
docker build -t ga-cli .

# Run with credentials mounted
docker run -v /path/to/credentials.json:/credentials.json \
  -v ~/.ga-cli:/root/.ga-cli \
  ga-cli accounts list --credentials /credentials.json

Download Binary (No Python Required)

Download standalone binaries from GitHub Releases:

Linux/macOS:

# Download and extract
curl -L -o ga-cli.tar.gz https://github.com/sulimanbenhalim/ga-cli/releases/latest/download/ga-cli-linux-amd64.tar.gz
tar -xzf ga-cli.tar.gz
chmod +x ga-cli
sudo mv ga-cli /usr/local/bin/

Windows: Download ga-cli-windows-amd64.exe.zip from the releases page, extract, and run.

From source

git clone https://github.com/sulimanbenhalim/ga-cli.git
cd ga-cli
pip install -e .

Setup

1. Get Google Service Account Credentials

  1. Go to Google Cloud Console
  2. Create or select a project
  3. Enable the Google Analytics Admin API
  4. Create a service account with Analytics Admin permissions
  5. Download the JSON credentials file

2. Initialize GA CLI

ga-cli config init

This will prompt you for the path to your service account JSON file and test the credentials.

Alternatively, set the environment variable:

export GOOGLE_APPLICATION_CREDENTIALS=/path/to/credentials.json

Usage

Configuration

# Initialize with credentials
ga-cli config init

# Show current configuration
ga-cli config show

Accounts

# List all accounts
ga-cli accounts list

# Get account details
ga-cli accounts get <account-id>

# Output as JSON
ga-cli accounts list --format json

Properties

# List properties for an account
ga-cli properties list <account-id>

# Get property details
ga-cli properties get <property-id>

# Create a new property
ga-cli properties create <account-id> --name "My Website" --timezone "America/New_York" --currency "USD"

# Delete a property
ga-cli properties delete <property-id>

Data Streams

# List data streams for a property
ga-cli datastreams list <property-id>

# Get data stream details (including measurement ID)
ga-cli datastreams get <property-id> <stream-id>

# Create a new web data stream
ga-cli datastreams create <property-id> --name "Main Website" --url "https://example.com"

Examples

Quick workflow to create a new GA4 property

# 1. List your accounts to get the account ID
ga-cli accounts list

# 2. Create a new property
ga-cli properties create 123456789 --name "BOTCHA" --timezone "Africa/Tripoli"

# 3. Create a web data stream
ga-cli datastreams create 987654321 --name "BOTCHA Website" --url "https://botcha.example.com"

# 4. Get the measurement ID
ga-cli datastreams get 987654321 111222333

Get measurement ID quickly

# If you know your property and stream IDs
ga-cli datastreams get <property-id> <stream-id> | grep "Measurement ID"

Command Reference

Global Options

  • --credentials PATH - Path to service account credentials file
  • --version - Show version
  • --help - Show help message

Output Formats

Most list and get commands support:

  • --format table (default) - Beautiful table output
  • --format json - JSON output

Development

Setup development environment

# Clone the repository
git clone https://github.com/sulimanbenhalim/ga-cli.git
cd ga-cli

# Create virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install in development mode
pip install -e .

Run tests

pytest tests/ -v

Project Structure

ga-cli/
├── ga_cli/
│   ├── __init__.py
│   ├── cli.py              # Main CLI entry point
│   ├── auth.py             # Authentication manager
│   ├── config.py           # Configuration manager
│   ├── commands/
│   │   ├── accounts.py     # Account commands
│   │   ├── properties.py   # Property commands
│   │   ├── datastreams.py  # Data stream commands
│   │   └── config.py       # Config commands
│   └── formatters/
│       ├── table.py        # Table formatter
│       └── json.py         # JSON formatter
├── tests/
├── setup.py
├── requirements.txt
└── README.md

Requirements

  • Python 3.8+
  • Click 8.0+
  • google-analytics-admin 0.27.0+
  • google-auth 2.0+
  • rich 13.0+
  • pytz 2023.3+

License

MIT License

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Support

For issues and questions, please open an issue on GitHub.

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

ga4_cli-0.1.4.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

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

ga4_cli-0.1.4-py3-none-any.whl (23.5 kB view details)

Uploaded Python 3

File details

Details for the file ga4_cli-0.1.4.tar.gz.

File metadata

  • Download URL: ga4_cli-0.1.4.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for ga4_cli-0.1.4.tar.gz
Algorithm Hash digest
SHA256 65474a19ac8363f962e667e20dbb556fb21498bde66df382a6eb28c102f7eef4
MD5 ebc2610d19c97b57085241d315e7a5dc
BLAKE2b-256 cbcf102fcbf4c20340dd56b9822c51bad21be4c0f07ab61200c72fb9fb111c84

See more details on using hashes here.

File details

Details for the file ga4_cli-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: ga4_cli-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 23.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for ga4_cli-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 cc556dbac8e7264be5b049c9bd76e0646d63551b737150d3808dbbdc17b4ade2
MD5 85236229d21a7cab38be8fd014797f86
BLAKE2b-256 83b3492918f1fa6efd2f69c4c0902687c7c08616af2fbb013b1daeefff0a744c

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