diff --git a/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll b/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll
index 12c150e2..65b099b6 100755
Binary files a/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll and b/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll differ
diff --git a/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll.meta b/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll.meta
index b43088d1..a35483b1 100644
--- a/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll.meta
+++ b/Assets/ExternalDependencyManager/Editor/Google.VersionHandler.dll.meta
@@ -1,8 +1,8 @@
fileFormatVersion: 2
-guid: f7632a50b10045458c53a5ddf7b6d238
+guid: 86460262ea60447dbb6a62d21167790f
labels:
- gvh
-- gvh_version-1.2.186
+- gvh_version-1.2.177
- gvhp_exportpath-ExternalDependencyManager/Editor/Google.VersionHandler.dll
- gvhp_targets-editor
timeCreated: 1480838400
diff --git a/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml b/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml
deleted file mode 100644
index 80f3b4c8..00000000
--- a/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml.meta b/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml.meta
deleted file mode 100644
index 3360fd3f..00000000
--- a/Assets/MaxSdk/AppLovin/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 746da98302dc0402aaa37e8f7bd97e77
-labels:
-- al_max
-- al_max_export_path-MaxSdk/AppLovin/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/AppLovin/Plugins/Android/applovin-max-unity-plugin.aar b/Assets/MaxSdk/AppLovin/Plugins/Android/applovin-max-unity-plugin.aar
deleted file mode 100644
index 9600e02c..00000000
Binary files a/Assets/MaxSdk/AppLovin/Plugins/Android/applovin-max-unity-plugin.aar and /dev/null differ
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h
deleted file mode 100644
index 117c7fd2..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h
+++ /dev/null
@@ -1,97 +0,0 @@
-//
-// MAUnityAdManager.h
-// AppLovin MAX Unity Plugin
-//
-
-#import
-#import
-
-NS_ASSUME_NONNULL_BEGIN
-typedef const void *MAUnityRef;
-typedef void (*ALUnityBackgroundCallback)(const char* args);
-
-@interface MAUnityAdManager : NSObject
-
-- (void)initializeSdkWithConfiguration:(ALSdkInitializationConfiguration *)initConfig andCompletionHandler:(ALSdkInitializationCompletionHandler)completionHandler;
-
-- (void)createBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier atPosition:(nullable NSString *)bannerPosition isAdaptive:(BOOL)isAdaptive;
-- (void)createBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier x:(CGFloat)xOffset y:(CGFloat)yOffset isAdaptive:(BOOL)isAdaptive;
-- (void)loadBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)setBannerBackgroundColorForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier hexColorCode:(nullable NSString *)hexColorCode;
-- (void)setBannerPlacement:(nullable NSString *)placement forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)startBannerAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)stopBannerAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)setBannerExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value;
-- (void)setBannerLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-- (void)setBannerCustomData:(nullable NSString *)customData forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)setBannerWidth:(CGFloat)width forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)updateBannerPosition:(nullable NSString *)bannerPosition forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)updateBannerPosition:(CGFloat)xOffset y:(CGFloat)yOffset forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)showBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)destroyBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)hideBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (NSString *)bannerLayoutForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-+ (CGFloat)adaptiveBannerHeightForWidth:(CGFloat)width;
-
-- (void)createMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier atPosition:(nullable NSString *)mrecPosition;
-- (void)createMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier x:(CGFloat)xOffset y:(CGFloat)yOffset;
-- (void)loadMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)setMRecPlacement:(nullable NSString *)placement forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)startMRecAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)stopMRecAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifer;
-- (void)setMRecExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value;
-- (void)setMRecLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-- (void)setMRecCustomData:(nullable NSString *)customData forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)showMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)destroyMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)hideMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)updateMRecPosition:(nullable NSString *)mrecPosition forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)updateMRecPosition:(CGFloat)xOffset y:(CGFloat)yOffset forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (NSString *)mrecLayoutForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-
-- (void)loadInterstitialWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (BOOL)isInterstitialReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)showInterstitialWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData;
-- (void)setInterstitialExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value;
-- (void)setInterstitialLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-
-- (void)loadAppOpenAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (BOOL)isAppOpenAdReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)showAppOpenAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData;
-- (void)setAppOpenAdExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value;
-- (void)setAppOpenAdLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-
-- (void)loadRewardedAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (BOOL)isRewardedAdReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-- (void)showRewardedAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData;
-- (void)setRewardedAdExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value;
-- (void)setRewardedAdLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-
-// Event Tracking
-- (void)trackEvent:(nullable NSString *)event parameters:(nullable NSString *)parameters;
-
-// Ad Value
-- (NSString *)adValueForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier withKey:(nullable NSString *)key;
-
-// User Service
-- (void)didDismissUserConsentDialog;
-
-// CMP Service
-- (void)showCMPForExistingUser;
-
-// Utils
-+ (NSString *)serializeParameters:(NSDictionary *)dict;
-+ (NSDictionary *)deserializeParameters:(nullable NSString *)serialized;
-
-+ (void)setUnityBackgroundCallback:(ALUnityBackgroundCallback)unityBackgroundCallback;
-
-/**
- * Creates an instance of @c MAUnityAdManager if needed and returns the singleton instance.
- */
-+ (instancetype)shared;
-
-- (instancetype)init NS_UNAVAILABLE;
-
-@end
-
-NS_ASSUME_NONNULL_END
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h.meta b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h.meta
deleted file mode 100644
index aef1db55..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h.meta
+++ /dev/null
@@ -1,115 +0,0 @@
-fileFormatVersion: 2
-guid: 4209563f82b8a4f7dabf03705ab761c6
-labels:
-- al_max
-- al_max_export_path-MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.h
-PluginImporter:
- externalObjects: {}
- serializedVersion: 2
- iconMap: {}
- executionOrder: {}
- defineConstraints: []
- isPreloaded: 0
- isOverridable: 0
- isExplicitlyReferenced: 0
- validateReferences: 1
- platformData:
- - first:
- '': Any
- second:
- enabled: 0
- settings:
- Exclude Android: 1
- Exclude Editor: 1
- Exclude Linux: 1
- Exclude Linux64: 1
- Exclude LinuxUniversal: 1
- Exclude OSXUniversal: 1
- Exclude Win: 1
- Exclude Win64: 1
- Exclude iOS: 0
- Exclude tvOS: 1
- - first:
- Android: Android
- second:
- enabled: 0
- settings:
- CPU: ARMv7
- - first:
- Any:
- second:
- enabled: 0
- settings: {}
- - first:
- Editor: Editor
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- DefaultValueInitialized: true
- OS: AnyOS
- - first:
- Facebook: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Facebook: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Linux
- second:
- enabled: 0
- settings:
- CPU: x86
- - first:
- Standalone: Linux64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: LinuxUniversal
- second:
- enabled: 0
- settings:
- CPU: None
- - first:
- Standalone: OSXUniversal
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- iPhone: iOS
- second:
- enabled: 1
- settings:
- CompileFlags:
- FrameworkDependencies:
- - first:
- tvOS: tvOS
- second:
- enabled: 0
- settings:
- CompileFlags:
- FrameworkDependencies:
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m
deleted file mode 100644
index a7bd6669..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m
+++ /dev/null
@@ -1,2067 +0,0 @@
-//
-// MAUnityAdManager.m
-// AppLovin MAX Unity Plugin
-//
-
-#import "MAUnityAdManager.h"
-
-#define KEY_WINDOW [UIApplication sharedApplication].keyWindow
-#define DEVICE_SPECIFIC_ADVIEW_AD_FORMAT ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdiomPad) ? MAAdFormat.leader : MAAdFormat.banner
-#define IS_VERTICAL_BANNER_POSITION(_POS) ( [@"center_left" isEqual: adViewPosition] || [@"center_right" isEqual: adViewPosition] )
-#define DEGREES_TO_RADIANS(angle) ((angle) / 180.0 * M_PI)
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
- extern bool max_unity_should_disable_all_logs(void); // Forward declaration
-
- // UnityAppController.mm
- UIViewController* UnityGetGLViewController(void);
- UIWindow* UnityGetMainWindow(void);
-
- // life cycle management
- int UnityIsPaused(void);
- void UnityPause(int pause);
-
- void max_unity_dispatch_on_main_thread(dispatch_block_t block)
- {
- if ( block )
- {
- if ( [NSThread isMainThread] )
- {
- block();
- }
- else
- {
- dispatch_async(dispatch_get_main_queue(), block);
- }
- }
- }
-#ifdef __cplusplus
-}
-#endif
-
-@interface MAUnityAdManager()
-
-// Parent Fields
-@property (nonatomic, weak) ALSdk *sdk;
-
-// Fullscreen Ad Fields
-@property (nonatomic, strong) NSMutableDictionary *interstitials;
-@property (nonatomic, strong) NSMutableDictionary *appOpenAds;
-@property (nonatomic, strong) NSMutableDictionary *rewardedAds;
-
-// AdView Fields
-@property (nonatomic, strong) NSMutableDictionary *adViews;
-@property (nonatomic, strong) NSMutableDictionary *adViewAdFormats;
-@property (nonatomic, strong) NSMutableDictionary *adViewPositions;
-@property (nonatomic, strong) NSMutableDictionary *adViewOffsets;
-@property (nonatomic, strong) NSMutableDictionary *adViewWidths;
-@property (nonatomic, strong) NSMutableDictionary *verticalAdViewFormats;
-@property (nonatomic, strong) NSMutableDictionary *> *adViewConstraints;
-@property (nonatomic, strong) NSMutableDictionary *> *adViewExtraParametersToSetAfterCreate;
-@property (nonatomic, strong) NSMutableDictionary *> *adViewLocalExtraParametersToSetAfterCreate;
-@property (nonatomic, strong) NSMutableDictionary *adViewCustomDataToSetAfterCreate;
-@property (nonatomic, strong) NSMutableArray *adUnitIdentifiersToShowAfterCreate;
-@property (nonatomic, strong) NSMutableSet *disabledAdaptiveBannerAdUnitIdentifiers;
-@property (nonatomic, strong) NSMutableSet *disabledAutoRefreshAdViewAdUnitIdentifiers;
-@property (nonatomic, strong) NSMutableSet *ignoreSafeAreaLandscapeAdUnitIdentifiers;
-@property (nonatomic, strong) UIView *safeAreaBackground;
-@property (nonatomic, strong, nullable) UIColor *publisherBannerBackgroundColor;
-
-@property (nonatomic, strong) NSMutableDictionary *adInfoDict;
-@property (nonatomic, strong) NSObject *adInfoDictLock;
-
-@property (nonatomic, strong) NSOperationQueue *backgroundCallbackEventsQueue;
-@property (nonatomic, assign) BOOL resumeUnityAfterApplicationBecomesActive;
-
-@end
-
-// Internal
-@interface UIColor (ALUtils)
-+ (nullable UIColor *)al_colorWithHexString:(NSString *)hexString;
-@end
-
-@interface NSNumber (ALUtils)
-+ (NSNumber *)al_numberWithString:(NSString *)string;
-@end
-
-@interface NSString (ALUtils)
-@property (assign, readonly, getter=al_isValidString) BOOL al_validString;
-@end
-
-@interface MAAdFormat (ALUtils)
-@property (nonatomic, assign, readonly, getter=isFullscreenAd) BOOL fullscreenAd;
-@property (nonatomic, assign, readonly, getter=isAdViewAd) BOOL adViewAd;
-@end
-
-@implementation MAUnityAdManager
-static NSString *const SDK_TAG = @"AppLovinSdk";
-static NSString *const TAG = @"MAUnityAdManager";
-static NSString *const DEFAULT_AD_VIEW_POSITION = @"top_left";
-static ALUnityBackgroundCallback backgroundCallback;
-
-#pragma mark - Initialization
-
-- (instancetype)init
-{
- self = [super init];
- if ( self )
- {
- self.interstitials = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.appOpenAds = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.rewardedAds = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViews = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewAdFormats = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewPositions = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewOffsets = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewWidths = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.verticalAdViewFormats = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewConstraints = [NSMutableDictionary dictionaryWithCapacity: 2];
- self.adViewExtraParametersToSetAfterCreate = [NSMutableDictionary dictionaryWithCapacity: 1];
- self.adViewLocalExtraParametersToSetAfterCreate = [NSMutableDictionary dictionaryWithCapacity: 1];
- self.adViewCustomDataToSetAfterCreate = [NSMutableDictionary dictionaryWithCapacity: 1];
- self.adUnitIdentifiersToShowAfterCreate = [NSMutableArray arrayWithCapacity: 2];
- self.disabledAdaptiveBannerAdUnitIdentifiers = [NSMutableSet setWithCapacity: 2];
- self.disabledAutoRefreshAdViewAdUnitIdentifiers = [NSMutableSet setWithCapacity: 2];
- self.ignoreSafeAreaLandscapeAdUnitIdentifiers = [NSMutableSet setWithCapacity: 2];
- self.adInfoDict = [NSMutableDictionary dictionary];
- self.adInfoDictLock = [[NSObject alloc] init];
-
- self.backgroundCallbackEventsQueue = [[NSOperationQueue alloc] init];
- self.backgroundCallbackEventsQueue.maxConcurrentOperationCount = 1;
-
- max_unity_dispatch_on_main_thread(^{
- self.safeAreaBackground = [[UIView alloc] init];
- self.safeAreaBackground.hidden = YES;
- self.safeAreaBackground.backgroundColor = UIColor.clearColor;
- self.safeAreaBackground.translatesAutoresizingMaskIntoConstraints = NO;
- self.safeAreaBackground.userInteractionEnabled = NO;
-
- UIViewController *rootViewController = [self unityViewController];
- [rootViewController.view addSubview: self.safeAreaBackground];
- });
-
- // Enable orientation change listener, so that the position can be updated for vertical banners.
- [[NSNotificationCenter defaultCenter] addObserverForName: UIDeviceOrientationDidChangeNotification
- object: nil
- queue: [NSOperationQueue mainQueue]
- usingBlock:^(NSNotification *notification) {
-
- for ( NSString *adUnitIdentifier in self.verticalAdViewFormats )
- {
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: self.verticalAdViewFormats[adUnitIdentifier]];
- }
- }];
-
- [[NSNotificationCenter defaultCenter] addObserver: self
- selector: @selector(applicationPaused:)
- name: UIApplicationDidEnterBackgroundNotification
- object: nil];
-
- [[NSNotificationCenter defaultCenter] addObserver: self
- selector: @selector(applicationResumed:)
- name: UIApplicationDidBecomeActiveNotification
- object: nil];
-
- [[NSNotificationCenter defaultCenter] addObserverForName: UIApplicationDidBecomeActiveNotification
- object: nil
- queue: [NSOperationQueue mainQueue]
- usingBlock:^(NSNotification *notification) {
-
-#if !IS_TEST_APP
- if ( self.resumeUnityAfterApplicationBecomesActive && UnityIsPaused() )
- {
- UnityPause(NO);
- }
-#endif
-
- self.backgroundCallbackEventsQueue.suspended = NO;
- }];
- }
- return self;
-}
-
-+ (MAUnityAdManager *)shared
-{
- static dispatch_once_t token;
- static MAUnityAdManager *shared;
- dispatch_once(&token, ^{
- shared = [[MAUnityAdManager alloc] init];
- });
- return shared;
-}
-
-+ (void)setUnityBackgroundCallback:(ALUnityBackgroundCallback)unityBackgroundCallback
-{
- backgroundCallback = unityBackgroundCallback;
-}
-
-#pragma mark - Plugin Initialization
-
-- (void)initializeSdkWithConfiguration:(ALSdkInitializationConfiguration *)initConfig andCompletionHandler:(ALSdkInitializationCompletionHandler)completionHandler;
-{
- self.sdk = [ALSdk shared];
- [self.sdk initializeWithConfiguration: initConfig completionHandler:^(ALSdkConfiguration *configuration) {
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- // Note: internal state should be updated first
- completionHandler( configuration );
-
- NSString *consentFlowUserGeographyStr = @(configuration.consentFlowUserGeography).stringValue;
- NSString *consentDialogStateStr = @(configuration.consentDialogState).stringValue;
- NSString *appTrackingStatus = @(configuration.appTrackingTransparencyStatus).stringValue; // Deliberately name it `appTrackingStatus` to be a bit more generic (in case Android introduces a similar concept)
- [self forwardUnityEventWithArgs: @{@"name" : @"OnSdkInitializedEvent",
- @"consentFlowUserGeography" : consentFlowUserGeographyStr,
- @"consentDialogState" : consentDialogStateStr,
- @"countryCode" : configuration.countryCode,
- @"appTrackingStatus" : appTrackingStatus,
- @"isSuccessfullyInitialized" : @([self.sdk isInitialized]),
- @"isTestModeEnabled" : @([configuration isTestModeEnabled])}];
- });
- }];
-}
-
-#pragma mark - Banners
-
-- (void)createBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier atPosition:(nullable NSString *)bannerPosition isAdaptive:(BOOL)isAdaptive
-{
- [self createAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier] atPosition: bannerPosition withOffset: CGPointZero isAdaptive: isAdaptive];
-}
-
-- (void)createBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier x:(CGFloat)xOffset y:(CGFloat)yOffset isAdaptive:(BOOL)isAdaptive
-{
- [self createAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier] atPosition: DEFAULT_AD_VIEW_POSITION withOffset: CGPointMake(xOffset, yOffset) isAdaptive: isAdaptive];
-}
-
-- (void)loadBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self loadAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)setBannerBackgroundColorForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier hexColorCode:(nullable NSString *)hexColorCode
-{
- [self setAdViewBackgroundColorForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier] hexColorCode: hexColorCode];
-}
-
-- (void)setBannerPlacement:(nullable NSString *)placement forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self setAdViewPlacement: placement forAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)startBannerAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self startAdViewAutoRefreshForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)stopBannerAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self stopAdViewAutoRefreshForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)setBannerWidth:(CGFloat)width forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self setAdViewWidth: width forAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)updateBannerPosition:(nullable NSString *)bannerPosition forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self updateAdViewPosition: bannerPosition withOffset: CGPointZero forAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)updateBannerPosition:(CGFloat)xOffset y:(CGFloat)yOffset forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self updateAdViewPosition: DEFAULT_AD_VIEW_POSITION withOffset: CGPointMake(xOffset, yOffset) forAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)setBannerExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value
-{
- [self setAdViewExtraParameterForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier] key: key value: value];
-}
-
-- (void)setBannerLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value
-{
- if ( !key )
- {
- [self log: @"Failed to set local extra parameter: No key specified"];
- return;
- }
-
- [self setAdViewLocalExtraParameterForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier] key: key value: value];
-}
-
-- (void)setBannerCustomData:(nullable NSString *)customData forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self setAdViewCustomData: customData forAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)showBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self showAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)hideBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self hideAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (NSString *)bannerLayoutForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- return [self adViewLayoutForAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-- (void)destroyBannerWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self destroyAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: [self adViewAdFormatForAdUnitIdentifier: adUnitIdentifier]];
-}
-
-+ (CGFloat)adaptiveBannerHeightForWidth:(CGFloat)width
-{
- return [DEVICE_SPECIFIC_ADVIEW_AD_FORMAT adaptiveSizeForWidth: width].height;
-}
-
-#pragma mark - MRECs
-
-- (void)createMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier atPosition:(nullable NSString *)mrecPosition
-{
- [self createAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec atPosition: mrecPosition withOffset: CGPointZero isAdaptive: NO];
-}
-
-- (void)createMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier x:(CGFloat)xOffset y:(CGFloat)yOffset
-{
- [self createAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec atPosition: DEFAULT_AD_VIEW_POSITION withOffset: CGPointMake(xOffset, yOffset) isAdaptive: NO];
-}
-
-- (void)loadMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self loadAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)setMRecPlacement:(nullable NSString *)placement forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self setAdViewPlacement: placement forAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)startMRecAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self startAdViewAutoRefreshForAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)stopMRecAutoRefreshForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self stopAdViewAutoRefreshForAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)updateMRecPosition:(nullable NSString *)mrecPosition forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self updateAdViewPosition: mrecPosition withOffset: CGPointZero forAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)updateMRecPosition:(CGFloat)xOffset y:(CGFloat)yOffset forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self updateAdViewPosition: DEFAULT_AD_VIEW_POSITION withOffset: CGPointMake(xOffset, yOffset) forAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)setMRecExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value
-{
- [self setAdViewExtraParameterForAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec key: key value: value];
-}
-
-- (void)setMRecLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value
-{
- if ( !key )
- {
- [self log: @"Failed to set local extra parameter: No key specified"];
- return;
- }
-
- [self setAdViewLocalExtraParameterForAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec key: key value: value];
-}
-
-- (void)setMRecCustomData:(nullable NSString *)customData forAdUnitIdentifier:(nullable NSString *)adUnitIdentifier;
-{
- [self setAdViewCustomData: customData forAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)showMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self showAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)destroyMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self destroyAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (void)hideMRecWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- [self hideAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-- (NSString *)mrecLayoutForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- return [self adViewLayoutForAdUnitIdentifier: adUnitIdentifier adFormat: MAAdFormat.mrec];
-}
-
-#pragma mark - Interstitials
-
-- (void)loadInterstitialWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MAInterstitialAd *interstitial = [self retrieveInterstitialForAdUnitIdentifier: adUnitIdentifier];
- [interstitial loadAd];
-}
-
-- (BOOL)isInterstitialReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MAInterstitialAd *interstitial = [self retrieveInterstitialForAdUnitIdentifier: adUnitIdentifier];
- return [interstitial isReady];
-}
-
-- (void)showInterstitialWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData
-{
- MAInterstitialAd *interstitial = [self retrieveInterstitialForAdUnitIdentifier: adUnitIdentifier];
- [interstitial showAdForPlacement: placement customData: customData];
-}
-
-- (void)setInterstitialExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value
-{
- MAInterstitialAd *interstitial = [self retrieveInterstitialForAdUnitIdentifier: adUnitIdentifier];
- [interstitial setExtraParameterForKey: key value: value];
-}
-
-- (void)setInterstitialLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value
-{
- if ( !key )
- {
- [self log: @"Failed to set local extra parameter: No key specified"];
- return;
- }
-
- MAInterstitialAd *interstitial = [self retrieveInterstitialForAdUnitIdentifier: adUnitIdentifier];
- [interstitial setLocalExtraParameterForKey: key value: value];
-}
-
-#pragma mark - App Open Ads
-
-- (void)loadAppOpenAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MAAppOpenAd *appOpenAd = [self retrieveAppOpenAdForAdUnitIdentifier: adUnitIdentifier];
- [appOpenAd loadAd];
-}
-
-- (BOOL)isAppOpenAdReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MAAppOpenAd *appOpenAd = [self retrieveAppOpenAdForAdUnitIdentifier: adUnitIdentifier];
- return [appOpenAd isReady];
-}
-
-- (void)showAppOpenAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData
-{
- MAAppOpenAd *appOpenAd = [self retrieveAppOpenAdForAdUnitIdentifier: adUnitIdentifier];
- [appOpenAd showAdForPlacement: placement customData: customData];
-}
-
-- (void)setAppOpenAdExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value
-{
- MAAppOpenAd *appOpenAd = [self retrieveAppOpenAdForAdUnitIdentifier: adUnitIdentifier];
- [appOpenAd setExtraParameterForKey: key value: value];
-}
-
-- (void)setAppOpenAdLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value
-{
- if ( !key )
- {
- [self log: @"Failed to set local extra parameter: No key specified"];
- return;
- }
-
- MAAppOpenAd *appOpenAd = [self retrieveAppOpenAdForAdUnitIdentifier: adUnitIdentifier];
- [appOpenAd setLocalExtraParameterForKey: key value: value];
-}
-
-#pragma mark - Rewarded
-
-- (void)loadRewardedAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MARewardedAd *rewardedAd = [self retrieveRewardedAdForAdUnitIdentifier: adUnitIdentifier];
- [rewardedAd loadAd];
-}
-
-- (BOOL)isRewardedAdReadyWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier
-{
- MARewardedAd *rewardedAd = [self retrieveRewardedAdForAdUnitIdentifier: adUnitIdentifier];
- return [rewardedAd isReady];
-}
-
-- (void)showRewardedAdWithAdUnitIdentifier:(nullable NSString *)adUnitIdentifier placement:(nullable NSString *)placement customData:(nullable NSString *)customData
-{
- MARewardedAd *rewardedAd = [self retrieveRewardedAdForAdUnitIdentifier: adUnitIdentifier];
- [rewardedAd showAdForPlacement: placement customData: customData];
-}
-
-- (void)setRewardedAdExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable NSString *)value
-{
- MARewardedAd *rewardedAd = [self retrieveRewardedAdForAdUnitIdentifier: adUnitIdentifier];
- [rewardedAd setExtraParameterForKey: key value: value];
-}
-
-- (void)setRewardedAdLocalExtraParameterForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier key:(nullable NSString *)key value:(nullable id)value;
-{
- if ( !key )
- {
- [self log: @"Failed to set local extra parameter: No key specified"];
- return;
- }
-
- MARewardedAd *rewardedAd = [self retrieveRewardedAdForAdUnitIdentifier: adUnitIdentifier];
- [rewardedAd setLocalExtraParameterForKey: key value: value];
-}
-
-#pragma mark - Event Tracking
-
-- (void)trackEvent:(nullable NSString *)event parameters:(nullable NSString *)parameters
-{
- NSDictionary *deserializedParameters = [MAUnityAdManager deserializeParameters: parameters];
- [self.sdk.eventService trackEvent: event parameters: deserializedParameters];
-}
-
-#pragma mark - Ad Info
-
-- (NSDictionary *)adInfoForAd:(MAAd *)ad
-{
- return @{@"adUnitId" : ad.adUnitIdentifier,
- @"adFormat" : ad.format.label,
- @"networkName" : ad.networkName,
- @"networkPlacement" : ad.networkPlacement,
- @"creativeId" : ad.creativeIdentifier ?: @"",
- @"placement" : ad.placement ?: @"",
- @"revenue" : [@(ad.revenue) stringValue],
- @"revenuePrecision" : ad.revenuePrecision,
- @"waterfallInfo" : [self createAdWaterfallInfo: ad.waterfall],
- @"latencyMillis" : [self requestLatencyMillisFromRequestLatency: ad.requestLatency],
- @"dspName" : ad.DSPName ?: @""};
-}
-
-#pragma mark - Waterfall Information
-
-- (NSDictionary *)createAdWaterfallInfo:(MAAdWaterfallInfo *)waterfallInfo
-{
- NSMutableDictionary *waterfallInfoDict = [NSMutableDictionary dictionary];
- if ( !waterfallInfo ) return waterfallInfoDict;
-
- waterfallInfoDict[@"name"] = waterfallInfo.name;
- waterfallInfoDict[@"testName"] = waterfallInfo.testName;
-
- NSMutableArray *> *networkResponsesArray = [NSMutableArray arrayWithCapacity: waterfallInfo.networkResponses.count];
- for ( MANetworkResponseInfo *response in waterfallInfo.networkResponses )
- {
- [networkResponsesArray addObject: [self createNetworkResponseInfo: response]];
- }
-
- waterfallInfoDict[@"networkResponses"] = networkResponsesArray;
- waterfallInfoDict[@"latencyMillis"] = [self requestLatencyMillisFromRequestLatency: waterfallInfo.latency];
-
- return waterfallInfoDict;
-}
-
-- (NSDictionary *)createNetworkResponseInfo:(MANetworkResponseInfo *)response
-{
- NSMutableDictionary *networkResponseDict = [NSMutableDictionary dictionary];
-
- networkResponseDict[@"adLoadState"] = @(response.adLoadState).stringValue;
-
- MAMediatedNetworkInfo *mediatedNetworkInfo = response.mediatedNetwork;
- if ( mediatedNetworkInfo )
- {
- NSMutableDictionary *networkInfoObject = [NSMutableDictionary dictionary];
- networkInfoObject[@"name"] = response.mediatedNetwork.name;
- networkInfoObject[@"adapterClassName"] = response.mediatedNetwork.adapterClassName;
- networkInfoObject[@"adapterVersion"] = response.mediatedNetwork.adapterVersion;
- networkInfoObject[@"sdkVersion"] = response.mediatedNetwork.sdkVersion;
- networkInfoObject[@"initializationStatus"] = @(response.mediatedNetwork.initializationStatus);
-
- networkResponseDict[@"mediatedNetwork"] = networkInfoObject;
- }
-
- networkResponseDict[@"credentials"] = response.credentials;
- networkResponseDict[@"isBidding"] = @([response isBidding]);
-
- MAError *error = response.error;
- if ( error )
- {
- NSMutableDictionary *errorObject = [NSMutableDictionary dictionary];
- errorObject[@"errorMessage"] = error.message;
- errorObject[@"adLoadFailure"] = error.adLoadFailureInfo;
- errorObject[@"errorCode"] = @(error.code).stringValue;
- errorObject[@"latencyMillis"] = [self requestLatencyMillisFromRequestLatency: error.requestLatency];
-
- networkResponseDict[@"error"] = errorObject;
- }
-
- networkResponseDict[@"latencyMillis"] = [self requestLatencyMillisFromRequestLatency: response.latency];
-
- return networkResponseDict;
-}
-
-#pragma mark - Ad Value
-
-- (NSString *)adValueForAdUnitIdentifier:(nullable NSString *)adUnitIdentifier withKey:(nullable NSString *)key
-{
- if ( adUnitIdentifier == nil || adUnitIdentifier.length == 0 ) return @"";
- if ( key == nil || key.length == 0 ) return @"";
-
- MAAd *ad = [self adWithAdUnitIdentifier: adUnitIdentifier];
- if ( !ad ) return @"";
-
- return [ad adValueForKey: key];
-}
-
-#pragma mark - Ad Callbacks
-
-- (void)didLoadAd:(MAAd *)ad
-{
- NSString *name;
- MAAdFormat *adFormat = ad.format;
- if ( [adFormat isAdViewAd] )
- {
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: ad.adUnitIdentifier adFormat: adFormat];
- // An ad is now being shown, enable user interaction.
- adView.userInteractionEnabled = YES;
-
- if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdLoadedEvent";
- }
- else
- {
- name = @"OnBannerAdLoadedEvent";
- }
- [self positionAdViewForAd: ad];
-
- // Do not auto-refresh by default if the ad view is not showing yet (e.g. first load during app launch and publisher does not automatically show banner upon load success)
- // We will resume auto-refresh in -[MAUnityAdManager showBannerWithAdUnitIdentifier:].
- if ( adView && [adView isHidden] )
- {
- [adView stopAutoRefresh];
- }
- }
- else if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialLoadedEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdLoadedEvent";
- }
- else if ( MAAdFormat.rewarded == adFormat )
- {
- name = @"OnRewardedAdLoadedEvent";
- }
- else
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- @synchronized ( self.adInfoDictLock )
- {
- self.adInfoDict[ad.adUnitIdentifier] = ad;
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didFailToLoadAdForAdUnitIdentifier:(NSString *)adUnitIdentifier withError:(MAError *)error
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- if ( !adUnitIdentifier )
- {
- [self log: @"adUnitIdentifier cannot be nil from %@", [NSThread callStackSymbols]];
- return;
- }
-
- NSString *name;
- if ( self.adViews[adUnitIdentifier] )
- {
- MAAdFormat *adFormat = self.adViewAdFormats[adUnitIdentifier];
- if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdLoadFailedEvent";
- }
- else
- {
- name = @"OnBannerAdLoadFailedEvent";
- }
- }
- else if ( self.interstitials[adUnitIdentifier] )
- {
- name = @"OnInterstitialLoadFailedEvent";
- }
- else if ( self.appOpenAds[adUnitIdentifier] )
- {
- name = @"OnAppOpenAdLoadFailedEvent";
- }
- else if ( self.rewardedAds[adUnitIdentifier] )
- {
- name = @"OnRewardedAdLoadFailedEvent";
- }
- else
- {
- [self log: @"invalid adUnitId from %@", [NSThread callStackSymbols]];
- return;
- }
-
- @synchronized ( self.adInfoDictLock )
- {
- [self.adInfoDict removeObjectForKey: adUnitIdentifier];
- }
-
- [self forwardUnityEventWithArgs: @{@"name" : name,
- @"adUnitId" : adUnitIdentifier,
- @"errorCode" : [@(error.code) stringValue],
- @"errorMessage" : error.message,
- @"waterfallInfo" : [self createAdWaterfallInfo: error.waterfall],
- @"adLoadFailureInfo" : error.adLoadFailureInfo ?: @"",
- @"latencyMillis" : [self requestLatencyMillisFromRequestLatency: error.requestLatency]}];
- });
-}
-
-- (void)didClickAd:(MAAd *)ad
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- MAAdFormat *adFormat = ad.format;
- if ( MAAdFormat.banner == adFormat || MAAdFormat.leader == adFormat )
- {
- name = @"OnBannerAdClickedEvent";
- }
- else if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdClickedEvent";
- }
- else if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialClickedEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdClickedEvent";
- }
- else if ( MAAdFormat.rewarded == adFormat )
- {
- name = @"OnRewardedAdClickedEvent";
- }
- else
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didDisplayAd:(MAAd *)ad
-{
- // BMLs do not support [DISPLAY] events in Unity
- MAAdFormat *adFormat = ad.format;
- if ( ![adFormat isFullscreenAd] ) return;
-
-#if !IS_TEST_APP
- // UnityPause needs to be called on the main thread.
- UnityPause(YES);
-#endif
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialDisplayedEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdDisplayedEvent";
- }
- else // rewarded
- {
- name = @"OnRewardedAdDisplayedEvent";
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didFailToDisplayAd:(MAAd *)ad withError:(MAError *)error
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- // BMLs do not support [DISPLAY] events in Unity
- MAAdFormat *adFormat = ad.format;
- if ( ![adFormat isFullscreenAd] ) return;
-
- NSString *name;
- if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialAdFailedToDisplayEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdFailedToDisplayEvent";
- }
- else // rewarded
- {
- name = @"OnRewardedAdFailedToDisplayEvent";
- }
-
- NSMutableDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- args[@"errorCode"] = [@(error.code) stringValue];
- args[@"errorMessage"] = error.message;
- args[@"mediatedNetworkErrorCode"] = [@(error.mediatedNetworkErrorCode) stringValue];
- args[@"mediatedNetworkErrorMessage"] = error.mediatedNetworkErrorMessage;
- args[@"waterfallInfo"] = [self createAdWaterfallInfo: error.waterfall];
- args[@"latencyMillis"] = [self requestLatencyMillisFromRequestLatency: error.requestLatency];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didHideAd:(MAAd *)ad
-{
- // BMLs do not support [HIDDEN] events in Unity
- MAAdFormat *adFormat = ad.format;
- if ( ![adFormat isFullscreenAd] ) return;
-
-#if !IS_TEST_APP
- extern bool _didResignActive;
- if ( _didResignActive )
- {
- // If the application is not active, we should wait until application becomes active to resume unity.
- self.resumeUnityAfterApplicationBecomesActive = YES;
- }
- else
- {
- // UnityPause needs to be called on the main thread.
- UnityPause(NO);
- }
-#endif
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialHiddenEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdHiddenEvent";
- }
- else // rewarded
- {
- name = @"OnRewardedAdHiddenEvent";
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didExpandAd:(MAAd *)ad
-{
- MAAdFormat *adFormat = ad.format;
- if ( ![adFormat isAdViewAd] )
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
-#if !IS_TEST_APP
- // UnityPause needs to be called on the main thread.
- UnityPause(YES);
-#endif
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdExpandedEvent";
- }
- else
- {
- name = @"OnBannerAdExpandedEvent";
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didCollapseAd:(MAAd *)ad
-{
- MAAdFormat *adFormat = ad.format;
- if ( ![adFormat isAdViewAd] )
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
-#if !IS_TEST_APP
- extern bool _didResignActive;
- if ( _didResignActive )
- {
- // If the application is not active, we should wait until application becomes active to resume unity.
- self.resumeUnityAfterApplicationBecomesActive = YES;
- }
- else
- {
- // UnityPause needs to be called on the main thread.
- UnityPause(NO);
- }
-#endif
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdCollapsedEvent";
- }
- else
- {
- name = @"OnBannerAdCollapsedEvent";
- }
-
- NSDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didRewardUserForAd:(MAAd *)ad withReward:(MAReward *)reward
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- MAAdFormat *adFormat = ad.format;
- if ( adFormat != MAAdFormat.rewarded )
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- NSString *rewardLabel = reward ? reward.label : @"";
- NSInteger rewardAmountInt = reward ? reward.amount : 0;
- NSString *rewardAmount = [@(rewardAmountInt) stringValue];
- NSString *name = @"OnRewardedAdReceivedRewardEvent";
-
- NSMutableDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- args[@"rewardLabel"] = rewardLabel;
- args[@"rewardAmount"] = rewardAmount;
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didPayRevenueForAd:(MAAd *)ad
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- MAAdFormat *adFormat = ad.format;
- if ( MAAdFormat.banner == adFormat || MAAdFormat.leader == adFormat )
- {
- name = @"OnBannerAdRevenuePaidEvent";
- }
- else if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdRevenuePaidEvent";
- }
- else if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialAdRevenuePaidEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnAppOpenAdRevenuePaidEvent";
- }
- else if ( MAAdFormat.rewarded == adFormat )
- {
- name = @"OnRewardedAdRevenuePaidEvent";
- }
- else
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- NSMutableDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- args[@"keepInBackground"] = @([adFormat isFullscreenAd]);
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didReloadExpiredAd:(MAAd *)expiredAd withNewAd:(MAAd *)newAd;
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- MAAdFormat *adFormat = newAd.format;
- if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnExpiredInterstitialAdReloadedEvent";
- }
- else if ( MAAdFormat.appOpen == adFormat )
- {
- name = @"OnExpiredAppOpenAdReloadedEvent";
- }
- else if ( MAAdFormat.rewarded == adFormat )
- {
- name = @"OnExpiredRewardedAdReloadedEvent ";
- }
- else
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- @synchronized ( self.adInfoDictLock )
- {
- self.adInfoDict[newAd.adUnitIdentifier] = newAd;
- }
-
- NSMutableDictionary *args = [NSMutableDictionary dictionary];
- args[@"expiredAdInfo"] = [self adInfoForAd: expiredAd];
- args[@"newAdInfo"] = [self adInfoForAd: newAd];
- args[@"name"] = name;
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (void)didGenerateCreativeIdentifier:(NSString *)creativeIdentifier forAd:(MAAd *)ad
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
-
- NSString *name;
- MAAdFormat *adFormat = ad.format;
- if ( MAAdFormat.banner == adFormat || MAAdFormat.leader == adFormat )
- {
- name = @"OnBannerAdReviewCreativeIdGeneratedEvent";
- }
- else if ( MAAdFormat.mrec == adFormat )
- {
- name = @"OnMRecAdReviewCreativeIdGeneratedEvent";
- }
- else if ( MAAdFormat.interstitial == adFormat )
- {
- name = @"OnInterstitialAdReviewCreativeIdGeneratedEvent";
- }
- else if ( MAAdFormat.rewarded == adFormat )
- {
- name = @"OnRewardedAdReviewCreativeIdGeneratedEvent";
- }
- else
- {
- [self logInvalidAdFormat: adFormat];
- return;
- }
-
- NSMutableDictionary *args = [self defaultAdEventParametersForName: name withAd: ad];
- args[@"adReviewCreativeId"] = creativeIdentifier;
- args[@"keepInBackground"] = @([adFormat isFullscreenAd]);
-
- // Forward the event in background for fullscreen ads so that the user gets the callback even while the ad is playing.
- [self forwardUnityEventWithArgs: args];
- });
-}
-
-- (NSMutableDictionary *)defaultAdEventParametersForName:(NSString *)name withAd:(MAAd *)ad
-{
- NSMutableDictionary *args = [[self adInfoForAd: ad] mutableCopy];
- args[@"name"] = name;
-
- return args;
-}
-
-#pragma mark - Internal Methods
-
-- (void)createAdViewWithAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat atPosition:(NSString *)adViewPosition withOffset:(CGPoint)offset isAdaptive:(BOOL)isAdaptive
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Creating %@ with ad unit identifier \"%@\" and position: \"%@\"", adFormat, adUnitIdentifier, adViewPosition];
-
- if ( self.adViews[adUnitIdentifier] )
- {
- [self log: @"Trying to create a %@ that was already created. This will cause the current ad to be hidden.", adFormat.label];
- }
-
- // Retrieve ad view from the map
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat atPosition: adViewPosition withOffset: offset isAdaptive: isAdaptive];
- adView.hidden = YES;
- self.safeAreaBackground.hidden = YES;
-
- // Position ad view immediately so if publisher sets color before ad loads, it will not be the size of the screen
- self.adViewAdFormats[adUnitIdentifier] = adFormat;
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
-
- NSDictionary *extraParameters = self.adViewExtraParametersToSetAfterCreate[adUnitIdentifier];
-
- // Handle initial extra parameters if publisher sets it before creating ad view
- if ( extraParameters )
- {
- for ( NSString *key in extraParameters )
- {
- [adView setExtraParameterForKey: key value: extraParameters[key]];
-
- [self handleExtraParameterChangesIfNeededForAdUnitIdentifier: adUnitIdentifier
- adFormat: adFormat
- key: key
- value: extraParameters[key]];
- }
-
- [self.adViewExtraParametersToSetAfterCreate removeObjectForKey: adUnitIdentifier];
- }
-
- // Handle initial local extra parameters if publisher sets it before creating ad view
- if ( self.adViewLocalExtraParametersToSetAfterCreate[adUnitIdentifier] )
- {
- NSDictionary *localExtraParameters = self.adViewLocalExtraParametersToSetAfterCreate[adUnitIdentifier];
- for ( NSString *key in localExtraParameters )
- {
- [adView setLocalExtraParameterForKey: key value: localExtraParameters[key]];
- }
-
- [self.adViewLocalExtraParametersToSetAfterCreate removeObjectForKey: adUnitIdentifier];
- }
-
- // Handle initial custom data if publisher sets it before creating ad view
- if ( self.adViewCustomDataToSetAfterCreate[adUnitIdentifier] )
- {
- NSString *customData = self.adViewCustomDataToSetAfterCreate[adUnitIdentifier];
- adView.customData = customData;
-
- [self.adViewCustomDataToSetAfterCreate removeObjectForKey: adUnitIdentifier];
- }
-
- [adView loadAd];
-
- // Disable auto-refresh if publisher sets it before creating the ad view.
- if ( [self.disabledAutoRefreshAdViewAdUnitIdentifiers containsObject: adUnitIdentifier] )
- {
- [adView stopAutoRefresh];
- }
-
- // The publisher may have requested to show the banner before it was created. Now that the banner is created, show it.
- if ( [self.adUnitIdentifiersToShowAfterCreate containsObject: adUnitIdentifier] )
- {
- [self showAdViewWithAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- [self.adUnitIdentifiersToShowAfterCreate removeObject: adUnitIdentifier];
- }
- });
-}
-
-- (void)loadAdViewWithAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( !adView )
- {
- [self log: @"%@ does not exist for ad unit identifier \"%@\".", adFormat.label, adUnitIdentifier];
- return;
- }
-
- if ( ![self.disabledAutoRefreshAdViewAdUnitIdentifiers containsObject: adUnitIdentifier] )
- {
- if ( [adView isHidden] )
- {
- [self log: @"Auto-refresh will resume when the %@ ad is shown. You should only call LoadBanner() or LoadMRec() if you explicitly pause auto-refresh and want to manually load an ad.", adFormat.label];
- return;
- }
-
- [self log: @"You must stop auto-refresh if you want to manually load %@ ads.", adFormat.label];
- return;
- }
-
- [adView loadAd];
- });
-}
-
-- (void)setAdViewBackgroundColorForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat hexColorCode:(NSString *)hexColorCode
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Setting %@ with ad unit identifier \"%@\" to color: \"%@\"", adFormat, adUnitIdentifier, hexColorCode];
-
- // In some cases, black color may get redrawn on each frame update, resulting in an undesired flicker
- NSString *hexColorCodeToUse = [hexColorCode containsString: @"FF000000"] ? @"FF000001" : hexColorCode;
- UIColor *convertedColor = [UIColor al_colorWithHexString: hexColorCodeToUse];
-
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- self.publisherBannerBackgroundColor = convertedColor;
- self.safeAreaBackground.backgroundColor = view.backgroundColor = convertedColor;
-
- // Position adView to ensure logic that depends on background color is properly run
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- });
-}
-
-- (void)setAdViewPlacement:(nullable NSString *)placement forAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Setting placement \"%@\" for \"%@\" with ad unit identifier \"%@\"", placement, adFormat, adUnitIdentifier];
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- adView.placement = placement;
- });
-}
-
-- (void)startAdViewAutoRefreshForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Starting %@ auto refresh for ad unit identifier \"%@\"", adFormat.label, adUnitIdentifier];
-
- [self.disabledAutoRefreshAdViewAdUnitIdentifiers removeObject: adUnitIdentifier];
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( !adView )
- {
- [self log: @"%@ does not exist for ad unit identifier %@.", adFormat.label, adUnitIdentifier];
- return;
- }
-
- [adView startAutoRefresh];
- });
-}
-
-- (void)stopAdViewAutoRefreshForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Stopping %@ auto refresh for ad unit identifier \"%@\"", adFormat.label, adUnitIdentifier];
-
- [self.disabledAutoRefreshAdViewAdUnitIdentifiers addObject: adUnitIdentifier];
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( !adView )
- {
- [self log: @"%@ does not exist for ad unit identifier %@.", adFormat.label, adUnitIdentifier];
- return;
- }
-
- [adView stopAutoRefresh];
- });
-}
-
-- (void)setAdViewWidth:(CGFloat)width forAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Setting width %f for \"%@\" with ad unit identifier \"%@\"", width, adFormat, adUnitIdentifier];
-
- BOOL isBannerOrLeader = adFormat.isBannerOrLeaderAd;
-
- // Banners and leaders need to be at least 320pts wide.
- CGFloat minWidth = isBannerOrLeader ? MAAdFormat.banner.size.width : adFormat.size.width;
- if ( width < minWidth )
- {
- [self log: @"The provided width: %f is smaller than the minimum required width: %f for ad format: %@. Automatically setting width to %f.", width, minWidth, adFormat, minWidth];
- }
-
- CGFloat widthToSet = MAX( minWidth, width );
- self.adViewWidths[adUnitIdentifier] = @(widthToSet);
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- });
-}
-
-- (void)updateAdViewPosition:(NSString *)adViewPosition withOffset:(CGPoint)offset forAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- self.adViewPositions[adUnitIdentifier] = adViewPosition;
- self.adViewOffsets[adUnitIdentifier] = [NSValue valueWithCGPoint: offset];
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- });
-}
-
-- (void)setAdViewExtraParameterForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat key:(NSString *)key value:(nullable NSString *)value
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Setting %@ extra with key: \"%@\" value: \"%@\"", adFormat, key, value];
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( adView )
- {
- [adView setExtraParameterForKey: key value: value];
- }
- else
- {
- [self log: @"%@ does not exist for ad unit identifier \"%@\". Saving extra parameter to be set when it is created.", adFormat, adUnitIdentifier];
-
- // The adView has not yet been created. Store the extra parameters, so that they can be added once the banner has been created.
- NSMutableDictionary *extraParameters = self.adViewExtraParametersToSetAfterCreate[adUnitIdentifier];
- if ( !extraParameters )
- {
- extraParameters = [NSMutableDictionary dictionaryWithCapacity: 1];
- self.adViewExtraParametersToSetAfterCreate[adUnitIdentifier] = extraParameters;
- }
-
- extraParameters[key] = value;
- }
-
- // Certain extra parameters need to be handled immediately
- [self handleExtraParameterChangesIfNeededForAdUnitIdentifier: adUnitIdentifier
- adFormat: adFormat
- key: key
- value: value];
- });
-}
-
-- (void)setAdViewLocalExtraParameterForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat key:(NSString *)key value:(nullable id)value
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Setting %@ local extra with key: \"%@\" value: \"%@\"", adFormat, key, value];
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( adView )
- {
- [adView setLocalExtraParameterForKey: key value: value];
- }
- else
- {
- [self log: @"%@ does not exist for ad unit identifier \"%@\". Saving local extra parameter to be set when it is created.", adFormat, adUnitIdentifier];
-
- // The adView has not yet been created. Store the loca extra parameters, so that they can be added once the adview has been created.
- NSMutableDictionary *localExtraParameters = self.adViewLocalExtraParametersToSetAfterCreate[adUnitIdentifier];
- if ( !localExtraParameters )
- {
- localExtraParameters = [NSMutableDictionary dictionaryWithCapacity: 1];
- self.adViewLocalExtraParametersToSetAfterCreate[adUnitIdentifier] = localExtraParameters;
- }
-
- localExtraParameters[key] = value;
- }
- });
-}
-
-- (void)setAdViewCustomData:(nullable NSString *)customData forAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
-
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( adView )
- {
- adView.customData = customData;
- }
- else
- {
- [self log: @"%@ does not exist for ad unit identifier %@. Saving custom data to be set when it is created.", adFormat, adUnitIdentifier];
-
- // The adView has not yet been created. Store the custom data, so that they can be added once the AdView has been created.
- self.adViewCustomDataToSetAfterCreate[adUnitIdentifier] = customData;
- }
- });
-}
-
-- (void)handleExtraParameterChangesIfNeededForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat key:(NSString *)key value:(nullable NSString *)value
-{
- if ( MAAdFormat.mrec != adFormat )
- {
- if ( [@"force_banner" isEqualToString: key] )
- {
- BOOL shouldForceBanner = [NSNumber al_numberWithString: value].boolValue;
- MAAdFormat *forcedAdFormat = shouldForceBanner ? MAAdFormat.banner : DEVICE_SPECIFIC_ADVIEW_AD_FORMAT;
-
- self.adViewAdFormats[adUnitIdentifier] = forcedAdFormat;
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: forcedAdFormat];
- }
- else if ( [@"adaptive_banner" isEqualToString: key] )
- {
- [self log: @"Setting adaptive banners via extra parameters is deprecated and will be removed in a future plugin version. Use the CreateBanner(adUnitIdentifier, AdViewConfiguration) API to properly configure adaptive banners."];
-
- BOOL shouldUseAdaptiveBanner = [NSNumber al_numberWithString: value].boolValue;
- if ( shouldUseAdaptiveBanner )
- {
- [self.disabledAdaptiveBannerAdUnitIdentifiers removeObject: adUnitIdentifier];
- }
- else
- {
- [self.disabledAdaptiveBannerAdUnitIdentifiers addObject: adUnitIdentifier];
- }
-
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- }
- else if ( [@"ignore_safe_area_landscape" isEqualToString: key] && [NSNumber al_numberWithString: value].boolValue )
- {
- [self.ignoreSafeAreaLandscapeAdUnitIdentifiers addObject: adUnitIdentifier];
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- }
- }
-
- if ( [adFormat isAdViewAd] && [@"clips_to_bounds" isEqualToString: key] )
- {
- BOOL clipsToBounds = [NSNumber al_numberWithString: value].boolValue;
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- view.clipsToBounds = clipsToBounds;
- }
-}
-
-- (void)showAdViewWithAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Showing %@ with ad unit identifier \"%@\"", adFormat, adUnitIdentifier];
-
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( !view )
- {
- [self log: @"%@ does not exist for ad unit identifier %@.", adFormat, adUnitIdentifier];
-
- // The adView has not yet been created. Store the ad unit ID, so that it can be displayed once the banner has been created.
- [self.adUnitIdentifiersToShowAfterCreate addObject: adUnitIdentifier];
- }
- else
- {
- // Check edge case where ad may be detatched from view controller
- if ( !view.window.rootViewController )
- {
- [self log: @"%@ missing view controller - re-attaching to %@...", adFormat, [self unityViewController]];
-
- UIViewController *rootViewController = [self unityViewController];
- [rootViewController.view addSubview: view];
-
- [self positionAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- }
- }
-
- self.safeAreaBackground.hidden = NO;
- view.hidden = NO;
-
- if ( ![self.disabledAutoRefreshAdViewAdUnitIdentifiers containsObject: adUnitIdentifier] )
- {
- [view startAutoRefresh];
- }
- });
-}
-
-- (void)hideAdViewWithAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Hiding %@ with ad unit identifier \"%@\"", adFormat, adUnitIdentifier];
- [self.adUnitIdentifiersToShowAfterCreate removeObject: adUnitIdentifier];
-
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- view.hidden = YES;
- self.safeAreaBackground.hidden = YES;
-
- [view stopAutoRefresh];
- });
-}
-
-- (NSString *)adViewLayoutForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- [self log: @"Getting %@ position with ad unit identifier \"%@\"", adFormat, adUnitIdentifier];
-
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- if ( !view )
- {
- [self log: @"%@ does not exist for ad unit identifier %@", adFormat, adUnitIdentifier];
-
- return @"";
- }
-
- CGRect adViewFrame = view.frame;
- return [MAUnityAdManager serializeParameters: @{@"origin_x" : [NSString stringWithFormat: @"%f", adViewFrame.origin.x],
- @"origin_y" : [NSString stringWithFormat: @"%f", adViewFrame.origin.y],
- @"width" : [NSString stringWithFormat: @"%f", CGRectGetWidth(adViewFrame)],
- @"height" : [NSString stringWithFormat: @"%f", CGRectGetHeight(adViewFrame)]}];
-}
-
-- (void)destroyAdViewWithAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- [self log: @"Destroying %@ with ad unit identifier \"%@\"", adFormat, adUnitIdentifier];
-
- MAAdView *view = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- view.delegate = nil;
- view.revenueDelegate = nil;
- view.adReviewDelegate = nil;
-
- [view removeFromSuperview];
-
- [self.adViews removeObjectForKey: adUnitIdentifier];
- [self.adViewAdFormats removeObjectForKey: adUnitIdentifier];
- [self.adViewPositions removeObjectForKey: adUnitIdentifier];
- [self.adViewOffsets removeObjectForKey: adUnitIdentifier];
- [self.adViewWidths removeObjectForKey: adUnitIdentifier];
- [self.verticalAdViewFormats removeObjectForKey: adUnitIdentifier];
- [self.disabledAdaptiveBannerAdUnitIdentifiers removeObject: adUnitIdentifier];
- });
-}
-
-- (void)logInvalidAdFormat:(MAAdFormat *)adFormat
-{
- [self log: @"invalid ad format: %@, from %@", adFormat, [NSThread callStackSymbols]];
-}
-
-- (void)log:(NSString *)format, ...
-{
- if (max_unity_should_disable_all_logs()) return;
-
- va_list valist;
- va_start(valist, format);
- NSString *message = [[NSString alloc] initWithFormat: format arguments: valist];
- va_end(valist);
-
- NSLog(@"[%@] [%@] %@", SDK_TAG, TAG, message);
-}
-
-+ (void)log:(NSString *)format, ...
-{
- if (max_unity_should_disable_all_logs()) return;
-
- va_list valist;
- va_start(valist, format);
- NSString *message = [[NSString alloc] initWithFormat: format arguments: valist];
- va_end(valist);
-
- NSLog(@"[%@] [%@] %@", SDK_TAG, TAG, message);
-}
-
-- (MAInterstitialAd *)retrieveInterstitialForAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- MAInterstitialAd *result = self.interstitials[adUnitIdentifier];
- if ( !result )
- {
- result = [[MAInterstitialAd alloc] initWithAdUnitIdentifier: adUnitIdentifier];
- result.delegate = self;
- result.revenueDelegate = self;
- result.adReviewDelegate = self;
- result.expirationDelegate = self;
-
- self.interstitials[adUnitIdentifier] = result;
- }
-
- return result;
-}
-
-- (MAAppOpenAd *)retrieveAppOpenAdForAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- MAAppOpenAd *result = self.appOpenAds[adUnitIdentifier];
- if ( !result )
- {
- result = [[MAAppOpenAd alloc] initWithAdUnitIdentifier: adUnitIdentifier];
- result.delegate = self;
- result.revenueDelegate = self;
- result.expirationDelegate = self;
-
- self.appOpenAds[adUnitIdentifier] = result;
- }
-
- return result;
-}
-
-- (MARewardedAd *)retrieveRewardedAdForAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- MARewardedAd *result = self.rewardedAds[adUnitIdentifier];
- if ( !result )
- {
- result = [MARewardedAd sharedWithAdUnitIdentifier: adUnitIdentifier];
- result.delegate = self;
- result.revenueDelegate = self;
- result.adReviewDelegate = self;
- result.expirationDelegate = self;
-
- self.rewardedAds[adUnitIdentifier] = result;
- }
-
- return result;
-}
-
-- (MAAdView *)retrieveAdViewForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- return [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat atPosition: nil withOffset: CGPointZero isAdaptive: YES];
-}
-
-- (MAAdView *)retrieveAdViewForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat atPosition:(NSString *)adViewPosition withOffset:(CGPoint)offset isAdaptive:(BOOL)isAdaptive
-{
- MAAdView *result = self.adViews[adUnitIdentifier];
- if ( !result && adViewPosition )
- {
- MAAdViewConfiguration *config = [MAAdViewConfiguration configurationWithBuilderBlock:^(MAAdViewConfigurationBuilder *builder) {
-
- // Set adaptive type only for banner ads. If adaptive is enabled, use ANCHORED; otherwise, fall back to NONE.
- if ( [adFormat isBannerOrLeaderAd] )
- {
- if ( isAdaptive )
- {
- builder.adaptiveType = MAAdViewAdaptiveTypeAnchored;
- }
- else
- {
- builder.adaptiveType = MAAdViewAdaptiveTypeNone;
- [self.disabledAdaptiveBannerAdUnitIdentifiers addObject:adUnitIdentifier];
- }
- }
- }];
-
- // There is a Unity bug where if an empty UIView is on screen with user interaction enabled, and a user interacts with it, it just passes the events to random parts of the screen.
- result = [[MAAdView alloc] initWithAdUnitIdentifier:adUnitIdentifier adFormat:adFormat configuration:config];
- result.userInteractionEnabled = NO;
- result.translatesAutoresizingMaskIntoConstraints = NO;
- result.delegate = self;
- result.revenueDelegate = self;
- result.adReviewDelegate = self;
-
- self.adViews[adUnitIdentifier] = result;
- self.adViewPositions[adUnitIdentifier] = adViewPosition;
- self.adViewOffsets[adUnitIdentifier] = [NSValue valueWithCGPoint: offset];
-
- UIViewController *rootViewController = [self unityViewController];
- [rootViewController.view addSubview: result];
-
- // Allow pubs to pause auto-refresh immediately, by default.
- [result setExtraParameterForKey: @"allow_pause_auto_refresh_immediately" value: @"true"];
- }
-
- return result;
-}
-
-- (void)positionAdViewForAd:(MAAd *)ad
-{
- [self positionAdViewForAdUnitIdentifier: ad.adUnitIdentifier adFormat: ad.format];
-}
-
-- (void)positionAdViewForAdUnitIdentifier:(NSString *)adUnitIdentifier adFormat:(MAAdFormat *)adFormat
-{
- max_unity_dispatch_on_main_thread(^{
- MAAdView *adView = [self retrieveAdViewForAdUnitIdentifier: adUnitIdentifier adFormat: adFormat];
- NSString *adViewPosition = self.adViewPositions[adUnitIdentifier];
- NSValue *adViewPositionValue = self.adViewOffsets[adUnitIdentifier];
- CGPoint adViewOffset = [adViewPositionValue CGPointValue];
- BOOL isAdaptiveBannerDisabled = [self.disabledAdaptiveBannerAdUnitIdentifiers containsObject: adUnitIdentifier];
- BOOL isWidthPtsOverridden = self.adViewWidths[adUnitIdentifier] != nil;
-
- UIView *superview = adView.superview;
- if ( !superview ) return;
-
- // Deactivate any previous constraints and reset rotation so that the banner can be positioned again.
- NSArray *activeConstraints = self.adViewConstraints[adUnitIdentifier];
- [NSLayoutConstraint deactivateConstraints: activeConstraints];
- adView.transform = CGAffineTransformIdentity;
- [self.verticalAdViewFormats removeObjectForKey: adUnitIdentifier];
-
- // Ensure superview contains the safe area background.
- if ( ![superview.subviews containsObject: self.safeAreaBackground] )
- {
- [self.safeAreaBackground removeFromSuperview];
- [superview insertSubview: self.safeAreaBackground belowSubview: adView];
- }
-
- // Deactivate any previous constraints and reset visibility state so that the safe area background can be positioned again.
- [NSLayoutConstraint deactivateConstraints: self.safeAreaBackground.constraints];
- self.safeAreaBackground.hidden = adView.hidden;
-
- //
- // Determine ad width
- //
- CGFloat adViewWidth;
-
- // Check if publisher has overridden width as points
- if ( isWidthPtsOverridden )
- {
- adViewWidth = self.adViewWidths[adUnitIdentifier].floatValue;
- }
- // Top center / bottom center stretches full screen
- else if ( [adViewPosition isEqual: @"top_center"] || [adViewPosition isEqual: @"bottom_center"] )
- {
- adViewWidth = CGRectGetWidth(KEY_WINDOW.bounds);
- }
- // Else use standard widths of 320, 728, or 300
- else
- {
- adViewWidth = adFormat.size.width;
- }
-
- //
- // Determine ad height
- //
- CGFloat adViewHeight;
-
- if ( (adFormat == MAAdFormat.banner || adFormat == MAAdFormat.leader) && !isAdaptiveBannerDisabled )
- {
- adViewHeight = [adFormat adaptiveSizeForWidth: adViewWidth].height;
- }
- else
- {
- adViewHeight = adFormat.size.height;
- }
-
- CGSize adViewSize = CGSizeMake(adViewWidth, adViewHeight);
-
- // All positions have constant height
- NSMutableArray *constraints = [NSMutableArray arrayWithObject: [adView.heightAnchor constraintEqualToConstant: adViewSize.height]];
-
- UILayoutGuide *layoutGuide = superview.safeAreaLayoutGuide;
- BOOL shouldIgnoreSafeArea = [self shouldIgnoreSafeAreaForAdUnitIdentifier: adUnitIdentifier];
- NSLayoutAnchor *topAnchor = shouldIgnoreSafeArea ? superview.topAnchor : layoutGuide.topAnchor;
-
- if ( [adViewPosition isEqual: @"top_center"] || [adViewPosition isEqual: @"bottom_center"] )
- {
- // Non AdMob banners will still be of 50/90 points tall. Set the auto sizing mask such that the inner ad view is pinned to the bottom or top according to the ad view position.
- if ( !isAdaptiveBannerDisabled )
- {
- adView.autoresizingMask = UIViewAutoresizingFlexibleWidth;
-
- if ( [@"top_center" isEqual: adViewPosition] )
- {
- adView.autoresizingMask |= UIViewAutoresizingFlexibleBottomMargin;
- }
- else // bottom_center
- {
- adView.autoresizingMask |= UIViewAutoresizingFlexibleTopMargin;
- }
- }
-
- // If publisher actually provided a banner background color
- if ( self.publisherBannerBackgroundColor && adFormat != MAAdFormat.mrec )
- {
- if ( isWidthPtsOverridden )
- {
- [constraints addObjectsFromArray: @[[adView.widthAnchor constraintEqualToConstant: adViewWidth],
- [adView.centerXAnchor constraintEqualToAnchor: layoutGuide.centerXAnchor],
- [self.safeAreaBackground.widthAnchor constraintEqualToConstant: adViewWidth],
- [self.safeAreaBackground.centerXAnchor constraintEqualToAnchor: layoutGuide.centerXAnchor]]];
-
- if ( [adViewPosition isEqual: @"top_center"] )
- {
- [constraints addObjectsFromArray: @[[adView.topAnchor constraintEqualToAnchor: topAnchor],
- [self.safeAreaBackground.topAnchor constraintEqualToAnchor: superview.topAnchor],
- [self.safeAreaBackground.bottomAnchor constraintEqualToAnchor: adView.topAnchor]]];
- }
- else // bottom_center
- {
- [constraints addObjectsFromArray: @[[adView.bottomAnchor constraintEqualToAnchor: layoutGuide.bottomAnchor],
- [self.safeAreaBackground.topAnchor constraintEqualToAnchor: adView.bottomAnchor],
- [self.safeAreaBackground.bottomAnchor constraintEqualToAnchor: superview.bottomAnchor]]];
- }
- }
- else
- {
- [constraints addObjectsFromArray: @[[adView.leftAnchor constraintEqualToAnchor: superview.leftAnchor],
- [adView.rightAnchor constraintEqualToAnchor: superview.rightAnchor],
- [self.safeAreaBackground.leftAnchor constraintEqualToAnchor: superview.leftAnchor],
- [self.safeAreaBackground.rightAnchor constraintEqualToAnchor: superview.rightAnchor]]];
-
- if ( [adViewPosition isEqual: @"top_center"] )
- {
- [constraints addObjectsFromArray: @[[adView.topAnchor constraintEqualToAnchor: topAnchor],
- [self.safeAreaBackground.topAnchor constraintEqualToAnchor: superview.topAnchor],
- [self.safeAreaBackground.bottomAnchor constraintEqualToAnchor: adView.topAnchor]]];
- }
- else // bottom_center
- {
- [constraints addObjectsFromArray: @[[adView.bottomAnchor constraintEqualToAnchor: layoutGuide.bottomAnchor],
- [self.safeAreaBackground.topAnchor constraintEqualToAnchor: adView.bottomAnchor],
- [self.safeAreaBackground.bottomAnchor constraintEqualToAnchor: superview.bottomAnchor]]];
- }
- }
- }
- // If pub does not have a background color set or this is not a banner
- else
- {
- self.safeAreaBackground.hidden = YES;
-
- [constraints addObjectsFromArray: @[[adView.widthAnchor constraintEqualToConstant: adViewWidth],
- [adView.centerXAnchor constraintEqualToAnchor: layoutGuide.centerXAnchor]]];
-
- if ( [adViewPosition isEqual: @"top_center"] )
- {
- [constraints addObject: [adView.topAnchor constraintEqualToAnchor: topAnchor]];
- }
- else // BottomCenter
- {
- [constraints addObject: [adView.bottomAnchor constraintEqualToAnchor: layoutGuide.bottomAnchor]];
- }
- }
- }
- // Check if the publisher wants vertical banners.
- else if ( [adViewPosition isEqual: @"center_left"] || [adViewPosition isEqual: @"center_right"] )
- {
- if ( MAAdFormat.mrec == adFormat )
- {
- [constraints addObject: [adView.widthAnchor constraintEqualToConstant: adViewSize.width]];
-
- if ( [adViewPosition isEqual: @"center_left"] )
- {
- [constraints addObjectsFromArray: @[[adView.centerYAnchor constraintEqualToAnchor: layoutGuide.centerYAnchor],
- [adView.leftAnchor constraintEqualToAnchor: superview.leftAnchor]]];
-
- [constraints addObjectsFromArray: @[[self.safeAreaBackground.rightAnchor constraintEqualToAnchor: layoutGuide.leftAnchor],
- [self.safeAreaBackground.leftAnchor constraintEqualToAnchor: superview.leftAnchor]]];
- }
- else // center_right
- {
- [constraints addObjectsFromArray: @[[adView.centerYAnchor constraintEqualToAnchor: layoutGuide.centerYAnchor],
- [adView.rightAnchor constraintEqualToAnchor: superview.rightAnchor]]];
-
- [constraints addObjectsFromArray: @[[self.safeAreaBackground.leftAnchor constraintEqualToAnchor: layoutGuide.rightAnchor],
- [self.safeAreaBackground.rightAnchor constraintEqualToAnchor: superview.rightAnchor]]];
- }
- }
- else
- {
- /* Align the center of the view such that when rotated it snaps into place.
- *
- * +---+---+-------+
- * | | |
- * | | |
- * | | |
- * | | |
- * | | |
- * | | |
- * +-------------+---+-----------+--+
- * | | + | + | |
- * +-------------+---+-----------+--+
- * <+> | |
- * |+ | |
- * || | |
- * || | |
- * || | |
- * || | |
- * +|--+-----------+
- * v
- * Banner Half Height
- */
- self.safeAreaBackground.hidden = YES;
-
- adView.transform = CGAffineTransformRotate(CGAffineTransformIdentity, M_PI_2);
-
- CGFloat width;
- // If the publiser has a background color set - set the width to the height of the screen, to span the ad across the screen after it is rotated.
- if ( self.publisherBannerBackgroundColor )
- {
- if ( isWidthPtsOverridden )
- {
- width = adViewWidth;
- }
- else
- {
- width = CGRectGetHeight(KEY_WINDOW.bounds);
- }
- }
- // Otherwise - we shouldn't span the banner the width of the realm (there might be user-interactable UI on the sides)
- else
- {
- width = adViewWidth;
- }
- [constraints addObject: [adView.widthAnchor constraintEqualToConstant: width]];
-
- // Set constraints such that the center of the banner aligns with the center left or right as needed. That way, once rotated, the banner snaps into place.
- [constraints addObject: [adView.centerYAnchor constraintEqualToAnchor: superview.centerYAnchor]];
-
- // Place the center of the banner half the height of the banner away from the side. If we align the center exactly with the left/right anchor, only half the banner will be visible.
- CGFloat bannerHalfHeight = adViewSize.height / 2.0;
- UIInterfaceOrientation orientation = [UIApplication sharedApplication].statusBarOrientation;
- if ( [adViewPosition isEqual: @"center_left"] )
- {
- NSLayoutAnchor *anchor = ( orientation == UIInterfaceOrientationLandscapeRight ) ? layoutGuide.leftAnchor : superview.leftAnchor;
- [constraints addObject: [adView.centerXAnchor constraintEqualToAnchor: anchor constant: bannerHalfHeight]];
- }
- else // CenterRight
- {
- NSLayoutAnchor *anchor = ( orientation == UIInterfaceOrientationLandscapeLeft ) ? layoutGuide.rightAnchor : superview.rightAnchor;
- [constraints addObject: [adView.centerXAnchor constraintEqualToAnchor: anchor constant: -bannerHalfHeight]];
- }
-
- // Store the ad view with format, so that it can be updated when the orientation changes.
- self.verticalAdViewFormats[adUnitIdentifier] = adFormat;
-
- // If adaptive - make top flexible since we anchor with the bottom of the banner at the edge of the screen
- if ( !isAdaptiveBannerDisabled )
- {
- adView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleTopMargin;
- }
- }
- }
- // Otherwise, publisher will likely construct his own views around the adview
- else
- {
- self.safeAreaBackground.hidden = YES;
-
- [constraints addObject: [adView.widthAnchor constraintEqualToConstant: adViewWidth]];
-
- if ( [adViewPosition isEqual: @"top_left"] )
- {
- [constraints addObjectsFromArray: @[[adView.leftAnchor constraintEqualToAnchor: superview.leftAnchor constant: adViewOffset.x],
- [adView.topAnchor constraintEqualToAnchor: topAnchor constant: adViewOffset.y]]];
- }
- else if ( [adViewPosition isEqual: @"top_right"] )
- {
- [constraints addObjectsFromArray: @[[adView.topAnchor constraintEqualToAnchor: topAnchor],
- [adView.rightAnchor constraintEqualToAnchor: superview.rightAnchor]]];
- }
- else if ( [adViewPosition isEqual: @"centered"] )
- {
- [constraints addObjectsFromArray: @[[adView.centerXAnchor constraintEqualToAnchor: layoutGuide.centerXAnchor],
- [adView.centerYAnchor constraintEqualToAnchor: layoutGuide.centerYAnchor]]];
- }
- else if ( [adViewPosition isEqual: @"bottom_left"] )
- {
- [constraints addObjectsFromArray: @[[adView.bottomAnchor constraintEqualToAnchor: layoutGuide.bottomAnchor],
- [adView.leftAnchor constraintEqualToAnchor: superview.leftAnchor]]];
- }
- else if ( [adViewPosition isEqual: @"bottom_right"] )
- {
- [constraints addObjectsFromArray: @[[adView.bottomAnchor constraintEqualToAnchor: layoutGuide.bottomAnchor],
- [adView.rightAnchor constraintEqualToAnchor: superview.rightAnchor]]];
- }
- }
-
- self.adViewConstraints[adUnitIdentifier] = constraints;
-
- [NSLayoutConstraint activateConstraints: constraints];
- });
-}
-
-- (UIViewController *)unityViewController
-{
- // Handle edge case where `UnityGetGLViewController()` returns nil
- return UnityGetGLViewController() ?: UnityGetMainWindow().rootViewController ?: [KEY_WINDOW rootViewController];
-}
-
-- (void)forwardUnityEventWithArgs:(NSDictionary *)args
-{
-#if !IS_TEST_APP
- extern bool _didResignActive;
- // We should not call any script callbacks when application is not active. Suspend the callback queue if resign is active.
- // We'll resume the queue once the application becomes active again.
- self.backgroundCallbackEventsQueue.suspended = _didResignActive;
-#endif
-
- [self.backgroundCallbackEventsQueue addOperationWithBlock:^{
- NSString *serializedParameters = [MAUnityAdManager serializeParameters: args];
- backgroundCallback(serializedParameters.UTF8String);
- }];
-}
-
-+ (NSString *)serializeParameters:(NSDictionary *)dict
-{
- NSData *jsonData = [NSJSONSerialization dataWithJSONObject: dict options: 0 error: nil];
- return [[NSString alloc] initWithData: jsonData encoding: NSUTF8StringEncoding];
-}
-
-+ (NSDictionary *)deserializeParameters:(nullable NSString *)serialized
-{
- if ( serialized.length > 0 )
- {
- NSError *error;
- NSDictionary *deserialized = [NSJSONSerialization JSONObjectWithData: [serialized dataUsingEncoding:NSUTF8StringEncoding]
- options: 0
- error: &error];
- if ( error )
- {
- [self log: @"Failed to deserialize (%@) with error %@", serialized, error];
- return @{};
- }
-
- return deserialized;
- }
- else
- {
- return @{};
- }
-}
-
-- (MAAdFormat *)adViewAdFormatForAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- if ( self.adViewAdFormats[adUnitIdentifier] )
- {
- return self.adViewAdFormats[adUnitIdentifier];
- }
- else
- {
- return DEVICE_SPECIFIC_ADVIEW_AD_FORMAT;
- }
-}
-
-- (NSString *)requestLatencyMillisFromRequestLatency:(NSTimeInterval)requestLatency
-{
- // Convert latency from seconds to milliseconds to match Android.
- long requestLatencyMillis = requestLatency * 1000;
- return @(requestLatencyMillis).stringValue;
-}
-
-#pragma mark - User Service
-
-- (void)didDismissUserConsentDialog
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
- [self forwardUnityEventWithArgs: @{@"name" : @"OnSdkConsentDialogDismissedEvent"}];
- });
-}
-
-#pragma mark - CMP Service
-
-- (void)showCMPForExistingUser
-{
- [self.sdk.cmpService showCMPForExistingUserWithCompletion:^(ALCMPError * _Nullable error) {
-
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
- NSMutableDictionary *args = [NSMutableDictionary dictionaryWithCapacity: 2];
- args[@"name"] = @"OnCmpCompletedEvent";
-
- if ( error )
- {
- args[@"error"] = @{@"code": @(error.code),
- @"message": error.message,
- @"cmpCode": @(error.cmpCode),
- @"cmpMessage": error.cmpMessage,
- @"keepInBackground": @(YES)};
- }
-
- [self forwardUnityEventWithArgs: args];
- });
- }];
-}
-
-#pragma mark - Application
-
-- (void)applicationPaused:(NSNotification *)notification
-{
- [self notifyApplicationStateChangedEventForPauseState: YES];
-}
-
-- (void)applicationResumed:(NSNotification *)notification
-{
- [self notifyApplicationStateChangedEventForPauseState: NO];
-}
-
-- (void)notifyApplicationStateChangedEventForPauseState:(BOOL)isPaused
-{
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
- [self forwardUnityEventWithArgs: @{@"name": @"OnApplicationStateChanged",
- @"isPaused": @(isPaused)}];
- });
-}
-
-- (MAAd *)adWithAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- @synchronized ( self.adInfoDictLock )
- {
- return self.adInfoDict[adUnitIdentifier];
- }
-}
-
-#pragma mark - Helper
-
-- (BOOL)shouldIgnoreSafeAreaForAdUnitIdentifier:(NSString *)adUnitIdentifier
-{
- if ( ![self.ignoreSafeAreaLandscapeAdUnitIdentifiers containsObject: adUnitIdentifier] ) return NO;
-
- // We should use the superview instead of layout guide if the application's orientation is landscape and the extra parameter is set
- UIInterfaceOrientation orientation = [UIApplication sharedApplication].statusBarOrientation;
- return orientation == UIInterfaceOrientationLandscapeRight || orientation == UIInterfaceOrientationLandscapeLeft;
-}
-
-@end
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m.meta b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m.meta
deleted file mode 100644
index 8c3581e8..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m.meta
+++ /dev/null
@@ -1,109 +0,0 @@
-fileFormatVersion: 2
-guid: 2973e70bd2fa74984b35aea07ae9db52
-labels:
-- al_max
-- al_max_export_path-MaxSdk/AppLovin/Plugins/iOS/MAUnityAdManager.m
-PluginImporter:
- externalObjects: {}
- serializedVersion: 2
- iconMap: {}
- executionOrder: {}
- defineConstraints: []
- isPreloaded: 0
- isOverridable: 0
- isExplicitlyReferenced: 0
- validateReferences: 1
- platformData:
- - first:
- '': Any
- second:
- enabled: 0
- settings:
- Exclude Android: 1
- Exclude Editor: 1
- Exclude Linux: 1
- Exclude Linux64: 1
- Exclude LinuxUniversal: 1
- Exclude OSXUniversal: 1
- Exclude Win: 1
- Exclude Win64: 1
- Exclude iOS: 0
- Exclude tvOS: 1
- - first:
- Android: Android
- second:
- enabled: 0
- settings:
- CPU: ARMv7
- - first:
- Any:
- second:
- enabled: 0
- settings: {}
- - first:
- Editor: Editor
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- DefaultValueInitialized: true
- OS: AnyOS
- - first:
- Facebook: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Facebook: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Linux
- second:
- enabled: 0
- settings:
- CPU: x86
- - first:
- Standalone: Linux64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: OSXUniversal
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- iPhone: iOS
- second:
- enabled: 1
- settings:
- CompileFlags:
- FrameworkDependencies:
- - first:
- tvOS: tvOS
- second:
- enabled: 0
- settings:
- CompileFlags:
- FrameworkDependencies:
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm
deleted file mode 100644
index b717fae0..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm
+++ /dev/null
@@ -1,1081 +0,0 @@
-//
-// MAUnityPlugin.mm
-// AppLovin MAX Unity Plugin
-//
-
-#pragma clang diagnostic push
-#pragma clang diagnostic ignored "-Wdeprecated-declarations"
-
-#import "MAUnityAdManager.h"
-
-#define VERSION @"8.6.2"
-#define NSSTRING(_X) ( (_X != NULL) ? [NSString stringWithCString: _X encoding: NSStringEncodingConversionAllowLossy].al_stringByTrimmingWhitespace : nil)
-
-@interface NSString (ALUtils)
-@property (nonatomic, copy, readonly) NSString *al_stringByTrimmingWhitespace;
-@property (assign, readonly, getter=al_isValidString) BOOL al_validString;
-- (BOOL)al_isEqualToStringIgnoringCase:(nullable NSString *)otherString;
-@end
-
-@interface ALSdkInitializationConfigurationBuilder (ALUtils)
-- (void)setSdkKey:(NSString *)sdkKey;
-@end
-
-// When native code plugin is implemented in .mm / .cpp file, then functions
-// should be surrounded with extern "C" block to conform C function naming rules
-extern "C"
-{
- static NSString *const TAG = @"MAUnityPlugin";
- static NSString *const KeySdkKey = @"SdkKey";
-
- UIView* UnityGetGLView();
-
- static ALSdkInitializationConfigurationBuilder *_initConfigurationBuilder;
- static ALSdk *_sdk;
- static MAUnityAdManager *_adManager;
-
- static bool _isSdkInitialized = false;
- static bool _initializeSdkCalled = false;
- static bool _disableAllLogs = false;
-
- // Helper method to create C string copy
- static const char * cStringCopy(NSString *string);
- // Helper method to log errors
- void max_unity_log_uninitialized_access_error(const char *callingMethod);
- void max_unity_log_error(NSString *message);
-
- ALSdk *getSdk()
- {
- if ( !_sdk )
- {
- _sdk = [ALSdk shared];
- }
-
- return _sdk;
- }
-
- MAUnityAdManager *getAdManager()
- {
- if ( !_adManager )
- {
- _adManager = [MAUnityAdManager shared];
- }
-
- return _adManager;
- }
-
- ALSdkInitializationConfigurationBuilder *getInitConfigurationBuilder()
- {
- if ( !_initConfigurationBuilder )
- {
- NSString *sdkKey = [getSdk().settings.extraParameters al_stringForKey: KeySdkKey];
- _initConfigurationBuilder = [ALSdkInitializationConfiguration builderWithSdkKey: sdkKey];
- }
-
- return _initConfigurationBuilder;
- }
-
- bool max_unity_should_disable_all_logs()
- {
- return _disableAllLogs;
- }
-
- int getConsentStatusValue(NSNumber *consentStatus)
- {
- if ( consentStatus )
- {
- return consentStatus.intValue;
- }
- else
- {
- return -1;
- }
- }
-
- id getLocalExtraParameterValue(const char *json)
- {
- NSData *jsonData = [NSSTRING(json) dataUsingEncoding: NSUTF8StringEncoding];
- NSError *error;
- NSDictionary *jsonDict = [NSJSONSerialization JSONObjectWithData: jsonData
- options: 0
- error: &error];
-
- if ( error )
- {
- return nil;
- }
- else
- {
- return jsonDict[@"value"];
- }
- }
-
- NSArray * toStringArray(char **arrayPointer, int size)
- {
- NSMutableArray *array = [NSMutableArray arrayWithCapacity: size];
- for ( int i = 0; i < size; i++ )
- {
- NSString *element = NSSTRING(arrayPointer[i]);
- if ( element )
- {
- [array addObject: element];
- }
- }
-
- return array;
- }
-
- MASegmentCollection *getSegmentCollection(const char *collectionJson)
- {
- MASegmentCollectionBuilder *segmentCollectionBuilder = [MASegmentCollection builder];
-
- NSDictionary *jsonDict = [MAUnityAdManager deserializeParameters: [NSString stringWithUTF8String: collectionJson]];
-
- NSArray *segmentsArray = jsonDict[@"segments"];
- for (NSDictionary *segmentDict in segmentsArray)
- {
- NSNumber *key = segmentDict[@"key"];
- NSArray *valuesArray = segmentDict[@"values"];
- NSMutableArray *values = [NSMutableArray array];
- for (NSNumber *value in valuesArray)
- {
- [values addObject:value];
- }
-
- MASegment *segment = [[MASegment alloc] initWithKey:key values:values];
- [segmentCollectionBuilder addSegment:segment];
- }
-
- return [segmentCollectionBuilder build];
- }
-
- void _MaxSetBackgroundCallback(ALUnityBackgroundCallback backgroundCallback)
- {
- [MAUnityAdManager setUnityBackgroundCallback: backgroundCallback];
- }
-
- void _MaxSetSdkKey(const char *sdkKey)
- {
- if (!sdkKey) return;
-
- NSString *sdkKeyStr = [NSString stringWithUTF8String: sdkKey];
- [getInitConfigurationBuilder() setSdkKey: sdkKeyStr];
- }
-
- void _MaxInitializeSdk(const char *serializedAdUnitIdentifiers, const char *serializedMetaData)
- {
- ALSdkInitializationConfigurationBuilder *initConfigurationBuilder = getInitConfigurationBuilder();
- initConfigurationBuilder.mediationProvider = @"max";
- initConfigurationBuilder.pluginVersion = [@"Max-Unity-" stringByAppendingString: VERSION];
- initConfigurationBuilder.adUnitIdentifiers = [[NSString stringWithUTF8String: serializedAdUnitIdentifiers] componentsSeparatedByString: @","];
-
- [getSdk().settings setExtraParameterForKey: @"applovin_unity_metadata" value: NSSTRING(serializedMetaData)];
-
- ALSdkInitializationConfiguration *initConfig = [initConfigurationBuilder build];
-
- [getAdManager() initializeSdkWithConfiguration: initConfig andCompletionHandler:^(ALSdkConfiguration *configuration) {
- _isSdkInitialized = true;
- }];
-
- _initializeSdkCalled = true;
- }
-
- bool _MaxIsInitialized()
- {
- return _isSdkInitialized;
- }
-
- const char * _MaxGetAvailableMediatedNetworks()
- {
- NSArray *availableMediatedNetworks = [getSdk() availableMediatedNetworks];
-
- // Create array of serialized network strings
- NSMutableArray *> *serializedNetworks = [NSMutableArray arrayWithCapacity: availableMediatedNetworks.count];
- for ( MAMediatedNetworkInfo *mediatedNetwork in availableMediatedNetworks )
- {
- NSDictionary *mediatedNetworkDictionary = @{@"name" : mediatedNetwork.name,
- @"adapterClassName" : mediatedNetwork.adapterClassName,
- @"adapterVersion" : mediatedNetwork.adapterVersion,
- @"sdkVersion" : mediatedNetwork.sdkVersion,
- @"initializationStatus" : @(mediatedNetwork.initializationStatus)};
- [serializedNetworks addObject: mediatedNetworkDictionary];
- }
-
- NSData *jsonData = [NSJSONSerialization dataWithJSONObject: serializedNetworks options: 0 error: nil];
- return cStringCopy([[NSString alloc] initWithData: jsonData encoding: NSUTF8StringEncoding]);
- }
-
- void _MaxShowMediationDebugger()
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_error(@"Failed to show mediation debugger - please ensure the AppLovin MAX Unity Plugin has been initialized by calling 'MaxSdk.InitializeSdk();'!");
- return;
- }
-
- [getSdk() showMediationDebugger];
- }
-
- void _MaxShowCreativeDebugger()
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_error(@"Failed to show creative debugger - please ensure the AppLovin MAX Unity Plugin has been initialized by calling 'MaxSdk.InitializeSdk();'!");
- return;
- }
-
- [getSdk() showCreativeDebugger];
- }
-
- void _MaxSetUserId(const char *userId)
- {
- getSdk().settings.userIdentifier = NSSTRING(userId);
- }
-
- void _MaxSetSegmentCollection(const char *collectionJson)
- {
- if ( _initializeSdkCalled )
- {
- max_unity_log_error(@"Segment collection must be set before MAX SDK is initialized");
- return;
- }
-
- getInitConfigurationBuilder().segmentCollection = getSegmentCollection(collectionJson);
- }
-
- const char * _MaxGetSdkConfiguration()
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxGetSdkConfiguration");
- return cStringCopy(@"");
- }
-
- NSString *consentFlowUserGeographyStr = @(getSdk().configuration.consentFlowUserGeography).stringValue;
- NSString *consentDialogStateStr = @(getSdk().configuration.consentDialogState).stringValue;
- NSString *appTrackingStatus = @(getSdk().configuration.appTrackingTransparencyStatus).stringValue; // Deliberately name it `appTrackingStatus` to be a bit more generic (in case Android introduces a similar concept)
-
- return cStringCopy([MAUnityAdManager serializeParameters: @{@"consentFlowUserGeography" : consentFlowUserGeographyStr,
- @"consentDialogState" : consentDialogStateStr,
- @"countryCode" : getSdk().configuration.countryCode,
- @"appTrackingStatus" : appTrackingStatus,
- @"isSuccessfullyInitialized" : @([getSdk() isInitialized]),
- @"isTestModeEnabled" : @([getSdk().configuration isTestModeEnabled])}]);
- }
-
- void _MaxSetHasUserConsent(bool hasUserConsent)
- {
- [ALPrivacySettings setHasUserConsent: hasUserConsent];
- }
-
- bool _MaxHasUserConsent()
- {
- return [ALPrivacySettings hasUserConsent];
- }
-
- bool _MaxIsUserConsentSet()
- {
- return [ALPrivacySettings isUserConsentSet];
- }
-
- void _MaxSetDoNotSell(bool doNotSell)
- {
- [ALPrivacySettings setDoNotSell: doNotSell];
- }
-
- bool _MaxIsDoNotSell()
- {
- return [ALPrivacySettings isDoNotSell];
- }
-
- bool _MaxIsDoNotSellSet()
- {
- return [ALPrivacySettings isDoNotSellSet];
- }
-
- void _MaxCreateBanner(const char *adUnitIdentifier, const char *bannerPosition, bool isAdaptive)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxCreateBanner");
- return;
- }
-
- [getAdManager() createBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) atPosition: NSSTRING(bannerPosition) isAdaptive: isAdaptive];
- }
-
- void _MaxCreateBannerXY(const char *adUnitIdentifier, const float x, const float y, bool isAdaptive)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxCreateBannerXY");
- return;
- }
-
- [getAdManager() createBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) x: x y: y isAdaptive: isAdaptive];
- }
-
- void _MaxLoadBanner(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxLoadBanner");
- return;
- }
-
- [getAdManager() loadBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetBannerBackgroundColor(const char *adUnitIdentifier, const char *hexColorCode)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerBackgroundColor");
- return;
- }
-
- [getAdManager() setBannerBackgroundColorForAdUnitIdentifier: NSSTRING(adUnitIdentifier) hexColorCode: NSSTRING(hexColorCode)];
- }
-
- void _MaxSetBannerPlacement(const char *adUnitIdentifier, const char *placement)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerPlacement");
- return;
- }
-
- [getAdManager() setBannerPlacement: NSSTRING(placement) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxStartBannerAutoRefresh(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxStartBannerAutoRefresh");
- return;
- }
-
- [getAdManager() startBannerAutoRefreshForAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxStopBannerAutoRefresh(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxStopBannerAutoRefresh");
- return;
- }
-
- [getAdManager() stopBannerAutoRefreshForAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetBannerExtraParameter(const char *adUnitIdentifier, const char *key, const char *value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerExtraParameter");
- return;
- }
-
- [getAdManager() setBannerExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: NSSTRING(value)];
- }
-
- void _MaxSetBannerLocalExtraParameter(const char *adUnitIdentifier, const char *key, MAUnityRef value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerLocalExtraParameter");
- return;
- }
-
- [getAdManager() setBannerLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: (__bridge id) value];
- }
-
- void _MaxSetBannerLocalExtraParameterJSON(const char *adUnitIdentifier, const char *key, const char *json)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerLocalExtraParameter");
- return;
- }
-
- id value = getLocalExtraParameterValue(json);
- [getAdManager() setBannerLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: value];
- }
-
- void _MaxSetBannerCustomData(const char *adUnitIdentifier, const char *customData)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerCustomData");
- return;
- }
-
- [getAdManager() setBannerCustomData: NSSTRING(customData) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetBannerWidth(const char *adUnitIdentifier, const float width)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetBannerWidth");
- return;
- }
-
- [getAdManager() setBannerWidth: width forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxUpdateBannerPosition(const char *adUnitIdentifier, const char *bannerPosition)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxUpdateBannerPosition");
- return;
- }
-
- [getAdManager() updateBannerPosition: NSSTRING(bannerPosition) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxUpdateBannerPositionXY(const char *adUnitIdentifier, const float x, const float y)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxUpdateBannerPositionXY");
- return;
- }
-
- [getAdManager() updateBannerPosition: x y: y forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxShowBanner(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowBanner");
- return;
- }
-
- [getAdManager() showBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxDestroyBanner(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxDestroyBanner");
- return;
- }
-
- [getAdManager() destroyBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxHideBanner(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxHideBanner");
- return;
- }
-
- [getAdManager() hideBannerWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- const char * _MaxGetBannerLayout(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxGetBannerLayout");
- return cStringCopy(@"");
- }
-
- return cStringCopy([getAdManager() bannerLayoutForAdUnitIdentifier: NSSTRING(adUnitIdentifier)]);
- }
-
- void _MaxCreateMRec(const char *adUnitIdentifier, const char *mrecPosition)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxCreateMRec");
- return;
- }
-
- [getAdManager() createMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) atPosition: NSSTRING(mrecPosition)];
- }
-
- void _MaxCreateMRecXY(const char *adUnitIdentifier, const float x, const float y)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxCreateMRecXY");
- return;
- }
-
- [getAdManager() createMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) x: x y: y];
- }
-
- void _MaxLoadMRec(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxLoadMRec");
- return;
- }
-
- [getAdManager() loadMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetMRecPlacement(const char *adUnitIdentifier, const char *placement)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetMRecPlacement");
- return;
- }
-
- [getAdManager() setMRecPlacement: NSSTRING(placement) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxStartMRecAutoRefresh(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxStartMRecAutoRefresh");
- return;
- }
-
- [getAdManager() startMRecAutoRefreshForAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxStopMRecAutoRefresh(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxStopMRecAutoRefresh");
- return;
- }
-
- [getAdManager() stopMRecAutoRefreshForAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxUpdateMRecPosition(const char *adUnitIdentifier, const char *mrecPosition)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxUpdateMRecPosition");
- return;
- }
-
- [getAdManager() updateMRecPosition: NSSTRING(mrecPosition) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxUpdateMRecPositionXY(const char *adUnitIdentifier, const float x, const float y)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxUpdateMRecPositionXY");
- return;
- }
-
- [getAdManager() updateMRecPosition: x y: y forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxShowMRec(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowMRec");
- return;
- }
-
- [getAdManager() showMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxDestroyMRec(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxDestroyMRec");
- return;
- }
-
- [getAdManager() destroyMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxHideMRec(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxHideMRec");
- return;
- }
-
- [getAdManager() hideMRecWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetMRecExtraParameter(const char *adUnitIdentifier, const char *key, const char *value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetMRecExtraParameter");
- return;
- }
-
- [getAdManager() setMRecExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: NSSTRING(value)];
- }
-
- void _MaxSetMRecLocalExtraParameter(const char *adUnitIdentifier, const char *key, MAUnityRef value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetMRecLocalExtraParameter");
- return;
- }
-
- [getAdManager() setMRecLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: (__bridge id)value];
- }
-
- void _MaxSetMRecLocalExtraParameterJSON(const char *adUnitIdentifier, const char *key, const char *json)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetMRecLocalExtraParameter");
- return;
- }
-
- id value = getLocalExtraParameterValue(json);
- [getAdManager() setMRecLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: value];
- }
-
- void _MaxSetMRecCustomData(const char *adUnitIdentifier, const char *customData)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetMRecCustomData");
- return;
- }
-
- [getAdManager() setMRecCustomData: NSSTRING(customData) forAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- const char * _MaxGetMRecLayout(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxGetMRecLayout");
- return cStringCopy(@"");
- }
-
- return cStringCopy([getAdManager() mrecLayoutForAdUnitIdentifier: NSSTRING(adUnitIdentifier)]);
- }
-
- void _MaxLoadInterstitial(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxLoadInterstitial");
- return;
- }
-
- [getAdManager() loadInterstitialWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetInterstitialExtraParameter(const char *adUnitIdentifier, const char *key, const char *value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetInterstitialExtraParameter");
- return;
- }
-
- [getAdManager() setInterstitialExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: NSSTRING(value)];
- }
-
- void _MaxSetInterstitialLocalExtraParameter(const char *adUnitIdentifier, const char *key, MAUnityRef value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetInterstitialLocalExtraParameter");
- return;
- }
-
- [getAdManager() setInterstitialLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: (__bridge id)value];
- }
-
- void _MaxSetInterstitialLocalExtraParameterJSON(const char *adUnitIdentifier, const char *key, const char *json)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetInterstitialLocalExtraParameter");
- return;
- }
-
- id value = getLocalExtraParameterValue(json);
- [getAdManager() setInterstitialLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: value];
- }
-
- bool _MaxIsInterstitialReady(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxIsInterstitialReady");
- return false;
- }
-
- return [getAdManager() isInterstitialReadyWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxShowInterstitial(const char *adUnitIdentifier, const char *placement, const char *customData)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowInterstitial");
- return;
- }
-
- [getAdManager() showInterstitialWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) placement: NSSTRING(placement) customData: NSSTRING(customData)];
- }
-
- void _MaxLoadAppOpenAd(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxLoadAppOpenAd");
- return;
- }
-
- [getAdManager() loadAppOpenAdWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetAppOpenAdExtraParameter(const char *adUnitIdentifier, const char *key, const char *value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetAppOpenAdExtraParameter");
- return;
- }
-
- [getAdManager() setAppOpenAdExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: NSSTRING(value)];
- }
-
- void _MaxSetAppOpenAdLocalExtraParameter(const char *adUnitIdentifier, const char *key, MAUnityRef value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetAppOpenAdLocalExtraParameter");
- return;
- }
-
- [getAdManager() setAppOpenAdLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: (__bridge id)value];
- }
-
- void _MaxSetAppOpenAdLocalExtraParameterJSON(const char *adUnitIdentifier, const char *key, const char *json)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetAppOpenAdLocalExtraParameter");
- return;
- }
-
- id value = getLocalExtraParameterValue(json);
- [getAdManager() setAppOpenAdLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: value];
- }
-
- bool _MaxIsAppOpenAdReady(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxIsAppOpenAdReady");
- return false;
- }
-
- return [getAdManager() isAppOpenAdReadyWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxShowAppOpenAd(const char *adUnitIdentifier, const char *placement, const char *customData)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowAppOpenAd");
- return;
- }
-
- [getAdManager() showAppOpenAdWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) placement: NSSTRING(placement) customData: NSSTRING(customData)];
- }
-
- void _MaxLoadRewardedAd(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxLoadRewardedAd");
- return;
- }
-
- [getAdManager() loadRewardedAdWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxSetRewardedAdExtraParameter(const char *adUnitIdentifier, const char *key, const char *value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetRewardedAdExtraParameter");
- return;
- }
-
- [getAdManager() setRewardedAdExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: NSSTRING(value)];
- }
-
- void _MaxSetRewardedAdLocalExtraParameter(const char *adUnitIdentifier, const char *key, MAUnityRef value)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetRewardedAdLocalExtraParameter");
- return;
- }
-
- [getAdManager() setRewardedAdLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: (__bridge id)value];
- }
-
- void _MaxSetRewardedAdLocalExtraParameterJSON(const char *adUnitIdentifier, const char *key, const char *json)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxSetRewardedAdLocalExtraParameter");
- return;
- }
-
- id value = getLocalExtraParameterValue(json);
- [getAdManager() setRewardedAdLocalExtraParameterForAdUnitIdentifier: NSSTRING(adUnitIdentifier)
- key: NSSTRING(key)
- value: value];
- }
-
- bool _MaxIsRewardedAdReady(const char *adUnitIdentifier)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxIsRewardedAdReady");
- return false;
- }
-
- return [getAdManager() isRewardedAdReadyWithAdUnitIdentifier: NSSTRING(adUnitIdentifier)];
- }
-
- void _MaxShowRewardedAd(const char *adUnitIdentifier, const char *placement, const char *customData)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowRewardedAd");
- return;
- }
-
- [getAdManager() showRewardedAdWithAdUnitIdentifier: NSSTRING(adUnitIdentifier) placement: NSSTRING(placement) customData: NSSTRING(customData)];
- }
-
- void _MaxTrackEvent(const char *event, const char *parameters)
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxTrackEvent");
- return;
- }
-
- [getAdManager() trackEvent: NSSTRING(event) parameters: NSSTRING(parameters)];
- }
-
- bool _MaxIsTablet()
- {
- return [UIDevice currentDevice].userInterfaceIdiom == UIUserInterfaceIdiomPad;
- }
-
- bool _MaxIsPhysicalDevice()
- {
- return !ALUtils.simulator;
- }
-
- int _MaxGetTcfVendorConsentStatus(int vendorIdentifier)
- {
- NSNumber *consentStatus = [ALPrivacySettings tcfVendorConsentStatusForIdentifier: vendorIdentifier];
- return getConsentStatusValue(consentStatus);
- }
-
- int _MaxGetAdditionalConsentStatus(int atpIdentifier)
- {
- NSNumber *consentStatus = [ALPrivacySettings additionalConsentStatusForIdentifier: atpIdentifier];
- return getConsentStatusValue(consentStatus);
- }
-
- int _MaxGetPurposeConsentStatus(int purposeIdentifier)
- {
- NSNumber *consentStatus = [ALPrivacySettings purposeConsentStatusForIdentifier: purposeIdentifier];
- return getConsentStatusValue(consentStatus);
- }
-
- int _MaxGetSpecialFeatureOptInStatus(int specialFeatureIdentifier)
- {
- NSNumber *consentStatus = [ALPrivacySettings specialFeatureOptInStatusForIdentifier: specialFeatureIdentifier];
- return getConsentStatusValue(consentStatus);
- }
-
- static const char * cStringCopy(NSString *string)
- {
- const char *value = string.UTF8String;
- return value ? strdup(value) : NULL;
- }
-
- void _MaxSetMuted(bool muted)
- {
- getSdk().settings.muted = muted;
- }
-
- bool _MaxIsMuted()
- {
- return getSdk().settings.muted;
- }
-
- float _MaxScreenDensity()
- {
- return [UIScreen.mainScreen nativeScale];
- }
-
- const char * _MaxGetAdValue(const char *adUnitIdentifier, const char *key)
- {
- return cStringCopy([getAdManager() adValueForAdUnitIdentifier: NSSTRING(adUnitIdentifier) withKey: NSSTRING(key)]);
- }
-
- void _MaxSetVerboseLogging(bool enabled)
- {
- getSdk().settings.verboseLoggingEnabled = enabled;
- }
-
- bool _MaxIsVerboseLoggingEnabled()
- {
- return [getSdk().settings isVerboseLoggingEnabled];
- }
-
- void _MaxSetTestDeviceAdvertisingIdentifiers(char **advertisingIdentifiers, int size)
- {
- if ( _initializeSdkCalled )
- {
- max_unity_log_error(@"Test device advertising IDs must be set before MAX SDK is initialized");
- return;
- }
-
- NSArray *advertisingIdentifiersArray = toStringArray(advertisingIdentifiers, size);
- getInitConfigurationBuilder().testDeviceAdvertisingIdentifiers = advertisingIdentifiersArray;
- }
-
- void _MaxSetCreativeDebuggerEnabled(bool enabled)
- {
- getSdk().settings.creativeDebuggerEnabled = enabled;
- }
-
- void _MaxSetExceptionHandlerEnabled(bool enabled)
- {
- if ( _initializeSdkCalled )
- {
- max_unity_log_error(@"Exception handler must be enabled/disabled before MAX SDK is initialized");
- return;
- }
-
- getInitConfigurationBuilder().exceptionHandlerEnabled = enabled;
- }
-
- void _MaxSetExtraParameter(const char *key, const char *value)
- {
- NSString *stringKey = NSSTRING(key);
- if ( ![stringKey al_isValidString] )
- {
- NSString *message = [NSString stringWithFormat:@"Failed to set extra parameter for nil or empty key: %@", stringKey];
- max_unity_log_error(message);
- return;
- }
-
- NSString *stringValue = NSSTRING(value);
- if ( [@"disable_all_logs" isEqualToString: stringKey] )
- {
- _disableAllLogs = [@"true" al_isEqualToStringIgnoringCase: stringValue];
- }
-
- ALSdkSettings *settings = getSdk().settings;
- [settings setExtraParameterForKey: stringKey value: stringValue];
- }
-
- int * _MaxGetSafeAreaInsets()
- {
- UIEdgeInsets safeAreaInsets = UnityGetGLView().safeAreaInsets;
- static int insets[4] = {(int) safeAreaInsets.left, (int) safeAreaInsets.top, (int) safeAreaInsets.right, (int) safeAreaInsets.bottom};
- return insets;
- }
-
- void _MaxShowCmpForExistingUser()
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxShowCmpForExistingUser");
- return;
- }
-
- [getAdManager() showCMPForExistingUser];
- }
-
- bool _MaxHasSupportedCmp()
- {
- if ( !_initializeSdkCalled )
- {
- max_unity_log_uninitialized_access_error("_MaxHasSupportedCmp");
- return false;
- }
-
- return [getSdk().cmpService hasSupportedCMP];
- }
-
- float _MaxGetAdaptiveBannerHeight(const float width)
- {
- return [MAUnityAdManager adaptiveBannerHeightForWidth: width];
- }
-
- void max_unity_log_uninitialized_access_error(const char *callingMethod)
- {
- NSString *message = [NSString stringWithFormat:@"Failed to execute: %s - please ensure the AppLovin MAX Unity Plugin has been initialized by calling 'MaxSdk.InitializeSdk();'!", callingMethod];
- max_unity_log_error(message);
- }
-
- void max_unity_log_error(NSString *message)
- {
- if (_disableAllLogs) return;
-
- NSString *logMessage = [NSString stringWithFormat: @"[%@] %@", TAG, message];
- NSLog(@"%@", logMessage);
- }
-}
-
-#pragma clang diagnostic pop
diff --git a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm.meta b/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm.meta
deleted file mode 100644
index 5ea08ff0..00000000
--- a/Assets/MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm.meta
+++ /dev/null
@@ -1,109 +0,0 @@
-fileFormatVersion: 2
-guid: 7e373ed7168b243e6b706e991ab5a643
-labels:
-- al_max
-- al_max_export_path-MaxSdk/AppLovin/Plugins/iOS/MAUnityPlugin.mm
-PluginImporter:
- externalObjects: {}
- serializedVersion: 2
- iconMap: {}
- executionOrder: {}
- defineConstraints: []
- isPreloaded: 0
- isOverridable: 0
- isExplicitlyReferenced: 0
- validateReferences: 1
- platformData:
- - first:
- '': Any
- second:
- enabled: 0
- settings:
- Exclude Android: 1
- Exclude Editor: 1
- Exclude Linux: 1
- Exclude Linux64: 1
- Exclude LinuxUniversal: 1
- Exclude OSXUniversal: 1
- Exclude Win: 1
- Exclude Win64: 1
- Exclude iOS: 0
- Exclude tvOS: 1
- - first:
- Android: Android
- second:
- enabled: 0
- settings:
- CPU: ARMv7
- - first:
- Any:
- second:
- enabled: 0
- settings: {}
- - first:
- Editor: Editor
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- DefaultValueInitialized: true
- OS: AnyOS
- - first:
- Facebook: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Facebook: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Linux
- second:
- enabled: 0
- settings:
- CPU: x86
- - first:
- Standalone: Linux64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: OSXUniversal
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- Standalone: Win64
- second:
- enabled: 0
- settings:
- CPU: AnyCPU
- - first:
- iPhone: iOS
- second:
- enabled: 1
- settings:
- CompileFlags:
- FrameworkDependencies:
- - first:
- tvOS: tvOS
- second:
- enabled: 0
- settings:
- CompileFlags:
- FrameworkDependencies:
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/CHANGELOG.md b/Assets/MaxSdk/CHANGELOG.md
deleted file mode 100644
index 906f42bd..00000000
--- a/Assets/MaxSdk/CHANGELOG.md
+++ /dev/null
@@ -1,3 +0,0 @@
-# AppLovin MAX Unity Plugin
-
-To get the latest changes, see the [AppLovin MAX Unity Changelog](https://support.axon.ai/en/max/unity/changelog).
diff --git a/Assets/MaxSdk/CHANGELOG.md.meta b/Assets/MaxSdk/CHANGELOG.md.meta
deleted file mode 100644
index 6d06bcb0..00000000
--- a/Assets/MaxSdk/CHANGELOG.md.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: dfb944c2e1cb479cabf023040a5942d2
-labels:
-- al_max
-- al_max_export_path-MaxSdk/CHANGELOG.md
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation.meta b/Assets/MaxSdk/Mediation.meta
deleted file mode 100644
index 103dd6f4..00000000
--- a/Assets/MaxSdk/Mediation.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: dcf2020c4018447c9b91170c0f62d799
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BidMachine.meta b/Assets/MaxSdk/Mediation/BidMachine.meta
deleted file mode 100644
index 03fa6742..00000000
--- a/Assets/MaxSdk/Mediation/BidMachine.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: f9593958d76e04a9fa0ca3653e293eea
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BidMachine/Editor.meta b/Assets/MaxSdk/Mediation/BidMachine/Editor.meta
deleted file mode 100644
index 0f3541e9..00000000
--- a/Assets/MaxSdk/Mediation/BidMachine/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 527c65004f8c84edbb4c14b8a2a04c5d
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/BidMachine/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml
deleted file mode 100644
index 312247ec..00000000
--- a/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml
+++ /dev/null
@@ -1,13 +0,0 @@
-
-
-
-
-
- https://artifactory.bidmachine.io/bidmachine
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml.meta
deleted file mode 100644
index 81f22af2..00000000
--- a/Assets/MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 98a383532dccb495aa31190874842cbe
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/BidMachine/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BigoAds.meta b/Assets/MaxSdk/Mediation/BigoAds.meta
deleted file mode 100644
index 45d4b6dc..00000000
--- a/Assets/MaxSdk/Mediation/BigoAds.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 057f3a425e2354240921c2e1b1da8f25
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BigoAds/Editor.meta b/Assets/MaxSdk/Mediation/BigoAds/Editor.meta
deleted file mode 100644
index 39a31408..00000000
--- a/Assets/MaxSdk/Mediation/BigoAds/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 1235281c630214a8999b2185ceba6388
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/BigoAds/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml
deleted file mode 100644
index 90c1f1f0..00000000
--- a/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml.meta
deleted file mode 100644
index 521ce000..00000000
--- a/Assets/MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: fba397d5cac8648fea9b0fe82e201e63
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/BigoAds/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/ByteDance.meta b/Assets/MaxSdk/Mediation/ByteDance.meta
deleted file mode 100644
index 8bcbd933..00000000
--- a/Assets/MaxSdk/Mediation/ByteDance.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 939bfc929854b45f78fb8e3caec1f2f8
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/ByteDance/Editor.meta b/Assets/MaxSdk/Mediation/ByteDance/Editor.meta
deleted file mode 100644
index e54a7664..00000000
--- a/Assets/MaxSdk/Mediation/ByteDance/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: ef8467ffb0e4447b79a8804884a7520a
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/ByteDance/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml
deleted file mode 100644
index 5efb9528..00000000
--- a/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml
+++ /dev/null
@@ -1,13 +0,0 @@
-
-
-
-
-
- https://artifact.bytedance.com/repository/pangle
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml.meta
deleted file mode 100644
index 52052332..00000000
--- a/Assets/MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 0828555cb1ce94702a4af6f3dce3d735
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/ByteDance/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Chartboost.meta b/Assets/MaxSdk/Mediation/Chartboost.meta
deleted file mode 100644
index 31cafe3b..00000000
--- a/Assets/MaxSdk/Mediation/Chartboost.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 7f473c184d2564d5da3060bde69424aa
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Chartboost/Editor.meta b/Assets/MaxSdk/Mediation/Chartboost/Editor.meta
deleted file mode 100644
index 38bff8d5..00000000
--- a/Assets/MaxSdk/Mediation/Chartboost/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: a90f13141c35746f5a2996c8ad068fe9
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Chartboost/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml
deleted file mode 100644
index d3c7e144..00000000
--- a/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
-
- https://cboost.jfrog.io/artifactory/chartboost-ads/
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml.meta
deleted file mode 100644
index 02628eb0..00000000
--- a/Assets/MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 93b0a4618bd884871af0981a7867bb2f
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Chartboost/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Facebook.meta b/Assets/MaxSdk/Mediation/Facebook.meta
deleted file mode 100644
index a2008af8..00000000
--- a/Assets/MaxSdk/Mediation/Facebook.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: b30ea37ccd95b42d8a51d03ab3c644fb
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Facebook/Editor.meta b/Assets/MaxSdk/Mediation/Facebook/Editor.meta
deleted file mode 100644
index 4beff5e4..00000000
--- a/Assets/MaxSdk/Mediation/Facebook/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 28880992a399a48b7abe95b66649d711
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Facebook/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml
deleted file mode 100644
index 9c2d3618..00000000
--- a/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml
+++ /dev/null
@@ -1,13 +0,0 @@
-
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml.meta
deleted file mode 100644
index 69b5d2c8..00000000
--- a/Assets/MaxSdk/Mediation/Facebook/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: aea9bdf974328420db5ae118ef0d2b87
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Facebook/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Fyber.meta b/Assets/MaxSdk/Mediation/Fyber.meta
deleted file mode 100644
index 7924127e..00000000
--- a/Assets/MaxSdk/Mediation/Fyber.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: b202e2f4f19d249c79cdd63e5abe4a87
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Fyber/Editor.meta b/Assets/MaxSdk/Mediation/Fyber/Editor.meta
deleted file mode 100644
index 315e8c8e..00000000
--- a/Assets/MaxSdk/Mediation/Fyber/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e076e4ef7e2874ba69b108cc7a346c2a
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Fyber/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml
deleted file mode 100644
index bba2782b..00000000
--- a/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml.meta
deleted file mode 100644
index fd0bbbf2..00000000
--- a/Assets/MaxSdk/Mediation/Fyber/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 5e123cdc08e804dffb2c40c4fbc83caf
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Fyber/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Google.meta b/Assets/MaxSdk/Mediation/Google.meta
deleted file mode 100644
index 469c65c9..00000000
--- a/Assets/MaxSdk/Mediation/Google.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 64176641aa4214f18881c7888b2f4187
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Google/Editor.meta b/Assets/MaxSdk/Mediation/Google/Editor.meta
deleted file mode 100644
index ea8dd557..00000000
--- a/Assets/MaxSdk/Mediation/Google/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e8015bd045cea462c8f39c8a05867d08
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Google/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml
deleted file mode 100644
index a921ad0a..00000000
--- a/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml.meta
deleted file mode 100644
index 36bef722..00000000
--- a/Assets/MaxSdk/Mediation/Google/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 053b810d3594744e38b6fd0fa378fb57
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Google/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/GoogleAdManager.meta b/Assets/MaxSdk/Mediation/GoogleAdManager.meta
deleted file mode 100755
index adc17791..00000000
--- a/Assets/MaxSdk/Mediation/GoogleAdManager.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: f75dec80f49c44ee68edd909bd32747a
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor.meta b/Assets/MaxSdk/Mediation/GoogleAdManager/Editor.meta
deleted file mode 100755
index 7b0912cd..00000000
--- a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 3e1635bfb5b164c389d38eb1e5e6e909
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/GoogleAdManager/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml
deleted file mode 100755
index 4ce9809f..00000000
--- a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml.meta
deleted file mode 100755
index 71b0087d..00000000
--- a/Assets/MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: aebbf5e9af66e431fa6078021b2f762f
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/GoogleAdManager/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/InMobi.meta b/Assets/MaxSdk/Mediation/InMobi.meta
deleted file mode 100755
index 7e215af9..00000000
--- a/Assets/MaxSdk/Mediation/InMobi.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: cc847e95315674385ba9f42c13733872
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/InMobi/Editor.meta b/Assets/MaxSdk/Mediation/InMobi/Editor.meta
deleted file mode 100755
index a998cfd2..00000000
--- a/Assets/MaxSdk/Mediation/InMobi/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: a141703acd55a48c2a3e6e6599f90c64
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/InMobi/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml
deleted file mode 100755
index 38e22d7a..00000000
--- a/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml
+++ /dev/null
@@ -1,12 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml.meta
deleted file mode 100755
index 1b62e827..00000000
--- a/Assets/MaxSdk/Mediation/InMobi/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: bc66a0ef4503843ee9b1bf1b1e867367
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/InMobi/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/IronSource.meta b/Assets/MaxSdk/Mediation/IronSource.meta
deleted file mode 100644
index 6747e845..00000000
--- a/Assets/MaxSdk/Mediation/IronSource.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 72048a5214d234cd1b850250f4dceb8e
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/IronSource/Editor.meta b/Assets/MaxSdk/Mediation/IronSource/Editor.meta
deleted file mode 100644
index 327f5d6b..00000000
--- a/Assets/MaxSdk/Mediation/IronSource/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 531d860cac61f47d19e32f526470ae43
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/IronSource/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml
deleted file mode 100755
index 6aa657bc..00000000
--- a/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml.meta
deleted file mode 100755
index f77e6f04..00000000
--- a/Assets/MaxSdk/Mediation/IronSource/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 19262406303f04f05b14b31b3c734d35
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/IronSource/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/MediationAdapters.txt b/Assets/MaxSdk/Mediation/MediationAdapters.txt
deleted file mode 100644
index 40f94d07..00000000
--- a/Assets/MaxSdk/Mediation/MediationAdapters.txt
+++ /dev/null
@@ -1,2 +0,0 @@
-A placeholder file to make sure that the Mediation folder asset is exported with the base plugin.
-This ensures that the adapters are imported into this directory even when the plugin has been moved to a different folder.
diff --git a/Assets/MaxSdk/Mediation/MediationAdapters.txt.meta b/Assets/MaxSdk/Mediation/MediationAdapters.txt.meta
deleted file mode 100644
index 41fb9948..00000000
--- a/Assets/MaxSdk/Mediation/MediationAdapters.txt.meta
+++ /dev/null
@@ -1,6 +0,0 @@
-fileFormatVersion: 2
-guid: 9a8f83e97729443c86120be3bb24190d
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/MediationAdapters.txt
-timeCreated: 1609308536
diff --git a/Assets/MaxSdk/Mediation/Mintegral.meta b/Assets/MaxSdk/Mediation/Mintegral.meta
deleted file mode 100644
index 9e8f58a0..00000000
--- a/Assets/MaxSdk/Mediation/Mintegral.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: daa6d88ad14e64ab69057674530502e0
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Mintegral/Editor.meta b/Assets/MaxSdk/Mediation/Mintegral/Editor.meta
deleted file mode 100644
index d189ce00..00000000
--- a/Assets/MaxSdk/Mediation/Mintegral/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: db1de4066dc4e4290b3879b34fa87de2
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Mintegral/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml
deleted file mode 100644
index 7cb4e966..00000000
--- a/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
-
- https://dl-maven-android.mintegral.com/repository/mbridge_android_sdk_oversea
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml.meta
deleted file mode 100644
index 415c4aba..00000000
--- a/Assets/MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 221b2a20a58a04f2cb4afb0779587206
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Mintegral/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Moloco.meta b/Assets/MaxSdk/Mediation/Moloco.meta
deleted file mode 100755
index 9e0dd0f2..00000000
--- a/Assets/MaxSdk/Mediation/Moloco.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 4a938c3e9196244689e2919e3bcd0c10
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Moloco/Editor.meta b/Assets/MaxSdk/Mediation/Moloco/Editor.meta
deleted file mode 100755
index 952b9699..00000000
--- a/Assets/MaxSdk/Mediation/Moloco/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 9ecadc3649c184389b90252aa2a2b448
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Moloco/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml
deleted file mode 100755
index 94d78d0b..00000000
--- a/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml.meta
deleted file mode 100755
index e066a5fc..00000000
--- a/Assets/MaxSdk/Mediation/Moloco/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 0f5b2cb1209274ba18b234b42d2efe96
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Moloco/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/UnityAds.meta b/Assets/MaxSdk/Mediation/UnityAds.meta
deleted file mode 100644
index c67a175a..00000000
--- a/Assets/MaxSdk/Mediation/UnityAds.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: de8dd244651464d549e42e9a133cddd9
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/UnityAds/Editor.meta b/Assets/MaxSdk/Mediation/UnityAds/Editor.meta
deleted file mode 100644
index b66e8469..00000000
--- a/Assets/MaxSdk/Mediation/UnityAds/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 30751f2dc322a40e588edfb7c978c9c0
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/UnityAds/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml
deleted file mode 100644
index 560779d3..00000000
--- a/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml.meta
deleted file mode 100644
index 937df6e2..00000000
--- a/Assets/MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 9950f1cb0da1e43efbeca604db142076
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/UnityAds/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Vungle.meta b/Assets/MaxSdk/Mediation/Vungle.meta
deleted file mode 100644
index 60f9da53..00000000
--- a/Assets/MaxSdk/Mediation/Vungle.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: a0abaf97c8c4846fb86e98da7dc31004
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Vungle/Editor.meta b/Assets/MaxSdk/Mediation/Vungle/Editor.meta
deleted file mode 100644
index 1ea75cce..00000000
--- a/Assets/MaxSdk/Mediation/Vungle/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 77b6ea05736a9458f8ef8762ee9b64bb
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Vungle/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml b/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml
deleted file mode 100644
index 8262be77..00000000
--- a/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml.meta b/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml.meta
deleted file mode 100644
index 7038186f..00000000
--- a/Assets/MaxSdk/Mediation/Vungle/Editor/Dependencies.xml.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 0d8ad3a6ddc4f44fab2efe607fe14f26
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Mediation/Vungle/Editor/Dependencies.xml
-TextScriptImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Prefabs.meta b/Assets/MaxSdk/Prefabs.meta
deleted file mode 100644
index 45829b7d..00000000
--- a/Assets/MaxSdk/Prefabs.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: b1ef42d076f894359b53ec57a427a224
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Prefabs/BannerBottom.prefab b/Assets/MaxSdk/Prefabs/BannerBottom.prefab
deleted file mode 100644
index bba7ac6a..00000000
--- a/Assets/MaxSdk/Prefabs/BannerBottom.prefab
+++ /dev/null
@@ -1,402 +0,0 @@
-%YAML 1.1
-%TAG !u! tag:unity3d.com,2011:
---- !u!1 &3149432657757030138
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5965516886513985157}
- - component: {fileID: 3167928293195730454}
- - component: {fileID: 6048907697713132302}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5965516886513985157
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 4118862295226300947}
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 0}
- m_AnchoredPosition: {x: 0, y: 84}
- m_SizeDelta: {x: 0, y: 168}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &3167928293195730454
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_CullTransparentMesh: 0
---- !u!114 &6048907697713132302
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0, g: 0, b: 0, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &3829518492429360636
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 4118862295226300947}
- - component: {fileID: 5582763645243389146}
- - component: {fileID: 1436650035481827287}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &4118862295226300947
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 5084927109723455527}
- - {fileID: 8189983859356672495}
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0.5, y: 1}
- m_AnchorMax: {x: 0.5, y: 1}
- m_AnchoredPosition: {x: 0, y: -50}
- m_SizeDelta: {x: 640, y: 100}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &5582763645243389146
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_CullTransparentMesh: 0
---- !u!114 &1436650035481827287
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 1, g: 1, b: 1, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &4772536868390647122
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 8189983859356672495}
- - component: {fileID: 7216515036998124610}
- - component: {fileID: 3801875349924125266}
- m_Layer: 5
- m_Name: InfoText
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &8189983859356672495
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4772536868390647122}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 4118862295226300947}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 3}
- m_SizeDelta: {x: 0, y: -6}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7216515036998124610
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4772536868390647122}
- m_CullTransparentMesh: 0
---- !u!114 &3801875349924125266
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4772536868390647122}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.29411766, g: 0.29411766, b: 0.29411766, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 18
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 1
- m_MaxSize: 40
- m_Alignment: 7
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: Actual banner size may vary on mobile devices
---- !u!1 &7742712311334970126
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3413013686078446151}
- - component: {fileID: 2511819091764556577}
- - component: {fileID: 2638196187645015298}
- - component: {fileID: 633018877563332563}
- m_Layer: 5
- m_Name: BannerBottom
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &3413013686078446151
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 0, y: 0, z: 0}
- m_Children:
- - {fileID: 5965516886513985157}
- m_Father: {fileID: 0}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 0, y: 0}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0, y: 0}
---- !u!223 &2511819091764556577
-Canvas:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- serializedVersion: 3
- m_RenderMode: 0
- m_Camera: {fileID: 0}
- m_PlaneDistance: 100
- m_PixelPerfect: 0
- m_ReceivesEvents: 1
- m_OverrideSorting: 0
- m_OverridePixelPerfect: 0
- m_SortingBucketNormalizedSize: 0
- m_AdditionalShaderChannelsFlag: 0
- m_SortingLayerID: 0
- m_SortingOrder: 500
- m_TargetDisplay: 0
---- !u!114 &2638196187645015298
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1980459831, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_UiScaleMode: 0
- m_ReferencePixelsPerUnit: 100
- m_ScaleFactor: 1
- m_ReferenceResolution: {x: 800, y: 600}
- m_ScreenMatchMode: 0
- m_MatchWidthOrHeight: 0
- m_PhysicalUnit: 3
- m_FallbackScreenDPI: 96
- m_DefaultSpriteDPI: 96
- m_DynamicPixelsPerUnit: 1
---- !u!114 &633018877563332563
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1301386320, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_IgnoreReversedGraphics: 1
- m_BlockingObjects: 0
- m_BlockingMask:
- serializedVersion: 2
- m_Bits: 4294967295
---- !u!1 &8436952342056443077
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5084927109723455527}
- - component: {fileID: 7267203896389005665}
- - component: {fileID: 5500603550844857255}
- m_Layer: 5
- m_Name: Text
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5084927109723455527
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 4118862295226300947}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: -4}
- m_SizeDelta: {x: 0, y: -8}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7267203896389005665
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_CullTransparentMesh: 0
---- !u!114 &5500603550844857255
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 26
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 0
- m_MaxSize: 71
- m_Alignment: 1
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: MAX Banner Ad
diff --git a/Assets/MaxSdk/Prefabs/BannerBottom.prefab.meta b/Assets/MaxSdk/Prefabs/BannerBottom.prefab.meta
deleted file mode 100644
index 153cfcf5..00000000
--- a/Assets/MaxSdk/Prefabs/BannerBottom.prefab.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 54c062c0526b148efa2ea2e9489b3aa0
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Prefabs/BannerBottom.prefab
-PrefabImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Prefabs/BannerTop.prefab b/Assets/MaxSdk/Prefabs/BannerTop.prefab
deleted file mode 100644
index 25d5f497..00000000
--- a/Assets/MaxSdk/Prefabs/BannerTop.prefab
+++ /dev/null
@@ -1,402 +0,0 @@
-%YAML 1.1
-%TAG !u! tag:unity3d.com,2011:
---- !u!1 &3149432657757030138
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5965516886513985157}
- - component: {fileID: 3167928293195730454}
- - component: {fileID: 6048907697713132302}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5965516886513985157
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 4118862295226300947}
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 1}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: -50}
- m_SizeDelta: {x: 0, y: 100}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &3167928293195730454
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_CullTransparentMesh: 0
---- !u!114 &6048907697713132302
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0, g: 0, b: 0, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &3829518492429360636
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 4118862295226300947}
- - component: {fileID: 5582763645243389146}
- - component: {fileID: 1436650035481827287}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &4118862295226300947
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 5084927109723455527}
- - {fileID: 7429934296583149777}
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0.5, y: 0}
- m_AnchorMax: {x: 0.5, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 640, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &5582763645243389146
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_CullTransparentMesh: 0
---- !u!114 &1436650035481827287
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3829518492429360636}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 1, g: 1, b: 1, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &5625059666589051168
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 7429934296583149777}
- - component: {fileID: 6576623406533516677}
- - component: {fileID: 5405475098690228567}
- m_Layer: 5
- m_Name: InfoText
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &7429934296583149777
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5625059666589051168}
- m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 4118862295226300947}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 3}
- m_SizeDelta: {x: 0, y: -6}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &6576623406533516677
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5625059666589051168}
- m_CullTransparentMesh: 0
---- !u!114 &5405475098690228567
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5625059666589051168}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.29411766, g: 0.29411766, b: 0.29411766, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 18
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 1
- m_MaxSize: 40
- m_Alignment: 7
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: Actual banner size may vary on mobile devices
---- !u!1 &7742712311334970126
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3413013686078446151}
- - component: {fileID: 2511819091764556577}
- - component: {fileID: 2638196187645015298}
- - component: {fileID: 633018877563332563}
- m_Layer: 5
- m_Name: BannerTop
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &3413013686078446151
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 0, y: 0, z: 0}
- m_Children:
- - {fileID: 5965516886513985157}
- m_Father: {fileID: 0}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 0, y: 0}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0, y: 0}
---- !u!223 &2511819091764556577
-Canvas:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- serializedVersion: 3
- m_RenderMode: 0
- m_Camera: {fileID: 0}
- m_PlaneDistance: 100
- m_PixelPerfect: 0
- m_ReceivesEvents: 1
- m_OverrideSorting: 0
- m_OverridePixelPerfect: 0
- m_SortingBucketNormalizedSize: 0
- m_AdditionalShaderChannelsFlag: 0
- m_SortingLayerID: 0
- m_SortingOrder: 500
- m_TargetDisplay: 0
---- !u!114 &2638196187645015298
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1980459831, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_UiScaleMode: 0
- m_ReferencePixelsPerUnit: 100
- m_ScaleFactor: 1
- m_ReferenceResolution: {x: 800, y: 600}
- m_ScreenMatchMode: 0
- m_MatchWidthOrHeight: 0
- m_PhysicalUnit: 3
- m_FallbackScreenDPI: 96
- m_DefaultSpriteDPI: 96
- m_DynamicPixelsPerUnit: 1
---- !u!114 &633018877563332563
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1301386320, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_IgnoreReversedGraphics: 1
- m_BlockingObjects: 0
- m_BlockingMask:
- serializedVersion: 2
- m_Bits: 4294967295
---- !u!1 &8436952342056443077
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5084927109723455527}
- - component: {fileID: 7267203896389005665}
- - component: {fileID: 5500603550844857255}
- m_Layer: 5
- m_Name: Text
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5084927109723455527
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 4118862295226300947}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: -4}
- m_SizeDelta: {x: 0, y: -8}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7267203896389005665
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_CullTransparentMesh: 0
---- !u!114 &5500603550844857255
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 26
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 0
- m_MaxSize: 71
- m_Alignment: 1
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: MAX Banner Ad
diff --git a/Assets/MaxSdk/Prefabs/BannerTop.prefab.meta b/Assets/MaxSdk/Prefabs/BannerTop.prefab.meta
deleted file mode 100644
index 52ef4649..00000000
--- a/Assets/MaxSdk/Prefabs/BannerTop.prefab.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 6521750c87fd14f709d09a1e38ffde47
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Prefabs/BannerTop.prefab
-PrefabImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Prefabs/Interstitial.prefab b/Assets/MaxSdk/Prefabs/Interstitial.prefab
deleted file mode 100644
index 10c7c7ba..00000000
--- a/Assets/MaxSdk/Prefabs/Interstitial.prefab
+++ /dev/null
@@ -1,523 +0,0 @@
-%YAML 1.1
-%TAG !u! tag:unity3d.com,2011:
---- !u!1 &3149432657757030138
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5965516886513985157}
- - component: {fileID: 3167928293195730454}
- - component: {fileID: 6048907697713132302}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5965516886513985157
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 5084927109723455527}
- - {fileID: 8681486192829137138}
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &3167928293195730454
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_CullTransparentMesh: 0
---- !u!114 &6048907697713132302
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.88235295, g: 0.88235295, b: 0.88235295, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &5668641863723001099
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 8681486192829137138}
- - component: {fileID: 8217482188885705039}
- - component: {fileID: 3177344817093501532}
- - component: {fileID: 4415703054918645549}
- m_Layer: 5
- m_Name: MaxInterstitialCloseButton
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &8681486192829137138
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 763654547095120985}
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 1, y: 1}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: -200, y: -100}
- m_SizeDelta: {x: 250, y: 100}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &8217482188885705039
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_CullTransparentMesh: 0
---- !u!114 &3177344817093501532
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 1, g: 1, b: 1, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 10905, guid: 0000000000000000f000000000000000, type: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!114 &4415703054918645549
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1392445389, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Navigation:
- m_Mode: 3
- m_SelectOnUp: {fileID: 0}
- m_SelectOnDown: {fileID: 0}
- m_SelectOnLeft: {fileID: 0}
- m_SelectOnRight: {fileID: 0}
- m_Transition: 1
- m_Colors:
- m_NormalColor: {r: 1, g: 1, b: 1, a: 1}
- m_HighlightedColor: {r: 0.9607843, g: 0.9607843, b: 0.9607843, a: 1}
- m_PressedColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 1}
- m_DisabledColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 0.5019608}
- m_ColorMultiplier: 1
- m_FadeDuration: 0.1
- m_SpriteState:
- m_HighlightedSprite: {fileID: 0}
- m_PressedSprite: {fileID: 0}
- m_DisabledSprite: {fileID: 0}
- m_AnimationTriggers:
- m_NormalTrigger: Normal
- m_HighlightedTrigger: Highlighted
- m_PressedTrigger: Pressed
- m_DisabledTrigger: Disabled
- m_Interactable: 1
- m_TargetGraphic: {fileID: 3177344817093501532}
- m_OnClick:
- m_PersistentCalls:
- m_Calls: []
---- !u!1 &6155160063690407013
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 1672649117655046507}
- - component: {fileID: 2484422763836779945}
- - component: {fileID: 1332063313327512547}
- - component: {fileID: 9160434328933334999}
- m_Layer: 5
- m_Name: EventSystem
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!4 &1672649117655046507
-Transform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6155160063690407013}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
---- !u!114 &2484422763836779945
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6155160063690407013}
- m_Enabled: 0
- m_EditorHideFlags: 0
- m_Script: {fileID: -619905303, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_FirstSelected: {fileID: 0}
- m_sendNavigationEvents: 1
- m_DragThreshold: 10
---- !u!114 &1332063313327512547
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6155160063690407013}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1077351063, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_HorizontalAxis: Horizontal
- m_VerticalAxis: Vertical
- m_SubmitButton: Submit
- m_CancelButton: Cancel
- m_InputActionsPerSecond: 10
- m_RepeatDelay: 0.5
- m_ForceModuleActive: 0
---- !u!114 &9160434328933334999
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6155160063690407013}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 11500000, guid: e0acf281ba86b4929a6942ecd998395b, type: 3}
- m_Name:
- m_EditorClassIdentifier:
---- !u!1 &6462551400748024402
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 763654547095120985}
- - component: {fileID: 6719360953530842803}
- - component: {fileID: 4616290306121202327}
- m_Layer: 5
- m_Name: Text
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &763654547095120985
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 8681486192829137138}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &6719360953530842803
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_CullTransparentMesh: 0
---- !u!114 &4616290306121202327
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 40
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 4
- m_MaxSize: 47
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: Close
---- !u!1 &7742712311334970126
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3413013686078446151}
- - component: {fileID: 2511819091764556577}
- - component: {fileID: 2638196187645015298}
- - component: {fileID: 633018877563332563}
- m_Layer: 5
- m_Name: Interstitial
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &3413013686078446151
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 0, y: 0, z: 0}
- m_Children:
- - {fileID: 5965516886513985157}
- - {fileID: 1672649117655046507}
- m_Father: {fileID: 0}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 0, y: 0}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0, y: 0}
---- !u!223 &2511819091764556577
-Canvas:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- serializedVersion: 3
- m_RenderMode: 0
- m_Camera: {fileID: 0}
- m_PlaneDistance: 100
- m_PixelPerfect: 0
- m_ReceivesEvents: 1
- m_OverrideSorting: 0
- m_OverridePixelPerfect: 0
- m_SortingBucketNormalizedSize: 0
- m_AdditionalShaderChannelsFlag: 0
- m_SortingLayerID: 0
- m_SortingOrder: 999
- m_TargetDisplay: 0
---- !u!114 &2638196187645015298
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1980459831, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_UiScaleMode: 0
- m_ReferencePixelsPerUnit: 100
- m_ScaleFactor: 1
- m_ReferenceResolution: {x: 800, y: 600}
- m_ScreenMatchMode: 0
- m_MatchWidthOrHeight: 0
- m_PhysicalUnit: 3
- m_FallbackScreenDPI: 96
- m_DefaultSpriteDPI: 96
- m_DynamicPixelsPerUnit: 1
---- !u!114 &633018877563332563
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1301386320, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_IgnoreReversedGraphics: 1
- m_BlockingObjects: 0
- m_BlockingMask:
- serializedVersion: 2
- m_Bits: 4294967295
---- !u!1 &8436952342056443077
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5084927109723455527}
- - component: {fileID: 7267203896389005665}
- - component: {fileID: 5500603550844857255}
- m_Layer: 5
- m_Name: MaxInterstitialTitle
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5084927109723455527
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0.5}
- m_AnchorMax: {x: 1, y: 0.5}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 300}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7267203896389005665
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_CullTransparentMesh: 0
---- !u!114 &5500603550844857255
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 50
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 0
- m_MaxSize: 71
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: MAX Interstitial Ad
diff --git a/Assets/MaxSdk/Prefabs/Interstitial.prefab.meta b/Assets/MaxSdk/Prefabs/Interstitial.prefab.meta
deleted file mode 100644
index 4fa240bc..00000000
--- a/Assets/MaxSdk/Prefabs/Interstitial.prefab.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: 3fc0c2627ce8a4490b8e319326f8a535
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Prefabs/Interstitial.prefab
-PrefabImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Prefabs/Rewarded.prefab b/Assets/MaxSdk/Prefabs/Rewarded.prefab
deleted file mode 100644
index dd3457ef..00000000
--- a/Assets/MaxSdk/Prefabs/Rewarded.prefab
+++ /dev/null
@@ -1,795 +0,0 @@
-%YAML 1.1
-%TAG !u! tag:unity3d.com,2011:
---- !u!1 &288832541099509301
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 6736833388881778366}
- - component: {fileID: 738723989743429661}
- - component: {fileID: 3366016410383180441}
- m_Layer: 5
- m_Name: Text
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &6736833388881778366
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 288832541099509301}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 2219183527695013266}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &738723989743429661
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 288832541099509301}
- m_CullTransparentMesh: 0
---- !u!114 &3366016410383180441
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 288832541099509301}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 35
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 3
- m_MaxSize: 48
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: 'Grant Reward
-
- (5 coins)'
---- !u!1 &2620135977249264498
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3035265698078104281}
- - component: {fileID: 7277178523579209441}
- - component: {fileID: 8085319417655039649}
- m_Layer: 5
- m_Name: MaxRewardStatus
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &3035265698078104281
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 2620135977249264498}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0.5}
- m_AnchorMax: {x: 1, y: 0.5}
- m_AnchoredPosition: {x: 0, y: -250}
- m_SizeDelta: {x: 0, y: 200}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7277178523579209441
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 2620135977249264498}
- m_CullTransparentMesh: 0
---- !u!114 &8085319417655039649
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 2620135977249264498}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 40
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 10
- m_MaxSize: 69
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: Reward not yet granted.
---- !u!1 &3096027301306273604
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 2219183527695013266}
- - component: {fileID: 3687429596110321440}
- - component: {fileID: 3757577222601629632}
- - component: {fileID: 87227930114769318}
- m_Layer: 5
- m_Name: MaxRewardButton
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &2219183527695013266
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3096027301306273604}
- m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 6736833388881778366}
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 2
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0.5, y: 0.5}
- m_AnchorMax: {x: 0.5, y: 0.5}
- m_AnchoredPosition: {x: 0, y: -150}
- m_SizeDelta: {x: 300, y: 100}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &3687429596110321440
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3096027301306273604}
- m_CullTransparentMesh: 0
---- !u!114 &3757577222601629632
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3096027301306273604}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 1, g: 1, b: 1, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 10905, guid: 0000000000000000f000000000000000, type: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!114 &87227930114769318
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3096027301306273604}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1392445389, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Navigation:
- m_Mode: 3
- m_SelectOnUp: {fileID: 0}
- m_SelectOnDown: {fileID: 0}
- m_SelectOnLeft: {fileID: 0}
- m_SelectOnRight: {fileID: 0}
- m_Transition: 1
- m_Colors:
- m_NormalColor: {r: 1, g: 1, b: 1, a: 1}
- m_HighlightedColor: {r: 0.9607843, g: 0.9607843, b: 0.9607843, a: 1}
- m_PressedColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 1}
- m_DisabledColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 0.5019608}
- m_ColorMultiplier: 1
- m_FadeDuration: 0.1
- m_SpriteState:
- m_HighlightedSprite: {fileID: 0}
- m_PressedSprite: {fileID: 0}
- m_DisabledSprite: {fileID: 0}
- m_AnimationTriggers:
- m_NormalTrigger: Normal
- m_HighlightedTrigger: Highlighted
- m_PressedTrigger: Pressed
- m_DisabledTrigger: Disabled
- m_Interactable: 1
- m_TargetGraphic: {fileID: 3757577222601629632}
- m_OnClick:
- m_PersistentCalls:
- m_Calls: []
---- !u!1 &3149432657757030138
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5965516886513985157}
- - component: {fileID: 3167928293195730454}
- - component: {fileID: 6048907697713132302}
- m_Layer: 5
- m_Name: Panel
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5965516886513985157
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 5084927109723455527}
- - {fileID: 8681486192829137138}
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &3167928293195730454
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_CullTransparentMesh: 0
---- !u!114 &6048907697713132302
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 3149432657757030138}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.88235295, g: 0.88235295, b: 0.88235295, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!1 &4010021198786516228
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3074011789293951898}
- - component: {fileID: 301935380126337495}
- - component: {fileID: 535359239537776472}
- - component: {fileID: 1463999766055390634}
- m_Layer: 5
- m_Name: EventSystem
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!4 &3074011789293951898
-Transform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4010021198786516228}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 3413013686078446151}
- m_RootOrder: 3
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
---- !u!114 &301935380126337495
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4010021198786516228}
- m_Enabled: 0
- m_EditorHideFlags: 0
- m_Script: {fileID: -619905303, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_FirstSelected: {fileID: 0}
- m_sendNavigationEvents: 1
- m_DragThreshold: 10
---- !u!114 &535359239537776472
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4010021198786516228}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1077351063, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_HorizontalAxis: Horizontal
- m_VerticalAxis: Vertical
- m_SubmitButton: Submit
- m_CancelButton: Cancel
- m_InputActionsPerSecond: 10
- m_RepeatDelay: 0.5
- m_ForceModuleActive: 0
---- !u!114 &1463999766055390634
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 4010021198786516228}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 11500000, guid: e0acf281ba86b4929a6942ecd998395b, type: 3}
- m_Name:
- m_EditorClassIdentifier:
---- !u!1 &5668641863723001099
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 8681486192829137138}
- - component: {fileID: 8217482188885705039}
- - component: {fileID: 3177344817093501532}
- - component: {fileID: 4415703054918645549}
- m_Layer: 5
- m_Name: MaxRewardedCloseButton
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &8681486192829137138
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children:
- - {fileID: 763654547095120985}
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 1
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 1, y: 1}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: -200, y: -100}
- m_SizeDelta: {x: 250, y: 100}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &8217482188885705039
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_CullTransparentMesh: 0
---- !u!114 &3177344817093501532
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: -765806418, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 1, g: 1, b: 1, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_Sprite: {fileID: 10905, guid: 0000000000000000f000000000000000, type: 0}
- m_Type: 1
- m_PreserveAspect: 0
- m_FillCenter: 1
- m_FillMethod: 4
- m_FillAmount: 1
- m_FillClockwise: 1
- m_FillOrigin: 0
- m_UseSpriteMesh: 0
---- !u!114 &4415703054918645549
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 5668641863723001099}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1392445389, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Navigation:
- m_Mode: 3
- m_SelectOnUp: {fileID: 0}
- m_SelectOnDown: {fileID: 0}
- m_SelectOnLeft: {fileID: 0}
- m_SelectOnRight: {fileID: 0}
- m_Transition: 1
- m_Colors:
- m_NormalColor: {r: 1, g: 1, b: 1, a: 1}
- m_HighlightedColor: {r: 0.9607843, g: 0.9607843, b: 0.9607843, a: 1}
- m_PressedColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 1}
- m_DisabledColor: {r: 0.78431374, g: 0.78431374, b: 0.78431374, a: 0.5019608}
- m_ColorMultiplier: 1
- m_FadeDuration: 0.1
- m_SpriteState:
- m_HighlightedSprite: {fileID: 0}
- m_PressedSprite: {fileID: 0}
- m_DisabledSprite: {fileID: 0}
- m_AnimationTriggers:
- m_NormalTrigger: Normal
- m_HighlightedTrigger: Highlighted
- m_PressedTrigger: Pressed
- m_DisabledTrigger: Disabled
- m_Interactable: 1
- m_TargetGraphic: {fileID: 3177344817093501532}
- m_OnClick:
- m_PersistentCalls:
- m_Calls: []
---- !u!1 &6462551400748024402
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 763654547095120985}
- - component: {fileID: 6719360953530842803}
- - component: {fileID: 4616290306121202327}
- m_Layer: 5
- m_Name: Text
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &763654547095120985
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 8681486192829137138}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 1, y: 1}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &6719360953530842803
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_CullTransparentMesh: 0
---- !u!114 &4616290306121202327
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 6462551400748024402}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 40
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 4
- m_MaxSize: 47
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: Close
---- !u!1 &7742712311334970126
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 3413013686078446151}
- - component: {fileID: 2511819091764556577}
- - component: {fileID: 2638196187645015298}
- - component: {fileID: 633018877563332563}
- m_Layer: 5
- m_Name: Rewarded
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &3413013686078446151
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 0, y: 0, z: 0}
- m_Children:
- - {fileID: 5965516886513985157}
- - {fileID: 3035265698078104281}
- - {fileID: 2219183527695013266}
- - {fileID: 3074011789293951898}
- m_Father: {fileID: 0}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0}
- m_AnchorMax: {x: 0, y: 0}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 0}
- m_Pivot: {x: 0, y: 0}
---- !u!223 &2511819091764556577
-Canvas:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- serializedVersion: 3
- m_RenderMode: 0
- m_Camera: {fileID: 0}
- m_PlaneDistance: 100
- m_PixelPerfect: 0
- m_ReceivesEvents: 1
- m_OverrideSorting: 0
- m_OverridePixelPerfect: 0
- m_SortingBucketNormalizedSize: 0
- m_AdditionalShaderChannelsFlag: 0
- m_SortingLayerID: 0
- m_SortingOrder: 999
- m_TargetDisplay: 0
---- !u!114 &2638196187645015298
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1980459831, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_UiScaleMode: 0
- m_ReferencePixelsPerUnit: 100
- m_ScaleFactor: 1
- m_ReferenceResolution: {x: 800, y: 600}
- m_ScreenMatchMode: 0
- m_MatchWidthOrHeight: 0
- m_PhysicalUnit: 3
- m_FallbackScreenDPI: 96
- m_DefaultSpriteDPI: 96
- m_DynamicPixelsPerUnit: 1
---- !u!114 &633018877563332563
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 7742712311334970126}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 1301386320, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_IgnoreReversedGraphics: 1
- m_BlockingObjects: 0
- m_BlockingMask:
- serializedVersion: 2
- m_Bits: 4294967295
---- !u!1 &8436952342056443077
-GameObject:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- serializedVersion: 6
- m_Component:
- - component: {fileID: 5084927109723455527}
- - component: {fileID: 7267203896389005665}
- - component: {fileID: 5500603550844857255}
- m_Layer: 5
- m_Name: MaxRewardTitle
- m_TagString: Untagged
- m_Icon: {fileID: 0}
- m_NavMeshLayer: 0
- m_StaticEditorFlags: 0
- m_IsActive: 1
---- !u!224 &5084927109723455527
-RectTransform:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
- m_LocalPosition: {x: 0, y: 0, z: 0}
- m_LocalScale: {x: 1, y: 1, z: 1}
- m_Children: []
- m_Father: {fileID: 5965516886513985157}
- m_RootOrder: 0
- m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
- m_AnchorMin: {x: 0, y: 0.5}
- m_AnchorMax: {x: 1, y: 0.5}
- m_AnchoredPosition: {x: 0, y: 0}
- m_SizeDelta: {x: 0, y: 300}
- m_Pivot: {x: 0.5, y: 0.5}
---- !u!222 &7267203896389005665
-CanvasRenderer:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_CullTransparentMesh: 0
---- !u!114 &5500603550844857255
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 8436952342056443077}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 708705254, guid: f70555f144d8491a825f0804e09c671c, type: 3}
- m_Name:
- m_EditorClassIdentifier:
- m_Material: {fileID: 0}
- m_Color: {r: 0.19607843, g: 0.19607843, b: 0.19607843, a: 1}
- m_RaycastTarget: 1
- m_OnCullStateChanged:
- m_PersistentCalls:
- m_Calls: []
- m_FontData:
- m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
- m_FontSize: 50
- m_FontStyle: 0
- m_BestFit: 0
- m_MinSize: 0
- m_MaxSize: 71
- m_Alignment: 4
- m_AlignByGeometry: 0
- m_RichText: 1
- m_HorizontalOverflow: 0
- m_VerticalOverflow: 0
- m_LineSpacing: 1
- m_Text: MAX Rewarded Ad
diff --git a/Assets/MaxSdk/Prefabs/Rewarded.prefab.meta b/Assets/MaxSdk/Prefabs/Rewarded.prefab.meta
deleted file mode 100644
index 214bea11..00000000
--- a/Assets/MaxSdk/Prefabs/Rewarded.prefab.meta
+++ /dev/null
@@ -1,10 +0,0 @@
-fileFormatVersion: 2
-guid: a28c1544d6f094d5eafc8da2343c9119
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Prefabs/Rewarded.prefab
-PrefabImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Resources/AppLovinSettings.asset b/Assets/MaxSdk/Resources/AppLovinSettings.asset
deleted file mode 100644
index 77261779..00000000
--- a/Assets/MaxSdk/Resources/AppLovinSettings.asset
+++ /dev/null
@@ -1,20 +0,0 @@
-%YAML 1.1
-%TAG !u! tag:unity3d.com,2011:
---- !u!114 &11400000
-MonoBehaviour:
- m_ObjectHideFlags: 0
- m_CorrespondingSourceObject: {fileID: 0}
- m_PrefabInstance: {fileID: 0}
- m_PrefabAsset: {fileID: 0}
- m_GameObject: {fileID: 0}
- m_Enabled: 1
- m_EditorHideFlags: 0
- m_Script: {fileID: 11500000, guid: ebc0ba1b5ef6b4a6b9dd53d7eadfea16, type: 3}
- m_Name: AppLovinSettings
- m_EditorClassIdentifier:
- qualityServiceEnabled: 1
- sdkKey: LHx_tPFslZpTTiIPABmS24T7Ev1QEVOUVOzirpkxLUuTwJTVZGCKAk9L3Tm3FwuM5LxHK3q1EIbAemJB5sNpX2
- customGradleVersionUrl:
- customGradleToolsVersion:
- adMobAndroidAppId: ca-app-pub-3940256099942544~3347511713
- adMobIosAppId: ca-app-pub-3940256099942544~1458002511
diff --git a/Assets/MaxSdk/Resources/AppLovinSettings.asset.meta b/Assets/MaxSdk/Resources/AppLovinSettings.asset.meta
deleted file mode 100644
index 0b1b24ae..00000000
--- a/Assets/MaxSdk/Resources/AppLovinSettings.asset.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 95645d8e09bd1744589b1ef54dc41982
-NativeFormatImporter:
- externalObjects: {}
- mainObjectFileID: 0
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Resources/Images/info_icon.png b/Assets/MaxSdk/Resources/Images/info_icon.png
deleted file mode 100644
index a0b19e82..00000000
Binary files a/Assets/MaxSdk/Resources/Images/info_icon.png and /dev/null differ
diff --git a/Assets/MaxSdk/Resources/Images/warning_icon.png.meta b/Assets/MaxSdk/Resources/Images/warning_icon.png.meta
deleted file mode 100644
index ee4941c3..00000000
--- a/Assets/MaxSdk/Resources/Images/warning_icon.png.meta
+++ /dev/null
@@ -1,91 +0,0 @@
-fileFormatVersion: 2
-guid: b504c956e7ed744b6b0e7f014e1cac5a
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Resources/Images/warning_icon.png
-TextureImporter:
- fileIDToRecycleName: {}
- externalObjects: {}
- serializedVersion: 9
- mipmaps:
- mipMapMode: 0
- enableMipMap: 1
- sRGBTexture: 1
- linearTexture: 0
- fadeOut: 0
- borderMipMap: 0
- mipMapsPreserveCoverage: 0
- alphaTestReferenceValue: 0.5
- mipMapFadeDistanceStart: 1
- mipMapFadeDistanceEnd: 3
- bumpmap:
- convertToNormalMap: 0
- externalNormalMap: 0
- heightScale: 0.25
- normalMapFilter: 0
- isReadable: 0
- streamingMipmaps: 0
- streamingMipmapsPriority: 0
- grayScaleToAlpha: 0
- generateCubemap: 6
- cubemapConvolution: 0
- seamlessCubemap: 0
- textureFormat: 1
- maxTextureSize: 2048
- textureSettings:
- serializedVersion: 2
- filterMode: -1
- aniso: -1
- mipBias: -100
- wrapU: -1
- wrapV: -1
- wrapW: -1
- nPOTScale: 1
- lightmap: 0
- compressionQuality: 50
- spriteMode: 0
- spriteExtrude: 1
- spriteMeshType: 1
- alignment: 0
- spritePivot: {x: 0.5, y: 0.5}
- spritePixelsToUnits: 100
- spriteBorder: {x: 0, y: 0, z: 0, w: 0}
- spriteGenerateFallbackPhysicsShape: 1
- alphaUsage: 1
- alphaIsTransparency: 0
- spriteTessellationDetail: -1
- textureType: 0
- textureShape: 1
- singleChannelComponent: 0
- maxTextureSizeSet: 0
- compressionQualitySet: 0
- textureFormatSet: 0
- platformSettings:
- - serializedVersion: 2
- buildTarget: DefaultTexturePlatform
- maxTextureSize: 2048
- resizeAlgorithm: 0
- textureFormat: -1
- textureCompression: 1
- compressionQuality: 50
- crunchedCompression: 0
- allowsAlphaSplitting: 0
- overridden: 0
- androidETC2FallbackOverride: 0
- spriteSheet:
- serializedVersion: 2
- sprites: []
- outline: []
- physicsShape: []
- bones: []
- spriteID:
- vertices: []
- indices:
- edges: []
- weights: []
- spritePackingTag:
- pSDRemoveMatte: 0
- pSDShowRemoveMatteOption: 0
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts.meta b/Assets/MaxSdk/Scripts.meta
deleted file mode 100644
index db94d676..00000000
--- a/Assets/MaxSdk/Scripts.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: b54f71ab59d7b492da373a6ae2e68337
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager.meta b/Assets/MaxSdk/Scripts/IntegrationManager.meta
deleted file mode 100644
index 39f65ccd..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e01816bc45c944d03afb95d035caf0e1
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor.meta
deleted file mode 100644
index 1d8400ae..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 0da229e279400497786c39933fe02e52
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs
deleted file mode 100644
index 922518e3..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs
+++ /dev/null
@@ -1,171 +0,0 @@
-//
-// AppLovinAutoUpdater.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 1/27/20.
-// Copyright © 2020 AppLovin. All rights reserved.
-//
-
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using UnityEditor;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// Handles auto updates for AppLovin MAX plugin.
- ///
- public static class AppLovinAutoUpdater
- {
- public const string KeyAutoUpdateEnabled = "com.applovin.auto_update_enabled";
- private const string KeyLastUpdateCheckTime = "com.applovin.last_update_check_time_v2"; // Updated to v2 to force adapter version checks in plugin version 3.1.10.
- private static readonly DateTime EpochTime = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
- private static readonly int SecondsInADay = (int) TimeSpan.FromDays(1).TotalSeconds;
-
- // TODO: Make this list dynamic.
- public static readonly Dictionary MinAdapterVersions = new Dictionary()
- {
- {"ADMOB_NETWORK", "android_23.3.0.1_ios_11.9.0.1"},
- {"BIDMACHINE_NETWORK", "android_3.0.1.1_ios_3.0.0.0.1"},
- {"CHARTBOOST_NETWORK", "android_9.7.0.3_ios_9.7.0.2"},
- {"FACEBOOK_MEDIATE", "android_6.17.0.1_ios_6.15.2.1"},
- {"FYBER_NETWORK", "android_8.3.1.1_ios_8.3.2.1"},
- {"GOOGLE_AD_MANAGER_NETWORK", "android_23.3.0.1_ios_11.9.0.1"},
- {"HYPRMX_NETWORK", "android_6.4.2.1_ios_6.4.1.0.1"},
- {"INMOBI_NETWORK", "android_10.7.7.1_ios_10.7.5.1"},
- {"IRONSOURCE_NETWORK", "android_8.3.0.0.2_ios_8.3.0.0.1"},
- {"LINE_NETWORK", "android_2024.8.27.1_ios_2.8.20240827.1"},
- {"MINTEGRAL_NETWORK", "android_16.8.51.1_ios_7.7.2.0.1"},
- {"MOBILEFUSE_NETWORK", "android_1.7.6.1_ios_1.7.6.1"},
- {"MOLOCO_NETWORK", "android_3.1.0.1_ios_3.1.3.1"},
- {"MYTARGET_NETWORK", "android_5.22.1.1_ios_5.21.7.1"},
- {"PUBMATIC_NETWORK", "android_3.9.0.2_ios_3.9.0.2"},
- {"SMAATO_NETWORK", "android_22.7.0.1_ios_22.8.4.1"},
- {"TIKTOK_NETWORK", "android_6.2.0.5.2_ios_6.2.0.7.2"},
- {"UNITY_NETWORK", "android_4.12.2.1_ios_4.12.2.1"},
- {"VERVE_NETWORK", "android_3.0.4.1_ios_3.0.4.1"},
- {"VUNGLE_NETWORK", "android_7.4.1.1_ios_7.4.1.1"},
- {"YANDEX_NETWORK", "android_7.4.0.1_ios_2.18.0.1"},
- };
-
- ///
- /// Checks if a new version of the plugin is available and prompts the user to update if one is available.
- ///
- public static void Update()
- {
- var now = (int) (DateTime.UtcNow - EpochTime).TotalSeconds;
- if (EditorPrefs.HasKey(KeyLastUpdateCheckTime))
- {
- var elapsedTime = now - EditorPrefs.GetInt(KeyLastUpdateCheckTime);
-
- // Check if we have checked for a new version in the last 24 hrs and skip update if we have.
- if (elapsedTime < SecondsInADay) return;
- }
-
- // Update last checked time.
- EditorPrefs.SetInt(KeyLastUpdateCheckTime, now);
-
- // Load the plugin data
- AppLovinEditorCoroutine.StartCoroutine(AppLovinIntegrationManager.Instance.LoadPluginData(data =>
- {
- if (data == null) return;
-
- ShowPluginUpdateDialogIfNeeded(data);
- ShowNetworkAdaptersUpdateDialogIfNeeded(data.MediatedNetworks);
- ShowGoogleNetworkAdaptersUpdateDialogIfNeeded(data.MediatedNetworks);
- }));
- }
-
- private static void ShowPluginUpdateDialogIfNeeded(PluginData data)
- {
- // Check if publisher has disabled auto update.
- if (!EditorPrefs.GetBool(KeyAutoUpdateEnabled, true)) return;
-
- // Check if the current and latest version are the same or if the publisher is on a newer version (on beta). If so, skip update.
- var comparison = data.AppLovinMax.CurrentToLatestVersionComparisonResult;
- if (comparison == MaxSdkUtils.VersionComparisonResult.Equal || comparison == MaxSdkUtils.VersionComparisonResult.Greater) return;
-
- // A new version of the plugin is available. Show a dialog to the publisher.
- var option = EditorUtility.DisplayDialogComplex(
- "AppLovin MAX Plugin Update",
- "A new version of AppLovin MAX plugin is available for download. Update now?",
- "Download",
- "Not Now",
- "Don't Ask Again");
-
- if (option == 0) // Download
- {
- MaxSdkLogger.UserDebug("Downloading plugin...");
- AppLovinEditorCoroutine.StartCoroutine(AppLovinIntegrationManager.Instance.DownloadPlugin(data.AppLovinMax));
- }
- else if (option == 1) // Not Now
- {
- // Do nothing
- MaxSdkLogger.UserDebug("Update postponed.");
- }
- else if (option == 2) // Don't Ask Again
- {
- MaxSdkLogger.UserDebug("Auto Update disabled. You can enable it again from the AppLovin Integration Manager");
- EditorPrefs.SetBool(KeyAutoUpdateEnabled, false);
- }
- }
-
- private static void ShowNetworkAdaptersUpdateDialogIfNeeded(Network[] networks)
- {
- var networksToUpdate = networks.Where(network => network.RequiresUpdate).ToList();
-
- // If all networks are above the required version, do nothing.
- if (networksToUpdate.Count <= 0) return;
-
- // We found a few adapters that are not compatible with the current SDK, show alert.
- var message = "The following network adapters are not compatible with the current version of AppLovin MAX Plugin:\n";
- foreach (var networkName in networksToUpdate)
- {
- message += "\n- ";
- message += networkName.DisplayName + " (Requires " + MinAdapterVersions[networkName.Name] + " or newer)";
- }
-
- message += "\n\nPlease update them to the latest versions to avoid any issues.";
-
- AppLovinIntegrationManager.ShowBuildFailureDialog(message);
- }
-
- private static void ShowGoogleNetworkAdaptersUpdateDialogIfNeeded(Network[] networks)
- {
- // AdMob and GAM use the same SDKs so their adapters should use the same underlying SDK version.
- var googleNetwork = networks.FirstOrDefault(network => network.Name.Equals("ADMOB_NETWORK"));
- var googleAdManagerNetwork = networks.FirstOrDefault(network => network.Name.Equals("GOOGLE_AD_MANAGER_NETWORK"));
-
- // If both AdMob and GAM are not integrated, do nothing.
- if (googleNetwork == null || string.IsNullOrEmpty(googleNetwork.CurrentVersions.Unity) ||
- googleAdManagerNetwork == null || string.IsNullOrEmpty(googleAdManagerNetwork.CurrentVersions.Unity)) return;
-
- var isAndroidVersionCompatible = GoogleNetworkAdaptersCompatible(googleNetwork.CurrentVersions.Android, googleAdManagerNetwork.CurrentVersions.Android, "19.8.0.0");
- var isIosVersionCompatible = GoogleNetworkAdaptersCompatible(googleNetwork.CurrentVersions.Ios, googleAdManagerNetwork.CurrentVersions.Ios, "8.0.0.0");
-
- if (isAndroidVersionCompatible && isIosVersionCompatible) return;
-
- var message = "You may see unexpected errors if you use different versions of the AdMob and Google Ad Manager adapter SDKs. " +
- "AdMob and Google Ad Manager share the same SDKs.\n\n" +
- "You can be sure that you are using the same SDK for both if the first three numbers in each adapter version match.";
-
- AppLovinIntegrationManager.ShowBuildFailureDialog(message);
- }
-
- private static bool GoogleNetworkAdaptersCompatible(string googleVersion, string googleAdManagerVersion, string breakingVersion)
- {
- var googleResult = MaxSdkUtils.CompareVersions(googleVersion, breakingVersion);
- var googleAdManagerResult = MaxSdkUtils.CompareVersions(googleAdManagerVersion, breakingVersion);
-
- // If one is less than the breaking version and the other is not, they are not compatible.
- if (googleResult == MaxSdkUtils.VersionComparisonResult.Lesser &&
- googleAdManagerResult != MaxSdkUtils.VersionComparisonResult.Lesser) return false;
-
- if (googleAdManagerResult == MaxSdkUtils.VersionComparisonResult.Lesser &&
- googleResult != MaxSdkUtils.VersionComparisonResult.Lesser) return false;
-
- return true;
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs.meta
deleted file mode 100644
index 0070e745..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 8bcdd5226273242c5bd9ec79568202e6
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinAutoUpdater.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs
deleted file mode 100644
index 28cb4969..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs
+++ /dev/null
@@ -1,94 +0,0 @@
-//
-// AppLovinBuildPostProcessor.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 10/30/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-#if UNITY_IOS || UNITY_IPHONE
-
-using System.Diagnostics;
-using System.IO;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// A helper class to run command line tools.
- ///
- /// TODO: Currently only supports shell (Linux). Add support for Windows machines.
- ///
- public static class AppLovinCommandLine
- {
- ///
- /// Result obtained by running a command line command.
- ///
- public class Result
- {
- ///
- /// Standard output stream from command line.
- ///
- public string StandardOutput;
-
- ///
- /// Standard error stream from command line.
- ///
- public string StandardError;
-
- ///
- /// Exit code returned from command line.
- ///
- public int ExitCode;
-
- ///
- /// The description of the result that can be used for error logging.
- ///
- public string Message;
- }
-
- ///
- /// Runs a command line tool using the provided and .
- ///
- /// The tool path to run
- /// The arguments to be passed to the command line tool
- /// The directory from which to run this command.
- ///
- public static Result Run(string toolPath, string arguments, string workingDirectory)
- {
- var stdoutFileName = Path.GetTempFileName();
- var stderrFileName = Path.GetTempFileName();
-
- var process = new Process();
- process.StartInfo.UseShellExecute = true;
- process.StartInfo.CreateNoWindow = false;
- process.StartInfo.RedirectStandardInput = false;
- process.StartInfo.RedirectStandardOutput = false;
- process.StartInfo.RedirectStandardError = false;
-
- process.StartInfo.WorkingDirectory = workingDirectory;
- process.StartInfo.FileName = "bash";
- process.StartInfo.Arguments = string.Format("-l -c '\"{0}\" {1} 1> {2} 2> {3}'", toolPath, arguments, stdoutFileName, stderrFileName);
- process.Start();
-
- process.WaitForExit();
-
- var stdout = File.ReadAllText(stdoutFileName);
- var stderr = File.ReadAllText(stderrFileName);
-
- File.Delete(stdoutFileName);
- File.Delete(stderrFileName);
-
- var result = new Result();
- result.StandardOutput = stdout;
- result.StandardError = stderr;
- result.ExitCode = process.ExitCode;
-
- var messagePrefix = result.ExitCode == 0 ? "Command executed successfully" : "Failed to run command";
- result.Message = string.Format("{0}: '{1} {2}'\nstdout: {3}\nstderr: {4}\nExit code: {5}", messagePrefix, toolPath, arguments, stdout, stderr, process.ExitCode);
-
- return result;
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs.meta
deleted file mode 100644
index 2c3ff20e..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 2d0aa55f9a7d2440f871dfb256372a33
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinCommandLine.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinEditorCoroutine.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinEditorCoroutine.cs.meta
deleted file mode 100644
index c622babf..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinEditorCoroutine.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 95747c688378548eeb92aeb528ac96ff
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinEditorCoroutine.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs
deleted file mode 100644
index 7c1cdc86..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs
+++ /dev/null
@@ -1,146 +0,0 @@
-//
-// MaxInitialization.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Thomas So on 5/24/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-using System.Collections.Generic;
-using System.IO;
-using UnityEditor;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- [InitializeOnLoad]
- public class AppLovinInitialize
- {
- private static readonly List ObsoleteNetworks = new List
- {
- "AdColony",
- "Criteo",
- "Nend",
- "Snap",
- "Tapjoy",
- "VerizonAds",
- "VoodooAds"
- };
-
- private static readonly List ObsoleteFileExportPathsToDelete = new List
- {
- // The `MaxSdk/Scripts/Editor` folder contents have been moved into `MaxSdk/Scripts/IntegrationManager/Editor`.
- "MaxSdk/Scripts/Editor",
- "MaxSdk/Scripts/Editor.meta",
-
- // The `EventSystemChecker` has been renamed to `MaxEventSystemChecker`.
- "MaxSdk/Scripts/EventSystemChecker.cs",
- "MaxSdk/Scripts/EventSystemChecker.cs.meta",
-
- // Google AdMob adapter pre/post process scripts. The logic has been migrated to the main plugin.
- "MaxSdk/Mediation/Google/Editor/MaxGoogleInitialize.cs",
- "MaxSdk/Mediation/Google/Editor/MaxGoogleInitialize.cs.meta",
- "MaxSdk/Mediation/Google/Editor/MaxMediationGoogleUtils.cs",
- "MaxSdk/Mediation/Google/Editor/MaxMediationGoogleUtils.cs.meta",
- "MaxSdk/Mediation/Google/Editor/PostProcessor.cs",
- "MaxSdk/Mediation/Google/Editor/PostProcessor.cs.meta",
- "MaxSdk/Mediation/Google/Editor/PreProcessor.cs",
- "MaxSdk/Mediation/Google/Editor/PreProcessor.cs.meta",
- "MaxSdk/Mediation/Google/Editor/MaxSdk.Mediation.Google.Editor.asmdef",
- "MaxSdk/Mediation/Google/MaxSdk.Mediation.Google.Editor.asmdef.meta",
- "Plugins/Android/MaxMediationGoogle.androidlib",
- "Plugins/Android/MaxMediationGoogle.androidlib.meta",
-
- // Google Ad Manager adapter pre/post process scripts. The logic has been migrated to the main plugin.
- "MaxSdk/Mediation/GoogleAdManager/Editor/MaxGoogleAdManagerInitialize.cs",
- "MaxSdk/Mediation/GoogleAdManager/Editor/MaxGoogleAdManagerInitialize.cs.meta",
- "MaxSdk/Mediation/GoogleAdManager/Editor/PostProcessor.cs",
- "MaxSdk/Mediation/GoogleAdManager/Editor/PostProcessor.cs.meta",
- "MaxSdk/Mediation/GoogleAdManager/Editor/MaxSdk.Mediation.GoogleAdManager.Editor.asmdef",
- "MaxSdk/Mediation/GoogleAdManager/Editor/MaxSdk.Mediation.GoogleAdManager.Editor.asmdef.meta",
- "Plugins/Android/MaxMediationGoogleAdManager.androidlib",
- "Plugins/Android/MaxMediationGoogleAdManager.androidlib.meta",
-
- // The `VariableService` has been removed.
- "MaxSdk/Scripts/MaxVariableServiceAndroid.cs",
- "MaxSdk/Scripts/MaxVariableServiceAndroid.cs.meta",
- "MaxSdk/Scripts/MaxVariableServiceiOS.cs",
- "MaxSdk/Scripts/MaxVariableServiceiOS.cs.meta",
- "MaxSdk/Scripts/MaxVariableServiceUnityEditor.cs",
- "MaxSdk/Scripts/MaxVariableServiceUnityEditor.cs.meta",
-
- // The `MaxSdk/Scripts/Editor` folder contents have been moved into `MaxSdk/Scripts/IntegrationManager/Editor`.
- "MaxSdk/Version.md",
- "MaxSdk/Version.md.meta",
-
- // The alert_icon.png has been renamed to error_icon.png.
- "MaxSdk/Resources/Images/alert_icon.png",
- "MaxSdk/Resources/Images/alert_icon.png.meta",
-
- // `TargetingData` has been removed and we no longer set `UserSegment` through the Unity Plugin.
- "MaxSdk/Scripts/MaxUserSegment.cs",
- "MaxSdk/Scripts/MaxUserSegment.cs.meta",
- "MaxSdk/Scripts/MaxTargetingData.cs",
- "MaxSdk/Scripts/MaxTargetingData.cs.meta"
- };
-
- static AppLovinInitialize()
- {
- // Don't run obsolete file cleanup logic when entering play mode.
- if (EditorApplication.isPlayingOrWillChangePlaymode) return;
-
-#if UNITY_IOS
- // Check that the publisher is targeting iOS 9.0+
- if (!PlayerSettings.iOS.targetOSVersionString.StartsWith("9.") && !PlayerSettings.iOS.targetOSVersionString.StartsWith("1"))
- {
- MaxSdkLogger.UserError("Detected iOS project version less than iOS 9 - The AppLovin MAX SDK WILL NOT WORK ON < iOS9!!!");
- }
-#endif
-
- var isPluginInPackageManager = AppLovinIntegrationManager.IsPluginInPackageManager;
- if (!isPluginInPackageManager)
- {
- var changesMade = false;
- foreach (var obsoleteFileExportPathToDelete in ObsoleteFileExportPathsToDelete)
- {
- var pathToDelete = MaxSdkUtils.GetAssetPathForExportPath(obsoleteFileExportPathToDelete);
- if (CheckExistence(pathToDelete))
- {
- MaxSdkLogger.UserDebug("Deleting obsolete file '" + pathToDelete + "' that is no longer needed.");
- FileUtil.DeleteFileOrDirectory(pathToDelete);
- changesMade = true;
- }
- }
-
- var pluginParentDir = AppLovinIntegrationManager.PluginParentDirectory;
- // Check if any obsolete networks are installed
- foreach (var obsoleteNetwork in ObsoleteNetworks)
- {
- var networkDir = Path.Combine(pluginParentDir, "MaxSdk/Mediation/" + obsoleteNetwork);
- if (CheckExistence(networkDir))
- {
- MaxSdkLogger.UserDebug("Deleting obsolete network " + obsoleteNetwork + " from path " + networkDir + "...");
- FileUtil.DeleteFileOrDirectory(networkDir);
- FileUtil.DeleteFileOrDirectory(networkDir + ".meta");
- changesMade = true;
- }
- }
-
- // Refresh UI
- if (changesMade)
- {
- AssetDatabase.Refresh();
- MaxSdkLogger.UserDebug("Obsolete networks and files removed.");
- }
- }
-
- AppLovinAutoUpdater.Update();
- }
-
- private static bool CheckExistence(string location)
- {
- return File.Exists(location) ||
- Directory.Exists(location) ||
- (location.EndsWith("/*") && Directory.Exists(Path.GetDirectoryName(location)));
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs.meta
deleted file mode 100644
index fb8a55c2..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 6b7dce7fe193a4058bc51d9f4d3a2aed
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInitialize.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs
deleted file mode 100644
index 236b9526..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs
+++ /dev/null
@@ -1,525 +0,0 @@
-//
-// MaxIntegrationManager.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 6/1/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-using System;
-using System.Collections;
-using System.IO;
-using AppLovinMax.Internal;
-using UnityEditor;
-using UnityEngine;
-using UnityEngine.Networking;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- [Serializable]
- public class PluginData
- {
- // ReSharper disable InconsistentNaming - Consistent with JSON data.
- public Network AppLovinMax;
- public Network[] MediatedNetworks;
- public Network[] PartnerMicroSdks;
- public DynamicLibraryToEmbed[] ThirdPartyDynamicLibrariesToEmbed;
- public Alert[] Alerts;
- }
-
- [Serializable]
- public class Network
- {
- //
- // Sample network data:
- //
- // {
- // "Name": "adcolony",
- // "DisplayName": "AdColony",
- // "DownloadUrl": "https://bintray.com/applovin/Unity-Mediation-Packages/download_file?file_path=AppLovin-AdColony-Adapters-Android-3.3.10.1-iOS-3.3.7.2.unitypackage",
- // "PluginFileName": "AppLovin-AdColony-Adapters-Android-3.3.10.1-iOS-3.3.7.2.unitypackage",
- // "DependenciesFilePath": "MaxSdk/Mediation/AdColony/Editor/Dependencies.xml",
- // "LatestVersions" : {
- // "Unity": "android_3.3.10.1_ios_3.3.7.2",
- // "Android": "3.3.10.1",
- // "Ios": "3.3.7.2"
- // }
- // }
- //
-
- // ReSharper disable InconsistentNaming - Consistent with JSON data.
- public string Name;
- public string DisplayName;
- public string DownloadUrl;
- public string DependenciesFilePath;
- public PackageInfo[] Packages;
- public string[] PluginFilePaths;
- public Versions LatestVersions;
- public DynamicLibraryToEmbed[] DynamicLibrariesToEmbed;
-
- [NonSerialized] public Versions CurrentVersions;
- [NonSerialized] public MaxSdkUtils.VersionComparisonResult CurrentToLatestVersionComparisonResult = MaxSdkUtils.VersionComparisonResult.Lesser;
- [NonSerialized] public bool RequiresUpdate;
- [NonSerialized] public bool IsCurrentlyInstalling;
- }
-
- [Serializable]
- public class DynamicLibraryToEmbed
- {
- // ReSharper disable InconsistentNaming - Consistent with JSON data.
- public string PodName;
- public string[] FrameworkNames;
-
- // Min and max versions are inclusive, so if the adapter is the min or max version, the xcframework will get embedded.
- public string MinVersion;
- public string MaxVersion;
-
- public DynamicLibraryToEmbed(string podName, string[] frameworkNames, string minVersion, string maxVersion)
- {
- PodName = podName;
- FrameworkNames = frameworkNames;
- MinVersion = minVersion;
- MaxVersion = maxVersion;
- }
- }
-
- public enum Severity
- {
- Info,
- Warning,
- Error
- }
-
- [Serializable]
- public class Alert
- {
- public string SeverityType;
- public string Title;
- public string Message;
- public string Url;
- public string MinimumPluginVersion;
- public string MaximumPluginVersion;
- public string MinimumUnityVersion;
- public string MaximumUnityVersion;
-
- public Severity Severity;
-
- public void InitializeSeverityEnum()
- {
- switch (SeverityType)
- {
- case "INFO":
- Severity = Severity.Info;
- break;
- case "WARNING":
- Severity = Severity.Warning;
- break;
- case "ERROR":
- Severity = Severity.Error;
- break;
- default:
- MaxSdkLogger.E(string.Format("Alert <{0}> has unsupported severity type <{1}>.", Title, SeverityType));
- Severity = Severity.Info;
- break;
- }
- }
-
- public bool ShouldShowAlert()
- {
- var pluginVersionValid = MaxSdkUtils.IsVersionInRange(MaxSdk.Version, MinimumPluginVersion, MaximumPluginVersion);
- var unityVersionValid = MaxSdkUtils.IsVersionInRange(Application.unityVersion, MinimumUnityVersion, MaximumUnityVersion);
- return pluginVersionValid && unityVersionValid;
- }
- }
-
- ///
- /// A helper data class used to get current versions from Dependency.xml files.
- ///
- [Serializable]
- public class Versions
- {
- // ReSharper disable InconsistentNaming - Consistent with JSON data.
- public string Unity;
- public string Android;
- public string Ios;
-
- public override bool Equals(object value)
- {
- var versions = value as Versions;
-
- return versions != null
- && Unity.Equals(versions.Unity)
- && (Android == null || Android.Equals(versions.Android))
- && (Ios == null || Ios.Equals(versions.Ios));
- }
-
- public bool HasEqualSdkVersions(Versions versions)
- {
- return versions != null
- && AdapterSdkVersion(Android).Equals(AdapterSdkVersion(versions.Android))
- && AdapterSdkVersion(Ios).Equals(AdapterSdkVersion(versions.Ios));
- }
-
- public override int GetHashCode()
- {
- return new {unity = Unity, android = Android, ios = Ios}.GetHashCode();
- }
-
- private static string AdapterSdkVersion(string adapterVersion)
- {
- if (string.IsNullOrEmpty(adapterVersion)) return "";
-
- var index = adapterVersion.LastIndexOf(".", StringComparison.Ordinal);
- return index > 0 ? adapterVersion.Substring(0, index) : adapterVersion;
- }
- }
-
- ///
- /// A manager class for MAX integration manager window.
- ///
- public class AppLovinIntegrationManager
- {
- ///
- /// Delegate to be called when a plugin package's import is started.
- ///
- internal delegate void ImportPackageStartedCallback(Network network);
-
- ///
- /// Delegate to be called when a plugin package is finished importing.
- ///
- /// The network data for which the package is imported.
- internal delegate void ImportPackageCompletedCallback(Network network);
-
- private static readonly AppLovinIntegrationManager instance = new AppLovinIntegrationManager();
-
- internal static readonly string GradleTemplatePath = Path.Combine("Assets/Plugins/Android", "mainTemplate.gradle");
- private const string MaxSdkAssetExportPath = "MaxSdk/Scripts/MaxSdk.cs";
- private const string MaxSdkMediationExportPath = "MaxSdk/Mediation";
-
- private const string PluginDataEndpoint = "https://unity.applovin.com/max/1.0/integration_manager_info?plugin_version={0}";
-
- private static string externalDependencyManagerVersion;
-
- internal static ImportPackageStartedCallback OnImportPackageStartedCallback;
- internal static ImportPackageCompletedCallback OnImportPackageCompletedCallback;
-
- private MaxWebRequest maxWebRequest;
- private Network importingNetwork;
-
- ///
- /// An Instance of the Integration manager.
- ///
- public static AppLovinIntegrationManager Instance
- {
- get { return instance; }
- }
-
- ///
- /// The parent directory path where the MaxSdk plugin directory is placed.
- ///
- public static string PluginParentDirectory
- {
- get
- {
- // Search for the asset with the export path label.
- // Paths are normalized using AltDirectorySeparatorChar (/) to ensure compatibility across platforms (in case of migrating a project from Windows to Mac or vice versa).
- var maxSdkScriptAssetPath = MaxSdkUtils.GetAssetPathForExportPath(MaxSdkAssetExportPath);
-
- // maxSdkScriptAssetPath will always have AltDirectorySeparatorChar (/) as the path separator. Convert to platform specific path.
- return maxSdkScriptAssetPath.Replace(MaxSdkAssetExportPath, "")
- .Replace(Path.AltDirectorySeparatorChar, Path.DirectorySeparatorChar);
- }
- }
-
- public static string MediationDirectory
- {
- get
- {
- var mediationAssetPath = MaxSdkUtils.GetAssetPathForExportPath(MaxSdkMediationExportPath);
- return mediationAssetPath.Replace(Path.AltDirectorySeparatorChar, Path.DirectorySeparatorChar);
- }
- }
-
- ///
- /// Whether or not the plugin is in the Unity Package Manager.
- ///
- public static bool IsPluginInPackageManager
- {
- get { return PluginParentDirectory.StartsWith("Packages"); }
- }
-
- ///
- /// Whether or not gradle build system is enabled.
- ///
- public static bool GradleBuildEnabled
- {
- get { return GetEditorUserBuildSetting("androidBuildSystem", "").ToString().Equals("Gradle"); }
- }
-
- ///
- /// Whether or not Gradle template is enabled.
- ///
- public static bool GradleTemplateEnabled
- {
- get { return GradleBuildEnabled && File.Exists(GradleTemplatePath); }
- }
-
- ///
- /// Whether or not the Quality Service settings can be processed which requires Gradle template enabled or Unity IDE newer than version 2018_2.
- ///
- public static bool CanProcessAndroidQualityServiceSettings
- {
- get { return GradleTemplateEnabled || GradleBuildEnabled; }
- }
-
- ///
- /// The External Dependency Manager version obtained dynamically.
- ///
- public static string ExternalDependencyManagerVersion
- {
- get
- {
- if (MaxSdkUtils.IsValidString(externalDependencyManagerVersion)) return externalDependencyManagerVersion;
-
- try
- {
- var versionHandlerVersionNumberType = Type.GetType("Google.VersionHandlerVersionNumber, Google.VersionHandlerImpl");
- externalDependencyManagerVersion = versionHandlerVersionNumberType.GetProperty("Value").GetValue(null, null).ToString();
- }
-#pragma warning disable 0168
- catch (Exception ignored)
-#pragma warning restore 0168
- {
- externalDependencyManagerVersion = "Failed to get version.";
- }
-
- return externalDependencyManagerVersion;
- }
- }
-
- private AppLovinIntegrationManager()
- {
- AssetDatabase.importPackageStarted += packageName =>
- {
- if (!IsImportingNetwork(packageName)) return;
-
- CallImportPackageStartedCallback(importingNetwork);
- };
-
- // Add asset import callbacks.
- AssetDatabase.importPackageCompleted += packageName =>
- {
- if (!IsImportingNetwork(packageName)) return;
-
- AssetDatabase.Refresh();
-
- CallImportPackageCompletedCallback(importingNetwork);
- importingNetwork = null;
- };
-
- AssetDatabase.importPackageCancelled += packageName =>
- {
- if (!IsImportingNetwork(packageName)) return;
-
- importingNetwork = null;
- };
-
- AssetDatabase.importPackageFailed += (packageName, errorMessage) =>
- {
- if (!IsImportingNetwork(packageName)) return;
-
- MaxSdkLogger.UserError(errorMessage);
- importingNetwork = null;
- };
- }
-
- static AppLovinIntegrationManager() { }
-
- public static PluginData LoadPluginDataSync()
- {
- var url = string.Format(PluginDataEndpoint, MaxSdk.Version);
- var webRequestConfig = new WebRequestConfig()
- {
- EndPoint = url,
- };
-
- var maxWebRequest = new MaxWebRequest(webRequestConfig);
- var webResponse = maxWebRequest.SendSync();
-
- return CreatePluginDataFromWebResponse(webResponse);
- }
-
- ///
- /// Loads the plugin data to be display by integration manager window.
- ///
- /// Callback to be called once the plugin data download completes.
- public IEnumerator LoadPluginData(Action callback)
- {
- var url = string.Format(PluginDataEndpoint, MaxSdk.Version);
- var webRequestConfig = new WebRequestConfig()
- {
- EndPoint = url,
- };
-
- maxWebRequest = new MaxWebRequest(webRequestConfig);
- yield return maxWebRequest.Send(webResponse =>
- {
- var pluginData = CreatePluginDataFromWebResponse(webResponse);
- callback(pluginData);
- });
- }
-
- private static PluginData CreatePluginDataFromWebResponse(WebResponse webResponse)
- {
- if (!webResponse.IsSuccess)
- {
- MaxSdkLogger.E("Failed to load plugin data. Please check your internet connection.");
- return null;
- }
-
- PluginData pluginData;
- try
- {
- pluginData = JsonUtility.FromJson(webResponse.ResponseMessage);
- AppLovinPackageManager.PluginData = pluginData;
- }
- catch (Exception exception)
- {
- Console.WriteLine(exception);
- pluginData = null;
- }
-
- if (pluginData == null) return null;
-
- // Get current version of the plugin
- var appLovinMax = pluginData.AppLovinMax;
- AppLovinPackageManager.UpdateCurrentVersions(appLovinMax);
-
- // Get current versions for all the mediation networks.
- foreach (var network in pluginData.MediatedNetworks)
- {
- AppLovinPackageManager.UpdateCurrentVersions(network);
- }
-
- if (pluginData.PartnerMicroSdks != null)
- {
- foreach (var partnerMicroSdk in pluginData.PartnerMicroSdks)
- {
- AppLovinPackageManager.UpdateCurrentVersions(partnerMicroSdk);
- }
- }
-
- if (pluginData.Alerts == null) return pluginData;
-
- // Initiate Severity enums from the raw strings in the response
- foreach (var alert in pluginData.Alerts)
- {
- alert.InitializeSeverityEnum();
- }
-
- return pluginData;
- }
-
- ///
- /// Downloads the plugin file for a given network.
- ///
- /// Network for which to download the current version.
- /// Whether or not to show the import window when downloading. Defaults to true.
- ///
- public IEnumerator DownloadPlugin(Network network, bool showImport = true)
- {
- var path = Path.Combine(Application.temporaryCachePath, GetPluginFileName(network)); // TODO: Maybe delete plugin file after finishing import.
- var webRequestConfig = new WebRequestConfig()
- {
- DownloadHandler = new DownloadHandlerFile(path),
- EndPoint = network.DownloadUrl
- };
-
- maxWebRequest = new MaxWebRequest(webRequestConfig);
- yield return maxWebRequest.Send(webResponse =>
- {
- if (webResponse.IsSuccess)
- {
- importingNetwork = network;
- AssetDatabase.ImportPackage(path, showImport);
- }
- else
- {
- MaxSdkLogger.UserError("Failed to download plugin package: " + webResponse.ErrorMessage);
- }
- });
- }
-
- ///
- /// Cancels the plugin download if one is in progress.
- ///
- public void CancelDownload()
- {
- if (maxWebRequest == null) return;
-
- maxWebRequest.Abort();
- }
-
- ///
- /// Shows a dialog to the user with the given message and logs the error message to console.
- ///
- /// The failure message to be shown to the user.
- public static void ShowBuildFailureDialog(string message)
- {
- var openIntegrationManager = EditorUtility.DisplayDialog("AppLovin MAX", message, "Open Integration Manager", "Dismiss");
- if (openIntegrationManager)
- {
- AppLovinIntegrationManagerWindow.ShowManager();
- }
-
- MaxSdkLogger.UserError(message);
- }
-
- #region Utility Methods
-
- ///
- /// Checks whether or not the given package name is the currently importing package.
- ///
- /// The name of the package that needs to be checked.
- /// true if the importing package matches the given package name.
- private bool IsImportingNetwork(string packageName)
- {
- // Note: The pluginName doesn't have the '.unitypackage' extension included in its name but the pluginFileName does. So using Contains instead of Equals.
- return importingNetwork != null && GetPluginFileName(importingNetwork).Contains(packageName);
- }
-
- private static void CallImportPackageStartedCallback(Network network)
- {
- if (OnImportPackageStartedCallback == null) return;
-
- OnImportPackageStartedCallback(network);
- }
-
- private static void CallImportPackageCompletedCallback(Network network)
- {
- if (OnImportPackageCompletedCallback == null) return;
-
- OnImportPackageCompletedCallback(network);
- }
-
- private static object GetEditorUserBuildSetting(string name, object defaultValue)
- {
- var editorUserBuildSettingsType = typeof(EditorUserBuildSettings);
- var property = editorUserBuildSettingsType.GetProperty(name);
- if (property != null)
- {
- var value = property.GetValue(null, null);
- if (value != null) return value;
- }
-
- return defaultValue;
- }
-
- private static string GetPluginFileName(Network network)
- {
- return network.Name.ToLowerInvariant() + "_" + network.LatestVersions.Unity + ".unitypackage";
- }
-
- #endregion
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs.meta
deleted file mode 100644
index e9e36030..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: c5b874c1e65274159bcc0dc15d9458cc
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManager.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs
deleted file mode 100644
index 6f50f254..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs
+++ /dev/null
@@ -1,80 +0,0 @@
-using System;
-using System.Linq;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public static class AppLovinIntegrationManagerUtils
- {
- ///
- /// Compares AppLovin MAX Unity mediation adapter plugin versions. Returns , ,
- /// or as the first version is less than, equal to, or greater than the second.
- ///
- /// If a version for a specific platform is only present in one of the provided versions, the one that contains it is considered newer.
- ///
- /// The first version to be compared.
- /// The second version to be compared.
- ///
- /// if versionA is less than versionB.
- /// if versionA and versionB are equal.
- /// if versionA is greater than versionB.
- ///
- internal static MaxSdkUtils.VersionComparisonResult CompareUnityMediationVersions(string versionA, string versionB)
- {
- if (versionA.Equals(versionB)) return MaxSdkUtils.VersionComparisonResult.Equal;
-
- // Unity version would be of format: android_w.x.y.z_ios_a.b.c.d
- // For Android only versions it would be: android_w.x.y.z
- // For iOS only version it would be: ios_a.b.c.d
-
- // After splitting into their respective components, the versions would be at the odd indices.
- var versionAComponents = versionA.Split('_').ToList();
- var versionBComponents = versionB.Split('_').ToList();
-
- var androidComparison = MaxSdkUtils.VersionComparisonResult.Equal;
- if (versionA.Contains("android") && versionB.Contains("android"))
- {
- var androidVersionA = versionAComponents[1];
- var androidVersionB = versionBComponents[1];
- androidComparison = MaxSdkUtils.CompareVersions(androidVersionA, androidVersionB);
-
- // Remove the Android version component so that iOS versions can be processed.
- versionAComponents.RemoveRange(0, 2);
- versionBComponents.RemoveRange(0, 2);
- }
- else if (versionA.Contains("android"))
- {
- androidComparison = MaxSdkUtils.VersionComparisonResult.Greater;
-
- // Remove the Android version component so that iOS versions can be processed.
- versionAComponents.RemoveRange(0, 2);
- }
- else if (versionB.Contains("android"))
- {
- androidComparison = MaxSdkUtils.VersionComparisonResult.Lesser;
-
- // Remove the Android version component so that iOS version can be processed.
- versionBComponents.RemoveRange(0, 2);
- }
-
- var iosComparison = MaxSdkUtils.VersionComparisonResult.Equal;
- if (versionA.Contains("ios") && versionB.Contains("ios"))
- {
- var iosVersionA = versionAComponents[1];
- var iosVersionB = versionBComponents[1];
- iosComparison = MaxSdkUtils.CompareVersions(iosVersionA, iosVersionB);
- }
- else if (versionA.Contains("ios"))
- {
- iosComparison = MaxSdkUtils.VersionComparisonResult.Greater;
- }
- else if (versionB.Contains("ios"))
- {
- iosComparison = MaxSdkUtils.VersionComparisonResult.Lesser;
- }
-
- // If either one of the Android or iOS version is greater, the entire version should be greater.
- return (androidComparison == MaxSdkUtils.VersionComparisonResult.Greater || iosComparison == MaxSdkUtils.VersionComparisonResult.Greater) ? MaxSdkUtils.VersionComparisonResult.Greater : MaxSdkUtils.VersionComparisonResult.Lesser;
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs.meta
deleted file mode 100644
index 9efcdd90..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 96efb4dba39eb48d2a60afab69786e6a
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerUtils.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs
deleted file mode 100644
index 244a76aa..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs
+++ /dev/null
@@ -1,1199 +0,0 @@
-//
-// MaxIntegrationManager.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 5/27/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-using System;
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using UnityEditor;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public class AppLovinIntegrationManagerWindow : EditorWindow
- {
- private const string WindowTitle = "AppLovin Integration Manager";
-
- private const string AppLovinSdkKeyLink = "https://dash.applovin.com/o/account#keys";
-
- private const string UserTrackingUsageDescriptionDocsLink = "https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription";
- private const string DocumentationTermsAndPrivacyPolicyFlow = "https://support.axon.ai/en/max/unity/overview/terms-and-privacy-policy-flow";
- private const string DocumentationAdaptersLink = "https://support.axon.ai/en/max/unity/preparing-mediated-networks";
- private const string DocumentationNote = "Please ensure that integration instructions (e.g. permissions, ATS settings, etc) specific to each network are implemented as well. Click the link below for more info:";
- private const string UninstallIconExportPath = "MaxSdk/Resources/Images/uninstall_icon.png";
- private const string InfoIconExportPath = "MaxSdk/Resources/Images/info_icon.png";
- private const string WarningIconExportPath = "MaxSdk/Resources/Images/warning_icon.png";
- private const string ErrorIconExportPath = "MaxSdk/Resources/Images/error_icon.png";
-
- private const string QualityServiceRequiresGradleBuildErrorMsg = "AppLovin Quality Service integration via AppLovin Integration Manager requires Custom Gradle Template enabled or Unity 2018.2 or higher.\n" +
- "If you would like to continue using your existing setup, please add Quality Service Plugin to your build.gradle manually.";
-
- private const string CustomGradleVersionTooltip = "To set the version to 6.9.3, set the field to: https://services.gradle.org/distributions/gradle-6.9.3-bin.zip";
- private const string CustomGradleToolsVersionTooltip = "To set the version to 4.2.0, set the field to: 4.2.0";
-
- private const string KeyShowAlerts = "com.applovin.show_alerts";
- private const string KeyShowMicroSdkPartners = "com.applovin.show_micro_sdk_partners";
- private const string KeyShowMediatedNetworks = "com.applovin.show_mediated_networks";
- private const string KeyShowSdkSettings = "com.applovin.show_sdk_settings";
- private const string KeyShowPrivacySettings = "com.applovin.show_privacy_settings";
- private const string KeyShowOtherSettings = "com.applovin.show_other_settings";
-
- private const string ExpandButtonText = "+";
- private const string CollapseButtonText = "-";
-
- private const string ExternalDependencyManagerPath = "Assets/ExternalDependencyManager";
-
- private readonly string[] debugUserGeographies = new string[2] {"Not Set", "GDPR"};
-
- private Vector2 scrollPosition;
- private static readonly Vector2 WindowMinSize = new Vector2(750, 750);
- private const float ActionFieldWidth = 70f;
- private const float UpgradeAllButtonWidth = 80f;
- private const float NetworkFieldMinWidth = 100f;
- private const float VersionFieldMinWidth = 190f;
- private const float PrivacySettingLabelWidth = 250f;
- private const float NetworkFieldWidthPercentage = 0.22f;
- private const float VersionFieldWidthPercentage = 0.36f; // There are two version fields. Each take 40% of the width, network field takes the remaining 20%.
- private static float previousWindowWidth = WindowMinSize.x;
- private static GUILayoutOption networkWidthOption = GUILayout.Width(NetworkFieldMinWidth);
- private static GUILayoutOption versionWidthOption = GUILayout.Width(VersionFieldMinWidth);
-
- private static GUILayoutOption privacySettingFieldWidthOption = GUILayout.Width(400);
- private static readonly GUILayoutOption FieldWidth = GUILayout.Width(ActionFieldWidth);
- private static readonly GUILayoutOption UpgradeAllButtonFieldWidth = GUILayout.Width(UpgradeAllButtonWidth);
- private static readonly GUILayoutOption CollapseButtonWidthOption = GUILayout.Width(20f);
-
- private static readonly Color DarkModeTextColor = new Color(0.29f, 0.6f, 0.8f);
-
- private GUIStyle titleLabelStyle;
- private GUIStyle headerLabelStyle;
- private GUIStyle environmentValueStyle;
- private GUIStyle wrapTextLabelStyle;
- private GUIStyle linkLabelStyle;
- private GUIStyle iconStyle;
-
- private PluginData pluginData;
- private bool pluginDataLoadFailed;
- private bool shouldShowGoogleWarning;
- private bool networkButtonsEnabled = true;
-
- private AppLovinEditorCoroutine loadDataCoroutine;
- private Texture2D uninstallIcon;
- private Texture2D infoIcon;
- private Texture2D warningIcon;
- private Texture2D errorIcon;
-
- public static void ShowManager()
- {
- var manager = GetWindow(utility: true, title: WindowTitle, focus: true);
- manager.minSize = WindowMinSize;
- }
-
- #region Editor Window Lifecyle Methods
-
- private void Awake()
- {
- titleLabelStyle = new GUIStyle(EditorStyles.label)
- {
- fontSize = 14,
- fontStyle = FontStyle.Bold,
- fixedHeight = 20
- };
-
- headerLabelStyle = new GUIStyle(EditorStyles.label)
- {
- fontSize = 12,
- fontStyle = FontStyle.Bold,
- fixedHeight = 18
- };
-
- environmentValueStyle = new GUIStyle(EditorStyles.label)
- {
- alignment = TextAnchor.MiddleRight
- };
-
- linkLabelStyle = new GUIStyle(EditorStyles.label)
- {
- wordWrap = true,
- normal = {textColor = EditorGUIUtility.isProSkin ? DarkModeTextColor : Color.blue}
- };
-
- wrapTextLabelStyle = new GUIStyle(EditorStyles.label)
- {
- wordWrap = true
- };
-
- iconStyle = new GUIStyle(EditorStyles.miniButton)
- {
- fixedWidth = 18,
- fixedHeight = 18,
- padding = new RectOffset(1, 1, 1, 1)
- };
-
- // Load uninstall icon texture.
- var uninstallIconData = File.ReadAllBytes(MaxSdkUtils.GetAssetPathForExportPath(UninstallIconExportPath));
- // 1. Set the initial size to 1, as Unity 6000 no longer supports a width or height of 0.
- // 2. The image will be automatically resized once the image asset is loaded.
- // 3. Set mipChain to false, else the texture has a weird blurry effect.
- uninstallIcon = new Texture2D(1, 1, TextureFormat.RGBA32, false);
- uninstallIcon.LoadImage(uninstallIconData);
-
- // Load info icon texture.
- var infoIconData = File.ReadAllBytes(MaxSdkUtils.GetAssetPathForExportPath(InfoIconExportPath));
- infoIcon = new Texture2D(1, 1, TextureFormat.RGBA32, false);
- infoIcon.LoadImage(infoIconData);
-
- // Load warning icon texture.
- var warningIconData = File.ReadAllBytes(MaxSdkUtils.GetAssetPathForExportPath(WarningIconExportPath));
- warningIcon = new Texture2D(1, 1, TextureFormat.RGBA32, false);
- warningIcon.LoadImage(warningIconData);
-
- // Load error icon texture.
- var errorIconData = File.ReadAllBytes(MaxSdkUtils.GetAssetPathForExportPath(ErrorIconExportPath));
- errorIcon = new Texture2D(1, 1, TextureFormat.RGBA32, false);
- errorIcon.LoadImage(errorIconData);
- }
-
- private void OnEnable()
- {
- // Script reloads can cause AppLovinSettings.Instance to be null for one frame,
- // so we load the Integration Manager on the following frame
- if (AppLovinSettings.Instance == null)
- {
- AppLovinEditorCoroutine.StartCoroutine(WaitForNextFrameForEnable());
- }
- else
- {
- OnWindowEnabled();
- }
- }
-
- private IEnumerator WaitForNextFrameForEnable()
- {
- yield return new WaitForEndOfFrame();
- OnWindowEnabled();
- }
-
- private void OnWindowEnabled()
- {
- // Plugin downloaded and imported. Update current versions for the imported package.
- AppLovinIntegrationManager.OnImportPackageStartedCallback = OnImportPackageStarted;
- AppLovinIntegrationManager.OnImportPackageCompletedCallback = OnImportPackageCompleted;
-
- Load();
- }
-
- private void OnDisable()
- {
- if (loadDataCoroutine != null)
- {
- loadDataCoroutine.Stop();
- loadDataCoroutine = null;
- }
-
- AppLovinIntegrationManager.Instance.CancelDownload();
- EditorUtility.ClearProgressBar();
-
- // Saves the AppLovinSettings object if it has been changed.
- AssetDatabase.SaveAssets();
- }
-
- private void OnGUI()
- {
- // OnGUI is called on each frame draw, so we don't want to do any unnecessary calculation if we can avoid it. So only calculate it when the width actually changed.
- if (Math.Abs(previousWindowWidth - position.width) > 1)
- {
- previousWindowWidth = position.width;
- CalculateFieldWidth();
- }
-
- using (var scrollView = new EditorGUILayout.ScrollViewScope(scrollPosition, false, false))
- {
- scrollPosition = scrollView.scrollPosition;
-
- GUILayout.Space(5);
-
- // Draw AppLovin MAX plugin details
- EditorGUILayout.LabelField("AppLovin MAX Plugin Details", titleLabelStyle);
- DrawPluginDetails();
-
- // Draw alerts
- if (pluginData != null && pluginData.Alerts != null)
- {
- var alertsToShow = pluginData.Alerts.Where(alert => alert.ShouldShowAlert()).ToList();
- if (alertsToShow.Count > 0)
- {
- EditorGUILayout.BeginHorizontal();
- var showAlertDetails = DrawExpandCollapseButton(KeyShowAlerts);
- EditorGUILayout.LabelField("Alerts", titleLabelStyle, GUILayout.Width(45));
- DrawAlertCount(alertsToShow);
- GUILayout.FlexibleSpace();
- EditorGUILayout.EndHorizontal();
- if (showAlertDetails)
- {
- DrawAlerts(alertsToShow);
- }
- }
- }
-
- // Draw Micro SDK Partners
- if (pluginData != null && !MaxSdkUtils.IsNullOrEmpty(pluginData.PartnerMicroSdks))
- {
- DrawCollapsibleSection(KeyShowMicroSdkPartners, "AppLovin Micro SDK Partners", DrawPartnerMicroSdks);
- }
-
- // Draw mediated networks);
- EditorGUILayout.BeginHorizontal();
- var showDetails = DrawExpandCollapseButton(KeyShowMediatedNetworks);
- EditorGUILayout.LabelField("Mediated Networks", titleLabelStyle);
- GUILayout.FlexibleSpace();
- DrawUpgradeAllButton();
- EditorGUILayout.EndHorizontal();
- if (showDetails)
- {
- DrawMediatedNetworks();
- }
-
- if (!AppLovinIntegrationManager.IsPluginInPackageManager)
- {
- EditorGUILayout.LabelField("Unity Package Manager Migration", titleLabelStyle);
- DrawPluginMigrationHelper();
- }
-
- // Draw AppLovin Quality Service settings
- DrawCollapsibleSection(KeyShowSdkSettings, "SDK Settings", DrawQualityServiceSettings);
-
- DrawCollapsibleSection(KeyShowPrivacySettings, "Privacy Settings", DrawPrivacySettings);
-
- DrawCollapsibleSection(KeyShowOtherSettings, "Other Settings", DrawOtherSettings);
-
- // Draw Unity environment details
- EditorGUILayout.LabelField("Unity Environment Details", titleLabelStyle);
- DrawUnityEnvironmentDetails();
-
- // Draw documentation notes
- EditorGUILayout.LabelField(new GUIContent(DocumentationNote), wrapTextLabelStyle);
- if (GUILayout.Button(new GUIContent(DocumentationAdaptersLink), linkLabelStyle))
- {
- Application.OpenURL(DocumentationAdaptersLink);
- }
- }
-
- if (GUI.changed)
- {
- AppLovinSettings.Instance.SaveAsync();
- AppLovinInternalSettings.Instance.Save();
- }
- }
-
- #endregion
-
- #region UI Methods
-
- ///
- /// Shows failure or loading screen based on whether or not plugin data failed to load.
- ///
- private void DrawEmptyPluginData()
- {
- GUILayout.Space(5);
-
- // Plugin data failed to load. Show error and retry button.
- if (pluginDataLoadFailed)
- {
- GUILayout.Space(10);
- GUILayout.BeginHorizontal();
- GUILayout.Space(5);
- EditorGUILayout.LabelField("Failed to load plugin data. Please click retry or restart the integration manager.", titleLabelStyle);
- if (GUILayout.Button("Retry", FieldWidth))
- {
- pluginDataLoadFailed = false;
- Load();
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- GUILayout.Space(10);
- }
- // Still loading, show loading label.
- else
- {
- GUILayout.Space(10);
- GUILayout.BeginHorizontal();
- GUILayout.FlexibleSpace();
- EditorGUILayout.LabelField("Loading data...", titleLabelStyle);
- GUILayout.FlexibleSpace();
- GUILayout.EndHorizontal();
- GUILayout.Space(10);
- }
-
- GUILayout.Space(5);
- }
-
- ///
- /// Draws AppLovin MAX plugin details.
- ///
- private void DrawPluginDetails()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- // Draw plugin version details
- DrawHeaders("Platform", false);
-
- // Immediately after downloading and importing a plugin the entire IDE reloads and current versions can be null in that case. Will just show loading text in that case.
- if (pluginData == null || pluginData.AppLovinMax.CurrentVersions == null)
- {
- DrawEmptyPluginData();
- }
- else
- {
- var appLovinMax = pluginData.AppLovinMax;
- // Check if a newer version is available to enable the upgrade button.
- var upgradeButtonEnabled = appLovinMax.CurrentToLatestVersionComparisonResult == MaxSdkUtils.VersionComparisonResult.Lesser;
- DrawPluginDetailRow("Unity 3D", appLovinMax.CurrentVersions.Unity, appLovinMax.LatestVersions.Unity);
- DrawPluginDetailRow("Android", appLovinMax.CurrentVersions.Android, appLovinMax.LatestVersions.Android);
- DrawPluginDetailRow("iOS", appLovinMax.CurrentVersions.Ios, appLovinMax.LatestVersions.Ios);
-
- // BeginHorizontal combined with FlexibleSpace makes sure that the button is centered horizontally.
- GUILayout.BeginHorizontal();
- GUILayout.FlexibleSpace();
-
- var action = appLovinMax.IsCurrentlyInstalling ? "Installing..." : "Upgrade";
-
- GUI.enabled = upgradeButtonEnabled && !appLovinMax.IsCurrentlyInstalling;
- if (GUILayout.Button(new GUIContent(action), FieldWidth))
- {
- // Only show "Installing..." if the plugin is in the Assets folder
- // Manifest edits don't trigger import callbacks, and UPM resolution locks the UI anyway.
- appLovinMax.IsCurrentlyInstalling = !AppLovinIntegrationManager.IsPluginInPackageManager;
- AppLovinEditorCoroutine.StartCoroutine(AppLovinPackageManager.AddNetwork(pluginData.AppLovinMax, true));
- }
-
- GUI.enabled = true;
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
-
- GUILayout.Space(5);
- }
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- ///
- /// Draw the number of each alert type next to the alert section header.
- ///
- private void DrawAlertCount(List alerts)
- {
- if (pluginData == null) return;
-
- var infoAlertsCount = alerts.Count(alert => alert.Severity == Severity.Info);
- var warningAlertsCount = alerts.Count(alert => alert.Severity == Severity.Warning);
- var errorAlertsCount = alerts.Count(alert => alert.Severity == Severity.Error);
-
- GUILayout.Label(infoIcon, GUILayout.Width(20), GUILayout.Height(20));
- EditorGUILayout.LabelField(AlertCountToString(infoAlertsCount), GUILayout.Width(20));
- GUILayout.Label(warningIcon, GUILayout.Width(20), GUILayout.Height(20));
- EditorGUILayout.LabelField(AlertCountToString(warningAlertsCount), GUILayout.Width(20));
- GUILayout.Label(errorIcon, GUILayout.Width(20), GUILayout.Height(20));
- EditorGUILayout.LabelField(AlertCountToString(errorAlertsCount), GUILayout.Width(20));
- }
-
- ///
- /// Draw the list of alerts grouped by severity.
- ///
- private void DrawAlerts(List alerts)
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- DrawAlertsOfType(alerts, Severity.Error);
- DrawAlertsOfType(alerts, Severity.Warning);
- DrawAlertsOfType(alerts, Severity.Info);
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private void DrawAlertsOfType(List alerts, Severity severity)
- {
- var alertsOfType = alerts.Where(alert => alert.Severity == severity).ToList();
- foreach (var alert in alertsOfType)
- {
- DrawAlert(alert);
- }
- }
-
- ///
- /// Draw a single alert.
- ///
- private void DrawAlert(Alert alert)
- {
- using (new EditorGUILayout.HorizontalScope())
- {
- using (new EditorGUILayout.VerticalScope(GUILayout.Width(20)))
- {
- GUILayout.Space(2);
- GUILayout.Label(GetSeverityIcon(alert.Severity), GUILayout.Width(20), GUILayout.Height(20));
- }
-
- using (new EditorGUILayout.VerticalScope())
- {
- GUILayout.Label(alert.Title, headerLabelStyle);
- EditorGUILayout.LabelField(alert.Message, wrapTextLabelStyle);
- if (MaxSdkUtils.IsValidString(alert.Url))
- {
- if (GUILayout.Button(new GUIContent(alert.Url), linkLabelStyle))
- {
- Application.OpenURL(alert.Url);
- }
- }
-
- GUILayout.Space(2);
- }
- }
-
- GUILayout.Space(10);
- }
-
- ///
- /// Draws the headers for a table.
- ///
- private void DrawHeaders(string firstColumnTitle, bool drawAction)
- {
- using (new EditorGUILayout.HorizontalScope())
- {
- GUILayout.Space(5);
- EditorGUILayout.LabelField(firstColumnTitle, headerLabelStyle, networkWidthOption);
- EditorGUILayout.LabelField("Current Version", headerLabelStyle, versionWidthOption);
- GUILayout.Space(3);
- EditorGUILayout.LabelField("Latest Version", headerLabelStyle, versionWidthOption);
- GUILayout.Space(3);
- if (drawAction)
- {
- GUILayout.FlexibleSpace();
- GUILayout.Button("Actions", headerLabelStyle, FieldWidth);
- GUILayout.Space(5);
- }
- }
-
- GUILayout.Space(4);
- }
-
- ///
- /// Draws the platform specific version details for AppLovin MAX plugin.
- ///
- private void DrawPluginDetailRow(string platform, string currentVersion, string latestVersion)
- {
- using (new EditorGUILayout.HorizontalScope())
- {
- GUILayout.Space(5);
- EditorGUILayout.LabelField(new GUIContent(platform), networkWidthOption);
- EditorGUILayout.LabelField(new GUIContent(currentVersion), versionWidthOption);
- GUILayout.Space(3);
- EditorGUILayout.LabelField(new GUIContent(latestVersion), versionWidthOption);
- GUILayout.Space(3);
- }
-
- GUILayout.Space(4);
- }
-
- ///
- /// Draws mediated network details table.
- ///
- private void DrawMediatedNetworks()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- DrawHeaders("Network", true);
-
- // Immediately after downloading and importing a plugin the entire IDE reloads and current versions can be null in that case. Will just show loading text in that case.
- if (pluginData == null || pluginData.AppLovinMax.CurrentVersions == null)
- {
- DrawEmptyPluginData();
- }
- else
- {
- var networks = pluginData.MediatedNetworks;
- foreach (var network in networks)
- {
- DrawNetworkDetailRow(network);
- }
-
- GUILayout.Space(10);
- }
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private void DrawPartnerMicroSdks()
- {
- if (pluginData == null) return;
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- DrawHeaders("Network", true);
-
- var partnerMicroSdks = pluginData.PartnerMicroSdks;
- foreach (var partnerMicroSdk in partnerMicroSdks)
- {
- DrawNetworkDetailRow(partnerMicroSdk);
- }
-
- GUILayout.Space(10);
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- ///
- /// Draws the network specific details for a given network.
- ///
- private void DrawNetworkDetailRow(Network network)
- {
- string action;
- var currentVersion = network.CurrentVersions != null ? network.CurrentVersions.Unity : "";
- var latestVersion = network.LatestVersions.Unity;
- bool isActionEnabled;
- bool isInstalled;
- if (string.IsNullOrEmpty(currentVersion))
- {
- action = "Install";
- currentVersion = "Not Installed";
- isActionEnabled = true;
- isInstalled = false;
- }
- else
- {
- isInstalled = true;
-
- var comparison = network.CurrentToLatestVersionComparisonResult;
- // A newer version is available
- if (comparison == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- action = "Upgrade";
- isActionEnabled = true;
- }
- // Current installed version is newer than latest version from DB (beta version)
- else if (comparison == MaxSdkUtils.VersionComparisonResult.Greater)
- {
- action = "Installed";
- isActionEnabled = false;
- }
- // Already on the latest version
- else
- {
- action = "Installed";
- isActionEnabled = false;
- }
- }
-
- GUILayout.Space(4);
- using (new EditorGUILayout.HorizontalScope(GUILayout.ExpandHeight(false)))
- {
- GUILayout.Space(5);
- EditorGUILayout.LabelField(new GUIContent(network.DisplayName), networkWidthOption);
- EditorGUILayout.LabelField(new GUIContent(currentVersion), versionWidthOption);
- GUILayout.Space(3);
- EditorGUILayout.LabelField(new GUIContent(latestVersion), versionWidthOption);
- GUILayout.Space(3);
- GUILayout.FlexibleSpace();
-
- if (network.RequiresUpdate)
- {
- GUILayout.Label(new GUIContent {image = errorIcon, tooltip = "Adapter not compatible, please update to the latest version."}, iconStyle);
- }
- else if ((network.Name.Equals("ADMOB_NETWORK") || network.Name.Equals("GOOGLE_AD_MANAGER_NETWORK")) && shouldShowGoogleWarning)
- {
- GUILayout.Label(new GUIContent {image = warningIcon, tooltip = "You may see unexpected errors if you use different versions of the AdMob and Google Ad Manager adapter SDKs."}, iconStyle);
- }
-
- if (network.IsCurrentlyInstalling)
- {
- action = "Installing...";
- }
-
- GUI.enabled = networkButtonsEnabled && isActionEnabled && !network.IsCurrentlyInstalling;
- if (GUILayout.Button(new GUIContent(action), FieldWidth))
- {
- // Only show "Installing..." if the plugin is in the Assets folder
- // Manifest edits don't trigger import callbacks, and UPM resolution locks the UI anyway.
- network.IsCurrentlyInstalling = !AppLovinIntegrationManager.IsPluginInPackageManager;
- AppLovinEditorCoroutine.StartCoroutine(AppLovinPackageManager.AddNetwork(network, true));
- }
-
- GUI.enabled = true;
- GUILayout.Space(2);
-
- GUI.enabled = networkButtonsEnabled && isInstalled;
- if (GUILayout.Button(new GUIContent {image = uninstallIcon, tooltip = "Uninstall"}, iconStyle))
- {
- AppLovinPackageManager.RemoveNetwork(network);
- AppLovinPackageManager.UpdateCurrentVersions(network);
- UpdateShouldShowGoogleWarningIfNeeded();
- }
-
- GUI.enabled = true;
- GUILayout.Space(5);
- }
-
- if (isInstalled)
- {
- DrawGoogleAppIdTextBoxIfNeeded(network);
- }
- }
-
- private void DrawGoogleAppIdTextBoxIfNeeded(Network network)
- {
- // Custom integration for AdMob where the user can enter the Android and iOS App IDs.
- if (network.Name.Equals("ADMOB_NETWORK"))
- {
- // Show only one set of text boxes if both ADMOB and GAM are installed
- if (AppLovinPackageManager.IsAdapterInstalled(pluginData, "GOOGLE_AD_MANAGER_NETWORK")) return;
-
- DrawGoogleAppIdTextBox();
- }
- // Custom integration for GAM where the user can enter the Android and iOS App IDs.
- else if (network.Name.Equals("GOOGLE_AD_MANAGER_NETWORK"))
- {
- DrawGoogleAppIdTextBox();
- }
- }
-
- ///
- /// Draws the text box for GAM or ADMOB to input the App ID
- ///
- private void DrawGoogleAppIdTextBox()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(20);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- GUILayout.Space(2);
- AppLovinSettings.Instance.AdMobAndroidAppId = DrawTextField("App ID (Android)", AppLovinSettings.Instance.AdMobAndroidAppId, networkWidthOption);
- AppLovinSettings.Instance.AdMobIosAppId = DrawTextField("App ID (iOS)", AppLovinSettings.Instance.AdMobIosAppId, networkWidthOption);
- }
-
- GUILayout.EndHorizontal();
- }
-
- ///
- /// Draws the upgrade all button
- ///
- private void DrawUpgradeAllButton()
- {
- GUI.enabled = NetworksRequireUpgrade();
- if (GUILayout.Button(new GUIContent("Upgrade All"), UpgradeAllButtonFieldWidth))
- {
- AppLovinEditorCoroutine.StartCoroutine(UpgradeAllNetworks());
- }
-
- GUI.enabled = true;
- GUILayout.Space(10);
- }
-
- private void DrawPluginMigrationHelper()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- GUILayout.Space(5);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.LabelField(new GUIContent("This will migrate the AppLovin MAX Unity Plugin and adapters to the Unity Package Manager."), wrapTextLabelStyle);
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
-
- GUI.enabled = true;
- GUILayout.Space(3);
- GUILayout.FlexibleSpace();
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- var migrationText = "Upgrade All Adapters and Migrate to UPM";
- if (GUILayout.Button(new GUIContent(migrationText)))
- {
- if (EditorUtility.DisplayDialog("Migrate to UPM?",
- "Are you sure you want to migrate the SDK and adapters to UPM? This action will move both the MAX SDK and its adapters.", "Yes", "No"))
- {
- var deleteExternalDependencyManager = false;
- if (Directory.Exists(ExternalDependencyManagerPath))
- {
- deleteExternalDependencyManager = EditorUtility.DisplayDialog("External Dependency Manager Detected",
- "Our plugin includes the External Dependency Manager via the Unity Package Manager. Would you like us to automatically remove the existing External Dependency Manager folder, or would you prefer to manage it manually?", "Remove Automatically", "Manage Manually");
- }
-
- AppLovinPluginMigrationHelper.MigrateToUnityPackageManager(pluginData, deleteExternalDependencyManager);
- }
- }
-
- GUILayout.Space(10);
- GUILayout.EndHorizontal();
-
- GUILayout.Space(5);
- EditorGUILayout.HelpBox("Ensure all changes are committed before migration.", MessageType.Warning);
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private void DrawQualityServiceSettings()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- GUILayout.Space(4);
- if (!AppLovinIntegrationManager.CanProcessAndroidQualityServiceSettings)
- {
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.HelpBox(QualityServiceRequiresGradleBuildErrorMsg, MessageType.Warning);
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
-
- GUILayout.Space(4);
- }
-
- AppLovinSettings.Instance.SdkKey = DrawTextField("AppLovin SDK Key", AppLovinSettings.Instance.SdkKey, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- GUILayout.Button("You can find your SDK key here: ", wrapTextLabelStyle, GUILayout.Width(185)); // Setting a fixed width since Unity adds arbitrary padding at the end leaving a space between link and text.
- if (GUILayout.Button(new GUIContent(AppLovinSdkKeyLink), linkLabelStyle))
- {
- Application.OpenURL(AppLovinSdkKeyLink);
- }
-
- GUILayout.FlexibleSpace();
- GUILayout.EndHorizontal();
-
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- AppLovinSettings.Instance.QualityServiceEnabled = GUILayout.Toggle(AppLovinSettings.Instance.QualityServiceEnabled, " Enable MAX Ad Review");
- GUILayout.EndHorizontal();
- GUILayout.Space(4);
-
- GUILayout.Space(4);
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private string DrawTextField(string fieldTitle, string text, GUILayoutOption labelWidth, GUILayoutOption textFieldWidthOption = null, bool isTextFieldEditable = true, string tooltip = "")
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- var guiContent = MaxSdkUtils.IsValidString(tooltip) ? new GUIContent(fieldTitle, tooltip) : new GUIContent(fieldTitle);
- EditorGUILayout.LabelField(guiContent, labelWidth);
- GUILayout.Space(4);
- if (isTextFieldEditable)
- {
- text = (textFieldWidthOption == null) ? GUILayout.TextField(text) : GUILayout.TextField(text, textFieldWidthOption);
- }
- else
- {
- if (textFieldWidthOption == null)
- {
- GUILayout.Label(text);
- }
- else
- {
- GUILayout.Label(text, textFieldWidthOption);
- }
- }
-
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
- GUILayout.Space(4);
-
- return text;
- }
-
- private void DrawPrivacySettings()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- DrawConsentFlowSettings();
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private void DrawConsentFlowSettings()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- AppLovinInternalSettings.Instance.ConsentFlowEnabled = GUILayout.Toggle(AppLovinInternalSettings.Instance.ConsentFlowEnabled, " Enable MAX Terms and Privacy Policy Flow");
- GUILayout.EndHorizontal();
- GUILayout.Space(6);
- GUILayout.Space(4);
- EditorGUILayout.HelpBox("This flow automatically includes Google UMP.", MessageType.Info);
-
- GUI.enabled = true;
-
- if (!AppLovinInternalSettings.Instance.ConsentFlowEnabled) return;
-
- GUILayout.Space(6);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.LabelField("Click the link below to access the guide on creating the GDPR form within AdMob's dashboard.");
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- if (GUILayout.Button(new GUIContent(DocumentationTermsAndPrivacyPolicyFlow), linkLabelStyle))
- {
- Application.OpenURL(DocumentationTermsAndPrivacyPolicyFlow);
- }
-
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
-
- GUILayout.Space(8);
-
- AppLovinInternalSettings.Instance.ConsentFlowPrivacyPolicyUrl = DrawTextField("Privacy Policy URL", AppLovinInternalSettings.Instance.ConsentFlowPrivacyPolicyUrl, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption);
- AppLovinInternalSettings.Instance.ConsentFlowTermsOfServiceUrl = DrawTextField("Terms of Service URL (optional)", AppLovinInternalSettings.Instance.ConsentFlowTermsOfServiceUrl, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption);
-
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- AppLovinInternalSettings.Instance.ShouldShowTermsAndPrivacyPolicyAlertInGDPR = GUILayout.Toggle(AppLovinInternalSettings.Instance.ShouldShowTermsAndPrivacyPolicyAlertInGDPR, " Show Terms and Privacy Policy Flow when in GDPR Regions");
- GUILayout.EndHorizontal();
-
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.LabelField("iOS specific settings:", headerLabelStyle);
- GUILayout.EndHorizontal();
-
- var isEditableTextField = AppLovinInternalSettings.Instance.OverrideDefaultUserTrackingUsageDescriptions;
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- AppLovinInternalSettings.Instance.OverrideDefaultUserTrackingUsageDescriptions = GUILayout.Toggle(AppLovinInternalSettings.Instance.OverrideDefaultUserTrackingUsageDescriptions, " Override Default User Tracking Usage Description");
- GUILayout.EndHorizontal();
- GUILayout.Space(4);
-
- GUILayout.Space(4);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEn = DrawTextField("User Tracking Usage Description", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEn, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- AppLovinInternalSettings.Instance.UserTrackingUsageLocalizationEnabled = GUILayout.Toggle(AppLovinInternalSettings.Instance.UserTrackingUsageLocalizationEnabled, " Localize User Tracking Usage Description");
- GUILayout.EndHorizontal();
- GUILayout.Space(4);
-
- if (AppLovinInternalSettings.Instance.UserTrackingUsageLocalizationEnabled)
- {
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHans = DrawTextField("Chinese, Simplified (zh-Hans)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHans, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHant = DrawTextField("Chinese, Traditional (zh-Hant)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHant, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionFr = DrawTextField("French (fr)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionFr, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionDe = DrawTextField("German (de)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionDe, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionJa = DrawTextField("Japanese (ja)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionJa, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionKo = DrawTextField("Korean (ko)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionKo, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
- AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEs = DrawTextField("Spanish (es)", AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEs, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, isEditableTextField);
-
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.HelpBox("If you have your own implementation of InfoPlist.strings localization implementation, please use that instead. Using both at the same time may cause conflicts.", MessageType.Info);
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
- }
-
- GUILayout.Space(4);
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- GUILayout.Button("Click the link below for more information about User Tracking Usage Description: ", wrapTextLabelStyle);
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- if (GUILayout.Button(new GUIContent(UserTrackingUsageDescriptionDocsLink), linkLabelStyle))
- {
- Application.OpenURL(UserTrackingUsageDescriptionDocsLink);
- }
-
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
- GUILayout.Space(8);
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.LabelField("Testing:", headerLabelStyle);
- GUILayout.EndHorizontal();
-
- GUILayout.BeginHorizontal();
- GUILayout.Space(4);
- EditorGUILayout.LabelField("Debug User Geography");
- AppLovinInternalSettings.Instance.DebugUserGeography = (MaxSdkBase.ConsentFlowUserGeography) EditorGUILayout.Popup((int) AppLovinInternalSettings.Instance.DebugUserGeography, debugUserGeographies, privacySettingFieldWidthOption);
- GUILayout.Space(4);
- GUILayout.EndHorizontal();
-
- EditorGUILayout.HelpBox("Debug User Geography is only enabled in debug mode", MessageType.Info);
- }
-
- private void DrawOtherSettings()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- GUILayout.Space(5);
- var autoUpdateEnabled = DrawOtherSettingsToggle(EditorPrefs.GetBool(AppLovinAutoUpdater.KeyAutoUpdateEnabled, true), " Enable Auto Update", "Checks for AppLovin MAX plugin updates and notifies you when an update is available.");
- EditorPrefs.SetBool(AppLovinAutoUpdater.KeyAutoUpdateEnabled, autoUpdateEnabled);
- GUILayout.Space(5);
- var verboseLoggingEnabled = DrawOtherSettingsToggle(EditorPrefs.GetBool(MaxSdkLogger.KeyVerboseLoggingEnabled, false), " Enable Verbose Logging");
- EditorPrefs.SetBool(MaxSdkLogger.KeyVerboseLoggingEnabled, verboseLoggingEnabled);
- GUILayout.Space(5);
- AppLovinSettings.Instance.CustomGradleVersionUrl = DrawTextField("Custom Gradle Version URL", AppLovinSettings.Instance.CustomGradleVersionUrl, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, tooltip: CustomGradleVersionTooltip);
- AppLovinSettings.Instance.CustomGradleToolsVersion = DrawTextField("Custom Gradle Tools Version", AppLovinSettings.Instance.CustomGradleToolsVersion, GUILayout.Width(PrivacySettingLabelWidth), privacySettingFieldWidthOption, tooltip: CustomGradleToolsVersionTooltip);
- EditorGUILayout.HelpBox("This will overwrite the gradle build tools version in your base gradle template.", MessageType.Info);
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private bool DrawOtherSettingsToggle(bool value, string text, string tooltip = "")
- {
- using (new EditorGUILayout.HorizontalScope())
- {
- GUILayout.Space(4);
- var content = MaxSdkUtils.IsValidString(tooltip) ? new GUIContent(text, tooltip) : new GUIContent(text);
- var toggleValue = GUILayout.Toggle(value, content);
- GUILayout.Space(4);
-
- return toggleValue;
- }
- }
-
- private void DrawUnityEnvironmentDetails()
- {
- GUILayout.BeginHorizontal();
- GUILayout.Space(10);
- using (new EditorGUILayout.VerticalScope("box"))
- {
- DrawUnityEnvironmentDetailRow("Unity Version", Application.unityVersion);
- GUILayout.Space(5);
- DrawUnityEnvironmentDetailRow("Platform", Application.platform.ToString());
- GUILayout.Space(5);
- DrawUnityEnvironmentDetailRow("External Dependency Manager Version", AppLovinIntegrationManager.ExternalDependencyManagerVersion);
- GUILayout.Space(5);
- DrawUnityEnvironmentDetailRow("Gradle Template Enabled", AppLovinIntegrationManager.GradleTemplateEnabled.ToString());
- }
-
- GUILayout.Space(5);
- GUILayout.EndHorizontal();
- }
-
- private void DrawUnityEnvironmentDetailRow(string key, string value)
- {
- using (new EditorGUILayout.HorizontalScope())
- {
- GUILayout.Space(5);
- EditorGUILayout.LabelField(key, GUILayout.Width(250));
- GUILayout.FlexibleSpace();
- EditorGUILayout.LabelField(value, environmentValueStyle);
- GUILayout.Space(5);
- }
- }
-
- private void DrawCollapsibleSection(string keyShowDetails, string label, Action drawContent)
- {
- EditorGUILayout.BeginHorizontal();
- var showDetails = DrawExpandCollapseButton(keyShowDetails);
-
- EditorGUILayout.LabelField(label, titleLabelStyle);
- GUILayout.FlexibleSpace();
- EditorGUILayout.EndHorizontal();
- if (showDetails)
- {
- drawContent();
- }
- }
-
- private bool DrawExpandCollapseButton(string keyShowDetails)
- {
- var showDetails = EditorPrefs.GetBool(keyShowDetails, true);
- var buttonText = showDetails ? CollapseButtonText : ExpandButtonText;
- if (GUILayout.Button(buttonText, CollapseButtonWidthOption))
- {
- EditorPrefs.SetBool(keyShowDetails, !showDetails);
- }
-
- return showDetails;
- }
-
- ///
- /// Calculates the fields width based on the width of the window.
- ///
- private void CalculateFieldWidth()
- {
- var currentWidth = position.width;
- var availableWidth = currentWidth - ActionFieldWidth - 80; // NOTE: Magic number alert. This is the sum of all the spacing the fields and other UI elements.
- var networkLabelWidth = Math.Max(NetworkFieldMinWidth, availableWidth * NetworkFieldWidthPercentage);
- networkWidthOption = GUILayout.Width(networkLabelWidth);
-
- var versionLabelWidth = Math.Max(VersionFieldMinWidth, availableWidth * VersionFieldWidthPercentage);
- versionWidthOption = GUILayout.Width(versionLabelWidth);
-
- const int textFieldOtherUiElementsWidth = 55; // NOTE: Magic number alert. This is the sum of all the spacing the fields and other UI elements.
- var availableUserDescriptionTextFieldWidth = currentWidth - PrivacySettingLabelWidth - textFieldOtherUiElementsWidth;
- privacySettingFieldWidthOption = GUILayout.Width(availableUserDescriptionTextFieldWidth);
- }
-
- #endregion
-
- #region Utility Methods
-
- ///
- /// Loads the plugin data to be displayed by this window.
- ///
- private void Load()
- {
- loadDataCoroutine = AppLovinEditorCoroutine.StartCoroutine(AppLovinIntegrationManager.Instance.LoadPluginData(data =>
- {
- if (data == null)
- {
- pluginDataLoadFailed = true;
- }
- else
- {
- pluginData = data;
- pluginDataLoadFailed = false;
-
- UpdateShouldShowGoogleWarningIfNeeded();
- }
-
- CalculateFieldWidth();
- Repaint();
- }));
- }
-
- private void OnImportPackageStarted(Network network)
- {
- network.IsCurrentlyInstalling = false;
- }
-
- private void OnImportPackageCompleted(Network network)
- {
- AppLovinPackageManager.UpdateCurrentVersions(network);
-
- UpdateShouldShowGoogleWarningIfNeeded();
- }
-
- private void UpdateShouldShowGoogleWarningIfNeeded()
- {
- if (pluginData == null)
- {
- shouldShowGoogleWarning = false;
- return;
- }
-
- var networks = pluginData.MediatedNetworks;
- var googleNetwork = networks.FirstOrDefault(foundNetwork => foundNetwork.Name.Equals("ADMOB_NETWORK"));
- var googleAdManagerNetwork = networks.FirstOrDefault(foundNetwork => foundNetwork.Name.Equals("GOOGLE_AD_MANAGER_NETWORK"));
-
- if (googleNetwork != null && googleAdManagerNetwork != null &&
- MaxSdkUtils.IsValidString(googleNetwork.CurrentVersions.Unity) && MaxSdkUtils.IsValidString(googleAdManagerNetwork.CurrentVersions.Unity) &&
- !googleNetwork.CurrentVersions.HasEqualSdkVersions(googleAdManagerNetwork.CurrentVersions))
- {
- shouldShowGoogleWarning = true;
- }
- else
- {
- shouldShowGoogleWarning = false;
- }
- }
-
- ///
- /// Upgrades all outdated networks
- ///
- private IEnumerator UpgradeAllNetworks()
- {
- networkButtonsEnabled = false;
- EditorApplication.LockReloadAssemblies();
- var networks = pluginData.MediatedNetworks;
- foreach (var network in networks)
- {
- var comparison = network.CurrentToLatestVersionComparisonResult;
- // A newer version is available
- if (MaxSdkUtils.IsValidString(network.CurrentVersions.Unity) && comparison == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- yield return AppLovinPackageManager.AddNetwork(network, false);
- }
- }
-
- EditorApplication.UnlockReloadAssemblies();
- networkButtonsEnabled = true;
-
- // The pluginData becomes stale after the networks have been updated, and we should re-load it.
- Load();
- }
-
- ///
- /// Returns whether any network adapter needs to be upgraded
- ///
- private bool NetworksRequireUpgrade()
- {
- if (pluginData == null || pluginData.AppLovinMax.CurrentVersions == null) return false;
-
- var networks = pluginData.MediatedNetworks;
- return networks.Any(network => MaxSdkUtils.IsValidString(network.CurrentVersions.Unity) && network.CurrentToLatestVersionComparisonResult == MaxSdkUtils.VersionComparisonResult.Lesser);
- }
-
- ///
- /// Takes in an int representing the count of an alert and returns it as a string or "9+" if greater than 9.
- ///
- private string AlertCountToString(int count)
- {
- return count > 9 ? "9+" : count.ToString();
- }
-
- ///
- /// Returns the icon for the given severity type.
- ///
- private Texture2D GetSeverityIcon(Severity severity)
- {
- switch (severity)
- {
- case Severity.Info:
- return infoIcon;
- case Severity.Warning:
- return warningIcon;
- case Severity.Error:
- return errorIcon;
- default:
- return infoIcon;
- }
- }
-
- #endregion
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs.meta
deleted file mode 100644
index d7996fdd..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 84c61b4c05e114cec91df447d1b585f8
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinIntegrationManagerWindow.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs
deleted file mode 100644
index 2ee24b97..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs
+++ /dev/null
@@ -1,307 +0,0 @@
-//
-// AppLovinInternalSettings.cs
-// AppLovin User Engagement Unity Plugin
-//
-// Created by Santosh Bagadi on 9/15/22.
-// Copyright © 2022 AppLovin. All rights reserved.
-//
-
-using System;
-using System.Collections.Generic;
-using System.IO;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// A representing the AppLovin internal settings that can be set in the Integration Manager Window.
- ///
- /// The scriptable object asset is saved under ProjectSettings as AppLovinInternalSettings.json.
- ///
- public class AppLovinInternalSettings : ScriptableObject
- {
- private static AppLovinInternalSettings instance;
-
- private const string DefaultUserTrackingDescriptionEn = "This uses device info for more personalized ads and content";
- private const string DefaultUserTrackingDescriptionDe = "Dies benutzt Gerätinformationen für relevantere Werbeinhalte";
- private const string DefaultUserTrackingDescriptionEs = "Esto utiliza la información del dispositivo para anuncios y contenido más personalizados";
- private const string DefaultUserTrackingDescriptionFr = "Cela permet d'utiliser les informations du téléphone pour afficher des contenus publicitaires plus pertinents.";
- private const string DefaultUserTrackingDescriptionJa = "これはユーザーデータをもとに、より関連性の高い広告コンテンツをお客様に提供します";
- private const string DefaultUserTrackingDescriptionKo = "보다 개인화된 광고 및 콘텐츠를 위해 기기 정보를 사용합니다.";
- private const string DefaultUserTrackingDescriptionZhHans = "我们使用设备信息来提供个性化的广告和内容。";
- private const string DefaultUserTrackingDescriptionZhHant = "我們使用設備信息來提供個性化的廣告和內容。";
-
- [SerializeField] private bool consentFlowEnabled;
- [SerializeField] private string consentFlowPrivacyPolicyUrl = string.Empty;
- [SerializeField] private string consentFlowTermsOfServiceUrl = string.Empty;
- [SerializeField] private bool shouldShowTermsAndPrivacyPolicyAlertInGDPR;
- [SerializeField] private bool overrideDefaultUserTrackingUsageDescriptions;
- [SerializeField] private MaxSdkBase.ConsentFlowUserGeography debugUserGeography;
- [SerializeField] private string userTrackingUsageDescriptionEn = string.Empty;
- [SerializeField] private bool userTrackingUsageLocalizationEnabled;
- [SerializeField] private string userTrackingUsageDescriptionDe = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionEs = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionFr = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionJa = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionKo = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionZhHans = string.Empty;
- [SerializeField] private string userTrackingUsageDescriptionZhHant = string.Empty;
-
- private const string SettingsFilePath = "ProjectSettings/AppLovinInternalSettings.json";
-
- public static AppLovinInternalSettings Instance
- {
- get
- {
- if (instance != null) return instance;
-
- instance = CreateInstance();
-
- var projectRootPath = Path.GetDirectoryName(Application.dataPath);
- var settingsFilePath = Path.Combine(projectRootPath, SettingsFilePath);
- if (!File.Exists(settingsFilePath))
- {
- instance.Save();
- return instance;
- }
-
- var settingsJson = File.ReadAllText(settingsFilePath);
- if (string.IsNullOrEmpty(settingsJson))
- {
- instance.Save();
- return instance;
- }
-
- JsonUtility.FromJsonOverwrite(settingsJson, instance);
- return instance;
- }
- }
-
- public void Save()
- {
- var settingsJson = JsonUtility.ToJson(instance);
- try
- {
- var projectRootPath = Path.GetDirectoryName(Application.dataPath);
- var settingsFilePath = Path.Combine(projectRootPath, SettingsFilePath);
- File.WriteAllText(settingsFilePath, settingsJson);
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to save internal settings.");
- Console.WriteLine(exception);
- }
- }
-
- ///
- /// Whether or not AppLovin Consent Flow is enabled.
- ///
- public bool ConsentFlowEnabled
- {
- get { return consentFlowEnabled; }
- set
- {
- var previousValue = consentFlowEnabled;
- consentFlowEnabled = value;
-
- if (value)
- {
- // If the value didn't change, we don't need to update anything.
- if (previousValue) return;
-
- UserTrackingUsageDescriptionEn = DefaultUserTrackingDescriptionEn;
- UserTrackingUsageLocalizationEnabled = true;
- }
- else
- {
- ConsentFlowPrivacyPolicyUrl = string.Empty;
- ConsentFlowTermsOfServiceUrl = string.Empty;
- UserTrackingUsageDescriptionEn = string.Empty;
- UserTrackingUsageLocalizationEnabled = false;
- OverrideDefaultUserTrackingUsageDescriptions = false;
- }
- }
- }
-
- ///
- /// A URL pointing to the Privacy Policy for the app to be shown when prompting the user for consent.
- ///
- public string ConsentFlowPrivacyPolicyUrl
- {
- get { return consentFlowPrivacyPolicyUrl; }
- set { consentFlowPrivacyPolicyUrl = value; }
- }
-
- ///
- /// An optional URL pointing to the Terms of Service for the app to be shown when prompting the user for consent.
- ///
- public string ConsentFlowTermsOfServiceUrl
- {
- get { return consentFlowTermsOfServiceUrl; }
- set { consentFlowTermsOfServiceUrl = value; }
- }
-
- ///
- /// Whether or not to show the Terms and Privacy Policy alert in GDPR regions prior to presenting the CMP prompt.
- ///
- public bool ShouldShowTermsAndPrivacyPolicyAlertInGDPR
- {
- get { return shouldShowTermsAndPrivacyPolicyAlertInGDPR; }
- set { shouldShowTermsAndPrivacyPolicyAlertInGDPR = value; }
- }
-
- ///
- /// A User Tracking Usage Description in English to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation.
- ///
- public string UserTrackingUsageDescriptionEn
- {
- get { return userTrackingUsageDescriptionEn; }
- set { userTrackingUsageDescriptionEn = value; }
- }
-
- ///
- /// An optional string to set debug user geography
- ///
- public MaxSdkBase.ConsentFlowUserGeography DebugUserGeography
- {
- get { return debugUserGeography; }
- set { debugUserGeography = value; }
- }
-
- public bool OverrideDefaultUserTrackingUsageDescriptions
- {
- get { return overrideDefaultUserTrackingUsageDescriptions; }
- set
- {
- var previousValue = overrideDefaultUserTrackingUsageDescriptions;
- overrideDefaultUserTrackingUsageDescriptions = value;
-
- if (!value)
- {
- if (!previousValue) return;
-
- UserTrackingUsageDescriptionEn = DefaultUserTrackingDescriptionEn;
- UserTrackingUsageDescriptionDe = DefaultUserTrackingDescriptionDe;
- UserTrackingUsageDescriptionEs = DefaultUserTrackingDescriptionEs;
- UserTrackingUsageDescriptionFr = DefaultUserTrackingDescriptionFr;
- UserTrackingUsageDescriptionJa = DefaultUserTrackingDescriptionJa;
- UserTrackingUsageDescriptionKo = DefaultUserTrackingDescriptionKo;
- UserTrackingUsageDescriptionZhHans = DefaultUserTrackingDescriptionZhHans;
- UserTrackingUsageDescriptionZhHant = DefaultUserTrackingDescriptionZhHant;
- }
- }
- }
-
- ///
- /// Whether or not to localize User Tracking Usage Description.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public bool UserTrackingUsageLocalizationEnabled
- {
- get { return userTrackingUsageLocalizationEnabled; }
- set
- {
- var previousValue = userTrackingUsageLocalizationEnabled;
- userTrackingUsageLocalizationEnabled = value;
-
- if (value)
- {
- // If the value didn't change, don't do anything
- if (previousValue) return;
-
- // Don't set the default values if they are being overriden.
- if (OverrideDefaultUserTrackingUsageDescriptions) return;
-
- UserTrackingUsageDescriptionDe = DefaultUserTrackingDescriptionDe;
- UserTrackingUsageDescriptionEs = DefaultUserTrackingDescriptionEs;
- UserTrackingUsageDescriptionFr = DefaultUserTrackingDescriptionFr;
- UserTrackingUsageDescriptionJa = DefaultUserTrackingDescriptionJa;
- UserTrackingUsageDescriptionKo = DefaultUserTrackingDescriptionKo;
- UserTrackingUsageDescriptionZhHans = DefaultUserTrackingDescriptionZhHans;
- UserTrackingUsageDescriptionZhHant = DefaultUserTrackingDescriptionZhHant;
- }
- else
- {
- UserTrackingUsageDescriptionDe = string.Empty;
- UserTrackingUsageDescriptionEs = string.Empty;
- UserTrackingUsageDescriptionFr = string.Empty;
- UserTrackingUsageDescriptionJa = string.Empty;
- UserTrackingUsageDescriptionKo = string.Empty;
- UserTrackingUsageDescriptionZhHans = string.Empty;
- UserTrackingUsageDescriptionZhHant = string.Empty;
- }
- }
- }
-
- ///
- /// A User Tracking Usage Description in German to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionDe
- {
- get { return userTrackingUsageDescriptionDe; }
- set { userTrackingUsageDescriptionDe = value; }
- }
-
- ///
- /// A User Tracking Usage Description in Spanish to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionEs
- {
- get { return userTrackingUsageDescriptionEs; }
- set { userTrackingUsageDescriptionEs = value; }
- }
-
- ///
- /// A User Tracking Usage Description in French to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionFr
- {
- get { return userTrackingUsageDescriptionFr; }
- set { userTrackingUsageDescriptionFr = value; }
- }
-
- ///
- /// A User Tracking Usage Description in Japanese to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionJa
- {
- get { return userTrackingUsageDescriptionJa; }
- set { userTrackingUsageDescriptionJa = value; }
- }
-
- ///
- /// A User Tracking Usage Description in Korean to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionKo
- {
- get { return userTrackingUsageDescriptionKo; }
- set { userTrackingUsageDescriptionKo = value; }
- }
-
- ///
- /// A User Tracking Usage Description in Chinese (Simplified) to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionZhHans
- {
- get { return userTrackingUsageDescriptionZhHans; }
- set { userTrackingUsageDescriptionZhHans = value; }
- }
-
- ///
- /// A User Tracking Usage Description in Chinese (Traditional) to be shown to users when requesting permission to use data for tracking.
- /// For more information see Apple's documentation: https://developer.apple.com/documentation/bundleresources/information_property_list/nsusertrackingusagedescription
- ///
- public string UserTrackingUsageDescriptionZhHant
- {
- get { return userTrackingUsageDescriptionZhHant; }
- set { userTrackingUsageDescriptionZhHant = value; }
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs.meta
deleted file mode 100644
index a863905b..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 65c51e21887ae42c2839962fb9585e9f
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinInternalSettings.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs
deleted file mode 100644
index debdfd28..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs
+++ /dev/null
@@ -1,60 +0,0 @@
-//
-// MaxMenuItems.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 5/27/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-using UnityEditor;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public static class AppLovinMenuItems
- {
- /**
- * The special characters at the end represent a shortcut for this action.
- *
- * % - ctrl on Windows, cmd on macOS
- * # - shift
- * & - alt
- *
- * So, (shift + cmd/ctrl + i) will launch the integration manager
- */
- [MenuItem("AppLovin/Integration Manager %#i")]
- private static void IntegrationManager()
- {
- ShowIntegrationManager();
- }
-
- [MenuItem("AppLovin/Documentation")]
- private static void Documentation()
- {
- Application.OpenURL("https://support.axon.ai/en/max/unity/overview/integration");
- }
-
- [MenuItem("AppLovin/Contact Us")]
- private static void ContactUs()
- {
- Application.OpenURL("https://www.applovin.com/contact/");
- }
-
- [MenuItem("AppLovin/About")]
- private static void About()
- {
- Application.OpenURL("https://www.applovin.com/about/");
- }
-
- [MenuItem("Assets/AppLovin Integration Manager")]
- private static void AssetsIntegrationManager()
- {
- ShowIntegrationManager();
- }
-
- private static void ShowIntegrationManager()
- {
- AppLovinIntegrationManagerWindow.ShowManager();
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs.meta
deleted file mode 100644
index 30fb834e..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 02c2d277874f649d18a59d382420bf65
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinMenuItems.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs
deleted file mode 100644
index 0945743c..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs
+++ /dev/null
@@ -1,614 +0,0 @@
-using System;
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-#if !UNITY_2020_1_OR_NEWER
-using System.Reflection;
-#endif
-using System.Xml.Linq;
-using UnityEditor;
-using UnityEditor.PackageManager;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- [Serializable]
- public class PackageInfo
- {
- // ReSharper disable InconsistentNaming - For JSON Deserialization
- public string Name;
- public string Version;
- }
-
- public interface IPackageManagerClient
- {
- IEnumerator AddNetwork(Network network, bool showImport);
- void RemoveNetwork(Network network);
- }
-
- public static class AppLovinPackageManager
- {
- private const string AppLovinMediationAmazonAdapterDependenciesPath = "Amazon/Scripts/Mediations/AppLovinMediation/Editor/Dependencies.xml";
-
- private static readonly IPackageManagerClient _upmPackageManager = new AppLovinUpmPackageManager();
- private static readonly IPackageManagerClient _assetsPackageManager = new AppLovinAssetsPackageManager();
-
- private static IPackageManagerClient PackageManagerClient
- {
- get
- {
- return AppLovinIntegrationManager.IsPluginInPackageManager ? _upmPackageManager : _assetsPackageManager;
- }
- }
-
- internal static PluginData PluginData { get; set; }
-
- ///
- /// Checks whether or not an adapter with the given version or newer exists.
- ///
- /// The name of the network (the root adapter folder name in "MaxSdk/Mediation/" folder.
- /// The min iOS adapter version to check for. Can be null if we want to check for any version.
- /// The min android adapter version to check for. Can be null if we want to check for any version.
- /// true if an adapter with the min version is installed.
- internal static bool IsAdapterInstalled(string adapterName, string iosVersion = null, string androidVersion = null)
- {
- var dependencyFilePathList = GetAssetPathListForExportPath("MaxSdk/Mediation/" + adapterName + "/Editor/Dependencies.xml");
- if (dependencyFilePathList.Count <= 0) return false;
-
- var currentVersion = GetCurrentVersions(dependencyFilePathList);
- if (iosVersion != null)
- {
- var iosVersionComparison = MaxSdkUtils.CompareVersions(currentVersion.Ios, iosVersion);
- if (iosVersionComparison == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- return false;
- }
- }
-
- if (androidVersion != null)
- {
- var androidVersionComparison = MaxSdkUtils.CompareVersions(currentVersion.Android, androidVersion);
- if (androidVersionComparison == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- return false;
- }
- }
-
- return true;
- }
-
- ///
- /// Checks whether an adapter is installed using the plugin data.
- ///
- /// The plugin data to check for the adapter
- /// The name of the network.
- /// Whether an adapter is installed in the plugin data
- internal static bool IsAdapterInstalled(PluginData pluginData, string adapterName)
- {
- var network = pluginData.MediatedNetworks.Where(mediatedNetwork => mediatedNetwork.Name.Equals(adapterName)).ToList().FirstOrDefault();
- var networkVersion = network != null ? network.CurrentVersions : null;
- var currentVersion = networkVersion != null ? networkVersion.Unity : "";
-
- return MaxSdkUtils.IsValidString(currentVersion);
- }
-
- ///
- /// Gets the mediation networks that are currently installed in the project. If using UPM, checks
- /// for networks in Packages folder and Mediation folder in case a custom adapter was added to the project.
- ///
- /// A list of the installed mediation network names.
- internal static List GetInstalledMediationNetworks()
- {
- var installedNetworks = new List();
- var installedNetworksInAssets = AppLovinAssetsPackageManager.GetInstalledMediationNetworks();
- installedNetworks.AddRange(installedNetworksInAssets);
-
- var installedNetworksInPackages = AppLovinUpmPackageManager.GetInstalledMediationNetworks();
- installedNetworks.AddRange(installedNetworksInPackages);
-
- if (IsAmazonAppLovinAdapterInstalled())
- {
- installedNetworks.Add("AmazonAdMarketplace");
- }
-
- return installedNetworks;
- }
-
- ///
- /// Adds a network to the project.
- ///
- /// The network to add.
- /// Whether to show the import window (only for non UPM)
- internal static IEnumerator AddNetwork(Network network, bool showImport)
- {
- yield return PackageManagerClient.AddNetwork(network, showImport);
-
- AppLovinEditorCoroutine.StartCoroutine(RefreshAssetsAtEndOfFrame(network));
- }
-
- ///
- /// Removes a network from the project.
- ///
- /// The network to remove.
- internal static void RemoveNetwork(Network network)
- {
- PackageManagerClient.RemoveNetwork(network);
-
- AppLovinEditorCoroutine.StartCoroutine(RefreshAssetsAtEndOfFrame(network));
- }
-
- #region Utility
-
- ///
- /// Gets the list of all asset paths for a given MAX plugin export path.
- ///
- /// The actual exported path of the asset.
- /// The exported path of the MAX plugin asset or an empty list if the asset is not found.
- private static List GetAssetPathListForExportPath(string exportPath)
- {
- var assetLabelToFind = "l:al_max_export_path-" + MaxSdkUtils.NormalizeToUnityPath(exportPath);
- var assetGuids = AssetDatabase.FindAssets(assetLabelToFind);
-
- var assetPaths = new List();
- foreach (var assetGuid in assetGuids)
- {
- assetPaths.Add(AssetDatabase.GUIDToAssetPath(assetGuid));
- }
-
- return assetPaths.Count <= 0 ? new List() : assetPaths;
- }
-
- ///
- /// Updates the CurrentVersion fields for a given network data object.
- ///
- /// Network for which to update the current versions.
- internal static void UpdateCurrentVersions(Network network)
- {
- var assetPaths = GetAssetPathListForExportPath(network.DependenciesFilePath);
- if (HasDuplicateAdapters(assetPaths))
- {
- ShowDeleteDuplicateAdapterPrompt(network);
- }
-
- var currentVersions = GetCurrentVersions(assetPaths);
- network.CurrentVersions = currentVersions;
-
- // If AppLovin mediation plugin, get the version from MaxSdk and the latest and current version comparison.
- if (network.Name.Equals("APPLOVIN_NETWORK"))
- {
- network.CurrentVersions.Unity = MaxSdk.Version;
-
- var unityVersionComparison = MaxSdkUtils.CompareVersions(network.CurrentVersions.Unity, network.LatestVersions.Unity);
- var androidVersionComparison = MaxSdkUtils.CompareVersions(network.CurrentVersions.Android, network.LatestVersions.Android);
- var iosVersionComparison = MaxSdkUtils.CompareVersions(network.CurrentVersions.Ios, network.LatestVersions.Ios);
-
- // Overall version is same if all the current and latest (from db) versions are same.
- if (unityVersionComparison == MaxSdkUtils.VersionComparisonResult.Equal &&
- androidVersionComparison == MaxSdkUtils.VersionComparisonResult.Equal &&
- iosVersionComparison == MaxSdkUtils.VersionComparisonResult.Equal)
- {
- network.CurrentToLatestVersionComparisonResult = MaxSdkUtils.VersionComparisonResult.Equal;
- }
- // One of the installed versions is newer than the latest versions which means that the publisher is on a beta version.
- else if (unityVersionComparison == MaxSdkUtils.VersionComparisonResult.Greater ||
- androidVersionComparison == MaxSdkUtils.VersionComparisonResult.Greater ||
- iosVersionComparison == MaxSdkUtils.VersionComparisonResult.Greater)
- {
- network.CurrentToLatestVersionComparisonResult = MaxSdkUtils.VersionComparisonResult.Greater;
- }
- // We have a new version available if all Android, iOS and Unity has a newer version available in db.
- else
- {
- network.CurrentToLatestVersionComparisonResult = MaxSdkUtils.VersionComparisonResult.Lesser;
- }
- }
- // For all other mediation adapters, get the version comparison using their Unity versions.
- else
- {
- // If adapter is indeed installed, compare the current (installed) and the latest (from db) versions, so that we can determine if the publisher is on an older, current or a newer version of the adapter.
- // If the publisher is on a newer version of the adapter than the db version, that means they are on a beta version.
- if (MaxSdkUtils.IsValidString(currentVersions.Unity))
- {
- network.CurrentToLatestVersionComparisonResult = AppLovinIntegrationManagerUtils.CompareUnityMediationVersions(currentVersions.Unity, network.LatestVersions.Unity);
- }
-
- if (MaxSdkUtils.IsValidString(network.CurrentVersions.Unity) && AppLovinAutoUpdater.MinAdapterVersions.ContainsKey(network.Name))
- {
- var comparisonResult = AppLovinIntegrationManagerUtils.CompareUnityMediationVersions(network.CurrentVersions.Unity, AppLovinAutoUpdater.MinAdapterVersions[network.Name]);
- // Requires update if current version is lower than the min required version.
- network.RequiresUpdate = comparisonResult < 0;
- }
- else
- {
- // Reset value so that the Integration manager can hide the alert icon once adapter is updated.
- network.RequiresUpdate = false;
- }
- }
- }
-
- ///
- /// Checks whether a network has duplicate adapters installed in both the Assets folder and via UPM.
- ///
- /// The list of paths to the dependencies.xml files
- /// True if there are adapters in both the Assets folder and installed via UPM
- private static bool HasDuplicateAdapters(List dependencyPaths)
- {
- var inPackagesFolder = dependencyPaths.Any(path => path.Contains("Packages"));
- var inAssetsFolder = dependencyPaths.Any(path => path.Contains("Assets"));
-
- return inPackagesFolder && inAssetsFolder;
- }
-
- ///
- /// Displays a prompt informing the user that duplicate adapters were detected
- /// and allows them to choose which version to keep.
- ///
- /// The network that has duplicate adapters installed.
- private static void ShowDeleteDuplicateAdapterPrompt(Network network)
- {
- var keepAssetsAdapter = EditorUtility.DisplayDialog("Duplicate Adapters Detected",
- "The " + network.DisplayName + " adapter is installed in both the Assets folder and via UPM. Please choose which version to keep.",
- "Keep Assets Folder Version",
- "Keep UPM Version");
- DeleteDuplicateAdapter(network, keepAssetsAdapter);
- }
-
- ///
- /// Removes a duplicate adapter by either deleting it from the Assets folder
- /// or uninstalling it from the Unity Package Manager (UPM).
- ///
- /// The network for which the duplicate adapter is being removed.
- /// If true, retains the adapter in the Assets folder and removes the UPM version;
- /// otherwise, deletes the adapter from the Assets folder.
- internal static void DeleteDuplicateAdapter(Network network, bool keepAssetsAdapter)
- {
- // Skip duplicate removal logic for our plugin.
- if (network.Name.Equals("APPLOVIN_NETWORK")) return;
-
- if (keepAssetsAdapter)
- {
- var appLovinManifest = AppLovinUpmManifest.Load();
- AppLovinUpmPackageManager.RemovePackages(network, appLovinManifest);
- appLovinManifest.Save();
- }
- else
- {
- foreach (var pluginFilePath in network.PluginFilePaths)
- {
- var filePath = Path.Combine(AppLovinIntegrationManager.MediationDirectory, pluginFilePath.Replace("MaxSdk/Mediation/", ""));
- FileUtil.DeleteFileOrDirectory(filePath);
- FileUtil.DeleteFileOrDirectory(filePath + ".meta");
- }
- }
-
- AppLovinUpmPackageManager.ResolvePackageManager();
- }
-
- ///
- /// Gets the current versions for a given network's dependency file paths. UPM will have multiple paths
- /// for each network - one each for iOS and Android.
- ///
- /// A list of dependency file paths to extract current versions from.
- /// Current versions of a given network's dependency files.
- private static Versions GetCurrentVersions(List dependencyPaths)
- {
- var currentVersions = new Versions();
- foreach (var dependencyPath in dependencyPaths)
- {
- GetCurrentVersion(currentVersions, dependencyPath);
- }
-
- if (currentVersions.Android != null && currentVersions.Ios != null)
- {
- currentVersions.Unity = "android_" + currentVersions.Android + "_ios_" + currentVersions.Ios;
- }
- else if (currentVersions.Android != null)
- {
- currentVersions.Unity = "android_" + currentVersions.Android;
- }
- else if (currentVersions.Ios != null)
- {
- currentVersions.Unity = "ios_" + currentVersions.Ios;
- }
-
- return currentVersions;
- }
-
- ///
- /// Extracts the current version of a network from its dependency.xml file.
- ///
- /// The Versions object we are using.
- /// The path to the dependency.xml file.
- private static void GetCurrentVersion(Versions currentVersions, string dependencyPath)
- {
- XDocument dependency;
- try
- {
- dependency = XDocument.Load(dependencyPath);
- }
-#pragma warning disable 0168
- catch (IOException exception)
-#pragma warning restore 0168
- {
- // Couldn't find the dependencies file. The plugin is not installed.
- return;
- }
-
- //
- //
- //
- //
- //
- //
- //
- //
- string androidVersion = null;
- string iosVersion = null;
- var dependenciesElement = dependency.Element("dependencies");
- if (dependenciesElement != null)
- {
- var androidPackages = dependenciesElement.Element("androidPackages");
- if (androidPackages != null)
- {
- var adapterPackage = androidPackages.Descendants().FirstOrDefault(element => element.Name.LocalName.Equals("androidPackage")
- && element.FirstAttribute.Name.LocalName.Equals("spec")
- && element.FirstAttribute.Value.StartsWith("com.applovin"));
- if (adapterPackage != null)
- {
- androidVersion = adapterPackage.FirstAttribute.Value.Split(':').Last();
- // Hack alert: Some Android versions might have square brackets to force a specific version. Remove them if they are detected.
- if (androidVersion.StartsWith("["))
- {
- androidVersion = androidVersion.Trim('[', ']');
- }
- }
- }
-
- var iosPods = dependenciesElement.Element("iosPods");
- if (iosPods != null)
- {
- var adapterPod = iosPods.Descendants().FirstOrDefault(element => element.Name.LocalName.Equals("iosPod")
- && element.FirstAttribute.Name.LocalName.Equals("name")
- && element.FirstAttribute.Value.StartsWith("AppLovin"));
- if (adapterPod != null)
- {
- iosVersion = adapterPod.Attributes().First(attribute => attribute.Name.LocalName.Equals("version")).Value;
- }
- }
- }
-
- if (androidVersion != null)
- {
- currentVersions.Android = androidVersion;
- }
-
- if (iosVersion != null)
- {
- currentVersions.Ios = iosVersion;
- }
- }
-
- ///
- /// Check for the Amazon AppLovin adapter in the project.
- ///
- /// Whether the AppLovin Adapter is installed through the Amazon SDK.
- private static bool IsAmazonAppLovinAdapterInstalled()
- {
- string[] dependenciesFiles = AssetDatabase.FindAssets("t:TextAsset Dependencies", new[] {"Assets"})
- .Select(AssetDatabase.GUIDToAssetPath)
- .ToArray();
-
- // Use regex to search for Amazon and then AppLovin in the file paths of the dependencies.xml files.
- return dependenciesFiles.Any(filePath => filePath.Contains(AppLovinMediationAmazonAdapterDependenciesPath));
- }
-
- ///
- /// Refresh assets and update current versions after a slight delay to allow for Client.Resolve to finish.
- ///
- /// The network that was just installed/removed.
- private static IEnumerator RefreshAssetsAtEndOfFrame(Network network)
- {
- yield return new WaitForEndOfFrame();
- UpdateCurrentVersions(network);
- AssetDatabase.Refresh();
- }
-
- #endregion
- }
-
- public class AppLovinUpmPackageManager : IPackageManagerClient
- {
- public const string PackageNamePrefixAppLovin = "com.applovin.mediation.ads";
- private const string PackageNamePrefixNetwork = "com.applovin.mediation.adapters";
- private const string PackageNamePrefixDsp = "com.applovin.mediation.dsp";
-
- private const float TimeoutFetchPackageCollectionSeconds = 10f;
-
-#if !UNITY_2020_1_OR_NEWER
- private static Type packageManagerClientType;
- private static MethodInfo packageManagerResolveMethod;
-#endif
-
- public static List GetInstalledMediationNetworks()
- {
- // Return empty list if we failed to get the package list
- var packageCollection = GetPackageCollectionSync(TimeoutFetchPackageCollectionSeconds);
- if (packageCollection == null)
- {
- return new List();
- }
-
- return packageCollection.Where(package => package.name.StartsWith(PackageNamePrefixNetwork) || package.name.StartsWith(PackageNamePrefixDsp))
- .SelectMany(package => package.keywords)
- .Where(keyword => keyword.StartsWith("dir:"))
- .Select(keyword => keyword.Replace("dir:", ""))
- .Distinct()
- .ToList();
- }
-
- public IEnumerator AddNetwork(Network network, bool showImport)
- {
- var appLovinManifest = AppLovinUpmManifest.Load();
- AddPackages(network, appLovinManifest);
- appLovinManifest.Save();
-
- // Remove any versions of the adapter in the Assets folder
- AppLovinPackageManager.DeleteDuplicateAdapter(network, false);
- ResolvePackageManager();
-
- yield break;
- }
-
- public void RemoveNetwork(Network network)
- {
- var appLovinManifest = AppLovinUpmManifest.Load();
- RemovePackages(network, appLovinManifest);
- appLovinManifest.Save();
- ResolvePackageManager();
- }
-
- ///
- /// Adds a network's packages to the package manager removes any beta version that exists
- ///
- /// The network to add.
- /// The AppLovinUpmManifest instance to edit
- internal static void AddPackages(Network network, AppLovinUpmManifest appLovinManifest)
- {
- foreach (var packageInfo in network.Packages)
- {
- appLovinManifest.AddPackageDependency(packageInfo.Name, packageInfo.Version);
- RemoveBetaPackage(packageInfo.Name, appLovinManifest);
- }
- }
-
- ///
- /// Removes a network's packages from the package manager
- ///
- /// The network to add.
- /// The AppLovinUpmManifest instance to edit
- internal static void RemovePackages(Network network, AppLovinUpmManifest appLovinManifest)
- {
- foreach (var packageInfo in network.Packages)
- {
- appLovinManifest.RemovePackageDependency(packageInfo.Name);
- RemoveBetaPackage(packageInfo.Name, appLovinManifest);
- }
- }
-
- ///
- /// Removes the beta version of a package name
- ///
- /// The name of the package to remove a beta for
- /// The AppLovinUpmManifest instance to edit
- private static void RemoveBetaPackage(string packageName, AppLovinUpmManifest appLovinManifest)
- {
- var prefix = "";
- if (packageName.Contains(PackageNamePrefixNetwork))
- {
- prefix = PackageNamePrefixNetwork;
- }
- else if (packageName.Contains(PackageNamePrefixDsp))
- {
- prefix = PackageNamePrefixDsp;
- }
- else if (packageName.Contains(PackageNamePrefixAppLovin))
- {
- prefix = PackageNamePrefixAppLovin;
- }
- else
- {
- return;
- }
-
- var betaPackageName = packageName.Replace(prefix, prefix + ".beta");
- appLovinManifest.RemovePackageDependency(betaPackageName);
- }
-
- ///
- /// Resolves the Unity Package Manager so any changes made to the manifest.json file are reflected in the Unity Editor.
- ///
- internal static void ResolvePackageManager()
- {
-#if UNITY_2020_1_OR_NEWER
- Client.Resolve();
-#else
- packageManagerClientType = packageManagerClientType ?? typeof(Client);
- if (packageManagerClientType != null)
- {
- packageManagerResolveMethod = packageManagerResolveMethod ?? packageManagerClientType.GetMethod("Resolve", BindingFlags.NonPublic | BindingFlags.Static);
- }
-
- if (packageManagerResolveMethod != null)
- {
- packageManagerResolveMethod.Invoke(null, null);
- }
-#endif
- }
-
- ///
- /// Gets the PackageCollection from the Unity Package Manager synchronously.
- ///
- /// How long to wait before exiting with a timeout error
- ///
- private static PackageCollection GetPackageCollectionSync(float timeoutSeconds = -1)
- {
- var request = Client.List();
-
- // Just wait till the request is complete
- var now = DateTime.Now;
- while (!request.IsCompleted)
- {
- // Wait indefinitely if there is no timeout set.
- if (timeoutSeconds < 0) continue;
-
- var delta = DateTime.Now - now;
- if (delta.TotalSeconds > timeoutSeconds)
- {
- MaxSdkLogger.UserError("Failed to list UPM packages: Timeout");
- break;
- }
- }
-
- if (!request.IsCompleted)
- {
- return null;
- }
-
- if (request.Status >= StatusCode.Failure)
- {
- MaxSdkLogger.UserError("Failed to list packages: " + request.Error.message);
- return null;
- }
-
- return (request.Status == StatusCode.Success) ? request.Result : null;
- }
- }
-
- public class AppLovinAssetsPackageManager : IPackageManagerClient
- {
- public static List GetInstalledMediationNetworks()
- {
- var maxMediationDirectory = AppLovinIntegrationManager.MediationDirectory;
- if (!Directory.Exists(maxMediationDirectory)) return new List();
-
- var mediationNetworkDirectories = Directory.GetDirectories(maxMediationDirectory);
- return mediationNetworkDirectories.Select(Path.GetFileName).ToList();
- }
-
- public IEnumerator AddNetwork(Network network, bool showImport)
- {
- yield return AppLovinIntegrationManager.Instance.DownloadPlugin(network, showImport);
- }
-
- public void RemoveNetwork(Network network)
- {
- foreach (var pluginFilePath in network.PluginFilePaths)
- {
- var filePath = Path.Combine(AppLovinIntegrationManager.PluginParentDirectory, pluginFilePath);
- FileUtil.DeleteFileOrDirectory(filePath);
- FileUtil.DeleteFileOrDirectory(filePath + ".meta");
- }
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs.meta
deleted file mode 100644
index 5a508fac..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 69faa9dfd9aac483daa24261a3e11206
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPackageManager.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs
deleted file mode 100644
index e240323c..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs
+++ /dev/null
@@ -1,166 +0,0 @@
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using UnityEditor;
-using UnityEngine;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// Moves our SDK Unity Plugin from under the Assets folder to the Unity Package Manager.
- ///
- public static class AppLovinPluginMigrationHelper
- {
- private const string ApplovinRegistryName = "AppLovin MAX Unity";
- private const string ApplovinRegistryUrl = "https://unity.packages.applovin.com/";
- private static readonly List AppLovinRegistryScopes = new List() {"com.applovin.mediation.ads", "com.applovin.mediation.adapters", "com.applovin.mediation.dsp"};
-
- private const string OpenUpmRegistryName = "package.openupm.com";
- private const string OpenUpmRegistryUrl = "https://package.openupm.com";
- private static readonly List OpenUpmRegistryScopes = new List() {"com.google.external-dependency-manager"};
-
- private static List betaNetworkPluginFilePaths = new List();
-
- ///
- /// Attempts to move the Unity plugin to UPM by adding the AppLovin scoped registry and dependencies to the manifest.
- ///
- /// The Unity Plugin data for our sdk and mediation adapters.
- /// Whether to delete the EDM folder under "Assets"
- internal static void MigrateToUnityPackageManager(PluginData pluginData, bool deleteExternalDependencyManager)
- {
- MaxSdkLogger.UserDebug("Moving AppLovin Unity Plugin to package manager");
-
- if (deleteExternalDependencyManager)
- {
- DeleteExternalDependencyManager();
- }
-
- var appLovinManifest = AppLovinUpmManifest.Load();
-
- MigrateAdapters(pluginData, appLovinManifest);
- MigratePlugin(pluginData, appLovinManifest);
-
- appLovinManifest.Save();
- AppLovinUpmPackageManager.ResolvePackageManager();
- DeletePluginFiles();
- }
-
- ///
- /// Add all currently installed networks to the manifest.
- ///
- internal static void MigrateAdapters(PluginData pluginData, AppLovinUpmManifest appLovinManifest)
- {
- var allNetworks = pluginData.MediatedNetworks.Concat(pluginData.PartnerMicroSdks).ToArray();
- betaNetworkPluginFilePaths.Clear();
-
- // Add every currently installed network and separate it by android and iOS.
- foreach (var network in allNetworks)
- {
- var currentVersion = network.CurrentVersions != null ? network.CurrentVersions.Unity : "";
- if (string.IsNullOrEmpty(currentVersion)) continue;
-
- if (currentVersion.Contains("beta"))
- {
- betaNetworkPluginFilePaths.AddRange(network.PluginFilePaths);
- continue;
- }
-
- AppLovinUpmPackageManager.AddPackages(network, appLovinManifest);
- }
- }
-
- ///
- /// Add the AppLovin scoped registry to the manifest if it doesn't exist. Otherwise update it.
- ///
- private static void MigratePlugin(PluginData pluginData, AppLovinUpmManifest appLovinManifest)
- {
- appLovinManifest.AddOrUpdateRegistry(ApplovinRegistryName, ApplovinRegistryUrl, AppLovinRegistryScopes);
- appLovinManifest.AddOrUpdateRegistry(OpenUpmRegistryName, OpenUpmRegistryUrl, OpenUpmRegistryScopes);
-
- var appLovinVersion = pluginData.AppLovinMax.LatestVersions.Unity;
- appLovinManifest.AddPackageDependency(AppLovinUpmPackageManager.PackageNamePrefixAppLovin, appLovinVersion);
- }
-
- #region Utility
-
- ///
- /// Delete the external dependency manager folder from the project.
- ///
- private static void DeleteExternalDependencyManager()
- {
- var externalDependencyManagerPath = Path.Combine(Application.dataPath, "ExternalDependencyManager");
- FileUtil.DeleteFileOrDirectory(externalDependencyManagerPath);
- FileUtil.DeleteFileOrDirectory(externalDependencyManagerPath + ".meta");
- }
-
- ///
- /// Deletes all the files in the plugin directory except the AppLovinSettings.asset file.
- ///
- private static void DeletePluginFiles()
- {
- if (AppLovinIntegrationManager.IsPluginInPackageManager) return;
-
- var pluginPath = Path.Combine(AppLovinIntegrationManager.PluginParentDirectory, "MaxSdk");
- var appLovinSettingsPath = Path.Combine(pluginPath, "Resources/AppLovinSettings.asset");
-
- var appLovinResourcesDirectory = Path.Combine(pluginPath, "Resources");
- var appLovinSettingsTempPath = Path.Combine(Path.GetTempPath(), "AppLovinSettings.asset");
- var appLovinMediationTempPath = Path.Combine(Path.GetTempPath(), "Mediation");
-
- // Ensure there aren't any errors when moving the files due to the directories/files already existing.
- FileUtil.DeleteFileOrDirectory(appLovinSettingsTempPath);
- FileUtil.DeleteFileOrDirectory(appLovinMediationTempPath);
-
- var mediationAssetsDir = Path.Combine(AppLovinIntegrationManager.PluginParentDirectory, "MaxSdk/Mediation");
-
- // Move the AppLovinSettings.asset file and any beta adapters to a temporary directory.
- File.Move(appLovinSettingsPath, appLovinSettingsTempPath);
- var adapterSaved = MoveBetaAdaptersIfNeeded(mediationAssetsDir, appLovinMediationTempPath);
-
- // Move the meta file if the adapter was saved to save the asset labels
- if (adapterSaved)
- {
- File.Move(mediationAssetsDir, appLovinMediationTempPath + ".meta");
- }
-
- // Delete the plugin directory and then move the AppLovinSettings.asset and beta adapters back.
- FileUtil.DeleteFileOrDirectory(pluginPath);
- Directory.CreateDirectory(appLovinResourcesDirectory);
- File.Move(appLovinSettingsTempPath, appLovinSettingsPath);
- MoveBetaAdaptersIfNeeded(appLovinMediationTempPath, mediationAssetsDir);
- if (adapterSaved)
- {
- File.Move(appLovinMediationTempPath + ".meta", mediationAssetsDir);
- }
-
- FileUtil.DeleteFileOrDirectory(appLovinMediationTempPath);
- }
-
- ///
- /// Moves the beta adapters from a source mediation directory to a destination mediation directory.
- ///
- /// The directory containing the beta adapters to be moved.
- /// The target directory where the beta adapters should be moved.
- private static bool MoveBetaAdaptersIfNeeded(string sourceMediationDirectory, string destinationMediationDirectory)
- {
- if (betaNetworkPluginFilePaths.Count == 0 || !Directory.Exists(sourceMediationDirectory)) return false;
-
- var movedAdapter = false;
- Directory.CreateDirectory(destinationMediationDirectory);
- foreach (var pluginFilePath in betaNetworkPluginFilePaths)
- {
- var sourceDirectory = Path.Combine(sourceMediationDirectory, Path.GetFileName(pluginFilePath));
- var destinationDirectory = Path.Combine(destinationMediationDirectory, Path.GetFileName(pluginFilePath));
- if (Directory.Exists(sourceDirectory))
- {
- Directory.Move(sourceDirectory, destinationDirectory);
- movedAdapter = true;
- }
- }
-
- return movedAdapter;
- }
-
- #endregion
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs.meta
deleted file mode 100644
index dc78f483..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 11288612632de49b99708cdee436692c
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPluginMigrationHelper.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs
deleted file mode 100644
index ae86796a..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs
+++ /dev/null
@@ -1,482 +0,0 @@
-//
-// MaxPostProcessBuildAndroid.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 4/10/20.
-// Copyright © 2020 AppLovin. All rights reserved.
-//
-
-#if UNITY_ANDROID
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text.RegularExpressions;
-using System.Xml.Linq;
-using AppLovinMax.ThirdParty.MiniJson;
-using UnityEditor;
-using UnityEditor.Android;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// A post processor used to update the Android project once it is generated.
- ///
- public class AppLovinPostProcessAndroid : IPostGenerateGradleAndroidProject
- {
- private const string PropertyAndroidX = "android.useAndroidX";
- private const string PropertyJetifier = "android.enableJetifier";
- private const string EnableProperty = "=true";
- private const string PropertyDexingArtifactTransform = "android.enableDexingArtifactTransform";
- private const string DisableProperty = "=false";
-
- private const string KeyMetaDataAppLovinVerboseLoggingOn = "applovin.sdk.verbose_logging";
- private const string KeyMetaDataGoogleApplicationId = "com.google.android.gms.ads.APPLICATION_ID";
- private const string KeyMetaDataGoogleOptimizeInitialization = "com.google.android.gms.ads.flag.OPTIMIZE_INITIALIZATION";
- private const string KeyMetaDataGoogleOptimizeAdLoading = "com.google.android.gms.ads.flag.OPTIMIZE_AD_LOADING";
-
- private const string KeyMetaDataMobileFuseAutoInit = "com.mobilefuse.sdk.disable_auto_init";
- private const string KeyMetaDataMyTargetAutoInit = "com.my.target.autoInitMode";
-
- private const string KeyMetaDataAppLovinSdkKey = "applovin.sdk.key";
-
- private const string AppLovinSettingsFileName = "applovin_settings.json";
-
- private const string KeySdkKey = "sdk_key";
- private const string KeyConsentFlowSettings = "consent_flow_settings";
- private const string KeyConsentFlowEnabled = "consent_flow_enabled";
- private const string KeyConsentFlowTermsOfService = "consent_flow_terms_of_service";
- private const string KeyConsentFlowPrivacyPolicy = "consent_flow_privacy_policy";
- private const string KeyConsentFlowShowTermsAndPrivacyPolicyAlertInGDPR = "consent_flow_show_terms_and_privacy_policy_alert_in_gdpr";
- private const string KeyConsentFlowDebugUserGeography = "consent_flow_debug_user_geography";
-
- private const string KeyRenderOutsideSafeArea = "render_outside_safe_area";
-
-#if UNITY_2022_3_OR_NEWER
- // To match "'com.android.library' version '7.3.1'" line in build.gradle
- private static readonly Regex TokenGradleVersionLibrary = new Regex(".*id ['\"]com\\.android\\.library['\"] version");
- private static readonly Regex TokenGradleVersion = new Regex(".*id ['\"]com\\.android\\.application['\"] version");
-#else
- // To match "classpath 'com.android.tools.build:gradle:4.0.1'" line in build.gradle
- private static readonly Regex TokenGradleVersion = new Regex(".*classpath ['\"]com\\.android\\.tools\\.build:gradle:.*");
-#endif
-
- // To match "distributionUrl=..." in gradle-wrapper.properties file
- private static readonly Regex TokenDistributionUrl = new Regex(".*distributionUrl.*");
-
- private static readonly XNamespace AndroidNamespace = "http://schemas.android.com/apk/res/android";
-
- public void OnPostGenerateGradleAndroidProject(string path)
- {
- var rootGradleBuildFilePath = Path.Combine(path, "../build.gradle");
- var gradlePropertiesPath = Path.Combine(path, "../gradle.properties");
- var gradleWrapperPropertiesPath = Path.Combine(path, "../gradle/wrapper/gradle-wrapper.properties");
-
- UpdateGradleVersionsIfNeeded(gradleWrapperPropertiesPath, rootGradleBuildFilePath);
-
- var gradlePropertiesUpdated = new List();
-
- // If the gradle properties file already exists, make sure to add any previous properties.
- if (File.Exists(gradlePropertiesPath))
- {
- var lines = File.ReadAllLines(gradlePropertiesPath);
-
- // Add all properties except AndroidX, Jetifier, and DexingArtifactTransform since they may already exist. We will re-add them below.
- gradlePropertiesUpdated.AddRange(lines.Where(line => !line.Contains(PropertyAndroidX) && !line.Contains(PropertyJetifier) && !line.Contains(PropertyDexingArtifactTransform)));
- }
-
- // Enable AndroidX and Jetifier properties
- gradlePropertiesUpdated.Add(PropertyAndroidX + EnableProperty);
- gradlePropertiesUpdated.Add(PropertyJetifier + EnableProperty);
-
- // `DexingArtifactTransform` has been removed in Gradle 8+ which is the default Gradle version for Unity 6.
-#if !UNITY_6000_0_OR_NEWER
- // Disable dexing using artifact transform (it causes issues for ExoPlayer with Gradle plugin 3.5.0+)
- gradlePropertiesUpdated.Add(PropertyDexingArtifactTransform + DisableProperty);
-#endif
-
- try
- {
- File.WriteAllText(gradlePropertiesPath, string.Join("\n", gradlePropertiesUpdated.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to enable AndroidX and Jetifier. gradle.properties file write failed.");
- Console.WriteLine(exception);
- }
-
- ProcessAndroidManifest(path);
- AddSdkSettings(path);
- }
-
- public int callbackOrder
- {
- get { return AppLovinPreProcess.CallbackOrder; }
- }
-
- private static void ProcessAndroidManifest(string path)
- {
- var manifestPath = Path.Combine(path, "src/main/AndroidManifest.xml");
- XDocument manifest;
- try
- {
- manifest = XDocument.Load(manifestPath);
- }
-#pragma warning disable 0168
- catch (IOException exception)
-#pragma warning restore 0168
- {
- MaxSdkLogger.UserWarning("[AppLovin MAX] AndroidManifest.xml is missing.");
- return;
- }
-
- // Get the `manifest` element.
- var elementManifest = manifest.Element("manifest");
- if (elementManifest == null)
- {
- MaxSdkLogger.UserWarning("[AppLovin MAX] AndroidManifest.xml is invalid.");
- return;
- }
-
- var elementApplication = elementManifest.Element("application");
- if (elementApplication == null)
- {
- MaxSdkLogger.UserWarning("[AppLovin MAX] AndroidManifest.xml is invalid.");
- return;
- }
-
- var metaDataElements = elementApplication.Descendants().Where(element => element.Name.LocalName.Equals("meta-data"));
-
- EnableVerboseLoggingIfNeeded(elementApplication);
- AddGoogleApplicationIdIfNeeded(elementApplication, metaDataElements);
- AddGoogleOptimizationFlagsIfNeeded(elementApplication, metaDataElements);
- DisableAutoInitIfNeeded(elementApplication, metaDataElements);
- RemoveSdkKeyIfNeeded(metaDataElements);
-
- // Save the updated manifest file.
- manifest.Save(manifestPath);
- }
-
- private static void EnableVerboseLoggingIfNeeded(XElement elementApplication)
- {
- var enabled = EditorPrefs.GetBool(MaxSdkLogger.KeyVerboseLoggingEnabled, false);
-
- var descendants = elementApplication.Descendants();
- var verboseLoggingMetaData = descendants.FirstOrDefault(descendant => descendant.FirstAttribute != null &&
- descendant.FirstAttribute.Name.LocalName.Equals("name") &&
- descendant.FirstAttribute.Value.Equals(KeyMetaDataAppLovinVerboseLoggingOn) &&
- descendant.LastAttribute != null &&
- descendant.LastAttribute.Name.LocalName.Equals("value"));
-
- // check if applovin.sdk.verbose_logging meta data exists.
- if (verboseLoggingMetaData != null)
- {
- if (enabled)
- {
- // update applovin.sdk.verbose_logging meta data value.
- verboseLoggingMetaData.LastAttribute.Value = enabled.ToString();
- }
- else
- {
- // remove applovin.sdk.verbose_logging meta data.
- verboseLoggingMetaData.Remove();
- }
- }
- else
- {
- if (enabled)
- {
- // add applovin.sdk.verbose_logging meta data if it does not exist.
- var metaData = CreateMetaDataElement(KeyMetaDataAppLovinVerboseLoggingOn, enabled.ToString());
- elementApplication.Add(metaData);
- }
- }
- }
-
- private static void AddGoogleApplicationIdIfNeeded(XElement elementApplication, IEnumerable metaDataElements)
- {
- if (!AppLovinPackageManager.IsAdapterInstalled("Google") && !AppLovinPackageManager.IsAdapterInstalled("GoogleAdManager")) return;
-
- var googleApplicationIdMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataGoogleApplicationId);
- var appId = AppLovinSettings.Instance.AdMobAndroidAppId;
- // Log error if the App ID is not set.
- if (string.IsNullOrEmpty(appId) || !appId.StartsWith("ca-app-pub-"))
- {
- MaxSdkLogger.UserError("Google App ID is not set. Please enter a valid app ID within the AppLovin Integration Manager window.");
- return;
- }
-
- // Check if the Google App ID meta data already exists. Update if it already exists.
- if (googleApplicationIdMetaData != null)
- {
- googleApplicationIdMetaData.SetAttributeValue(AndroidNamespace + "value", appId);
- }
- // Meta data doesn't exist, add it.
- else
- {
- elementApplication.Add(CreateMetaDataElement(KeyMetaDataGoogleApplicationId, appId));
- }
- }
-
- private static void AddGoogleOptimizationFlagsIfNeeded(XElement elementApplication, IEnumerable metaDataElements)
- {
- if (!AppLovinPackageManager.IsAdapterInstalled("Google") && !AppLovinPackageManager.IsAdapterInstalled("GoogleAdManager")) return;
-
- var googleOptimizeInitializationMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataGoogleOptimizeInitialization);
- // If meta data doesn't exist, add it
- if (googleOptimizeInitializationMetaData == null)
- {
- elementApplication.Add(CreateMetaDataElement(KeyMetaDataGoogleOptimizeInitialization, true));
- }
-
- var googleOptimizeAdLoadingMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataGoogleOptimizeAdLoading);
- // If meta data doesn't exist, add it
- if (googleOptimizeAdLoadingMetaData == null)
- {
- elementApplication.Add(CreateMetaDataElement(KeyMetaDataGoogleOptimizeAdLoading, true));
- }
- }
-
- private static void DisableAutoInitIfNeeded(XElement elementApplication, IEnumerable metaDataElements)
- {
- if (AppLovinPackageManager.IsAdapterInstalled("MobileFuse"))
- {
- var mobileFuseMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataMobileFuseAutoInit);
- // If MobileFuse meta data doesn't exist, add it
- if (mobileFuseMetaData == null)
- {
- elementApplication.Add(CreateMetaDataElement(KeyMetaDataMobileFuseAutoInit, true));
- }
- }
-
- if (AppLovinPackageManager.IsAdapterInstalled("MyTarget"))
- {
- var myTargetMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataMyTargetAutoInit);
- // If MyTarget meta data doesn't exist, add it
- if (myTargetMetaData == null)
- {
- elementApplication.Add(CreateMetaDataElement(KeyMetaDataMyTargetAutoInit, 0));
- }
- }
- }
-
- private static void RemoveSdkKeyIfNeeded(IEnumerable metaDataElements)
- {
- var sdkKeyMetaData = GetMetaDataElement(metaDataElements, KeyMetaDataAppLovinSdkKey);
- if (sdkKeyMetaData == null) return;
-
- sdkKeyMetaData.Remove();
- }
-
- private static void UpdateGradleVersionsIfNeeded(string gradleWrapperPropertiesPath, string rootGradleBuildFilePath)
- {
- var customGradleVersionUrl = AppLovinSettings.Instance.CustomGradleVersionUrl;
- var customGradleToolsVersion = AppLovinSettings.Instance.CustomGradleToolsVersion;
-
- if (MaxSdkUtils.IsValidString(customGradleVersionUrl))
- {
- var newDistributionUrl = string.Format("distributionUrl={0}", customGradleVersionUrl);
- if (ReplaceStringInFile(gradleWrapperPropertiesPath, TokenDistributionUrl, newDistributionUrl))
- {
- MaxSdkLogger.D("Distribution url set to " + newDistributionUrl);
- }
- else
- {
- MaxSdkLogger.E("Failed to set distribution URL");
- }
- }
-
- if (MaxSdkUtils.IsValidString(customGradleToolsVersion))
- {
-#if UNITY_2022_3_OR_NEWER
- // Unity 2022.3+ requires Gradle Plugin version 7.1.2+.
- if (MaxSdkUtils.CompareVersions(customGradleToolsVersion, "7.1.2") == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- MaxSdkLogger.E("Failed to set gradle plugin version. Unity 2022.3+ requires gradle plugin version 7.1.2+");
- return;
- }
-
- var newGradleVersionLibraryLine = AppLovinProcessGradleBuildFile.GetFormattedBuildScriptLine(string.Format("id 'com.android.library' version '{0}' apply false", customGradleToolsVersion));
- if (ReplaceStringInFile(rootGradleBuildFilePath, TokenGradleVersionLibrary, newGradleVersionLibraryLine))
- {
- MaxSdkLogger.D("Gradle library version set to " + newGradleVersionLibraryLine);
- }
- else
- {
- MaxSdkLogger.E("Failed to set gradle library version");
- }
-
- var newGradleVersionLine = AppLovinProcessGradleBuildFile.GetFormattedBuildScriptLine(string.Format("id 'com.android.application' version '{0}' apply false", customGradleToolsVersion));
-#else
- var newGradleVersionLine = AppLovinProcessGradleBuildFile.GetFormattedBuildScriptLine(string.Format("classpath 'com.android.tools.build:gradle:{0}'", customGradleToolsVersion));
-#endif
- if (ReplaceStringInFile(rootGradleBuildFilePath, TokenGradleVersion, newGradleVersionLine))
- {
- MaxSdkLogger.D("Gradle version set to " + newGradleVersionLine);
- }
- else
- {
- MaxSdkLogger.E("Failed to set gradle plugin version");
- }
- }
- }
-
- private static void AddSdkSettings(string path)
- {
- var appLovinSdkSettings = new Dictionary();
- var rawResourceDirectory = Path.Combine(path, "src/main/res/raw");
-
- // Add the SDK key to the SDK settings.
- appLovinSdkSettings[KeySdkKey] = AppLovinSettings.Instance.SdkKey;
- appLovinSdkSettings[KeyRenderOutsideSafeArea] = PlayerSettings.Android.renderOutsideSafeArea;
-
- // Add the Terms and Privacy Policy flow settings if needed.
- EnableConsentFlowIfNeeded(rawResourceDirectory, appLovinSdkSettings);
-
- WriteAppLovinSettings(rawResourceDirectory, appLovinSdkSettings);
- }
-
- private static void EnableConsentFlowIfNeeded(string rawResourceDirectory, Dictionary applovinSdkSettings)
- {
- // Check if consent flow is enabled. No need to create the applovin_consent_flow_settings.json if consent flow is disabled.
- var consentFlowEnabled = AppLovinInternalSettings.Instance.ConsentFlowEnabled;
- if (!consentFlowEnabled)
- {
- RemoveAppLovinSettingsRawResourceFileIfNeeded(rawResourceDirectory);
- return;
- }
-
- var privacyPolicyUrl = AppLovinInternalSettings.Instance.ConsentFlowPrivacyPolicyUrl;
- if (string.IsNullOrEmpty(privacyPolicyUrl))
- {
- AppLovinIntegrationManager.ShowBuildFailureDialog("You cannot use the AppLovin SDK's consent flow without defining a Privacy Policy URL in the AppLovin Integration Manager.");
-
- // No need to update the applovin_consent_flow_settings.json here. Default consent flow state will be determined on the SDK side.
- return;
- }
-
- var consentFlowSettings = new Dictionary();
- consentFlowSettings[KeyConsentFlowEnabled] = consentFlowEnabled;
- consentFlowSettings[KeyConsentFlowPrivacyPolicy] = privacyPolicyUrl;
-
- var termsOfServiceUrl = AppLovinInternalSettings.Instance.ConsentFlowTermsOfServiceUrl;
- if (MaxSdkUtils.IsValidString(termsOfServiceUrl))
- {
- consentFlowSettings[KeyConsentFlowTermsOfService] = termsOfServiceUrl;
- }
-
- consentFlowSettings[KeyConsentFlowShowTermsAndPrivacyPolicyAlertInGDPR] = AppLovinInternalSettings.Instance.ShouldShowTermsAndPrivacyPolicyAlertInGDPR;
-
- var debugUserGeography = AppLovinInternalSettings.Instance.DebugUserGeography;
- if (debugUserGeography == MaxSdkBase.ConsentFlowUserGeography.Gdpr)
- {
- consentFlowSettings[KeyConsentFlowDebugUserGeography] = "gdpr";
- }
-
- applovinSdkSettings[KeyConsentFlowSettings] = consentFlowSettings;
- }
-
- private static void WriteAppLovinSettingsRawResourceFile(string applovinSdkSettingsJson, string rawResourceDirectory)
- {
- if (!Directory.Exists(rawResourceDirectory))
- {
- Directory.CreateDirectory(rawResourceDirectory);
- }
-
- var consentFlowSettingsFilePath = Path.Combine(rawResourceDirectory, AppLovinSettingsFileName);
- try
- {
- File.WriteAllText(consentFlowSettingsFilePath, applovinSdkSettingsJson + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("applovin_settings.json file write failed due to: " + exception.Message);
- Console.WriteLine(exception);
- }
- }
-
- ///
- /// Removes the applovin_settings json file from the build if it exists.
- ///
- /// The raw resource directory that holds the json file
- private static void RemoveAppLovinSettingsRawResourceFileIfNeeded(string rawResourceDirectory)
- {
- var consentFlowSettingsFilePath = Path.Combine(rawResourceDirectory, AppLovinSettingsFileName);
- if (!File.Exists(consentFlowSettingsFilePath)) return;
-
- try
- {
- File.Delete(consentFlowSettingsFilePath);
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Deleting applovin_settings.json failed due to: " + exception.Message);
- Console.WriteLine(exception);
- }
- }
-
- private static void WriteAppLovinSettings(string rawResourceDirectory, Dictionary applovinSdkSettings)
- {
- var applovinSdkSettingsJson = Json.Serialize(applovinSdkSettings);
- WriteAppLovinSettingsRawResourceFile(applovinSdkSettingsJson, rawResourceDirectory);
- }
-
- ///
- /// Creates and returns a meta-data element with the given name and value.
- ///
- private static XElement CreateMetaDataElement(string name, object value)
- {
- var metaData = new XElement("meta-data");
- metaData.Add(new XAttribute(AndroidNamespace + "name", name));
- metaData.Add(new XAttribute(AndroidNamespace + "value", value));
-
- return metaData;
- }
-
- ///
- /// Looks through all the given meta-data elements to check if the required one exists. Returns null if it doesn't exist.
- ///
- private static XElement GetMetaDataElement(IEnumerable metaDataElements, string metaDataName)
- {
- foreach (var metaDataElement in metaDataElements)
- {
- var attributes = metaDataElement.Attributes();
- if (attributes.Any(attribute => attribute.Name.Namespace.Equals(AndroidNamespace)
- && attribute.Name.LocalName.Equals("name")
- && attribute.Value.Equals(metaDataName)))
- {
- return metaDataElement;
- }
- }
-
- return null;
- }
-
- ///
- /// Finds the first line that contains regexToMatch and replaces the whole line with replacement
- ///
- /// Path to the file you want to replace a line in
- /// Regex to search for in the line you want to replace
- /// String that you want as the new line
- /// Returns whether the string was successfully replaced or not
- private static bool ReplaceStringInFile(string path, Regex regexToMatch, string replacement)
- {
- if (!File.Exists(path)) return false;
-
- var lines = File.ReadAllLines(path);
- for (var i = 0; i < lines.Length; i++)
- {
- if (regexToMatch.IsMatch(lines[i]))
- {
- lines[i] = replacement;
- File.WriteAllLines(path, lines);
- return true;
- }
- }
-
- return false;
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs.meta
deleted file mode 100644
index 28771409..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: c01ea79d0cb2a43c093e2fd07201df9e
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroid.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs
deleted file mode 100644
index e56f2556..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs
+++ /dev/null
@@ -1,51 +0,0 @@
-//
-// AppLovinBuildPostProcessor.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 8/29/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-#if UNITY_ANDROID
-
-using System.IO;
-using UnityEditor.Android;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// Adds Quality Service plugin to the Gradle project once the project has been exported. See for more details.
- ///
- public class AppLovinPostProcessGradleProject : AppLovinProcessGradleBuildFile, IPostGenerateGradleAndroidProject
- {
- public void OnPostGenerateGradleAndroidProject(string path)
- {
- if (!AppLovinSettings.Instance.QualityServiceEnabled) return;
-
- var failedToAddPlugin = !AddQualityServiceToRootGradleFile(path);
- if (failedToAddPlugin)
- {
- MaxSdkLogger.UserWarning("Failed to add AppLovin Quality Service plugin to the gradle project.");
- return;
- }
-
- // The plugin needs to be added to the application module (named launcher)
- var applicationGradleBuildFilePath = Path.Combine(path, "../launcher/build.gradle");
-
- if (!File.Exists(applicationGradleBuildFilePath))
- {
- MaxSdkLogger.UserWarning("Couldn't find build.gradle file. Failed to add AppLovin Quality Service plugin to the gradle project.");
- return;
- }
-
- AddAppLovinQualityServicePlugin(applicationGradleBuildFilePath);
- }
-
- public int callbackOrder
- {
- get { return CallbackOrder; }
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs.meta
deleted file mode 100644
index c167f0ce..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: f75e54e2eb78f427ca8643c97684387b
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessAndroidGradle.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs
deleted file mode 100644
index 475481d0..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs
+++ /dev/null
@@ -1,686 +0,0 @@
-//
-// MaxIntegrationManager.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 8/29/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-#if UNITY_IOS || UNITY_IPHONE
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text.RegularExpressions;
-using AppLovinMax.Internal;
-using UnityEditor;
-using UnityEditor.Callbacks;
-using UnityEditor.iOS.Xcode.Extensions;
-using UnityEditor.iOS.Xcode;
-using UnityEngine;
-using UnityEngine.Networking;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- [Serializable]
- public class SkAdNetworkData
- {
- [SerializeField] public string[] SkAdNetworkIds;
- }
-
- public class AppLovinPostProcessiOS
- {
- private const string OutputFileName = "AppLovinQualityServiceSetup.rb";
-
- // Use a priority of 90 to have AppLovin embed frameworks after Pods are installed (EDM finishes installing Pods at priority 60) and before Firebase Crashlytics runs their scripts (at priority 100).
- private const int AppLovinEmbedFrameworksPriority = 90;
-
- private const string TargetUnityIphonePodfileLine = "target 'Unity-iPhone' do";
- private const string UseFrameworksPodfileLine = "use_frameworks!";
- private const string UseFrameworksDynamicPodfileLine = "use_frameworks! :linkage => :dynamic";
- private const string UseFrameworksStaticPodfileLine = "use_frameworks! :linkage => :static";
-
- private const string ResourcesDirectoryName = "Resources";
- private const string AppLovinMaxResourcesDirectoryName = "AppLovinMAXResources";
- private const string AppLovinAdvertisingAttributionEndpoint = "https://postbacks-app.com";
-
- private const string AppLovinSettingsPlistFileName = "AppLovin-Settings.plist";
-
- private const string KeySdkKey = "SdkKey";
-
- private const string AppLovinVerboseLoggingOnKey = "AppLovinVerboseLoggingOn";
-
- private const string KeyConsentFlowInfo = "ConsentFlowInfo";
- private const string KeyConsentFlowEnabled = "ConsentFlowEnabled";
- private const string KeyConsentFlowTermsOfService = "ConsentFlowTermsOfService";
- private const string KeyConsentFlowPrivacyPolicy = "ConsentFlowPrivacyPolicy";
- private const string KeyConsentFlowShowTermsAndPrivacyPolicyAlertInGDPR = "ConsentFlowShowTermsAndPrivacyPolicyAlertInGDPR";
- private const string KeyConsentFlowDebugUserGeography = "ConsentFlowDebugUserGeography";
-
- private const string KeyAppLovinSdkKeyToRemove = "AppLovinSdkKey";
-
- private static readonly Regex PodfilePodLineRegex = new Regex("pod \'([^\']*)\'");
-
- ///
- /// Adds AppLovin Quality Service to the iOS project once the project has been exported.
- ///
- /// 1. Downloads the Quality Service ruby script.
- /// 2. Runs the script using Ruby which integrates AppLovin Quality Service to the project.
- ///
- [PostProcessBuild(AppLovinPreProcess.CallbackOrder)] // We want to run Quality Service script last.
- public static void OnPostProcessBuild(BuildTarget buildTarget, string buildPath)
- {
- if (!AppLovinSettings.Instance.QualityServiceEnabled) return;
-
- var sdkKey = AppLovinSettings.Instance.SdkKey;
- if (string.IsNullOrEmpty(sdkKey))
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. SDK Key is empty. Please enter the AppLovin SDK Key in the Integration Manager.");
- return;
- }
-
- var outputFilePath = Path.Combine(buildPath, OutputFileName);
-
- // Check if Quality Service is already installed.
- if (File.Exists(outputFilePath) && Directory.Exists(Path.Combine(buildPath, "AppLovinQualityService")))
- {
- // TODO: Check if there is a way to validate if the SDK key matches the script. Else the pub can't use append when/if they change the SDK Key.
- return;
- }
-
- var webRequestConfig = new WebRequestConfig()
- {
- DownloadHandler = new DownloadHandlerFile(outputFilePath),
- JsonString = string.Format("{{\"sdk_key\" : \"{0}\"}}", sdkKey),
- EndPoint = "https://api2.safedk.com/v1/build/ios_setup2",
- RequestType = WebRequestType.Post,
- };
-
- webRequestConfig.Headers.Add("Content-Type", "application/json");
-
- var maxWebRequest = new MaxWebRequest(webRequestConfig);
-
- var webResponse = maxWebRequest.SendSync();
- if (!webResponse.IsSuccess)
- {
- MaxSdkLogger.UserError("AppLovin Quality Service installation failed. Failed to download script with error: " + webResponse.ErrorMessage);
- return;
- }
-
- // Check if Ruby is installed
- var rubyVersion = AppLovinCommandLine.Run("ruby", "--version", buildPath);
- if (rubyVersion.ExitCode != 0)
- {
- MaxSdkLogger.UserError("AppLovin Quality Service installation requires Ruby. Please install Ruby, export it to your system PATH and re-export the project.");
- return;
- }
-
- // Ruby is installed, run `ruby AppLovinQualityServiceSetup.rb`
- var result = AppLovinCommandLine.Run("ruby", OutputFileName, buildPath);
-
- // Check if we have an error.
- if (result.ExitCode != 0) MaxSdkLogger.UserError("Failed to set up AppLovin Quality Service");
-
- MaxSdkLogger.UserDebug(result.Message);
- }
-
- [PostProcessBuild(AppLovinEmbedFrameworksPriority)]
- public static void MaxPostProcessPbxProject(BuildTarget buildTarget, string buildPath)
- {
- var projectPath = PBXProject.GetPBXProjectPath(buildPath);
- var project = new PBXProject();
- project.ReadFromFile(projectPath);
-
- var unityMainTargetGuid = project.GetUnityMainTargetGuid();
- var unityFrameworkTargetGuid = project.GetUnityFrameworkTargetGuid();
-
- EmbedDynamicLibrariesIfNeeded(buildPath, project, unityMainTargetGuid);
-
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionDe, "de", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEn, "en", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEs, "es", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionFr, "fr", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionJa, "ja", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionKo, "ko", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHans, "zh-Hans", buildPath, project, unityMainTargetGuid);
- LocalizeUserTrackingDescriptionIfNeeded(AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionZhHant, "zh-Hant", buildPath, project, unityMainTargetGuid);
-
- AddSwiftSupport(buildPath, project, unityFrameworkTargetGuid, unityMainTargetGuid);
- AddYandexSettingsIfNeeded(project, unityMainTargetGuid);
-
- project.WriteToFile(projectPath);
- }
-
- private static void EmbedDynamicLibrariesIfNeeded(string buildPath, PBXProject project, string targetGuid)
- {
- // Check that the Pods directory exists (it might not if a publisher is building with Generate Podfile setting disabled in EDM).
- var podsDirectory = Path.Combine(buildPath, "Pods");
- if (!Directory.Exists(podsDirectory) || !ShouldEmbedDynamicLibraries(buildPath)) return;
-
- var dynamicLibraryPathsToEmbed = GetDynamicLibraryPathsToEmbed(podsDirectory, buildPath);
- if (dynamicLibraryPathsToEmbed == null || dynamicLibraryPathsToEmbed.Count == 0) return;
-
- foreach (var dynamicLibraryPath in dynamicLibraryPathsToEmbed)
- {
- var fileGuid = project.AddFile(dynamicLibraryPath, dynamicLibraryPath);
- project.AddFileToEmbedFrameworks(targetGuid, fileGuid);
- }
- }
-
- ///
- /// |-----------------------------------------------------------------------------------------------------------------------------------------------------|
- /// | embed | use_frameworks! (:linkage => :dynamic) | use_frameworks! :linkage => :static | `use_frameworks!` line not present |
- /// |---------------------------|------------------------------------------|---------------------------------------|--------------------------------------|
- /// | Unity-iPhone present | Do not embed dynamic libraries | Embed dynamic libraries | Do not embed dynamic libraries |
- /// | Unity-iPhone not present | Embed dynamic libraries | Embed dynamic libraries | Embed dynamic libraries |
- /// |-----------------------------------------------------------------------------------------------------------------------------------------------------|
- ///
- /// An iOS build path
- /// Whether or not the dynamic libraries should be embedded.
- private static bool ShouldEmbedDynamicLibraries(string buildPath)
- {
- var podfilePath = Path.Combine(buildPath, "Podfile");
- if (!File.Exists(podfilePath)) return false;
-
- // If the Podfile doesn't have a `Unity-iPhone` target, we should embed the dynamic libraries.
- var lines = File.ReadAllLines(podfilePath);
- var containsUnityIphoneTarget = lines.Any(line => line.Contains(TargetUnityIphonePodfileLine));
- if (!containsUnityIphoneTarget) return true;
-
- // If the Podfile does not have a `use_frameworks! :linkage => static` line, we should not embed the dynamic libraries.
- var useFrameworksStaticLineIndex = Array.FindIndex(lines, line => line.Contains(UseFrameworksStaticPodfileLine));
- if (useFrameworksStaticLineIndex == -1) return false;
-
- // If more than one of the `use_frameworks!` lines are present, CocoaPods will use the last one.
- var useFrameworksLineIndex = Array.FindIndex(lines, line => line.Trim() == UseFrameworksPodfileLine); // Check for exact line to avoid matching `use_frameworks! :linkage => static/dynamic`
- var useFrameworksDynamicLineIndex = Array.FindIndex(lines, line => line.Contains(UseFrameworksDynamicPodfileLine));
-
- // Check if `use_frameworks! :linkage => :static` is the last line of the three. If it is, we should embed the dynamic libraries.
- return useFrameworksLineIndex < useFrameworksStaticLineIndex && useFrameworksDynamicLineIndex < useFrameworksStaticLineIndex;
- }
-
- private static List GetDynamicLibraryPathsToEmbed(string podsDirectory, string buildPath)
- {
- var podfilePath = Path.Combine(buildPath, "Podfile");
- var dynamicLibraryFrameworksToEmbed = GetDynamicLibraryFrameworksToEmbed(podfilePath);
-
- return GetDynamicLibraryPathsInProjectToEmbed(podsDirectory, dynamicLibraryFrameworksToEmbed);
- }
-
- private static List GetDynamicLibraryFrameworksToEmbed(string podfilePath)
- {
- var dynamicLibrariesToEmbed = GetDynamicLibrariesToEmbed();
-
- var podsInUnityIphoneTarget = GetPodNamesInUnityIphoneTarget(podfilePath);
- var dynamicLibrariesToIgnore = dynamicLibrariesToEmbed.Where(dynamicLibraryToEmbed => podsInUnityIphoneTarget.Contains(dynamicLibraryToEmbed.PodName)).ToList();
-
- // Determine frameworks to embed based on the dynamic libraries to embed and ignore
- var dynamicLibraryFrameworksToIgnore = dynamicLibrariesToIgnore.SelectMany(library => library.FrameworkNames).Distinct().ToList();
- return dynamicLibrariesToEmbed.SelectMany(library => library.FrameworkNames).Except(dynamicLibraryFrameworksToIgnore).Distinct().ToList();
- }
-
- private static List GetDynamicLibrariesToEmbed()
- {
- var pluginData = AppLovinIntegrationManager.LoadPluginDataSync();
- if (pluginData == null)
- {
- MaxSdkLogger.E("Failed to load plugin data. Dynamic libraries will not be embedded.");
- return null;
- }
-
- // Get the dynamic libraries to embed for each network
- var librariesToAdd = pluginData.MediatedNetworks
- .Where(network => network.DynamicLibrariesToEmbed != null)
- .SelectMany(network => network.DynamicLibrariesToEmbed
- .Where(libraryToEmbed => IsRequiredNetworkVersionInstalled(libraryToEmbed, network)))
- .ToList();
-
- // Get the dynamic libraries to embed for AppLovin MAX
- if (pluginData.AppLovinMax.DynamicLibrariesToEmbed != null)
- {
- librariesToAdd.AddRange(pluginData.AppLovinMax.DynamicLibrariesToEmbed);
- }
-
- // Get the dynamic libraries to embed for third parties
- if (pluginData.ThirdPartyDynamicLibrariesToEmbed != null)
- {
- // TODO: Add version check for third party dynamic libraries.
- librariesToAdd.AddRange(pluginData.ThirdPartyDynamicLibrariesToEmbed);
- }
-
- return librariesToAdd;
- }
-
- private static List GetPodNamesInUnityIphoneTarget(string podfilePath)
- {
- var lines = File.ReadAllLines(podfilePath);
- var podNamesInUnityIphone = new List();
-
- var insideUnityIphoneTarget = false;
- foreach (var line in lines)
- {
- // Loop until we find the `target 'Unity-iPhone'` line
- if (insideUnityIphoneTarget)
- {
- if (line.Trim() == "end") break;
-
- if (PodfilePodLineRegex.IsMatch(line))
- {
- var podName = PodfilePodLineRegex.Match(line).Groups[1].Value;
- podNamesInUnityIphone.Add(podName);
- }
- }
- else if (line.Contains(TargetUnityIphonePodfileLine))
- {
- insideUnityIphoneTarget = true;
- }
- }
-
- return podNamesInUnityIphone;
- }
-
- private static bool IsRequiredNetworkVersionInstalled(DynamicLibraryToEmbed libraryToEmbed, Network network)
- {
- var currentIosVersion = network.CurrentVersions.Ios;
- if (string.IsNullOrEmpty(currentIosVersion)) return false;
-
- return MaxSdkUtils.IsVersionInRange(currentIosVersion, libraryToEmbed.MinVersion, libraryToEmbed.MaxVersion);
- }
-
- private static List GetDynamicLibraryPathsInProjectToEmbed(string podsDirectory, List dynamicLibrariesToEmbed)
- {
- var dynamicLibraryPathsPresentInProject = new List();
- foreach (var dynamicLibraryToSearch in dynamicLibrariesToEmbed)
- {
- // both .framework and .xcframework are directories, not files
- var directories = Directory.GetDirectories(podsDirectory, dynamicLibraryToSearch, SearchOption.AllDirectories);
- if (directories.Length <= 0) continue;
-
- var dynamicLibraryAbsolutePath = directories[0];
- var relativePath = GetDynamicLibraryRelativePath(dynamicLibraryAbsolutePath);
- dynamicLibraryPathsPresentInProject.Add(relativePath);
- }
-
- return dynamicLibraryPathsPresentInProject;
- }
-
- private static string GetDynamicLibraryRelativePath(string dynamicLibraryAbsolutePath)
- {
- var index = dynamicLibraryAbsolutePath.LastIndexOf("Pods", StringComparison.Ordinal);
- return dynamicLibraryAbsolutePath.Substring(index);
- }
-
- private static void LocalizeUserTrackingDescriptionIfNeeded(string localizedUserTrackingDescription, string localeCode, string buildPath, PBXProject project, string targetGuid)
- {
- var resourcesDirectoryPath = Path.Combine(buildPath, AppLovinMaxResourcesDirectoryName);
- var localeSpecificDirectoryName = localeCode + ".lproj";
- var localeSpecificDirectoryPath = Path.Combine(resourcesDirectoryPath, localeSpecificDirectoryName);
- var infoPlistStringsFilePath = Path.Combine(localeSpecificDirectoryPath, "InfoPlist.strings");
-
- // Check if localization has been disabled between builds, and remove them as needed.
- if (ShouldRemoveLocalization(localizedUserTrackingDescription))
- {
- if (!File.Exists(infoPlistStringsFilePath)) return;
-
- File.Delete(infoPlistStringsFilePath);
- return;
- }
-
- // Log an error if we detect a localization file for this language in the `Resources` directory
- var legacyResourcedDirectoryPath = Path.Combine(buildPath, ResourcesDirectoryName);
- var localeSpecificLegacyDirectoryPath = Path.Combine(legacyResourcedDirectoryPath, localeSpecificDirectoryName);
- if (Directory.Exists(localeSpecificLegacyDirectoryPath))
- {
- MaxSdkLogger.UserError("Detected existing localization resource for \"" + localeCode + "\" locale. Skipping localization for User Tracking Usage Description. Please disable localization in AppLovin Integration manager and add the localizations to your existing resource.");
- return;
- }
-
- // Create intermediate directories as needed.
- if (!Directory.Exists(resourcesDirectoryPath))
- {
- Directory.CreateDirectory(resourcesDirectoryPath);
- }
-
- if (!Directory.Exists(localeSpecificDirectoryPath))
- {
- Directory.CreateDirectory(localeSpecificDirectoryPath);
- }
-
- var localizedDescriptionLine = "\"NSUserTrackingUsageDescription\" = \"" + localizedUserTrackingDescription + "\";\n";
- // File already exists, update it in case the value changed between builds.
- if (File.Exists(infoPlistStringsFilePath))
- {
- var output = new List();
- var lines = File.ReadAllLines(infoPlistStringsFilePath);
- var keyUpdated = false;
- foreach (var line in lines)
- {
- if (line.Contains("NSUserTrackingUsageDescription"))
- {
- output.Add(localizedDescriptionLine);
- keyUpdated = true;
- }
- else
- {
- output.Add(line);
- }
- }
-
- if (!keyUpdated)
- {
- output.Add(localizedDescriptionLine);
- }
-
- File.WriteAllText(infoPlistStringsFilePath, string.Join("\n", output.ToArray()) + "\n");
- }
- // File doesn't exist, create one.
- else
- {
- File.WriteAllText(infoPlistStringsFilePath, "/* Localized versions of Info.plist keys - Generated by AL MAX plugin */\n" + localizedDescriptionLine);
- }
-
- var localeSpecificDirectoryRelativePath = Path.Combine(AppLovinMaxResourcesDirectoryName, localeSpecificDirectoryName);
- var guid = project.AddFolderReference(localeSpecificDirectoryRelativePath, localeSpecificDirectoryRelativePath);
- project.AddFileToBuild(targetGuid, guid);
- }
-
- private static bool ShouldRemoveLocalization(string localizedUserTrackingDescription)
- {
- if (string.IsNullOrEmpty(localizedUserTrackingDescription)) return true;
-
- var internalSettings = AppLovinInternalSettings.Instance;
- return !internalSettings.ConsentFlowEnabled || !internalSettings.UserTrackingUsageLocalizationEnabled;
- }
-
- private static void AddSwiftSupport(string buildPath, PBXProject project, string unityFrameworkTargetGuid, string unityMainTargetGuid)
- {
- var swiftFileRelativePath = "Classes/MAXSwiftSupport.swift";
- var swiftFilePath = Path.Combine(buildPath, swiftFileRelativePath);
-
- // Add Swift file
- CreateSwiftFile(swiftFilePath);
- var swiftFileGuid = project.AddFile(swiftFileRelativePath, swiftFileRelativePath);
- project.AddFileToBuild(unityFrameworkTargetGuid, swiftFileGuid);
-
- // Add Swift version property if needed
- var swiftVersion = project.GetBuildPropertyForAnyConfig(unityFrameworkTargetGuid, "SWIFT_VERSION");
- if (string.IsNullOrEmpty(swiftVersion))
- {
- project.SetBuildProperty(unityFrameworkTargetGuid, "SWIFT_VERSION", "5.0");
- }
-
- // Some publishers may configure these settings in their own post-processing scripts.
- // Only set them if they haven't already been defined to avoid overwriting publisher-defined values.
- var enableModules = project.GetBuildPropertyForAnyConfig(unityFrameworkTargetGuid, "CLANG_ENABLE_MODULES");
- if (string.IsNullOrEmpty(enableModules))
- {
- project.SetBuildProperty(unityFrameworkTargetGuid, "CLANG_ENABLE_MODULES", "YES");
- }
-
- var alwaysEmbedSwiftLibraries = project.GetBuildPropertyForAnyConfig(unityMainTargetGuid, "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES");
- if (string.IsNullOrEmpty(alwaysEmbedSwiftLibraries))
- {
- project.SetBuildProperty(unityMainTargetGuid, "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES", "YES");
- }
- }
-
- private static void CreateSwiftFile(string swiftFilePath)
- {
- if (File.Exists(swiftFilePath)) return;
-
- // Create a file to write to.
- using (var writer = File.CreateText(swiftFilePath))
- {
- writer.WriteLine("//\n// MAXSwiftSupport.swift\n//");
- writer.WriteLine("\nimport Foundation\n");
- writer.WriteLine("// This file ensures the project includes Swift support.");
- writer.WriteLine("// It is automatically generated by the MAX Unity Plugin.");
- writer.Close();
- }
- }
-
- [PostProcessBuild(AppLovinPreProcess.CallbackOrder)]
- public static void MaxPostProcessPlist(BuildTarget buildTarget, string path)
- {
- var plistPath = Path.Combine(path, "Info.plist");
- var plist = new PlistDocument();
- plist.ReadFromFile(plistPath);
-
- RemoveAttributionReportEndpointIfNeeded(plist);
-
- EnableVerboseLoggingIfNeeded(plist);
- AddGoogleApplicationIdIfNeeded(plist);
-
- AddSdkSettings(plist, path);
- AddSkAdNetworksInfoIfNeeded(plist);
- RemoveSdkKeyIfNeeded(plist);
-
- plist.WriteToFile(plistPath);
- }
-
- private static void RemoveAttributionReportEndpointIfNeeded(PlistDocument plist)
- {
- PlistElement attributionReportEndPoint;
- plist.root.values.TryGetValue("NSAdvertisingAttributionReportEndpoint", out attributionReportEndPoint);
-
- // We no longer support this feature. Check if we had previously set the attribution endpoint and un-set it.
- if (attributionReportEndPoint == null || !AppLovinAdvertisingAttributionEndpoint.Equals(attributionReportEndPoint.AsString())) return;
-
- MaxSdkLogger.UserWarning("Global SKAdNetwork postback forwarding is no longer supported by AppLovin. Removing AppLovin Advertising Attribution Endpoint from Info.plist.");
- plist.root.values.Remove("NSAdvertisingAttributionReportEndpoint");
- }
-
- private static void EnableVerboseLoggingIfNeeded(PlistDocument plist)
- {
- if (!EditorPrefs.HasKey(MaxSdkLogger.KeyVerboseLoggingEnabled)) return;
-
- var enabled = EditorPrefs.GetBool(MaxSdkLogger.KeyVerboseLoggingEnabled);
- if (enabled)
- {
- plist.root.SetBoolean(AppLovinVerboseLoggingOnKey, true);
- }
- else
- {
- plist.root.values.Remove(AppLovinVerboseLoggingOnKey);
- }
- }
-
- private static void AddGoogleApplicationIdIfNeeded(PlistDocument plist)
- {
- if (!AppLovinPackageManager.IsAdapterInstalled("Google") && !AppLovinPackageManager.IsAdapterInstalled("GoogleAdManager")) return;
-
- const string googleApplicationIdentifier = "GADApplicationIdentifier";
- var appId = AppLovinSettings.Instance.AdMobIosAppId;
- // Log error if the App ID is not set.
- if (string.IsNullOrEmpty(appId) || !appId.StartsWith("ca-app-pub-"))
- {
- MaxSdkLogger.UserError("[AppLovin MAX] Google App ID is not set. Please enter a valid app ID within the AppLovin Integration Manager window.");
- return;
- }
-
- plist.root.SetString(googleApplicationIdentifier, appId);
- }
-
- private static void AddYandexSettingsIfNeeded(PBXProject project, string unityMainTargetGuid)
- {
- if (!AppLovinPackageManager.IsAdapterInstalled("Yandex")) return;
-
- if (MaxSdkUtils.CompareVersions(PlayerSettings.iOS.targetOSVersionString, "12.0") == MaxSdkUtils.VersionComparisonResult.Lesser)
- {
- MaxSdkLogger.UserWarning("Your iOS target version is under the minimum required version by Yandex. Please update it to 12.0 or newer in your ProjectSettings and rebuild your project.");
- return;
- }
-
- project.SetBuildProperty(unityMainTargetGuid, "GENERATE_INFOPLIST_FILE", "NO");
- }
-
- private static void AddSdkSettings(PlistDocument infoPlist, string buildPath)
- {
- var sdkSettingsPlistPath = Path.Combine(buildPath, AppLovinSettingsPlistFileName);
- var sdkSettingsPlist = new PlistDocument();
- if (File.Exists(sdkSettingsPlistPath))
- {
- sdkSettingsPlist.ReadFromFile(sdkSettingsPlistPath);
- }
-
- // Add the SDK key to the SDK settings plist.
- sdkSettingsPlist.root.SetString(KeySdkKey, AppLovinSettings.Instance.SdkKey);
-
- // Add consent flow settings if needed.
- EnableConsentFlowIfNeeded(sdkSettingsPlist, infoPlist);
-
- sdkSettingsPlist.WriteToFile(sdkSettingsPlistPath);
-
- var projectPath = PBXProject.GetPBXProjectPath(buildPath);
- var project = new PBXProject();
- project.ReadFromFile(projectPath);
-
- var unityMainTargetGuid = project.GetUnityMainTargetGuid();
-
- var guid = project.AddFile(AppLovinSettingsPlistFileName, AppLovinSettingsPlistFileName);
- project.AddFileToBuild(unityMainTargetGuid, guid);
- project.WriteToFile(projectPath);
- }
-
- private static void EnableConsentFlowIfNeeded(PlistDocument applovinSettingsPlist, PlistDocument infoPlist)
- {
- var consentFlowEnabled = AppLovinInternalSettings.Instance.ConsentFlowEnabled;
- if (!consentFlowEnabled) return;
-
- var userTrackingUsageDescription = AppLovinInternalSettings.Instance.UserTrackingUsageDescriptionEn;
- var privacyPolicyUrl = AppLovinInternalSettings.Instance.ConsentFlowPrivacyPolicyUrl;
- if (string.IsNullOrEmpty(userTrackingUsageDescription) || string.IsNullOrEmpty(privacyPolicyUrl))
- {
- AppLovinIntegrationManager.ShowBuildFailureDialog("You cannot use the AppLovin SDK's consent flow without defining a Privacy Policy URL and the `User Tracking Usage Description` in the AppLovin Integration Manager. \n\n" +
- "Both values must be included to enable the SDK's consent flow.");
-
- // No need to update the info.plist here. Default consent flow state will be determined on the SDK side.
- return;
- }
-
- var consentFlowInfoRoot = applovinSettingsPlist.root.CreateDict(KeyConsentFlowInfo);
- consentFlowInfoRoot.SetBoolean(KeyConsentFlowEnabled, consentFlowEnabled);
- consentFlowInfoRoot.SetString(KeyConsentFlowPrivacyPolicy, privacyPolicyUrl);
-
- var termsOfServiceUrl = AppLovinInternalSettings.Instance.ConsentFlowTermsOfServiceUrl;
- if (MaxSdkUtils.IsValidString(termsOfServiceUrl))
- {
- consentFlowInfoRoot.SetString(KeyConsentFlowTermsOfService, termsOfServiceUrl);
- }
-
- var shouldShowTermsAndPrivacyPolicyAlertInGdpr = AppLovinInternalSettings.Instance.ShouldShowTermsAndPrivacyPolicyAlertInGDPR;
- consentFlowInfoRoot.SetBoolean(KeyConsentFlowShowTermsAndPrivacyPolicyAlertInGDPR, shouldShowTermsAndPrivacyPolicyAlertInGdpr);
-
- var debugUserGeography = AppLovinInternalSettings.Instance.DebugUserGeography;
- if (debugUserGeography == MaxSdkBase.ConsentFlowUserGeography.Gdpr)
- {
- consentFlowInfoRoot.SetString(KeyConsentFlowDebugUserGeography, "gdpr");
- }
-
- infoPlist.root.SetString("NSUserTrackingUsageDescription", userTrackingUsageDescription);
- }
-
- private static void AddSkAdNetworksInfoIfNeeded(PlistDocument plist)
- {
- var skAdNetworkData = GetSkAdNetworkData();
- var skAdNetworkIds = skAdNetworkData.SkAdNetworkIds;
- // Check if we have a valid list of SKAdNetworkIds that need to be added.
- if (skAdNetworkIds == null || skAdNetworkIds.Length < 1) return;
-
- //
- // Add the SKAdNetworkItems to the plist. It should look like following:
- //
- // SKAdNetworkItems
- //
- //
- // SKAdNetworkIdentifier
- // ABC123XYZ.skadnetwork
- //
- //
- // SKAdNetworkIdentifier
- // 123QWE456.skadnetwork
- //
- //
- // SKAdNetworkIdentifier
- // 987XYZ123.skadnetwork
- //
- //
- //
- PlistElement skAdNetworkItems;
- plist.root.values.TryGetValue("SKAdNetworkItems", out skAdNetworkItems);
- var existingSkAdNetworkIds = new HashSet();
- // Check if SKAdNetworkItems array is already in the Plist document and collect all the IDs that are already present.
- if (skAdNetworkItems != null && skAdNetworkItems.GetType() == typeof(PlistElementArray))
- {
- var plistElementDictionaries = skAdNetworkItems.AsArray().values.Where(plistElement => plistElement.GetType() == typeof(PlistElementDict));
- foreach (var plistElement in plistElementDictionaries)
- {
- PlistElement existingId;
- plistElement.AsDict().values.TryGetValue("SKAdNetworkIdentifier", out existingId);
- if (existingId == null || existingId.GetType() != typeof(PlistElementString) || string.IsNullOrEmpty(existingId.AsString())) continue;
-
- existingSkAdNetworkIds.Add(existingId.AsString());
- }
- }
- // Else, create an array of SKAdNetworkItems into which we will add our IDs.
- else
- {
- skAdNetworkItems = plist.root.CreateArray("SKAdNetworkItems");
- }
-
- foreach (var skAdNetworkId in skAdNetworkIds)
- {
- // Skip adding IDs that are already in the array.
- if (existingSkAdNetworkIds.Contains(skAdNetworkId)) continue;
-
- var skAdNetworkItemDict = skAdNetworkItems.AsArray().AddDict();
- skAdNetworkItemDict.SetString("SKAdNetworkIdentifier", skAdNetworkId);
- }
- }
-
- private static SkAdNetworkData GetSkAdNetworkData()
- {
- // Get the list of installed ad networks to be passed up
- var installedNetworks = AppLovinPackageManager.GetInstalledMediationNetworks();
- var uriBuilder = new UriBuilder("https://unity.applovin.com/max/1.0/skadnetwork_ids");
- var adNetworks = string.Join(",", installedNetworks.ToArray());
- if (MaxSdkUtils.IsValidString(adNetworks))
- {
- uriBuilder.Query += string.Format("ad_networks={0}", adNetworks);
- }
-
- var webRequestConfig = new WebRequestConfig()
- {
- EndPoint = uriBuilder.ToString()
- };
-
- var maxWebRequest = new MaxWebRequest(webRequestConfig);
- var webResponse = maxWebRequest.SendSync();
-
- if (!webResponse.IsSuccess)
- {
- MaxSdkLogger.UserError("Failed to retrieve SKAdNetwork IDs with error: " + webResponse.ErrorMessage);
- return new SkAdNetworkData();
- }
-
- try
- {
- return JsonUtility.FromJson(webResponse.ResponseMessage);
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to parse data '" + webResponse.ResponseMessage + "' with exception: " + exception);
- return new SkAdNetworkData();
- }
- }
-
- private static void RemoveSdkKeyIfNeeded(PlistDocument plist)
- {
- if (!plist.root.values.ContainsKey(KeyAppLovinSdkKeyToRemove)) return;
-
- plist.root.values.Remove(KeyAppLovinSdkKeyToRemove);
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs.meta
deleted file mode 100644
index 8182708b..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: d5d209f90444f4a90830b48b5f3f3ff4
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPostProcessiOS.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs
deleted file mode 100644
index 3ed102af..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs
+++ /dev/null
@@ -1,182 +0,0 @@
-//
-// AppLovinPreProcess.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Jonathan Liu on 10/19/2023.
-// Copyright © 2023 AppLovin. All rights reserved.
-//
-
-using System;
-using System.IO;
-using System.Linq;
-using System.Xml;
-using System.Xml.Linq;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public abstract class AppLovinPreProcess
- {
- // Use a slightly lower value than max value so pubs have the option to run a post process script after ours.
- internal const int CallbackOrder = int.MaxValue - 10;
- private const string AppLovinDependenciesFileExportPath = "MaxSdk/AppLovin/Editor/Dependencies.xml";
- private const string ElementNameDependencies = "dependencies";
-
- private static readonly XmlWriterSettings DependenciesFileXmlWriterSettings = new XmlWriterSettings
- {
- Indent = true,
- IndentChars = " ",
- NewLineChars = "\n",
- NewLineHandling = NewLineHandling.Replace
- };
-
- protected static string AppLovinDependenciesFilePath
- {
- get { return AppLovinIntegrationManager.IsPluginInPackageManager ? Path.Combine("Assets", AppLovinDependenciesFileExportPath) : MaxSdkUtils.GetAssetPathForExportPath(AppLovinDependenciesFileExportPath); }
- }
-
- ///
- /// Gets the AppLovin Dependencies.xml file. If `createIfNotExists` is true, a new file will be created if one does not exist.
- ///
- /// The path to the AppLovin Dependencies.xml file
- /// Whether to create a new Dependencies.xml file if one does not exist
- ///
- protected static XDocument GetAppLovinDependenciesFile(string path, bool createIfNotExists = false)
- {
- try
- {
- if (File.Exists(path))
- {
- return XDocument.Load(path);
- }
-
- if (createIfNotExists)
- {
- return new XDocument(new XDeclaration("1.0", "utf-8", "yes"),
- new XElement(ElementNameDependencies));
- }
- }
- catch (Exception exception)
- {
- MaxSdkLogger.E("Unable to load Dependencies file due to exception: " + exception.Message);
- }
-
- return null;
- }
-
- ///
- /// Updates a dependency if it exists, otherwise adds a new dependency.
- ///
- /// The dependencies document we are writing to
- /// The parent tag that we want to search for the dependency. For example, to add a new dependency to Android, pass in "androidPackages"
- /// The element we are looking to update/add. For example, to add a new dependency to Android, pass in "androidPackage"
- /// The attribute name we want in the dependency. For example, to add something to the spec attribute, pass in "spec"
- /// The attribute value prefix we are looking to replace. For example, "com.google.android.ump:user-messaging-platform"
- /// The new dependency we want to add.
- protected static void AddOrUpdateDependency(
- XDocument dependenciesDocument,
- string parentTag,
- string elementTag,
- string matchAttribute,
- string matchValuePrefix,
- XElement newDependency)
- {
- var parentElement = dependenciesDocument.Root.Element(parentTag);
- if (parentElement == null)
- {
- parentElement = new XElement(parentTag);
- dependenciesDocument.Root.Add(parentElement);
- }
-
- // Check if a dependency exists that matches the attributes name and value
- var existingElement = parentElement.Elements(elementTag)
- .FirstOrDefault(element =>
- {
- var attr = element.Attribute(matchAttribute);
- return attr != null && attr.Value.StartsWith(matchValuePrefix, StringComparison.OrdinalIgnoreCase);
- });
-
- if (existingElement != null)
- {
- foreach (var attr in newDependency.Attributes())
- {
- existingElement.SetAttributeValue(attr.Name, attr.Value);
- }
- }
- else
- {
- parentElement.Add(newDependency);
- }
- }
-
- ///
- /// Removes a dependency from an xml file.
- ///
- /// The xml file to remove a dependency from
- /// The parent tag that we want to search for the dependency to remove. For example: "androidPackages"
- /// The element we are looking to remove. For example: "androidPackage"
- /// The attribute name we want to remove. For example: "spec"
- /// The attribute value prefix we are looking to replace. For example: "com.google.android.ump:user-messaging-platform"
- /// True if the dependency was removed successfully, otherwise return false.
- protected static bool RemoveDependency(
- XDocument doc,
- string parentTag,
- string elementTag,
- string matchAttribute,
- string matchValuePrefix)
- {
- var root = doc.Root;
- if (root == null) return false;
-
- var parentElement = root.Element(parentTag);
- if (parentElement == null) return false;
-
- XElement toRemove = null;
- foreach (var e in parentElement.Elements(elementTag))
- {
- var attr = e.Attribute(matchAttribute);
- if (attr != null && attr.Value.StartsWith(matchValuePrefix))
- {
- toRemove = e;
- break;
- }
- }
-
- if (toRemove == null) return false;
-
- toRemove.Remove();
- return true;
- }
-
- ///
- /// Saves an xml file.
- ///
- /// The document to save
- /// The path to the document to save
- /// Returns true if the file was saved successfully
- protected static bool SaveDependenciesFile(XDocument doc, string path)
- {
- try
- {
- // Ensure directory exists before saving the file
- var directory = Path.GetDirectoryName(path);
- if (MaxSdkUtils.IsValidString(directory))
- {
- // Does nothing if directory already exists
- Directory.CreateDirectory(directory);
- }
-
- using (var xmlWriter = XmlWriter.Create(path, DependenciesFileXmlWriterSettings))
- {
- doc.Save(xmlWriter);
- return true;
- }
- }
- catch (Exception exception)
- {
- MaxSdkLogger.E("Unable to save Dependencies file due to exception: " + exception.Message);
- }
-
- return false;
- }
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs.meta
deleted file mode 100644
index f5e00dbb..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 0e6254f24e89548b3a7644fa7bf25f9d
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcess.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs
deleted file mode 100644
index 2df7e0af..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs
+++ /dev/null
@@ -1,111 +0,0 @@
-//
-// AppLovinBuildPreProcessor.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 8/27/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-#if UNITY_ANDROID
-
-using System.Xml.Linq;
-using UnityEditor.Build;
-using UnityEditor.Build.Reporting;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- ///
- /// Adds the AppLovin Quality Service plugin to the gradle template file. See for more details.
- ///
- public class AppLovinPreProcessAndroid : AppLovinProcessGradleBuildFile, IPreprocessBuildWithReport
- {
- private const string ElementNameAndroidPackages = "androidPackages";
- private const string ElementNameAndroidPackage = "androidPackage";
- private const string AttributeNameSpec = "spec";
- private const string UmpDependencyPackage = "com.google.android.ump:user-messaging-platform:";
- private const string UmpDependencyVersion = "4.0.0";
-
- public void OnPreprocessBuild(BuildReport report)
- {
- PreprocessAppLovinQualityServicePlugin();
- AddGoogleCmpDependencyIfNeeded();
- }
-
- private static void PreprocessAppLovinQualityServicePlugin()
- {
- // We can only process gradle template file here. If it is not available, we will try again in post build on Unity IDEs newer than 2018_2 (see AppLovinPostProcessGradleProject).
- if (!AppLovinIntegrationManager.GradleTemplateEnabled) return;
-
- // The publisher could be migrating from older Unity versions to 2019_3 or newer.
- // If so, we should delete the plugin from the template. The plugin will be added to the project's application module in the post processing script (AppLovinPostProcessGradleProject).
- RemoveAppLovinQualityServiceOrSafeDkPlugin(AppLovinIntegrationManager.GradleTemplatePath);
- }
-
- private static void AddGoogleCmpDependencyIfNeeded()
- {
- if (AppLovinInternalSettings.Instance.ConsentFlowEnabled)
- {
- var umpPackage = new XElement(ElementNameAndroidPackage,
- new XAttribute(AttributeNameSpec, UmpDependencyPackage + UmpDependencyVersion));
- var success = AddOrUpdateAndroidDependency(UmpDependencyPackage, umpPackage );
- if (!success)
- {
- MaxSdkLogger.UserWarning("Google CMP will not function. Unable to add user-messaging-platform dependency.");
- }
- }
- else
- {
- RemoveAndroidDependency(UmpDependencyPackage);
- }
- }
-
- ///
- /// Adds or updates an Android dependency in the AppLovin Dependencies.xml file.
- ///
- /// The package that we are trying to update
- /// The new dependency to add if it doesn't exist
- /// Returns true if the file was successfully edited
- private static bool AddOrUpdateAndroidDependency(string package, XElement newDependency)
- {
- var dependenciesFilePath = AppLovinDependenciesFilePath;
- var dependenciesDocument = GetAppLovinDependenciesFile(dependenciesFilePath, AppLovinIntegrationManager.IsPluginInPackageManager);
- if (dependenciesDocument == null) return false;
-
- AddOrUpdateDependency(dependenciesDocument,
- ElementNameAndroidPackages,
- ElementNameAndroidPackage,
- AttributeNameSpec,
- package,
- newDependency);
- return SaveDependenciesFile(dependenciesDocument, dependenciesFilePath);
- }
-
- ///
- /// Removed an android dependency from the AppLovin Dependencies.xml file.
- ///
- /// The package to remove
- private static void RemoveAndroidDependency(string package)
- {
- var dependenciesFilePath = AppLovinDependenciesFilePath;
- var dependenciesDocument = GetAppLovinDependenciesFile(dependenciesFilePath);
- if (dependenciesDocument == null) return;
-
- var removed = RemoveDependency(dependenciesDocument,
- ElementNameAndroidPackages,
- ElementNameAndroidPackage,
- AttributeNameSpec,
- package);
-
- if (!removed) return;
-
- SaveDependenciesFile(dependenciesDocument, dependenciesFilePath);
- }
-
- public int callbackOrder
- {
- get { return CallbackOrder; }
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs.meta
deleted file mode 100644
index 4dd79e87..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 8ccaf444d0d4f4cadb5debe7c41b20c4
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessAndroid.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs
deleted file mode 100644
index 19729a1f..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs
+++ /dev/null
@@ -1,99 +0,0 @@
-//
-// AppLovinBuildPreProcessiOS.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Jonathan Liu on 10/17/2023.
-// Copyright © 2023 AppLovin. All rights reserved.
-//
-
-#if UNITY_IOS
-
-using System.Xml.Linq;
-using UnityEditor.Build;
-using UnityEditor.Build.Reporting;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public class AppLovinPreProcessiOS : AppLovinPreProcess, IPreprocessBuildWithReport
- {
- public void OnPreprocessBuild(BuildReport report)
- {
- AddGoogleCmpDependencyIfNeeded();
- }
-
- private const string ElementNameIosPods = "iosPods";
- private const string ElementNameIosPod = "iosPod";
- private const string AttributeNameName = "name";
- private const string AttributeNameVersion = "version";
- private const string UmpDependencyPod = "GoogleUserMessagingPlatform";
- private const string UmpDependencyVersion = "~> 3.1";
-
- private static void AddGoogleCmpDependencyIfNeeded()
- {
- if (AppLovinInternalSettings.Instance.ConsentFlowEnabled)
- {
- var umpDependency = new XElement(ElementNameIosPod,
- new XAttribute(AttributeNameName, UmpDependencyPod),
- new XAttribute(AttributeNameVersion, UmpDependencyVersion));
- var success = AddOrUpdateIosDependency(UmpDependencyPod, umpDependency);
- if (!success)
- {
- MaxSdkLogger.UserWarning("Google CMP will not function. Unable to add GoogleUserMessagingPlatform dependency.");
- }
- }
- else
- {
- RemoveIosDependency(UmpDependencyPod);
- }
- }
-
- ///
- /// Adds or updates an iOS pod in the AppLovin Dependencies.xml file.
- ///
- /// The pod that we are trying to update
- /// The new dependency to add if it doesn't exist
- /// Returns true if the file was successfully edited
- private static bool AddOrUpdateIosDependency(string pod, XElement newDependency)
- {
- var dependenciesFilePath = AppLovinDependenciesFilePath;
- var dependenciesDocument = GetAppLovinDependenciesFile(dependenciesFilePath, AppLovinIntegrationManager.IsPluginInPackageManager);
- if (dependenciesDocument == null) return false;
-
- AddOrUpdateDependency(dependenciesDocument,
- ElementNameIosPods,
- ElementNameIosPod,
- AttributeNameName,
- pod,
- newDependency);
- return SaveDependenciesFile(dependenciesDocument, dependenciesFilePath);
- }
-
- ///
- /// Removed an iOS pod from the AppLovin Dependencies.xml file.
- ///
- /// The pod to remove
- private static void RemoveIosDependency(string pod)
- {
- var dependenciesFilePath = AppLovinDependenciesFilePath;
- var dependenciesDocument = GetAppLovinDependenciesFile(dependenciesFilePath);
- if (dependenciesDocument == null) return;
-
- var removed = RemoveDependency(dependenciesDocument,
- ElementNameIosPods,
- ElementNameIosPod,
- AttributeNameName,
- pod);
-
- if (!removed) return;
-
- SaveDependenciesFile(dependenciesDocument, dependenciesFilePath);
- }
-
- public int callbackOrder
- {
- get { return CallbackOrder; }
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs.meta
deleted file mode 100644
index 33bdffb1..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: ee45537a5833240d7afcfac4a38df1b9
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinPreProcessiOS.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs
deleted file mode 100644
index 88bd6683..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs
+++ /dev/null
@@ -1,658 +0,0 @@
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 9/3/19.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-#if UNITY_ANDROID
-
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text.RegularExpressions;
-using AppLovinMax.Internal;
-using UnityEngine;
-using UnityEngine.PlayerLoop;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- [Serializable]
- public class AppLovinQualityServiceData
- {
- // ReSharper disable once InconsistentNaming - Need to keep name for response data
- public string api_key;
- }
-
- ///
- /// Adds or updates the AppLovin Quality Service plugin to the provided build.gradle file.
- /// If the gradle file already has the plugin, the API key is updated.
- ///
- public abstract class AppLovinProcessGradleBuildFile : AppLovinPreProcess
- {
- private static readonly Regex TokenBuildScriptRepositories = new Regex(".*repositories.*");
- private static readonly Regex TokenBuildScriptDependencies = new Regex(".*classpath \'com.android.tools.build:gradle.*");
- private static readonly Regex TokenApplicationPlugin = new Regex(".*apply plugin: \'com.android.application\'.*");
- private static readonly Regex TokenApiKey = new Regex(".*apiKey.*");
- private static readonly Regex TokenAppLovinPlugin = new Regex(".*apply plugin:.+?(?=applovin-quality-service).*");
-
- private const string PluginsMatcher = "plugins";
- private const string PluginManagementMatcher = "pluginManagement";
- private const string QualityServicePluginRoot = " id 'com.applovin.quality' version '+' apply false // NOTE: Requires version 4.8.3+ for Gradle version 7.2+";
-
- private const string BuildScriptMatcher = "buildscript";
- private const string QualityServiceMavenRepo = "maven { url 'https://artifacts.applovin.com/android'; content { includeGroupByRegex 'com.applovin.*' } }";
- private const string QualityServiceDependencyClassPath = "classpath 'com.applovin.quality:AppLovinQualityServiceGradlePlugin:+'";
- private const string QualityServiceApplyPlugin = "apply plugin: 'applovin-quality-service'";
- private const string QualityServicePlugin = "applovin {";
- private const string QualityServiceApiKey = " apiKey '{0}'";
- private const string QualityServiceBintrayMavenRepo = "https://applovin.bintray.com/Quality-Service";
- private const string QualityServiceNoRegexMavenRepo = "maven { url 'https://artifacts.applovin.com/android' }";
-
- // Legacy plugin detection variables
- private const string QualityServiceDependencyClassPathV3 = "classpath 'com.applovin.quality:AppLovinQualityServiceGradlePlugin:3.+'";
- private static readonly Regex TokenSafeDkLegacyApplyPlugin = new Regex(".*apply plugin:.+?(?=safedk).*");
- private const string SafeDkLegacyPlugin = "safedk {";
- private const string SafeDkLegacyMavenRepo = "http://download.safedk.com";
- private const string SafeDkLegacyDependencyClassPath = "com.safedk:SafeDKGradlePlugin:";
-
- ///
- /// Adds the Quality Service plugin to the root gradle file.
- ///
- /// The path to the unityLibrary's module.
- /// True if the plugin was added successfully, otherwise return false
- protected static bool AddQualityServiceToRootGradleFile(string path)
- {
- var rootGradleBuildFilePath = Path.Combine(path, "../build.gradle");
- var shouldAddQualityServiceToDependencies = ShouldAddQualityServiceToDependencies(rootGradleBuildFilePath);
-
- if (shouldAddQualityServiceToDependencies)
- {
- // Add the Quality Service Plugin to the dependencies block in the root build.gradle file
- return AddQualityServiceBuildScriptLines(rootGradleBuildFilePath);
- }
-
- // Add the Quality Service Plugin to the plugin block in the root build.gradle file
- var rootSettingsGradleFilePath = Path.Combine(path, "../settings.gradle");
- var qualityServiceAdded = AddPluginToRootGradleBuildFile(rootGradleBuildFilePath);
- var appLovinRepositoryAdded = AddAppLovinRepository(rootSettingsGradleFilePath);
- return qualityServiceAdded && appLovinRepositoryAdded;
- }
-
- ///
- /// Determines whether the AppLovin Quality Service plugin should be added to the
- /// dependencies block in the root build.gradle file or to the plugins block.
- ///
- /// Gradle's required structure for including plugins varies by version:
- /// - Older versions of Gradle require the plugin to be added to the dependencies block.
- /// Example:
- /// dependencies {
- /// classpath 'com.android.tools.build:gradle:4.0.1'
- /// classpath 'com.applovin.quality:AppLovinQualityServiceGradlePlugin:+'
- /// }
- ///
- /// - Newer versions of gradle require the plugin to be added to the plugins block.
- /// Example:
- /// plugins {
- /// id 'com.android.application' version '7.4.2' apply false
- /// id 'com.android.library' version '7.4.2' apply false
- /// id 'com.applovin.quality' version '+' apply false
- /// }
- ///
- /// Since Unity projects may use custom Gradle versions depending on the Unity version or
- /// user modifications, this check ensures proper integration of the AppLovin plugin.
- ///
- /// The path to project's root build.gradle file.
- /// true if the file contains a `dependencies` block, indicating an older Gradle version
- private static bool ShouldAddQualityServiceToDependencies(string rootGradleBuildFile)
- {
- var lines = File.ReadAllLines(rootGradleBuildFile).ToList();
- return lines.Any(line => TokenBuildScriptDependencies.IsMatch(line));
- }
-
- ///
- /// Updates the provided Gradle script to add Quality Service plugin.
- ///
- /// The gradle file to update.
- protected static void AddAppLovinQualityServicePlugin(string applicationGradleBuildFilePath)
- {
- if (!AppLovinSettings.Instance.QualityServiceEnabled) return;
-
- var sdkKey = AppLovinSettings.Instance.SdkKey;
- if (string.IsNullOrEmpty(sdkKey))
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. SDK Key is empty. Please enter the AppLovin SDK Key in the Integration Manager.");
- return;
- }
-
- // Retrieve the API Key using the SDK Key.
- var qualityServiceData = RetrieveQualityServiceData(sdkKey);
- var apiKey = qualityServiceData.api_key;
- if (string.IsNullOrEmpty(apiKey))
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. API Key is empty.");
- return;
- }
-
- // Generate the updated Gradle file that needs to be written.
- var lines = File.ReadAllLines(applicationGradleBuildFilePath).ToList();
- var sanitizedLines = RemoveLegacySafeDkPlugin(lines);
- var outputLines = GenerateUpdatedBuildFileLines(
- sanitizedLines,
- apiKey,
- false // The buildscript closure related lines will to be added to the root build.gradle file.
- );
- // outputLines can be null if we couldn't add the plugin.
- if (outputLines == null) return;
-
- try
- {
- File.WriteAllText(applicationGradleBuildFilePath, string.Join("\n", outputLines.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. Gradle file write failed.");
- Console.WriteLine(exception);
- }
- }
-
- ///
- /// Adds AppLovin Quality Service plugin DSL element to the project's root build.gradle file.
- /// Sample build.gradle file after adding quality service:
- /// plugins {
- /// id 'com.android.application' version '7.4.2' apply false
- /// id 'com.android.library' version '7.4.2' apply false
- /// id 'com.applovin.quality' version '+' apply false
- /// }
- /// tasks.register('clean', Delete) {
- /// delete rootProject.layout.buildDirectory
- /// }
- ///
- ///
- /// The path to project's root build.gradle file.
- /// true when the plugin was added successfully.
- private static bool AddPluginToRootGradleBuildFile(string rootGradleBuildFile)
- {
- var lines = File.ReadAllLines(rootGradleBuildFile).ToList();
-
- // Check if the plugin is already added to the file.
- var pluginAdded = lines.Any(line => line.Contains(QualityServicePluginRoot));
- if (pluginAdded) return true;
-
- var outputLines = new List();
- var insidePluginsClosure = false;
- foreach (var line in lines)
- {
- if (line.Contains(PluginsMatcher))
- {
- insidePluginsClosure = true;
- }
-
- if (!pluginAdded && insidePluginsClosure && line.Contains("}"))
- {
- outputLines.Add(QualityServicePluginRoot);
- pluginAdded = true;
- insidePluginsClosure = false;
- }
-
- outputLines.Add(line);
- }
-
- if (!pluginAdded) return false;
-
- try
- {
- File.WriteAllText(rootGradleBuildFile, string.Join("\n", outputLines.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. Root Gradle file write failed.");
- Console.WriteLine(exception);
- return false;
- }
-
- return true;
- }
-
- ///
- /// Adds the AppLovin maven repository to the project's settings.gradle file.
- /// Sample settings.gradle file after adding AppLovin Repository:
- /// pluginManagement {
- /// repositories {
- /// maven { url 'https://artifacts.applovin.com/android'; content { includeGroupByRegex 'com.applovin.*' } }
- ///
- /// gradlePluginPortal()
- /// google()
- /// mavenCentral()
- /// }
- /// }
- /// ...
- ///
- ///
- /// The path to the project's settings.gradle file.
- /// true if the repository was added successfully.
- private static bool AddAppLovinRepository(string settingsGradleFile)
- {
- var lines = File.ReadLines(settingsGradleFile).ToList();
- var outputLines = new List();
- var mavenRepoAdded = false;
- var pluginManagementClosureDepth = 0;
- var insidePluginManagementClosure = false;
- var pluginManagementMatched = false;
- foreach (var line in lines)
- {
- outputLines.Add(line);
-
- if (!pluginManagementMatched && line.Contains(PluginManagementMatcher))
- {
- pluginManagementMatched = true;
- insidePluginManagementClosure = true;
- }
-
- if (insidePluginManagementClosure)
- {
- if (line.Contains("{"))
- {
- pluginManagementClosureDepth++;
- }
-
- if (line.Contains("}"))
- {
- pluginManagementClosureDepth--;
- }
-
- if (pluginManagementClosureDepth == 0)
- {
- insidePluginManagementClosure = false;
- }
- }
-
- if (insidePluginManagementClosure)
- {
- if (!mavenRepoAdded && TokenBuildScriptRepositories.IsMatch(line))
- {
- outputLines.Add(GetFormattedBuildScriptLine(QualityServiceMavenRepo));
- mavenRepoAdded = true;
- }
- }
- }
-
- if (!mavenRepoAdded) return false;
-
- try
- {
- File.WriteAllText(settingsGradleFile, string.Join("\n", outputLines.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. Setting Gradle file write failed.");
- Console.WriteLine(exception);
- return false;
- }
-
- return true;
- }
-
- ///
- /// Adds the necessary AppLovin Quality Service dependency and maven repo lines to the provided root build.gradle file.
- /// Sample build.gradle file after adding quality service:
- /// allprojects {
- /// buildscript {
- /// repositories {
- /// maven { url 'https://artifacts.applovin.com/android'; content { includeGroupByRegex 'com.applovin.*' } }
- /// google()
- /// jcenter()
- /// }
- ///
- /// dependencies {
- /// classpath 'com.android.tools.build:gradle:4.0.1'
- /// classpath 'com.applovin.quality:AppLovinQualityServiceGradlePlugin:+'
- /// }
- /// ...
- ///
- ///
- /// The root build.gradle file path
- /// true if the build script lines were applied correctly.
- private static bool AddQualityServiceBuildScriptLines(string rootGradleBuildFile)
- {
- var lines = File.ReadAllLines(rootGradleBuildFile).ToList();
- var outputLines = GenerateUpdatedBuildFileLines(lines, null, true);
-
- // outputLines will be null if we couldn't add the build script lines.
- if (outputLines == null) return false;
-
- try
- {
- File.WriteAllText(rootGradleBuildFile, string.Join("\n", outputLines.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to install AppLovin Quality Service plugin. Root Gradle file write failed.");
- Console.WriteLine(exception);
- return false;
- }
-
- return true;
- }
-
- ///
- /// Removes the AppLovin Quality Service Plugin or Legacy SafeDK plugin from the given gradle template file if either of them are present.
- ///
- /// The gradle template file from which to remove the plugin from
- protected static void RemoveAppLovinQualityServiceOrSafeDkPlugin(string gradleTemplateFile)
- {
- var lines = File.ReadAllLines(gradleTemplateFile).ToList();
- lines = RemoveLegacySafeDkPlugin(lines);
- lines = RemoveAppLovinQualityServicePlugin(lines);
-
- try
- {
- File.WriteAllText(gradleTemplateFile, string.Join("\n", lines.ToArray()) + "\n");
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to remove AppLovin Quality Service Plugin from mainTemplate.gradle. Please remove the Quality Service plugin from the mainTemplate.gradle manually.");
- Console.WriteLine(exception);
- }
- }
-
- private static AppLovinQualityServiceData RetrieveQualityServiceData(string sdkKey)
- {
- var webRequestConfig = new WebRequestConfig()
- {
- JsonString = string.Format("{{\"sdk_key\" : \"{0}\"}}", sdkKey),
- EndPoint = "https://api2.safedk.com/v1/build/cred",
- RequestType = WebRequestType.Post,
- };
-
- webRequestConfig.Headers.Add("Content-Type", "application/json");
-
- var maxWebRequest = new MaxWebRequest(webRequestConfig);
- var webResponse = maxWebRequest.SendSync();
-
- if (!webResponse.IsSuccess)
- {
- MaxSdkLogger.UserError("Failed to retrieve API Key for SDK Key: " + sdkKey + "with error: " + webResponse.ErrorMessage);
- return new AppLovinQualityServiceData();
- }
-
- try
- {
- return JsonUtility.FromJson(webResponse.ResponseMessage);
- }
- catch (Exception exception)
- {
- MaxSdkLogger.UserError("Failed to parse API Key." + exception);
- return new AppLovinQualityServiceData();
- }
- }
-
- private static List RemoveLegacySafeDkPlugin(List lines)
- {
- return RemovePlugin(lines, SafeDkLegacyPlugin, SafeDkLegacyMavenRepo, SafeDkLegacyDependencyClassPath, TokenSafeDkLegacyApplyPlugin);
- }
-
- private static List RemoveAppLovinQualityServicePlugin(List lines)
- {
- return RemovePlugin(lines, QualityServicePlugin, QualityServiceMavenRepo, QualityServiceDependencyClassPath, TokenAppLovinPlugin);
- }
-
- private static List RemovePlugin(List lines, string pluginLine, string mavenRepo, string dependencyClassPath, Regex applyPluginToken)
- {
- var sanitizedLines = new List();
- var legacyRepoRemoved = false;
- var legacyDependencyClassPathRemoved = false;
- var legacyPluginRemoved = false;
- var legacyPluginMatched = false;
- var insideLegacySafeDkClosure = false;
- foreach (var line in lines)
- {
- if (!legacyPluginMatched && line.Contains(pluginLine))
- {
- legacyPluginMatched = true;
- insideLegacySafeDkClosure = true;
- }
-
- if (insideLegacySafeDkClosure && line.Contains("}"))
- {
- insideLegacySafeDkClosure = false;
- continue;
- }
-
- if (insideLegacySafeDkClosure)
- {
- continue;
- }
-
- if (!legacyRepoRemoved && line.Contains(mavenRepo))
- {
- legacyRepoRemoved = true;
- continue;
- }
-
- if (!legacyDependencyClassPathRemoved && line.Contains(dependencyClassPath))
- {
- legacyDependencyClassPathRemoved = true;
- continue;
- }
-
- if (!legacyPluginRemoved && applyPluginToken.IsMatch(line))
- {
- legacyPluginRemoved = true;
- continue;
- }
-
- sanitizedLines.Add(line);
- }
-
- return sanitizedLines;
- }
-
- private static List GenerateUpdatedBuildFileLines(List lines, string apiKey, bool addBuildScriptLines)
- {
- // Check if the plugin exists, if so, update the SDK Key.
- var pluginExists = lines.Any(line => TokenAppLovinPlugin.IsMatch(line));
- return pluginExists ? UpdateExistingPlugin(lines, apiKey) : AddPluginAndBuildScript(lines, apiKey, addBuildScriptLines);
- }
-
- private static List UpdateExistingPlugin(List lines, string apiKey)
- {
- // A sample of the template file.
- // ...
- // allprojects {
- // repositories {**ARTIFACTORYREPOSITORY**
- // google()
- // jcenter()
- // flatDir {
- // dirs 'libs'
- // }
- // }
- // }
- //
- // apply plugin: 'com.android.application'
- // **APPLY_PLUGINS**
- //
- // dependencies {
- // implementation fileTree(dir: 'libs', include: ['*.jar'])
- // **DEPS**}
- // ...
- var outputLines = new List();
- var pluginMatched = false;
- var insideAppLovinClosure = false;
- var updatedApiKey = false;
- var mavenRepoUpdated = false;
- var dependencyClassPathUpdated = false;
- foreach (var line in lines)
- {
- // Bintray maven repo is no longer being used. Update to s3 maven repo with regex check
- if (!mavenRepoUpdated && (line.Contains(QualityServiceBintrayMavenRepo) || line.Contains(QualityServiceNoRegexMavenRepo)))
- {
- outputLines.Add(GetFormattedBuildScriptLine(QualityServiceMavenRepo));
- mavenRepoUpdated = true;
- continue;
- }
-
- // We no longer use version specific dependency class path. Just use + for version to always pull the latest.
- if (!dependencyClassPathUpdated && line.Contains(QualityServiceDependencyClassPathV3))
- {
- outputLines.Add(GetFormattedBuildScriptLine(QualityServiceDependencyClassPath));
- dependencyClassPathUpdated = true;
- continue;
- }
-
- if (!pluginMatched && line.Contains(QualityServicePlugin))
- {
- insideAppLovinClosure = true;
- pluginMatched = true;
- }
-
- if (insideAppLovinClosure && line.Contains("}"))
- {
- insideAppLovinClosure = false;
- }
-
- // Update the API key.
- if (insideAppLovinClosure && !updatedApiKey && TokenApiKey.IsMatch(line))
- {
- outputLines.Add(string.Format(QualityServiceApiKey, apiKey));
- updatedApiKey = true;
- }
- // Keep adding the line until we find and update the plugin.
- else
- {
- outputLines.Add(line);
- }
- }
-
- return outputLines;
- }
-
- private static List AddPluginAndBuildScript(List lines, string apiKey, bool addBuildScriptLines)
- {
- var shouldAddPlugin = MaxSdkUtils.IsValidString(apiKey);
- if (shouldAddPlugin)
- {
- lines = AddPlugin(lines, apiKey);
- if (lines == null) return null;
- }
-
- if (!addBuildScriptLines) return lines;
-
- lines = AddBuildScript(lines);
- return lines;
- }
-
- private static List AddBuildScript(List lines)
- {
- var outputLines = new List();
- var buildScriptClosureDepth = 0;
- var insideBuildScriptClosure = false;
- var buildScriptMatched = false;
- var qualityServiceRepositoryAdded = false;
- var qualityServiceDependencyClassPathAdded = false;
- foreach (var line in lines)
- {
- // Add the line to the output lines.
- outputLines.Add(line);
-
- if (!buildScriptMatched && line.Contains(BuildScriptMatcher))
- {
- buildScriptMatched = true;
- insideBuildScriptClosure = true;
- }
-
- // Match the parenthesis to track if we are still inside the buildscript closure.
- if (insideBuildScriptClosure)
- {
- if (line.Contains("{"))
- {
- buildScriptClosureDepth++;
- }
-
- if (line.Contains("}"))
- {
- buildScriptClosureDepth--;
- }
-
- if (buildScriptClosureDepth == 0)
- {
- insideBuildScriptClosure = false;
-
- // There may be multiple buildscript closures and we need to keep looking until we added both the repository and classpath.
- buildScriptMatched = qualityServiceRepositoryAdded && qualityServiceDependencyClassPathAdded;
- }
- }
-
- if (insideBuildScriptClosure)
- {
- // Add the build script dependency repositories.
- if (!qualityServiceRepositoryAdded && TokenBuildScriptRepositories.IsMatch(line))
- {
- outputLines.Add(GetFormattedBuildScriptLine(QualityServiceMavenRepo));
- qualityServiceRepositoryAdded = true;
- }
- // Add the build script dependencies.
- else if (!qualityServiceDependencyClassPathAdded && TokenBuildScriptDependencies.IsMatch(line))
- {
- outputLines.Add(GetFormattedBuildScriptLine(QualityServiceDependencyClassPath));
- qualityServiceDependencyClassPathAdded = true;
- }
- }
- }
-
- if (!qualityServiceRepositoryAdded || !qualityServiceDependencyClassPathAdded)
- {
- return null;
- }
-
- return outputLines;
- }
-
- private static List AddPlugin(List lines, string apiKey)
- {
- var outputLines = new List();
- var qualityServicePluginAdded = false;
- foreach (var line in lines)
- {
- outputLines.Add(line);
-
- // Add the plugin.
- if (qualityServicePluginAdded || !TokenApplicationPlugin.IsMatch(line)) continue;
-
- outputLines.Add(QualityServiceApplyPlugin);
- outputLines.AddRange(GenerateAppLovinPluginClosure(apiKey));
- qualityServicePluginAdded = true;
- }
-
- return qualityServicePluginAdded ? outputLines : null;
- }
-
- public static string GetFormattedBuildScriptLine(string buildScriptLine)
- {
-#if UNITY_2022_2_OR_NEWER
- return " "
-#else
- return " "
-#endif
- + buildScriptLine;
- }
-
- private static IEnumerable GenerateAppLovinPluginClosure(string apiKey)
- {
- // applovin {
- // // NOTE: DO NOT CHANGE - this is NOT your AppLovin MAX SDK key - this is a derived key.
- // apiKey "456...a1b"
- // }
- var linesToInject = new List(5);
- linesToInject.Add("");
- linesToInject.Add("applovin {");
- linesToInject.Add(" // NOTE: DO NOT CHANGE - this is NOT your AppLovin MAX SDK key - this is a derived key.");
- linesToInject.Add(string.Format(QualityServiceApiKey, apiKey));
- linesToInject.Add("}");
-
- return linesToInject;
- }
- }
-}
-
-#endif
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs.meta
deleted file mode 100644
index 5e498444..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: 732b7510bc9c94aafb3fd3b8c0dc5d2d
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinProcessGradleBuildFile.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs
deleted file mode 100644
index 6a56a228..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs
+++ /dev/null
@@ -1,159 +0,0 @@
-//
-// AppLovinSettings.cs
-// AppLovin MAX Unity Plugin
-//
-// Created by Santosh Bagadi on 1/27/20.
-// Copyright © 2019 AppLovin. All rights reserved.
-//
-
-using AppLovinMax.Scripts.IntegrationManager.Editor;
-using System.IO;
-using UnityEditor;
-using UnityEngine;
-using UnityEngine.Serialization;
-
-///
-/// A representing the AppLovin Settings that can be set in the Integration Manager Window.
-///
-/// The scriptable object asset is created with the name AppLovinSettings.asset and is placed under the directory Assets/MaxSdk/Resources.
-///
-/// NOTE: Not name spacing this class since it is reflected upon by the Google adapter and will break compatibility.
-///
-public class AppLovinSettings : ScriptableObject
-{
- private const string SettingsExportPath = "MaxSdk/Resources/AppLovinSettings.asset";
-
- private static AppLovinSettings instance;
-
- [SerializeField] private bool qualityServiceEnabled = true;
- [SerializeField] private string sdkKey;
-
- [SerializeField] private string customGradleVersionUrl;
- [SerializeField] private string customGradleToolsVersion;
-
- [SerializeField] private string adMobAndroidAppId = string.Empty;
- [SerializeField] private string adMobIosAppId = string.Empty;
-
- ///
- /// An instance of AppLovin Setting.
- ///
- public static AppLovinSettings Instance
- {
- get
- {
- if (instance == null)
- {
- // Check for an existing AppLovinSettings somewhere in the project
- var guids = AssetDatabase.FindAssets("AppLovinSettings t:ScriptableObject");
- if (guids.Length > 1)
- {
- MaxSdkLogger.UserWarning("Multiple AppLovinSettings found. This may cause unexpected results.");
- }
-
- if (guids.Length != 0)
- {
- var path = AssetDatabase.GUIDToAssetPath(guids[0]);
- instance = AssetDatabase.LoadAssetAtPath(path);
- return instance;
- }
-
- string settingsFilePath;
- // The settings file should be under the Assets/ folder so that it can be version controlled and cannot be overriden when updating.
- // If the plugin is outside the Assets folder or if there is no existing AppLovinSettings asset, create the settings asset at the default location.
- if (AppLovinIntegrationManager.IsPluginInPackageManager)
- {
- // Note: Can't use absolute path when calling `CreateAsset`. Should use path relative to Assets/ directory.
- settingsFilePath = MaxSdkUtils.NormalizeToUnityPath(Path.Combine("Assets", SettingsExportPath));
-
- var maxSdkDir = MaxSdkUtils.NormalizeToUnityPath(Path.Combine(Application.dataPath, "MaxSdk"));
- if (!Directory.Exists(maxSdkDir))
- {
- Directory.CreateDirectory(maxSdkDir);
- }
- }
- else
- {
- settingsFilePath = MaxSdkUtils.NormalizeToUnityPath(Path.Combine(AppLovinIntegrationManager.PluginParentDirectory, SettingsExportPath));
- }
-
- var settingsDir = Path.GetDirectoryName(settingsFilePath);
- if (!Directory.Exists(settingsDir))
- {
- Directory.CreateDirectory(settingsDir);
- }
-
- // On script reload AssetDatabase.FindAssets() can fail and will overwrite AppLovinSettings without this check
- if (!File.Exists(settingsFilePath))
- {
- instance = CreateInstance();
- AssetDatabase.CreateAsset(instance, settingsFilePath);
- MaxSdkLogger.D("Creating new AppLovinSettings asset at path: " + settingsFilePath);
- }
- }
-
- return instance;
- }
- }
-
- ///
- /// Whether or not to install Quality Service plugin.
- ///
- public bool QualityServiceEnabled
- {
- get { return Instance.qualityServiceEnabled; }
- set { Instance.qualityServiceEnabled = value; }
- }
-
- ///
- /// AppLovin SDK Key.
- ///
- public string SdkKey
- {
- get { return Instance.sdkKey; }
- set { Instance.sdkKey = value; }
- }
-
- ///
- /// A URL to set the distributionUrl in the gradle-wrapper.properties file (ex: https\://services.gradle.org/distributions/gradle-6.9.3-bin.zip)
- ///
- public string CustomGradleVersionUrl
- {
- get { return Instance.customGradleVersionUrl; }
- set { Instance.customGradleVersionUrl = value; }
- }
-
- ///
- /// A string to set the custom gradle tools version (ex: com.android.tools.build:gradle:4.2.0)
- ///
- public string CustomGradleToolsVersion
- {
- get { return Instance.customGradleToolsVersion; }
- set { Instance.customGradleToolsVersion = value; }
- }
-
- ///
- /// AdMob Android App ID.
- ///
- public string AdMobAndroidAppId
- {
- get { return Instance.adMobAndroidAppId; }
- set { Instance.adMobAndroidAppId = value; }
- }
-
- ///
- /// AdMob iOS App ID.
- ///
- public string AdMobIosAppId
- {
- get { return Instance.adMobIosAppId; }
- set { Instance.adMobIosAppId = value; }
- }
-
- ///
- /// Saves the instance of the settings.
- ///
- public void SaveAsync()
- {
- EditorUtility.SetDirty(instance);
- }
-}
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs.meta b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs.meta
deleted file mode 100644
index 7e40d737..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs.meta
+++ /dev/null
@@ -1,14 +0,0 @@
-fileFormatVersion: 2
-guid: ebc0ba1b5ef6b4a6b9dd53d7eadfea16
-labels:
-- al_max
-- al_max_export_path-MaxSdk/Scripts/IntegrationManager/Editor/AppLovinSettings.cs
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinUpmManifest.cs b/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinUpmManifest.cs
deleted file mode 100644
index 8a55ae97..00000000
--- a/Assets/MaxSdk/Scripts/IntegrationManager/Editor/AppLovinUpmManifest.cs
+++ /dev/null
@@ -1,190 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using AppLovinMax.ThirdParty.MiniJson;
-
-namespace AppLovinMax.Scripts.IntegrationManager.Editor
-{
- public class AppLovinUpmManifest
- {
- private const string KeyUrl = "url";
- private const string KeyName = "name";
- private const string KeyScopes = "scopes";
- private const string KeyScopedRegistry = "scopedRegistries";
-
- private Dictionary manifest;
-
- private static string ManifestPath
- {
- get { return Path.Combine(Directory.GetCurrentDirectory(), "Packages/manifest.json"); }
- }
-
- // Private constructor to enforce the use of the Load() method
- private AppLovinUpmManifest() { }
-
- ///
- /// Creates a new instance of AppLovinUpmManifest and loads the manifest.json file.
- ///
- /// An instance of AppLovinUpmManifest
- public static AppLovinUpmManifest Load()
- {
- return new AppLovinUpmManifest { manifest = GetManifest() };
- }
-
- ///
- /// Adds or updates a scoped registry in the manifest.
- ///
- /// The name of the registry
- /// The url of the registry
- /// The scopes of the registry
- public void AddOrUpdateRegistry(string name, string url, List scopes)
- {
- var registry = GetRegistry(name);
- if (registry == null)
- {
- var registries = GetRegistries();
- if (registries == null) return;
-
- registries.Add(new Dictionary
- {
- {KeyName, name},
- {KeyUrl, url},
- {KeyScopes, scopes}
- });
-
- return;
- }
-
- UpdateRegistry(registry, scopes);
- }
-
- ///
- /// Saves the manifest by serializing it back to JSON and writing to file.
- ///
- public void Save()
- {
- var content = Json.Serialize(manifest, true);
- File.WriteAllText(ManifestPath, content);
- }
-
- ///
- /// Adds a dependency to the manifest.
- ///
- /// The name of the package to add
- /// The version of the package to add
- public void AddPackageDependency(string packageName, string version)
- {
- var manifestDependencies = GetDependencies();
- manifestDependencies[packageName] = version;
- }
-
- ///
- /// Removes a dependency from the manifest.
- ///
- /// The name of the package to remove
- public void RemovePackageDependency(string packageName)
- {
- var manifestDependencies = GetDependencies();
- manifestDependencies.Remove(packageName);
- }
-
- #region Utility
-
- ///
- /// Returns the manifest.json file as a dictionary.
- ///
- private static Dictionary GetManifest()
- {
- if (!File.Exists(ManifestPath))
- {
- throw new Exception("Manifest not Found!");
- }
-
- var manifestJson = File.ReadAllText(ManifestPath);
- if (string.IsNullOrEmpty(manifestJson))
- {
- throw new Exception("Manifest is empty!");
- }
-
- var deserializedManifest = Json.Deserialize(manifestJson) as Dictionary;
- if (deserializedManifest == null)
- {
- throw new Exception("Failed to deserialize manifest");
- }
-
- return deserializedManifest;
- }
-
- ///
- /// Gets the manifest's dependencies section.
- ///
- /// The dependencies section of the manifest.
- private Dictionary GetDependencies()
- {
- var dependencies = manifest["dependencies"] as Dictionary;
- if (dependencies == null)
- {
- throw new Exception("No dependencies found in manifest.");
- }
-
- return dependencies;
- }
-
- ///
- /// Gets the manifest's registries section. Creates a new registries section if one does not exist.
- ///
- /// The registries section of the manifest.
- private List