IDeviceManager.cs 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. #nullable disable
  2. #pragma warning disable CS1591
  3. using System;
  4. using System.Threading.Tasks;
  5. using Jellyfin.Data.Entities;
  6. using Jellyfin.Data.Entities.Security;
  7. using Jellyfin.Data.Events;
  8. using MediaBrowser.Model.Devices;
  9. using MediaBrowser.Model.Querying;
  10. using MediaBrowser.Model.Session;
  11. namespace MediaBrowser.Controller.Devices
  12. {
  13. public interface IDeviceManager
  14. {
  15. event EventHandler<GenericEventArgs<Tuple<string, DeviceOptions>>> DeviceOptionsUpdated;
  16. /// <summary>
  17. /// Saves the capabilities.
  18. /// </summary>
  19. /// <param name="deviceId">The device id.</param>
  20. /// <param name="capabilities">The capabilities.</param>
  21. void SaveCapabilities(string deviceId, ClientCapabilities capabilities);
  22. /// <summary>
  23. /// Gets the capabilities.
  24. /// </summary>
  25. /// <param name="deviceId">The device id.</param>
  26. /// <returns>ClientCapabilities.</returns>
  27. ClientCapabilities GetCapabilities(string deviceId);
  28. /// <summary>
  29. /// Gets the device information.
  30. /// </summary>
  31. /// <param name="id">The identifier.</param>
  32. /// <returns>DeviceInfo.</returns>
  33. Task<DeviceInfo> GetDevice(string id);
  34. /// <summary>
  35. /// Gets the devices.
  36. /// </summary>
  37. /// <param name="userId">The user's id, or <c>null</c>.</param>
  38. /// <param name="supportsSync">A value indicating whether the device supports sync, or <c>null</c>.</param>
  39. /// <returns>IEnumerable&lt;DeviceInfo&gt;.</returns>
  40. Task<QueryResult<DeviceInfo>> GetDevicesForUser(Guid? userId, bool? supportsSync);
  41. /// <summary>
  42. /// Determines whether this instance [can access device] the specified user identifier.
  43. /// </summary>
  44. bool CanAccessDevice(User user, string deviceId);
  45. Task UpdateDeviceOptions(string deviceId, DeviceOptions options);
  46. Task<DeviceOptions> GetDeviceOptions(string deviceId);
  47. }
  48. }