Skip to main content

Solar Engine

Integrate Purchases SDK with Solar Engine for precise revenue tracking

AIAsk AIChatGPTClaude

With our Solar Engine integration you can:

  • Attribute subscription revenue and lifecycle events to the campaigns that drove them.
  • Stream trial conversions, renewals, cancellations, and more directly from RevenueCat without relying on an app in the foreground.
  • Continue measuring long-tail revenue from each campaign as subscriptions renew over time.

Integration at a Glance

Includes RevenueSupports Negative RevenueSends Sandbox EventsIncludes Customer AttributesSends Transfer EventsOptional Event Types
Standard Reserved Attributesnon_subscription_purchase_event uncancellation_event subscription_paused_event expiration_event billing_issue_event product_change_event

1. Install the Solar Engine SDK

Set up the latest Solar Engine SDK in every platform where you collect purchases before enabling the integration. Refer to the Solar Engine developer documentation for the most up-to-date installation instructions.

2. Send device data to RevenueCat

Solar Engine matches RevenueCat events to campaign cohorts using device and advertising identifiers. Make sure your app collects and sends the following Customer Attributes to RevenueCat before the first purchase occurs:

KeyDescriptionRecommended Platforms
$idfaiOS advertising identifier UUIDiOS
$idfviOS vendor identifier UUIDiOS
$gpsAdIdGoogle advertising identifierAndroid
$ipDevice IP address, gathered server-side when enablediOS & Android

These identifiers can be set manually like any other attribute, or by calling collectDeviceIdentifiers() after configuring the Purchases SDK. Call it again if a user later grants Ads Tracking permission so the $idfa value is updated.

Solar Engine also uses specific identifiers to associate lifecycle events with campaign cohorts. Use the Purchases SDK helpers to forward these identifiers to RevenueCat:

  • setSolarEngineDistinctId() - The Solar Engine Distinct ID (primary identifier)
  • setSolarEngineAccountId() - The Solar Engine Account ID (optional)
  • setSolarEngineVisitorId() - The Solar Engine Visitor ID (optional)
import Purchases

// ...
Purchases.configure(withAPIKey: "public_sdk_key")
// ...

// Collect device identifiers (important for attribution matching)
Purchases.shared.collectDeviceIdentifiers()

// Retrieve the identifiers from the Solar Engine SDK
let distinctId = /* Solar Engine SDK Distinct ID (optional) */
let accountId = /* Solar Engine SDK Account ID (optional) */
let visitorId = /* Solar Engine SDK Visitor ID (optional) */

// Forward them to RevenueCat
Purchases.shared.attribution.setSolarEngineDistinctId(distinctId)
Purchases.shared.attribution.setSolarEngineAccountId(accountId)
Purchases.shared.attribution.setSolarEngineVisitorId(visitorId)

3. Configure Solar Engine in the RevenueCat dashboard

After your SDK is ready and device data is flowing, finish the setup in RevenueCat:

  1. Navigate to your project settings in the RevenueCat dashboard and choose Solar Engine from the Integrations menu.

  1. Enter your iOS App Key and/or Android App Key. These keys authenticate requests from RevenueCat to Solar Engine. You can find them in your Solar Engine dashboard under Attribution > App > Edit App.

  1. If your app targets users in China mainland, enable the Use China Mainland Storage Region option to ensure data is stored in the appropriate region.

  2. Provide event names for each lifecycle event RevenueCat will send, or choose Use default event names to populate the recommended mapping:

    RevenueCat lifecycle eventDefault Solar Engine event nameEvent TypeRequired
    Initial purchaseinitial_purchase_eventIn-App Purchase + rc_event_name
    Trial startedtrial_started_eventCustom event
    Trial convertedtrial_converted_eventIn-App Purchase + rc_event_name
    Trial cancelledtrial_cancelled_eventCustom event
    Renewalrenewal_eventIn-App Purchase + rc_event_name
    Cancellationcancellation_eventCustom event
    Non-renewing purchasenon_renewing_purchase_eventIn-App Purchase + rc_event_nameOptional
    Uncancellationuncancellation_eventCustom eventOptional
    Subscription pausedsubscription_paused_eventCustom eventOptional
    Expirationexpiration_eventCustom eventOptional
    Billing issuebilling_issue_eventCustom eventOptional
    Product changeproduct_change_eventCustom eventOptional
  3. Select how RevenueCat should report revenue totals using the Revenue reporting mode menu:

    • Gross reports transaction amounts before app store commission and taxes.
    • Net reports revenue after estimated store commission and/or taxes.
  4. Click Add integration (or Save) to enable the connection.

4. Test the Solar Engine integration

Before rolling out the integration, run through an end-to-end test:

  1. Make a sandbox purchase with a new user after confirming the device identifiers from step 2 are present.
  2. Visit the Customer View for the tester and confirm the Solar Engine attributes are listed.
  3. Open the test transaction in Customer History and ensure a Solar Engine event was delivered successfully. You can also review the Last dispatched events panel in the integration settings for a delivery log.
👍You're all set!

Once configured, you should begin to see RevenueCat lifecycle events appear in Solar Engine aligned with the campaigns that sourced those users.