IQuickConnect.cs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. using System;
  2. using System.Collections.Generic;
  3. using MediaBrowser.Model.QuickConnect;
  4. using MediaBrowser.Model.Services;
  5. namespace MediaBrowser.Controller.QuickConnect
  6. {
  7. /// <summary>
  8. /// Quick connect standard interface.
  9. /// </summary>
  10. public interface IQuickConnect
  11. {
  12. /// <summary>
  13. /// Gets or sets the length of user facing codes.
  14. /// </summary>
  15. public int CodeLength { get; set; }
  16. /// <summary>
  17. /// Gets or sets the string to prefix internal access tokens with.
  18. /// </summary>
  19. public string TokenNamePrefix { get; set; }
  20. /// <summary>
  21. /// Gets the current state of quick connect.
  22. /// </summary>
  23. public QuickConnectState State { get; }
  24. /// <summary>
  25. /// Gets or sets the time (in minutes) before a pending request will expire.
  26. /// </summary>
  27. public int RequestExpiry { get; set; }
  28. /// <summary>
  29. /// Assert that quick connect is currently active and throws an exception if it is not.
  30. /// </summary>
  31. void AssertActive();
  32. /// <summary>
  33. /// Temporarily activates quick connect for a short amount of time.
  34. /// </summary>
  35. /// <returns>A quick connect result object indicating success.</returns>
  36. QuickConnectResult Activate();
  37. /// <summary>
  38. /// Changes the status of quick connect.
  39. /// </summary>
  40. /// <param name="newState">New state to change to.</param>
  41. void SetEnabled(QuickConnectState newState);
  42. /// <summary>
  43. /// Initiates a new quick connect request.
  44. /// </summary>
  45. /// <param name="friendlyName">Friendly device name to display in the request UI.</param>
  46. /// <returns>A quick connect result with tokens to proceed or a descriptive error message otherwise.</returns>
  47. QuickConnectResult TryConnect(string friendlyName);
  48. /// <summary>
  49. /// Checks the status of an individual request.
  50. /// </summary>
  51. /// <param name="secret">Unique secret identifier of the request.</param>
  52. /// <returns>Quick connect result.</returns>
  53. QuickConnectResult CheckRequestStatus(string secret);
  54. /// <summary>
  55. /// Returns all current quick connect requests as DTOs. Does not include sensitive information.
  56. /// </summary>
  57. /// <returns>List of all quick connect results.</returns>
  58. List<QuickConnectResultDto> GetCurrentRequests();
  59. /// <summary>
  60. /// Returns all current quick connect requests (including sensitive information).
  61. /// </summary>
  62. /// <returns>List of all quick connect results.</returns>
  63. List<QuickConnectResult> GetCurrentRequestsInternal();
  64. /// <summary>
  65. /// Authorizes a quick connect request to connect as the calling user.
  66. /// </summary>
  67. /// <param name="request">HTTP request object.</param>
  68. /// <param name="lookup">Public request lookup value.</param>
  69. /// <returns>A boolean indicating if the authorization completed successfully.</returns>
  70. bool AuthorizeRequest(IRequest request, string lookup);
  71. /// <summary>
  72. /// Deletes all quick connect access tokens for the provided user.
  73. /// </summary>
  74. /// <param name="user">Guid of the user to delete tokens for.</param>
  75. /// <returns>A count of the deleted tokens.</returns>
  76. int DeleteAllDevices(Guid user);
  77. /// <summary>
  78. /// Generates a short code to display to the user to uniquely identify this request.
  79. /// </summary>
  80. /// <returns>A short, unique alphanumeric string.</returns>
  81. string GenerateCode();
  82. }
  83. }