jellyfin-server/MediaBrowser.Controller/Entities/Game.cs

125 lines
3.7 KiB
C#
Raw Normal View History

2014-02-07 03:10:13 +00:00
using MediaBrowser.Controller.Providers;
using MediaBrowser.Model.Configuration;
2013-12-26 16:53:23 +00:00
using MediaBrowser.Model.Entities;
2013-11-12 15:36:08 +00:00
using System;
using System.Collections.Generic;
using MediaBrowser.Model.IO;
2016-10-25 19:02:04 +00:00
using MediaBrowser.Model.Serialization;
2013-09-19 20:36:45 +00:00
2013-06-22 18:15:31 +00:00
namespace MediaBrowser.Controller.Entities
{
2016-10-09 07:18:43 +00:00
public class Game : BaseItem, IHasTrailers, IHasScreenshots, ISupportsPlaceHolders, IHasLookupInfo<GameInfo>
2013-06-22 18:15:31 +00:00
{
2013-09-19 20:36:45 +00:00
public Game()
{
MultiPartGameFiles = EmptyStringArray;
2017-08-10 18:01:31 +00:00
RemoteTrailers = EmptyMediaUrlArray;
LocalTrailerIds = EmptyGuidArray;
RemoteTrailerIds = EmptyGuidArray;
2013-09-19 20:36:45 +00:00
}
2017-08-10 18:01:31 +00:00
public Guid[] LocalTrailerIds { get; set; }
public Guid[] RemoteTrailerIds { get; set; }
2015-02-06 05:39:07 +00:00
public override bool CanDownload()
{
var locationType = LocationType;
return locationType != LocationType.Remote &&
locationType != LocationType.Virtual;
}
2016-10-09 07:18:43 +00:00
[IgnoreDataMember]
public override bool SupportsThemeMedia
{
get { return true; }
}
2013-12-02 16:46:25 +00:00
/// <summary>
/// Gets or sets the remote trailers.
/// </summary>
/// <value>The remote trailers.</value>
2017-08-10 18:01:31 +00:00
public MediaUrl[] RemoteTrailers { get; set; }
2013-06-22 18:15:31 +00:00
/// <summary>
/// Gets the type of the media.
/// </summary>
/// <value>The type of the media.</value>
2016-07-24 16:46:17 +00:00
[IgnoreDataMember]
2013-06-22 18:15:31 +00:00
public override string MediaType
{
get { return Model.Entities.MediaType.Game; }
}
/// <summary>
/// Gets or sets the players supported.
/// </summary>
/// <value>The players supported.</value>
public int? PlayersSupported { get; set; }
2013-09-22 22:42:21 +00:00
/// <summary>
/// Gets a value indicating whether this instance is place holder.
2013-09-22 22:42:21 +00:00
/// </summary>
/// <value><c>true</c> if this instance is place holder; otherwise, <c>false</c>.</value>
public bool IsPlaceHolder { get; set; }
2013-09-22 22:42:21 +00:00
2013-06-22 18:15:31 +00:00
/// <summary>
/// Gets or sets the game system.
/// </summary>
/// <value>The game system.</value>
public string GameSystem { get; set; }
2013-07-22 17:07:39 +00:00
2013-09-19 20:36:45 +00:00
/// <summary>
/// Gets or sets a value indicating whether this instance is multi part.
/// </summary>
/// <value><c>true</c> if this instance is multi part; otherwise, <c>false</c>.</value>
public bool IsMultiPart { get; set; }
/// <summary>
/// Holds the paths to the game files in the event this is a multipart game
/// </summary>
public string[] MultiPartGameFiles { get; set; }
2013-09-19 20:36:45 +00:00
2016-04-30 23:05:21 +00:00
public override List<string> GetUserDataKeys()
{
2016-04-30 23:05:21 +00:00
var list = base.GetUserDataKeys();
var id = this.GetProviderId(MetadataProviders.Gamesdb);
if (!string.IsNullOrEmpty(id))
{
2016-04-30 23:05:21 +00:00
list.Insert(0, "Game-Gamesdb-" + id);
}
2016-04-30 23:05:21 +00:00
return list;
}
public override IEnumerable<FileSystemMetadata> GetDeletePaths()
{
2017-07-31 05:16:22 +00:00
if (!IsInMixedFolder)
{
return new[] {
new FileSystemMetadata
{
2017-05-04 18:14:45 +00:00
FullName = FileSystem.GetDirectoryName(Path),
IsDirectory = true
}
};
}
return base.GetDeletePaths();
}
2013-12-26 16:53:23 +00:00
2015-11-06 15:02:22 +00:00
public override UnratedItem GetBlockUnratedType()
2013-12-26 16:53:23 +00:00
{
2015-11-06 15:02:22 +00:00
return UnratedItem.Game;
2013-12-26 16:53:23 +00:00
}
2014-02-07 03:10:13 +00:00
public GameInfo GetLookupInfo()
{
var id = GetItemLookupInfo<GameInfo>();
id.GameSystem = GameSystem;
return id;
}
2013-06-22 18:15:31 +00:00
}
}