Unity + Internet Identity universal links
Overview
This sample shows one way to integrate Internet Identity with iOS apps. It contains two parts: a dapp with II integrated, and an Unity Project which interacts with this dapp.
ii_integration_dapp is an example that integrates with Internet Identity, with the backend and frontend. It derives from the Internet Identity integration sample demo with some modifications.
Please refer to README for details.
unity_project is a Unity project with ICP.NET embedded, which is a C# agent that is able to communicate with the IC from C#. Please refer to README for details.
Workflow
Before continuing, please read through the iOS Universal Links to understand how iOS Universal Links works.
Here is the basic workflow that how to integrate with Internet Identity from a Unity iOS game. The basic idea is to open the Web Browser from the game, login in with II in the browser, and pass the DelegationChain back to the game.
The steps in detail are described below:
Set up an Internet Identity integration dapp which supports logging in with II, with an
apple-app-site-associationfile associated. Please refer to ii_integration_dapp to set up the dapp.Run a Unity game on iOS, which is built from ios_integration sample. Please refer to unity_project to build the Unity iOS game.
Launch the Web Browser from the game to open the dapp frontend deployed in #1, with the public key of
Ed25519Identityas a parameter.Login with your Internet Identity in the Web Browser.
Launch the application via App Links, and pass the
DelegationChainback to the game as the URL parameter.Composite the
DelegationIdentitywithDelegationChainand theEd25519Identity.Call the backend canister with the
DelegationIdentityto greet.