GuestLogin
public BackendReturnObject GuestLogin();
public BackendReturnObject GuestLogin(string etc);
Parameter
Value | Type | Description |
---|---|---|
etc | string | (Optional) Information you wish to save in addition |
Description
BACKND SDK provides the guest login function utilizing the custom (ID/password) account function.
- Guest login accounts can be changed into Google/Apple/Facebook federation account.
- Guest login accounts can perform token login.
- Guest accounts log in based on the locally stored account information.
- When local data deletion, app re-installation, device change, or local data damage occurs, the user cannot attempt guest login using the given account.
- Even if the locally saved account information is deleted, the user data stored in the server remains.
- BACKND does not provide separate login methods for guest accounts that have been restricted due to the deletion of locally saved account information.
- The console does not provide the function to change ID/password of the guest login account.
- Services such as data restoration and data transfer are not provided for guest accounts.
- In case of local data deletion, app re-installation, device change, or local data damage, please make sure to notify the user that access to the guest account will not be available.
- When email information is registered in the guest account, you can send a password initialization mail. With this email, password initialization will be available. However, if the password is initialized, the password of the guest account in SDK and the password of the actual account will differ.
In this case, the user may log in only via a custom login.
Guest login
When the guest login method is called, the existence of guest account information stored locally in the device is checked.
The way of handling the method varies depending on whether the system has guest account information or not.
- The ID of a guest account is generated in the format of guest-0514db55-6bd3-46f3-a4dd-0cc5a57ddf53.
- guest- is a value that indicates that the account is a guest.
- The suffix string is a UUID value that is not duplicated.
- A guest account is regarded as a custom sign-up account. In BACKND Console, the type of sign-up is also displayed as customSignUp.
When guest account information exists in the device
A custom login is performed using the stored guest account.
When guest account information does not exist in the device
A custom sign-up is performed by creating an ID that does not match with another user.
When the sign-up succeeds, guest account information is stored in the device locally using BACKND file system function.
Example
Synchronous
BackendReturnObject bro = Backend.BMember.GuestLogin("Logged in using guest login");
if(bro.IsSuccess())
{
Debug.Log("Guest login successful");
}
Asynchronous
Backend.BMember.GuestLogin("Logged in using guest login", (callback) => {
if (callback.IsSuccess()) {
Debug.Log("Guest login successful");
}
});
SendQueue
SendQueue.Enqueue(
Backend.BMember.GuestLogin,
"Logged in using guest login",
(callback) => {
if (callback.IsSuccess()) {
Debug.Log("Guest login successful");
}
}
);
ReturnCase
Success cases
When the guest login is successful
statusCode : 200
errorCode : Success
When the guest sign-up is successful
statusCode : 201
errorCode : Success
Error cases
When the device information is 'null'
statusCode : 400
errorCode : UndefinedParameterException
message : undefined device_unique_id, device_unique_id cannot be checked
When the ID does not exist (when local data has been tampered)
statusCode : 401
errorCode : BadUnauthorizedException
message : bad customId, Invalid customId
When a guest login was attempted after changing the guest account to a federation account
statusCode : 401
errorCode : BadUnauthorizedException
message : bad customId, Invalid customId
When the user is blocked
statusCode : 403
errorCode : The reason for blocking entered in the console
message : Forbidden blocked user, Blocked user
code : 403100
errorMessage : 757fe1d0-03af-11ef-bda5-fd24a5f141c1 blocked until 2024-11-29T12:41:19.465Z
errorData : {
uuid : 757fe1d0-03af-11ef-bda5-fd24a5f141c1
nickname : Nickname
blockReason : The reason for blocking entered in the console
blockDate : 2024-11-29T12:41:19.465Z
}
If the user is blocked, you can check the following error data.
- Code : Unique ID for the error case
- ErrorMessage : Details of that error
- ErrorData : Detailed data related to the error (if nickname and blockReason do not exist, data cannot be parsed.)
Error use example
var callback = Backend.BMember.CustomLogin("a0", "a0");
Debug.Log(
if (callback.GetMessage().StartsWith("Forbidden blocked user"))
{
StringBuilder returnString = new StringBuilder();
returnString.Append("StatusCode : ").Append(callback.GetStatusCode()).AppendLine();
returnString.Append("ErrorCode : ").Append(callback.GetErrorCode()).AppendLine();
returnString.Append("Message : ").Append(callback.GetMessage()).AppendLine();
returnString.Append("Code : ").Append(callback.GetCode()).AppendLine();
returnString.Append("ErrorMessage : ").Append(callback.GetErrorMessage()).AppendLine();
returnString.Append("errorData(uuid) : ").Append(callback.GetErrorData()["uuid"].ToString()).AppendLine();
if (callback.GetErrorData().ContainsKey("nickname"))
{
returnString.Append("errorData(nickname) : ").Append(callback.GetErrorData()?["nickname"].ToString()).AppendLine();
}
if (callback.GetErrorData().ContainsKey("blockReason"))
{
returnString.Append("errorData(blockReason) : ").Append(callback.GetErrorData()?["blockReason"].ToString()).AppendLine();
}
returnString.Append("errorData(blockDate) : ").Append(callback.GetErrorData()["blockDate"].ToString()).AppendLine();
Debug.Log(returnString.ToString());
}
)
When the device is blocked
statusCode : 403
errorCode : ForbiddenException
message : Forbidden blocked device, Blocked device
code : 403100
errorMessage : 20240426092307fc5ac478c is blocked
errorData : {
deviceUniqueId : 20240426092307fc5ac478c
}
If the device is blocked, you can check the following error data.
- Code : Unique ID for the error case
- ErrorMessage : Details of that error
- ErrorData : Detailed data related to the error
Error use example
var callback = Backend.BMember.CustomSignUp("a0", "a0");
Debug.Log(
if (callback.IsDeviceBlockError())
{
StringBuilder returnString = new StringBuilder();
returnString.Append("StatusCode : ").Append(callback.GetStatusCode()).AppendLine();
returnString.Append("ErrorCode : ").Append(callback.GetErrorCode()).AppendLine();
returnString.Append("Message : ").Append(callback.GetMessage()).AppendLine();
returnString.Append("Code : ").Append(callback.GetCode()).AppendLine();
returnString.Append("ErrorMessage : ").Append(callback.GetErrorMessage()).AppendLine();
returnString.Append("errorData(deviceUniqueId)").Append(callback.GetErrorData()["deviceUniqueId"].ToString()).AppendLine();
Debug.Log(returnString.ToString());
}
)
When withdrawal is in progress (after calling the WithdrawAccount method)
statusCode : 410
errorCode : GoneResourceException
message : Gone user, This user does not exist