From f1a602f5a87f666eec03b9afd3f3edfa27d337f6 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Sat, 18 Oct 2014 15:02:54 -0400 Subject: disable nuget package restore --- .gitignore | 5 +- MediaBrowser.Api/ConnectService.cs | 41 +++++++++++- MediaBrowser.Api/MediaBrowser.Api.csproj | 1 - .../MediaBrowser.Common.Implementations.csproj | 2 - MediaBrowser.Common/MediaBrowser.Common.csproj | 2 - .../MediaBrowser.Controller.csproj | 2 - .../MediaBrowser.MediaEncoding.csproj | 2 - .../MediaBrowser.Model.Portable.csproj | 5 +- .../MediaBrowser.Model.net35.csproj | 5 +- MediaBrowser.Model/ApiClient/ServerCredentials.cs | 27 +++++++- .../Configuration/ServerConfiguration.cs | 1 - .../Connect/ConnectAuthenticationExchangeResult.cs | 17 +++++ MediaBrowser.Model/MediaBrowser.Model.csproj | 3 +- .../MediaBrowser.Providers.csproj | 2 - .../HttpServer/Security/AuthService.cs | 15 ++++- .../Localization/JavaScript/de.json | 30 ++++----- .../Localization/JavaScript/fr.json | 10 +-- .../Localization/JavaScript/kk.json | 12 ++-- .../Localization/JavaScript/ru.json | 8 +-- .../Localization/Server/de.json | 76 +++++++++++----------- .../Localization/Server/fr.json | 20 +++--- .../Localization/Server/kk.json | 40 ++++++------ .../Localization/Server/ru.json | 16 ++--- .../MediaBrowser.Server.Implementations.csproj | 2 - .../MediaBrowser.Server.Mono.csproj | 8 --- .../MediaBrowser.ServerApplication.csproj | 2 - .../MediaBrowser.WebDashboard.csproj | 2 - Nuget/MediaBrowser.Common.Internal.nuspec | 4 +- Nuget/MediaBrowser.Common.nuspec | 2 +- Nuget/MediaBrowser.Model.Signed.nuspec | 2 +- Nuget/MediaBrowser.Server.Core.nuspec | 4 +- OpenSubtitlesHandler/OpenSubtitlesHandler.csproj | 1 - 32 files changed, 218 insertions(+), 151 deletions(-) create mode 100644 MediaBrowser.Model/Connect/ConnectAuthenticationExchangeResult.cs diff --git a/.gitignore b/.gitignore index f1b81038b..673f15dfe 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ +!* + ################# ## Eclipse ################# @@ -145,8 +147,9 @@ publish/ # NuGet Packages Directory ## TODO: If you have NuGet Package Restore enabled, uncomment the next line -packages/ +# packages/ dlls/ +dllssigned/ # Windows Azure Build Output csx diff --git a/MediaBrowser.Api/ConnectService.cs b/MediaBrowser.Api/ConnectService.cs index 5a2c04ab6..3c3ad16b1 100644 --- a/MediaBrowser.Api/ConnectService.cs +++ b/MediaBrowser.Api/ConnectService.cs @@ -1,13 +1,18 @@ -using MediaBrowser.Controller.Connect; +using MediaBrowser.Common.Extensions; +using MediaBrowser.Controller.Connect; +using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Net; using MediaBrowser.Model.Connect; using ServiceStack; +using System; using System.Collections.Generic; +using System.Linq; using System.Threading.Tasks; namespace MediaBrowser.Api { [Route("/Users/{Id}/Connect/Link", "POST", Summary = "Creates a Connect link for a user")] + [Authenticated(Roles = "Admin")] public class CreateConnectLink : IReturn { [ApiMember(Name = "Id", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")] @@ -18,6 +23,7 @@ namespace MediaBrowser.Api } [Route("/Users/{Id}/Connect/Link", "DELETE", Summary = "Removes a Connect link for a user")] + [Authenticated(Roles = "Admin")] public class DeleteConnectLink : IReturnVoid { [ApiMember(Name = "Id", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "DELETE")] @@ -25,6 +31,7 @@ namespace MediaBrowser.Api } [Route("/Connect/Invite", "POST", Summary = "Creates a Connect link for a user")] + [Authenticated(Roles = "Admin")] public class CreateConnectInvite : IReturn { [ApiMember(Name = "ConnectUsername", Description = "Connect username", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")] @@ -36,26 +43,37 @@ namespace MediaBrowser.Api [Route("/Connect/Pending", "GET", Summary = "Creates a Connect link for a user")] + [Authenticated(Roles = "Admin")] public class GetPendingGuests : IReturn> { } [Route("/Connect/Pending", "DELETE", Summary = "Deletes a Connect link for a user")] + [Authenticated(Roles = "Admin")] public class DeleteAuthorization : IReturnVoid { [ApiMember(Name = "Id", Description = "Authorization Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "DELETE")] public string Id { get; set; } } - [Authenticated(Roles = "Admin")] + [Route("/Connect/Exchange", "GET", Summary = "Gets the corresponding local user from a connect user id")] + [Authenticated] + public class GetLocalUser : IReturn + { + [ApiMember(Name = "ConnectUserId", Description = "ConnectUserId", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")] + public string ConnectUserId { get; set; } + } + public class ConnectService : BaseApiService { private readonly IConnectManager _connectManager; + private readonly IUserManager _userManager; - public ConnectService(IConnectManager connectManager) + public ConnectService(IConnectManager connectManager, IUserManager userManager) { _connectManager = connectManager; + _userManager = userManager; } public object Post(CreateConnectLink request) @@ -88,5 +106,22 @@ namespace MediaBrowser.Api Task.WaitAll(task); } + + public object Get(GetLocalUser request) + { + var user = _userManager.Users + .FirstOrDefault(i => string.Equals(i.ConnectUserId, request.ConnectUserId, StringComparison.OrdinalIgnoreCase)); + + if (user == null) + { + throw new ResourceNotFoundException(); + } + + return ToOptimizedResult(new ConnectAuthenticationExchangeResult + { + AccessToken = user.ConnectAccessKey, + LocalUserId = user.Id.ToString("N") + }); + } } } diff --git a/MediaBrowser.Api/MediaBrowser.Api.csproj b/MediaBrowser.Api/MediaBrowser.Api.csproj index df9569e28..38f85b9a3 100644 --- a/MediaBrowser.Api/MediaBrowser.Api.csproj +++ b/MediaBrowser.Api/MediaBrowser.Api.csproj @@ -11,7 +11,6 @@ MediaBrowser.Api 512 ..\ - true 10.0.0 2.0 v4.5 diff --git a/MediaBrowser.Common.Implementations/MediaBrowser.Common.Implementations.csproj b/MediaBrowser.Common.Implementations/MediaBrowser.Common.Implementations.csproj index 81df19924..fcf44c0b0 100644 --- a/MediaBrowser.Common.Implementations/MediaBrowser.Common.Implementations.csproj +++ b/MediaBrowser.Common.Implementations/MediaBrowser.Common.Implementations.csproj @@ -11,7 +11,6 @@ MediaBrowser.Common.Implementations 512 ..\ - true 10.0.0 2.0 v4.5 @@ -120,7 +119,6 @@ - if '$(ConfigurationName)' == 'Release' ( xcopy "$(TargetPath)" "$(SolutionDir)\Nuget\dlls\" /y /d /r /i diff --git a/MediaBrowser.Common/MediaBrowser.Common.csproj b/MediaBrowser.Common/MediaBrowser.Common.csproj index 661073c89..3c5b8b249 100644 --- a/MediaBrowser.Common/MediaBrowser.Common.csproj +++ b/MediaBrowser.Common/MediaBrowser.Common.csproj @@ -11,7 +11,6 @@ MediaBrowser.Common 512 ..\ - true 10.0.0 2.0 v4.5 @@ -116,7 +115,6 @@ - if '$(ConfigurationName)' == 'Release' ( xcopy "$(TargetPath)" "$(SolutionDir)\Nuget\dlls\" /y /d /r /i diff --git a/MediaBrowser.Controller/MediaBrowser.Controller.csproj b/MediaBrowser.Controller/MediaBrowser.Controller.csproj index 7e2892c6e..8b228d9ec 100644 --- a/MediaBrowser.Controller/MediaBrowser.Controller.csproj +++ b/MediaBrowser.Controller/MediaBrowser.Controller.csproj @@ -11,7 +11,6 @@ MediaBrowser.Controller 512 ..\ - true 10.0.0 2.0 v4.5 @@ -369,7 +368,6 @@ xcopy "$(TargetPath)" "$(SolutionDir)\Nuget\dlls\" /y /d /r /i -