@affise/mcp-server
v2.0.1
Published
MCP server for the Affise public API: stdio transport, 23 tools, 6 analysis prompts
Maintainers
Readme
Affise MCP Server
A Model Context Protocol (MCP) server that provides access to Affise affiliate marketing platform data and analytics. This server enables AI assistants like Claude to interact with Affise APIs for comprehensive affiliate marketing analysis and monitoring using natural language queries.
Features
🔧 Tools (23 total)
Status & search
affise_status— Check Affise API connectivity and configurationaffise_search_offers— Search offers with natural-language queries (e.g. "find gaming offers for US mobile")affise_smart_search🧠 — Intelligent offer search with auto category/country resolutionaffise_offer_categories— List/search offer categoriesaffise_get_offer— Fetch detail for a single offer by idaffise_offer_tracking_link— Generate a tracking link foroffer × affiliate × sub IDs
Statistics
affise_stats— Statistics by natural language ("top 10 partners by income last week")affise_stats_raw— Structured stats query withslice/fields/filter(Affise/3.0/stats/custom)affise_conversions_raw— Per-event conversion records from/3.0/stats/conversionsaffise_get_conversion— Fetch a single conversion by idaffise_trafficback— Trafficback reason / partner / geo breakdownaffise_retention_rate— Retention analytics across periodsaffise_time_to_action— Time-to-action distribution analytics
Admin: partners & advertisers
affise_list_partners— Paginated affiliate listaffise_get_partner— Affiliate detail by idaffise_list_advertisers— Paginated advertiser listaffise_get_advertiser— Advertiser detail by MongoId
Partner-role (requires a partner-scoped API key)
affise_partner_profile— Calling affiliate's own profileaffise_partner_balance— Calling affiliate's own balanceaffise_partner_news— News feed visible to the affiliateaffise_partner_offers— Offers visible to the affiliateaffise_partner_live_offers— Currently-live offersaffise_partner_find_subs— Discover sub-ID values the affiliate has used
📊 Analysis Prompts (6)
analyze_offers— Offer-portfolio analysis (performance, market, technical, competitive, compliance)analyze_stats— Stats analysis (geo, performance, conversion, traffic)analyze_trafficback— Trafficback root-cause and optimization insightsanalyze_conversions— Conversion-level analysis (fraud review, attribution, partner quality, geo/tech, payouts)workflow_analysis— End-to-end offer search → analysis pipelineauto_analysis— Multi-data-type orchestration across stats/conversions/offers
🚀 Capabilities
- Natural-language queries — ask in plain English; the parser handles dimensions, top-N, filters, sub-IDs, periods
- Auto-resolution — partner
clientId→ numericid, advertiser/category names → IDs, vertical keywords → category IDs - Response compaction — tabular outputs (stats, conversions, partners, advertisers) ship a
{columns, rows, dropped_columns?}envelope, saving 50–70% tokens vs raw JSON - Strict validation — security-aware input sanitization with defensive coercion of numeric-keyed objects back to arrays
- Smart caching — per-tool TTL (e.g. 5 min for categories, 3 min for stats, longer for static lookups)
Installation
Prerequisites
- Node.js 18+ (LTS recommended)
- Docker (recommended)
- Affise API credentials
Method 1: Docker
Clone the repository:
git clone <repository-url> cd mcp-affiseBuild the Docker image:
docker build -t affise-mcp-server:latest .Configure environment variables: Create a
.envfile in the project root:AFFISE_BASE_URL=https://api-demo.affise.com AFFISE_API_KEY=your_affise_api_key_here NODE_ENV=production
Method 2: Local Development
Install dependencies:
npm installBuild the project:
npm run buildStart the MCP server:
npm start
Configuration
Environment Variables
| Variable | Required | Description | Default |
|----------|----------|-------------|---------|
| AFFISE_BASE_URL | ✅ | Base URL for your Affise instance | https://api-demo.affise.com |
| AFFISE_API_KEY | ✅ | Your Affise API key | - |
| NODE_ENV | ❌ | Environment mode | development |
Getting Affise API Credentials
- Log into your Affise dashboard
- Navigate to Settings → Users → Add & Manage → Get User
- Get current user API key
- Copy the API key and your instance API URL
Usage with Claude Desktop
Method 1: Desktop Extension (Recommended) 🚀
The easiest way to install is using the Desktop Extension (.dxt) - a one-click installation package.
Step 1: Install DXT Toolchain
npm install -g @anthropic-ai/dxtStep 2: Build and Package
# Build TypeScript and create .dxt package
npm run build-dxt
# Or step by step:
npm run build # Compile TypeScript
npm run package-dxt # Create .dxt file
npm run validate-dxt # Validate packageStep 3: Install in Claude Desktop
- Build the extension: Run
npm run build-dxtin your project directory - Find the .dxt file: Look for
mcp-affise.dxtin your project root - Install in Claude Desktop:
- Open Claude Desktop Settings
- Go to Extensions section
- Drag your
.dxtfile into the window - Click "Install"
- Configure credentials:
- Find "Affise Analytics Extension" in your extensions
- Set your Affise API URL (e.g.,
https://api-yourcompany.affise.com) - Set your Affise API Key
- Test: Try using the
affise_statustool in Claude Desktop
Benefits of Desktop Extension:
- ✅ One-click install - No JSON editing required
- ✅ Secure credentials - API keys stored in OS keychain
- ✅ Automatic updates - Extensions update automatically
- ✅ No crashes - Graceful handling of missing configuration
- ✅ Better UX - Configuration through Claude Desktop UI
Method 2: Manual MCP Server Configuration
Docker Installation
Add this configuration to your Claude Desktop settings file:
Location: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"affise-mcp-server": {
"command": "docker",
"args": [
"run",
"--rm",
"-i",
"-e",
"AFFISE_API_KEY",
"-e",
"AFFISE_BASE_URL",
"-e",
"NODE_ENV=production",
"affise-mcp-server:latest"
],
"env": {
"AFFISE_API_KEY": "your_affise_api_key_here",
"AFFISE_BASE_URL": "https://your-affise-instance.com"
}
}
}
}Local Installation
If you prefer running locally without Docker:
{
"mcpServers": {
"affise-mcp-server": {
"command": "node",
"args": ["/path/to/affise-mcp-server/build/index.js"],
"env": {
"AFFISE_API_KEY": "your_affise_api_key_here",
"AFFISE_BASE_URL": "https://your-affise-instance.com"
}
}
}
}Example Interactions
Basic API Health Check
Human: Check if Affise API is available
Claude: I'll check the Affise API status for you.
> Uses affise_status tool
✅ API is healthy and responding in 234msPerformance Analytics
Human: Show me conversion performance by country for the last 7 days
Claude: I'll analyze your conversion performance by country.
> Uses affise_stats tool with natural language parsing
📊 Top performing countries:
- US: 2,847 conversions (4.2% CR)
- UK: 1,238 conversions (3.8% CR)
- DE: 892 conversions (3.1% CR)Offer Analysis
Human: Find high-performing offers in the gaming category
Claude: I'll search for gaming offers using natural language processing.
> Uses affise_search_offers tool
🎮 Top Gaming Offers:
1. Mobile Casino Pro - $45 EPC, 85% approval rate
2. Fantasy Sports App - $32 EPC, 92% approval rateIntelligent Category Resolution
Human: Find gaming offers for US mobile traffic
Claude: I'll search for gaming offers with smart category resolution.
> Uses affise_smart_search
🧠 **Smart Resolution Applied**
- Searched for: "gaming"
- Auto-corrected to: "Games & Entertainment" (92% confidence)
- Found 23 active offers for US mobile traffic
🎯 Top Results:
1. Mobile Casino Pro - $45 EPC, 4.2% CR
2. Puzzle Games Hub - $32 EPC, 5.1% CR
3. Sports Betting App - $38 EPC, 3.8% CR
💡 Note: Automatically corrected "gaming" to the actual category nameOffer Category Management
Human: What offer categories are available in our Affise account?
Claude: I'll get all the available offer categories for you.
> Uses affise_offer_categories tool
📂 Available Categories (18 total):
- Gaming (ID: 1) - 45 active offers
- Finance (ID: 2) - 23 active offers
- Dating (ID: 3) - 31 active offers
- Health & Beauty (ID: 4) - 12 active offers
- E-commerce (ID: 5) - 67 active offersIntelligent Workflow
Human: Give me a complete analysis of our best offers with revenue trends
Claude: I'll perform a comprehensive analysis of your top offers.
> Uses auto_analysis prompt with combined data types
📈 Complete Performance Report:
- Revenue Analysis: $847K total (↑23% vs last month)
- Top Performers: 12 offers exceeding targets
- Optimization Opportunities: 5 offers need attention
- Traffic Quality: 94% legitimate traffic📚 Detailed Examples & Guides
For comprehensive examples and real-world usage scenarios, check out these detailed guides:
🚀 Smart Features Guide
Your key differentiator vs competitors - AI-powered capabilities:
- Natural language understanding with typo correction
- Intelligent category resolution and auto-correction
- Context-aware search with geographic intelligence
- Smart pagination for large datasets
- Predictive insights and recommendations
🔬 Advanced Analysis Guide
Unlock the full power of enterprise-grade analysis:
- Strategic business intelligence workflows
- Multi-dimensional performance analysis
- Predictive modeling and forecasting
- Crisis management and recovery protocols
- Complete workflow orchestration
👥 Role-Specific User Journey Guides
👨💼 Affiliate Manager Guide
Daily operations and partner optimization:
- Morning routine workflows (15 min)
- Partner performance management
- Issue resolution protocols
- Weekly reporting templates
- Crisis management procedures
📊 Advertiser Manager Guide
Campaign management and revenue optimization:
- Advertiser health monitoring
- Campaign performance optimization
- Cross-advertiser collaboration strategies
- Revenue forecasting and analysis
- Quality assurance workflows
🏢 General Manager Guide
Strategic leadership and business intelligence:
- Executive morning briefing (10 min)
- Strategic decision frameworks
- Competitive analysis and positioning
- Financial performance and forecasting
- M&A evaluation and strategic planning
🔧 Tool Selection Guide
Master the art of choosing the right tool for your analysis:
- Tool comparison matrix
- Use case scenarios
- Performance optimization tips
- Best practices for different user roles
- Advanced workflow combinations
🤖 AI Search Examples
Harness the power of AI-driven search capabilities:
- Natural language query processing
- Smart category resolution
- Intelligent typo correction
- Context-aware search suggestions
- Advanced filtering techniques
📂 Offer Categories Examples
Master offer categorization and vertical analysis:
- Complete category taxonomy
- Vertical performance comparison
- Category-specific optimization tips
- Cross-category opportunity identification
- Industry benchmarking data
🔍 Trafficback Analysis Examples
Learn how to analyze traffic quality and identify redirection issues:
- Geographic trafficback patterns
- Device-specific analysis
- Partner quality assessment
- Real-time issue detection
- All 7 preset configurations
📊 Performance Stats Examples
Master performance analytics and conversion optimization:
- Revenue and earnings analysis
- Conversion rate breakdowns
- Geographic performance comparison
- Partner and affiliate metrics
- Time-based trend analysis
🎯 Offer Search Examples
Discover and research affiliate offers effectively:
- Category-based searches (gaming, finance, dating)
- Geographic targeting and compliance
- Performance-based filtering
- Competitive research techniques
- Natural language search queries
🚀 Client Prompts Guide
Ready-to-use prompts for common affiliate marketing tasks:
- Daily operations and monitoring
- Revenue and performance analysis
- Geographic and device targeting
- Optimization and troubleshooting
🗺️ Quick Guide Reference
| Guide | Purpose | Target User | |-------|---------|-------------| | Smart Features Guide | AI-powered capabilities overview | All users | | Advanced Analysis Guide | Enterprise-grade analysis workflows | Analysts, Managers | | Tool Selection Guide | Choose the right tool for your task | All users | | Affiliate Manager Guide | Daily operations for affiliate managers | Affiliate Managers | | Advertiser Manager Guide | Campaign management workflows | Advertiser Managers | | General Manager Guide | Strategic leadership insights | Executives | | AI Search Examples | Natural language search techniques | All users | | Offer Categories Examples | Category analysis and optimization | Analysts | | Trafficback Analysis Examples | Traffic quality assessment | Traffic Managers | | Performance Stats Examples | Analytics and KPI tracking | Analysts | | Offer Search Examples | Basic offer discovery | All users | | Client Prompts Guide | Ready-to-use prompt templates | All users |
💡 Pro Tip: These guides show you exactly how to talk to Claude naturally - no need to learn complex JSON syntax!
Available Tools
Core API Tools
affise_status
Check Affise API health and connectivity.
{
"name": "affise_status",
"arguments": {}
}affise_stats
Get statistics using natural language queries.
{
"name": "affise_stats",
"arguments": {
"query": "Show me revenue by country for the last 30 days"
}
}affise_stats_raw
Get raw statistics with specific API parameters (/3.0/stats/custom).
{
"name": "affise_stats_raw",
"arguments": {
"slice": ["country", "day"],
"date_from": "2024-01-01",
"date_to": "2024-01-07",
"fields": ["clicks", "conversions", "income"],
"filter": {
"country": ["US", "GB", "DE"]
}
}
}affise_search_offers
Search offers using natural language queries.
{
"name": "affise_search_offers",
"arguments": {
"query": "Find gaming offers for US mobile traffic"
}
}Analysis Prompts
analyze_offers
Expert offer analysis with recommendations.
{
"name": "analyze_offers",
"arguments": {
"offers_data": "...",
"analysis_type": "performance",
"format": "actionable"
}
}auto_analysis
Comprehensive multi-data analysis.
{
"name": "auto_analysis",
"arguments": {
"data_type": "combined",
"period": "last30days",
"analysis_type": "comprehensive",
"format": "executive"
}
}Development
Project Structure
affise-mcp-server/
├── src/
│ ├── handlers/ # MCP request handlers (enhanced-tools, prompts)
│ ├── tools/ # 23 Affise API integration tools
│ ├── prompts/ # 6 analysis prompt factories
│ ├── services/ # Cache, error handling, validation, secure config
│ ├── types/ # Type definitions + simple-parser
│ ├── utils/ # Response compaction, stats normalizer
│ ├── shared/ # Shared utilities (date-utils)
│ ├── health/ # Health-check helpers
│ └── index.ts # Main MCP server entry point (stdio)
├── tests/ # Vitest test suite (~380 tests)
├── guides/ # Usage guides and examples
├── manifest.json # Claude Desktop DXT extension manifest
├── vitest.config.ts # Vitest configuration
├── Dockerfile # Optional Docker build
├── docker-compose.yml # Optional Docker development environment
└── package.json # Node.js dependenciesAvailable Scripts
# Development
npm run dev # Start with hot reload (tsx)
# Building
npm run build # Compile TypeScript (+ npm audit)
npm run build:unsafe # Compile without audit (faster iteration)
npm run clean # Clean build directory
npm run rebuild # Clean and build
# Tests
npm test # Run Vitest suite
npm run test:watch # Vitest in watch mode
npm run test:coverage # With coverage report
npm run test:unit # Unit tests only
npm run test:integration # Integration tests only
# Production
npm start # Start MCP server (stdio)
# Claude Desktop extension package
npm run build-dxt # Build + package as .dxt
npm run validate-dxt # Validate the .dxtDocker Commands
# Build image
docker build -t affise-mcp-server:latest .
# Run with docker-compose
docker-compose up -d
# Test with Docker
echo '{"jsonrpc": "2.0", "id": 1, "method": "initialize", "params": {"protocolVersion": "2024-11-05", "capabilities": {}, "clientInfo": {"name": "test", "version": "1.0.0"}}}' | docker run --rm -i \
-e AFFISE_API_KEY=your_key \
-e AFFISE_BASE_URL=https://api-demo.affise.com \
-e NODE_ENV=production \
affise-mcp-server:latest
# Check logs
docker-compose logs -f affise-mcp-serverTroubleshooting
Common Issues
1. Authentication Errors
Error: 401 UnauthorizedSolution: Verify your AFFISE_API_KEY is correct and has proper permissions.
2. Connection Timeouts
Error: Request timeoutSolution: Check your AFFISE_BASE_URL and network connectivity.
3. Docker Permission Issues
Error: Permission deniedSolution: Ensure Docker has proper permissions and the user is in the docker group.
4. Claude Desktop Not Detecting Server
Solutions:
- Restart Claude Desktop after configuration changes
- Verify JSON syntax in
claude_desktop_config.json - Check that Docker image is built and tagged correctly
- Ensure environment variables are set properly
Debug Mode
Enable debug logging by setting:
export NODE_ENV=developmentThis will provide detailed logging including:
- API request/response details
- MCP message tracing
- Performance metrics
- Error stack traces
MCP Protocol Testing
Test MCP server:
# Test MCP protocol with initialize
echo '{"jsonrpc": "2.0", "id": 1, "method": "initialize", "params": {"protocolVersion": "2024-11-05", "capabilities": {}, "clientInfo": {"name": "test", "version": "1.0.0"}}}' | npm startArchitecture
Simplified Design
The server uses a simplified architecture focused on direct API integration:
- Direct Tool Handlers - No complex abstraction layers
- Natural Language Processing - Simple pattern matching for user queries
- Unified Types - Single source of truth for response types
- Minimal Dependencies - Clean, maintainable codebase
Benefits
- ✅ Easy to understand - Direct API calls without complexity
- ✅ Fast performance - Minimal processing layers
- ✅ Easy to maintain - Simple codebase structure
- ✅ Reliable - Fewer points of failure
- ✅ Extensible - Easy to add new tools and features
Security
Best Practices
- ✅ API keys in environment variables (never hardcoded)
- ✅ Runtime API key encryption with AES-256-GCM
- ✅ Comprehensive input validation with injection protection
- ✅ Non-root Docker user for container security
- ✅ Alpine Linux base for minimal attack surface
- ✅ No sensitive data logging in production mode
- ✅ HTTPS-only API communication
- ✅ Automated dependency security auditing
Data Privacy
- No API keys or sensitive data are stored locally
- All communication uses secure HTTPS connections
- Logs contain no personally identifiable information
- Containers are ephemeral and stateless
Dependency Security
- ✅ Automated security audits on every build
- ✅ Regular dependency updates for security patches
- ✅ Vulnerability scanning with npm audit
- 🔧 Security scripts:
npm run security:check,npm run security:fix
License
This project is licensed under the ISC License.
Support
Getting Help
- 📖 Documentation: Check this README and inline code comments
- 🐛 Bug Reports: Open an issue with detailed reproduction steps
- 💡 Feature Requests: Open an issue with use case description
- 📧 Direct Support: Contact the maintainers
Useful Resources
- Model Context Protocol Documentation
- Affise API Documentation
- Claude Desktop MCP Guide
- Docker Best Practices
Made with ❤️ for the affiliate marketing community
This MCP server bridges the gap between AI assistants and affiliate marketing data, enabling intelligent analysis and optimization of your Affise campaigns using natural language.
