aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs')
-rw-r--r--MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs68
1 files changed, 68 insertions, 0 deletions
diff --git a/MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs b/MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs
new file mode 100644
index 000000000..10fc2ad91
--- /dev/null
+++ b/MediaBrowser.Server.Implementations/Devices/CameraUploadsFolder.cs
@@ -0,0 +1,68 @@
+using MediaBrowser.Common.Configuration;
+using MediaBrowser.Controller.Entities;
+using System.IO;
+using System.Linq;
+
+namespace MediaBrowser.Server.Implementations.Devices
+{
+ public class CameraUploadsFolder : BasePluginFolder
+ {
+ public CameraUploadsFolder()
+ {
+ Name = "Camera Uploads";
+ DisplayMediaType = "CollectionFolder";
+ }
+
+ public override bool IsVisible(User user)
+ {
+ return GetChildren(user, true).Any() &&
+ base.IsVisible(user);
+ }
+
+ public override bool IsHidden
+ {
+ get
+ {
+ return base.IsHidden || !Children.Any();
+ }
+ }
+
+ public override bool IsHiddenFromUser(User user)
+ {
+ return false;
+ }
+
+ public override string CollectionType
+ {
+ get { return Model.Entities.CollectionType.Photos; }
+ }
+
+ public override string GetClientTypeName()
+ {
+ return typeof(CollectionFolder).Name;
+ }
+ }
+
+ public class CameraUploadsDynamicFolder : IVirtualFolderCreator
+ {
+ private readonly IApplicationPaths _appPaths;
+
+ public CameraUploadsDynamicFolder(IApplicationPaths appPaths)
+ {
+ _appPaths = appPaths;
+ }
+
+ public BasePluginFolder GetFolder()
+ {
+ var path = Path.Combine(_appPaths.DataPath, "camerauploads");
+
+ Directory.CreateDirectory(path);
+
+ return new CameraUploadsFolder
+ {
+ Path = path
+ };
+ }
+ }
+
+}