aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Api/ConnectService.cs
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2015-03-19 13:21:35 -0400
committerLuke <luke.pulverenti@gmail.com>2015-03-19 13:21:35 -0400
commit9926be0d9de688c04065c916e44ada4177b38a80 (patch)
tree15338144a143948ffbee316641757e81489a7354 /MediaBrowser.Api/ConnectService.cs
parentb756e677d733992c2033bdd369980a37e17609e4 (diff)
parent0564d454e5ad4f59702aa9022af6bb8fd064a9ff (diff)
Merge pull request #1043 from MediaBrowser/dev
3.0.5557.0
Diffstat (limited to 'MediaBrowser.Api/ConnectService.cs')
-rw-r--r--MediaBrowser.Api/ConnectService.cs55
1 files changed, 54 insertions, 1 deletions
diff --git a/MediaBrowser.Api/ConnectService.cs b/MediaBrowser.Api/ConnectService.cs
index 4bcd33d9e..bdd2eeaad 100644
--- a/MediaBrowser.Api/ConnectService.cs
+++ b/MediaBrowser.Api/ConnectService.cs
@@ -1,8 +1,10 @@
-using MediaBrowser.Common.Extensions;
+using System;
+using MediaBrowser.Common.Extensions;
using MediaBrowser.Controller.Connect;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Net;
using MediaBrowser.Model.Connect;
+using MediaBrowser.Model.Dto;
using ServiceStack;
using System.Collections.Generic;
using System.Linq;
@@ -73,6 +75,28 @@ namespace MediaBrowser.Api
public string ConnectUserId { get; set; }
}
+ [Route("/Connect/Supporters", "GET")]
+ [Authenticated(Roles = "Admin")]
+ public class GetConnectSupporterSummary : IReturn<ConnectSupporterSummary>
+ {
+ }
+
+ [Route("/Connect/Supporters", "DELETE")]
+ [Authenticated(Roles = "Admin")]
+ public class RemoveConnectSupporter : IReturnVoid
+ {
+ [ApiMember(Name = "Id", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "DELETE")]
+ public string Id { get; set; }
+ }
+
+ [Route("/Connect/Supporters", "POST")]
+ [Authenticated(Roles = "Admin")]
+ public class AddConnectSupporter : IReturnVoid
+ {
+ [ApiMember(Name = "Id", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")]
+ public string Id { get; set; }
+ }
+
public class ConnectService : BaseApiService
{
private readonly IConnectManager _connectManager;
@@ -84,6 +108,35 @@ namespace MediaBrowser.Api
_userManager = userManager;
}
+ public async Task<object> Get(GetConnectSupporterSummary request)
+ {
+ var result = await _connectManager.GetConnectSupporterSummary().ConfigureAwait(false);
+ var existingConnectUserIds = result.Users.Select(i => i.Id).ToList();
+
+ result.EligibleUsers = _userManager.Users
+ .Where(i => !string.IsNullOrWhiteSpace(i.ConnectUserId))
+ .Where(i => !existingConnectUserIds.Contains(i.ConnectUserId, StringComparer.OrdinalIgnoreCase))
+ .OrderBy(i => i.Name)
+ .Select(i => _userManager.GetUserDto(i))
+ .ToList();
+
+ return ToOptimizedResult(result);
+ }
+
+ public void Delete(RemoveConnectSupporter request)
+ {
+ var task = _connectManager.RemoveConnectSupporter(request.Id);
+
+ Task.WaitAll(task);
+ }
+
+ public void Post(AddConnectSupporter request)
+ {
+ var task = _connectManager.AddConnectSupporter(request.Id);
+
+ Task.WaitAll(task);
+ }
+
public object Post(CreateConnectLink request)
{
return _connectManager.LinkUser(request.Id, request.ConnectUsername);