Preference.cs 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. using System;
  2. using System.ComponentModel.DataAnnotations;
  3. using System.ComponentModel.DataAnnotations.Schema;
  4. using Jellyfin.Data.Enums;
  5. namespace Jellyfin.Data.Entities
  6. {
  7. /// <summary>
  8. /// An entity representing a preference attached to a user or group.
  9. /// </summary>
  10. public class Preference : ISavingChanges
  11. {
  12. /// <summary>
  13. /// Initializes a new instance of the <see cref="Preference"/> class.
  14. /// Public constructor with required data.
  15. /// </summary>
  16. /// <param name="kind">The preference kind.</param>
  17. /// <param name="value">The value.</param>
  18. public Preference(PreferenceKind kind, string value)
  19. {
  20. Kind = kind;
  21. Value = value ?? throw new ArgumentNullException(nameof(value));
  22. }
  23. /// <summary>
  24. /// Initializes a new instance of the <see cref="Preference"/> class.
  25. /// Default constructor. Protected due to required properties, but present because EF needs it.
  26. /// </summary>
  27. protected Preference()
  28. {
  29. }
  30. /*************************************************************************
  31. * Properties
  32. *************************************************************************/
  33. /// <summary>
  34. /// Gets or sets the id of this preference.
  35. /// </summary>
  36. /// <remarks>
  37. /// Identity, Indexed, Required.
  38. /// </remarks>
  39. [Key]
  40. [Required]
  41. [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
  42. public int Id { get; protected set; }
  43. /// <summary>
  44. /// Gets or sets the type of this preference.
  45. /// </summary>
  46. /// <remarks>
  47. /// Required.
  48. /// </remarks>
  49. [Required]
  50. public PreferenceKind Kind { get; protected set; }
  51. /// <summary>
  52. /// Gets or sets the value of this preference.
  53. /// </summary>
  54. /// <remarks>
  55. /// Required, Max length = 65535.
  56. /// </remarks>
  57. [Required]
  58. [MaxLength(65535)]
  59. [StringLength(65535)]
  60. public string Value { get; set; }
  61. /// <summary>
  62. /// Gets or sets the row version.
  63. /// </summary>
  64. /// <remarks>
  65. /// Required, ConcurrencyToken.
  66. /// </remarks>
  67. [ConcurrencyCheck]
  68. [Required]
  69. public uint RowVersion { get; set; }
  70. /// <summary>
  71. /// Static create function (for use in LINQ queries, etc.)
  72. /// </summary>
  73. /// <param name="kind">The preference kind.</param>
  74. /// <param name="value">The value.</param>
  75. /// <returns>The new instance.</returns>
  76. public static Preference Create(PreferenceKind kind, string value)
  77. {
  78. return new Preference(kind, value);
  79. }
  80. /// <inheritdoc/>
  81. public void OnSavingChanges()
  82. {
  83. RowVersion++;
  84. }
  85. }
  86. }