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 { [Table("Photo")] public partial class Photo : LibraryItem { partial void Init(); /// /// Default constructor. Protected due to required properties, but present because EF needs it. /// protected Photo() : base() { PhotoMetadata = new HashSet(); Releases = new HashSet(); Init(); } /// /// Replaces default constructor, since it's protected. Caller assumes responsibility for setting all required values before saving. /// public static Photo CreatePhotoUnsafe() { return new Photo(); } /// /// Public constructor with required data /// /// This is whats gets displayed in the Urls and API requests. This could also be a string. public Photo(Guid urlid, DateTime dateadded) { this.UrlId = urlid; this.PhotoMetadata = new HashSet(); this.Releases = new 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 Photo Create(Guid urlid, DateTime dateadded) { return new Photo(urlid, dateadded); } /************************************************************************* * Properties *************************************************************************/ /************************************************************************* * Navigation properties *************************************************************************/ [ForeignKey("PhotoMetadata_PhotoMetadata_Id")] public virtual ICollection PhotoMetadata { get; protected set; } [ForeignKey("Release_Releases_Id")] public virtual ICollection Releases { get; protected set; } } }