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.2.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.2-py3-none-any.whl (23.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ga4_cli-0.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 1ec062c79a7205eb7c5e62152a78efdaba5c1d5fb6f2401a801f10871be45dfd
MD5 86fe1e26458bfa0dace5437a462949a7
BLAKE2b-256 a8938b8d339137e23a17ad7bad5425504208d32e1c6db9789f7336782600b8f1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ga4_cli-0.1.2-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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ff0b18229deecb0c247124359aae868ae6977048935dc1c45d9223004bbf6a43
MD5 395f597c4f3e933ba5119dc3f94329ef
BLAKE2b-256 f5138d66171e4beb3c513aa6401407f8c429e15520f318717cdf20d4ce8c8d6c

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