|
@@ -18,6 +18,9 @@ using System.IO;
|
|
using System.Linq;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using System.Threading.Tasks;
|
|
using CommonIO;
|
|
using CommonIO;
|
|
|
|
+using MediaBrowser.Controller.Configuration;
|
|
|
|
+using MediaBrowser.Controller.Plugins;
|
|
|
|
+using MediaBrowser.Model.Entities;
|
|
|
|
|
|
namespace MediaBrowser.Server.Implementations.Devices
|
|
namespace MediaBrowser.Server.Implementations.Devices
|
|
{
|
|
{
|
|
@@ -27,7 +30,7 @@ namespace MediaBrowser.Server.Implementations.Devices
|
|
private readonly IUserManager _userManager;
|
|
private readonly IUserManager _userManager;
|
|
private readonly IFileSystem _fileSystem;
|
|
private readonly IFileSystem _fileSystem;
|
|
private readonly ILibraryMonitor _libraryMonitor;
|
|
private readonly ILibraryMonitor _libraryMonitor;
|
|
- private readonly IConfigurationManager _config;
|
|
|
|
|
|
+ private readonly IServerConfigurationManager _config;
|
|
private readonly ILogger _logger;
|
|
private readonly ILogger _logger;
|
|
private readonly INetworkManager _network;
|
|
private readonly INetworkManager _network;
|
|
|
|
|
|
@@ -38,7 +41,7 @@ namespace MediaBrowser.Server.Implementations.Devices
|
|
/// </summary>
|
|
/// </summary>
|
|
public event EventHandler<GenericEventArgs<DeviceInfo>> DeviceOptionsUpdated;
|
|
public event EventHandler<GenericEventArgs<DeviceInfo>> DeviceOptionsUpdated;
|
|
|
|
|
|
- public DeviceManager(IDeviceRepository repo, IUserManager userManager, IFileSystem fileSystem, ILibraryMonitor libraryMonitor, IConfigurationManager config, ILogger logger, INetworkManager network)
|
|
|
|
|
|
+ public DeviceManager(IDeviceRepository repo, IUserManager userManager, IFileSystem fileSystem, ILibraryMonitor libraryMonitor, IServerConfigurationManager config, ILogger logger, INetworkManager network)
|
|
{
|
|
{
|
|
_repo = repo;
|
|
_repo = repo;
|
|
_userManager = userManager;
|
|
_userManager = userManager;
|
|
@@ -187,11 +190,6 @@ namespace MediaBrowser.Server.Implementations.Devices
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
- private string GetUploadPath(string deviceId)
|
|
|
|
- {
|
|
|
|
- return GetUploadPath(GetDevice(deviceId));
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
private string GetUploadPath(DeviceInfo device)
|
|
private string GetUploadPath(DeviceInfo device)
|
|
{
|
|
{
|
|
if (!string.IsNullOrWhiteSpace(device.CameraUploadPath))
|
|
if (!string.IsNullOrWhiteSpace(device.CameraUploadPath))
|
|
@@ -205,16 +203,81 @@ namespace MediaBrowser.Server.Implementations.Devices
|
|
return config.CameraUploadPath;
|
|
return config.CameraUploadPath;
|
|
}
|
|
}
|
|
|
|
|
|
- var path = Path.Combine(_config.CommonApplicationPaths.DataPath, "camerauploads");
|
|
|
|
|
|
+ var path = DefaultCameraUploadsPath;
|
|
|
|
|
|
if (config.EnableCameraUploadSubfolders)
|
|
if (config.EnableCameraUploadSubfolders)
|
|
{
|
|
{
|
|
path = Path.Combine(path, _fileSystem.GetValidFilename(device.Name));
|
|
path = Path.Combine(path, _fileSystem.GetValidFilename(device.Name));
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ EnsureMediaLibrarySetup();
|
|
|
|
+
|
|
return path;
|
|
return path;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ private string DefaultCameraUploadsPath
|
|
|
|
+ {
|
|
|
|
+ get { return Path.Combine(_config.CommonApplicationPaths.DataPath, "camerauploads"); }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ internal void EnsureMediaLibrarySetup()
|
|
|
|
+ {
|
|
|
|
+ //EnsureMediaLibrarySetup(DefaultCameraUploadsPath, false);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ private void EnsureMediaLibrarySetup(string libraryPath, bool force)
|
|
|
|
+ {
|
|
|
|
+ var requiresSetup = false;
|
|
|
|
+
|
|
|
|
+ var path = Path.Combine(_config.ApplicationPaths.DefaultUserViewsPath, "Camera Uploads");
|
|
|
|
+
|
|
|
|
+ var collectionMarkerFile = Path.Combine(path, CollectionType.Photos + ".collection");
|
|
|
|
+ if (!_fileSystem.FileExists(collectionMarkerFile))
|
|
|
|
+ {
|
|
|
|
+ requiresSetup = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ var shortcutFile = Path.Combine(path, "camerauploads.mblink");
|
|
|
|
+ try
|
|
|
|
+ {
|
|
|
|
+ if (!string.Equals(_fileSystem.ReadAllText(shortcutFile), libraryPath))
|
|
|
|
+ {
|
|
|
|
+ requiresSetup = true;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ catch
|
|
|
|
+ {
|
|
|
|
+ requiresSetup = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (requiresSetup)
|
|
|
|
+ {
|
|
|
|
+ if (!force)
|
|
|
|
+ {
|
|
|
|
+ var extensions = new[] { ".jpg", ".png" };
|
|
|
|
+ var hasPhotos = _fileSystem.GetFiles(libraryPath, true).Any(i => extensions.Contains(i.Extension, StringComparer.OrdinalIgnoreCase));
|
|
|
|
+
|
|
|
|
+ // Nothing to do
|
|
|
|
+ if (!hasPhotos)
|
|
|
|
+ {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (requiresSetup)
|
|
|
|
+ {
|
|
|
|
+ Directory.CreateDirectory(path);
|
|
|
|
+
|
|
|
|
+ using (File.Create(collectionMarkerFile))
|
|
|
|
+ {
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ _fileSystem.CreateShortcut(shortcutFile, libraryPath);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
public async Task UpdateDeviceInfo(string id, DeviceOptions options)
|
|
public async Task UpdateDeviceInfo(string id, DeviceOptions options)
|
|
{
|
|
{
|
|
var device = GetDevice(id);
|
|
var device = GetDevice(id);
|
|
@@ -274,6 +337,25 @@ namespace MediaBrowser.Server.Implementations.Devices
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ public class DeviceManagerEntryPoint : IServerEntryPoint
|
|
|
|
+ {
|
|
|
|
+ private readonly IDeviceManager _deviceManager;
|
|
|
|
+
|
|
|
|
+ public DeviceManagerEntryPoint(IDeviceManager deviceManager)
|
|
|
|
+ {
|
|
|
|
+ _deviceManager = deviceManager;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void Run()
|
|
|
|
+ {
|
|
|
|
+ ((DeviceManager)_deviceManager).EnsureMediaLibrarySetup();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void Dispose()
|
|
|
|
+ {
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
public class DevicesConfigStore : IConfigurationFactory
|
|
public class DevicesConfigStore : IConfigurationFactory
|
|
{
|
|
{
|
|
public IEnumerable<ConfigurationStore> GetConfigurations()
|
|
public IEnumerable<ConfigurationStore> GetConfigurations()
|