End-to-end RevenueCat integration — sets up the dashboard side via the RevenueCat MCP (project, app, public API key) and installs/configures the Purchases SDK in the app. Use when the user asks to add RevenueCat, integrate Purchases, install the RevenueCat SDK, set up a RevenueCat API key, configure Purchases on launch, or set up a brand new RevenueCat integration on iOS, Android, Kotlin Multiplatform, Flutter, or React Native.
68
81%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Passed
No known issues
Use this skill when the user wants to add RevenueCat to a project for the first time, or to reconfigure the SDK with a public API key. The skill covers two halves:
Purchases.configure(…) at app entry, and verify the configuration banner in the logs.Walk them in order. Most integrations need both halves, even when the user asks "just install the SDK" — the SDK needs an API key from the dashboard.
If a project + app already exist and the user only wants to wire the SDK into code, jump to Section 3 below. If the user wants to bootstrap a brand new RevenueCat project (apps + products + entitlements + offerings), use the
create-revenuecat-projectskill instead, then come back here for the SDK install.
Available as $ARGUMENTS when invoked as a slash command:
platform (optional): One of ios, android, kmp, flutter, react-native. If omitted, run the detection algorithm in Section 3a.app_identifier (optional): Bundle ID (iOS) or package name (Android). If omitted, read it from the project files (Info.plist, AndroidManifest.xml, app.json, pubspec.yaml).project_name (optional): Name of the RevenueCat project to use. If omitted, list projects via MCP and ask the user.Before touching the dashboard, gather the facts:
Info.plist / AndroidManifest.xml / app.json / pubspec.yaml rather than asking.Use the RevenueCat MCP server for every tool call below.
list-projects — list accessible projects. If multiple, ask the user which one matches this app, or offer to create a new one.create-revenuecat-project skill, then resume here.project_id for the rest of the steps.test_store app is always present; app_store and play_store apps are present only if the user has finished store-side setup.test_store app is enough to start integrating.create-app:
type: "app_store", bundle_id from Section 1.type: "play_store", package_name from Section 1.name derived from the identifier or asked from the user.list-public-api-keys with the relevant app ID:
app_store / play_store if the store-side app exists.test_store app.appl_…, Android keys goog_…, Amazon amzn_….Never use the secret API key in client code. Secret keys are server-side only.
Inspect the working directory and pick the first match, from top to bottom:
package.json has a react-native-purchases entry, or react-native as a dependency → read platforms/react-native.md. If expo is also a dependency, note it as an Expo project.pubspec.yaml exists at the project root → read platforms/flutter.md.build.gradle.kts contains a kotlin { … } multiplatform source sets block, or depends on com.revenuecat.purchases:purchases-kmp* → read platforms/kmp.md.build.gradle(.kts) applies com.android.application (and is not KMP) → read platforms/android.md.Package.swift, *.xcodeproj, *.xcworkspace, or Podfile at the project root → read platforms/ios.md.If several match (e.g. an ios/ folder inside a Flutter project), pick the outermost project, the one that owns the build. If still ambiguous, ask the user which platform they want to configure.
appl_… key, Android apps use a goog_… key (Amazon uses amzn_…). Server-side secret keys must never appear in client apps.Purchases.configure(…) exactly once, as early as possible (app entry point). Later calls no-op or warn.appUserID, RevenueCat creates a stable anonymous ID. Only pass appUserID if you already have an authenticated user at launch; otherwise call logIn(…) later (see the revenuecat-identify-user skill)..env (RN), xcconfig (iOS), local.properties / gradle.properties (Android), or dart-define (Flutter) when the user asks about secret management.Read the platform file that matches detection:
platforms/ios.mdplatforms/android.mdplatforms/kmp.mdplatforms/flutter.mdplatforms/react-native.mdEach platform file is self-contained: install command, exact configure snippet, and where to place it in the app entry point.
Do not claim setup is complete until:
./gradlew assembleDebug, flutter run, npx react-native run-ios, or the KMP equivalent).If the user only asked to "install" without running the app, tell them what to look for in the logs when they do run it.
Check whether products, entitlements, and offerings are already set up in the project. If not, offer to help via the create-revenuecat-project skill.
iOS (App Store Connect)
.p8 file. Note the Key ID and Issuer ID.create-app / update-app.Android (Google Play Console)
create-app / update-app.Common follow-ups after integrate-revenuecat:
revenuecat-paywall — display a dashboard-configured paywall.revenuecat-purchase-flow — implement purchase + restore manually.revenuecat-entitlements-gate — gate features behind active entitlements.revenuecat-identify-user — wire logIn / logOut to the app's auth system.revenuecat-testing-setup — set up a sandbox testing channel.revenuecat-troubleshoot — diagnose offerings / products / entitlement bugs.407e465
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.