mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-08-22 06:13:22 -07:00
mobile user logged in & discord username null
This commit is contained in:
parent
fed035ab54
commit
ecd68ef2f4
4 changed files with 70 additions and 3 deletions
|
@ -107,7 +107,7 @@ namespace Ombi.Notifications.Agents
|
|||
var discordBody = new DiscordWebhookBody
|
||||
{
|
||||
content = model.Message,
|
||||
username = settings.Username,
|
||||
username = settings.Username ?? "Ombi",
|
||||
};
|
||||
|
||||
var fields = new List<DiscordField>();
|
||||
|
|
64
src/Ombi.Tests/Middlewear/ApiKeyMiddlewearTests.cs
Normal file
64
src/Ombi.Tests/Middlewear/ApiKeyMiddlewearTests.cs
Normal file
|
@ -0,0 +1,64 @@
|
|||
using Microsoft.AspNetCore.Http;
|
||||
using Moq;
|
||||
using Moq.AutoMock;
|
||||
using NUnit.Framework;
|
||||
using Ombi.Core.Authentication;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Ombi.Tests.Middlewear
|
||||
{
|
||||
[TestFixture]
|
||||
public class ApiKeyMiddlewearTests
|
||||
{
|
||||
private AutoMocker _mocker;
|
||||
private ApiKeyMiddlewear _subject;
|
||||
private Mock<IServiceProvider> _serviceProviderMock;
|
||||
|
||||
[SetUp]
|
||||
public void Setup()
|
||||
{
|
||||
_mocker = new AutoMocker();
|
||||
_serviceProviderMock = new Mock<IServiceProvider>();
|
||||
_mocker.Use(_serviceProviderMock);
|
||||
_subject = _mocker.CreateInstance<ApiKeyMiddlewear>();
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task NonApiAccess()
|
||||
{
|
||||
var context = GetContext();
|
||||
context.Request.Path = "/notanapi";
|
||||
await _subject.Invoke(context);
|
||||
|
||||
_mocker.Verify<IServiceProvider>(x => x.GetService(It.IsAny<Type>()), Times.Never);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task ValidateUserAccessToken()
|
||||
{
|
||||
var context = GetContext();
|
||||
context.Request.Path = "/api";
|
||||
context.Request.Headers.Add("UserAccessToken", new Microsoft.Extensions.Primitives.StringValues("test"));
|
||||
|
||||
var umMock = new Mock<OmbiUserManager>();
|
||||
_mocker.Setup<IServiceProvider, OmbiUserManager>(x => (OmbiUserManager)x.GetService(typeof(OmbiUserManager)))
|
||||
.Returns(umMock.Object);
|
||||
|
||||
|
||||
await _subject.Invoke(context);
|
||||
|
||||
_mocker.Verify<IServiceProvider>(x => x.GetService(It.IsAny<Type>()), Times.Never);
|
||||
}
|
||||
|
||||
private HttpContext GetContext()
|
||||
{
|
||||
var context = new DefaultHttpContext();
|
||||
context.RequestServices = _serviceProviderMock.Object;
|
||||
return context;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -9,6 +9,7 @@
|
|||
<ItemGroup>
|
||||
<PackageReference Include="Microsoft.AspNetCore.TestHost" Version="6.0.9" />
|
||||
<PackageReference Include="Moq" Version="4.18.2" />
|
||||
<PackageReference Include="Moq.AutoMock" Version="3.4.0" />
|
||||
<PackageReference Include="Nunit" Version="3.13.3" />
|
||||
<PackageReference Include="Hangfire" Version="1.7.31" />
|
||||
<PackageReference Include="NUnit.ConsoleRunner" Version="3.15.2" />
|
||||
|
|
|
@ -57,7 +57,7 @@ namespace Ombi
|
|||
}
|
||||
}
|
||||
|
||||
private async Task ValidateUserAccessToken(HttpContext context, RequestDelegate next, string key)
|
||||
private static async Task ValidateUserAccessToken(HttpContext context, RequestDelegate next, string key)
|
||||
{
|
||||
if (string.IsNullOrEmpty(key))
|
||||
{
|
||||
|
@ -74,11 +74,13 @@ namespace Ombi
|
|||
}
|
||||
else
|
||||
{
|
||||
|
||||
var identity = new GenericIdentity(user.UserName);
|
||||
var roles = await um.GetRolesAsync(user);
|
||||
var principal = new GenericPrincipal(identity, roles.ToArray());
|
||||
context.User = principal;
|
||||
user.LastLoggedIn = DateTime.UtcNow;
|
||||
await um.UpdateAsync(user);
|
||||
|
||||
await next.Invoke(context);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue