Rei-skills segment-automation
Automate Segment tasks via Rube MCP (Composio): track events, identify users, manage groups, page views, aliases, batch operations. Always search tools first for current schemas.
git clone https://github.com/rootcastleco/rei-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/rootcastleco/rei-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/segment-automation" ~/.claude/skills/rootcastleco-rei-skills-segment-automation && rm -rf "$T"
skills/segment-automation/SKILL.mdSegment Automation via Rube MCP
Automate Segment customer data platform operations through Composio's Segment toolkit via Rube MCP.
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Segment connection via
with toolkitRUBE_MANAGE_CONNECTIONSsegment - Always call
first to get current tool schemasRUBE_SEARCH_TOOLS
Setup
Get Rube MCP: Add
https://rube.app/mcp as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
- Verify Rube MCP is available by confirming
respondsRUBE_SEARCH_TOOLS - Call
with toolkitRUBE_MANAGE_CONNECTIONSsegment - If connection is not ACTIVE, follow the returned auth link to complete Segment authentication
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. Track Events
When to use: User wants to send event data to Segment for downstream destinations
Tool sequence:
- Send a single track event [Required]SEGMENT_TRACK
Key parameters:
: User identifier (required if nouserId
)anonymousId
: Anonymous identifier (required if noanonymousId
)userId
: Event name (e.g., 'Order Completed', 'Button Clicked')event
: Object with event-specific propertiesproperties
: ISO 8601 timestamp (optional; defaults to server time)timestamp
: Object with contextual metadata (IP, user agent, etc.)context
Pitfalls:
- At least one of
oruserId
is requiredanonymousId
name is required and should follow consistent naming conventionsevent- Properties are freeform objects; ensure consistent schema across events
- Timestamp must be ISO 8601 format (e.g., '2024-01-15T10:30:00Z')
- Events are processed asynchronously; successful API response means accepted, not delivered
2. Identify Users
When to use: User wants to associate traits with a user profile in Segment
Tool sequence:
- Set user traits and identity [Required]SEGMENT_IDENTIFY
Key parameters:
: User identifier (required if nouserId
)anonymousId
: Anonymous identifieranonymousId
: Object with user properties (email, name, plan, etc.)traits
: ISO 8601 timestamptimestamp
: Contextual metadatacontext
Pitfalls:
- At least one of
oruserId
is requiredanonymousId - Traits are merged with existing traits, not replaced
- To remove a trait, set it to
null - Identify calls should be made before track calls for new users
- Avoid sending PII in traits unless destinations are configured for it
3. Batch Operations
When to use: User wants to send multiple events, identifies, or other calls in a single request
Tool sequence:
- Send multiple Segment calls in one request [Required]SEGMENT_BATCH
Key parameters:
: Array of message objects, each with:batch
: Message type ('track', 'identify', 'group', 'page', 'alias')type
/userId
: User identifieranonymousId- Additional fields based on type (event, properties, traits, etc.)
Pitfalls:
- Each message in the batch must have a valid
fieldtype - Maximum batch size limit applies; check schema for current limit
- All messages in a batch are processed independently; one failure does not affect others
- Each message must independently satisfy its type's requirements (e.g., track needs event name)
- Batch is the most efficient way to send multiple calls; prefer over individual calls
4. Group Users
When to use: User wants to associate a user with a company, team, or organization
Tool sequence:
- Associate user with a group [Required]SEGMENT_GROUP
Key parameters:
: User identifier (required if nouserId
)anonymousId
: Anonymous identifieranonymousId
: Group/organization identifier (required)groupId
: Object with group properties (name, industry, size, plan)traits
: ISO 8601 timestamptimestamp
Pitfalls:
is required; it identifies the company or organizationgroupId- Group traits are merged with existing traits for that group
- A user can belong to multiple groups
- Group traits update the group profile, not the user profile
5. Track Page Views
When to use: User wants to record page view events in Segment
Tool sequence:
- Send a page view event [Required]SEGMENT_PAGE
Key parameters:
: User identifier (required if nouserId
)anonymousId
: Anonymous identifieranonymousId
: Page name (e.g., 'Home', 'Pricing', 'Dashboard')name
: Page category (e.g., 'Docs', 'Marketing')category
: Object with page-specific properties (url, title, referrer)properties
Pitfalls:
- At least one of
oruserId
is requiredanonymousId
andname
are optional but recommended for proper analyticscategory- Standard properties include
,url
,title
,referrer
,pathsearch - Page calls are often automated; manual use is for server-side page tracking
6. Alias Users and Manage Sources
When to use: User wants to merge anonymous and identified users, or manage source configuration
Tool sequence:
- Link two user identities together [Optional]SEGMENT_ALIAS
- View source schema settings [Optional]SEGMENT_LIST_SCHEMA_SETTINGS_IN_SOURCE
- Update source configuration [Optional]SEGMENT_UPDATE_SOURCE
Key parameters:
- For ALIAS:
: New user identifier (the identified ID)userId
: Old user identifier (the anonymous ID)previousId
- For source operations:
: Source identifiersourceId
Pitfalls:
- ALIAS is a one-way operation; cannot be undone
is the anonymous/old ID,previousId
is the new/identified IDuserId- Not all destinations support alias calls; check destination documentation
- ALIAS should be called once when a user first identifies (e.g., signs up)
- Source updates may affect data collection; review changes carefully
Common Patterns
User Lifecycle
Standard Segment user lifecycle:
1. Anonymous user visits -> PAGE call with anonymousId 2. User interacts -> TRACK call with anonymousId 3. User signs up -> ALIAS (anonymousId -> userId), then IDENTIFY with traits 4. User takes action -> TRACK call with userId 5. User joins org -> GROUP call linking userId to groupId
Batch Optimization
For bulk data ingestion:
1. Collect events in memory (array of message objects) 2. Each message includes type, userId/anonymousId, and type-specific fields 3. Call SEGMENT_BATCH with the collected messages 4. Check response for any individual message errors
Naming Conventions
Segment recommends consistent event naming:
- Events: Use "Object Action" format (e.g., 'Order Completed', 'Article Viewed')
- Properties: Use snake_case (e.g., 'order_total', 'product_name')
- Traits: Use snake_case (e.g., 'first_name', 'plan_type')
Known Pitfalls
Identity Resolution:
- Always include
oruserId
on every callanonymousId - Use ALIAS only once per user identity merge
- Identify before tracking to ensure proper user association
Data Quality:
- Event names should be consistent across all sources
- Properties should follow a defined schema for downstream compatibility
- Avoid sending sensitive PII unless destinations are configured for it
Rate Limits:
- Use BATCH for bulk operations to stay within rate limits
- Individual calls are rate-limited per source
- Batch calls are more efficient and less likely to be throttled
Response Parsing:
- Successful responses indicate acceptance, not delivery to destinations
- Response data may be nested under
keydata - Check for error fields in batch responses for individual message failures
Timestamps:
- Must be ISO 8601 format with timezone (e.g., '2024-01-15T10:30:00Z')
- Omitting timestamp uses server receive time
- Historical data imports should include explicit timestamps
Quick Reference
| Task | Tool Slug | Key Params |
|---|---|---|
| Track event | SEGMENT_TRACK | userId, event, properties |
| Identify user | SEGMENT_IDENTIFY | userId, traits |
| Batch calls | SEGMENT_BATCH | batch (array of messages) |
| Group user | SEGMENT_GROUP | userId, groupId, traits |
| Page view | SEGMENT_PAGE | userId, name, properties |
| Alias identity | SEGMENT_ALIAS | userId, previousId |
| Source schema | SEGMENT_LIST_SCHEMA_SETTINGS_IN_SOURCE | sourceId |
| Update source | SEGMENT_UPDATE_SOURCE | sourceId |
| Warehouses | SEGMENT_LIST_CONNECTED_WAREHOUSES_FROM_SOURCE | sourceId |
When to Use
This skill is applicable to execute the workflow or actions described in the overview.
🏰 Rei Skills — Curated by Rootcastle Engineering & Innovation | Batuhan Ayrıbaş
Engineering Beyond Boundaries | admin@rootcastle.com