using System; using Microsoft.Extensions.Logging; namespace Selector.MAUI.Services; public class SessionManager { private const string jwt_keychain_key = "last_jwt_key"; private string lastStoredKey; private DateTime lastRefresh; private readonly ISelectorNetClient _selectorNetClient; private readonly ILogger _logger; public SessionManager(ISelectorNetClient selectorNetClient, ILogger logger) { _selectorNetClient = selectorNetClient; _logger = logger; } public bool IsLoggedIn => !string.IsNullOrWhiteSpace(lastStoredKey); public async Task LoadUserFromDisk() { var lastToken = await SecureStorage.Default.GetAsync(jwt_keychain_key); lastStoredKey = lastToken; if(!string.IsNullOrWhiteSpace(lastToken)) { await Authenticate(); } } public async Task Authenticate(string username, string password) { _logger.LogDebug("Making login token request"); var tokenResponse = await _selectorNetClient.GetToken(username, password); return await HandleTokenResponse(tokenResponse); } public async Task Authenticate() { _logger.LogDebug("Making token request with current key"); var tokenResponse = await _selectorNetClient.GetToken(lastStoredKey); return await HandleTokenResponse(tokenResponse); } private async Task HandleTokenResponse(SelectorNetClient.TokenResponse tokenResponse) { switch (tokenResponse.Status) { case SelectorNetClient.TokenResponseStatus.OK: _logger.LogInformation("Token response ok"); lastStoredKey = tokenResponse.Token; lastRefresh = DateTime.Now; //await SecureStorage.Default.SetAsync(jwt_keychain_key, lastStoredKey); break; case SelectorNetClient.TokenResponseStatus.Malformed: _logger.LogInformation("Token request failed, missing username or password"); break; case SelectorNetClient.TokenResponseStatus.UserSearchFailed: _logger.LogInformation("Token request failed, no user by that name"); break; case SelectorNetClient.TokenResponseStatus.BadCreds: _logger.LogInformation("Token request failed, bad password"); break; default: throw new NotImplementedException(); } return tokenResponse.Status; } }