jellyfin-server/Jellyfin.Data/Entities/Person.cs

312 lines
9.1 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace Jellyfin.Data.Entities
{
2020-05-02 21:56:05 +00:00
public partial class Person
{
partial void Init();
2020-05-02 21:56:05 +00:00
/// <summary>
/// Default constructor. Protected due to required properties, but present because EF needs it.
/// </summary>
protected Person()
{
Sources = new HashSet<MetadataProviderId>();
2020-05-02 21:56:05 +00:00
Init();
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Replaces default constructor, since it's protected. Caller assumes responsibility for setting all required values before saving.
/// </summary>
public static Person CreatePersonUnsafe()
{
return new Person();
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Public constructor with required data.
2020-05-02 21:56:05 +00:00
/// </summary>
/// <param name="urlid"></param>
/// <param name="name"></param>
public Person(Guid urlid, string name, DateTime dateadded, DateTime datemodified)
{
this.UrlId = urlid;
2020-06-20 08:35:29 +00:00
if (string.IsNullOrEmpty(name))
{
throw new ArgumentNullException(nameof(name));
}
2020-05-02 21:56:05 +00:00
this.Name = name;
2020-05-02 21:56:05 +00:00
this.Sources = new HashSet<MetadataProviderId>();
2020-05-02 21:56:05 +00:00
Init();
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Static create function (for use in LINQ queries, etc.)
/// </summary>
/// <param name="urlid"></param>
/// <param name="name"></param>
public static Person Create(Guid urlid, string name, DateTime dateadded, DateTime datemodified)
{
return new Person(urlid, name, dateadded, datemodified);
}
2020-05-02 21:56:05 +00:00
/*************************************************************************
* Properties
*************************************************************************/
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for Id.
2020-05-02 21:56:05 +00:00
/// </summary>
internal int _Id;
/// <summary>
/// When provided in a partial class, allows value of Id to be changed before setting.
/// </summary>
partial void SetId(int oldValue, ref int newValue);
/// <summary>
/// When provided in a partial class, allows value of Id to be changed before returning.
/// </summary>
partial void GetId(ref int result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Identity, Indexed, Required.
2020-05-02 21:56:05 +00:00
/// </summary>
[Key]
[Required]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id
{
get
{
int value = _Id;
GetId(ref value);
2020-06-19 09:57:37 +00:00
return _Id = value;
2020-05-02 21:56:05 +00:00
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
protected set
{
2020-05-02 21:56:05 +00:00
int oldValue = _Id;
SetId(oldValue, ref value);
if (oldValue != value)
{
_Id = value;
}
}
2020-05-02 21:56:05 +00:00
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for UrlId.
2020-05-02 21:56:05 +00:00
/// </summary>
protected Guid _UrlId;
/// <summary>
/// When provided in a partial class, allows value of UrlId to be changed before setting.
/// </summary>
partial void SetUrlId(Guid oldValue, ref Guid newValue);
/// <summary>
/// When provided in a partial class, allows value of UrlId to be changed before returning.
/// </summary>
partial void GetUrlId(ref Guid result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Required.
2020-05-02 21:56:05 +00:00
/// </summary>
[Required]
public Guid UrlId
{
get
{
2020-05-02 21:56:05 +00:00
Guid value = _UrlId;
GetUrlId(ref value);
2020-06-19 09:57:37 +00:00
return _UrlId = value;
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
set
{
Guid oldValue = _UrlId;
SetUrlId(oldValue, ref value);
if (oldValue != value)
{
_UrlId = value;
}
}
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for Name.
2020-05-02 21:56:05 +00:00
/// </summary>
protected string _Name;
/// <summary>
/// When provided in a partial class, allows value of Name to be changed before setting.
/// </summary>
partial void SetName(string oldValue, ref string newValue);
/// <summary>
/// When provided in a partial class, allows value of Name to be changed before returning.
/// </summary>
partial void GetName(ref string result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Required, Max length = 1024
/// </summary>
[Required]
[MaxLength(1024)]
[StringLength(1024)]
public string Name
{
get
{
string value = _Name;
GetName(ref value);
2020-06-19 09:57:37 +00:00
return _Name = value;
2020-05-02 21:56:05 +00:00
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
set
{
2020-05-02 21:56:05 +00:00
string oldValue = _Name;
SetName(oldValue, ref value);
if (oldValue != value)
{
_Name = value;
}
}
2020-05-02 21:56:05 +00:00
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for SourceId.
2020-05-02 21:56:05 +00:00
/// </summary>
protected string _SourceId;
/// <summary>
/// When provided in a partial class, allows value of SourceId to be changed before setting.
/// </summary>
partial void SetSourceId(string oldValue, ref string newValue);
/// <summary>
/// When provided in a partial class, allows value of SourceId to be changed before returning.
/// </summary>
partial void GetSourceId(ref string result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Max length = 255
/// </summary>
[MaxLength(255)]
[StringLength(255)]
public string SourceId
{
get
{
2020-05-02 21:56:05 +00:00
string value = _SourceId;
GetSourceId(ref value);
2020-06-19 09:57:37 +00:00
return _SourceId = value;
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
set
{
string oldValue = _SourceId;
SetSourceId(oldValue, ref value);
if (oldValue != value)
{
_SourceId = value;
}
}
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for DateAdded.
2020-05-02 21:56:05 +00:00
/// </summary>
protected DateTime _DateAdded;
/// <summary>
/// When provided in a partial class, allows value of DateAdded to be changed before setting.
/// </summary>
partial void SetDateAdded(DateTime oldValue, ref DateTime newValue);
/// <summary>
/// When provided in a partial class, allows value of DateAdded to be changed before returning.
/// </summary>
partial void GetDateAdded(ref DateTime result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Required.
2020-05-02 21:56:05 +00:00
/// </summary>
[Required]
public DateTime DateAdded
{
get
{
DateTime value = _DateAdded;
GetDateAdded(ref value);
2020-06-19 09:57:37 +00:00
return _DateAdded = value;
2020-05-02 21:56:05 +00:00
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
internal set
{
2020-05-02 21:56:05 +00:00
DateTime oldValue = _DateAdded;
SetDateAdded(oldValue, ref value);
if (oldValue != value)
{
_DateAdded = value;
}
}
2020-05-02 21:56:05 +00:00
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Backing field for DateModified.
2020-05-02 21:56:05 +00:00
/// </summary>
protected DateTime _DateModified;
/// <summary>
/// When provided in a partial class, allows value of DateModified to be changed before setting.
/// </summary>
partial void SetDateModified(DateTime oldValue, ref DateTime newValue);
/// <summary>
/// When provided in a partial class, allows value of DateModified to be changed before returning.
/// </summary>
partial void GetDateModified(ref DateTime result);
2020-05-02 21:56:05 +00:00
/// <summary>
/// Required.
2020-05-02 21:56:05 +00:00
/// </summary>
[Required]
public DateTime DateModified
{
get
{
DateTime value = _DateModified;
GetDateModified(ref value);
2020-06-19 09:57:37 +00:00
return _DateModified = value;
2020-05-02 21:56:05 +00:00
}
2020-06-15 21:43:52 +00:00
2020-05-02 21:56:05 +00:00
internal set
{
2020-05-02 21:56:05 +00:00
DateTime oldValue = _DateModified;
SetDateModified(oldValue, ref value);
if (oldValue != value)
{
_DateModified = value;
}
}
2020-05-02 21:56:05 +00:00
}
2020-05-02 21:56:05 +00:00
/// <summary>
/// Required, ConcurrenyToken.
2020-05-02 21:56:05 +00:00
/// </summary>
[ConcurrencyCheck]
[Required]
public uint RowVersion { get; set; }
2020-05-02 21:56:05 +00:00
public void OnSavingChanges()
{
RowVersion++;
}
2020-05-02 21:56:05 +00:00
/*************************************************************************
* Navigation properties
*************************************************************************/
[ForeignKey("MetadataProviderId_Sources_Id")]
public virtual ICollection<MetadataProviderId> Sources { get; protected set; }
}
}