Skip to main content

Get Started

LEVEL INFINITE PASS provides streamlined UI and user authentication process for games. This article guides you on how to integrate LEVEL INFINITE PASS.

Prerequisites

  1. Set up your game on Player Network Console
  2. Integrate the SDK

Set up for game client

Step 1: Import LI PASS resources

Engine Version

Unity 2021.3.33f1 - Unity 2022

note

The directory StreamingAssets/LevelInfinite is used for Player Network SDK V1.20.01 and later, while the directory StreamingAssets/INTLGameNative is used for Player Network SDK V1.20.00 and earlier.

  1. Copy the LevelInfinite, Plugins and StreamingAssets/LevelInfinite folders to the Assets folder of the project first, then import them to Unity.

    Image: LevelInfinite File Structure

    FolderDescription
    LevelInfiniteLI PASS engine layer code
    PluginsLI PASS plugins
    StreamingAssets/LevelInfiniteLI PASS resources, can be hotfixed
2. [Optional] Remove assembly from the project.

Assembly support has been added to LI PASS since V1.08. If assembly is not required for your project, follow the below steps to remove assembly:

  1. Delete the below Assembly Definition files. Delete Assembly Definition
  2. Edit luaSvr.cs, changing the assembly name from LevelInfinite to Assembly-CSharp. Edit assembly name
  3. Contact the Player Network representative for a new AssetBundle package without assembly.
  1. In Unity's menu, select INTLLua > All > Clear to delete the Assets/LevelInfinite/INTLGameNative/Scripts/LuaObject directory.
    A prompt to generate the Lua interface for Unity appears automatically if the deletion is successful. Otherwise, in Unity's menu, select INTL > INTLLua > All > Make to trigger the popup manually.

    Image: INTLLua menu

  2. From the popup, click Generate to generate the interfaces exported from C# to Lua.

    Image: INTLLua popup

  3. Check if the interface files have been successfully generated in the Assets/LevelInfinite/INTLGameNative/Scripts/LuaObject directory.

    Image: INTLLua directory

    note

    If Custom and Unity folders appear in the directory, the files have been successfully generated.

    • Custom folder: Custom class interfaces exported to Lua.
    • Unity folder: Unity engine class interfaces exported to Lua.
6. [Optional] Switch loading modes.

The default loading mode is Editor, which may be changed to StreamingAssets mode during the development process, and CDN mode for packaging before publishing.

note

Using the StreamingAssets mode when publishing may cause Player Network Console resources to be unable to load, affecting the hot update capabilities of the console as a result. As such, switch the loading mode to CDN before packaging.

In the menu, select the loading mode from LevelInfinite > AssetLoadMode.

Image:LevelInfinite menu

ModeDescription
EditorCorresponds to the INTL_DEBUG_LUA macro, reads a local Lua file
StreamingAssetsCorresponds to the INTL_USE_LOCAL_ASSETS macro, loads the AssetBundle from StreamingAssets
CDNCorresponds to the AssetBundle from Player Network Console, if the loading of resources fails then AssetBundle from StreamingAssets is loaded instead
7. [Optional] Configure your project for console games developed using Unity.
  1. Install and activate the Input System package:

    note

    Input System requires Unity 2019.1 or later versions and .NET Framework 4 to work. It does not work with projects running .NET Framework 3.5.

    Input System version 1.6.1 must be installed along with the expansion pack com.unity.inputsystem.gxdk-1.0.1 on the Xbox Series X|S (XSX) running the game. For any issues regarding the installation, reach out to the Player Network representative.

    For more information, see Input System Installation Guide.

    1. In Unity's top menu, go to Window > Package Manager to open the Unity Package Manager.

    2. Click Advanced, make sure that Show Preview Packages has been enabled.

    3. From the list of packages on the left, select the latest Input System package, then click Install.

      Image:Introducing InputSystem

    4. In Unity's top menu, go to Edit > Project Settings, then click Player.

    5. Set the value of Active Input Handling to Input System Package (New).

      Image:Setting Active Input Handling

  2. Add scripting define symbols:

    1. In Unity's top menu, go to Edit > Project Settings, then click Player.

    2. Open the Other Settings panel, then navigate to Scripting Define Symbols.

    3. Add INTL_CONSOLE_GAME_INPUT to the textbox, separated by semicolons.

      Image:Add INTL_CONSOLE_GAME_INPUT macro definition

Step 2: Configure LI PASS

Developers can choose between using the editor window to configure LI PASS, or editing the INTLConfig.ini file directly after opening it from the project directory. The steps below show how LI PASS can be configured easily by using the editor window.

To know more about each configuration item, either select the item in the editor window to display a brief description, or see LI PASS Client Configurations for a list of all configuration items.

note

For configuration changes to take effect in the editor at runtime, you need to restart the engine. Otherwise, it will take effect automatically when building an installation package.

  1. In Unity's menu, select INTL > LI INIConfig Window to open the editor window for LI PASS configurations.

    Image: INTLLua menu Image: INTLLua menu

  1. Set the ACCOUNT_SDK_KEY and ACCOUNT_APP_ID to the values assigned by Player Network Console.

    note

    For versions before LI PASS V1.16, set ACCOUNT_URL to https://test-pass.intlgame.com to define the LI PASS environment.
    For LI PASS V1.16 or later, this configuration is optional.

  2. Specify the third-party login channels for the designated platform.
    For example, ACCOUNT_THIRD_CHANNEL_ANDROID = Facebook,Google.

    For a complete list of configurations, see Configs.

4. [Optional] To obtain the email of players during third-party channel login.

Set up permissions to obtain the email address of players during third-party channel login.

  • Email masking can be performed on the returned email according to compliance requirements, reach out to the Player Network representative to enable this feature.
  • The hashed base64(sha256(email)) can be reported to the backend logs, reach out to the Player Network representative to enable this feature.
  • Can be used to verify if email is present in a player's profile or third-party channel information, reach out to the Player Network representative to enable this feature.
  • Can be used to enable Private Set Membership (PSM) for Firebase on iOS, see Firebase iOS configurations for more details.

The third-party channels below support returning player email address:

Apple

note

Player authorization is required to obtain the email address for Apple, and will not be available if player authorization is refused, see Passing email and fullName to the Login API for more information.

  1. From the editor window, add the email permission to APPLE_LOGIN_PERMISSION under [Dynamic].

  2. Enable email return on Player Network Console by setting return_email to YES, see Configure Third-party Channels for detailed procedures.

Google

Enable email return on Player Network Console by setting return_email to YES, see Configure Third-party Channels for detailed procedures.

Facebook

  1. From the editor window, add the email permission to FACEBOOK_LOGIN_PERMISSION under [Dynamic]. If FACEBOOK_LOGIN_PERMISSION is not present within INTLConfig.ini, the email permission will be added automatically.

  2. Configure the email permission on Meta for Developers. The email permission requires Advanced access, in order for all apps to be able to obtain player email.

    Image: Facebook permission request

  3. Enable email return on Player Network Console by setting return_email to YES, see Configure Third-party Channels for detailed procedures.

Twitter

  1. Under User authentication settings in the Twitter Developer Platform, enable Request email from users.

    Image: OAUTH1.OA SETTINGS
  2. Enable email return on Player Network Console by setting return_email to YES, see Configure Third-party Channels for detailed procedures.

Step 3: Initialize LI PASS

After initializing the SDK during the game's startup process, invoke InitLIP to initialize the LI PASS login widget. The initialization process first checks for any available hotfixes for the current resource version. If available, it downloads the resources for the newer version, and subsequently loads the latest resources. Upon completion of the loading process, the initialization is deemed complete and it triggers the GN_READY event. This event is then processed by the LI PASS callback function.

Font font = GetFont();
LevelInfinite.InitLIP(font, Application.version, "en");

Step 4: Handle LI PASS events

note

Do not handle any internal callback events for LI PASS, as it may interrupt the LI PASS callback process and cause login exceptions.

Follow the below example to handle LI PASS callback events, such as OpenLoginPanel and AutoLogin.

Developers need to add AuthResultObserver, AuthBaseResultObserver, and LIEventObserver to receive login callback and callback for opening or closing the LI PASS login widget. The callback data structure is INTLAuthResult, which includes login information and account information, such as OpenID, account linking information, and account deletion status.

// Add callbacks
public void AddAuthBaseObserver()
{
INTLAPI.AddAuthBaseResultObserver(OnAuthBaseResultEvent);
}

// Remove callbacks
public void RemoveAuthBaseObserver()
{
INTLAPI.RemoveAuthBaseResultObserver(OnAuthBaseResultEvent);
}

// Add callbacks
public void AddAuthObserver()
{
INTLAPI.AddAuthResultObserver(OnAuthResultEvent);
}

// Remove callbacks
public void RemoveAuthObserver()
{
INTLAPI.RemoveAuthResultObserver(OnAuthResultEvent);
}

// Handle AuthResultObserver callback result
private void OnAuthResultEvent(INTLAuthResult AuthResult)
{
switch (AuthResult.MethodId)
{
// LI PASS third channel / LI channel enter game
case (int)INTLMethodID.LI_LOGIN_ENTER_GAME:
if(AuthResult.RetCode == (int)ERROR_CODE.SUCCESS) {
Debug.Log("LI PASS Login success");
} else {
Debug.Log("LI PASS Login failed, ret_code = " + AuthResult.RetCode + ", ret_msg = " + AuthResult.RetMsg);
LevelInfinite.OpenLoginPanel();
}
break;
// LI PASS autologin enter game
case (int)INTLMethodID.LI_AUTOLOGIN_ENTER_GAME:
if(AuthResult.RetCode == (int)ERROR_CODE.SUCCESS) {
Debug.Log("LI PASS Autologin success");
} else {
Debug.Log("LI PASS Autologin failed, ret_code = " + AuthResult.RetCode + ", ret_msg = " + AuthResult.RetMsg);
LevelInfinite.OpenLoginPanel();
}
break;
default:
break;
}
}

// Process the INTLBaseResult callback
public void OnAuthBaseResultEvent(INTLBaseResult ret)
{
Debug.Log($"MethodID: {ret.MethodId}");

string methodTag = "";
if (ret.MethodId == (int)INTLMethodID.INTL_AUTH_LOGOUT)
{
methodTag = "Logout";
}
ShowLogInNewLine(methodTag + Tools.Instance.GetRetString(ret));
}

// Add callbacks
LevelInfinite.AddLIEventObserver(OnLIBaseEventResult);
// Handle LIEventObserver callback result
private void OnLIBaseEventResult(LIBaseEventResult liRet)
{
Debug.Log("<color=#ff00ff>OnLIBaseEventResult. lIEventType : " + Enum.GetName(typeof(LIEventType), liRet.lIEventType) + ", extraJson:" + liRet.extraJson + "</color>");
ShowLogInNewLine("OnLIBaseEventResult. lIEventType : " + Enum.GetName(typeof(LIEventType), liRet.lIEventType) + ", extraJson:" + liRet.extraJson);
switch (liRet.lIEventType)
{
// LI PASS Init Finish
case LIEventType.GN_READY:
// LevelInfinite.AutoLogin()
// LevelInfinite.OpenLoginPanel()
break;
// LI PASS Panel Open
case LIEventType.LIP_PANEL_OPEN:
break;
// LI PASS Panel Close
case LIEventType.LIP_PANEL_CLOSE:
break;
// LI PASS Open Login Panel
case LIEventType.OPEN_LOGIN:
break;
// LI PASS Close Login Panel
case LIEventType.CLOSE_LOGIN:
break;
// LI PASS Open Account Center
case LIEventType.OPEN_ACCOUNT_CENTER:
break;
// LI PASS Close Account Center
case LIEventType.CLOSE_ACCOUNT_CENTER:
break;
// LI PASS Close Delete Account Panel
case LIEventType.CLOSE_DELETE_ACCOUNT:
break;
// LI PASS Close Parent Certificate Panel
case LIEventType.CLOSE_PARENT_CERTIFICATE:
break;
// LI PASS Close Parent Tip Panel
case LIEventType.CLOSE_PARENT_TIP:
break;
// LI PASS Close Parent Deny Panel
case LIEventType.CLOSE_PARENT_DENY:
break;
// LI PASS Init Repeat
case LIEventType.GN_REPEAT:
break;
// LI PASS Closed
case LIEventType.GN_DISABLED:
break;
default:
break;
}
}
// Remove callbacks
LevelInfinite.RemoveLIEventObserver(OnLIBaseEventResult);

Developers can also add an optional LILuaErrorObserver to handle lua errors.

Step 5: Set the language of LI PASS user interface

Call SetLanguage with the language code as the input parameter to set the language used in all LI PASS user interfaces and emails. It's recommended to align this setting with the game's language to ensure consistency. Otherwise, the language used in LI PASS interfaces and emails may differ from the game's language.

LevelInfinite.SetLanguage("zh-Hans");

Step 6: Set the LI PASS UI root

Call the SetUIRoot method to establish the root for all LI PASS interfaces before calling any other LI PASS functions.

note

Once the UI root node is set, avoid deleting it. Doing so could prevent the LI PASS UI interface from mounting, leading to unexpected behavior.

The LI PASS UI should be released via UI buttons and not force destroyed. If garbage collection (GC) is controlled by Unity when switching scenes, a null pointer error may occur.

For more details regarding the canvas resolution, see SetUIRoot.

LevelInfinite.SetUIRoot(uiRoot);

Step 7: Set the country/region

The LI PASS login widget adheres to its default compliance workflow, requiring developers to call the UpdateCountryList method with two input parameters: the allowList and blockList arrays. The allowList array should contain ISO 3166-1 numeric codes representing the countries or regions to be displayed on the LI PASS country or region selection page, while the blockList array should contain codes for countries or regions that should not be displayed.

The countries and regions specified here will be utilized in the login widget during the compliance workflow which is entirely handled by the login widget itself.

string[] allowArray = new string[] {"496","400"};
string[] blockArray = new string[] {"400"};

LevelInfinite.UpdateCountryList(allowArray,blockArray);

Step 8: Add LI PASS functions to the game client

  • Login Widget
    Add the LI PASS login widget, which supports features such as account registration, login, logout, and access to the account center.

  • Reward
    Configure reward events for the game.

In-game account link for Console platforms on Unreal Engine
caution

The in-game account link function is only for use in console platforms running on Unreal Engine, and is not required for other platforms.

Use this function to display a popup to link with LI PASS within the game.

// Add callback
AuthResultObserver = UINTLSDKAPI::GetAuthResultObserver().AddUObject(this, &UFloatingSidebar::OnAuthResult_Callback);

// Query user bind info
UINTLSDKAPI::QueryBindInfo();

// handle callback
void UFloatingSidebar::OnAuthResult_Callback(FINTLAuthResult AuthResult)
{
UE_LOG(LogTemp, Warning, TEXT("UFloatingSidebar::OnAuthResult_Callback AuthResult.MethodId: %d"),AuthResult.MethodId);
if(AuthResult.MethodId == (int32)LIMethodId::kLIQueryBindInfo) {
if(AuthResult.RetCode == INTL_NAMESPACE::ErrorCode::SUCCESS)
{
UE_LOG(LogTemp, Warning, TEXT("LI query bind info success bindlist = %s"), *AuthResult.BindList);
TArray <TSharedPtr<FJsonValue>> bindInfoArray;
TSharedRef<TJsonReader<TCHAR>>jsonReader = TJsonReaderFactory<TCHAR>::Create(AuthResult.BindList);
bool isSe = FJsonSerializer::Deserialize(jsonReader, bindInfoArray);
if (isSe)
{
UE_LOG(LogTemp, Warning, TEXT("LI query bind info format JsonObject success"));
bool haveBindLI = false;
FString liEmail;
for(int i = 0; i < bindInfoArray.Num(); i++)
{
int32 channelId = bindInfoArray[i]->AsObject()->GetIntegerField("channelid");
FString email = bindInfoArray[i]->AsObject()->GetStringField("email");
UE_LOG(LogTemp, Warning, TEXT("LI query bind info channelId = %d, email = %s"), channelId, *email);
if(channelId == (int32)EINTLLoginChannel::kChannelLevelInfinite) {
haveBindLI = true;
liEmail = email;
break;
}
}
if(!haveBindLI) {
// open link account in game panel
ULevelInfiniteAPI::OpenBindAccount();
} else {
// account already linked to LI PASS
UE_LOG(LogTemp, Warning, TEXT("Account have bind LI"));
}
} else {
UE_LOG(LogTemp, Warning, TEXT("LI query bind info format JsonObject failed"));
}
}else{
UE_LOG(LogTemp, Warning, TEXT("LI query bind info failed, ret_code = %d, ret_msg = %s"), AuthResult.RetCode, *AuthResult.RetMsg);
// token unavailable
FINTLAuthResult CurrentAuthResult;
if (UINTLSDKAPI::GetAuthResult(CurrentAuthResult)) {
EINTLLoginChannel channel = static_cast<EINTLLoginChannel>(CurrentAuthResult.ChannelID);

if (channel == EINTLLoginChannel::kChannelPS5) {
FString permissions = "psn:s2s openid id_token:psn.basic_claims";
ULevelInfiniteAPI::LoginChannelWithLIPass(channel, permissions, "{}");
} else if (channel == EINTLLoginChannel::kChannelXbox) {
ULevelInfiniteAPI::LoginChannelWithLIPass(channel, "", "{}");
} else {
ULevelInfiniteAPI::LoginChannelWithLIPass(channel, "", "{}");
}
}
}
}
}

Sample image:

Image: BIND_LI_IN_GAME

Set up for the website

note

Player Network Console is recommended to be used for the configuration of LI PASS Web SDK, see the web configurations in Configure LI PASS for more details.

Step 1: Import the JavaScript SDK

Install the JavaScript SDK from CDN.

// SDK Test Version Package
<script src="https://test-common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.umd.js"></script>
<link rel="stylesheet" href="https://test-common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.css" />


// SDK Production Version Package
<script src="https://common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.umd.js"></script>
<link rel="stylesheet" href="https://common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.css" />

Step 2: Configure LI PASS in Player Network Console

For detailed configuration steps, see Configure LI PASS. After completing login configurations for web, the WEB_ID will be available after publishing.
Image: get web id

note

Multiple LI PASS web configurations can be created in Player Network Console, for use in different web scenarios.

Step 3: Instantiate the JavaScript SDK

Import the JS and CSS resources.

<script src="https://test-common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.umd.js"></script>
<link rel="stylesheet" href="https://test-common-web.intlgame.com/sdk-cdn/infinite-pass/latest/index.css" />
<!-- For the production environment, please use the production version sdk -->

<!-- mount node -->
<div id="infinite-pass-component"></div>

Instantiate the SDK.

const pass = new PassFactory.Pass({
env: "test", // For production environment, reach out to the Player Network representative
gameID: xxxxx, // GAME_ID configured in Player Network Console
appID: "", // APP_ID configured in Player Network Console
webID: "", // WEB_ID in Player Network Console

config: {}, // required if webID is not provided, not required if webID is provided
});

For more details on initialization parameters and other advanced configurations, see Web Widget Configurations.

note

If configurations for LI PASS web have been completed in Player Network Console, the WEB_ID can be passed during code initialization, with support for real-time modifications.
Else, if web configurations have not been completed in Player Network Console, manually configure config in the code according to LI PASS Web Configurations.

Step 4: Add LI PASS login / registration to the website

The LEVEL INFINITE PASS web login widget supports both LEVEL INFINITE PASS login and third-party channel login.

After instantiating the pass component, call the Start method to mount the LI PASS web login widget to the specified DOM node. After a successful login, the login result will be returned in intlSignResp.

After successful login/registration, the UI of the component is not changed automatically and requires manual handling. For example, storing the login information in a cookie or the localStorage, then navigate the UI to the successful login page.

For more information about customizing the login widget, see Web

<div id="infinite-pass-component"></div>
const pass = new PassFactory.Pass({
env: "test", // Environment
gameID: xxxxx, // GAME_ID configured in Player Network Console
appID: "", // APP_ID configured in Player Network Console
webID: "", // WEB_ID in Player Network Console
})

// Call `Start` to mount the login widget to the specified DOM node
// After a successful login, the login result is returned in the `onLogin` and `onRegister` events.
pass.start("#infinite-pass-component")

// You should listen to the events and obtain the user's authentication information when the user completes login or registration.
pass.on("onLogin", (userInfo) => {
// After the user fails to log in, the 'onLoginError event' will be triggered, and the game logic after the user successfully logs in, can be processed in the event callback
// For example, redirect to a specific page
console.log(userInfo);
});

pass.on("onRegister", (userInfo) => {
// Logic added after successful registration
// For example, redirect to a specific page
console.log(userInfo);
});

Return parameters

ParameterTypeDescription
retnumberReturn code
0: Request success
!=0: Request failure, see msg for detailed return message
msgstringResult description
tokenstringPlayer Network SDK generated user authorization token
length 40 bytes, see Token
openidstringPlayer Network SDK unique user ID
Default is a string of 64-bit unsigned integers, 32-bit is also supported
token_expire_timeint64Token expiration time
Unix time
user_namestringUsername used for login
channel_infoobjectChannel information for the current channel.
For more information, see Channel Information.
del_account_statusnumberAccount deletion status
-1: Query failure
0: No record of revoking Player Network account deletion request (including email account and phone account)
1: Cooling-off period for deletion
2: Account deletion completed
3: Account deleted
4: Account deletion failed
seqstringSequence number of the message in the data stream
first_loginnumberWhether the current login is the first login
Unknown: -1
No: 0
Yes: 1

Return sample

{
channel_info:{
account:"wuqinghao@outlook.com",
account_plat_type: 131,
account_type: 1,
channelId: 131
},
del_account_status: 0,
first_login: 0,
msg: "success",
need_name_auth: false,
openid: "xxx",
ret: 0,
seq: "1638194026-0180225310-032531-0000292460",
token: "xxx",
token_expire_time: 1638494026,
user_name: "user",
}

Step 5: Add third-party channel login to the website

caution

LI PASS web login for third-party channels is only supported for the system browser, and is not supported for the built-in WebView component of any game or app:

  • Based on security concerns, Google and Facebook has prohibited the use of built-in WebView for web login.
  • The WebView component cannot load two pages at the same time, and therefore the third-party login page cannot be loaded to complete the login process.

The LI PASS web login widget currently supports Apple, Discord, Epic, Facebook, Google, LINE, PS5, Steam, Twitch, Twitter, VK, QQ, Wechat.

Configure the third-party channels for login in Player Network Console, changing the channels to be displayed in real-time. For detailed configuration steps, see Login channels for web.

Method 2: Configure with code

<div id="infinite-pass-component"></div>
const pass = new PassFactory.Pass({
env: "test", // Environment
gameID: xxxxx, // GAME_ID configured in Player Network Console
appID: "", // APP_ID configured in Player Network Console

config: {
socialList: ['facebook', 'twitter']
}
});

// Call the `start` method to mount the login enabler to the specified DOM node
pass.start("#infinite-pass-component");

// You can listen to a list of events to get information about a user's credentials when they log in or register.
pass.on("onLogin", (userInfo) => {
// After the user fails to log in, the 'onLoginError event' will be triggered, and the game logic after the user successfully logs in, can be processed in the event callback
// For example, redirect to a specific page
console.log(userInfo);
});

pass.on("onLoginError", (userInfo) => {
// The 'onLogin event' will be triggered after the user successfully logs in, and the game logic after the user fails to log in, can be processed in the event callback.
console.log(userInfo);
});

Key configuration parameters

ParameterTypeDescriptionRemarks
socialListstring[]Channel list, see config for detailed configurations.Optional
socialParamsobjectConfiguration required when logging in through three-party channels, see socialParams for detailed configurations.Optional

Return parameter

ParameterTypeDescription
retnumberReturn code
0: Request success
!=0: Request failure, see msg for detailed return message
msgstringResult description
tokenstringPlayer Network SDK generated user authorization token
length 40 bytes, see Token
openidstringPlayer Network SDK unique user ID
Default is a string of 64-bit unsigned integers, 32-bit is also supported
token_expire_timeint64Token expiration time
Unix time
user_namestringUsername used for login
channel_infoobjectChannel information for the current channel.
For more information, see Channel Information.
del_account_statusnumberDelete account
-1: Query failure
0: No record of cancellation of Player Network account deletion request (including email account and phone account)
1: Cooling-off period for deletion
2: Account deletion completed
3: Account deleted
4: Account deletion failed
seqstringData stream message sequence number

Return sample

{
channel_info: {
access_token:"xxxxx",
expire_ts: 1641527900,
}
first_login: 0,
msg: "success",
need_name_auth: false,
openid: "xxxx",
picture_url: "https://www.google.com/Images/profileA.png",
ret: 0,
seq: "1638935899-1006943754-018668-0000656615",
token: "xxx",
token_expire_time: 1641527900,
del_account_status: 0,
user_name: "user",
}

Step 6: Implement authentication state retention

When using the LI PASS web login widget, you can customize how the authentication state is retained by varying how the information is being stored:

  • Retain authentication state indefinitely (stored in cookie or localStorage) for logged in users, until explicitly logged out
  • Clear authentication state when window is closed (stored in sessionStorage)
  • Clear authentication state on page reload (not stored)

The below table lists the user credentials to be stored, which can be obtained by listening to the onLogin and onRegister events.

ParameterTypeRead method
openidstringuserInfo.openid
tokenstringuserInfo.token
channelIdstringuserInfo.channel_info.channelId

Disable default behavior

After logging in using the LI PASS web login widget, the authentication state is automatically stored in the logined_account_cache_key cookie. To avoid overreliance on this cookie, instead handle authentication state retention by storing the user credentials in the localStorage or sessionStorage.

To disable this default behavior, set the following when initializing the widget:

const pass = new PassFactory.Pass({
env: "", // Environment
gameID: "", // Game ID
appID: "", // LI PASS App ID

config: {
disableCookie: true
}
});

API list

Method nameDescription
startInitialize LI PASS web login widget
unmountUnmount/close LI PASS web login widget
changeLanguageSwitch language, see Language list for a list of supported languages
onMonitor events, see Event list for a list of supported events
preOrderMethod to preregister on LI PASS

unmount

Calling the unmount method will unmount the LI PASS web login widget from the DOM.

changeLanguage

Switch the login widget language by calling the changeLanguage method, if the passed language parameter is not supported yet, the default language en will be displayed.

Language list
CodeLanguage type
arArabic
csCzech
deGerman
enEnglish
esSpanish (Latin America)
es-euSpanish (Europe)
fiFinnish
fil-PHFilipino
frFrench
hiHindi
idIndonesian
itItalian
jaJapanese
koKorean
msMalay
nlDutch
plPolish
ptPortuguese (Latin America)
ruRussian
thThai
trTurkish
viVietnamese
zh-HantChinese (Traditional)
zh-HansChinese (Simplified)
zh-TWChinese (Taiwan)
Sample
// Switch login widget language to Italian
pass.changeLanguage("it");

on

Call the on method of the pass component to register a callback event handler. When the user operates on the LI PASS web login widget, the component will callback the event at the corresponding time.

note

The event needs to be registered before the user triggers the corresponding event.

Sample
pass.on("onLogin", (userInfo) => {
// After the user fails to log in, the 'onLoginError event' will be triggered, and the game logic after the user successfully logs in, can be processed in the event callback
// For example, redirect to a specific page
console.log(userInfo);
});

pass.on("onLoginError", (userInfo) => {
// The 'onLogin event' will be triggered after the user successfully logs in, and the game logic after the user fails to log in, can be processed in the event callback.
console.log(userInfo);
});

pass.on("onRegister", (userInfo) => {
// Logic added after successful registration
// For example, redirect to a specific page
console.log(userInfo);
});
Event list
Method nameDescriptionCallback parameters
onLoadLoad rendered componentaccountApi
onCloseClose component by clicking the close button while in modal modeaccountApi
onLoginLogin successfuluserInfo, accountApi
onLoginErrorLogin failederror
onLoginTabChangeTab switch on login widgetactiveTab
onRegisterRegistration successfuluserInfo, accountApi
onRegisterErrorRegistration failederror
onPwdResetReset password successfulaccountApi
onPwdResetErrorReset password failederror, accountApi
onPreOrderPreregistration successfulresult
onPreOrderErrorPreregistration failedresult

preOrder

Use the preOrder method to preregister users, preregistered users do not have to register again after downloading the game. This can be used to collect valid email addresses from your users to achieve greater effective reach.

Parameters
ParameterTypeDescriptionRemarks
apiKeystringUse the same gameid to apply for an apiKey in SmartlinkRequired
tagsstring[]Add custom tags to contacts in SmartlinkOptional
Sample
const pass = new PassFactory.Pass({
env: "", // Environment
gameID: "", // Game ID
appID: "", // LI PASS App ID

config: {
langType: 'en' // Defaults to 'en', change this configuration to change the default language
}
});


// Call the `preOrder` method to display the preregistration component
pass.preOrder({
apiKey: 'xxxxxxxxx',
tags: ['tag1', 'tag2'],
})