2020-09-01 15:36:45 +00:00
|
|
|
#pragma warning disable CA2227
|
|
|
|
|
2019-06-01 20:40:01 +00:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.ComponentModel.DataAnnotations;
|
|
|
|
using System.ComponentModel.DataAnnotations.Schema;
|
2020-08-30 22:50:54 +00:00
|
|
|
using Jellyfin.Data.Enums;
|
|
|
|
using Jellyfin.Data.Interfaces;
|
2019-06-01 20:40:01 +00:00
|
|
|
|
2020-08-29 17:30:09 +00:00
|
|
|
namespace Jellyfin.Data.Entities.Libraries
|
2019-06-01 20:40:01 +00:00
|
|
|
{
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <summary>
|
|
|
|
/// An entity representing a file on disk.
|
|
|
|
/// </summary>
|
|
|
|
public class MediaFile : IHasConcurrencyToken
|
2020-05-02 21:56:05 +00:00
|
|
|
{
|
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Initializes a new instance of the <see cref="MediaFile"/> class.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <param name="path">The path relative to the LibraryRoot.</param>
|
|
|
|
/// <param name="kind">The file kind.</param>
|
|
|
|
/// <param name="release">The release.</param>
|
|
|
|
public MediaFile(string path, MediaFileKind kind, Release release)
|
2020-05-02 21:56:05 +00:00
|
|
|
{
|
2020-06-20 08:35:29 +00:00
|
|
|
if (string.IsNullOrEmpty(path))
|
|
|
|
{
|
|
|
|
throw new ArgumentNullException(nameof(path));
|
|
|
|
}
|
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
Path = path;
|
|
|
|
Kind = kind;
|
2020-05-02 21:56:05 +00:00
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
if (release == null)
|
2020-06-20 08:35:29 +00:00
|
|
|
{
|
2020-08-30 22:50:54 +00:00
|
|
|
throw new ArgumentNullException(nameof(release));
|
2020-06-20 08:35:29 +00:00
|
|
|
}
|
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
release.MediaFiles.Add(this);
|
2020-05-02 21:56:05 +00:00
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
MediaFileStreams = new HashSet<MediaFileStream>();
|
2020-05-02 21:56:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Initializes a new instance of the <see cref="MediaFile"/> class.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <remarks>
|
|
|
|
/// Default constructor. Protected due to required properties, but present because EF needs it.
|
|
|
|
/// </remarks>
|
|
|
|
protected MediaFile()
|
2020-05-02 21:56:05 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Gets or sets the id.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <remarks>
|
2020-06-15 22:37:52 +00:00
|
|
|
/// Identity, Indexed, Required.
|
2020-08-30 22:50:54 +00:00
|
|
|
/// </remarks>
|
2020-05-02 21:56:05 +00:00
|
|
|
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
|
2020-08-30 22:50:54 +00:00
|
|
|
public int Id { get; protected set; }
|
2020-05-02 21:56:05 +00:00
|
|
|
|
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Gets or sets the path relative to the library root.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <remarks>
|
|
|
|
/// Required, Max length = 65535.
|
|
|
|
/// </remarks>
|
2020-05-02 21:56:05 +00:00
|
|
|
[Required]
|
|
|
|
[MaxLength(65535)]
|
|
|
|
[StringLength(65535)]
|
2020-08-30 22:50:54 +00:00
|
|
|
public string Path { get; set; }
|
2020-06-15 21:43:52 +00:00
|
|
|
|
2020-05-02 21:56:05 +00:00
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Gets or sets the kind of media file.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <remarks>
|
2020-06-15 22:37:52 +00:00
|
|
|
/// Required.
|
2020-08-30 22:50:54 +00:00
|
|
|
/// </remarks>
|
|
|
|
public MediaFileKind Kind { get; set; }
|
2020-06-15 21:43:52 +00:00
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <inheritdoc />
|
|
|
|
[ConcurrencyCheck]
|
|
|
|
public uint RowVersion { get; set; }
|
2020-05-02 21:56:05 +00:00
|
|
|
|
|
|
|
/// <summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
/// Gets or sets a collection containing the streams in this file.
|
2020-05-02 21:56:05 +00:00
|
|
|
/// </summary>
|
2020-08-30 22:50:54 +00:00
|
|
|
public virtual ICollection<MediaFileStream> MediaFileStreams { get; protected set; }
|
2019-06-01 20:40:01 +00:00
|
|
|
|
2020-08-30 22:50:54 +00:00
|
|
|
/// <inheritdoc />
|
2020-05-02 21:56:05 +00:00
|
|
|
public void OnSavingChanges()
|
|
|
|
{
|
|
|
|
RowVersion++;
|
|
|
|
}
|
|
|
|
}
|
2019-06-01 20:40:01 +00:00
|
|
|
}
|