فهرست منبع

add more to mbt endpoints

Luke Pulverenti 11 سال پیش
والد
کامیت
82ffaafc03

+ 1 - 0
MediaBrowser.Api/DefaultTheme/Models.cs

@@ -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

+ 16 - 0
MediaBrowser.Api/Playback/BaseStreamingService.cs

@@ -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

+ 43 - 13
MediaBrowser.Controller/Entities/Folder.cs

@@ -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>

+ 1 - 1
MediaBrowser.Mono.userprefs

@@ -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>

+ 1 - 5
MediaBrowser.Server.Mono/Networking/NetworkManager.cs

@@ -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()
         {

+ 1 - 0
MediaBrowser.ServerApplication/ApplicationHost.cs

@@ -402,6 +402,7 @@ namespace MediaBrowser.ServerApplication
             User.XmlSerializer = XmlSerializer;
             User.UserManager = UserManager;
             LocalizedStrings.ApplicationPaths = ApplicationPaths;
+            Folder.UserManager = UserManager;
         }
 
         /// <summary>