@ -10,6 +10,17 @@ namespace MediaBrowser.Model.Dlna
{
{
public class StreamBuilder
public class StreamBuilder
{
{
private readonly ILocalPlayer _localPlayer ;
public StreamBuilder ( ILocalPlayer localPlayer )
{
_localPlayer = localPlayer ;
}
public StreamBuilder ( )
: this ( new NullLocalPlayer ( ) )
{
}
public StreamInfo BuildAudioItem ( AudioOptions options )
public StreamInfo BuildAudioItem ( AudioOptions options )
{
{
ValidateAudioInput ( options ) ;
ValidateAudioInput ( options ) ;
@ -73,7 +84,7 @@ namespace MediaBrowser.Model.Dlna
StreamInfo streamInfo = BuildVideoItem ( i , options ) ;
StreamInfo streamInfo = BuildVideoItem ( i , options ) ;
if ( streamInfo ! = null )
if ( streamInfo ! = null )
{
{
streams . Add ( streamInfo ) ;
streams . Add ( streamInfo ) ;
}
}
}
}
@ -180,7 +191,15 @@ namespace MediaBrowser.Model.Dlna
if ( all )
if ( all )
{
{
playlistItem . PlayMethod = PlayMethod . DirectStream ;
if ( item . Protocol = = MediaProtocol . File & & _localPlayer . CanAccessFile ( item . Path ) )
{
playlistItem . PlayMethod = PlayMethod . DirectPlay ;
}
else
{
playlistItem . PlayMethod = PlayMethod . DirectStream ;
}
playlistItem . Container = item . Container ;
playlistItem . Container = item . Container ;
return playlistItem ;
return playlistItem ;
@ -530,15 +549,14 @@ namespace MediaBrowser.Model.Dlna
if ( mediaSource . Protocol = = MediaProtocol . Http )
if ( mediaSource . Protocol = = MediaProtocol . Http )
{
{
if ( ! options . SupportsDirectRemoteContent )
if ( _localPlayer . CanAccessUrl ( mediaSource . Path , mediaSource . RequiredHttpHeaders . Count > 0 ) )
{
{
return null ;
return PlayMethod . DirectPlay ;
}
}
}
if ( mediaSource . RequiredHttpHeaders . Count > 0 & & ! options . SupportsCustomHttpHeaders )
else if ( mediaSource . Protocol = = MediaProtocol . File & & _localPlayer . CanAccessFile ( mediaSource . Path ) )
{
{
return null ;
}
return PlayMethod . DirectPlay ;
return PlayMethod . DirectPlay ;
}
}