This guide provides focused instructions for implementing the Unity-Immutable-SDK in WebGL projects.
For general information on the SDK, please refer to the Immutable Unity SDK documentation.
Live example can be found at https://immutable.github.io/unity-immutable-sdk
WebGL template is a configuration setting that lets you control the appearance of the HTML page, so that you can: test, demonstrate, and preview your WebGL application in a browser.
-
Create a custom WebGL template:
- Navigate to Assets > WebGLTemplates in your Unity project.
- Copy one of the built-in templates (Default or Minimal) from [Unity Installation] > PlaybackEngines > WebGLSupport > BuildTools > WebGLTemplates.
- Rename the copied template to something meaningful for your project.
-
Copy the following files from the Passport package into your Assets > WebGLTemplates folder:
Packages/Immutable Passport/WebGLTemplates~/unity-webview.js
Packages/Immutable Passport/WebGLTemplates~/callback.html
Packages/Immutable Passport/WebGLTemplates~/logout.html
Packages/Immutable Passport/Runtime/Resources/index.html
>Passport/index.html
-
Add the following script tag to the
index.html
in WebGL Templates:<script src="unity-webview.js"></script>
Important
WebGL supports only PKCE flow.
Follow these steps for implementation:
Note
You can rename callback.html
and logout.html
to suit your project needs.
For local testing with WebGL builds, note the random port number assigned (e.g., http://localhost:60750). You may need to update the Hub Passport config each time you start a new local WebGL build, as the port number may change.
-
Define a deep link scheme for your game:
- Redirect URL: https://game.domain.com/callback.html
- Logout URL: https://game.domain.com/logout.html
-
Configure Immutable Hub:
- Login to Immutable Hub
- Add these deep links to your client's Redirect URLs and Logout URLs
-
Update Passport initialisation:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using Immutable.Passport;
public class InitPassport : MonoBehaviour
{
private Passport passport;
async void Start()
{
string clientId = "YOUR_IMMUTABLE_CLIENT_ID";
string environment = Immutable.Passport.Model.Environment.SANDBOX;
string redirectUri = "https://game.domain.com/callback.html";
string logoutRedirectUri = "https://game.domain.com/logout.html";
passport = await Passport.Init(clientId, environment, redirectUri, logoutRedirectUri);
}
}
- Go to File > Build Settings
- Select WebGL as the target platform
- Click "Build And Run"
- Choose a directory for the build output Your WebGL application will open in your default web browser once the build is complete.
For a complete working example, refer to the sample application in the SDK repository.