Параметры запроса, специфичные для сети

Некоторые сетевые адаптеры поддерживают дополнительные параметры, которые могут быть переданы адаптеру при создании запроса на рекламу. Они называются сетевыми экстра-параметрами.

Плагин Google Mobile Ads предоставляет API для Android и iOS, позволяющие передавать дополнительные сетевые параметры адаптерам медиации. Для этого необходимо реализовать MediationNetworkExtrasProvider на Android и FLTMediationNetworkExtrasProvider на iOS, а затем зарегистрировать реализацию вашего поставщика дополнительных параметров в плагине. После этого плагин будет использовать его для передачи дополнительных сетевых параметров при создании запроса на показ рекламы на Android или iOS.

Зарегистрируйте своего поставщика MediationNetworkExtrasProvider на Android.

Создайте реализацию MediationNetworkExtrasProvider :

class MyMediationNetworkExtrasProvider implements MediationNetworkExtrasProvider {

  @Override
  public Map<Class<? extends MediationExtrasReceiver>, Bundle> getMediationExtras(
      String adUnitId, @Nullable String identifier) {
    // This example passes extras to the AppLovin adapter.
    // This method is called with the ad unit of the associated ad request, and
    // an optional string parameter which comes from the dart ad request object.
    Bundle appLovinBundle = new AppLovinExtras.Builder().setMuteAudio(true).build();
    Map<Class<? extends MediationExtrasReceiver>, Bundle> extras = new HashMap<>();
    extras.put(ApplovinAdapter.class, appLovinBundle);
    // Note: You can pass extras to multiple adapters by adding more entries.
    return extras;
  }
}

Затем зарегистрируйте его в плагине GoogleMobileAdsPlugin :

// Register a MediationNetworkExtrasProvider with the plugin.
public class MainActivity extends FlutterActivity {

  @Override
  public void configureFlutterEngine(@NonNull FlutterEngine flutterEngine) {
    super.configureFlutterEngine(flutterEngine);

    // Register your MediationNetworkExtrasProvider to provide network extras to ad requests.
    GoogleMobileAdsPlugin.registerMediationNetworkExtrasProvider(
        flutterEngine, new MyMediationNetworkExtrasProvider());
  }
}

В справочнике Android для конкретной сети можно посмотреть, какие дополнительные модули поддерживаются различными сетями и как их настроить.

Зарегистрируйте своего поставщика услуг FLTMediationNetworkExtrasProvider на iOS.

Создайте реализацию FLTMediationNetworkExtrasProvider :

@implementation MyFLTMediationNetworkExtrasProvider

- (NSArray<id<GADAdNetworkExtras>> *_Nullable)getMediationExtras:(NSString *_Nonnull)adUnitId
                                       mediationExtrasIdentifier:
                                           (NSString *_Nullable)mediationExtrasIdentifier {
  // This example passes extras to the AppLovin adapter.
  // This method is called with the ad unit of the associated ad request, and
  // an optional string parameter which comes from the dart ad request object.
  GADMAdapterAppLovinExtras *appLovinExtras = [[GADMAdapterAppLovinExtras alloc] init];
  appLovinExtras.muteAudio = NO;
  // Note: You can pass extras to multiple adapters by adding more entries.

  return @[ appLovinExtras ];
}
@end

И зарегистрируйте его в FLTGoogleMobileAdsPlugin :


@implementation AppDelegate

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  [GeneratedPluginRegistrant registerWithRegistry:self];

  // Register your network extras provider if you want to provide
  // network extras to specific ad requests.
  MyFLTMediationNetworkExtrasProvider *networkExtrasProvider =
      [[MyFLTMediationNetworkExtrasProvider alloc] init];
  [FLTGoogleMobileAdsPlugin registerMediationNetworkExtrasProvider:networkExtrasProvider
                                                          registry:self];
  return [super application:application didFinishLaunchingWithOptions:launchOptions];
}

@end

В справочнике iOS для конкретной сети можно посмотреть, какие дополнительные функции поддерживаются различными сетями и как их настроить.