mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-07-15 01:32:55 -07:00
parent
cbfe88cd6d
commit
915459a141
8 changed files with 388 additions and 63 deletions
|
@ -28,6 +28,7 @@ using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
using FluentValidation;
|
using FluentValidation;
|
||||||
|
|
||||||
|
@ -44,6 +45,7 @@ using NUnit.Framework;
|
||||||
|
|
||||||
using PlexRequests.Core;
|
using PlexRequests.Core;
|
||||||
using PlexRequests.Core.SettingModels;
|
using PlexRequests.Core.SettingModels;
|
||||||
|
using PlexRequests.Helpers;
|
||||||
using PlexRequests.Store;
|
using PlexRequests.Store;
|
||||||
using PlexRequests.Store.Repository;
|
using PlexRequests.Store.Repository;
|
||||||
using PlexRequests.UI.Models;
|
using PlexRequests.UI.Models;
|
||||||
|
@ -68,6 +70,7 @@ namespace PlexRequests.UI.Tests
|
||||||
var settingsMock = new Mock<ISettingsService<PlexRequestSettings>>();
|
var settingsMock = new Mock<ISettingsService<PlexRequestSettings>>();
|
||||||
var userRepoMock = new Mock<IRepository<UsersModel>>();
|
var userRepoMock = new Mock<IRepository<UsersModel>>();
|
||||||
var mapperMock = new Mock<ICustomUserMapper>();
|
var mapperMock = new Mock<ICustomUserMapper>();
|
||||||
|
var authSettingsMock = new Mock<ISettingsService<AuthenticationSettings>>();
|
||||||
|
|
||||||
var userModels = fixture.CreateMany<UsersModel>().ToList();
|
var userModels = fixture.CreateMany<UsersModel>().ToList();
|
||||||
userModels.Add(new UsersModel
|
userModels.Add(new UsersModel
|
||||||
|
@ -87,13 +90,21 @@ namespace PlexRequests.UI.Tests
|
||||||
mapperMock.Setup(x => x.ValidateUser("user1", It.IsAny<string>())).Returns(Guid.NewGuid());
|
mapperMock.Setup(x => x.ValidateUser("user1", It.IsAny<string>())).Returns(Guid.NewGuid());
|
||||||
mapperMock.Setup(x => x.UpdatePassword("user1", "password", "newpassword")).Returns(true);
|
mapperMock.Setup(x => x.UpdatePassword("user1", "password", "newpassword")).Returns(true);
|
||||||
|
|
||||||
|
authSettingsMock.Setup(x => x.SaveSettings(It.Is<AuthenticationSettings>(c => c.PlexAuthToken.Equals("abc")))).Returns(true);
|
||||||
|
|
||||||
Bootstrapper = new ConfigurableBootstrapper(with =>
|
Bootstrapper = new ConfigurableBootstrapper(with =>
|
||||||
{
|
{
|
||||||
with.Module<ApiModule>();
|
with.Module<ApiRequestModule>();
|
||||||
|
with.Module<ApiUserModule>();
|
||||||
|
with.Module<ApiSettingsModule>();
|
||||||
|
|
||||||
with.Dependency(requestMock.Object);
|
with.Dependency(requestMock.Object);
|
||||||
with.Dependency(settingsMock.Object);
|
with.Dependency(settingsMock.Object);
|
||||||
with.Dependency(userRepoMock.Object);
|
with.Dependency(userRepoMock.Object);
|
||||||
with.Dependency(mapperMock.Object);
|
with.Dependency(mapperMock.Object);
|
||||||
|
with.Dependency(authSettingsMock.Object);
|
||||||
|
|
||||||
|
|
||||||
with.RootPathProvider<TestRootPathProvider>();
|
with.RootPathProvider<TestRootPathProvider>();
|
||||||
with.ModelValidatorLocator(
|
with.ModelValidatorLocator(
|
||||||
new DefaultValidatorLocator(
|
new DefaultValidatorLocator(
|
||||||
|
@ -364,5 +375,64 @@ namespace PlexRequests.UI.Tests
|
||||||
Assert.That(body.Error, Is.True);
|
Assert.That(body.Error, Is.True);
|
||||||
Assert.That(body.ErrorMessage, Is.Not.Null.Or.Empty);
|
Assert.That(body.ErrorMessage, Is.Not.Null.Or.Empty);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void SaveNewAuthSettings()
|
||||||
|
{
|
||||||
|
var model = new AuthenticationSettings
|
||||||
|
{
|
||||||
|
Id = 1,
|
||||||
|
PlexAuthToken = "abc",
|
||||||
|
DeniedUsers = "abc",
|
||||||
|
UsePassword = false,
|
||||||
|
UserAuthentication = true
|
||||||
|
};
|
||||||
|
var browser = new Browser(Bootstrapper);
|
||||||
|
var result = browser.Post("api/settings/authentication", with =>
|
||||||
|
{
|
||||||
|
with.HttpRequest();
|
||||||
|
with.Header("Accept", "application/json");
|
||||||
|
with.Query("apikey", "api");
|
||||||
|
with.JsonBody(model);
|
||||||
|
});
|
||||||
|
|
||||||
|
Assert.That(HttpStatusCode.OK, Is.EqualTo(result.StatusCode));
|
||||||
|
|
||||||
|
var body = JsonConvert.DeserializeObject<ApiModel<string>>(result.Body.AsString());
|
||||||
|
Assert.That(body.Data, Is.Not.Null.Or.Empty);
|
||||||
|
Assert.That(body.Error, Is.False);
|
||||||
|
Assert.That(body.ErrorMessage, Is.Null.Or.Empty);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestCaseSource(nameof(AuthSettingsData))]
|
||||||
|
public object SaveNewAuthSettings(object model)
|
||||||
|
{
|
||||||
|
|
||||||
|
var browser = new Browser(Bootstrapper);
|
||||||
|
var result = browser.Post("api/settings/authentication", with =>
|
||||||
|
{
|
||||||
|
with.HttpRequest();
|
||||||
|
with.Header("Accept", "application/json");
|
||||||
|
with.Query("apikey", "api");
|
||||||
|
with.JsonBody(model);
|
||||||
|
});
|
||||||
|
|
||||||
|
Assert.That(HttpStatusCode.OK, Is.EqualTo(result.StatusCode));
|
||||||
|
var body = JsonConvert.DeserializeObject<ApiModel<bool>>(result.Body.AsString());
|
||||||
|
|
||||||
|
var retVal = new List<string> { body.ErrorMessage, body.Error.ToString(), body.Data.ToString() };
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static IEnumerable<TestCaseData> AuthSettingsData
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
yield return
|
||||||
|
new TestCaseData(new AuthenticationSettings { Id = 1, PlexAuthToken = "abc", DeniedUsers = "abc", UsePassword = false, UserAuthentication = true })
|
||||||
|
.Returns(new List<string> { null, false.ToString(), true.ToString() });
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
#region Copyright
|
#region Copyright
|
||||||
// /************************************************************************
|
// /************************************************************************
|
||||||
// Copyright (c) 2016 Jamie Rees
|
// Copyright (c) 2016 Jamie Rees
|
||||||
// File: ApiMetadataModule.cs
|
// File: ApiRequestMetadataModule.cs
|
||||||
// Created By: Jamie Rees
|
// Created By: Jamie Rees
|
||||||
//
|
//
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
@ -34,9 +34,9 @@ using PlexRequests.UI.Models;
|
||||||
|
|
||||||
namespace PlexRequests.UI.Modules
|
namespace PlexRequests.UI.Modules
|
||||||
{
|
{
|
||||||
public class ApiMetadataModule: MetadataModule<SwaggerRouteData>
|
public class ApiRequestMetadataModule: MetadataModule<SwaggerRouteData>
|
||||||
{
|
{
|
||||||
public ApiMetadataModule()
|
public ApiRequestMetadataModule()
|
||||||
{
|
{
|
||||||
Describe["GetRequests"] = description => description.AsSwagger(with =>
|
Describe["GetRequests"] = description => description.AsSwagger(with =>
|
||||||
{
|
{
|
|
@ -1,7 +1,7 @@
|
||||||
#region Copyright
|
#region Copyright
|
||||||
// /************************************************************************
|
// /************************************************************************
|
||||||
// Copyright (c) 2016 Jamie Rees
|
// Copyright (c) 2016 Jamie Rees
|
||||||
// File: ApiModule.cs
|
// File: ApiRequestModule.cs
|
||||||
// Created By: Jamie Rees
|
// Created By: Jamie Rees
|
||||||
//
|
//
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
@ -37,9 +37,9 @@ using PlexRequests.UI.Models;
|
||||||
|
|
||||||
namespace PlexRequests.UI.Modules
|
namespace PlexRequests.UI.Modules
|
||||||
{
|
{
|
||||||
public class ApiModule : BaseApiModule
|
public class ApiRequestModule : BaseApiModule
|
||||||
{
|
{
|
||||||
public ApiModule(IRequestService service, ISettingsService<PlexRequestSettings> pr, ICustomUserMapper m) : base("api", pr)
|
public ApiRequestModule(IRequestService service, ISettingsService<PlexRequestSettings> pr) : base("api", pr)
|
||||||
{
|
{
|
||||||
Get["GetRequests","/requests"] = x => GetRequests();
|
Get["GetRequests","/requests"] = x => GetRequests();
|
||||||
Get["GetRequest","/requests/{id}"] = x => GetSingleRequests(x);
|
Get["GetRequest","/requests/{id}"] = x => GetSingleRequests(x);
|
||||||
|
@ -47,18 +47,13 @@ namespace PlexRequests.UI.Modules
|
||||||
Put["PutRequests", "/requests"] = x => UpdateRequest();
|
Put["PutRequests", "/requests"] = x => UpdateRequest();
|
||||||
Delete["DeleteRequests", "/requests/{id}"] = x => DeleteRequest(x);
|
Delete["DeleteRequests", "/requests/{id}"] = x => DeleteRequest(x);
|
||||||
|
|
||||||
Get["GetApiKey", "/apikey"] = x => GetApiKey();
|
|
||||||
|
|
||||||
Put["PutCredentials", "/credentials/{username}"] = x => ChangePassword(x);
|
|
||||||
|
|
||||||
RequestService = service;
|
RequestService = service;
|
||||||
SettingsService = pr;
|
SettingsService = pr;
|
||||||
UserMapper = m;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private IRequestService RequestService { get; }
|
private IRequestService RequestService { get; }
|
||||||
private ISettingsService<PlexRequestSettings> SettingsService { get; }
|
private ISettingsService<PlexRequestSettings> SettingsService { get; }
|
||||||
private ICustomUserMapper UserMapper { get; }
|
|
||||||
|
|
||||||
public Response GetRequests()
|
public Response GetRequests()
|
||||||
{
|
{
|
||||||
|
@ -164,54 +159,6 @@ namespace PlexRequests.UI.Modules
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Response GetApiKey()
|
|
||||||
{
|
|
||||||
var user = Request.Query["username"];
|
|
||||||
var password = Request.Query["password"];
|
|
||||||
var result = UserMapper.ValidateUser(user, password);
|
|
||||||
var model = new ApiModel<string>();
|
|
||||||
if (result == null)
|
|
||||||
{
|
|
||||||
model.Error = true;
|
|
||||||
model.ErrorMessage = "Incorrect username or password";
|
|
||||||
return ReturnReponse(model);
|
|
||||||
}
|
|
||||||
|
|
||||||
var settings = SettingsService.GetSettings();
|
|
||||||
model.Data = settings.ApiKey;
|
|
||||||
|
|
||||||
return ReturnReponse(model);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Response ChangePassword(dynamic x)
|
|
||||||
{
|
|
||||||
var username = (string)x.username;
|
|
||||||
var userModel = this.BindAndValidate<UserUpdateViewModel>();
|
|
||||||
|
|
||||||
if (!ModelValidationResult.IsValid)
|
|
||||||
{
|
|
||||||
return ReturnValidationReponse(ModelValidationResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
var valid = UserMapper.ValidateUser(username, userModel.CurrentPassword);
|
|
||||||
if (valid == null)
|
|
||||||
{
|
|
||||||
var errorModel = new ApiModel<string> { Error = true, ErrorMessage = "Incorrect username or password" };
|
|
||||||
return ReturnReponse(errorModel);
|
|
||||||
}
|
|
||||||
var result = UserMapper.UpdatePassword(username, userModel.CurrentPassword, userModel.NewPassword);
|
|
||||||
|
|
||||||
if (!result)
|
|
||||||
{
|
|
||||||
var errorModel = new ApiModel<string> { Error = true, ErrorMessage = "Could not update the password. " };
|
|
||||||
return ReturnReponse(errorModel);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var model = new ApiModel<string> { Data = "Successfully updated the password"};
|
|
||||||
return ReturnReponse(model);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
60
PlexRequests.UI/Modules/ApiSettingsMetadataModule.cs
Normal file
60
PlexRequests.UI/Modules/ApiSettingsMetadataModule.cs
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
#region Copyright
|
||||||
|
// /************************************************************************
|
||||||
|
// Copyright (c) 2016 Jamie Rees
|
||||||
|
// File: ApiSettingsMetadataModule.cs
|
||||||
|
// Created By: Jamie Rees
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
// ************************************************************************/
|
||||||
|
#endregion
|
||||||
|
using Nancy.Metadata.Modules;
|
||||||
|
using Nancy.Swagger;
|
||||||
|
|
||||||
|
using PlexRequests.Core.SettingModels;
|
||||||
|
|
||||||
|
namespace PlexRequests.UI.Modules
|
||||||
|
{
|
||||||
|
public class ApiSettingsMetadataModule: MetadataModule<SwaggerRouteData>
|
||||||
|
{
|
||||||
|
public ApiSettingsMetadataModule()
|
||||||
|
{
|
||||||
|
Describe["GetAuthSettings"] = description => description.AsSwagger(with =>
|
||||||
|
{
|
||||||
|
with.ResourcePath("/settings/authentication");
|
||||||
|
with.Summary("Gets the authentication settings saved in the application");
|
||||||
|
with.Model<ApiModel<AuthenticationSettings>>();
|
||||||
|
with.Notes("Gets the authentication settings saved in the application");
|
||||||
|
|
||||||
|
with.QueryParam<string>("apikey", "The Api Key found in the settings", true);
|
||||||
|
});
|
||||||
|
|
||||||
|
Describe["PostAuthSettings"] = description => description.AsSwagger(with =>
|
||||||
|
{
|
||||||
|
with.ResourcePath("/settings/authentication");
|
||||||
|
with.Summary("Saves the authentication settings saved in the application");
|
||||||
|
with.Model<ApiModel<bool>>();
|
||||||
|
with.QueryParam<string>("apikey", "The Api Key found in the settings", true);
|
||||||
|
with.BodyParam<AuthenticationSettings>("Authentication settings", true);
|
||||||
|
with.Notes("Saves the authentication settings saved in the application");
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
79
PlexRequests.UI/Modules/ApiSettingsModule.cs
Normal file
79
PlexRequests.UI/Modules/ApiSettingsModule.cs
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
#region Copyright
|
||||||
|
// /************************************************************************
|
||||||
|
// Copyright (c) 2016 Jamie Rees
|
||||||
|
// File: ApiModule.cs
|
||||||
|
// Created By: Jamie Rees
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
// ************************************************************************/
|
||||||
|
#endregion
|
||||||
|
using Nancy;
|
||||||
|
using Nancy.ModelBinding;
|
||||||
|
|
||||||
|
using PlexRequests.Core;
|
||||||
|
using PlexRequests.Core.SettingModels;
|
||||||
|
|
||||||
|
namespace PlexRequests.UI.Modules
|
||||||
|
{
|
||||||
|
public class ApiSettingsModule : BaseApiModule
|
||||||
|
{
|
||||||
|
public ApiSettingsModule(ISettingsService<PlexRequestSettings> pr, ISettingsService<AuthenticationSettings> auth) : base("api", pr)
|
||||||
|
{
|
||||||
|
Get["GetAuthSettings","/settings/authentication"] = x => GetAuthSettings();
|
||||||
|
Post["PostAuthSettings","/settings/authentication"] = x => PostAuthSettings();
|
||||||
|
|
||||||
|
SettingsService = pr;
|
||||||
|
AuthSettings = auth;
|
||||||
|
}
|
||||||
|
|
||||||
|
private ISettingsService<PlexRequestSettings> SettingsService { get; }
|
||||||
|
private ISettingsService<AuthenticationSettings> AuthSettings { get; }
|
||||||
|
|
||||||
|
public Response GetAuthSettings()
|
||||||
|
{
|
||||||
|
var model = new ApiModel<AuthenticationSettings>();
|
||||||
|
var settings = AuthSettings.GetSettings();
|
||||||
|
model.Data = settings;
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Response PostAuthSettings()
|
||||||
|
{
|
||||||
|
var newSettings = this.BindAndValidate<AuthenticationSettings>();
|
||||||
|
if (!ModelValidationResult.IsValid)
|
||||||
|
{
|
||||||
|
return ReturnValidationReponse(ModelValidationResult);
|
||||||
|
}
|
||||||
|
|
||||||
|
var model = new ApiModel<bool>();
|
||||||
|
var settings = AuthSettings.SaveSettings(newSettings);
|
||||||
|
if (settings)
|
||||||
|
{
|
||||||
|
model.Data = true;
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
model.Error = true;
|
||||||
|
model.ErrorMessage = "Could not update the settings";
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
61
PlexRequests.UI/Modules/ApiUserMetadataModule.cs
Normal file
61
PlexRequests.UI/Modules/ApiUserMetadataModule.cs
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
#region Copyright
|
||||||
|
// /************************************************************************
|
||||||
|
// Copyright (c) 2016 Jamie Rees
|
||||||
|
// File: ApiUserMetadataModule.cs
|
||||||
|
// Created By: Jamie Rees
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
// ************************************************************************/
|
||||||
|
#endregion
|
||||||
|
using Nancy.Metadata.Modules;
|
||||||
|
using Nancy.Swagger;
|
||||||
|
|
||||||
|
using PlexRequests.UI.Models;
|
||||||
|
|
||||||
|
namespace PlexRequests.UI.Modules
|
||||||
|
{
|
||||||
|
public class ApiUserMetadataModule: MetadataModule<SwaggerRouteData>
|
||||||
|
{
|
||||||
|
public ApiUserMetadataModule()
|
||||||
|
{
|
||||||
|
Describe["GetApiKey"] = description => description.AsSwagger(with =>
|
||||||
|
{
|
||||||
|
with.ResourcePath("/apikey");
|
||||||
|
with.Summary("Gets the Api Key for Plex Requests");
|
||||||
|
with.Model<ApiModel<string>>();
|
||||||
|
with.QueryParam<string>("username", required:true );
|
||||||
|
with.QueryParam<string>("password", required: true );
|
||||||
|
with.Notes("Get's the current api key for the application");
|
||||||
|
});
|
||||||
|
|
||||||
|
Describe["PutCredentials"] = description => description.AsSwagger(with =>
|
||||||
|
{
|
||||||
|
with.ResourcePath("/credentials/{username}");
|
||||||
|
with.Summary("Sets a new password for the user");
|
||||||
|
with.Model<ApiModel<string>>();
|
||||||
|
with.PathParam<int>("username", required:true);
|
||||||
|
with.QueryParam<string>("apikey", "The Api Key found in the settings", true);
|
||||||
|
with.BodyParam<UserUpdateViewModel>("User update view model", true);
|
||||||
|
with.Notes("Sets a new password for the user");
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
104
PlexRequests.UI/Modules/ApiUserModule.cs
Normal file
104
PlexRequests.UI/Modules/ApiUserModule.cs
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
#region Copyright
|
||||||
|
// /************************************************************************
|
||||||
|
// Copyright (c) 2016 Jamie Rees
|
||||||
|
// File: ApiModule.cs
|
||||||
|
// Created By: Jamie Rees
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
// ************************************************************************/
|
||||||
|
#endregion
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
using Nancy;
|
||||||
|
using Nancy.ModelBinding;
|
||||||
|
|
||||||
|
using PlexRequests.Core;
|
||||||
|
using PlexRequests.Core.SettingModels;
|
||||||
|
using PlexRequests.Store;
|
||||||
|
using PlexRequests.UI.Models;
|
||||||
|
|
||||||
|
namespace PlexRequests.UI.Modules
|
||||||
|
{
|
||||||
|
public class ApiUserModule : BaseApiModule
|
||||||
|
{
|
||||||
|
public ApiUserModule(ISettingsService<PlexRequestSettings> pr, ICustomUserMapper m) : base("api", pr)
|
||||||
|
{
|
||||||
|
|
||||||
|
Put["PutCredentials", "/credentials/{username}"] = x => ChangePassword(x);
|
||||||
|
|
||||||
|
Get["GetApiKey", "/apikey"] = x => GetApiKey();
|
||||||
|
|
||||||
|
SettingsService = pr;
|
||||||
|
UserMapper = m;
|
||||||
|
}
|
||||||
|
|
||||||
|
private ISettingsService<PlexRequestSettings> SettingsService { get; }
|
||||||
|
private ICustomUserMapper UserMapper { get; }
|
||||||
|
|
||||||
|
public Response ChangePassword(dynamic x)
|
||||||
|
{
|
||||||
|
var username = (string)x.username;
|
||||||
|
var userModel = this.BindAndValidate<UserUpdateViewModel>();
|
||||||
|
|
||||||
|
if (!ModelValidationResult.IsValid)
|
||||||
|
{
|
||||||
|
return ReturnValidationReponse(ModelValidationResult);
|
||||||
|
}
|
||||||
|
|
||||||
|
var valid = UserMapper.ValidateUser(username, userModel.CurrentPassword);
|
||||||
|
if (valid == null)
|
||||||
|
{
|
||||||
|
var errorModel = new ApiModel<string> { Error = true, ErrorMessage = "Incorrect username or password" };
|
||||||
|
return ReturnReponse(errorModel);
|
||||||
|
}
|
||||||
|
var result = UserMapper.UpdatePassword(username, userModel.CurrentPassword, userModel.NewPassword);
|
||||||
|
|
||||||
|
if (!result)
|
||||||
|
{
|
||||||
|
var errorModel = new ApiModel<string> { Error = true, ErrorMessage = "Could not update the password. " };
|
||||||
|
return ReturnReponse(errorModel);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var model = new ApiModel<string> { Data = "Successfully updated the password"};
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
public Response GetApiKey()
|
||||||
|
{
|
||||||
|
var user = Request.Query["username"];
|
||||||
|
var password = Request.Query["password"];
|
||||||
|
var result = UserMapper.ValidateUser(user, password);
|
||||||
|
var model = new ApiModel<string>();
|
||||||
|
if (result == null)
|
||||||
|
{
|
||||||
|
model.Error = true;
|
||||||
|
model.ErrorMessage = "Incorrect username or password";
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
var settings = SettingsService.GetSettings();
|
||||||
|
model.Data = settings.ApiKey;
|
||||||
|
|
||||||
|
return ReturnReponse(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -175,7 +175,11 @@
|
||||||
<Compile Include="Models\SearchMovieViewModel.cs" />
|
<Compile Include="Models\SearchMovieViewModel.cs" />
|
||||||
<Compile Include="Models\UserUpdateViewModel.cs" />
|
<Compile Include="Models\UserUpdateViewModel.cs" />
|
||||||
<Compile Include="Modules\ApiDocsModule.cs" />
|
<Compile Include="Modules\ApiDocsModule.cs" />
|
||||||
<Compile Include="Modules\ApiMetadataModule.cs" />
|
<Compile Include="Modules\ApiSettingsMetadataModule.cs" />
|
||||||
|
<Compile Include="Modules\ApiUserMetadataModule.cs" />
|
||||||
|
<Compile Include="Modules\ApiRequestMetadataModule.cs" />
|
||||||
|
<Compile Include="Modules\ApiSettingsModule.cs" />
|
||||||
|
<Compile Include="Modules\ApiUserModule.cs" />
|
||||||
<Compile Include="Modules\BaseApiModule.cs" />
|
<Compile Include="Modules\BaseApiModule.cs" />
|
||||||
<Compile Include="Modules\BaseModule.cs" />
|
<Compile Include="Modules\BaseModule.cs" />
|
||||||
<Compile Include="Modules\UpdateCheckerModule.cs" />
|
<Compile Include="Modules\UpdateCheckerModule.cs" />
|
||||||
|
@ -279,7 +283,7 @@
|
||||||
<Content Include="Views\UserManagement\Index.cshtml">
|
<Content Include="Views\UserManagement\Index.cshtml">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Compile Include="Modules\ApiModule.cs" />
|
<Compile Include="Modules\ApiRequestModule.cs" />
|
||||||
<Compile Include="Models\ApiModel.cs" />
|
<Compile Include="Models\ApiModel.cs" />
|
||||||
<Compile Include="Models\UserManagementUsersViewModel.cs" />
|
<Compile Include="Models\UserManagementUsersViewModel.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue