affiliate-networks-mcp
v0.9.0
Published
Bring affiliate-network data to Claude or Codex through a local stdio MCP server. 80+ publisher and advertiser-side adapters, most experimental. Local-only, bring your own keys.
Readme
affiliate-mcp
Integrate your affiliate networks with Claude or Codex.
Network operators: most adapters are community-built and
experimental. Adoption gives your team ownership and a verification path; promotion topartialorproductionstill requires current evidence and maintainer review. Find your network's issue under theadopt-this-networklabel.
Affiliate networks have two sides — and neither has a first-class AI workspace integration.
Publishers earn commissions from the programmes they join. Brands (and the agencies who manage them) run those programmes and pay the commissions out. I wanted to chat to my own affiliate data in the AI workspace I already use; none of the networks had shipped an integration for either side, so I built a broad beta set that covers both publisher and advertiser-side work.
If you're a publisher, you can ask:
"What did I earn across all networks last month?"
"Which programmes have transactions still pending after 90 days?"
"Compare my earnings month on month."
If you're on the brand side — running a programme, or an agency managing several — you can ask:
"How is Acme's programme doing this quarter?"
"Show me revenue across all my clients this week."
"Any anomalies in the affiliate data?"
Your AI workspace figures out which networks to call, fetches the data live from their APIs, and gives you the answer. You can use Claude or Codex to turn it into a sheet, an artifact, an email to your boss, whatever you want.
Free and open source. MIT licensed. Bring your own keys. For the product philosophy, read the AI-native affiliate data manifesto.
Who this is for
This tool serves two audiences. Pick the one that fits — or both, if you wear both hats.
You're a publisher. You earn commissions from affiliate programmes, your dashboards can't keep up with how fast you can think, and you want one conversation that spans every network you're on.
You're on the brand side. You run an affiliate programme — or you're an agency managing several brands' programmes. You want one question that fans out across networks and brands, and surfaces what the dashboards bury: publishers trending down, reversal spikes, dead links, programmes drifting toward zero.
Either way, you do not need to know what an API is or write code. The non-technical Claude Desktop track needs:
- Your existing logins to the affiliate networks you already work with.
- Claude Desktop installed.
The technical track uses a terminal, Node.js 20 or newer, and Claude Desktop, Claude Code, Codex, or another compatible local stdio MCP client; check the support states below before relying on an untested client journey.
And if you work for an affiliate network, this is also for you. The
bundled adapters are placeholders until each network adopts its own. See
CONTRIBUTING.md under "Adopting your network".
Why bother?
One question, every network and every brand. "Show me earnings by programme" hits your configured publisher networks in parallel. On the brand side, "show me revenue across all my clients this week" fans out across every brand and network pair you've registered.
Plain English, not filters. No more clicking through date pickers and saved views. "Last quarter, status pending, sorted by amount" is the whole prompt.
Your data, your machine. It runs locally. Your keys live in
~/.affiliate-mcp/.env, locked to your user account. There is no hosted
account. Optional anonymous usage telemetry is off by default and never
contains affiliate data, credentials, prompts, arguments, results, or error
text. The networks see the same API calls they'd see from their dashboard.
Catches what dashboards bury. Stale transactions, inactive programmes, dead deeplinks and week-on-week drops are surfaced by the packaged skills.
Optional local result cache. Persistent caching is off by default. Set
AFFILIATE_MCP_CACHE=on in ~/.affiliate-mcp/.env to cache selected programme
inventory and closed reporting windows locally with owner-only permissions.
Open and current windows always go live. On a shared machine where you cannot
rely on file permissions, leave caching off. Run
affiliate-networks-mcp cache clear to remove cached results; see
PRIVACY.md for the storage and retention contract.
Getting started
Choose one of two primary tracks. Both run the same local MCP server and keep your credentials on your machine.
Track 1: non-technical, Claude Desktop
Use the host-native Claude Desktop .mcpb. No Terminal, Node.js, or manual
configuration is required.
- Download
affiliate-networks-mcp-<version>.mcpbfrom the latest GitHub release. - In Claude Desktop, open Settings → Extensions → Advanced settings → Install Extension… and select the downloaded file.
- Add credentials for the networks you use, then ask Claude "What affiliate networks do you have access to?"
The native extension currently offers secure setup fields for Awin, CJ, Impact,
and Partnerize. It runs the complete server, so an existing
~/.affiliate-mcp/.env continues to enable every other adapter. A portable
browser setup flow for the remaining networks is planned; until then, use the
technical track below when adding them.
The standalone Electron/DMG setup app is a fixes-only compatibility
fallback for existing macOS users. It is not a third primary onboarding
track. See desktop/README.md for its remaining use
case.
Track 2: technical and semi-technical, CLI plus local stdio
You'll need Node.js 20 or newer installed. If you don't have it, use the Node.js download page.
1. Run the setup wizard. Open Terminal (macOS) or PowerShell (Windows):
npx affiliate-networks-mcp setupIt walks you through one network at a time, asks which side you want, shows where to find each credential, then checks it against the live network.
For brand-side networks, the wizard asks which brands those credentials can
reach, then lets you pick local nicknames. The mapping is saved to
~/.affiliate-mcp/brands.json, see Managing brands.
2. Check everything is wired up.
npx affiliate-networks-mcp testYou should see one line per network: ok for everything that's healthy,
error — <reason> for anything that isn't.
3. Connect it to your local MCP client. Use a host-native package, the CLI installer, or local stdio configuration. The setup wizard offers the shipped CLI installer targets at the end automatically.
Claude Desktop (Mac/Windows app):
npx affiliate-networks-mcp installFinds your Claude Desktop config, adds the affiliate entry alongside
anything else you already have, takes a timestamped backup first. Restart
Claude Desktop after it finishes. Flags: --desktop / --code / --codex
to pick one, --all to include Codex and skip prompting, --dry-run to
preview, --force-overwrite if
your existing config is malformed JSON.
Claude Code (terminal):
claude plugin marketplace add bobberrisford/affiliatemcp
claude plugin install affiliate-networks-mcp@affiliatemcpRegisters the MCP server and bundled skills in one step. (Or use the
install command above — it detects Claude Code too.) Already inside a
Claude Code session? Just ask it to install the affiliate-mcp plugin and it
runs these commands for you; no terminal juggling needed.
Codex (OpenAI, terminal or IDE extension):
npx affiliate-networks-mcp install --codexThis adds the local stdio MCP server to ~/.codex/config.toml; the same MCP
config is used by the Codex CLI and Codex IDE extension. Manual setup:
codex mcp add affiliate -- npx -y affiliate-networks-mcpVerify: open Codex, run /mcp, then ask "What affiliate networks do you
have access to?" This is OpenAI/Codex support, not ChatGPT connector
support. ChatGPT requires a reachable HTTPS MCP server and is scoped separately.
Claude Cowork desktop (org accounts):
Cowork syncs plugins from a GitHub repo, but blocks public repos from org
marketplaces — so you need a private mirror first. The setup wizard offers
this at the end, or run install and pick Cowork:
npx affiliate-networks-mcp install # detects your clients, offers Cowork(Or go straight to it: npx affiliate-networks-mcp cowork-mirror.)
It creates <you>/affiliatemcp-internal as a private repo and mirrors the
upstream into it. If you have the GitHub CLI (gh) signed in, it's used
automatically; otherwise it tells you exactly where to get a GitHub token and
prompts you to paste it — the same "paste a credential" flow as setting up a
network. Re-run with --sync to refresh against new releases.
Then, with org-admin access, in Cowork: Organization settings → Plugins
→ Add plugin → GitHub → enter <you>/affiliatemcp-internal → install
affiliate-networks-mcp from the synced marketplace.
Open the Claude Desktop config file at:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
Add the affiliate entry inside mcpServers — keep any siblings:
{
"mcpServers": {
"affiliate": {
"command": "npx",
"args": ["affiliate-networks-mcp"]
}
}
}Restart Claude Desktop after saving.
For another local stdio MCP client, configure the server command
npx -y affiliate-networks-mcp. These clients are compatible in principle,
not yet tested first-party journeys. Draft PR
#49 is the existing
VS Code/Copilot installer candidate.
Client support states
These labels describe the onboarding journey, not whether every network
adapter is live-verified. "Tested" below means repository-owned automated
validation, not live proof against every host version. See
REPORT.md for adapter maturity.
| Client or path | Support state | What that means |
| --- | --- | --- |
| Claude Desktop .mcpb | Shipped and release-tested | Primary non-technical path. CI builds and smoke-tests the bundle. Secure setup fields currently cover Awin, CJ, Impact, and Partnerize. |
| Claude Desktop CLI/manual config | Shipped and tested | Technical local stdio path. Installer/config behaviour has automated coverage. |
| Claude Code plugin and CLI registration | Shipped and tested | Technical path with packaged skills and local MCP registration. |
| Codex CLI and IDE extension | Shipped and tested | Technical path using the shared local Codex MCP configuration. This is not ChatGPT connector support. |
| Claude Cowork private mirror | Partially shipped | Requires a private mirror and org-admin follow-through; it is not a simple individual setup path. |
| Cursor, VS Code, and generic local MCP clients | Possible, not yet a tested first-party journey | The local stdio server is compatible in principle. Client-specific setup, packaging, and support ownership are tracked in #207. |
| Portable browser credential setup | Planned, not shipped | Intended to make all network credentials available without a terminal. Its security and DMG-retirement decision is tracked in #206. |
| ChatGPT connector or remote HTTPS MCP | Planned, not shipped | ChatGPT cannot use this local stdio server directly. The separate remote architecture decision is tracked in #208. |
Check it worked. In a new Claude conversation, ask "What affiliate networks do you have access to?" — you should see every network you configured. If you registered any brands, also try "list my brands".
To disconnect later: npx affiliate-networks-mcp uninstall, or
claude plugin uninstall affiliate-networks-mcp for the plugin path.
Anonymous telemetry
The project reads aggregate npm and GitHub adoption statistics. npm downloads
are downloads, not users: they include repeated npx runs, CI, caches, and
other automated traffic.
Optional runtime telemetry is explicitly opt-in and sent at most once per active day. It contains package version, launch surface, a random identifier that rotates monthly, and counts by network, operation, and coarse outcome. See the privacy policy for the exact contract.
affiliate-networks-mcp telemetry status
affiliate-networks-mcp telemetry enable
affiliate-networks-mcp telemetry disableTroubleshooting install
"Unknown skill: plugin" in a Claude session. The /plugin syntax is a
shell command, not a chat slash command. Run claude plugin marketplace
add ... from your terminal, not inside the conversation.
Cowork rejects the marketplace repo. Confirm the repo is private.
Public repos are blocked for org-marketplace sync. Run npx
affiliate-networks-mcp cowork-mirror to create a private mirror.
What affiliate networks… returns nothing. The MCP server is loaded
but credentials are missing. Trigger the bundled
affiliate-network-setup-help
skill (ask "help me set up my affiliate network credentials") or run
npx affiliate-networks-mcp setup in a terminal.
Stale npm cache. npx --yes affiliate-networks-mcp@latest forces a
fresh fetch. Verify the published version with
npm view affiliate-networks-mcp version.
What you can ask
The packaged skills are pre-written conversation patterns. You don't need to invoke them — Claude picks the right one based on what you type.
Publisher side
- "What did I earn last month?" — consolidated earnings report across every publisher network, split by status (pending, approved, paid, reversed), with anything unpaid >90 days flagged.
- "Are all my affiliate networks healthy?" — one-shot auth and capability check.
- "Help me set up Awin" (or CJ, Impact, Rakuten) — guided credential setup with dashboard menu paths quoted verbatim.
- "Audit the affiliate links in my sitemap at https://mysite.com/sitemap.xml" — reads the sitemap, classifies every affiliate link by network, and flags the dead or declined ones. URLs, HTML, or markdown also accepted directly.
Brand side
- "How is Acme performing this quarter?" — single-brand report across that brand's bound networks. Top publishers, status splits, period-over-period delta.
- "Show me revenue across all my clients this week." — portfolio rollup, brand-aggregated, with a "needs attention" subsection for brands trending down.
- "Any anomalies in the affiliate data this week?" — week-over-week scan for revenue drops, reversal spikes, top-10 dropouts, dead programmes. Designed to run on a schedule via Claude's own scheduling.
- "Set up Acme's strategy and KPIs" — bind the brand during setup, record
advisory context with
client-onboarding, then reports, anomaly watches, and portfolio rollups use it to frame verdicts. It never authorises a network write or changes the figures.
Networks
The repository currently ships 86 adapters across 72 network families. The
breadth is real, but maturity varies; most adapters are experimental. Check
the table below and REPORT.md before relying on one for
production work.
| Network | Setup time | Approval required | Supported ops | Notes | | --- | ---: | --- | ---: | --- | | 2Performant | 5 min | no | 6 / 7 | no clicks | | AccessTrade | 10 min | no | 6 / 7 | no clicks | | Adcell | 10 min | no | 6 / 7 | no clicks | | Addrevenue | 5 min | no | 7 / 7 | pagination quirks | | Admitad | 15 min | no | 6 / 7 | clicks gated | | Admitad (advertiser) | 12 min | no | 7 / 7 | see notes | | Adrecord | 5 min | no | 6 / 7 | no clicks | | Adservice | 10 min | no | 6 / 7 | no clicks | | Adtraction | 5 min | no | 6 / 7 | no clicks | | Adtraction (advertiser) | 6 min | no | 7 / 7 | see notes | | Affilae | 5 min | no | 6 / 7 | no clicks | | Affiliate Future | 5 min | no | 6 / 7 | no clicks | | Affise | 10 min | no | 7 / 7 | no clicks | | Afilio | 10 min | no | 6 / 7 | no clicks | | Amazon Creators | 10 min | yes (~1 days) | 6 / 7 | no clicks | | AvantLink | 10 min | no | 6 / 7 | no clicks | | Awin | 5 min | no | 6 / 7 | no clicks | | Awin (advertiser) | 6 min | no | 7 / 7 | see notes | | Belboon | 10 min | no | 6 / 7 | no clicks | | CAKE | 10 min | no | 6 / 7 | no clicks | | CJ Affiliate | 8 min | no | 6 / 7 | no clicks | | CJ Affiliate (advertiser) | 8 min | no | 7 / 7 | pagination quirks | | ClickBank | 10 min | no | 6 / 7 | no clicks | | Commission Factory | 10 min | no | 6 / 7 | clicks gated | | Commission Factory (advertiser) | 7 min | no | 7 / 7 | pagination quirks | | Connexity | 10 min | no | 6 / 7 | no clicks | | Coupang Partners | 10 min | no | 6 / 7 | no clicks | | Daisycon | 15 min | no | 6 / 7 | no clicks | | Daisycon (advertiser) | 15 min | no | 7 / 7 | see notes | | Digistore24 | 5 min | no | 6 / 7 | no clicks | | eBay Partner Network | 10 min | yes (~3 days) | 7 / 7 | see notes | | Eduzz | 10 min | no | 6 / 7 | no clicks | | Effiliation | 5 min | no | 6 / 7 | no clicks | | eHUB | 5 min | no | 7 / 7 | see notes | | Everflow | 10 min | yes (~1 days) | 7 / 7 | see notes | | Everflow (Advertiser) | 10 min | no | 7 / 7 | no clicks | | financeAds | 10 min | yes (~2 days) | 6 / 7 | no clicks | | FirstPromoter | 5 min | no | 6 / 7 | no clicks | | FlexOffers | 10 min | no | 6 / 7 | no clicks | | Flipkart Affiliate | 10 min | no | 6 / 7 | no clicks | | GrowSurf | 10 min | no | 6 / 7 | no clicks | | Hotmart | 10 min | no | 6 / 7 | no clicks | | Howl | 5 min | no | 6 / 7 | clicks gated | | Impact | 6 min | no | 7 / 7 | upstream variability | | Impact (advertiser) | 8 min | no | 7 / 7 | see notes | | Indoleads | 5 min | no | 6 / 7 | no clicks | | Involve Asia | 5 min | no | 6 / 7 | no clicks | | Kwanko | 10 min | no | 6 / 7 | no clicks | | Kwanko (advertiser) | 10 min | no | 6 / 7 | no clicks | | LeadDyno | 5 min | no | 6 / 7 | no clicks | | Levanta | 5 min | no | 6 / 7 | no clicks | | LinkConnector | 5 min | no | 6 / 7 | no clicks | | Lomadee | 15 min | no | 6 / 7 | no clicks | | Monetizze | 5 min | no | 6 / 7 | no clicks | | mrge | 10 min | no | 6 / 7 | no clicks | | NetRefer | 15 min | yes (~5 days) | 6 / 7 | no clicks | | Offer18 | 10 min | no | 6 / 7 | no clicks | | Optimise Media | 10 min | no | 6 / 7 | no clicks | | Partnerize | 10 min | no | 7 / 7 | no clicks | | Partnerize (Advertiser) | 5 min | no | 6 / 7 | no clicks | | Partnero | 5 min | no | 6 / 7 | no clicks | | PartnerStack | 5 min | no | 6 / 7 | no clicks | | PartnerStack (advertiser) | 6 min | no | 7 / 7 | no clicks | | Pepperjam | 5 min | no | 6 / 7 | no clicks | | Post Affiliate Pro | 5 min | no | 6 / 7 | no clicks | | Profitshare | 5 min | no | 6 / 7 | no clicks | | Rakuten Advertising | 12 min | yes (~5 days) | 6 / 7 | clicks gated | | Refersion | 5 min | no | 6 / 7 | no clicks | | Rewardful | 5 min | no | 6 / 7 | no clicks | | Scaleo | 10 min | yes (~1 days) | 7 / 7 | see notes | | ShareASale | 10 min | no | 6 / 7 | no clicks | | ShopMy | 10 min | no | 6 / 7 | no clicks | | Skimlinks | 10 min | no | 6 / 7 | no clicks | | Sovrn Commerce | 10 min | no | 6 / 7 | no clicks | | Tapfiliate | 5 min | no | 6 / 7 | no clicks | | Tolt | 5 min | no | 6 / 7 | no clicks | | Tradedoubler | 15 min | no | 6 / 7 | clicks gated | | Tradedoubler (Advertiser) | 10 min | no | 7 / 7 | no clicks | | TradeTracker | 10 min | no | 7 / 7 | see notes | | Travelpayouts | 5 min | no | 6 / 7 | no clicks | | TUNE | 10 min | no | 7 / 7 | no clicks | | ValueCommerce | 10 min | no | 6 / 7 | no clicks | | ValueCommerce (advertiser) | 10 min | no | 6 / 7 | no clicks | | Webgains | 10 min | no | 6 / 7 | no clicks | | Webgains (advertiser) | 10 min | no | 7 / 7 | see notes | | Yieldkit | 5 min | no | 7 / 7 | see notes |
A few networks make you wait for approval (eBay, Rakuten) before they hand over API access. The setup wizard tells you exactly what to do in each case. "Supported ops" being less than 7/7 just means the network itself doesn't expose that data to its users — not a missing feature on our side.
The (advertiser) rows are the brand-side adapters. They use a
separate credential type from the publisher row (sometimes the same
auth model with a different account behind it; the per-network notes
spell out which), and the brand-id is selected per call rather than
baked into the credential. Every brand-side adapter is read-only at
v0.1 — the client refuses any non-GET HTTP method before it leaves
your machine. The full editorial position, including known upstream
quirks and the read-only stance, lives in REPORT.md.
Contribute in 10 minutes
A first PR shouldn't take longer than an evening. The path:
Pick an issue. Browse the
good-first-prqueue. Each has a file path, acceptance bullets, and a how-to-test line. Comment to claim it.Get to green. One command runs the full pre-PR check — typecheck, lint, tests, build — in a few seconds:
git clone https://github.com/bobberrisford/affiliatemcp.git cd affiliatemcp npm install npm run verifyIf
npm run verifypasses locally, CI will pass.Open the PR. Use the default template (a short summary + test plan). First review within 24h on weekdays — see
CONTRIBUTING.mdfor the full PR process and the four ranked help-wanted areas.
If you work for an affiliate network, the highest-leverage contribution
is adopting your own adapter — see the
adopt-this-network
issues.
Wanted
Networks people have asked for but that don't have an adapter yet. If
you work for one of these — or just have API access and want to
contribute — this is the most useful place to start. See
CONTRIBUTING.md for the workflow, and open (or
pile onto) a tracking issue before you start.
| Network | Side wanted | Notes | Tracking issue | | --- | --- | --- | --- |
Awin reference implementation
Awin is the current reference slice for the repo's future shape. It keeps the seven canonical publisher tools and adds Awin-specific tools for accounts, programme details, commission groups, transaction-by-ID lookup, transaction queries, advertiser/creative/campaign reports, Link Builder, Offers, and safe stubs for gated Product Feed and Proof of Purchase APIs.
Start here if you want to understand the product direction:
Where your credentials live
When you run the setup wizard it writes a single file at
~/.affiliate-mcp/.env on your machine, locked to your user account
(file mode 0600). That's the only place your API keys exist outside
the network dashboards. Both publisher and brand-side credentials live
here, each keyed by network slug. Open, edit, delete, or copy it like
any other file.
If you registered any brand-side networks, the wizard also writes
~/.affiliate-mcp/brands.json next to it. That file maps your local
nickname for each brand (e.g. acme) to the network's brand id on
every network the brand is bound to. Empty for the publisher-only path.
There is no hosted service. There is no account to create with us.
Managing brands
The brand-side flow adds one concept: a local brand slug. You give each client (or each of your own brands) a short nickname; the tool maps it to the network's own brand id on every network the brand is registered on.
A real brands.json looks like this:
{
"version": 1,
"brands": {
"acme": [
{ "network": "impact-advertiser", "credentialId": "default", "networkBrandId": "IA-12345" },
{ "network": "cj-advertiser", "credentialId": "default", "networkBrandId": "7654321" }
],
"globex": [
{ "network": "awin-advertiser", "credentialId": "default", "networkBrandId": "98765" }
]
}
}The same logical brand can appear under multiple networks; that's how
"earnings for Acme across all networks" fans out across the right
brand id on each one. You can hand-edit this file to rename, remove,
or add brands. Re-run npx affiliate-networks-mcp setup to register
new ones interactively — the wizard skips brands already in the file.
Three skills are tuned for the brand side:
programme-performance-report— one brand across its bound networks. Per-publisher rollup, status split, period-over-period delta.agency-portfolio-rollup— every brand × every network in the book. Brand-aggregated headline with week-over-week deltas.programme-anomaly-watch— week-over-week anomaly scan, designed to run on a schedule.
When something goes wrong
npx affiliate-networks-mcp doctorThat runs a live diagnostic across every configured network and tells you, in English, what's broken and how to fix it. If a specific network is misbehaving, append its slug:
npx affiliate-networks-mcp doctor rakutenMost failures are one of three things: an expired token, a network
that needs your approval re-confirmed, or a credential typed with a trailing
space. The JSON also reports clientStrategies health; it never deletes them.
Per-network setup notes
Each network has a short page covering dashboard navigation, where to click for credentials, and common stumbling blocks:
Publisher side:
- Awin — API token + publisher ID.
- CJ Affiliate — Developer Key (GraphQL).
- eBay Partner Network — OAuth client + secret + campaign ID; approval required.
- Everflow — API key (admin-issued); experimental, built from public docs.
- Impact — Account SID + Auth Token.
- mrge — API key + secret + site ID; experimental, built from public docs.
- Partnerize — application key + user API key; experimental, built from public docs.
- PartnerStack — Partner API key; experimental, built from public docs.
- Rakuten Advertising — OAuth client + SID; approval required.
- Skimlinks — OAuth client ID + secret + publisher ID + domain ID; experimental, built from public docs.
- Sovrn Commerce — API key + secret key; experimental, built from public docs.
- Tradedoubler — bearer token + organisation ID; experimental, built from public docs.
- Admitad — OAuth2 client ID + secret + website ID; experimental, built from public docs.
- Adservice — UID + login token (cookie session); experimental, built from public docs.
- Adtraction — API token; experimental, built from public docs.
- Afilio — affiliate token + Aff ID; experimental, built from public docs.
- Commission Factory — API key; experimental, built from public docs.
- Coupang Partners — access key + secret key (HMAC); experimental, built from public docs.
- Daisycon — OAuth2 client ID + secret + refresh token + publisher ID; experimental, built from public docs.
- Eduzz — email + public key + API key; experimental, built from public docs.
- FlexOffers — API key; experimental, built from public docs.
- Hotmart — OAuth2 client ID + secret; experimental, built from public docs.
- Indoleads — bearer token; experimental, built from public docs.
- Kwanko — API token; experimental, built from public docs.
- Lomadee — app token + source ID + publisher ID + report login; experimental, built from public docs.
- Monetizze — API key; experimental, built from public docs.
- ValueCommerce — report-API key pair; experimental, built from public docs.
- Webgains — API key + publisher ID + campaign ID; experimental, built from public docs.
- Affise — per-tenant base URL + API-Key header; tenant CPA engine; experimental, built from public docs.
- Scaleo — per-tenant base URL + API key (query param); tenant engine; experimental, built from public docs.
- Offer18 — per-tenant base URL + key/aid/mid (query params); tenant engine; experimental, built from public docs.
- CAKE — per-instance base URL + API key + affiliate ID (XML API); experimental, built from public docs.
- NetRefer — per-operator base URL + OAuth2 (Azure AD); iGaming ASR reporting; experimental, built from public docs.
- Affilae — Bearer token; single-brand; FR network; experimental, built from public docs.
- Optimise Media — apikey header (Service Account); UK/IN/APAC; experimental, built from public docs.
- AccessTrade — Token header + site ID; SE-Asia/Japan, per-country base URL; experimental, built from public docs.
- Travelpayouts — X-Access-Token; global travel; experimental, built from public docs.
- Flipkart Affiliate — affiliate ID + token headers; India; experimental, built from public docs.
- Adrecord — APIKEY header; Nordic; experimental, built from public docs.
- Addrevenue — Bearer token + channel ID; Nordic; experimental, built from public docs.
- ShareASale — affiliate ID + token + secret (signed); US; experimental, built from public docs.
- Pepperjam — apiKey query param; US (Ascend, distinct from Partnerize); experimental, built from public docs.
- AvantLink — affiliate ID + auth key + website ID (query params); US/outdoor; experimental, built from public docs.
- Digistore24 — X-DS-API-KEY header; DE digital products; experimental, built from public docs.
- ClickBank — DEV:CLERK key header + nickname; digital products; experimental, built from public docs.
- TUNE — NetworkId + api_key (per-tenant host); HasOffers engine; experimental, built from public docs.
- Involve Asia — key + secret (token exchange); APAC; experimental, built from public docs.
- TradeTracker — customer ID + passphrase + site ID (SOAP session); NL/EU; experimental, built from public docs.
- Amazon Creators — API key + partner tag; single programme per marketplace; experimental, built from public docs.
- Belboon — magic key + user ID (CSV export); DACH; experimental, built from public docs.
- financeAds — API key + publisher ID; DACH finance; experimental, built from public docs.
- Adcell — API key + affiliate ID; DACH; experimental, built from public docs.
- ShopMy — Brand Partner token; US creator network; experimental, built from public docs.
- Levanta — Bearer token; Amazon creator platform; experimental, built from public docs.
- Howl — NRTV-API-KEY header + publisher ID; creator link network; smart-link minting; experimental, built from public docs.
- Yieldkit — api_key + secret (query params); link monetisation; clicks supported; experimental, built from public docs.
- eHUB — apiKey query param + publisher ID; CZ/CEE; clicks supported; experimental, built from public docs.
- LinkConnector — API key (query param); US; experimental, built from public docs.
- Connexity — publisher ID + API key; US CPC-commerce (distinct from Skimlinks); experimental, built from public docs.
- Affiliate Future — API key + password (query params); UK; 1-day pull window; experimental, built from public docs.
- Effiliation — API key (query param); FR; experimental, built from public docs.
- 2Performant — email + password (session login); Romania; experimental, built from public docs.
- Profitshare — API user + key (HMAC-signed); Romania; experimental, built from public docs.
Brand / advertiser side:
- Awin (advertiser) — OAuth bearer token; multi-brand via
GET /accounts; gated to Accelerate / Advanced plans; read-only. - CJ Affiliate (advertiser) — Personal Access Token (GraphQL); multi-brand via CID list; read-only.
- Everflow (advertiser) — API key (admin-issued); multi-brand; experimental, built from public docs.
- Impact (advertiser) — Account SID + Auth Token; agency or brand-direct; read-only.
- Partnerize (advertiser) — application key + user API key; multi-brand; experimental, built from public docs.
- PartnerStack (advertiser) — public + secret key pair (Vendor API); single-brand; experimental, built from public docs.
- Tradedoubler (advertiser) — reports token + organisation ID; multi-brand; experimental, built from public docs.
- Admitad (advertiser) — OAuth2 client ID + secret + advertiser ID; multi-brand; read-only; experimental, built from public docs.
- Adtraction (advertiser) — API token; multi-brand; read-only (POST-read allowlist); experimental, built from public docs.
- Commission Factory (advertiser) — API key; read-only; experimental, built from public docs.
- Daisycon (advertiser) — OAuth2 client ID + secret + refresh token; multi-brand; read-only; experimental, built from public docs.
- Kwanko (advertiser) — API token; multi-brand; read-only; experimental, built from public docs.
- ValueCommerce (advertiser) — report-API key pair; multi-brand; read-only; experimental, built from public docs.
- Webgains (advertiser) — API key + account ID; multi-brand; read-only; experimental, built from public docs.
- Rewardful — API Secret (HTTP Basic); single-brand; Stripe-native SaaS; experimental, built from public docs.
- FirstPromoter — API key + account ID (Bearer); single-brand; SaaS-referral; experimental, built from public docs.
- Partnero — API token (Bearer); single-brand; SaaS-referral; experimental, built from public docs.
- GrowSurf — API key + campaign ID (Bearer); single-brand; referral-credit SaaS; experimental, built from public docs.
- LeadDyno — private key (query param); single-brand; SaaS-referral; experimental, built from public docs.
- Post Affiliate Pro — per-tenant base URL + API key (Bearer); single-brand; SaaS engine; experimental, built from public docs.
- Tolt — Bearer key; single-brand; SaaS-referral; experimental, built from public docs.
- Refersion — public + secret key headers; single-brand; Shopify-heavy SaaS; experimental, built from public docs.
- Tapfiliate — X-Api-Key header; single-brand; SaaS-referral; experimental, built from public docs.
For the curious (or technical)
affiliate-mcp has five practical layers. Adapters under src/networks/
handle each network's auth, API quirks, normalisation, and capability metadata.
MCP tools expose typed operations such as affiliate_awin_list_transactions;
six meta-tools cover listing, diagnostics, brand resolution, and advisory client
strategy. Skills and workflows compose tools into affiliate jobs. MCP
prompts are reusable templates and currently Awin-specific. Setup paths
connect the same local server to Claude Desktop, Claude Code, Codex, Cowork, or
another compatible local stdio MCP client.
The packaged skills under skills/ are the
conversation patterns Claude follows for common requests:
Publisher side:
Brand side:
For per-network capability detail, known upstream quirks, and the
editorial baseline used when accepting new network claims, see
REPORT.md. It is regenerated from each adapter's
network.json on every merge, so it stays in step with the code.
Repository layout
If you're poking around the source, the top-level folders are:
src/— the MCP server. Entry pointindex.ts; one folder per network undersrc/networks/(publisher adapters at<slug>/, advertiser adapters at<slug>-advertiser/); shared primitives undersrc/shared/; bundled Claude skills underskills/.docs/networks/— per-network setup walkthroughs (dashboard navigation, credentials, common failures), publisher and advertiser side.docs/README.md— documentation map, authority order, and review rules.templates/new-network/— scaffold to copy when adding a new network adapter.scripts/— generators and validators (validate:network,generate:readme,generate:report).tests/— vitest suite. No live API calls; everything runs against verbatim fixtures.examples/— Claude Desktop config snippet.
Adding a network
If you work for an affiliate network, the canonical path is in
CONTRIBUTING.md under "Adopting your network".
You can take ownership via .github/CODEOWNERS, verify the adapter with live
evidence, and cover whichever sides your API exposes. Adoption does not
automatically grant production; promotion follows the same evidence,
freshness, and maintainer-review gates as every adapter.
If your favourite network isn't in the table and you don't work for
it, you can add it anyway — and you don't necessarily need to be a
developer to do it. Open this repo in Claude Code and say "add
[network name] to affiliate-mcp". The contribute skill kicks in
and walks the whole process: it asks early which side you're adding
(publisher, brand-side, or both), picks the right scaffold and
credential-scope conventions, researches the network's API, writes
the tests, drafts the docs. You're the editor; Claude does the
typing.
If you'd rather drive it yourself, CONTRIBUTING.md
is the human-side workflow, AGENTS.md is the primer
for AI coding agents, and templates/new-network/
is the scaffold to copy. Networks people most often ask for are
tracked in GitHub Issues under the good first issue label.
Local development:
npm install
npm test
npm run typecheck
npm run lint
npm run buildStatus
Beta — available now. The repository contains 86 adapters across 72 network
families: 63 publisher-side and 23 advertiser-side. Support varies by adapter;
check the generated network table and REPORT.md for each
adapter's declared operations, claim status, and known limitations. Adapters
remain partial or experimental until their behaviour is confirmed against
real publisher, agency, or in-house brand accounts.
Licence
MIT. See LICENCE.
Acknowledgements
This project is only possible because the engineering teams at Awin, CJ Affiliate, eBay Partner Network, Impact, and Rakuten Advertising publish public, documented APIs — both the publisher endpoints and (for Awin, CJ, and Impact) the brand-side advertiser endpoints. These adapters read those APIs directly. Where a network has no usable API, an adapter may instead drive the user's own dashboard session (browser-driven).
