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. No subscriber attributes are strictly required for events to be sent. The following Customer Attributes are recommended for accurate attribution:

KeyDescriptionRequired
$solarEngineDistinctIdSolar Engine Distinct Id. The primary Solar Engine identifier for the device⚠️ (recommended)
$solarEngineAccountIdSolar Engine Account Id⚠️ (recommended)
$solarEngineVisitorIdSolar Engine Visitor Id⚠️ (optional)
$idfaiOS advertising identifier UUID⚠️ (recommended)
$gpsAdIdGoogle advertising identifier⚠️ (recommended)
$idfviOS vendor identifier UUID⚠️ (recommended)
$ipThe IP address of the device⚠️ (recommended)

These properties can be set manually, like any other Customer Attributes, or through the helper methods collectDeviceIdentifiers() and the Solar Engine setter methods.

import AdSupport
import Purchases

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

// Automatically collect the $idfa, $idfv, and $ip values
Purchases.shared.attribution.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)

You should make sure to call collectDeviceIdentifiers() after the Purchases SDK is configured, and before the first purchase occurs. It's safe to call this multiple times, as only the new/updated values will be sent to RevenueCat.

❗️Device identifiers with iOS App Tracking Transparency (iOS 14.5+)

If you are requesting the App Tracking permission through ATT to access the IDFA, you can call .collectDeviceIdentifiers() again if the customer accepts the permission to update the $idfa attribute in RevenueCat.

📘Import AdSupport Framework (iOS)

The AdSupport framework is required to access the IDFA parameter on iOS. Don't forget to import this into your project.

Import AdSupport Framework

❗️Remove any client-side purchase tracking

Make sure to remove all client-side tracking of revenue. Since RevenueCat will be sending events for all revenue actions, tracking purchases with the Solar Engine SDK directly can lead to double counting of revenue in Solar Engine.

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.