some progress towards brining back hls, but not finished yet

pull/702/head
LukePulverenti 12 years ago
parent 2828688ced
commit 9b3a97edfc

@ -647,10 +647,13 @@ namespace MediaBrowser.Api.Playback
videoRequest.VideoCodec = InferVideoCodec(url); videoRequest.VideoCodec = InferVideoCodec(url);
} }
state.AudioStream = GetMediaStream(media.MediaStreams, videoRequest.AudioStreamIndex, MediaStreamType.Audio, true);
state.VideoStream = GetMediaStream(media.MediaStreams, videoRequest.VideoStreamIndex, MediaStreamType.Video, true); state.VideoStream = GetMediaStream(media.MediaStreams, videoRequest.VideoStreamIndex, MediaStreamType.Video, true);
state.SubtitleStream = GetMediaStream(media.MediaStreams, videoRequest.SubtitleStreamIndex, MediaStreamType.Subtitle, false); state.SubtitleStream = GetMediaStream(media.MediaStreams, videoRequest.SubtitleStreamIndex, MediaStreamType.Subtitle, false);
} }
else
{
state.AudioStream = GetMediaStream(media.MediaStreams, null, MediaStreamType.Audio, true);
}
return state; return state;
} }

@ -2,10 +2,32 @@
using MediaBrowser.Controller; using MediaBrowser.Controller;
using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Library;
using MediaBrowser.Model.Dto; using MediaBrowser.Model.Dto;
using ServiceStack.ServiceHost;
using System; using System;
using System.IO;
namespace MediaBrowser.Api.Playback.Hls namespace MediaBrowser.Api.Playback.Hls
{ {
/// <summary>
/// Class GetHlsAudioStream
/// </summary>
[Route("/Audio/{Id}/stream.m3u8", "GET")]
[ServiceStack.ServiceHost.Api(Description = "Gets an audio stream using HTTP live streaming.")]
public class GetHlsAudioStream : StreamRequest
{
}
[Route("/Audio/{Id}/segments/{SegmentId}.mp3", "GET")]
[Route("/Audio/{Id}/segments/{SegmentId}.aac", "GET")]
[ServiceStack.ServiceHost.Api(Description = "Gets an Http live streaming segment file. Internal use only.")]
public class GetHlsAudioSegment
{
public string Id { get; set; }
public string SegmentId { get; set; }
}
/// <summary> /// <summary>
/// Class AudioHlsService /// Class AudioHlsService
/// </summary> /// </summary>
@ -16,6 +38,25 @@ namespace MediaBrowser.Api.Playback.Hls
{ {
} }
public object Get(GetHlsAudioSegment request)
{
var file = SegmentFilePrefix + request.SegmentId + Path.GetExtension(Request.PathInfo);
file = Path.Combine(ApplicationPaths.EncodedMediaCachePath, file);
return ToStaticFileResult(file);
}
/// <summary>
/// Gets the specified request.
/// </summary>
/// <param name="request">The request.</param>
/// <returns>System.Object.</returns>
public object Get(GetHlsAudioStream request)
{
return ProcessRequest(request);
}
/// <summary> /// <summary>
/// Gets the audio arguments. /// Gets the audio arguments.
/// </summary> /// </summary>
@ -75,7 +116,7 @@ namespace MediaBrowser.Api.Playback.Hls
return ".mp3"; return ".mp3";
} }
throw new InvalidOperationException("Only aac and mp3 audio codecs are supported."); throw new ArgumentException("Must specify either aac or mp3 audio codec.");
} }
/// <summary> /// <summary>

@ -52,10 +52,11 @@ namespace MediaBrowser.Api.Playback.Hls
/// <summary> /// <summary>
/// Processes the request. /// Processes the request.
/// </summary> /// </summary>
/// <param name="state">The state.</param>
/// <returns>System.Object.</returns> /// <returns>System.Object.</returns>
protected object ProcessRequest(StreamState state) protected object ProcessRequest(StreamRequest request)
{ {
var state = GetState(request);
return ProcessRequestAsync(state).Result; return ProcessRequestAsync(state).Result;
} }
@ -85,12 +86,10 @@ namespace MediaBrowser.Api.Playback.Hls
var content = Encoding.UTF8.GetBytes(playlistText); var content = Encoding.UTF8.GetBytes(playlistText);
var stream = new MemoryStream(content);
try try
{ {
Response.ContentType = MimeTypes.GetMimeType("playlist.m3u8"); Response.ContentType = MimeTypes.GetMimeType("playlist.m3u8");
return new StreamWriter(stream); return content;
} }
finally finally
{ {
@ -130,6 +129,8 @@ namespace MediaBrowser.Api.Playback.Hls
// The segement paths within the playlist are phsyical, so strip that out to make it relative // The segement paths within the playlist are phsyical, so strip that out to make it relative
fileText = fileText.Replace(Path.GetDirectoryName(playlist) + Path.DirectorySeparatorChar, string.Empty); fileText = fileText.Replace(Path.GetDirectoryName(playlist) + Path.DirectorySeparatorChar, string.Empty);
fileText = fileText.Replace(SegmentFilePrefix, "segments/");
// Even though we specify target duration of 9, ffmpeg seems unable to keep all segments under that amount // Even though we specify target duration of 9, ffmpeg seems unable to keep all segments under that amount
fileText = fileText.Replace("#EXT-X-TARGETDURATION:9", "#EXT-X-TARGETDURATION:10"); fileText = fileText.Replace("#EXT-X-TARGETDURATION:9", "#EXT-X-TARGETDURATION:10");

Loading…
Cancel
Save