Remove IIsoMounter and IsoMounter
This commit is contained in:
parent
ea20f05de4
commit
ca5c20c988
|
@ -538,8 +538,6 @@ namespace Emby.Server.Implementations
|
||||||
|
|
||||||
ServiceCollection.AddSingleton(NetManager);
|
ServiceCollection.AddSingleton(NetManager);
|
||||||
|
|
||||||
ServiceCollection.AddSingleton<IIsoManager, IsoManager>();
|
|
||||||
|
|
||||||
ServiceCollection.AddSingleton<ITaskManager, TaskManager>();
|
ServiceCollection.AddSingleton<ITaskManager, TaskManager>();
|
||||||
|
|
||||||
ServiceCollection.AddSingleton(_xmlSerializer);
|
ServiceCollection.AddSingleton(_xmlSerializer);
|
||||||
|
@ -820,8 +818,6 @@ namespace Emby.Server.Implementations
|
||||||
Resolve<IMediaSourceManager>().AddParts(GetExports<IMediaSourceProvider>());
|
Resolve<IMediaSourceManager>().AddParts(GetExports<IMediaSourceProvider>());
|
||||||
|
|
||||||
Resolve<INotificationManager>().AddParts(GetExports<INotificationService>(), GetExports<INotificationTypeFactory>());
|
Resolve<INotificationManager>().AddParts(GetExports<INotificationService>(), GetExports<INotificationTypeFactory>());
|
||||||
|
|
||||||
Resolve<IIsoManager>().AddParts(GetExports<IIsoMounter>());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|
|
@ -1,67 +0,0 @@
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Globalization;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Threading;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using MediaBrowser.Model.IO;
|
|
||||||
|
|
||||||
namespace Emby.Server.Implementations.IO
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Class IsoManager.
|
|
||||||
/// </summary>
|
|
||||||
public class IsoManager : IIsoManager
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// The _mounters.
|
|
||||||
/// </summary>
|
|
||||||
private readonly List<IIsoMounter> _mounters = new List<IIsoMounter>();
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Mounts the specified iso path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="isoPath">The iso path.</param>
|
|
||||||
/// <param name="cancellationToken">The cancellation token.</param>
|
|
||||||
/// <returns><see creaf="IsoMount" />.</returns>
|
|
||||||
public Task<IIsoMount> Mount(string isoPath, CancellationToken cancellationToken)
|
|
||||||
{
|
|
||||||
if (string.IsNullOrEmpty(isoPath))
|
|
||||||
{
|
|
||||||
throw new ArgumentNullException(nameof(isoPath));
|
|
||||||
}
|
|
||||||
|
|
||||||
var mounter = _mounters.FirstOrDefault(i => i.CanMount(isoPath));
|
|
||||||
|
|
||||||
if (mounter == null)
|
|
||||||
{
|
|
||||||
throw new ArgumentException(
|
|
||||||
string.Format(
|
|
||||||
CultureInfo.InvariantCulture,
|
|
||||||
"No mounters are able to mount {0}",
|
|
||||||
isoPath));
|
|
||||||
}
|
|
||||||
|
|
||||||
return mounter.Mount(isoPath, cancellationToken);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Determines whether this instance can mount the specified path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="path">The path.</param>
|
|
||||||
/// <returns><c>true</c> if this instance can mount the specified path; otherwise, <c>false</c>.</returns>
|
|
||||||
public bool CanMount(string path)
|
|
||||||
{
|
|
||||||
return _mounters.Any(i => i.CanMount(path));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Adds the parts.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="mounters">The mounters.</param>
|
|
||||||
public void AddParts(IEnumerable<IIsoMounter> mounters)
|
|
||||||
{
|
|
||||||
_mounters.AddRange(mounters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -12,7 +12,6 @@ using Jellyfin.Api.Models.PlaybackDtos;
|
||||||
using Jellyfin.Api.Models.StreamingDtos;
|
using Jellyfin.Api.Models.StreamingDtos;
|
||||||
using Jellyfin.Data.Enums;
|
using Jellyfin.Data.Enums;
|
||||||
using MediaBrowser.Common.Configuration;
|
using MediaBrowser.Common.Configuration;
|
||||||
using MediaBrowser.Common.Extensions;
|
|
||||||
using MediaBrowser.Controller.Configuration;
|
using MediaBrowser.Controller.Configuration;
|
||||||
using MediaBrowser.Controller.Library;
|
using MediaBrowser.Controller.Library;
|
||||||
using MediaBrowser.Controller.MediaEncoding;
|
using MediaBrowser.Controller.MediaEncoding;
|
||||||
|
@ -46,7 +45,6 @@ namespace Jellyfin.Api.Helpers
|
||||||
private readonly IAuthorizationContext _authorizationContext;
|
private readonly IAuthorizationContext _authorizationContext;
|
||||||
private readonly EncodingHelper _encodingHelper;
|
private readonly EncodingHelper _encodingHelper;
|
||||||
private readonly IFileSystem _fileSystem;
|
private readonly IFileSystem _fileSystem;
|
||||||
private readonly IIsoManager _isoManager;
|
|
||||||
private readonly ILogger<TranscodingJobHelper> _logger;
|
private readonly ILogger<TranscodingJobHelper> _logger;
|
||||||
private readonly IMediaEncoder _mediaEncoder;
|
private readonly IMediaEncoder _mediaEncoder;
|
||||||
private readonly IMediaSourceManager _mediaSourceManager;
|
private readonly IMediaSourceManager _mediaSourceManager;
|
||||||
|
@ -64,7 +62,6 @@ namespace Jellyfin.Api.Helpers
|
||||||
/// <param name="serverConfigurationManager">Instance of the <see cref="IServerConfigurationManager"/> interface.</param>
|
/// <param name="serverConfigurationManager">Instance of the <see cref="IServerConfigurationManager"/> interface.</param>
|
||||||
/// <param name="sessionManager">Instance of the <see cref="ISessionManager"/> interface.</param>
|
/// <param name="sessionManager">Instance of the <see cref="ISessionManager"/> interface.</param>
|
||||||
/// <param name="authorizationContext">Instance of the <see cref="IAuthorizationContext"/> interface.</param>
|
/// <param name="authorizationContext">Instance of the <see cref="IAuthorizationContext"/> interface.</param>
|
||||||
/// <param name="isoManager">Instance of the <see cref="IIsoManager"/> interface.</param>
|
|
||||||
/// <param name="subtitleEncoder">Instance of the <see cref="ISubtitleEncoder"/> interface.</param>
|
/// <param name="subtitleEncoder">Instance of the <see cref="ISubtitleEncoder"/> interface.</param>
|
||||||
/// <param name="configuration">Instance of the <see cref="IConfiguration"/> interface.</param>
|
/// <param name="configuration">Instance of the <see cref="IConfiguration"/> interface.</param>
|
||||||
/// <param name="loggerFactory">Instance of the <see cref="ILoggerFactory"/> interface.</param>
|
/// <param name="loggerFactory">Instance of the <see cref="ILoggerFactory"/> interface.</param>
|
||||||
|
@ -76,7 +73,6 @@ namespace Jellyfin.Api.Helpers
|
||||||
IServerConfigurationManager serverConfigurationManager,
|
IServerConfigurationManager serverConfigurationManager,
|
||||||
ISessionManager sessionManager,
|
ISessionManager sessionManager,
|
||||||
IAuthorizationContext authorizationContext,
|
IAuthorizationContext authorizationContext,
|
||||||
IIsoManager isoManager,
|
|
||||||
ISubtitleEncoder subtitleEncoder,
|
ISubtitleEncoder subtitleEncoder,
|
||||||
IConfiguration configuration,
|
IConfiguration configuration,
|
||||||
ILoggerFactory loggerFactory)
|
ILoggerFactory loggerFactory)
|
||||||
|
@ -88,7 +84,6 @@ namespace Jellyfin.Api.Helpers
|
||||||
_serverConfigurationManager = serverConfigurationManager;
|
_serverConfigurationManager = serverConfigurationManager;
|
||||||
_sessionManager = sessionManager;
|
_sessionManager = sessionManager;
|
||||||
_authorizationContext = authorizationContext;
|
_authorizationContext = authorizationContext;
|
||||||
_isoManager = isoManager;
|
|
||||||
_loggerFactory = loggerFactory;
|
_loggerFactory = loggerFactory;
|
||||||
_encodingHelper = new EncodingHelper(mediaEncoder, fileSystem, subtitleEncoder, configuration);
|
_encodingHelper = new EncodingHelper(mediaEncoder, fileSystem, subtitleEncoder, configuration);
|
||||||
|
|
||||||
|
|
|
@ -117,6 +117,6 @@ namespace MediaBrowser.Controller.MediaEncoding
|
||||||
|
|
||||||
void UpdateEncoderPath(string path, string pathType);
|
void UpdateEncoderPath(string path, string pathType);
|
||||||
|
|
||||||
IEnumerable<string> GetPrimaryPlaylistVobFiles(string path, IIsoMount isoMount, uint? titleNumber);
|
IEnumerable<string> GetPrimaryPlaylistVobFiles(string path, uint? titleNumber);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -949,16 +949,14 @@ namespace MediaBrowser.MediaEncoding.Encoder
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
public IEnumerable<string> GetPrimaryPlaylistVobFiles(string path, IIsoMount isoMount, uint? titleNumber)
|
public IEnumerable<string> GetPrimaryPlaylistVobFiles(string path, uint? titleNumber)
|
||||||
{
|
{
|
||||||
// min size 300 mb
|
// min size 300 mb
|
||||||
const long MinPlayableSize = 314572800;
|
const long MinPlayableSize = 314572800;
|
||||||
|
|
||||||
var root = isoMount != null ? isoMount.MountedPath : path;
|
|
||||||
|
|
||||||
// Try to eliminate menus and intros by skipping all files at the front of the list that are less than the minimum size
|
// Try to eliminate menus and intros by skipping all files at the front of the list that are less than the minimum size
|
||||||
// Once we reach a file that is at least the minimum, return all subsequent ones
|
// Once we reach a file that is at least the minimum, return all subsequent ones
|
||||||
var allVobs = _fileSystem.GetFiles(root, true)
|
var allVobs = _fileSystem.GetFiles(path, true)
|
||||||
.Where(file => string.Equals(file.Extension, ".vob", StringComparison.OrdinalIgnoreCase))
|
.Where(file => string.Equals(file.Extension, ".vob", StringComparison.OrdinalIgnoreCase))
|
||||||
.OrderBy(i => i.FullName)
|
.OrderBy(i => i.FullName)
|
||||||
.ToList();
|
.ToList();
|
||||||
|
|
|
@ -1,35 +0,0 @@
|
||||||
#pragma warning disable CS1591
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Threading;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Model.IO
|
|
||||||
{
|
|
||||||
public interface IIsoManager
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Mounts the specified iso path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="isoPath">The iso path.</param>
|
|
||||||
/// <param name="cancellationToken">The cancellation token.</param>
|
|
||||||
/// <returns>IsoMount.</returns>
|
|
||||||
/// <exception cref="IOException">Unable to create mount.</exception>
|
|
||||||
Task<IIsoMount> Mount(string isoPath, CancellationToken cancellationToken);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Determines whether this instance can mount the specified path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="path">The path.</param>
|
|
||||||
/// <returns><c>true</c> if this instance can mount the specified path; otherwise, <c>false</c>.</returns>
|
|
||||||
bool CanMount(string path);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Adds the parts.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="mounters">The mounters.</param>
|
|
||||||
void AddParts(IEnumerable<IIsoMounter> mounters);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,22 +0,0 @@
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Model.IO
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Interface IIsoMount.
|
|
||||||
/// </summary>
|
|
||||||
public interface IIsoMount : IDisposable
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the iso path.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The iso path.</value>
|
|
||||||
string IsoPath { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the mounted path.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The mounted path.</value>
|
|
||||||
string MountedPath { get; }
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,35 +0,0 @@
|
||||||
#pragma warning disable CS1591
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.IO;
|
|
||||||
using System.Threading;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Model.IO
|
|
||||||
{
|
|
||||||
public interface IIsoMounter
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the name.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The name.</value>
|
|
||||||
string Name { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Mounts the specified iso path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="isoPath">The iso path.</param>
|
|
||||||
/// <param name="cancellationToken">The cancellation token.</param>
|
|
||||||
/// <returns>IsoMount.</returns>
|
|
||||||
/// <exception cref="ArgumentNullException">isoPath</exception>
|
|
||||||
/// <exception cref="IOException">Unable to create mount.</exception>
|
|
||||||
Task<IIsoMount> Mount(string isoPath, CancellationToken cancellationToken);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Determines whether this instance can mount the specified path.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="path">The path.</param>
|
|
||||||
/// <returns><c>true</c> if this instance can mount the specified path; otherwise, <c>false</c>.</returns>
|
|
||||||
bool CanMount(string path);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -619,7 +619,7 @@ namespace MediaBrowser.Providers.MediaInfo
|
||||||
item.RunTimeTicks = GetRuntime(primaryTitle);
|
item.RunTimeTicks = GetRuntime(primaryTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
return _mediaEncoder.GetPrimaryPlaylistVobFiles(item.Path, null, titleNumber)
|
return _mediaEncoder.GetPrimaryPlaylistVobFiles(item.Path, titleNumber)
|
||||||
.Select(Path.GetFileName)
|
.Select(Path.GetFileName)
|
||||||
.ToArray();
|
.ToArray();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user