aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs')
-rw-r--r--MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs47
1 files changed, 47 insertions, 0 deletions
diff --git a/MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs b/MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs
new file mode 100644
index 000000000..d36aa9944
--- /dev/null
+++ b/MediaBrowser.Model/MediaInfo/LiveStreamRequest.cs
@@ -0,0 +1,47 @@
+using MediaBrowser.Model.Dlna;
+using System;
+
+namespace MediaBrowser.Model.MediaInfo
+{
+ public class LiveStreamRequest
+ {
+ public string OpenToken { get; set; }
+ public Guid UserId { get; set; }
+ public string PlaySessionId { get; set; }
+ public long? MaxStreamingBitrate { get; set; }
+ public long? StartTimeTicks { get; set; }
+ public int? AudioStreamIndex { get; set; }
+ public int? SubtitleStreamIndex { get; set; }
+ public int? MaxAudioChannels { get; set; }
+ public Guid ItemId { get; set; }
+ public DeviceProfile DeviceProfile { get; set; }
+
+ public bool EnableDirectPlay { get; set; }
+ public bool EnableDirectStream { get; set; }
+ public MediaProtocol[] DirectPlayProtocols { get; set; }
+
+ public LiveStreamRequest()
+ {
+ EnableDirectPlay = true;
+ EnableDirectStream = true;
+ DirectPlayProtocols = new MediaProtocol[] { MediaProtocol.Http };
+ }
+
+ public LiveStreamRequest(AudioOptions options)
+ {
+ MaxStreamingBitrate = options.MaxBitrate;
+ ItemId = options.ItemId;
+ DeviceProfile = options.Profile;
+ MaxAudioChannels = options.MaxAudioChannels;
+
+ DirectPlayProtocols = new MediaProtocol[] { MediaProtocol.Http };
+
+ VideoOptions videoOptions = options as VideoOptions;
+ if (videoOptions != null)
+ {
+ AudioStreamIndex = videoOptions.AudioStreamIndex;
+ SubtitleStreamIndex = videoOptions.SubtitleStreamIndex;
+ }
+ }
+ }
+}