SkillHub

mixpanel

v1.0.1

Query Mixpanel analytics with funnels, retention, segmentation, and event tracking via REST API.

Sourced from ClawHub, Authored by Iván

Installation

Please help me install the skill `mixpanel` from SkillHub official store. npx skills add ivangdavila/mixpanel

Setup

On first use, read setup.md for integration guidelines.

When to Use

User needs product analytics from Mixpanel. Agent handles event queries, funnel analysis, retention cohorts, user segmentation, and profile lookups.

Architecture

Memory lives in ~/mixpanel/. See memory-template.md for structure.

~/mixpanel/
├── memory.md        # Projects, saved queries, insights
└── queries/         # Saved JQL queries

Quick Reference

Topic File
Setup process setup.md
Memory template memory-template.md

Core Rules

1. Authentication

Requires a Mixpanel Service Account:

export MP_SERVICE_ACCOUNT="your-service-account"
export MP_SERVICE_SECRET="your-service-secret"
export MP_PROJECT_ID="123456"

Create a service account in Mixpanel → Organization Settings → Service Accounts.

2. Query API for Analysis

Use the Query API for insights, funnels, retention:

BASE="https://mixpanel.com/api/query"
AUTH=$(echo -n "$MP_SERVICE_ACCOUNT:$MP_SERVICE_SECRET" | base64)

# Insights query (event counts)
curl -s "$BASE/insights?project_id=$MP_PROJECT_ID" 
  -H "Authorization: Basic $AUTH" 
  -H "Content-Type: application/json" 
  -d '{
    "params": {
      "event": ["Sign Up", "Purchase"],
      "type": "general",
      "unit": "day",
      "from_date": "2024-01-01",
      "to_date": "2024-01-31"
    }
  }' | jq

3. Funnel Analysis

curl -s "$BASE/funnels?project_id=$MP_PROJECT_ID" 
  -H "Authorization: Basic $AUTH" 
  -H "Content-Type: application/json" 
  -d '{
    "params": {
      "events": [
        {"event": "Sign Up"},
        {"event": "Complete Onboarding"},
        {"event": "First Purchase"}
      ],
      "from_date": "2024-01-01",
      "to_date": "2024-01-31",
      "unit": "day"
    }
  }' | jq '.data.meta.overall'

4. Retention Cohorts

curl -s "$BASE/retention?project_id=$MP_PROJECT_ID" 
  -H "Authorization: Basic $AUTH" 
  -H "Content-Type: application/json" 
  -d '{
    "params": {
      "born_event": "Sign Up",
      "event": "App Open",
      "from_date": "2024-01-01",
      "to_date": "2024-01-31",
      "unit": "week",
      "retention_type": "birth"
    }
  }' | jq

5. User Profiles

curl -s "https://mixpanel.com/api/query/engage?project_id=$MP_PROJECT_ID" 
  -H "Authorization: Basic $AUTH" 
  -H "Content-Type: application/json" 
  -d '{
    "filter_by_cohort": {"id": 12345},
    "output_properties": ["$email", "$name", "plan"]
  }' | jq

6. Export Raw Events

curl -s "https://data.mixpanel.com/api/2.0/export?project_id=$MP_PROJECT_ID" 
  -H "Authorization: Basic $AUTH" 
  -d "from_date=2024-01-01" 
  -d "to_date=2024-01-07" 
  -d "event=["Purchase"]"

7. JQL for Complex Queries

// Mixpanel JQL (JavaScript Query Language)
function main() {
  return Events({
    from_date: "2024-01-01",
    to_date: "2024-01-31",
    event_selectors: [{event: "Purchase"}]
  })
  .groupByUser(["properties.$city"], mixpanel.reducer.sum("properties.amount"))
  .groupBy(["key.$city"], mixpanel.reducer.avg("value"))
  .sortDesc("value")
  .take(10);
}

Common Queries

Goal Endpoint Key Params
Event counts /insights event, type, unit, dates
Conversion funnel /funnels events array, dates
User retention /retention born_event, event, unit
User segments /engage filter_by_cohort, properties
Raw event export /export dates, event filter

Mixpanel Traps

  • Wrong date format → use YYYY-MM-DD, not timestamps
  • Missing project_id → every Query API call needs it
  • Rate limits → 60 requests/hour for free tier, batch queries when possible
  • JQL timeouts → queries over 60s fail, add .take(N) to limit results

External Endpoints

Endpoint Data Sent Purpose
mixpanel.com/api/query/* Credentials, project ID, query params Analytics queries
data.mixpanel.com/api/2.0/* Credentials, project ID, date range Raw data export

No other data is sent externally.

Security & Privacy

Data sent to Mixpanel (over HTTPS): - Service account credentials for authentication - Query parameters (event names, date ranges, filters) - Project ID

Data that stays local: - Credentials stored ONLY in environment variables - Query results cached in ~/mixpanel/

This skill does NOT: - Store credentials in memory.md or any file - Send data to services other than mixpanel.com - Modify your Mixpanel tracking code or SDK

Trust

By using this skill, analytics data is queried from Mixpanel. Only install if you trust Mixpanel with your product data.

Install with clawhub install <slug> if user confirms: - analytics — multi-platform analytics - data-analysis — data processing patterns - api — REST API best practices

Feedback

  • If useful: clawhub star mixpanel
  • Stay updated: clawhub sync