Autenticación de usuarios dentro del juego
Cómo funciona
Launcher envía los datos de los usuarios, autenticados a través de la aplicación de escritorio, al juego en el parámetro –xsolla-login-token
en el formato JWT. Puede utilizar este parámetro para establecer la autenticación automática de usuarios en el juego.
Principales notificaciones del JWT
Un token contendrá las notificaciones principales tras la autenticación o la confirmación de la dirección de correo electrónico. La presencia de estas notificaciones no depende de la base de datos de usuarios ni de la llamada de autenticación.
Reclamación | Tipo | Obligatorio | Descripción |
---|---|---|---|
exp | Unix Timestamp | Sí | Fecha y hora de expiración del token. El tiempo de expiración por defecto es de 24 horas. Puede cambiar el tiempo de expiración para cada proyecto de Login. |
iss | string | Sí | Servicio que firmó el token: https://login.xsolla.com . |
iat | Unix Timestamp | Sí | Fecha y hora de entrega del token. |
sub | string (UUID) | Sí | ID de usuario escrito en el lado del servidor de Xsolla Login. |
groups | array | Sí | La lista de grupos a los que pertenece el usuario. Cada grupo se escribe en el siguiente formato:
|
xsolla_login_project_id | string (UUID) | Sí | Identificación del proyecto de Login. |
username | string | Nombre de usuario. | |
publisher_id | integer | ID de un comerciante que pose un proyecto de Login. | |
email | string | Dirección de correo electrónico del usuario. | |
payload | string | Información adicional que se transmite en el parámetro de carga útil durante la autenticación. | |
promo_email_agreement | boolean | Consentimiento para recibir un boletín. Puede tener uno de los siguientes valores:
true por defecto.Para agregar la función al formulario de registro del widget de Login:
| |
connection_information | string | Muestra si el usuario confirmó o no su fecha de nacimiento. La confirmación se realiza a través del servicio okname. |
Autenticación a través de redes sociales
Notificaciones que contiene el token tras la autenticación a través de una red social. La presencia de estas notificaciones no depende de la base de datos de usuarios.
Reclamación | Tipo | Obligatorio | Descripción |
---|---|---|---|
provider | string | Sí | Nombre de la red social utilizada para la autenticación. Valores posibles: amazon , apple , baidu , battlenet , discord , facebook , github , google , kakao , linkedin , mailru , microsoft , msn , naver , ok , paypal , psn , qq , reddit , steam , twitch , twitter , vimeo , vk , wechat , weibo , yahoo , yandex , youtube y xbox . |
id | string | Sí | ID de usuario en una red social. |
is_cross_auth | boolean | Muestra que la solicitud de autenticación silenciosa está en curso. | |
social_access_token | string | Parámetro del access_token a la cuenta de red social utilizado para la autenticación. Contacte con su gestor del éxito del cliente o envíe un correo electrónico a csm@xsolla.com para establecer la función. | |
picture | string (URL) | Enlace a la foto de perfil del usuario en una red social. | |
birthday | date (RFC3339) | Fecha de nacimiento del usuario en una red social. | |
gender | string | Sexo/género de usuario en una red social. | |
name | string | Alias del usuario en una red social. |
Flujo del usuario
- Un usuario inicia sesión en el lanzador.
- El lanzador recibe el token de autorización con la información del usuario desde el servidor de Xsolla Login.
- El usuario inicia el juego desde el lanzador.
- Al iniciar el juego, el lanzador transmite los siguientes argumentos al cliente del juego:
--xsolla-login-token <token>
- el token de autorización obtenido del servidor de Xsolla Login.--xsolla-locale <locale>
- Idioma de la interfaz de usuario.
Ejemplo
game.exe --xsolla-login-token eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJlbWFpbCI6InAudHVnb2x1a292QHhzb2xsYS5jb20iLCJleHAiOjE1ODU1MDYxMTMsImdyb3VwcyI6W10sImlhdCI6MTU4NDY0MjExMywiaXNzIjoiaHR0cHM6Ly9sb2dpbi54c29sbGEuY29tIiwicGFydG5lcl9kYXRhIjp7ImFkbWluIjp0cnVlfSwicGF5bG9hZCI6IiIsInByb21vX2VtYWlsX2FncmVlbWVudCI6dHJ1ZSwicHJvdmlkZXIiOiJ4c29sbGEiLCJyZWRpcmVjdF91cmwiOiIiLCJzdWIiOiIyNmYxNzI5Ni00Nzk5LTExZTgtOTBkMC00MjAxMGE4YTAwMTkiLCJ0eXBlIjoic29jaWFsIiwidXNlcm5hbWUiOiJzb21lX3VzZXJAbWFpbC5jb20iLCJ4c29sbGFfbG9naW5fYWNjZXNzX2tleSI6Ikk2QTJrTEZPQ2JkcnUzamIxMjNyT3JmWnNkTnFpdVcxMjNpWTdKcW85OHI5b0hPbyIsInhzb2xsYV9sb2dpbl9wcm9qZWN0X2lkIjoiNDBkYjJlYTQtNWQ0Mi0xMWU2LWEzZmYtMDA1NDU2YTBlMTRhIn0.ZsTNiwY2iPp7HKqHs5g6JXzL2kv_RVuMNBlF-Tn2ccE --xsolla-locale en
- El cliente del juego envía el token de usuario obtenido al servidor del juego para recuperar los datos del usuario de una de las siguientes maneras:
Cómo conseguirlo
- Implemente la recuperación de datos del usuario:
- Establezca el procesamiento de parámetros para que el juego autentique a los usuarios automáticamente.
- Implemente la selección del idioma de la interfaz basándose en el idioma obtenido en el argumento
--xsolla-locale <locale>
en el cliente del juego. - Implemente el seguimiento de nuevos usuarios y la creación de sus cuentas en el servidor del juego.
Decodificar un JWT en el servidor del juego
- Abra su proyecto en Cuenta del editor y vaya a la sección Login.
- Haga clic en Configure en el panel de un proyecto de Login.
- Vaya al bloque Security y seleccione la sección JWT signature.
- Сopie el valor del campo Secret key.
- Elige la biblioteca y conéctela en el lado del servidor de su aplicación.
- Transmita el valor copiado en el paso 4 a la entrada de la función de decodificación.
Recuperación de datos del usuario mediante Login API
Llame al método Get user detailsde Login API para recuperar los datos del usuario.
Registro de usuarios
Para realizar un seguimiento del registro de nuevos usuarios:
- Abra su proyecto en Cuenta del editor y vaya a la sección Login API.
- Haga clic en Configure en el panel de un proyecto de Login.
- En el bloque de configuración superior, haga clic en Callback URLs.
- En el campo Callback URLs, introduzca la dirección URL a la que se debe redirigir al usuario tras el registro.
- Configure la creación de una nueva cuenta en el juego. Tras el registro, el usuario será redirigido a la URL especificada en el campo Callback URL con el parámetro
is_new=1
. - Para obtener información para rellenar la cuenta, utilice el método Login API.
Ejemplo
https://<callbackUrl>?is_new=1&token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWR
Idioma de la interfaz de usuario
Example | Value | Meaning |
---|---|---|
–xsolla-locale en | “en”“ru”“cn”“tw”“fr”“de”“it”“pt”“es”“pl”“cs”“ko”“ar”“bg”“he”“ja”“tr”“th”“vi”“ro” | “English”“Русский”“简体中文”“中国传统的”“Français”“Deutsch”“Italiano”“Português”“Español”“Polski”“Čeština”“한국어”“العربية”“Български”“עברית”“日本語”“Türkçe”“ไทย”“Tiếng Việt”“Română” |
¿Te ha resultado útil este artículo?
Valore esta página
Prefiero no responder
¡Gracias por tu mensaje!
¿Has encontrado una errata u otro error de texto? Selecciona el texto y pulsa Ctrl+Intro.