mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-07-09 03:04:24 -04:00
add more to mbt endpoints
This commit is contained in:
parent
94becdd339
commit
82ffaafc03
@ -47,6 +47,7 @@ namespace MediaBrowser.Api.DefaultTheme
|
||||
public class GamesView
|
||||
{
|
||||
public List<BaseItemDto> SpotlightItems { get; set; }
|
||||
public List<ItemStub> MultiPlayerItems { get; set; }
|
||||
}
|
||||
|
||||
public class HomeView
|
||||
|
@ -282,6 +282,14 @@ namespace MediaBrowser.Api.Playback
|
||||
string.Format(" -vf \"scale={0}:-1{1}\"", request.Width.Value, assSubtitleParam);
|
||||
}
|
||||
|
||||
// If a fixed height was requested
|
||||
if (request.Height.HasValue)
|
||||
{
|
||||
return isH264Output ?
|
||||
string.Format(" -vf \"scale={0}:trunc(oh/a/2)*2{1}\"", request.Height.Value, assSubtitleParam) :
|
||||
string.Format(" -vf \"scale=-1{1}:{0}\"", request.Height.Value, assSubtitleParam);
|
||||
}
|
||||
|
||||
// If a max width was requested
|
||||
if (request.MaxWidth.HasValue && (!request.MaxHeight.HasValue || state.VideoStream == null))
|
||||
{
|
||||
@ -290,6 +298,14 @@ namespace MediaBrowser.Api.Playback
|
||||
string.Format(" -vf \"scale=min(iw\\,{0}):-1{1}\"", request.MaxWidth.Value, assSubtitleParam);
|
||||
}
|
||||
|
||||
// If a max height was requested
|
||||
if (request.MaxHeight.HasValue && (!request.MaxWidth.HasValue || state.VideoStream == null))
|
||||
{
|
||||
return isH264Output ?
|
||||
string.Format(" -vf \"scale=min(ih\\,{0}):trunc(oh/a/2)*2{1}\"", request.MaxHeight.Value, assSubtitleParam) :
|
||||
string.Format(" -vf \"scale=min(ih\\,{0}):-1{1}\"", request.MaxHeight.Value, assSubtitleParam);
|
||||
}
|
||||
|
||||
if (state.VideoStream == null)
|
||||
{
|
||||
// No way to figure this out
|
||||
|
@ -24,6 +24,8 @@ namespace MediaBrowser.Controller.Entities
|
||||
/// </summary>
|
||||
public class Folder : BaseItem
|
||||
{
|
||||
public static IUserManager UserManager { get; set; }
|
||||
|
||||
public Folder()
|
||||
{
|
||||
LinkedChildren = new List<LinkedChild>();
|
||||
@ -89,6 +91,11 @@ namespace MediaBrowser.Controller.Entities
|
||||
item.Id = item.Path.GetMBId(item.GetType());
|
||||
}
|
||||
|
||||
if (_children.Any(i => i.Id == item.Id))
|
||||
{
|
||||
throw new ArgumentException(string.Format("A child with the Id {0} already exists.", item.Id));
|
||||
}
|
||||
|
||||
if (item.DateCreated == DateTime.MinValue)
|
||||
{
|
||||
item.DateCreated = DateTime.UtcNow;
|
||||
@ -718,17 +725,17 @@ namespace MediaBrowser.Controller.Entities
|
||||
|
||||
foreach (var item in itemsRemoved)
|
||||
{
|
||||
if (IsRootPathAvailable(item.Path))
|
||||
{
|
||||
item.IsOffline = false;
|
||||
actualRemovals.Add(item);
|
||||
}
|
||||
else
|
||||
if (IsPathOffline(item.Path))
|
||||
{
|
||||
item.IsOffline = true;
|
||||
|
||||
validChildren.Add(new Tuple<BaseItem, bool>(item, false));
|
||||
}
|
||||
else
|
||||
{
|
||||
item.IsOffline = false;
|
||||
actualRemovals.Add(item);
|
||||
}
|
||||
}
|
||||
|
||||
if (actualRemovals.Count > 0)
|
||||
@ -855,29 +862,52 @@ namespace MediaBrowser.Controller.Entities
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Determines if a path's root is available or not
|
||||
/// Determines whether the specified path is offline.
|
||||
/// </summary>
|
||||
/// <param name="path"></param>
|
||||
/// <returns></returns>
|
||||
private bool IsRootPathAvailable(string path)
|
||||
/// <param name="path">The path.</param>
|
||||
/// <returns><c>true</c> if the specified path is offline; otherwise, <c>false</c>.</returns>
|
||||
private bool IsPathOffline(string path)
|
||||
{
|
||||
if (File.Exists(path))
|
||||
{
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
var originalPath = path;
|
||||
|
||||
// Depending on whether the path is local or unc, it may return either null or '\' at the top
|
||||
while (!string.IsNullOrEmpty(path) && path.Length > 1)
|
||||
{
|
||||
if (Directory.Exists(path))
|
||||
{
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
path = System.IO.Path.GetDirectoryName(path);
|
||||
}
|
||||
|
||||
return false;
|
||||
if (ContainsPath(LibraryManager.GetDefaultVirtualFolders(), originalPath))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
return UserManager.Users.Any(user => ContainsPath(LibraryManager.GetVirtualFolders(user), originalPath));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Determines whether the specified folders contains path.
|
||||
/// </summary>
|
||||
/// <param name="folders">The folders.</param>
|
||||
/// <param name="path">The path.</param>
|
||||
/// <returns><c>true</c> if the specified folders contains path; otherwise, <c>false</c>.</returns>
|
||||
private bool ContainsPath(IEnumerable<VirtualFolderInfo> folders, string path)
|
||||
{
|
||||
return folders.SelectMany(i => i.Locations).Any(i => ContainsPath(i, path));
|
||||
}
|
||||
|
||||
private bool ContainsPath(string parent, string path)
|
||||
{
|
||||
return string.Equals(parent, path, StringComparison.OrdinalIgnoreCase) || path.IndexOf(parent.TrimEnd(System.IO.Path.DirectorySeparatorChar) + System.IO.Path.DirectorySeparatorChar, StringComparison.OrdinalIgnoreCase) != -1;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -4,7 +4,7 @@
|
||||
<Files>
|
||||
<File FileName="MediaBrowser.Server.Implementations\HttpServer\HttpServer.cs" Line="1" Column="1" />
|
||||
<File FileName="MediaBrowser.Server.Mono\FFMpeg\FFMpegDownloader.cs" Line="1" Column="1" />
|
||||
<File FileName="MediaBrowser.Server.Mono\Networking\NetworkManager.cs" Line="39" Column="1" />
|
||||
<File FileName="MediaBrowser.Server.Mono\Networking\NetworkManager.cs" Line="28" Column="9" />
|
||||
</Files>
|
||||
</MonoDevelop.Ide.Workbench>
|
||||
<MonoDevelop.Ide.DebuggingService.Breakpoints>
|
||||
|
@ -23,12 +23,8 @@ namespace MediaBrowser.ServerApplication.Networking
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Uses the DllImport : NetServerEnum with all its required parameters
|
||||
/// (see http://msdn.microsoft.com/library/default.asp?url=/library/en-us/netmgmt/netmgmt/netserverenum.asp
|
||||
/// for full details or method signature) to retrieve a list of domain SV_TYPE_WORKSTATION
|
||||
/// and SV_TYPE_SERVER PC's
|
||||
/// Gets a list of network devices
|
||||
/// </summary>
|
||||
/// <returns>Arraylist that represents all the SV_TYPE_WORKSTATION and SV_TYPE_SERVER
|
||||
/// PC's in the Domain</returns>
|
||||
public IEnumerable<string> GetNetworkDevices()
|
||||
{
|
||||
|
@ -402,6 +402,7 @@ namespace MediaBrowser.ServerApplication
|
||||
User.XmlSerializer = XmlSerializer;
|
||||
User.UserManager = UserManager;
|
||||
LocalizedStrings.ApplicationPaths = ApplicationPaths;
|
||||
Folder.UserManager = UserManager;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
Loading…
x
Reference in New Issue
Block a user