/// <summary> /// Método encargado de gestionar la información de tokens /// </summary> /// <param name="context"></param> /// <returns></returns> public async Task CreateAsync(AuthenticationTokenCreateContext context) { var clientid = context.Ticket.Properties.Dictionary["as:client_id"]; if (string.IsNullOrEmpty(clientid)) { return; } //Se genera un identificador único para el token var refreshTokenId = Guid.NewGuid().ToString("n"); using (AutenticacionRepository _repo = new AutenticacionRepository()) { var refreshTokenLifeTime = context.OwinContext.Get<string>("as:clientRefreshTokenLifeTime"); //Se asignan las propiedades del token var token = new RefreshToken() { Id = Helper.GetHash(refreshTokenId), ClientId = clientid, Subject = context.Ticket.Identity.Name, FechaEmision = DateTime.UtcNow, FechaExpiracion = DateTime.UtcNow.AddMinutes(Convert.ToDouble(refreshTokenLifeTime)) }; context.Ticket.Properties.IssuedUtc = token.FechaEmision; context.Ticket.Properties.ExpiresUtc = token.FechaExpiracion; token.TicketProtegido = context.SerializeTicket(); var result = await _repo.AgregarRefreshToken(token); if (result) { context.SetToken(refreshTokenId); } } }