From 28947f5877b28b754a494c8555ad1b7e2c6f3f19 Mon Sep 17 00:00:00 2001 From: helium-service Date: Thu, 8 Aug 2024 20:15:21 +0000 Subject: [PATCH] Syncing changes from private repository --- CHANGELOG.md | 22 ++++ CHANGELOG.md.meta | 7 ++ ...rp.Mediation.Unity.Adapter.AppLovin.nuspec | 23 ++++ ...diation.Unity.Adapter.AppLovin.nuspec.meta | 7 ++ Editor.meta | 8 ++ Editor/AppLovinAdapterDependencies.xml | 14 +++ Editor/AppLovinAdapterDependencies.xml.meta | 7 ++ LICENSE.md | 9 ++ LICENSE.md.meta | 7 ++ README.md | 87 +++++++++++++- README.md.meta | 7 ++ Runtime.meta | 8 ++ Runtime/Android.meta | 8 ++ Runtime/Android/AppLovinAdapter.cs | 108 ++++++++++++++++++ Runtime/Android/AppLovinAdapter.cs.meta | 11 ++ Runtime/Android/AssemblyInfo.cs | 3 + Runtime/Android/AssemblyInfo.cs.meta | 3 + ...artboost.Mediation.AppLovin.Android.asmdef | 26 +++++ ...ost.Mediation.AppLovin.Android.asmdef.meta | 7 ++ Runtime/AppLovin.meta | 8 ++ Runtime/AppLovin/AppLovinAdapter.cs | 51 +++++++++ Runtime/AppLovin/AppLovinAdapter.cs.meta | 11 ++ Runtime/AppLovin/AssemblyInfo.cs | 16 +++ Runtime/AppLovin/AssemblyInfo.cs.meta | 3 + .../Chartboost.Mediation.AppLovin.asmdef | 21 ++++ .../Chartboost.Mediation.AppLovin.asmdef.meta | 7 ++ Runtime/AppLovin/Common.meta | 8 ++ Runtime/AppLovin/Common/IAppLovinAdapter.cs | 25 ++++ .../AppLovin/Common/IAppLovinAdapter.cs.meta | 11 ++ Runtime/AppLovin/Default.meta | 8 ++ Runtime/AppLovin/Default/AppLovinDefault.cs | 28 +++++ .../AppLovin/Default/AppLovinDefault.cs.meta | 11 ++ Runtime/iOS.meta | 8 ++ Runtime/iOS/AppLovinAdapter.cs | 62 ++++++++++ Runtime/iOS/AppLovinAdapter.cs.meta | 11 ++ Runtime/iOS/AssemblyInfo.cs | 3 + Runtime/iOS/AssemblyInfo.cs.meta | 3 + .../Chartboost.Mediation.AppLovin.IOS.asmdef | 25 ++++ ...rtboost.Mediation.AppLovin.IOS.asmdef.meta | 7 ++ Runtime/iOS/Plugins.meta | 8 ++ Runtime/iOS/Plugins/iOS.meta | 8 ++ .../iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm | 46 ++++++++ .../iOS/CBMAppLovinUnityBridge.mm.meta | 37 ++++++ Tests.meta | 8 ++ Tests/Editor.meta | 8 ++ ...ost.Mediation.AppLovin.Tests.Editor.asmdef | 26 +++++ ...ediation.AppLovin.Tests.Editor.asmdef.meta | 7 ++ Tests/Editor/VersionValidator.cs | 21 ++++ Tests/Editor/VersionValidator.cs.meta | 3 + Tests/Runtime.meta | 8 ++ Tests/Runtime/AppLovinAdapterTests.cs | 42 +++++++ Tests/Runtime/AppLovinAdapterTests.cs.meta | 11 ++ ...st.Mediation.AppLovin.Tests.Runtime.asmdef | 29 +++++ ...diation.AppLovin.Tests.Runtime.asmdef.meta | 7 ++ package.json | 31 +++++ package.json.meta | 7 ++ 56 files changed, 1005 insertions(+), 1 deletion(-) create mode 100644 CHANGELOG.md create mode 100644 CHANGELOG.md.meta create mode 100644 Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec create mode 100644 Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec.meta create mode 100644 Editor.meta create mode 100644 Editor/AppLovinAdapterDependencies.xml create mode 100644 Editor/AppLovinAdapterDependencies.xml.meta create mode 100644 LICENSE.md create mode 100644 LICENSE.md.meta create mode 100644 README.md.meta create mode 100644 Runtime.meta create mode 100644 Runtime/Android.meta create mode 100644 Runtime/Android/AppLovinAdapter.cs create mode 100644 Runtime/Android/AppLovinAdapter.cs.meta create mode 100644 Runtime/Android/AssemblyInfo.cs create mode 100644 Runtime/Android/AssemblyInfo.cs.meta create mode 100644 Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef create mode 100644 Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef.meta create mode 100644 Runtime/AppLovin.meta create mode 100644 Runtime/AppLovin/AppLovinAdapter.cs create mode 100644 Runtime/AppLovin/AppLovinAdapter.cs.meta create mode 100644 Runtime/AppLovin/AssemblyInfo.cs create mode 100644 Runtime/AppLovin/AssemblyInfo.cs.meta create mode 100644 Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef create mode 100644 Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef.meta create mode 100644 Runtime/AppLovin/Common.meta create mode 100644 Runtime/AppLovin/Common/IAppLovinAdapter.cs create mode 100644 Runtime/AppLovin/Common/IAppLovinAdapter.cs.meta create mode 100644 Runtime/AppLovin/Default.meta create mode 100644 Runtime/AppLovin/Default/AppLovinDefault.cs create mode 100644 Runtime/AppLovin/Default/AppLovinDefault.cs.meta create mode 100644 Runtime/iOS.meta create mode 100644 Runtime/iOS/AppLovinAdapter.cs create mode 100644 Runtime/iOS/AppLovinAdapter.cs.meta create mode 100644 Runtime/iOS/AssemblyInfo.cs create mode 100644 Runtime/iOS/AssemblyInfo.cs.meta create mode 100644 Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef create mode 100644 Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef.meta create mode 100644 Runtime/iOS/Plugins.meta create mode 100644 Runtime/iOS/Plugins/iOS.meta create mode 100644 Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm create mode 100644 Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm.meta create mode 100644 Tests.meta create mode 100644 Tests/Editor.meta create mode 100644 Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef create mode 100644 Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef.meta create mode 100644 Tests/Editor/VersionValidator.cs create mode 100644 Tests/Editor/VersionValidator.cs.meta create mode 100644 Tests/Runtime.meta create mode 100644 Tests/Runtime/AppLovinAdapterTests.cs create mode 100644 Tests/Runtime/AppLovinAdapterTests.cs.meta create mode 100644 Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef create mode 100644 Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef.meta create mode 100644 package.json create mode 100644 package.json.meta diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..b8b786c --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,22 @@ +# Changelog +All notable changes to this project will be documented in this file using the standards as defined at [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0). + +### Version 5.0.0 *(2024-08-08)* + +First version of the Chartboost Mediation Unity SDK - AppLovin Adapter. + +#Added +- Support for the following `AppLovin` dependencies. Notice adapter dependencies are optimistic and any patches and hot-fixes will be automatically picked up.: + * Android: `com.chartboost:chartboost-mediation-adapter-applovin:5.12.6.+` + * iOS: `ChartboostMediationAdapterAppLovin ~> 5.12.5.0` + +- `AppLovinAdapter.cs` with Configuration Properties for `AppLovin`. +- The following properties have been added in `AppLovinAdapter.cs` + * `string AdapterUnityVersion` + * `string AdapterNativeVersion` + * `string PartnerSDKVersion` + * `string PartnerIdentifier` + * `string PartnerDisplayName` + * `bool TestMode` + * `bool MuteAudio` + * `bool VerboseLogging` \ No newline at end of file diff --git a/CHANGELOG.md.meta b/CHANGELOG.md.meta new file mode 100644 index 0000000..029a79c --- /dev/null +++ b/CHANGELOG.md.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 4d7d421b424de4328959251f2cecadc2 +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec b/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec new file mode 100644 index 0000000..fc5cecf --- /dev/null +++ b/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec @@ -0,0 +1,23 @@ + + + + Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin + 5.0.0 + Chartboost Mediation Adapter - AppLovin + The Chartboost Mediation Unity SDK Adapter for AppLovin. + Chartboost + Chartboost + LICENSE.md + README.md + https://www.chartboost.com/products/mediation/ + Copyright 2024 + Chartboost, Ads, Mediation, Unity, Adapter, AppLovin, cs + + + + + + + + + diff --git a/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec.meta b/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec.meta new file mode 100644 index 0000000..bb4f495 --- /dev/null +++ b/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin.nuspec.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: f55ff7f270e204a96b4a79a661cd04f0 +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Editor.meta b/Editor.meta new file mode 100644 index 0000000..4e4cb48 --- /dev/null +++ b/Editor.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 26967c9626a5b48208cf6b76fe602ea9 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Editor/AppLovinAdapterDependencies.xml b/Editor/AppLovinAdapterDependencies.xml new file mode 100644 index 0000000..a0128bf --- /dev/null +++ b/Editor/AppLovinAdapterDependencies.xml @@ -0,0 +1,14 @@ + + + + + + + + + + + + + + diff --git a/Editor/AppLovinAdapterDependencies.xml.meta b/Editor/AppLovinAdapterDependencies.xml.meta new file mode 100644 index 0000000..2a95087 --- /dev/null +++ b/Editor/AppLovinAdapterDependencies.xml.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: d9203f7b8611248648c8fea2fd14bd9a +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/LICENSE.md b/LICENSE.md new file mode 100644 index 0000000..926856a --- /dev/null +++ b/LICENSE.md @@ -0,0 +1,9 @@ +MIT License + +Copyright 2024 Chartboost Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/LICENSE.md.meta b/LICENSE.md.meta new file mode 100644 index 0000000..92d06c2 --- /dev/null +++ b/LICENSE.md.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 6e7f7e6afc9684e1ba9e2a32b633bca2 +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/README.md b/README.md index 54a973a..365eb34 100644 --- a/README.md +++ b/README.md @@ -1 +1,86 @@ -# chartboost-mediation-unity-adapter-applovin \ No newline at end of file +# Chartboost Mediation Unity SDK - AppLovin Adapter + +Provides a list of externally configurable properties pertaining to the partner SDK that can be retrieved and set by publishers. + +Dependencies for the adapter are now embedded in the package, and can be found at `com.chartboost.mediation.unity.adapter.appLovin/Editor/AppLovinAdapterDependencies.xml`. + +# Installation + +## Using the public [npm registry](https://www.npmjs.com/search?q=com.chartboost.mediation.unity.adapter.applovin) + +In order to add the Chartboost Mediation Unity SDK - AppLovin Adapter to your project using the npm package, add the following to your Unity Project's ***manifest.json*** file. The scoped registry section is required in order to fetch packages from the NpmJS registry. + +```json +"dependencies": { + "com.chartboost.mediation.unity.adapter.applovin": "5.0.0", + ... +}, +"scopedRegistries": [ +{ + "name": "NpmJS", + "url": "https://registry.npmjs.org", + "scopes": [ + "com.chartboost" + ] +} +] +``` +## Using the public [NuGet package](https://www.nuget.org/packages/Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin) + +To add the Chartboost Mediation Unity SDK - AppLovin Adapter to your project using the NuGet package, you will first need to add the [NugetForUnity](https://github.com/GlitchEnzo/NuGetForUnity) package into your Unity Project. + +This can be done by adding the following to your Unity Project's ***manifest.json*** + +```json + "dependencies": { + "com.github-glitchenzo.nugetforunity": "https://github.com/GlitchEnzo/NuGetForUnity.git?path=/src/NuGetForUnity", + ... + }, +``` + +Once NugetForUnity is installed, search for `Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin` in the search bar of Nuget Explorer window(Nuget -> Manage Nuget Packages). +You should be able to see the `Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin` package. Choose the appropriate version and install. + +# Usage +The following code block exemplifies usage of the `AppLovinAdapter.cs` configuration class. + +## IPartnerAdapterConfiguration Properties + +```csharp + +// AdapterUnityVersion - The partner adapter Unity version, e.g: 5.0.0 +Debug.Log($"Adapter Unity Version: {AppLovinAdapter.AdapterUnityVersion}"); + +// AdapterNativeVersion - The partner adapter version, e.g: 5.12.5.0.0 +Debug.Log($"Adapter Native Version: {AppLovinAdapter.AdapterNativeVersion}"); + +// PartnerSDKVersion - The partner SDK version, e.g: 12.5.0 +Debug.Log($"Partner SDK Version: {AppLovinAdapter.PartnerSDKVersion}"); + +// PartnerIdentifier - The partner ID for internal uses, e.g: applovin +Debug.Log($"Partner Identifier: {AppLovinAdapter.PartnerIdentifier}"); + +// PartnerDisplayName - The partner name for external uses, e.g: AppLovin +Debug.Log($"Partner Display Name: {AppLovinAdapter.PartnerDisplayName}"); +``` + +## Test Mode +To enable test mode for the AppLovin adapter, the following property has been made available: + +```csharp +AppLovinAdapter.TestMode = true; +``` + +## Mute Audio +To mute the audio from videos for the AppLovin adapter, the following property has been made available: + +```csharp +AppLovinAdapter.MuteAudio = true; +``` + +## Verbose Logging +To enable verbose logging for the AppLovin adapter, the following property has been made available: + +```csharp +AppLovinAdapter.VerboseLogging = true; +``` \ No newline at end of file diff --git a/README.md.meta b/README.md.meta new file mode 100644 index 0000000..adf2224 --- /dev/null +++ b/README.md.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 926f774da917d4be58dee377961430d6 +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime.meta b/Runtime.meta new file mode 100644 index 0000000..8869b65 --- /dev/null +++ b/Runtime.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: c7511f017524e40c385be8415121d923 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/Android.meta b/Runtime/Android.meta new file mode 100644 index 0000000..98c3ad4 --- /dev/null +++ b/Runtime/Android.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 74c6cc89647d1472786a3848130fe23e +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/Android/AppLovinAdapter.cs b/Runtime/Android/AppLovinAdapter.cs new file mode 100644 index 0000000..0cadc9e --- /dev/null +++ b/Runtime/Android/AppLovinAdapter.cs @@ -0,0 +1,108 @@ +using Chartboost.Constants; +using Chartboost.Mediation.AppLovin.Common; +using UnityEngine; + +namespace Chartboost.Mediation.AppLovin.Android +{ + internal sealed class AppLovinAdapter : IAppLovinAdapter + { + private const string AppLovinAdapterConfiguration = "com.chartboost.mediation.applovinadapter.AppLovinAdapterConfiguration"; + private const string FunctionGetIsMuted = "isMuted"; + private const string FunctionSetMuteAudio = "setMuted"; + private const string FunctionIsVerboseLoggingEnabled = "isVerboseLoggingEnabled"; + + [RuntimeInitializeOnLoadMethod] + private static void RegisterInstance() + { + if (Application.isEditor) + return; + AppLovin.AppLovinAdapter.Instance = new AppLovinAdapter(); + } + + /// + public string AdapterNativeVersion + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(SharedAndroidConstants.FunctionGetAdapterVersion); + } + } + + /// + public string PartnerSDKVersion + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(SharedAndroidConstants.FunctionGetPartnerSdkVersion); + } + } + + /// + public string PartnerIdentifier + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(SharedAndroidConstants.FunctionGetPartnerId); + } + } + + /// + public string PartnerDisplayName + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(SharedAndroidConstants.FunctionGetPartnerDisplayName); + } + } + + /// + public bool TestMode + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(SharedAndroidConstants.FunctionGetTestMode);; + } + set + { + using var currentActivity = SharedAndroidConstants.UnityPlayerCurrentActivity(); + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + adapterConfiguration.Call(SharedAndroidConstants.FunctionSetTestMode, currentActivity, value); + } + } + + /// + public bool MuteAudio + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(FunctionGetIsMuted); + } + set + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + adapterConfiguration.Call(FunctionSetMuteAudio, value); + } + } + + /// + public bool VerboseLogging + { + get + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + return adapterConfiguration.Call(FunctionIsVerboseLoggingEnabled); + } + set + { + using var adapterConfiguration = new AndroidJavaObject(AppLovinAdapterConfiguration); + adapterConfiguration.Call(SharedAndroidConstants.FunctionSetVerboseLoggingEnabled, value); + } + } + } +} diff --git a/Runtime/Android/AppLovinAdapter.cs.meta b/Runtime/Android/AppLovinAdapter.cs.meta new file mode 100644 index 0000000..a8eddb6 --- /dev/null +++ b/Runtime/Android/AppLovinAdapter.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 714caa095b1df494e8a36566c3ab3293 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/Android/AssemblyInfo.cs b/Runtime/Android/AssemblyInfo.cs new file mode 100644 index 0000000..5324eb2 --- /dev/null +++ b/Runtime/Android/AssemblyInfo.cs @@ -0,0 +1,3 @@ +using UnityEngine.Scripting; + +[assembly: AlwaysLinkAssembly] diff --git a/Runtime/Android/AssemblyInfo.cs.meta b/Runtime/Android/AssemblyInfo.cs.meta new file mode 100644 index 0000000..93fe0f0 --- /dev/null +++ b/Runtime/Android/AssemblyInfo.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: 8d619b633a2a04fe8a1645e4238f0c8a +timeCreated: 1684175795 \ No newline at end of file diff --git a/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef b/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef new file mode 100644 index 0000000..2e52259 --- /dev/null +++ b/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef @@ -0,0 +1,26 @@ +{ + "name": "Chartboost.Mediation.AppLovin.Android", + "rootNamespace": "Chartboost.Mediation.AppLovin.Android", + "references": [ + "Chartboost.Threading", + "Chartboost.Logging", + "Chartboost.Mediation.AppLovin", + "Chartboost.Mediation", + "Chartboost.Mediation.Android", + "Chartboost.Utilities.Android" + ], + "includePlatforms": [ + "Android", + "Editor" + ], + "excludePlatforms": [], + "allowUnsafeCode": false, + "overrideReferences": false, + "precompiledReferences": [ + "" + ], + "autoReferenced": true, + "defineConstraints": [], + "versionDefines": [], + "noEngineReferences": false +} \ No newline at end of file diff --git a/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef.meta b/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef.meta new file mode 100644 index 0000000..f78eaa4 --- /dev/null +++ b/Runtime/Android/Chartboost.Mediation.AppLovin.Android.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 6c68adf124ace4f9c9ddda4bda762de8 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin.meta b/Runtime/AppLovin.meta new file mode 100644 index 0000000..fab97c4 --- /dev/null +++ b/Runtime/AppLovin.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 979a38dffba5b4ed1944983787ef7496 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/AppLovinAdapter.cs b/Runtime/AppLovin/AppLovinAdapter.cs new file mode 100644 index 0000000..85b932c --- /dev/null +++ b/Runtime/AppLovin/AppLovinAdapter.cs @@ -0,0 +1,51 @@ +using System.Collections.Generic; +using Chartboost.Mediation.Adapters; +using Chartboost.Mediation.AppLovin.Common; +using Chartboost.Mediation.AppLovin.Default; + +namespace Chartboost.Mediation.AppLovin +{ + /// + public sealed class AppLovinAdapter + { + internal static IAppLovinAdapter Instance = new AppLovinDefault(); + + /// + /// The partner adapter Unity version. + /// + public const string AdapterUnityVersion = "5.0.0"; + + /// + public static string AdapterNativeVersion => Instance.AdapterNativeVersion; + + /// + public static string PartnerSDKVersion => Instance.PartnerSDKVersion; + + /// + public static string PartnerIdentifier => Instance.PartnerIdentifier; + + /// + public static string PartnerDisplayName => Instance.PartnerDisplayName; + + /// + public static bool TestMode + { + get => Instance.TestMode; + set => Instance.TestMode = value; + } + + /// + public static bool MuteAudio + { + get => Instance.MuteAudio; + set => Instance.MuteAudio = value; + } + + /// + public static bool VerboseLogging + { + get => Instance.VerboseLogging; + set => Instance.VerboseLogging = value; + } + } +} diff --git a/Runtime/AppLovin/AppLovinAdapter.cs.meta b/Runtime/AppLovin/AppLovinAdapter.cs.meta new file mode 100644 index 0000000..b7f3f37 --- /dev/null +++ b/Runtime/AppLovin/AppLovinAdapter.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: bffe45ddbcb5342278f4dd64a112c401 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/AssemblyInfo.cs b/Runtime/AppLovin/AssemblyInfo.cs new file mode 100644 index 0000000..c61ba5d --- /dev/null +++ b/Runtime/AppLovin/AssemblyInfo.cs @@ -0,0 +1,16 @@ +using System.Runtime.CompilerServices; +using Chartboost.Mediation.AppLovin; +using UnityEngine.Scripting; + +[assembly: AlwaysLinkAssembly] +[assembly: InternalsVisibleTo(AssemblyInfo.AppLovinAssemblyInfoAndroid)] +[assembly: InternalsVisibleTo(AssemblyInfo.AppLovinAssemblyInfoIOS)] + +namespace Chartboost.Mediation.AppLovin +{ + internal class AssemblyInfo + { + public const string AppLovinAssemblyInfoAndroid = "Chartboost.Mediation.AppLovin.Android"; + public const string AppLovinAssemblyInfoIOS = "Chartboost.Mediation.AppLovin.IOS"; + } +} diff --git a/Runtime/AppLovin/AssemblyInfo.cs.meta b/Runtime/AppLovin/AssemblyInfo.cs.meta new file mode 100644 index 0000000..614bdaf --- /dev/null +++ b/Runtime/AppLovin/AssemblyInfo.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: fb7ea54a18fce42a2b24f7251affb813 +timeCreated: 1684175795 \ No newline at end of file diff --git a/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef b/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef new file mode 100644 index 0000000..c9b9f5c --- /dev/null +++ b/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef @@ -0,0 +1,21 @@ +{ + "name": "Chartboost.Mediation.AppLovin", + "rootNamespace": "Chartboost.Mediation.AppLovin", + "references": [ + "Chartboost.Threading", + "Chartboost.Logging", + "Chartboost.Utilities", + "Chartboost.Mediation" + ], + "includePlatforms": [], + "excludePlatforms": [], + "allowUnsafeCode": false, + "overrideReferences": false, + "precompiledReferences": [ + "" + ], + "autoReferenced": true, + "defineConstraints": [], + "versionDefines": [], + "noEngineReferences": false +} diff --git a/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef.meta b/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef.meta new file mode 100644 index 0000000..e0d99ba --- /dev/null +++ b/Runtime/AppLovin/Chartboost.Mediation.AppLovin.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 9f8670e97e37546e489b1d6d240ae1f9 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/Common.meta b/Runtime/AppLovin/Common.meta new file mode 100644 index 0000000..6000237 --- /dev/null +++ b/Runtime/AppLovin/Common.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 8927b339c30d34d02ac23564a6a714a0 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/Common/IAppLovinAdapter.cs b/Runtime/AppLovin/Common/IAppLovinAdapter.cs new file mode 100644 index 0000000..831a6c9 --- /dev/null +++ b/Runtime/AppLovin/Common/IAppLovinAdapter.cs @@ -0,0 +1,25 @@ +using Chartboost.Mediation.Adapters; + +namespace Chartboost.Mediation.AppLovin.Common +{ + /// + /// The Chartboost Mediation AppLovin adapter. + /// + internal interface IAppLovinAdapter : IPartnerAdapterConfiguration + { + /// + /// Enable/disable AppLovin's test mode. Remember to set this to false in production. + /// + bool TestMode { get; set; } + + /// + /// Enable/disable AppLovin's mute setting. + /// + bool MuteAudio { get; set; } + + /// + /// Enable/disable AppLovin's verbose logging. + /// + bool VerboseLogging { get; set; } + } +} diff --git a/Runtime/AppLovin/Common/IAppLovinAdapter.cs.meta b/Runtime/AppLovin/Common/IAppLovinAdapter.cs.meta new file mode 100644 index 0000000..015d5cd --- /dev/null +++ b/Runtime/AppLovin/Common/IAppLovinAdapter.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 429fdb0656591409eabbdd20a5177e9b +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/Default.meta b/Runtime/AppLovin/Default.meta new file mode 100644 index 0000000..e7f883f --- /dev/null +++ b/Runtime/AppLovin/Default.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: fcd724473a753491290d92723e2b254e +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/AppLovin/Default/AppLovinDefault.cs b/Runtime/AppLovin/Default/AppLovinDefault.cs new file mode 100644 index 0000000..3a9a20e --- /dev/null +++ b/Runtime/AppLovin/Default/AppLovinDefault.cs @@ -0,0 +1,28 @@ +using Chartboost.Mediation.AppLovin.Common; + +namespace Chartboost.Mediation.AppLovin.Default +{ + internal class AppLovinDefault : IAppLovinAdapter + { + /// + public string AdapterNativeVersion => AppLovinAdapter.AdapterUnityVersion; + + /// + public string PartnerSDKVersion => AppLovinAdapter.AdapterUnityVersion; + + /// + public string PartnerIdentifier => "applovin"; + + /// + public string PartnerDisplayName => "AppLovin"; + + /// + public bool TestMode { get; set; } + + /// + public bool MuteAudio { get; set; } + + /// + public bool VerboseLogging { get; set; } + } +} diff --git a/Runtime/AppLovin/Default/AppLovinDefault.cs.meta b/Runtime/AppLovin/Default/AppLovinDefault.cs.meta new file mode 100644 index 0000000..cd837a0 --- /dev/null +++ b/Runtime/AppLovin/Default/AppLovinDefault.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 8bfe194ab4ac34588ba94e3174eaf43d +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS.meta b/Runtime/iOS.meta new file mode 100644 index 0000000..868212f --- /dev/null +++ b/Runtime/iOS.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 344a7eb223da945a5a88d3df4046bdcc +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS/AppLovinAdapter.cs b/Runtime/iOS/AppLovinAdapter.cs new file mode 100644 index 0000000..1836cdb --- /dev/null +++ b/Runtime/iOS/AppLovinAdapter.cs @@ -0,0 +1,62 @@ +using System.Runtime.InteropServices; +using Chartboost.Constants; +using Chartboost.Mediation.AppLovin.Common; +using UnityEngine; + +namespace Chartboost.Mediation.AppLovin.IOS +{ + internal sealed class AppLovinAdapter : IAppLovinAdapter + { + [RuntimeInitializeOnLoadMethod] + private static void RegisterInstance() + { + if (Application.isEditor) + return; + AppLovin.AppLovinAdapter.Instance = new AppLovinAdapter(); + } + + /// + public string AdapterNativeVersion => _CBMAppLovinAdapterAdapterVersion(); + + /// + public string PartnerSDKVersion => _CBMAppLovinAdapterPartnerSDKVersion(); + + /// + public string PartnerIdentifier => _CBMAppLovinAdapterPartnerId(); + + /// + public string PartnerDisplayName => _CBMAppLovinAdapterPartnerDisplayName(); + + /// + public bool TestMode + { + get => _CBMAppLovinAdapterGetTestMode(); + set => _CBMAppLovinAdapterSetTestMode(value); + } + + /// + public bool MuteAudio + { + get => _CBMAppLovinAdapterGetMuteAudio(); + set => _CBMAppLovinAdapterSetMuteAudio(value); + } + + /// + public bool VerboseLogging + { + get => _CBMAppLovinAdapterGetVerboseLogging(); + set => _CBMAppLovinAdapterSetVerboseLogging(value); + } + + [DllImport(SharedIOSConstants.DLLImport)] private static extern string _CBMAppLovinAdapterAdapterVersion(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern string _CBMAppLovinAdapterPartnerSDKVersion(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern string _CBMAppLovinAdapterPartnerId(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern string _CBMAppLovinAdapterPartnerDisplayName(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern bool _CBMAppLovinAdapterGetTestMode(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern void _CBMAppLovinAdapterSetTestMode(bool enabled); + [DllImport(SharedIOSConstants.DLLImport)] private static extern bool _CBMAppLovinAdapterGetMuteAudio(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern void _CBMAppLovinAdapterSetMuteAudio(bool muteAudio); + [DllImport(SharedIOSConstants.DLLImport)] private static extern bool _CBMAppLovinAdapterGetVerboseLogging(); + [DllImport(SharedIOSConstants.DLLImport)] private static extern void _CBMAppLovinAdapterSetVerboseLogging(bool verboseLogging); + } +} diff --git a/Runtime/iOS/AppLovinAdapter.cs.meta b/Runtime/iOS/AppLovinAdapter.cs.meta new file mode 100644 index 0000000..e2a306a --- /dev/null +++ b/Runtime/iOS/AppLovinAdapter.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: d61b5756f4fb84697af5996ab7c1bf2d +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS/AssemblyInfo.cs b/Runtime/iOS/AssemblyInfo.cs new file mode 100644 index 0000000..5324eb2 --- /dev/null +++ b/Runtime/iOS/AssemblyInfo.cs @@ -0,0 +1,3 @@ +using UnityEngine.Scripting; + +[assembly: AlwaysLinkAssembly] diff --git a/Runtime/iOS/AssemblyInfo.cs.meta b/Runtime/iOS/AssemblyInfo.cs.meta new file mode 100644 index 0000000..bf5e775 --- /dev/null +++ b/Runtime/iOS/AssemblyInfo.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: a29edeca1753a49f7b434fab50dd991c +timeCreated: 1684175795 \ No newline at end of file diff --git a/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef b/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef new file mode 100644 index 0000000..5be5247 --- /dev/null +++ b/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef @@ -0,0 +1,25 @@ +{ + "name": "Chartboost.Mediation.AppLovin.IOS", + "rootNamespace": "Chartboost.Mediation.AppLovin.IOS", + "references": [ + "Chartboost.Threading", + "Chartboost.Logging", + "Chartboost.Mediation.AppLovin", + "Chartboost.Mediation", + "Chartboost.Utilities.IOS" + ], + "includePlatforms": [ + "Editor", + "iOS" + ], + "excludePlatforms": [], + "allowUnsafeCode": false, + "overrideReferences": false, + "precompiledReferences": [ + "" + ], + "autoReferenced": true, + "defineConstraints": [], + "versionDefines": [], + "noEngineReferences": false +} diff --git a/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef.meta b/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef.meta new file mode 100644 index 0000000..59eba52 --- /dev/null +++ b/Runtime/iOS/Chartboost.Mediation.AppLovin.IOS.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: c0eae8605e3b4433c951bed74a585000 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS/Plugins.meta b/Runtime/iOS/Plugins.meta new file mode 100644 index 0000000..13b58b7 --- /dev/null +++ b/Runtime/iOS/Plugins.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 549ac0581b8eb4af99a4de339ccd5ce5 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS/Plugins/iOS.meta b/Runtime/iOS/Plugins/iOS.meta new file mode 100644 index 0000000..7973762 --- /dev/null +++ b/Runtime/iOS/Plugins/iOS.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 0620700c8fc944fc6ab283c9f917f294 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm b/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm new file mode 100644 index 0000000..7704baf --- /dev/null +++ b/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm @@ -0,0 +1,46 @@ +#import "CBMDelegates.h" +#import "ChartboostUnityUtilities.h" +#import + +extern "C" { + + const char * _CBMAppLovinAdapterAdapterVersion(){ + return toCStringOrNull([AppLovinAdapterConfiguration adapterVersion]); + } + + const char * _CBMAppLovinAdapterPartnerSDKVersion(){ + return toCStringOrNull([AppLovinAdapterConfiguration partnerSDKVersion]); + } + + const char * _CBMAppLovinAdapterPartnerId(){ + return toCStringOrNull([AppLovinAdapterConfiguration partnerID]); + } + + const char * _CBMAppLovinAdapterPartnerDisplayName(){ + return toCStringOrNull([AppLovinAdapterConfiguration partnerDisplayName]); + } + + BOOL _CBMAppLovinAdapterGetTestMode() { + return [AppLovinAdapterConfiguration testMode]; + } + + void _CBMAppLovinAdapterSetTestMode(BOOL enabled) { + return [AppLovinAdapterConfiguration setTestMode:enabled]; + } + + BOOL _CBMAppLovinAdapterGetMuteAudio(){ + return [AppLovinAdapterConfiguration isMuted]; + } + + void _CBMAppLovinAdapterSetMuteAudio(BOOL muteAudio){ + [AppLovinAdapterConfiguration setIsMuted:muteAudio]; + } + + BOOL _CBMAppLovinAdapterGetVerboseLogging(){ + return [AppLovinAdapterConfiguration verboseLogging]; + } + + void _CBMAppLovinAdapterSetVerboseLogging(BOOL verboseLogging){ + [AppLovinAdapterConfiguration setVerboseLogging:verboseLogging]; + } +} diff --git a/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm.meta b/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm.meta new file mode 100644 index 0000000..3ae3eee --- /dev/null +++ b/Runtime/iOS/Plugins/iOS/CBMAppLovinUnityBridge.mm.meta @@ -0,0 +1,37 @@ +fileFormatVersion: 2 +guid: a696f87af8df64de49952965785f72bb +PluginImporter: + externalObjects: {} + serializedVersion: 2 + iconMap: {} + executionOrder: {} + defineConstraints: [] + isPreloaded: 0 + isOverridable: 1 + isExplicitlyReferenced: 0 + validateReferences: 1 + platformData: + - first: + Any: + second: + enabled: 0 + settings: {} + - first: + Editor: Editor + second: + enabled: 0 + settings: + DefaultValueInitialized: true + - first: + iPhone: iOS + second: + enabled: 1 + settings: {} + - first: + tvOS: tvOS + second: + enabled: 1 + settings: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests.meta b/Tests.meta new file mode 100644 index 0000000..dd3ef77 --- /dev/null +++ b/Tests.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: caee2e4f6232d4d4f8863dfb4b520ee2 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests/Editor.meta b/Tests/Editor.meta new file mode 100644 index 0000000..063b2ab --- /dev/null +++ b/Tests/Editor.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: fce012473d3f64502bbd68968f62e75f +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef b/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef new file mode 100644 index 0000000..6189e27 --- /dev/null +++ b/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef @@ -0,0 +1,26 @@ +{ + "name": "Chartboost.Mediation.AppLovin.Tests.Editor", + "rootNamespace": "Chartboost.Tests.Editor", + "references": [ + "UnityEngine.TestRunner", + "UnityEditor.TestRunner", + "Chartboost.Utilities.Editor", + "Chartboost.Logging", + "Chartboost.Mediation.AppLovin" + ], + "includePlatforms": [ + "Editor" + ], + "excludePlatforms": [], + "allowUnsafeCode": false, + "overrideReferences": true, + "precompiledReferences": [ + "nunit.framework.dll" + ], + "autoReferenced": false, + "defineConstraints": [ + "UNITY_INCLUDE_TESTS" + ], + "versionDefines": [], + "noEngineReferences": false +} diff --git a/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef.meta b/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef.meta new file mode 100644 index 0000000..672d0ee --- /dev/null +++ b/Tests/Editor/Chartboost.Mediation.AppLovin.Tests.Editor.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 3afbd679d9a5d496e80760763b922898 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests/Editor/VersionValidator.cs b/Tests/Editor/VersionValidator.cs new file mode 100644 index 0000000..3481878 --- /dev/null +++ b/Tests/Editor/VersionValidator.cs @@ -0,0 +1,21 @@ +using Chartboost.Editor; +using Chartboost.Logging; +using Chartboost.Mediation.AppLovin; +using NUnit.Framework; + +namespace Chartboost.Tests.Editor +{ + internal class VersionValidator + { + private const string UnityPackageManagerPackageName = "com.chartboost.mediation.unity.adapter.applovin"; + private const string NuGetPackageName = "Chartboost.CSharp.Mediation.Unity.Adapter.AppLovin"; + + [SetUp] + public void SetUp() + => LogController.LoggingLevel = LogLevel.Debug; + + [Test] + public void ValidateVersion() + => VersionCheck.ValidateVersions(UnityPackageManagerPackageName, NuGetPackageName, AppLovinAdapter.AdapterUnityVersion); + } +} diff --git a/Tests/Editor/VersionValidator.cs.meta b/Tests/Editor/VersionValidator.cs.meta new file mode 100644 index 0000000..8752438 --- /dev/null +++ b/Tests/Editor/VersionValidator.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: fae6e7219aab64fac9afa7e04833a28a +timeCreated: 1710897732 \ No newline at end of file diff --git a/Tests/Runtime.meta b/Tests/Runtime.meta new file mode 100644 index 0000000..6b754cc --- /dev/null +++ b/Tests/Runtime.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 2b316e1b735954f74ad0eb5662b791ac +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests/Runtime/AppLovinAdapterTests.cs b/Tests/Runtime/AppLovinAdapterTests.cs new file mode 100644 index 0000000..fa3685d --- /dev/null +++ b/Tests/Runtime/AppLovinAdapterTests.cs @@ -0,0 +1,42 @@ +using Chartboost.Logging; +using Chartboost.Mediation.AppLovin; +using Chartboost.Tests.Runtime; +using NUnit.Framework; + +namespace Chartboost.Tests +{ + internal class AppLovinAdapterTests + { + [SetUp] + public void SetUp() + => LogController.LoggingLevel = LogLevel.Debug; + + [Test] + public void AdapterNativeVersion() + => TestUtilities.TestStringGetter(() => AppLovinAdapter.AdapterNativeVersion); + + [Test] + public void PartnerSDKVersion() + => TestUtilities.TestStringGetter(() => AppLovinAdapter.PartnerSDKVersion); + + [Test] + public void PartnerIdentifier() + => TestUtilities.TestStringGetter(() => AppLovinAdapter.PartnerIdentifier); + + [Test] + public void PartnerDisplayName() + => TestUtilities.TestStringGetter(() => AppLovinAdapter.PartnerDisplayName); + + [Test] + public void TestMode() + => TestUtilities.TestBooleanAccessor(() => AppLovinAdapter.TestMode, value => AppLovinAdapter.TestMode = value); + + [Test] + public void MuteAudio() + => TestUtilities.TestBooleanAccessor(() => AppLovinAdapter.MuteAudio, value => AppLovinAdapter.MuteAudio = value); + + [Test] + public void VerboseLogging() + => TestUtilities.TestBooleanAccessor(() => AppLovinAdapter.VerboseLogging, value => AppLovinAdapter.VerboseLogging = value); + } +} diff --git a/Tests/Runtime/AppLovinAdapterTests.cs.meta b/Tests/Runtime/AppLovinAdapterTests.cs.meta new file mode 100644 index 0000000..29a0d31 --- /dev/null +++ b/Tests/Runtime/AppLovinAdapterTests.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 40bdef0deee3942069a9eecc6e1f26dd +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef b/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef new file mode 100644 index 0000000..eaea0da --- /dev/null +++ b/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef @@ -0,0 +1,29 @@ +{ + "name": "Chartboost.Mediation.AppLovin.Tests.Runtime", + "rootNamespace": "Chartboost.Tests", + "references": [ + "UnityEngine.TestRunner", + "UnityEditor.TestRunner", + "Chartboost.Utilities", + "Chartboost.Mediation.AppLovin", + "Chartboost.Logging", + "Chartboost.Utilities.Tests.Runtime" + ], + "includePlatforms": [ + "Android", + "Editor", + "iOS" + ], + "excludePlatforms": [], + "allowUnsafeCode": false, + "overrideReferences": true, + "precompiledReferences": [ + "nunit.framework.dll" + ], + "autoReferenced": false, + "defineConstraints": [ + "UNITY_INCLUDE_TESTS" + ], + "versionDefines": [], + "noEngineReferences": false +} \ No newline at end of file diff --git a/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef.meta b/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef.meta new file mode 100644 index 0000000..5891614 --- /dev/null +++ b/Tests/Runtime/Chartboost.Mediation.AppLovin.Tests.Runtime.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 63462cf7cfade4a54821055bf6cebfc3 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/package.json b/package.json new file mode 100644 index 0000000..e05df9b --- /dev/null +++ b/package.json @@ -0,0 +1,31 @@ +{ + "name": "com.chartboost.mediation.unity.adapter.applovin", + "version": "5.0.0", + "displayName": "Chartboost Mediation Adapter - AppLovin", + "description": "The Chartboost Mediation Unity SDK Adapter for AppLovin.", + "unity": "2022.3", + "documentationUrl": "https://docs.chartboost.com/en/mediation/integrate/unity/get-started/", + "changelogUrl": "https://docs.chartboost.com/en/mediation/integrate/unity/changelog/", + "licensesUrl": "https://docs.chartboost.com/en/legal/", + "dependencies": { + "com.chartboost.mediation" : "5.0.0", + "com.chartboost.unity.threading": "1.0.1", + "com.chartboost.unity.utilities": "1.0.1", + "com.chartboost.unity.logging": "1.0.0" + }, + "keywords": ["Chartboost", "Mediation", "Adapter", "Unity", "AppLovin"], + "author": { + "name": "Chartboost", + "email": "sales@chartboost.com", + "url": "https://www.chartboost.com/products/mediation/" + }, + "repository": { + "type": "git", + "url": "https://github.com/ChartBoost/chartboost-mediation-unity-adapter-applovin.git" + }, + "bugs": { + "url": "https://github.com/ChartBoost/chartboost-mediation-unity-adapter-applovin/issues", + "email": "helium-service@chartboost.com" + }, + "hideInEditor": false +} \ No newline at end of file diff --git a/package.json.meta b/package.json.meta new file mode 100644 index 0000000..f5d9893 --- /dev/null +++ b/package.json.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: e0163c3d4710e4c9bb37d294ac891598 +PackageManifestImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: