1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- using System;
- using System.ComponentModel.DataAnnotations;
- using System.ComponentModel.DataAnnotations.Schema;
- using Jellyfin.Data.Enums;
- namespace Jellyfin.Data.Entities
- {
- /// <summary>
- /// An entity representing a preference attached to a user or group.
- /// </summary>
- public class Preference : ISavingChanges
- {
- /// <summary>
- /// Initializes a new instance of the <see cref="Preference"/> class.
- /// Public constructor with required data.
- /// </summary>
- /// <param name="kind">The preference kind.</param>
- /// <param name="value">The value.</param>
- public Preference(PreferenceKind kind, string value)
- {
- Kind = kind;
- Value = value ?? throw new ArgumentNullException(nameof(value));
- }
- /// <summary>
- /// Initializes a new instance of the <see cref="Preference"/> class.
- /// Default constructor. Protected due to required properties, but present because EF needs it.
- /// </summary>
- protected Preference()
- {
- }
- /*************************************************************************
- * Properties
- *************************************************************************/
- /// <summary>
- /// Gets or sets the id of this preference.
- /// </summary>
- /// <remarks>
- /// Identity, Indexed, Required.
- /// </remarks>
- [Key]
- [Required]
- [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
- public int Id { get; protected set; }
- /// <summary>
- /// Gets or sets the type of this preference.
- /// </summary>
- /// <remarks>
- /// Required.
- /// </remarks>
- [Required]
- public PreferenceKind Kind { get; protected set; }
- /// <summary>
- /// Gets or sets the value of this preference.
- /// </summary>
- /// <remarks>
- /// Required, Max length = 65535.
- /// </remarks>
- [Required]
- [MaxLength(65535)]
- [StringLength(65535)]
- public string Value { get; set; }
- /// <summary>
- /// Gets or sets the row version.
- /// </summary>
- /// <remarks>
- /// Required, ConcurrencyToken.
- /// </remarks>
- [ConcurrencyCheck]
- [Required]
- public uint RowVersion { get; set; }
- /// <summary>
- /// Static create function (for use in LINQ queries, etc.)
- /// </summary>
- /// <param name="kind">The preference kind.</param>
- /// <param name="value">The value.</param>
- /// <returns>The new instance.</returns>
- public static Preference Create(PreferenceKind kind, string value)
- {
- return new Preference(kind, value);
- }
- /// <inheritdoc/>
- public void OnSavingChanges()
- {
- RowVersion++;
- }
- }
- }
|