mirror of
https://github.com/aliasvault/aliasvault.git
synced 2025-12-23 22:28:22 -05:00
73 lines
2.2 KiB
C#
73 lines
2.2 KiB
C#
//-----------------------------------------------------------------------
|
|
// <copyright file="AliasVaultUserRefreshToken.cs" company="lanedirt">
|
|
// Copyright (c) lanedirt. All rights reserved.
|
|
// Licensed under the AGPLv3 license. See LICENSE.md file in the project root for full license information.
|
|
// </copyright>
|
|
//-----------------------------------------------------------------------
|
|
namespace AliasServerDb;
|
|
|
|
using System.ComponentModel.DataAnnotations;
|
|
using System.ComponentModel.DataAnnotations.Schema;
|
|
using Microsoft.AspNetCore.Identity;
|
|
|
|
/// <summary>
|
|
/// Refresh tokens for users.
|
|
/// </summary>
|
|
public class AliasVaultUserRefreshToken
|
|
{
|
|
/// <summary>
|
|
/// Gets or sets Refresh Token ID.
|
|
/// </summary>
|
|
[Key]
|
|
public Guid Id { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets user ID foreign key.
|
|
/// </summary>
|
|
[StringLength(255)]
|
|
public string UserId { get; set; } = null!;
|
|
|
|
/// <summary>
|
|
/// Gets or sets foreign key to the AliasVaultUser object.
|
|
/// </summary>
|
|
[ForeignKey("UserId")]
|
|
public virtual AliasVaultUser User { get; set; } = null!;
|
|
|
|
/// <summary>
|
|
/// Gets or sets the device identifier (one token per device).
|
|
/// </summary>
|
|
[StringLength(255)]
|
|
public string DeviceIdentifier { get; set; } = null!;
|
|
|
|
/// <summary>
|
|
/// Gets or sets the IP address associated with the refresh token.
|
|
/// </summary>
|
|
[StringLength(45)]
|
|
public string? IpAddress { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets the token value.
|
|
/// </summary>
|
|
[StringLength(255)]
|
|
public string Value { get; set; } = null!;
|
|
|
|
/// <summary>
|
|
/// Gets or sets the previous token value that was replaced by the current one (optional).
|
|
/// This is used to allow a short reuse window where if multiple refresh requests are
|
|
/// made in quick succession they all get the same new refresh token.
|
|
/// </summary>
|
|
[StringLength(255)]
|
|
public string? PreviousTokenValue { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets the expiration date.
|
|
/// </summary>
|
|
[StringLength(255)]
|
|
public DateTime ExpireDate { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets created timestamp.
|
|
/// </summary>
|
|
public DateTime CreatedAt { get; set; }
|
|
}
|