React Native Plugin Integration

Before you start

Our React Native plugin is supported from the native SDK versions 7.2.4.1 for Android and 7.2.4 for  iOS.

The plugin supports both JavaScript and TypeScript. The type declarations are included in the npm package.

Support React Native 0.66+.

iOS version support is defined per network.  ironSource ads and LevelPlay mediation supports iOS versions 12+,  XCode version 14.3.1+.

Android operating systems version 5.0 (API level 21)+.ֿ

Step 1. Add the ironSource Mediation plugin to your project

Import the event class from the IronSource mediation:

import {
IronSource,
} from 'ironsource-mediation'

NPM Integration

There are 2 options for adding the ironSource React Native plugin to your project, using npm:

  1. Run the npm CLI command
    npm install ironsource-mediation

  2. Update package.json file
    Add the ironsource-mediation definition to your package.json file:
    "dependencies": {
        "ironsource-mediation": "2.0.0"
    }

  3. Add Ad Quality SDK

    Android:

    dependencies { implementation 'com.ironsource:adqualitysdk:7.20.1 }

    iOS:

    pod 'IronSourceAdQualitySDK','7.20.1'

Manual Integration

  1. Download React Native Plugin Version
  2. Add the ironsource-mediation definition to your package.json file:
  "dependencies": {
    "ironsource-mediation": "Path/To/Local/Directory"
  },

ironSource LevelPlay demo app

The Integration Demo application demonstrates how to integrate ironSource LevelPlay in your app.

Download React Native Demo Application

Step 2. Additional settings for iOS

SKAdNetwork support

To enable the display of ironSource network ads while using SDK 7+, make sure to include the ironSource ad network ID in your app property list file (Info.plist). 

  1. Select Info.plist in the Project navigator in Xcode
  2. Click the Add button (+) beside a key in the property list editor and press Return
  3. Type the key name SKAdNetworkItems
  4. Choose Array from the pop-up menu in the Type column
  5. Create a dictionary item, and below it a single sting item  
  6. Enter Key name SKAdNetworkIdentifier, and the key value:
    su67r6k2v3.skadnetwork

  1. You can also add SKAdNetworkIdentifier  to your Info.plist, by using this code:

<key>SKAdNetworkItems</key>
<array>
   <dict>
      <key>SKAdNetworkIdentifier</key>
      <string>su67r6k2v3.skadnetwork</string>
   </dict>
</array>

SKAdNetork IDs Manager

Use ironSource SKAdNetwork IDs Manager to easily create code snippet to support ironSource network and mediated network IDs. 

For more information on editing the property list, see the Xcode documentation.

Universal SKAN Reporting

To receive copies of winning install-validation postbacks from all of the demand sources for your advertised app, add the NSAdvertisingAttributionReportEndpoint key in your app’s Info.plist.

  1. Select Info.plist in the Project navigator in Xcode
  2. Click the Add button (+) beside a key in the property list editor and press Return
  3. Type the key name NSAdvertisingAttributionReportEndpoint
  4. Choose String from the pop-up menu in the Type column
  5. Type the URL: https://postbacks-is.com 

Learn more about Universal SKAN reporting here.

App transport security settings

To ensure uninterrupted support for ironSource ad delivery across all mediation networks, it’s important to make the following changes in your info.plist:

  • Add in a dictionary called ‘NSAppTransportSecurity‘. Make sure you add this dictionary on the ‘Top Level Key‘.
  •  Inside this dictionary, add a Boolean called ‘NSAllowsArbitraryLoads‘ and set it to YES.
    ats
  • Make sure that your info.plist does not contain any other exceptions besides ‘NSAllowsArbitraryLoads‘, as this might create a conflict.
  • Find more information on ATS here.

Step 3. Additional setup for Android

Play Services Dependencies

Add Play Services Dependencies to your app level build.gradle as follows:

dependencies { implementation ‘com.google.android.gms:play-services-ads-identifier:18.0.1’
 implementation ‘com.google.android.gms:play-services-basement:18.3.0’ implementation ‘com.google.android.gms:play-services-appset:16.0.2’
 }

Android 12 Support

Apps updating their target API level to 31 (Android 12) will need to declare a Google Play services normal permission in the manifest file as follows:

<uses-permission android:name="com.google.android.gms.permission.AD_ID"/>

Read more about Google Advertising ID changes here.

Step 4. Initialize ironSource SDK

  • ironSource supports SDK settings such as setMetaData and Segments that must be configured before you initialize the SDK. See our guide on Advanced Settings for setup instructions
  • If you plan to get user authorization (iOS 14) using a pop-up whenever your app is launched, we recommend that you perform this action before you init ironSource SDK. You can learn more about App Tracking Transparency on Apple’s documentation
  • If you don’t ask for user authorization (iOS 14) upon app launch, init the ironSource SDK immediately upon launch
  • If you’re using server-to-server callbacks to reward your users with ironSource rewarded ad units, set the UserID

Init the plugin and ad units

Use the init SDK api init the SDK as detailed below to init all the ad units you’ve configured on the ironSource platform:

IronSource.init(YOUR_APP_KEY);

If you wish to initialize only specific ad units, you can use one of the following APIs:

  1. Initialize multiple ad units simultaneously:
    IronSource.init(YOUR_APP_KEY, ['REWARDED_VIDEO', 'INTERSTITIAL','BANNER']);

  2. Initialize each ad unit separately at a different touchpoint in your app flow:
    // For Rewarded Video
    IronSource.init(YOUR_APP_KEY, ['REWARDED_VIDEO']);
    /// For Interstitial
    IronSource.init(YOUR_APP_KEY, ['INTERSTITIAL']);
    /// For Banners
    IronSource.init(YOUR_APP_KEY, ['BANNER']);

    Init Complete Callback

    The ironSource SDK fires a callback to inform you that the ironSource SDK was initialized successfully. This listener will provide you with an indication that the initialization process was completed, and you can start loading ads. The callback will be sent once per session and will indicate the first initialization of the SDK.

    const listener: InitializationListener = {
      onInitializationComplete: () =>  {
        console.log('onInitializationComplete')
      }
    }
    IronSource.setInitializationListener(listener);
    IronSource.init(YOUR_APP_KEY);
    

    Step 5. Verify your integration

    The ironSource SDK provides an easy way to verify that your mediation integration was completed successfully. To verify your ironSource SDK integration as well as any additional Ad Networks you have implemented, simply add this method to your project:

    IronSource.validateIntegration();

    For more details on the ironSource Integration Verification tool navigate to this article.

    Adapters Debug

    Call the following API to enable debug logs of mediated network adapters & SDKs:

    IronSource.setAdaptersDebug(true);

    For Proguard Users Only

    If you are using ProGuard with the ironSource SDK, you must add the following code to your ProGuard file (Android Studio: proguard-rules.pro or Eclipse: proguard-project.txt):

    -keepclassmembers class com.ironsource.sdk.controller.IronSourceWebView$JSInterface {
        public *;
    }
    -keepclassmembers class * implements android.os.Parcelable {
        public static final android.os.Parcelable$Creator *;
    }
    -keep public class com.google.android.gms.ads.** {
       public *;
    }
    -keep class com.ironsource.adapters.** { *;
    }
    -keep class com.ironsource.unity.androidbridge.** { *;
    }
    -dontwarn com.ironsource.mediationsdk.**
    -dontwarn com.ironsource.adapters.**
    -keepattributes JavascriptInterface
    -keepclassmembers class * {
        @android.webkit.JavascriptInterface <methods>;
    }

    Done!

    You’re now ready to start working with ironSource’s ad units and mediation tools.

    What’s Next?

    Once you’ve verified your integration with the Integration Helper, follow our integration guides and implement our Ad Units:

    Interested in Mediation? Integrate our Rewarded Video or Interstitial Ads in your app and follow our Mediation articles.