Skip to content

Bloomidea/mautic-cli

Repository files navigation

mautic-cli

Control Mautic from the command line or any AI coding agent.

License: MIT Python 3.11+ Mautic 4.x-7.x

Quick Start · Commands · Output Formats

mautic-cli screenshot

How it works

Mautic-CLI runs on your local machine (laptop, desktop, CI server) and connects to your Mautic instance remotely via its REST API. You don't install anything on your Mautic server - you just need to enable the API there.

┌──────────────────┐         HTTPS          ┌──────────────────┐
│  Your computer   │ ────── API calls ─────▶│  Mautic server   │
│  (mautic-cli)    │ ◀──── JSON responses ──│  (any hosting)   │
└──────────────────┘                        └──────────────────┘

On your Mautic server: Go to Settings > API Settings, enable the API, and enable Basic Authentication (or set up OAuth2 credentials).

On your machine: Install the CLI and run mautic auth setup - see Quick Start below.

What it does

Category Capabilities
Contacts List, search, create, edit, delete, points, segments, campaigns, activity
Segments List, create, edit, delete, add/remove contacts
Emails List, create, edit, send to contact, send to segment
Campaigns List, create, edit, delete, clone (7+), add/remove contacts
Forms List, create, edit, delete, submissions, submission by ID, contact submissions, embed code
Companies List, get, create, edit, delete, add/remove contacts
Notes List (per contact), get, create
Stages List, set contact stage
Assets List, get
Tags List, create
Categories List (with bundle filter), create
Pages List, get
Webhooks List, get, create, delete
Fields List, create
Reports List, get
Points List actions, list triggers
Auth Basic Auth, OAuth2 Client Credentials, multiple profiles
Output JSON, colored tables, CSV, NDJSON streaming

Quick Start

No Python knowledge needed. The recommended installer, uv, handles everything including Python itself:

# 0. Install uv (one-time) — see https://docs.astral.sh/uv/getting-started/installation/
curl -LsSf https://astral.sh/uv/install.sh | sh      # macOS / Linux
# powershell -c "irm https://astral.sh/uv/install.ps1 | iex"   # Windows

# 1. Install mautic-cli (uv downloads the right Python automatically)
uv tool install mautic-cli
uv tool install --upgrade mautic-cli   # upgrade to latest

# 2. Authenticate (connects to your remote Mautic instance)
mautic auth setup

# 3. Use it
mautic contacts list --limit 5
mautic --format table emails list
Alternative: install with pip

If you already have Python 3.11+ installed and prefer pip:

pip install mautic-cli

🤖 Using an AI agent? Add the skill and let your agent handle the rest:

npx skills add bloomidea/mautic-cli

"list my mautic contacts" / "send email 5 to contact 42" / "export all contacts to CSV"

Works with Claude Code, Cursor, Codex, Gemini, Windsurf, and 37+ agents.

Commands

Contacts

mautic contacts list --search "email:*@company.com" --limit 50
mautic contacts get 42
mautic contacts create --json '{"firstname":"Ana","email":"ana@example.com"}'
mautic contacts edit 42 --json '{"lastname":"Silva"}'
mautic contacts delete 42
mautic contacts add-points 42 10
mautic contacts add-to-segment 42 5
mautic contacts activity 42

Segments

mautic segments list
mautic segments get 1
mautic segments contacts 1
mautic segments create --json '{"name":"Newsletter Q1","isPublished":true}'

Emails

mautic emails list
mautic emails get 1
mautic emails send 1 --contact 42
mautic emails send-to-segment 1

Campaigns

mautic campaigns list
mautic campaigns get 1
mautic campaigns contacts 1
mautic campaigns clone 1    # Mautic 7+ only

Forms

mautic forms list
mautic forms get 1
mautic forms create --json @form.json
mautic forms edit 1 --json '{"name":"Updated Form"}'
mautic forms submissions 1              # list all submissions
mautic forms submissions 1 --offset 30 # paginate submissions
mautic forms submission 1 10           # get submission 10 from form 1
mautic forms contact-submissions 1 42  # submissions by contact 42 on form 1
mautic forms embed 1                    # show JS + iframe embed codes
mautic forms embed 1 --type js          # script tag only
mautic forms embed 1 --type iframe      # iframe only
mautic forms embed 1 --type html        # raw cached HTML
mautic forms delete 1

Companies

mautic companies list
mautic companies get 1
mautic companies create --json '{"companyname":"Acme Inc"}'
mautic companies edit 1 --json '{"companyname":"Updated"}'
mautic companies delete 1
mautic companies add-contact 1 42
mautic companies remove-contact 1 42

Notes

mautic notes list --contact 42
mautic notes get 1
mautic notes create --json '{"lead":42,"type":"general","text":"Called, no answer"}'

Stages & Points

mautic stages list
mautic stages set 42 1         # set contact 42 to stage 1
mautic points list
mautic points triggers list

Assets, Tags, Categories

mautic assets list
mautic assets get 1
mautic tags list
mautic tags create --json '{"tag":"vip"}'
mautic categories list --bundle email
mautic categories create --json '{"title":"Q1 2026","bundle":"email"}'

Pages, Webhooks, Fields, Reports

mautic pages list
mautic pages get 1
mautic webhooks list
mautic webhooks create --json '{"name":"New Lead","webhookUrl":"https://...","triggers":["mautic.lead_post_save_new"]}'
mautic webhooks delete 1
mautic fields list
mautic fields create --json '{"label":"Company Size","type":"number","group":"professional"}'
mautic reports list
mautic reports get 1
All write commands accept JSON from inline, file, or stdin
mautic contacts create --json '{"email":"test@example.com"}'
mautic contacts create --json @contact.json
cat contact.json | mautic contacts create --json @-

Output Formats

Table - colored, aligned columns with total count (powered by rich):

                     Showing 5 of 274,528
id      firstname  lastname  email               points  dateAdded
66515   Lidia      Duarte    lidia@example.com    0       2024-09-27
26698   Claudia    Preis     claudia@example.com  0       2024-08-25
mautic --format table contacts list --limit 5

JSON (default) - full API response, pretty-printed in terminal:

mautic contacts list --limit 5

CSV - same key fields, pipe to file:

mautic --format csv contacts list > contacts.csv

NDJSON - one JSON object per line, auto-paginating through all results:

mautic --page-all contacts list | jq '.fields.all.email'

Global Flags

Global flags go before the resource group:

mautic --format table --published-only emails list
Flag Description
--format json|table|csv Output format (default: json)
--pretty Pretty-print JSON
--page-all Auto-paginate, output NDJSON per record
--dry-run Show HTTP request without executing
--verbose Show HTTP request/response details
--published-only Filter to published items only
--no-verify-ssl Skip SSL certificate verification
--profile <name> Use a named config profile

Authentication

Interactive Setup

mautic auth setup    # Prompts for URL, method (basic/oauth2), credentials
mautic auth test     # Verify connection and detect Mautic version

Supports Basic Auth and OAuth2 Client Credentials grant.

Environment Variables

export MAUTIC_BASE_URL=https://mautic.example.com
export MAUTIC_USERNAME=admin
export MAUTIC_PASSWORD=secret        # zsh: use $'p@ss!' if password contains !

Profiles

Manage multiple Mautic instances with named profiles:

mautic auth setup           # Profile name: production
mautic auth setup           # Profile name: staging
mautic auth list            # Show all profiles
mautic auth delete staging  # Remove a profile

mautic --profile staging contacts list
SSL / self-signed certificates (DDEV, local dev)
# Per-command
mautic --no-verify-ssl contacts list

# Or save the preference during auth setup
mautic auth setup
# Skip SSL verification? (for self-signed certs) [y/N]: y

Search Syntax

The --search flag passes through to Mautic's native search:

mautic contacts list --search "email:*@company.com"
mautic emails list --search "name:Newsletter"
mautic --published-only segments list    # uses is:published internally

Shell Completion

Tab-completion for all commands, subcommands, and options:

mautic completion    # Shows install instructions for your shell

License

MIT