aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Controller/QuickConnect/IQuickConnect.cs
blob: d44765e1125381f72319da060883fc91310e8cc9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
using System;
using System.Collections.Generic;
using MediaBrowser.Model.QuickConnect;
using MediaBrowser.Model.Services;

namespace MediaBrowser.Controller.QuickConnect
{
    /// <summary>
    /// Quick connect standard interface.
    /// </summary>
    public interface IQuickConnect
    {
        /// <summary>
        /// Gets or sets the length of user facing codes.
        /// </summary>
        public int CodeLength { get; set; }

        /// <summary>
        /// Gets or sets the string to prefix internal access tokens with.
        /// </summary>
        public string TokenNamePrefix { get; set; }

        /// <summary>
        /// Gets the current state of quick connect.
        /// </summary>
        public QuickConnectState State { get; }

        /// <summary>
        /// Gets or sets the time (in minutes) before a pending request will expire.
        /// </summary>
        public int RequestExpiry { get; set; }

        /// <summary>
        /// Assert that quick connect is currently active and throws an exception if it is not.
        /// </summary>
        void AssertActive();

        /// <summary>
        /// Temporarily activates quick connect for a short amount of time.
        /// </summary>
        /// <returns>A quick connect result object indicating success.</returns>
        QuickConnectResult Activate();

        /// <summary>
        /// Changes the status of quick connect.
        /// </summary>
        /// <param name="newState">New state to change to.</param>
        void SetEnabled(QuickConnectState newState);

        /// <summary>
        /// Initiates a new quick connect request.
        /// </summary>
        /// <param name="friendlyName">Friendly device name to display in the request UI.</param>
        /// <returns>A quick connect result with tokens to proceed or a descriptive error message otherwise.</returns>
        QuickConnectResult TryConnect(string friendlyName);

        /// <summary>
        /// Checks the status of an individual request.
        /// </summary>
        /// <param name="secret">Unique secret identifier of the request.</param>
        /// <returns>Quick connect result.</returns>
        QuickConnectResult CheckRequestStatus(string secret);

        /// <summary>
        /// Returns all current quick connect requests as DTOs. Does not include sensitive information.
        /// </summary>
        /// <returns>List of all quick connect results.</returns>
        List<QuickConnectResultDto> GetCurrentRequests();

        /// <summary>
        /// Returns all current quick connect requests (including sensitive information).
        /// </summary>
        /// <returns>List of all quick connect results.</returns>
        List<QuickConnectResult> GetCurrentRequestsInternal();

        /// <summary>
        /// Authorizes a quick connect request to connect as the calling user.
        /// </summary>
        /// <param name="request">HTTP request object.</param>
        /// <param name="lookup">Public request lookup value.</param>
        /// <returns>A boolean indicating if the authorization completed successfully.</returns>
        bool AuthorizeRequest(IRequest request, string lookup);

        /// <summary>
        /// Deletes all quick connect access tokens for the provided user.
        /// </summary>
        /// <param name="user">Guid of the user to delete tokens for.</param>
        /// <returns>A count of the deleted tokens.</returns>
        int DeleteAllDevices(Guid user);

        /// <summary>
        /// Generates a short code to display to the user to uniquely identify this request.
        /// </summary>
        /// <returns>A short, unique alphanumeric string.</returns>
        string GenerateCode();
    }
}