@ -10,6 +10,17 @@ namespace MediaBrowser.Model.Dlna
{
public class StreamBuilder
{
private readonly ILocalPlayer _localPlayer ;
public StreamBuilder ( ILocalPlayer localPlayer )
{
_localPlayer = localPlayer ;
}
public StreamBuilder ( )
: this ( new NullLocalPlayer ( ) )
{
}
public StreamInfo BuildAudioItem ( AudioOptions options )
{
ValidateAudioInput ( options ) ;
@ -179,8 +190,16 @@ namespace MediaBrowser.Model.Dlna
}
if ( all )
{
if ( item . Protocol = = MediaProtocol . File & & _localPlayer . CanAccessFile ( item . Path ) )
{
playlistItem . PlayMethod = PlayMethod . DirectPlay ;
}
else
{
playlistItem . PlayMethod = PlayMethod . DirectStream ;
}
playlistItem . Container = item . Container ;
return playlistItem ;
@ -530,15 +549,14 @@ namespace MediaBrowser.Model.Dlna
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 ;
}