//------------------------------------------------------------------------------
//
// This code was generated from a template.
//
// Manual changes to this file may cause unexpected behavior in your application.
// Manual changes to this file will be overwritten if the code is regenerated.
//
// Produced by Entity Framework Visual Editor
// https://github.com/msawczyn/EFDesigner
//
//------------------------------------------------------------------------------
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Runtime.CompilerServices;
namespace Jellyfin.Data.Entities
{
public partial class Episode: global::Jellyfin.Data.Entities.LibraryItem
{
partial void Init();
///
/// Default constructor. Protected due to required properties, but present because EF needs it.
///
protected Episode(): base()
{
// NOTE: This class has one-to-one associations with LibraryRoot, LibraryItem and CollectionItem.
// One-to-one associations are not validated in constructors since this causes a scenario where each one must be constructed before the other.
Releases = new System.Collections.Generic.HashSet();
EpisodeMetadata = new System.Collections.Generic.HashSet();
Init();
}
///
/// Replaces default constructor, since it's protected. Caller assumes responsibility for setting all required values before saving.
///
public static Episode CreateEpisodeUnsafe()
{
return new Episode();
}
///
/// Public constructor with required data
///
/// This is whats gets displayed in the Urls and API requests. This could also be a string.
///
public Episode(Guid urlid, DateTime dateadded, global::Jellyfin.Data.Entities.Season _season0)
{
// NOTE: This class has one-to-one associations with LibraryRoot, LibraryItem and CollectionItem.
// One-to-one associations are not validated in constructors since this causes a scenario where each one must be constructed before the other.
this.UrlId = urlid;
if (_season0 == null) throw new ArgumentNullException(nameof(_season0));
_season0.Episodes.Add(this);
this.Releases = new System.Collections.Generic.HashSet();
this.EpisodeMetadata = new System.Collections.Generic.HashSet();
Init();
}
///
/// Static create function (for use in LINQ queries, etc.)
///
/// This is whats gets displayed in the Urls and API requests. This could also be a string.
///
public static Episode Create(Guid urlid, DateTime dateadded, global::Jellyfin.Data.Entities.Season _season0)
{
return new Episode(urlid, dateadded, _season0);
}
/*************************************************************************
* Properties
*************************************************************************/
///
/// Backing field for EpisodeNumber
///
protected int? _EpisodeNumber;
///
/// When provided in a partial class, allows value of EpisodeNumber to be changed before setting.
///
partial void SetEpisodeNumber(int? oldValue, ref int? newValue);
///
/// When provided in a partial class, allows value of EpisodeNumber to be changed before returning.
///
partial void GetEpisodeNumber(ref int? result);
public int? EpisodeNumber
{
get
{
int? value = _EpisodeNumber;
GetEpisodeNumber(ref value);
return (_EpisodeNumber = value);
}
set
{
int? oldValue = _EpisodeNumber;
SetEpisodeNumber(oldValue, ref value);
if (oldValue != value)
{
_EpisodeNumber = value;
}
}
}
/*************************************************************************
* Navigation properties
*************************************************************************/
public virtual ICollection Releases { get; protected set; }
public virtual ICollection EpisodeMetadata { get; protected set; }
}
}