Recuperación de sesiones
Por defecto, el SDK requerirá que los usuarios inicien sesión cada vez que la aplicación se cierre completamente. Esto se debe a que, por defecto, no guardamos la información de la wallet de sesión (por ejemplo, claves privadas) en ningún tipo de almacenamiento persistente para proteger la seguridad del usuario. Sin embargo, en ciertas plataformas, hemos integrado el almacenamiento seguro nativo de la plataforma. Si habilitaStoreSessionPrivateKeyInSecureStorage en su ScriptableObject SequenceConfig, almacenaremos automáticamente la información de la wallet de sesión por usted (en plataformas compatibles) y expondremos la opción de intentar recuperar la sesión en SequenceLogin. El LoginPanel predeterminado también gestionará automáticamente el flujo de UI para esto (vea Autenticación). Si la plataforma no es compatible, esta opción no tendrá efecto.
A continuación puede ver las plataformas compatibles y aprender sobre la solución de almacenamiento seguro de cada una; es importante entender los conceptos básicos de cómo funcionan estos sistemas y pensar cuidadosamente en las implicaciones de seguridad de almacenar claves privadas (o cualquier secreto) en almacenamiento persistente.
iOS
En iOS, utilizamos el iOS Keychain.MacOS
En MacOS, utilizamos el MacOS Keychain.Windows
En PCs con Windows, utilizamos la Crypto: Next Generation - Data Protection API (CNG DPAPI)Web
En compilaciones Web, utilizamos IndexedDB a través de PlayerPrefs.Android
En compilaciones Android, utilizamos el Android Keystore. Nuestro plugin Keystore para Unity (incluido en el SDK) requiere una Plantilla Gradle Principal personalizada. Por favor, vaya a la configuración de su proyecto y, enPlayer > Publishing Settings, habilite Custom Main Gradle Template. Esto creará un archivo Assets/Plugins/Android/mainTemplate.gradle (o similar; el editor le mostrará la ruta) si aún no tiene uno. Aquí tiene un ejemplo de archivo mainTemplate.gradle; por favor, copie/pegue (o incorpore en su archivo existente).
Player > Publishing Settings, habilite Custom Gradle Properties Template. Esto creará un archivo Assets/Plugins/Android/gradleTemplate.properties (o similar; el editor le mostrará la ruta) si aún no tiene uno. Aquí tiene un ejemplo de archivo gradleTemplate.properties; por favor, copie/pegue (o incorpore en su archivo existente).