123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- using System;
- using System.ComponentModel.DataAnnotations;
- using System.ComponentModel.DataAnnotations.Schema;
- using Jellyfin.Data.Interfaces;
- namespace Jellyfin.Data.Entities.Libraries
- {
- /// <summary>
- /// An entity representing a rating for an entity.
- /// </summary>
- public class Rating : IHasConcurrencyToken
- {
- /// <summary>
- /// Initializes a new instance of the <see cref="Rating"/> class.
- /// </summary>
- /// <param name="value">The value.</param>
- /// <param name="itemMetadata">The metadata.</param>
- public Rating(double value, ItemMetadata itemMetadata)
- {
- Value = value;
- if (itemMetadata == null)
- {
- throw new ArgumentNullException(nameof(itemMetadata));
- }
- itemMetadata.Ratings.Add(this);
- }
- /// <summary>
- /// Initializes a new instance of the <see cref="Rating"/> class.
- /// </summary>
- /// <remarks>
- /// Default constructor. Protected due to required properties, but present because EF needs it.
- /// </remarks>
- protected Rating()
- {
- }
- /// <summary>
- /// Gets or sets the id.
- /// </summary>
- /// <remarks>
- /// Identity, Indexed, Required.
- /// </remarks>
- [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
- public int Id { get; protected set; }
- /// <summary>
- /// Gets or sets the value.
- /// </summary>
- /// <remarks>
- /// Required.
- /// </remarks>
- public double Value { get; set; }
- /// <summary>
- /// Gets or sets the number of votes.
- /// </summary>
- public int? Votes { get; set; }
- /// <inheritdoc />
- [ConcurrencyCheck]
- public uint RowVersion { get; set; }
- /// <summary>
- /// Gets or sets the rating type.
- /// If this is <c>null</c> it's the internal user rating.
- /// </summary>
- public virtual RatingSource RatingType { get; set; }
- /// <inheritdoc />
- public void OnSavingChanges()
- {
- RowVersion++;
- }
- }
- }
|