Guidelines for AI agents working in this repository.
This repository contains Agent Skills for AI agents following the Agent Skills specification. Skills install to .agents/skills/ (the cross-agent standard). This repo also serves as a Claude Code plugin marketplace via .claude-plugin/marketplace.json.
- Name: Marketing Skills
- GitHub: coreyhaines31/marketingskills
- Creator: Corey Haines
- License: MIT
marketingskills/
├── .claude-plugin/
│ └── marketplace.json # Claude Code plugin marketplace manifest
├── skills/ # Agent Skills
│ └── skill-name/
│ └── SKILL.md # Required skill file
├── tools/
│ ├── clis/ # Zero-dependency Node.js CLI tools (51 tools)
│ ├── composio/ # Composio integration layer (quick start + toolkit mapping)
│ ├── integrations/ # API integration guides per tool
│ └── REGISTRY.md # Tool index with capabilities
├── CONTRIBUTING.md
├── LICENSE
└── README.md
Skills are content-only (no build step). Verify manually:
- YAML frontmatter is valid
namefield matches directory name exactlynameis 1-64 chars, lowercase alphanumeric and hyphens onlydescriptionis 1-1024 characters
CLI tools (tools/clis/*.js) are zero-dependency Node.js scripts (Node 18+). Verify with:
node --check tools/clis/<name>.js # Syntax check
node tools/clis/<name>.js # Show usage (no args = help)
node tools/clis/<name>.js <cmd> --dry-run # Preview request without sendingSkills follow the Agent Skills spec.
---
name: skill-name
description: What this skill does and when to use it. Include trigger phrases.
---| Field | Required | Constraints |
|---|---|---|
name |
Yes | 1-64 chars, lowercase a-z, numbers, hyphens. Must match dir. |
description |
Yes | 1-1024 chars. Describe what it does and when to use it. |
license |
No | License name (default: MIT) |
metadata |
No | Key-value pairs (author, version, etc.) |
- Lowercase letters, numbers, and hyphens only
- Cannot start or end with hyphen
- No consecutive hyphens (
--) - Must match parent directory name exactly
Valid: page-cro, email-sequence, ab-test-setup
Invalid: Page-CRO, -page, page--cro
skills/skill-name/
├── SKILL.md # Required - main instructions (<500 lines)
├── references/ # Optional - detailed docs loaded on demand
├── scripts/ # Optional - executable code
└── assets/ # Optional - templates, data files
- Keep
SKILL.mdunder 500 lines (move details toreferences/) - Use H2 (
##) for main sections, H3 (###) for subsections - Use bullet points and numbered lists liberally
- Short paragraphs (2-4 sentences max)
- Direct and instructional
- Second person ("You are a conversion rate optimization expert")
- Professional but approachable
- Bold (
**text**) for key terms - Code blocks for examples and templates
- Tables for reference data
- No excessive emojis
- Clarity over cleverness
- Specific over vague
- Active voice over passive
- One idea per section
The description is critical for skill discovery. Include:
- What the skill does
- When to use it (trigger phrases)
- Related skills for scope boundaries
description: When the user wants to optimize conversions on any marketing page. Use when the user says "CRO," "conversion rate optimization," "this page isn't converting." For signup flows, see signup-flow-cro.This repo also serves as a plugin marketplace. The manifest at .claude-plugin/marketplace.json lists all skills for installation via:
/plugin marketplace add coreyhaines31/marketingskills
/plugin install marketing-skillsSee Claude Code plugins documentation for details.
- New skills:
feature/skill-name - Improvements:
fix/skill-name-description - Documentation:
docs/description
Follow the Conventional Commits specification:
feat: add skill-name skillfix: improve clarity in page-crodocs: update README
-
namematches directory name exactly -
namefollows naming rules (lowercase, hyphens, no--) -
descriptionis 1-1024 chars with trigger phrases -
SKILL.mdis under 500 lines - No sensitive data or credentials
This repository includes a tools registry for agent-compatible marketing tools.
- Tool discovery: Read
tools/REGISTRY.mdto see available tools and their capabilities - Integration details: See
tools/integrations/{tool}.mdfor API endpoints, auth, and common operations - MCP-enabled tools: ga4, stripe, mailchimp, google-ads, resend, zapier, zoominfo, clay, supermetrics, coupler, outreach, crossbeam, introw, composio
- Composio (integration layer): Adds MCP access to OAuth-heavy tools without native MCP servers (HubSpot, Salesforce, Meta Ads, LinkedIn Ads, Google Sheets, Slack, etc.). See
tools/integrations/composio.md
tools/
├── REGISTRY.md # Index of all tools with capabilities
└── integrations/ # Detailed integration guides
├── ga4.md
├── stripe.md
├── rewardful.md
└── ...
Skills reference relevant tools for implementation. For example:
referral-programskill → rewardful, tolt, dub-co, mention-me guidesanalytics-trackingskill → ga4, mixpanel, segment guidesemail-sequenceskill → customer-io, mailchimp, resend guidespaid-adsskill → google-ads, meta-ads, linkedin-ads guides
For tools without native MCP servers (HubSpot, Salesforce, Meta Ads, LinkedIn Ads, Google Sheets, Slack, Notion), Composio provides MCP access via a single server. See tools/integrations/composio.md for setup and tools/composio/marketing-tools.md for the full toolkit mapping.
When using any skill from this repository:
-
Once per session, on first skill use, check for updates:
- Fetch
VERSIONS.mdfrom GitHub: https://raw.githubusercontent.com/coreyhaines31/marketingskills/main/VERSIONS.md - Compare versions against local skill files
- Fetch
-
Only prompt if meaningful:
- 2 or more skills have updates, OR
- Any skill has a major version bump (e.g., 1.x to 2.x)
-
Non-blocking notification at end of response:
--- Skills update available: X marketing skills have updates. Say "update skills" to update automatically, or run `git pull` in your marketingskills folder. -
If user says "update skills":
- Run
git pullin the marketingskills directory - Confirm what was updated
- Run
See README.md for the current list of skills organized by category. When adding new skills, follow the naming patterns of existing skills in that category.
These patterns are Claude Code only and must not be added to SKILL.md files directly, as skills are designed to be cross-agent compatible (Codex, Cursor, Windsurf, etc.). Apply them locally in your own project's .claude/skills/ overrides instead.
Claude Code supports embedding shell commands in SKILL.md using !`command` syntax. When the skill is invoked, Claude Code runs the command and injects the output inline — the model sees the result, not the instruction.
Most useful application: auto-inject the product marketing context file
Instead of every skill telling the agent "go check if .agents/product-marketing-context.md exists and read it," you can inject it automatically:
Product context: !`cat .agents/product-marketing-context.md 2>/dev/null || echo "No product context file found — ask the user about their product before proceeding."`Place this at the top of a skill's body (after frontmatter) to make context available immediately without any file-reading step.
Other useful injections:
# Inject today's date for recency-sensitive skills
Today's date: !`date +%Y-%m-%d`
# Inject current git branch (useful for workflow skills)
Current branch: !`git branch --show-current 2>/dev/null`
# Inject recent commits for context
Recent commits: !`git log --oneline -5 2>/dev/null`Why this is Claude Code-only: Other agents that load skills will see the literal !`command` string rather than executing it, which would appear as garbled instructions. Keep cross-agent skill files free of this syntax.