Skip to main content

Install Unreal Engine SDK for iOS

UE4.21 - UE4.27 & UE5 - UE5.4
Version Requirements

Minimum supported iOS version is iOS 12, due to App Store Connect's upload requirements mandating the use of Xcode 15.

For LINE, Kakao, upgrade iOS SDK to version 13 and above.

Prerequisites

caution

The version of each SDK plugin used by the game, including the version used by the game launcher, must be consistent. If games require access to multiple versions of Player Network SDK at the same time, or if only one component needs to be upgraded, reach out to the Player Network representative.

  1. Get a login account from Player Network.
  2. Create a new project.
  3. [Optional] Invite users to join the project.
  4. Download the SDK.

Step 1: Install the SDK

1. Add Player Network SDK to your project

  1. Unzip the SDK package.

  2. Copy the INTLSDK folder to the Plugins folder of your project.
    If your project does not have a Plugins folder, create one.

  3. Open your project's {Project Name}.Build.cs file and add Player Network SDK to Unreal Engine by following the below example.

    public INTLSample(ReadOnlyTargetRules Target) : base(Target)
    {
    PrivateDependencyModuleNames.AddRange(new string[] {
    "INTLCore",
    "INTLFoundation",
    "INTLConfig",
    });
    }
Player Network SDK package
├─INTLSDK
│ ├─INTLSDK.uplugin // Player Network SDK plugins description files
│ ├─Resources // Player Network SDK resources
│ └─Source // Player Network SDK plugin modules. Each module contains its own Build.cs file, libraries, and interfaces.
│ ├─INTLApple
│ ├─INTLConfig // Player Network SDK configurations
│ ├─INTLCore // Player Network SDK Core module
│ ├─INTLDiscord
│ ├─INTLEpic
│ ├─INTLFacebook
│ ├─INTLFoundation
│ ├─INTLGoogle
│ ├─INTLKakao
│ ├─INTLLine
│ ├─INTLSteam
│ ├─INTLTwitter
│ └─INTLVK
├─LevelInfinite // LI PASS APIs
└─Symbols // Player Network SDK symbol table *.so files
INTLSDK/Source/INTLCore
└─INTLSDK
├─INTLSDK.uplugin
├─Resources
└─Source
├─INTLConfig
├─INTLCore
| ├─INTLCore.Build.cs // INTLCore Build.cs file
| ├─Libs // INTLCore libraries for different platforms which contain dll, lib, and other binary files.
| | ├─Android
| | ├─include
| | ├─iOS
| | ├─MacOS
| | └─Win
| ├─Private // Player Network SDK private folder
| └─Public // Player Network SDK public interfaces
| // INTLSDKAPI.h: Player Network SDK APIs
| // INTLSDKPluginObserver.h: Player Network SDK observer classes
| // INTLSDKPluginDefine.h: Player Network SDK data types
| // INTLSDKOutputUtility.h: Player Network SDK utility to process callbacks
| // INTLSDKBaseUserWidget.h: Player Network SDK base class for UserWidget which includes registration and deregistration APIs
├─INTLCustomer
├─INTLDiscord
├─INTLEpic
INTLSDK/Source/INTLConfig
└─INTLSDK
├─INTLSDK.uplugin
├─Resources
└─Source
├─INTLConfig
| ├─Configs // Player Network SDK configurations for different platform
| | ├─Android
| | | └─INTLConfig_APL.xml // Player Network SDK Android gradle configuration file
| | ├─iOS
| | | └─INTLConfig_UPL.xml
| | ├─Resources
| | | ├─APASConfig.ini // APAS device level configuration file
| | | └─INTLConfig.ini // Player Network SDK main configuration file
| ├─Encrypt
| ├─INTLConfig.Build.cs
| ├─INTLConfig.uplugin
| ├─Private
| ├─Public
| └─Resources
├─INTLCore

2. Load required permissions and plugins

Add Player Network SDK related configurations to the configuration file.

For example, for the Facebook Plugin Configuration, you should modify the Facebook configuration according to your game.

Open and modify the file that corresponds to your SDK version:

  • For V1.24 or later: INTLSDK/Source/INTLFacebook/Libs/iOS/INTLFacebook_UPL.xml
  • For V1.18 to V1.23: INTLSDK/Source/INTLConfig/Configs/iOS/Plist/INTLFacebook.plist
<key>CFBundleURLSchemes</key>
<array>
<string>fb{INTL_FACEBOOK_APP_ID}</string>
</array>

iOS usage description

caution

When integrating, users can modify the contents according to their needs, then confirm with the legal team if the contents are compliant. If there are no modifications, replace INTLSample with the game name.

According to the requirements for iOS, when requesting sensitive permissions, fill in usage description when prompted by the system popup.

  1. In Plugins/INTLSDK/Source/INTLConfig/Configs/iOS/Plist/INTLCore.plist, the following permissions have been upgraded:

    <key>NSPhotoLibraryUsageDescription</key>
    <key>NSCameraUsageDescription</key>
    <key>NSLocationWhenInUseUsageDescription</key>
    <key>NSPhotoLibraryAddUsageDescription</key>
    <key>NSMicrophoneUsageDescription</key>
  2. In Plugins/INTLSDK/Source/INTLConfig/Configs/iOS/Plist/INTLADTracking.plist, the following permissions has been upgraded:

    <key>NSUserTrackingUsageDescription</key>

3. Add compatibility for Swift SDK

note

For Unreal Engine 5.2 or later, the Swift module is already included in the engine code, and compatibility does not have to be added. The following steps are only applicable to versions before Unreal Engine 5.2.

The iOS Swift module cannot be directly added to Unreal Engine, and the engine configuration must be modified.

  1. Modify the local Unreal Engine source code.

    Add the following code in the private void AppendProjectBuildConfiguration(StringBuilder Content, string ConfigName, string ConfigGuid) function of /Your_UE_Installation_Path/Engine/Source/Programs/UnrealBuildTool/ProjectFiles/Xcode/XcodeProject.cs.

    // Enable Swift
    Content.Append("\t\t\t\tCLANG_ENABLE_MODULES = YES;" + ProjectFileGenerator.NewLine);
    Content.Append("\t\t\t\tSWIFT_VERSION = 5.0;" + ProjectFileGenerator.NewLine);
    Content.Append("\t\t\t\tLIBRARY_SEARCH_PATHS = \"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\";" + ProjectFileGenerator.NewLine);
    if (ConfigName == "Debug")
    {
    Content.Append("\t\t\t\tSWIFT_OPTIMIZATION_LEVEL = \"-Onone\";" + ProjectFileGenerator.NewLine);
    }
    Content.Append("\t\t\t\tALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;" + ProjectFileGenerator.NewLine);
    Content.Append("\t\t\t\tEMBEDDED_CONTENT_CONTAINS_SWIFT = YES;" + ProjectFileGenerator.NewLine);

    Image: Unreal Swift Configuration 5

  2. Add the following code in the string GetLinkArguments_Global(LinkEnvironment LinkEnvironment) function of /Your_UE_Installation_Path/Engine/Source/Programs/UnrealBuildTool/Platform/IOS/IOSToolChain.cs.

    // enable swift support
    Result += " -rpath \"/usr/lib/swift\"";
    Result += " -rpath \"@executable_path/Frameworks\"";
    // /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib/swift/
    String swiftLibPath = String.Format(" -L {0}Platforms/{1}.platform/Developer/SDKs/{1}{2}.sdk/usr/lib/swift",
    Settings.Value.XcodeDeveloperDir,
    bIsDevice? Settings.Value.DevicePlatformName : Settings.Value.SimulatorPlatformName,
    Settings.Value.IOSSDKVersion);
    Result += swiftLibPath;
    Log.TraceInformation("Add swift lib path : {0}", swiftLibPath);
    ///Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/swift/iphoneos
    swiftLibPath = String.Format(" -L {0}Toolchains/XcodeDefault.xctoolchain/usr/lib/swift/{1}",
    Settings.Value.XcodeDeveloperDir,
    bIsDevice? Settings.Value.DevicePlatformName.ToLower() : Settings.Value.SimulatorPlatformName.ToLower());
    Result += swiftLibPath;
    Log.TraceInformation("Add swift lib path : {0}", swiftLibPath);
    ///Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/swift-5.0/iphoneos
    swiftLibPath = String.Format(" -L {0}Toolchains/XcodeDefault.xctoolchain/usr/lib/swift-5.0/{1}",
    Settings.Value.XcodeDeveloperDir,
    bIsDevice? Settings.Value.DevicePlatformName.ToLower() : Settings.Value.SimulatorPlatformName.ToLower());
    Result += swiftLibPath;

    Image: Unreal Swift Configuration 3

  3. Open the solutions and recompile /Users/intl/UE4/UE_4.25/Engine/Source/Programs/UnrealBuildTool/UnrealBuildTool.sln.

4. Merge privacy manifest

Version requirements: Player Network SDK V1.22 or later

From Spring 2024, developers will have to clearly describe data use in the privacy manifest, showing how required reason APIs will be utilized in apps that are updated or uploaded to Apple App Store Connect. For more information, see Upcoming third-party SDK requirements.

With regard to the Player Network SDK plugins that are affected, INTLFoundation, INTLCore, and INTLGarena need to be merged manually, among which INTLGarena is only required if the project has integrated Garena.
In addition, INTLLine is integrated automatically in Player Network SDK and need not be configured.

For the other third-party SDKs that have yet to publish their privacy manifests, such content is not available in the Player Network SDK privacy manifest. For the list of plugins that have not been published yet, see iOS 17 Privacy Manifest.

Procedures

  1. Find the privacy manifest PrivacyInfo.xcprivacy for the required plugin from the Player Network SDK product catalog.

    PluginPath
    INTLFoundation/Plugins/iOS/INTLSDK/INTLFoundation/INTLFoundation.framework/PrivacyInfo.xcprivacy
    INTLCore/Plugins/iOS/INTLSDK/INTLCore/INTLCore.framework/PrivacyInfo.xcprivacy
    INTLGarena/Plugins/iOS/INTLSDK/INTLGarena/INTLGarena.framework/PrivacyInfo.xcprivacy
  2. Compare the 4 nodes of the PrivacyInfo.xcprivacy from Player Network SDK with the contents in the PrivacyInfo.xcprivacy from the game project, then merge based on the below conditions.

    1. Privacy Nutrition Label Types (NSPrivacyCollectedDataTypes) describes the data types used:
      Compare the Collected Data Type (NSPrivacyCollectedDataType) of each item, add the value to the game project file if they are different.
      If they are the same, instead compare Collection Purposes (NSPrivacyCollectedDataTypePurposes), add the value to the game project file if they are different.

    2. Privacy Tracking Domains (NSPrivacyTrackingDomains) lists the domains that engage in tracking:
      Compare the corresponding nodes, add the value to the game project file if they are different.

    3. Privacy Tracking Enabled (NSPrivacyTracking) describes if the App Tracking Transparency feature is enabled:
      Compare the corresponding nodes, modify the game project file if the value is YES in the Player Network SDK privacy manifest.

    4. Privacy Accessed API Types (NSPrivacyAccessedAPITypes) describes the API types used:
      Compare the Privacy Accessed API Type (NSPrivacyAccessedAPIType) of each item, add the value to the game project file if they are different.
      If they are the same, instead compare Privacy Accessed API Reasons (NSPrivacyAccessedAPITypeReasons), add the value to the game project file if they are different.

  3. Generate a privacy report using Xcode 15 to verify if expectations have been met.

5. Player Network SDK configuration

note

When INTLConfig.ini is modified manually, reach out to the Player Network representative to confirm if configuration changes meet expectations, see SDK Config Information for more information.

Follow the instructions in INTLConfig.ini to configure accordingly.

6. Initialize the SDK

Before implementing any Player Network features, initialize the SDK first.

UINTLSDKAPI::Init();

7. Verify that the Player Network SDK is successfully connected

  1. Modify the configuration under the INTL Log node in the INTLConfig.ini file.
[INTL Log]
LOG_LEVEL = 1
LOG_ENCRYPT_ENABLE = 0
LOG_COMPRESS_ENABLE = 0
LOG_CONSOLE_OUTPUT_ENABLE = 1
LOG_FILE_OUTPUT_ENABLE = 1
  1. Run the program, integration is successful when Init INTL SDK success. can be found in the log.

Now that the Player Network SDK has been successfully connected, you are ready to start building your project.

We recommend using the following services with Player Network:

  • Refer to our Authentication tutorials for a list of third-party identity providers you can incorporate into your project.
  • See Social for more information on the various social features that can be used to improve player interaction.
  • For instructions on how to configure in-game announcements and push notifications, see Engagement.
  • See Data Insights for ways to collect and report telemetry data.
  • Check out Tools & Utilities for a list of convenient tools provided by Player Network, such as Deep Link and WebView.
  • Depending on your countries/regions of release, determine the Compliance Services that may be required for your project.

Alternatively, gain access to all of the above features and more by simply adding LEVEL INFINITE PASS to your project.
Regular users can follow the streamlined workflow for standard solutions that work on most games, while more advanced users can begin customizing their project with minimal integration involved.

For more information, reach out to the Player Network representative.