LiveTvProgram.cs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. using MediaBrowser.Controller.Entities;
  2. using MediaBrowser.Controller.Providers;
  3. using MediaBrowser.Model.Configuration;
  4. using MediaBrowser.Model.LiveTv;
  5. using MediaBrowser.Model.Users;
  6. using System;
  7. using System.Linq;
  8. using System.Runtime.Serialization;
  9. namespace MediaBrowser.Controller.LiveTv
  10. {
  11. public class LiveTvProgram : BaseItem, ILiveTvItem, IHasLookupInfo<LiveTvProgramLookupInfo>, IHasStartDate, IHasProgramAttributes
  12. {
  13. /// <summary>
  14. /// Gets the user data key.
  15. /// </summary>
  16. /// <returns>System.String.</returns>
  17. protected override string CreateUserDataKey()
  18. {
  19. return GetClientTypeName() + "-" + Name;
  20. }
  21. /// <summary>
  22. /// Id of the program.
  23. /// </summary>
  24. public string ExternalId { get; set; }
  25. /// <summary>
  26. /// Gets or sets the original air date.
  27. /// </summary>
  28. /// <value>The original air date.</value>
  29. public DateTime? OriginalAirDate { get; set; }
  30. /// <summary>
  31. /// Gets or sets the type of the channel.
  32. /// </summary>
  33. /// <value>The type of the channel.</value>
  34. public ChannelType ChannelType { get; set; }
  35. /// <summary>
  36. /// The start date of the program, in UTC.
  37. /// </summary>
  38. public DateTime StartDate { get; set; }
  39. /// <summary>
  40. /// Gets or sets a value indicating whether this instance is hd.
  41. /// </summary>
  42. /// <value><c>true</c> if this instance is hd; otherwise, <c>false</c>.</value>
  43. public bool? IsHD { get; set; }
  44. /// <summary>
  45. /// Gets or sets the audio.
  46. /// </summary>
  47. /// <value>The audio.</value>
  48. public ProgramAudio? Audio { get; set; }
  49. /// <summary>
  50. /// Gets or sets a value indicating whether this instance is repeat.
  51. /// </summary>
  52. /// <value><c>true</c> if this instance is repeat; otherwise, <c>false</c>.</value>
  53. public bool IsRepeat { get; set; }
  54. /// <summary>
  55. /// Gets or sets the episode title.
  56. /// </summary>
  57. /// <value>The episode title.</value>
  58. public string EpisodeTitle { get; set; }
  59. /// <summary>
  60. /// Gets or sets the name of the service.
  61. /// </summary>
  62. /// <value>The name of the service.</value>
  63. public string ServiceName { get; set; }
  64. /// <summary>
  65. /// Supply the image path if it can be accessed directly from the file system
  66. /// </summary>
  67. /// <value>The image path.</value>
  68. public string ProviderImagePath { get; set; }
  69. /// <summary>
  70. /// Supply the image url if it can be downloaded
  71. /// </summary>
  72. /// <value>The image URL.</value>
  73. public string ProviderImageUrl { get; set; }
  74. /// <summary>
  75. /// Gets or sets a value indicating whether this instance has image.
  76. /// </summary>
  77. /// <value><c>null</c> if [has image] contains no value, <c>true</c> if [has image]; otherwise, <c>false</c>.</value>
  78. public bool? HasProviderImage { get; set; }
  79. /// <summary>
  80. /// Gets or sets a value indicating whether this instance is movie.
  81. /// </summary>
  82. /// <value><c>true</c> if this instance is movie; otherwise, <c>false</c>.</value>
  83. public bool IsMovie { get; set; }
  84. /// <summary>
  85. /// Gets or sets a value indicating whether this instance is sports.
  86. /// </summary>
  87. /// <value><c>true</c> if this instance is sports; otherwise, <c>false</c>.</value>
  88. public bool IsSports { get; set; }
  89. /// <summary>
  90. /// Gets or sets a value indicating whether this instance is series.
  91. /// </summary>
  92. /// <value><c>true</c> if this instance is series; otherwise, <c>false</c>.</value>
  93. public bool IsSeries { get; set; }
  94. /// <summary>
  95. /// Gets or sets a value indicating whether this instance is live.
  96. /// </summary>
  97. /// <value><c>true</c> if this instance is live; otherwise, <c>false</c>.</value>
  98. public bool IsLive { get; set; }
  99. /// <summary>
  100. /// Gets or sets a value indicating whether this instance is news.
  101. /// </summary>
  102. /// <value><c>true</c> if this instance is news; otherwise, <c>false</c>.</value>
  103. public bool IsNews { get; set; }
  104. /// <summary>
  105. /// Gets or sets a value indicating whether this instance is kids.
  106. /// </summary>
  107. /// <value><c>true</c> if this instance is kids; otherwise, <c>false</c>.</value>
  108. public bool IsKids { get; set; }
  109. /// <summary>
  110. /// Gets or sets a value indicating whether this instance is premiere.
  111. /// </summary>
  112. /// <value><c>true</c> if this instance is premiere; otherwise, <c>false</c>.</value>
  113. public bool IsPremiere { get; set; }
  114. /// <summary>
  115. /// Returns the folder containing the item.
  116. /// If the item is a folder, it returns the folder itself
  117. /// </summary>
  118. /// <value>The containing folder path.</value>
  119. [IgnoreDataMember]
  120. public override string ContainingFolderPath
  121. {
  122. get
  123. {
  124. return Path;
  125. }
  126. }
  127. /// <summary>
  128. /// Gets a value indicating whether this instance is owned item.
  129. /// </summary>
  130. /// <value><c>true</c> if this instance is owned item; otherwise, <c>false</c>.</value>
  131. [IgnoreDataMember]
  132. public override bool IsOwnedItem
  133. {
  134. get
  135. {
  136. return false;
  137. }
  138. }
  139. [IgnoreDataMember]
  140. public override string MediaType
  141. {
  142. get
  143. {
  144. return ChannelType == ChannelType.TV ? Model.Entities.MediaType.Video : Model.Entities.MediaType.Audio;
  145. }
  146. }
  147. [IgnoreDataMember]
  148. public bool IsAiring
  149. {
  150. get
  151. {
  152. var now = DateTime.UtcNow;
  153. return now >= StartDate && now < EndDate;
  154. }
  155. }
  156. [IgnoreDataMember]
  157. public bool HasAired
  158. {
  159. get
  160. {
  161. var now = DateTime.UtcNow;
  162. return now >= EndDate;
  163. }
  164. }
  165. public override string GetClientTypeName()
  166. {
  167. return "Program";
  168. }
  169. protected override bool GetBlockUnratedValue(UserPolicy config)
  170. {
  171. return config.BlockUnratedItems.Contains(UnratedItem.LiveTvProgram);
  172. }
  173. protected override string GetInternalMetadataPath(string basePath)
  174. {
  175. return System.IO.Path.Combine(basePath, "livetv", Id.ToString("N"));
  176. }
  177. public override bool CanDelete()
  178. {
  179. return false;
  180. }
  181. public override bool IsInternetMetadataEnabled()
  182. {
  183. if (IsMovie)
  184. {
  185. var options = (LiveTvOptions)ConfigurationManager.GetConfiguration("livetv");
  186. return options.EnableMovieProviders;
  187. }
  188. return false;
  189. }
  190. public LiveTvProgramLookupInfo GetLookupInfo()
  191. {
  192. var info = GetItemLookupInfo<LiveTvProgramLookupInfo>();
  193. info.IsMovie = IsMovie;
  194. return info;
  195. }
  196. public override bool SupportsPeople
  197. {
  198. get
  199. {
  200. // Optimization
  201. if (IsNews || IsSports)
  202. {
  203. return false;
  204. }
  205. return base.SupportsPeople;
  206. }
  207. }
  208. }
  209. }